summaryrefslogtreecommitdiff
diff options
context:
space:
mode:
authorDevin Lu <devin.lu@quantatw.com>2020-04-16 21:04:25 +0800
committerCommit Bot <commit-bot@chromium.org>2020-04-30 07:13:50 +0000
commitdc7284ebb87cfb02ab243435eae92938a776397c (patch)
treea374b89c670a1df166e46fb655cc829107bb6982
parentd76c37b3c16e9ef5b17bc201f7b5da06767451dd (diff)
downloadchrome-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.c29
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);