gpio/rockchip: fetch deferred output settings on probe
Fetch the output settings the pinctrl driver may have created
for pinctrl hogs and set the relevant pins as requested.
Fixes: 9ce9a02039
("pinctrl/rockchip: drop the gpio related codes")
Signed-off-by: Heiko Stuebner <heiko@sntech.de>
Link: https://lore.kernel.org/r/20210913224926.1260726-5-heiko@sntech.de
Signed-off-by: Linus Walleij <linus.walleij@linaro.org>
This commit is contained in:
parent
e7165b1dff
commit
59dd178e1d
@ -689,6 +689,7 @@ static int rockchip_gpio_probe(struct platform_device *pdev)
|
|||||||
struct device_node *pctlnp = of_get_parent(np);
|
struct device_node *pctlnp = of_get_parent(np);
|
||||||
struct pinctrl_dev *pctldev = NULL;
|
struct pinctrl_dev *pctldev = NULL;
|
||||||
struct rockchip_pin_bank *bank = NULL;
|
struct rockchip_pin_bank *bank = NULL;
|
||||||
|
struct rockchip_pin_output_deferred *cfg;
|
||||||
static int gpio;
|
static int gpio;
|
||||||
int id, ret;
|
int id, ret;
|
||||||
|
|
||||||
@ -716,12 +717,33 @@ static int rockchip_gpio_probe(struct platform_device *pdev)
|
|||||||
if (ret)
|
if (ret)
|
||||||
return ret;
|
return ret;
|
||||||
|
|
||||||
|
/*
|
||||||
|
* Prevent clashes with a deferred output setting
|
||||||
|
* being added right at this moment.
|
||||||
|
*/
|
||||||
|
mutex_lock(&bank->deferred_lock);
|
||||||
|
|
||||||
ret = rockchip_gpiolib_register(bank);
|
ret = rockchip_gpiolib_register(bank);
|
||||||
if (ret) {
|
if (ret) {
|
||||||
clk_disable_unprepare(bank->clk);
|
clk_disable_unprepare(bank->clk);
|
||||||
|
mutex_unlock(&bank->deferred_lock);
|
||||||
return ret;
|
return ret;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
while (!list_empty(&bank->deferred_output)) {
|
||||||
|
cfg = list_first_entry(&bank->deferred_output,
|
||||||
|
struct rockchip_pin_output_deferred, head);
|
||||||
|
list_del(&cfg->head);
|
||||||
|
|
||||||
|
ret = rockchip_gpio_direction_output(&bank->gpio_chip, cfg->pin, cfg->arg);
|
||||||
|
if (ret)
|
||||||
|
dev_warn(dev, "setting output pin %u to %u failed\n", cfg->pin, cfg->arg);
|
||||||
|
|
||||||
|
kfree(cfg);
|
||||||
|
}
|
||||||
|
|
||||||
|
mutex_unlock(&bank->deferred_lock);
|
||||||
|
|
||||||
platform_set_drvdata(pdev, bank);
|
platform_set_drvdata(pdev, bank);
|
||||||
dev_info(dev, "probed %pOF\n", np);
|
dev_info(dev, "probed %pOF\n", np);
|
||||||
|
|
||||||
|
Loading…
Reference in New Issue
Block a user