|
@@ -238,6 +238,15 @@ static int palmas_rtc_probe(struct platform_device *pdev)
|
|
|
struct palmas *palmas = dev_get_drvdata(pdev->dev.parent);
|
|
|
struct palmas_rtc *palmas_rtc = NULL;
|
|
|
int ret;
|
|
|
+ bool enable_bb_charging = false;
|
|
|
+ bool high_bb_charging;
|
|
|
+
|
|
|
+ if (pdev->dev.of_node) {
|
|
|
+ enable_bb_charging = of_property_read_bool(pdev->dev.of_node,
|
|
|
+ "ti,backup-battery-chargeable");
|
|
|
+ high_bb_charging = of_property_read_bool(pdev->dev.of_node,
|
|
|
+ "ti,backup-battery-charge-high-current");
|
|
|
+ }
|
|
|
|
|
|
palmas_rtc = devm_kzalloc(&pdev->dev, sizeof(struct palmas_rtc),
|
|
|
GFP_KERNEL);
|
|
@@ -254,6 +263,32 @@ static int palmas_rtc_probe(struct platform_device *pdev)
|
|
|
palmas_rtc->dev = &pdev->dev;
|
|
|
platform_set_drvdata(pdev, palmas_rtc);
|
|
|
|
|
|
+ if (enable_bb_charging) {
|
|
|
+ unsigned reg = PALMAS_BACKUP_BATTERY_CTRL_BBS_BBC_LOW_ICHRG;
|
|
|
+
|
|
|
+ if (high_bb_charging)
|
|
|
+ reg = 0;
|
|
|
+
|
|
|
+ ret = palmas_update_bits(palmas, PALMAS_PMU_CONTROL_BASE,
|
|
|
+ PALMAS_BACKUP_BATTERY_CTRL,
|
|
|
+ PALMAS_BACKUP_BATTERY_CTRL_BBS_BBC_LOW_ICHRG, reg);
|
|
|
+ if (ret < 0) {
|
|
|
+ dev_err(&pdev->dev,
|
|
|
+ "BACKUP_BATTERY_CTRL update failed, %d\n", ret);
|
|
|
+ return ret;
|
|
|
+ }
|
|
|
+
|
|
|
+ ret = palmas_update_bits(palmas, PALMAS_PMU_CONTROL_BASE,
|
|
|
+ PALMAS_BACKUP_BATTERY_CTRL,
|
|
|
+ PALMAS_BACKUP_BATTERY_CTRL_BB_CHG_EN,
|
|
|
+ PALMAS_BACKUP_BATTERY_CTRL_BB_CHG_EN);
|
|
|
+ if (ret < 0) {
|
|
|
+ dev_err(&pdev->dev,
|
|
|
+ "BACKUP_BATTERY_CTRL update failed, %d\n", ret);
|
|
|
+ return ret;
|
|
|
+ }
|
|
|
+ }
|
|
|
+
|
|
|
/* Start RTC */
|
|
|
ret = palmas_update_bits(palmas, PALMAS_RTC_BASE, PALMAS_RTC_CTRL_REG,
|
|
|
PALMAS_RTC_CTRL_REG_STOP_RTC,
|