summaryrefslogtreecommitdiff
path: root/common
diff options
context:
space:
mode:
authorShawn Nematbakhsh <shawnn@chromium.org>2016-10-17 14:12:38 -0700
committerchrome-bot <chrome-bot@chromium.org>2016-12-05 16:42:58 -0800
commit64414f92b30d3d75d0ba29fd8b32f772a16acdff (patch)
treed48e47fd8ad8476139beba9af39204200ca175bd /common
parentd447b71f7132111beb8f973337ec6cabf15fe384 (diff)
downloadchrome-ec-64414f92b30d3d75d0ba29fd8b32f772a16acdff.tar.gz
pd: Limit input current to 500mA on PD voltage transition
Upon requesting a PD power contract at a new voltage, keep the input current limit at 500mA until PD_RDY is received. BUG=b:30744563,chrome-os-partner:59311,chrome-os-partner:44340 BRANCH=ryu, gru, glados TEST=Manual on kevin, set ilim to 5V through `chglim` console command, attach zinger. Set ilim to 20V through `chglim`, verify that ilim goes from 3A to 500mA to 3A. Signed-off-by: Shawn Nematbakhsh <shawnn@chromium.org> Change-Id: I452f183cfb958780e336a9f99dc6398356de17a0 Reviewed-on: https://chromium-review.googlesource.com/399918 Commit-Ready: Shawn N <shawnn@chromium.org> Tested-by: Shawn N <shawnn@chromium.org> Reviewed-by: Todd Broch <tbroch@chromium.org> Reviewed-by: Vincent Palatin <vpalatin@chromium.org>
Diffstat (limited to 'common')
-rw-r--r--common/charge_manager.c19
-rw-r--r--common/usb_pd_protocol.c13
2 files changed, 29 insertions, 3 deletions
diff --git a/common/charge_manager.c b/common/charge_manager.c
index a4d9d8dea4..cd59c93007 100644
--- a/common/charge_manager.c
+++ b/common/charge_manager.c
@@ -817,6 +817,25 @@ void charge_manager_set_ceil(int port, enum ceil_requestor requestor, int ceil)
}
}
+void charge_manager_force_ceil(int port, int ceil)
+{
+ ASSERT(port >= 0 && port < CONFIG_USB_PD_PORT_COUNT);
+
+ /*
+ * Force our input current to ceil if we're exceeding it, without
+ * waiting for our deferred task to run.
+ */
+ if (port == charge_port && ceil < charge_current)
+ board_set_charge_limit(port, CHARGE_SUPPLIER_PD,
+ ceil, charge_current_uncapped);
+
+ /*
+ * Now inform charge_manager so it stays in sync with the state of
+ * the world.
+ */
+ charge_manager_set_ceil(port, CEIL_REQUESTOR_PD, ceil);
+}
+
/**
* Select an 'override port', a port which is always the preferred charge port.
* Returns EC_SUCCESS on success, ec_error_list status on failure.
diff --git a/common/usb_pd_protocol.c b/common/usb_pd_protocol.c
index 4370835fe1..3ea1dbf723 100644
--- a/common/usb_pd_protocol.c
+++ b/common/usb_pd_protocol.c
@@ -659,9 +659,16 @@ static int pd_send_request_msg(int port, int always_send_request)
*/
return -1;
- /* Don't re-request the same voltage */
- if (!always_send_request && pd[port].prev_request_mv == supply_voltage)
- return EC_SUCCESS;
+ if (!always_send_request) {
+ /* Don't re-request the same voltage */
+ if (pd[port].prev_request_mv == supply_voltage)
+ return EC_SUCCESS;
+#ifdef CONFIG_CHARGE_MANAGER
+ /* Limit current to PD_MIN_MA during transition */
+ else
+ charge_manager_force_ceil(port, PD_MIN_MA);
+#endif
+ }
CPRINTF("Req C%d [%d] %dmV %dmA", port, RDO_POS(rdo),
supply_voltage, curr_limit);