power: supply: cw2015: Fix potential null-ptr-deref in cw_bat_probe()
authorShang XiaoJing <shangxiaojing@huawei.com>
Thu, 17 Nov 2022 02:45:58 +0000 (10:45 +0800)
committerSebastian Reichel <sebastian.reichel@collabora.com>
Thu, 24 Nov 2022 22:00:00 +0000 (23:00 +0100)
cw_bat_probe() calls create_singlethread_workqueue() and not checked the
ret value, which may return NULL. And a null-ptr-deref may happen:

cw_bat_probe()
    create_singlethread_workqueue() # failed, cw_bat->wq is NULL
    queue_delayed_work()
        queue_delayed_work_on()
            __queue_delayed_work()  # warning here, but continue
                __queue_work()      # access wq->flags, null-ptr-deref

Check the ret value and return -ENOMEM if it is NULL.

Fixes: b4c7715c10c1 ("power: supply: add CellWise cw2015 fuel gauge driver")
Signed-off-by: Shang XiaoJing <shangxiaojing@huawei.com>
Signed-off-by: Sebastian Reichel <sebastian.reichel@collabora.com>
drivers/power/supply/cw2015_battery.c

index 6d52641151d9ac4a1eb9dcade7ce1f1e32eb0d08..473522b4326adc5f84aebfbf8962e2b7e2ef1089 100644 (file)
@@ -699,6 +699,9 @@ static int cw_bat_probe(struct i2c_client *client)
        }
 
        cw_bat->battery_workqueue = create_singlethread_workqueue("rk_battery");
+       if (!cw_bat->battery_workqueue)
+               return -ENOMEM;
+
        devm_delayed_work_autocancel(&client->dev,
                                                          &cw_bat->battery_delay_work, cw_bat_work);
        queue_delayed_work(cw_bat->battery_workqueue,