summaryrefslogtreecommitdiff
path: root/common/charge_state_v2.c
diff options
context:
space:
mode:
Diffstat (limited to 'common/charge_state_v2.c')
-rw-r--r--common/charge_state_v2.c43
1 files changed, 25 insertions, 18 deletions
diff --git a/common/charge_state_v2.c b/common/charge_state_v2.c
index ef12f0bf15..1a292d866d 100644
--- a/common/charge_state_v2.c
+++ b/common/charge_state_v2.c
@@ -181,6 +181,11 @@ static void problem(enum problem_type p, int v)
problems_exist = 1;
}
+test_export_static enum ec_charge_control_mode get_chg_ctrl_mode(void)
+{
+ return chg_ctl_mode;
+}
+
static int battery_sustainer_set(int8_t lower, int8_t upper)
{
if (lower == -1 || upper == -1) {
@@ -1066,6 +1071,9 @@ static void dump_charge_state(void)
#define DUMP(FLD, FMT) ccprintf(#FLD " = " FMT "\n", curr.FLD)
#define DUMP_CHG(FLD, FMT) ccprintf("\t" #FLD " = " FMT "\n", curr.chg. FLD)
#define DUMP_BATT(FLD, FMT) ccprintf("\t" #FLD " = " FMT "\n", curr.batt. FLD)
+
+ enum ec_charge_control_mode cmode = get_chg_ctrl_mode();
+
ccprintf("state = %s\n", state_list[curr.state]);
DUMP(ac, "%d");
DUMP(batt_is_charging, "%d");
@@ -1099,8 +1107,8 @@ static void dump_charge_state(void)
DUMP(input_voltage, "%dmV");
#endif
ccprintf("chg_ctl_mode = %s (%d)\n",
- chg_ctl_mode < CHARGE_CONTROL_COUNT
- ? mode_text[chg_ctl_mode] : "UNDEF", chg_ctl_mode);
+ cmode < CHARGE_CONTROL_COUNT ? mode_text[cmode] : "UNDEF",
+ cmode);
ccprintf("manual_voltage = %d\n", manual_voltage);
ccprintf("manual_current = %d\n", manual_current);
ccprintf("user_current_limit = %dmA\n", user_current_limit);
@@ -1118,6 +1126,7 @@ static void dump_charge_state(void)
static void show_charging_progress(void)
{
int rv = 0, minutes, to_full;
+ int dsoc;
#ifdef CONFIG_BATTERY_SMART
/*
@@ -1151,19 +1160,17 @@ static void show_charging_progress(void)
}
#endif
+ dsoc = charge_get_display_charge();
if (rv)
CPRINTS("Battery %d%% (Display %d.%d %%) / ??h:?? %s%s",
curr.batt.state_of_charge,
- curr.batt.display_charge / 10,
- curr.batt.display_charge % 10,
+ dsoc / 10, dsoc % 10,
to_full ? "to full" : "to empty",
is_full ? ", not accepting current" : "");
else
CPRINTS("Battery %d%% (Display %d.%d %%) / %dh:%d %s%s",
curr.batt.state_of_charge,
- curr.batt.display_charge / 10,
- curr.batt.display_charge % 10,
- minutes / 60, minutes % 60,
+ dsoc / 10, dsoc % 10, minutes / 60, minutes % 60,
to_full ? "to full" : "to empty",
is_full ? ", not accepting current" : "");
@@ -1513,7 +1520,7 @@ const struct batt_params *charger_current_battery_params(void)
static void sustain_battery_soc(void)
{
- enum ec_charge_control_mode mode = chg_ctl_mode;
+ enum ec_charge_control_mode mode = get_chg_ctrl_mode();
int soc;
int rv;
@@ -1524,7 +1531,7 @@ static void sustain_battery_soc(void)
soc = charge_get_display_charge() / 10;
- switch (chg_ctl_mode) {
+ switch (mode) {
case CHARGE_CONTROL_NORMAL:
/* Going up */
if (sustain_soc.upper < soc)
@@ -1545,7 +1552,7 @@ static void sustain_battery_soc(void)
return;
}
- if (mode == chg_ctl_mode)
+ if (mode == get_chg_ctrl_mode())
return;
rv = set_chg_ctrl_mode(mode);
@@ -1788,7 +1795,7 @@ void charger_task(void *u)
/* Okay, we're on AC and we should have a battery. */
/* Used for factory tests. */
- if (chg_ctl_mode != CHARGE_CONTROL_NORMAL) {
+ if (get_chg_ctrl_mode() != CHARGE_CONTROL_NORMAL) {
set_charge_state(ST_IDLE);
goto wait_for_it;
}
@@ -1880,7 +1887,7 @@ void charger_task(void *u)
wait_for_it:
#ifdef CONFIG_CHARGER_PROFILE_OVERRIDE
- if (chg_ctl_mode == CHARGE_CONTROL_NORMAL) {
+ if (get_chg_ctrl_mode() == CHARGE_CONTROL_NORMAL) {
sleep_usec = charger_profile_override(&curr);
if (sleep_usec < 0)
problem(PR_CUSTOM, sleep_usec);
@@ -1928,7 +1935,7 @@ wait_for_it:
#endif
(is_full != prev_full) ||
(curr.state != prev_state) ||
- (curr.batt.display_charge != prev_disp_charge)) {
+ (charge_get_display_charge() != prev_disp_charge)) {
sustain_battery_soc();
show_charging_progress();
prev_charge = curr.batt.state_of_charge;
@@ -2217,7 +2224,7 @@ uint32_t charge_get_flags(void)
{
uint32_t flags = 0;
- if (chg_ctl_mode != CHARGE_CONTROL_NORMAL)
+ if (get_chg_ctrl_mode() != CHARGE_CONTROL_NORMAL)
flags |= CHARGE_FLAG_FORCE_IDLE;
if (curr.ac)
flags |= CHARGE_FLAG_EXTERNAL_POWER;
@@ -2238,7 +2245,7 @@ int charge_get_percent(void)
return is_full ? 100 : curr.batt.state_of_charge;
}
-int charge_get_display_charge(void)
+test_mockable int charge_get_display_charge(void)
{
return curr.batt.display_charge;
}
@@ -2345,7 +2352,7 @@ static int charge_command_charge_control(struct host_cmd_handler_args *args)
if (args->version >= 2) {
if (p->cmd == EC_CHARGE_CONTROL_CMD_SET) {
- if (chg_ctl_mode == CHARGE_CONTROL_NORMAL) {
+ if (get_chg_ctrl_mode() == CHARGE_CONTROL_NORMAL) {
rv = battery_sustainer_set(
p->sustain_soc.lower,
p->sustain_soc.upper);
@@ -2357,7 +2364,7 @@ static int charge_command_charge_control(struct host_cmd_handler_args *args)
battery_sustainer_disable();
}
} else if (p->cmd == EC_CHARGE_CONTROL_CMD_GET) {
- r->mode = chg_ctl_mode;
+ r->mode = get_chg_ctrl_mode();
r->sustain_soc.lower = sustain_soc.lower;
r->sustain_soc.upper = sustain_soc.upper;
args->response_size = sizeof(*r);
@@ -2667,7 +2674,7 @@ int charge_get_charge_state_debug(int param, uint32_t *value)
{
switch (param) {
case CS_PARAM_DEBUG_CTL_MODE:
- *value = chg_ctl_mode;
+ *value = get_chg_ctrl_mode();
break;
case CS_PARAM_DEBUG_MANUAL_CURRENT:
*value = manual_current;