As per Jani and Daniel's feedback, I have updated the patch so that
the `wled->name` null check now occurs in the `wled_configure`
function, right after the `devm_kasprintf` callsite. This should
resolve the issue.
The updated patch is as follows:

In the function "wled_probe", the "wled->name" is dynamically allocated
(wled_probe -> wled_configure -> devm_kasprintf), and it is possible
for it to be NULL.

To avoid dereferencing a NULL pointer (wled_probe ->
devm_backlight_device_register -> backlight_device_register),
we add a null-check after the allocation rather than in
backlight_device_register.

Fixes: f86b77583d88 ("backlight: pm8941: Convert to using %pOFn instead of 
device_node.name")
Signed-off-by: Haoyu Li <lihaoyu...@gmail.com>
Cc: sta...@vger.kernel.org
---
 drivers/video/backlight/qcom-wled.c | 5 +++++
 1 file changed, 5 insertions(+)

diff --git a/drivers/video/backlight/qcom-wled.c 
b/drivers/video/backlight/qcom-wled.c
index 9afe701b2a1b..3dacfef821ca 100644
--- a/drivers/video/backlight/qcom-wled.c
+++ b/drivers/video/backlight/qcom-wled.c
@@ -1409,6 +1409,11 @@ static int wled_configure(struct wled *wled)
        if (rc)
                wled->name = devm_kasprintf(dev, GFP_KERNEL, "%pOFn", 
dev->of_node);
 
+       if (!wled->name) {
+               dev_err(wled->dev, "Fail to initialize wled name\n");
+               return -EINVAL;
+       }
+
        switch (wled->version) {
        case 3:
                u32_opts = wled3_opts;
-- 
2.34.1

Reply via email to