91 lines
2.8 KiB
Diff
91 lines
2.8 KiB
Diff
From 553cc02e3c0006fd568ba21e52d6dbfa86510d58 Mon Sep 17 00:00:00 2001
|
|
From: Ondrej Jirman <megous@megous.com>
|
|
Date: Wed, 23 Sep 2020 14:59:41 +0200
|
|
Subject: [PATCH 270/351] power: supply: axp20x_battery: Setup thermal
|
|
regulation (experimental)
|
|
|
|
Values for NTC resistances were pulled out of thin air!
|
|
|
|
None of this is tested to actually work.
|
|
|
|
Signed-off-by: Ondrej Jirman <megous@megous.com>
|
|
---
|
|
drivers/power/supply/axp20x_battery.c | 54 +++++++++++++++++++++++++++
|
|
1 file changed, 54 insertions(+)
|
|
|
|
diff --git a/drivers/power/supply/axp20x_battery.c b/drivers/power/supply/axp20x_battery.c
|
|
index 99494bd1a714..933afeb9fce7 100644
|
|
--- a/drivers/power/supply/axp20x_battery.c
|
|
+++ b/drivers/power/supply/axp20x_battery.c
|
|
@@ -614,6 +614,7 @@ static int axp20x_power_probe(struct platform_device *pdev)
|
|
struct power_supply_config psy_cfg = {};
|
|
struct device *dev = &pdev->dev;
|
|
struct power_supply_battery_info *info;
|
|
+ int ret;
|
|
|
|
if (!of_device_is_available(pdev->dev.of_node))
|
|
return -ENODEV;
|
|
@@ -701,6 +702,59 @@ static int axp20x_power_probe(struct platform_device *pdev)
|
|
axp20x_get_constant_charge_current(axp20x_batt,
|
|
&axp20x_batt->max_ccc);
|
|
|
|
+ if (of_machine_is_compatible("pine64,pinephone-1.2") > 0 ||
|
|
+ of_machine_is_compatible("pine64,pinephone-1.1") > 0 ||
|
|
+ of_machine_is_compatible("pine64,pinephone-1.0") > 0) {
|
|
+ // 3kOhm NTC inside PinePhone batery
|
|
+ // ---------------------------------
|
|
+ //
|
|
+ // Charging:
|
|
+ // 0 - 15 °C: Max 0.2C CC to 4.35V : 9750 Ohm - 4710 Ohm
|
|
+ // 15 - 50 °C: Max 0.5C CC to 4.35V : 4710 Ohm - 1080 Ohm
|
|
+ //
|
|
+ // Discharging:
|
|
+ // -10 °C : 16500 Ohm
|
|
+ // 55 °C : 896 Ohm
|
|
+ // enable TS pin input to ADC
|
|
+
|
|
+ dev_info(dev, "Configuring battery thermal regulation for Pinephone\n");
|
|
+
|
|
+ ret = regmap_update_bits(axp20x_batt->regmap, 0x82, BIT(0), BIT(0));
|
|
+ if (ret)
|
|
+ goto warn_bat;
|
|
+
|
|
+ // safety thresholds:
|
|
+
|
|
+ // voltage = reg_val * 12800 uV (range is 0 - 3.264V)
|
|
+ ret = regmap_write(axp20x_batt->regmap, 0x38, 9750 * 80 / 12800); // V_LTF-charge
|
|
+ if (ret)
|
|
+ goto warn_bat;
|
|
+
|
|
+ ret = regmap_write(axp20x_batt->regmap, 0x39, 1080 * 80 / 12800); // V_HTF-charge
|
|
+ if (ret)
|
|
+ goto warn_bat;
|
|
+
|
|
+ ret = regmap_write(axp20x_batt->regmap, 0x3c, 16500 * 80 / 12800); // V_LTF-work
|
|
+ if (ret)
|
|
+ goto warn_bat;
|
|
+
|
|
+ ret = regmap_write(axp20x_batt->regmap, 0x3d, 896 * 80 / 12800); // V_HTF-work
|
|
+ if (ret)
|
|
+ goto warn_bat;
|
|
+
|
|
+ // There is a hysteresis of 460.8 mV(refer to TS pin voltage) for UTP
|
|
+ // threshold, and there is a hysteresis of 57.6 mV for OTP threshold.
|
|
+
|
|
+ // use TS pin only when charging, make it affect the charger, I = 80uA
|
|
+ ret = regmap_update_bits(axp20x_batt->regmap, 0x84, 0x37, 0x31);
|
|
+ if (ret)
|
|
+ goto warn_bat;
|
|
+ }
|
|
+
|
|
+ return 0;
|
|
+
|
|
+warn_bat:
|
|
+ dev_err(dev, "Failed to configure battery thermal regulation\n");
|
|
return 0;
|
|
}
|
|
|
|
--
|
|
2.34.0
|
|
|