diff options
author | Gustavo A. R. Silva <gustavo@embeddedor.com> | 2019-01-22 10:56:36 -0600 |
---|---|---|
committer | Lee Jones <lee.jones@linaro.org> | 2019-02-07 10:42:47 +0000 |
commit | ae7b8eda27b33b1f688dfdebe4d46f690a8f9162 (patch) | |
tree | 7125e9cb83d8f1955c8dddb6165dced548ed5c5a /drivers/mfd/sm501.c | |
parent | 09fdc98577120d4f47601c3127efde726a2300c6 (diff) | |
download | lwn-ae7b8eda27b33b1f688dfdebe4d46f690a8f9162.tar.gz lwn-ae7b8eda27b33b1f688dfdebe4d46f690a8f9162.zip |
mfd: sm501: Fix potential NULL pointer dereference
There is a potential NULL pointer dereference in case devm_kzalloc()
fails and returns NULL.
Fix this by adding a NULL check on *lookup*
This bug was detected with the help of Coccinelle.
Fixes: b2e63555592f ("i2c: gpio: Convert to use descriptors")
Cc: stable@vger.kernel.org
Signed-off-by: Gustavo A. R. Silva <gustavo@embeddedor.com>
Signed-off-by: Lee Jones <lee.jones@linaro.org>
Diffstat (limited to 'drivers/mfd/sm501.c')
-rw-r--r-- | drivers/mfd/sm501.c | 3 |
1 files changed, 3 insertions, 0 deletions
diff --git a/drivers/mfd/sm501.c b/drivers/mfd/sm501.c index a530972c5a7e..e0173bf4b0dc 100644 --- a/drivers/mfd/sm501.c +++ b/drivers/mfd/sm501.c @@ -1145,6 +1145,9 @@ static int sm501_register_gpio_i2c_instance(struct sm501_devdata *sm, lookup = devm_kzalloc(&pdev->dev, sizeof(*lookup) + 3 * sizeof(struct gpiod_lookup), GFP_KERNEL); + if (!lookup) + return -ENOMEM; + lookup->dev_id = "i2c-gpio"; if (iic->pin_sda < 32) lookup->table[0].chip_label = "SM501-LOW"; |