diff options
Diffstat (limited to 'board/cherry')
-rw-r--r-- | board/cherry/battery.c | 81 | ||||
-rw-r--r-- | board/cherry/board.h | 2 |
2 files changed, 70 insertions, 13 deletions
diff --git a/board/cherry/battery.c b/board/cherry/battery.c index f76af4d99b..00404ce63c 100644 --- a/board/cherry/battery.c +++ b/board/cherry/battery.c @@ -14,9 +14,66 @@ #include "usb_pd.h" const struct board_batt_params board_battery_info[] = { + /* Panasonic AP16L5J Battery Information */ + [BATTERY_PANASONIC_AC16L5J] = { + .fuel_gauge = { + .manuf_name = "PANASONIC", + .device_name = "AP16L5J", + .ship_mode = { + .reg_addr = 0x3A, + .reg_data = { 0xC574, 0xC574 }, + }, + .fet = { + .reg_addr = 0x0, + .reg_mask = 0x4000, + .disconnect_val = 0x0, + } + }, + .batt_info = { + .voltage_max = 8800, + .voltage_normal = 7700, + .voltage_min = 6000, + .precharge_current = 256, + .start_charging_min_c = 0, + .start_charging_max_c = 50, + .charging_min_c = 0, + .charging_max_c = 60, + .discharging_min_c = -20, + .discharging_max_c = 75, + }, + }, + [BATTERY_PANASONIC_AC16L5J_KT00205009] = { + .fuel_gauge = { + .manuf_name = "PANASONIC KT00205009", + .device_name = "AP16L5J", + .ship_mode = { + .reg_addr = 0x3A, + .reg_data = { 0xC574, 0xC574 }, + }, + .fet = { + .reg_addr = 0x0, + .reg_mask = 0x4000, + .disconnect_val = 0x0, + } + }, + .batt_info = { + .voltage_max = 8800, + .voltage_normal = 7700, + .voltage_min = 6000, + .precharge_current = 256, + .start_charging_min_c = 0, + .start_charging_max_c = 50, + .charging_min_c = 0, + .charging_max_c = 60, + .discharging_min_c = -20, + .discharging_max_c = 75, + }, + }, + /* LGC AP18C8K Battery Information */ [BATTERY_LGC_AP18C8K] = { .fuel_gauge = { .manuf_name = "LGC KT0030G020", + .device_name = "AP18C8K", .ship_mode = { .reg_addr = 0x3A, .reg_data = { 0xC574, 0xC574 }, @@ -25,24 +82,22 @@ const struct board_batt_params board_battery_info[] = { .reg_addr = 0x43, .reg_mask = 0x0001, .disconnect_val = 0x0, - .cfet_mask = 0x0002, - .cfet_off_val = 0x0000, }, }, .batt_info = { - .voltage_max = 13050, - .voltage_normal = 11250, - .voltage_min = 9000, - .precharge_current = 256, - .start_charging_min_c = 0, - .start_charging_max_c = 50, - .charging_min_c = 0, - .charging_max_c = 60, - .discharging_min_c = -20, - .discharging_max_c = 75, + .voltage_max = 13050, + .voltage_normal = 11250, + .voltage_min = 9000, + .precharge_current = 256, + .start_charging_min_c = 0, + .start_charging_max_c = 50, + .charging_min_c = 0, + .charging_max_c = 60, + .discharging_min_c = -20, + .discharging_max_c = 75, }, }, }; BUILD_ASSERT(ARRAY_SIZE(board_battery_info) == BATTERY_TYPE_COUNT); -const enum battery_type DEFAULT_BATTERY_TYPE = BATTERY_LGC_AP18C8K; +const enum battery_type DEFAULT_BATTERY_TYPE = BATTERY_PANASONIC_AC16L5J; diff --git a/board/cherry/board.h b/board/cherry/board.h index 866fd4c823..32f2cefb48 100644 --- a/board/cherry/board.h +++ b/board/cherry/board.h @@ -77,6 +77,8 @@ #include "registers.h" enum battery_type { + BATTERY_PANASONIC_AC16L5J, + BATTERY_PANASONIC_AC16L5J_KT00205009, BATTERY_LGC_AP18C8K, BATTERY_TYPE_COUNT, }; |