power: supply: bq24190_charger: Fix bq24190_vbus_is_enabled() wrong false return
authorHans de Goede <hdegoede@redhat.com>
Sat, 12 Feb 2022 16:48:16 +0000 (17:48 +0100)
committerSebastian Reichel <sre@kernel.org>
Fri, 25 Feb 2022 19:07:57 +0000 (20:07 +0100)
The datasheet says that the BQ24190_REG_POC_CHG_CONFIG bits can
have a value of either 10(0x2) or 11(0x3) for OTG (5V boost regulator)
mode.

Sofar bq24190_vbus_is_enabled() was only checking for 10 but some BIOS-es
uses 11 when enabling the regulator at boot.

Make bq24190_vbus_is_enabled() also check for 11 so that it does not
wrongly returns false when the bits are set to 11.

Fixes: 66b6bef2c4e0 ("power: supply: bq24190_charger: Export 5V boost converter as regulator")
Cc: Bastien Nocera <hadess@hadess.net>
Signed-off-by: Hans de Goede <hdegoede@redhat.com>
Reviewed-by: Andy Shevchenko <andriy.shevchenko@linux.intel.com>
Signed-off-by: Sebastian Reichel <sebastian.reichel@collabora.com>
drivers/power/supply/bq24190_charger.c

index 04aa25f2d0335d91e671eea4692689dd187653e0..dcbfd97a55beba7ff85f62434426216dbd564694 100644 (file)
@@ -39,6 +39,7 @@
 #define BQ24190_REG_POC_CHG_CONFIG_DISABLE             0x0
 #define BQ24190_REG_POC_CHG_CONFIG_CHARGE              0x1
 #define BQ24190_REG_POC_CHG_CONFIG_OTG                 0x2
+#define BQ24190_REG_POC_CHG_CONFIG_OTG_ALT             0x3
 #define BQ24190_REG_POC_SYS_MIN_MASK           (BIT(3) | BIT(2) | BIT(1))
 #define BQ24190_REG_POC_SYS_MIN_SHIFT          1
 #define BQ24190_REG_POC_SYS_MIN_MIN                    3000
@@ -555,7 +556,11 @@ static int bq24190_vbus_is_enabled(struct regulator_dev *dev)
        pm_runtime_mark_last_busy(bdi->dev);
        pm_runtime_put_autosuspend(bdi->dev);
 
-       return ret ? ret : val == BQ24190_REG_POC_CHG_CONFIG_OTG;
+       if (ret)
+               return ret;
+
+       return (val == BQ24190_REG_POC_CHG_CONFIG_OTG ||
+               val == BQ24190_REG_POC_CHG_CONFIG_OTG_ALT);
 }
 
 static const struct regulator_ops bq24190_vbus_ops = {