diff options
author | Devin Lu <devin.lu@quantatw.com> | 2020-04-16 21:04:25 +0800 |
---|---|---|
committer | Commit Bot <commit-bot@chromium.org> | 2020-04-30 07:13:50 +0000 |
commit | dc7284ebb87cfb02ab243435eae92938a776397c (patch) | |
tree | a374b89c670a1df166e46fb655cc829107bb6982 | |
parent | d76c37b3c16e9ef5b17bc201f7b5da06767451dd (diff) | |
download | chrome-ec-dc7284ebb87cfb02ab243435eae92938a776397c.tar.gz |
jinlon: Reduce input voltage to 5V when battery full
Apply CL:2104813 for Jinlon.
To reduce power consumption, reduce USB-C PD input voltage to 5V
when the battery is full and the system is off (S5/G3).
BUG=b:149890873
BRANCH=firmware-hatch-12672.B
TEST=battery 90%: chgsup shows 15V or 20V,
when battery full: chgsup shows 5V,
power on AP: chgsup shows 15V or 20V
Change-Id: Ia17bdcfc1da6e6909f5da7cdedfa37008440f1d2
Signed-off-by: Devin Lu <Devin.Lu@quantatw.com>
Reviewed-on: https://chromium-review.googlesource.com/c/chromiumos/platform/ec/+/2152035
Reviewed-by: Tim Wawrzynczak <twawrzynczak@chromium.org>
-rw-r--r-- | board/jinlon/battery.c | 29 |
1 files changed, 28 insertions, 1 deletions
diff --git a/board/jinlon/battery.c b/board/jinlon/battery.c index 24b331639e..cf3941221c 100644 --- a/board/jinlon/battery.c +++ b/board/jinlon/battery.c @@ -6,8 +6,11 @@ */ #include "battery_fuel_gauge.h" +#include "charge_state.h" +#include "chipset.h" #include "common.h" -#include "util.h" +#include "hooks.h" +#include "usb_pd.h" /* * Battery info for all Jinlon battery types. Note that the fields @@ -64,3 +67,27 @@ const struct board_batt_params board_battery_info[] = { BUILD_ASSERT(ARRAY_SIZE(board_battery_info) == BATTERY_TYPE_COUNT); const enum battery_type DEFAULT_BATTERY_TYPE = BATTERY_DANAPACK_COS; + +/* Lower our input voltage to 5V in S5/G3 when battery is full. */ +static void reduce_input_voltage_when_full(void) +{ + int max_pd_voltage_mv; + int port; + + if (charge_get_percent() == 100 && + chipset_in_or_transitioning_to_state(CHIPSET_STATE_ANY_OFF)) + max_pd_voltage_mv = 5000; + else + max_pd_voltage_mv = PD_MAX_VOLTAGE_MV; + + if (pd_get_max_voltage() != max_pd_voltage_mv) { + for (port = 0; port < CONFIG_USB_PD_PORT_MAX_COUNT; port++) + pd_set_external_voltage_limit(port, max_pd_voltage_mv); + } +} +DECLARE_HOOK(HOOK_BATTERY_SOC_CHANGE, reduce_input_voltage_when_full, + HOOK_PRIO_DEFAULT); +DECLARE_HOOK(HOOK_CHIPSET_STARTUP, reduce_input_voltage_when_full, + HOOK_PRIO_DEFAULT); +DECLARE_HOOK(HOOK_CHIPSET_SHUTDOWN, reduce_input_voltage_when_full, + HOOK_PRIO_DEFAULT); |