mirror of
https://github.com/Telecominfraproject/OpenCellular.git
synced 2026-01-09 17:11:42 +00:00
The decision on whether to ramp (and how high) depends on the quirks of charger identification, so move the decision out of board, into the drivers that implement usb_charger. Also, rename CONFIG_CHARGE_RAMP to CONFIG_CHARGE_RAMP_SW, to better contrast with the existing CONFIG_CHARGE_RAMP_HW. BUG=None TEST=Manual on kevin, verify ramp occurs when port plugged into Z840 workstation. BRANCH=None Change-Id: I5b395274133837a18a4f4ac34b59b623287be175 Signed-off-by: Shawn Nematbakhsh <shawnn@chromium.org> Reviewed-on: https://chromium-review.googlesource.com/702681 Commit-Ready: Shawn N <shawnn@chromium.org> Tested-by: Shawn N <shawnn@chromium.org> Reviewed-by: Vincent Palatin <vpalatin@chromium.org>
97 lines
2.3 KiB
C
97 lines
2.3 KiB
C
/* Copyright 2015 The Chromium OS Authors. All rights reserved.
|
|
* Use of this source code is governed by a BSD-style license that can be
|
|
* found in the LICENSE file.
|
|
*/
|
|
|
|
/* Charge input current limit ramp header for Chrome EC */
|
|
|
|
#ifndef __CROS_EC_CHARGE_RAMP_H
|
|
#define __CROS_EC_CHARGE_RAMP_H
|
|
|
|
#include "timer.h"
|
|
|
|
/* Charge ramp state used for checking VBUS */
|
|
enum chg_ramp_vbus_state {
|
|
CHG_RAMP_VBUS_RAMPING,
|
|
CHG_RAMP_VBUS_STABLE
|
|
};
|
|
|
|
/**
|
|
* Check if board is consuming full input current
|
|
*
|
|
* @return Board is consuming full input current
|
|
*/
|
|
int board_is_consuming_full_charge(void);
|
|
|
|
/**
|
|
* Check if VBUS is too low
|
|
*
|
|
* @param port Charge ramp port
|
|
* @param ramp_state Current ramp state
|
|
*
|
|
* @return VBUS is sagging low
|
|
*/
|
|
int board_is_vbus_too_low(int port, enum chg_ramp_vbus_state ramp_state);
|
|
|
|
/**
|
|
* Check if ramping is allowed for given supplier
|
|
*
|
|
* @supplier Supplier to check
|
|
*
|
|
* @return Ramping is allowed for given supplier
|
|
*/
|
|
int chg_ramp_allowed(int supplier);
|
|
|
|
/**
|
|
* Get the maximum current limit that we are allowed to ramp to
|
|
*
|
|
* @supplier Active supplier type
|
|
* @sup_curr Input current limit based on supplier
|
|
*
|
|
* @return Maximum current in mA
|
|
*/
|
|
int chg_ramp_max(int supplier, int sup_curr);
|
|
|
|
/**
|
|
* Get the input current limit set by ramp module
|
|
*
|
|
* Active input current limit (mA)
|
|
*/
|
|
int chg_ramp_get_current_limit(void);
|
|
|
|
/**
|
|
* Return if charge ramping has reached stable state
|
|
*
|
|
* @return 1 if stable, 0 otherwise
|
|
*/
|
|
int chg_ramp_is_stable(void);
|
|
|
|
/**
|
|
* Return if charge ramping has reached detected state
|
|
*
|
|
* @return 1 if detected, 0 otherwise
|
|
*/
|
|
int chg_ramp_is_detected(void);
|
|
|
|
#ifdef HAS_TASK_CHG_RAMP
|
|
/**
|
|
* Notify charge ramp module of supplier type change on a port. If port
|
|
* is CHARGE_PORT_NONE, the call indicates the last charge supplier went
|
|
* away.
|
|
*
|
|
* @port Active charging port
|
|
* @supplier Active charging supplier
|
|
* @current Minimum input current limit
|
|
* @registration_time Timestamp of when the supplier is registered
|
|
* @voltage Negotiated charge voltage.
|
|
*/
|
|
void chg_ramp_charge_supplier_change(int port, int supplier, int current,
|
|
timestamp_t registration_time, int voltage);
|
|
|
|
#else
|
|
static inline void chg_ramp_charge_supplier_change(
|
|
int port, int supplier, timestamp_t registration_time) { }
|
|
#endif
|
|
|
|
#endif /* __CROS_EC_CHARGE_RAMP_H */
|