pinctrl: sprd: check for allocation failure

devm_pinctrl_get() could fail with ERR_PTR(-ENOMEM) so I have added a
check for that.  I also reversed the other IS_ERR() test because it was
a little confusing to test one way and then the opposite a couple lines
later.

Fixes: 41d32cfce1 ("pinctrl: sprd: Add Spreadtrum pin control driver")
Signed-off-by: Dan Carpenter <dan.carpenter@oracle.com>
Signed-off-by: Linus Walleij <linus.walleij@linaro.org>
This commit is contained in:
Dan Carpenter 2017-09-07 10:29:26 +03:00 committed by Linus Walleij
parent baec7e687a
commit 41470c379b
1 changed files with 7 additions and 3 deletions

View File

@ -1100,12 +1100,16 @@ int sprd_pinctrl_remove(struct platform_device *pdev)
void sprd_pinctrl_shutdown(struct platform_device *pdev) void sprd_pinctrl_shutdown(struct platform_device *pdev)
{ {
struct pinctrl *pinctl = devm_pinctrl_get(&pdev->dev); struct pinctrl *pinctl;
struct pinctrl_state *state; struct pinctrl_state *state;
pinctl = devm_pinctrl_get(&pdev->dev);
if (IS_ERR(pinctl))
return;
state = pinctrl_lookup_state(pinctl, "shutdown"); state = pinctrl_lookup_state(pinctl, "shutdown");
if (!IS_ERR(state)) if (IS_ERR(state))
pinctrl_select_state(pinctl, state); return;
pinctrl_select_state(pinctl, state);
} }
MODULE_DESCRIPTION("SPREADTRUM Pin Controller Driver"); MODULE_DESCRIPTION("SPREADTRUM Pin Controller Driver");