diff options
Diffstat (limited to 'common/charge_state_v2.c')
-rw-r--r-- | common/charge_state_v2.c | 43 |
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; |