power: supply: bq27xxx_battery: Silence deferred-probe error
authorDmitry Osipenko <digetx@gmail.com>
Sun, 8 Mar 2020 21:51:43 +0000 (00:51 +0300)
committerGreg Kroah-Hartman <gregkh@linuxfoundation.org>
Thu, 23 Apr 2020 08:36:29 +0000 (10:36 +0200)
[ Upstream commit 583b53ece0b0268c542a1eafadb62e3d4b0aab8c ]

The driver fails to probe with -EPROBE_DEFER if battery's power supply
(charger driver) isn't ready yet and this results in a bit noisy error
message in KMSG during kernel's boot up. Let's silence the harmless
error message.

Signed-off-by: Dmitry Osipenko <digetx@gmail.com>
Reviewed-by: Andrew F. Davis <afd@ti.com>
Reviewed-by: Pali Rohár <pali@kernel.org>
Signed-off-by: Sebastian Reichel <sebastian.reichel@collabora.com>
Signed-off-by: Sasha Levin <sashal@kernel.org>
drivers/power/supply/bq27xxx_battery.c

index 195c18c2f426e6d4d675c92ca5336fcf0166e83a..664e50103eaaffa84051ed5dc0689cf55cfadff6 100644 (file)
@@ -1885,7 +1885,10 @@ int bq27xxx_battery_setup(struct bq27xxx_device_info *di)
 
        di->bat = power_supply_register_no_ws(di->dev, psy_desc, &psy_cfg);
        if (IS_ERR(di->bat)) {
-               dev_err(di->dev, "failed to register battery\n");
+               if (PTR_ERR(di->bat) == -EPROBE_DEFER)
+                       dev_dbg(di->dev, "failed to register battery, deferring probe\n");
+               else
+                       dev_err(di->dev, "failed to register battery\n");
                return PTR_ERR(di->bat);
        }