diff options
author | Alexandre Belloni <alexandre.belloni@bootlin.com> | 2019-11-28 11:25:31 +0100 |
---|---|---|
committer | Stephen Boyd <sboyd@kernel.org> | 2019-12-16 09:56:18 -0800 |
commit | 6956eb33abb5deab2cd916b4c31226b57736bc3c (patch) | |
tree | bc5073c9253c9c2e6e899ee55186c8de98ffac81 /drivers/clk/at91/at91sam9rl.c | |
parent | d3ab06f432891bfcb9e28a9d183e7f7c50f8d951 (diff) | |
download | lwn-6956eb33abb5deab2cd916b4c31226b57736bc3c.tar.gz lwn-6956eb33abb5deab2cd916b4c31226b57736bc3c.zip |
clk: at91: fix possible deadlock
Lockdep warns about a possible circular locking dependency because using
syscon_node_to_regmap() will make the created regmap get and enable the
first clock it can parse from the device tree. This clock is not needed to
access the registers and should not be enabled at that time.
Use the recently introduced device_node_to_regmap to solve that as it looks
up the regmap in the same list but doesn't care about the clocks.
Reported-by: Michał Mirosław <mirq-linux@rere.qmqm.pl>
Signed-off-by: Alexandre Belloni <alexandre.belloni@bootlin.com>
Link: https://lkml.kernel.org/r/20191128102531.817549-1-alexandre.belloni@bootlin.com
Tested-by: Michał Mirosław <mirq-linux@rere.qmqm.pl>
Signed-off-by: Stephen Boyd <sboyd@kernel.org>
Diffstat (limited to 'drivers/clk/at91/at91sam9rl.c')
-rw-r--r-- | drivers/clk/at91/at91sam9rl.c | 2 |
1 files changed, 1 insertions, 1 deletions
diff --git a/drivers/clk/at91/at91sam9rl.c b/drivers/clk/at91/at91sam9rl.c index 0ac34cdaa106..77fe83a73bf4 100644 --- a/drivers/clk/at91/at91sam9rl.c +++ b/drivers/clk/at91/at91sam9rl.c @@ -83,7 +83,7 @@ static void __init at91sam9rl_pmc_setup(struct device_node *np) return; mainxtal_name = of_clk_get_parent_name(np, i); - regmap = syscon_node_to_regmap(np); + regmap = device_node_to_regmap(np); if (IS_ERR(regmap)) return; |