Commit 0dd1628a authored by AngeloGioacchino Del Regno's avatar AngeloGioacchino Del Regno Committed by Linus Walleij

pinctrl: mediatek: pinctrl-mtk-common: Simplify with dev_err_probe()

Use the dev_err_probe() helper to simplify error handling during probe.
Signed-off-by: default avatarAngeloGioacchino Del Regno <angelogioacchino.delregno@collabora.com>
Reviewed-by: default avatarChen-Yu Tsai <wenst@chromium.org>
Signed-off-by: default avatarChen-Yu Tsai <wenst@chromium.org>
Link: https://lore.kernel.org/r/20220308100956.2750295-12-wenst@chromium.orgSigned-off-by: default avatarLinus Walleij <linus.walleij@linaro.org>
parent dc75d1ed
...@@ -1013,10 +1013,12 @@ static int mtk_eint_init(struct mtk_pinctrl *pctl, struct platform_device *pdev) ...@@ -1013,10 +1013,12 @@ static int mtk_eint_init(struct mtk_pinctrl *pctl, struct platform_device *pdev)
return mtk_eint_do_init(pctl->eint); return mtk_eint_do_init(pctl->eint);
} }
/* This is used as a common probe function */
int mtk_pctrl_init(struct platform_device *pdev, int mtk_pctrl_init(struct platform_device *pdev,
const struct mtk_pinctrl_devdata *data, const struct mtk_pinctrl_devdata *data,
struct regmap *regmap) struct regmap *regmap)
{ {
struct device *dev = &pdev->dev;
struct pinctrl_pin_desc *pins; struct pinctrl_pin_desc *pins;
struct mtk_pinctrl *pctl; struct mtk_pinctrl *pctl;
struct device_node *np = pdev->dev.of_node, *node; struct device_node *np = pdev->dev.of_node, *node;
...@@ -1030,10 +1032,9 @@ int mtk_pctrl_init(struct platform_device *pdev, ...@@ -1030,10 +1032,9 @@ int mtk_pctrl_init(struct platform_device *pdev,
platform_set_drvdata(pdev, pctl); platform_set_drvdata(pdev, pctl);
prop = of_find_property(np, "pins-are-numbered", NULL); prop = of_find_property(np, "pins-are-numbered", NULL);
if (!prop) { if (!prop)
dev_err(&pdev->dev, "only support pins-are-numbered format\n"); return dev_err_probe(dev, -EINVAL,
return -EINVAL; "only support pins-are-numbered format\n");
}
node = of_parse_phandle(np, "mediatek,pctl-regmap", 0); node = of_parse_phandle(np, "mediatek,pctl-regmap", 0);
if (node) { if (node) {
...@@ -1044,8 +1045,7 @@ int mtk_pctrl_init(struct platform_device *pdev, ...@@ -1044,8 +1045,7 @@ int mtk_pctrl_init(struct platform_device *pdev,
} else if (regmap) { } else if (regmap) {
pctl->regmap1 = regmap; pctl->regmap1 = regmap;
} else { } else {
dev_err(&pdev->dev, "Pinctrl node has not register regmap.\n"); return dev_err_probe(dev, -EINVAL, "Cannot find pinctrl regmap.\n");
return -EINVAL;
} }
/* Only 8135 has two base addr, other SoCs have only one. */ /* Only 8135 has two base addr, other SoCs have only one. */
...@@ -1059,10 +1059,8 @@ int mtk_pctrl_init(struct platform_device *pdev, ...@@ -1059,10 +1059,8 @@ int mtk_pctrl_init(struct platform_device *pdev,
pctl->devdata = data; pctl->devdata = data;
ret = mtk_pctrl_build_state(pdev); ret = mtk_pctrl_build_state(pdev);
if (ret) { if (ret)
dev_err(&pdev->dev, "build state failed: %d\n", ret); return dev_err_probe(dev, ret, "build state failed\n");
return -EINVAL;
}
pins = devm_kcalloc(&pdev->dev, pctl->devdata->npins, sizeof(*pins), pins = devm_kcalloc(&pdev->dev, pctl->devdata->npins, sizeof(*pins),
GFP_KERNEL); GFP_KERNEL);
...@@ -1083,10 +1081,9 @@ int mtk_pctrl_init(struct platform_device *pdev, ...@@ -1083,10 +1081,9 @@ int mtk_pctrl_init(struct platform_device *pdev,
pctl->pctl_dev = devm_pinctrl_register(&pdev->dev, &pctl->pctl_desc, pctl->pctl_dev = devm_pinctrl_register(&pdev->dev, &pctl->pctl_desc,
pctl); pctl);
if (IS_ERR(pctl->pctl_dev)) { if (IS_ERR(pctl->pctl_dev))
dev_err(&pdev->dev, "couldn't register pinctrl driver\n"); return dev_err_probe(dev, PTR_ERR(pctl->pctl_dev),
return PTR_ERR(pctl->pctl_dev); "Couldn't register pinctrl driver\n");
}
pctl->chip = devm_kzalloc(&pdev->dev, sizeof(*pctl->chip), GFP_KERNEL); pctl->chip = devm_kzalloc(&pdev->dev, sizeof(*pctl->chip), GFP_KERNEL);
if (!pctl->chip) if (!pctl->chip)
......
Markdown is supported
0%
or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment