clk: tegra: Use readl_relaxed_poll_timeout_atomic() in tegra210_clock_init()
authorNicolin Chen <nicoleotsuka@gmail.com>
Fri, 15 Sep 2017 19:10:13 +0000 (12:10 -0700)
committerThierry Reding <treding@nvidia.com>
Wed, 1 Nov 2017 14:00:07 +0000 (15:00 +0100)
commit22ef01a203d27fee8b7694020b7e722db7efd2a7
tree8acd2427d7f5542eebe15e9675fdae706aba8f78
parent1752c9ee23fb20e5bfdbedf677e91f927f2b8d80
clk: tegra: Use readl_relaxed_poll_timeout_atomic() in tegra210_clock_init()

Below is the call trace of tegra210_init_pllu() function:
  start_kernel()
  -> time_init()
  --> of_clk_init()
  ---> tegra210_clock_init()
  ----> tegra210_pll_init()
  -----> tegra210_init_pllu()

Because the preemption is disabled in the start_kernel before calling
time_init, tegra210_init_pllu is actually in an atomic context while
it includes a readl_relaxed_poll_timeout that might sleep.

So this patch just changes this readl_relaxed_poll_timeout() to its
atomic version.

Signed-off-by: Nicolin Chen <nicoleotsuka@gmail.com>
Acked-By: Peter De Schrijver <pdeschrijver@nvidia.com>
Signed-off-by: Thierry Reding <treding@nvidia.com>
drivers/clk/tegra/clk-tegra210.c