regulator: s2mps11: Fix ERR_PTR dereference on GPIO lookup failure
authorKrzysztof Kozlowski <krzk@kernel.org>
Wed, 19 Jun 2019 12:42:39 +0000 (14:42 +0200)
committerMark Brown <broonie@kernel.org>
Thu, 20 Jun 2019 12:04:40 +0000 (13:04 +0100)
If devm_gpiod_get_from_of_node() call returns ERR_PTR, it is assigned
into an array of GPIO descriptors and used later because such error is
not treated as critical thus it is not propagated back to the probe
function.

All code later expects that such GPIO descriptor is either a NULL or
proper value.  This later might lead to dereference of ERR_PTR.

Only devices with S2MPS14 flavor are affected (other do not control
regulators with GPIOs).

Fixes: 1c984942f0a4 ("regulator: s2mps11: Pass descriptor instead of GPIO number")
Cc: <stable@vger.kernel.org>
Signed-off-by: Krzysztof Kozlowski <krzk@kernel.org>
Signed-off-by: Mark Brown <broonie@kernel.org>
drivers/regulator/s2mps11.c

index 134c62db36c5d5ebb6ce2adebcf430b59ca1c8d6..af9bf10b4c3373a6684bd44d97b609931f52b0a4 100644 (file)
@@ -824,6 +824,7 @@ static void s2mps14_pmic_dt_parse_ext_control_gpio(struct platform_device *pdev,
                if (IS_ERR(gpio[reg])) {
                        dev_err(&pdev->dev, "Failed to get control GPIO for %d/%s\n",
                                reg, rdata[reg].name);
+                       gpio[reg] = NULL;
                        continue;
                }
                if (gpio[reg])