summaryrefslogtreecommitdiff
diff options
context:
space:
mode:
-rw-r--r--driver/charger/rt9490.h1
-rw-r--r--zephyr/projects/corsola/src/krabby/charger_workaround.c15
2 files changed, 16 insertions, 0 deletions
diff --git a/driver/charger/rt9490.h b/driver/charger/rt9490.h
index ffc7f4089d..2fd0edbac2 100644
--- a/driver/charger/rt9490.h
+++ b/driver/charger/rt9490.h
@@ -235,6 +235,7 @@ struct rt9490_init_setting {
/* ADD CTRL0 */
#define RT9490_AUTO_AICR BIT(5)
+#define RT9490_TD_EOC BIT(4)
#define RT9490_AUTO_MIVR BIT(2)
#define RT9490_JEITA_COLD_HOT BIT(0)
diff --git a/zephyr/projects/corsola/src/krabby/charger_workaround.c b/zephyr/projects/corsola/src/krabby/charger_workaround.c
index 576ea65bc7..373917db56 100644
--- a/zephyr/projects/corsola/src/krabby/charger_workaround.c
+++ b/zephyr/projects/corsola/src/krabby/charger_workaround.c
@@ -72,10 +72,25 @@ static void pwm_freq_workaround(void)
rt9490_enable_pwm_1mhz(CHARGER_SOLO, true);
}
+static void eoc_deglitch_workaround(void)
+{
+ if (system_get_board_version() != 1) {
+ return;
+ }
+
+ /* set end-of-charge deglitch time to 2ms */
+ i2c_update8(chg_chips[CHARGER_SOLO].i2c_port,
+ chg_chips[CHARGER_SOLO].i2c_addr_flags,
+ RT9490_REG_ADD_CTRL0,
+ RT9490_TD_EOC,
+ MASK_CLR);
+}
+
static void board_rt9490_workaround(void)
{
ibus_adc_workaround();
i2c_speed_workaround();
pwm_freq_workaround();
+ eoc_deglitch_workaround();
}
DECLARE_HOOK(HOOK_INIT, board_rt9490_workaround, HOOK_PRIO_DEFAULT);