cpuidle: tegra: Annotate tegra_pm_set_cpu_in_lp2() with RCU_NONIDLE

Annotate tegra_pm_set[clear]_cpu_in_lp2() with RCU_NONIDLE in order to
fix lockdep warning about suspicious RCU usage of a spinlock during late
idling phase.

 WARNING: suspicious RCU usage
 ...
 include/trace/events/lock.h:13 suspicious rcu_dereference_check() usage!
 ...
  (dump_stack) from (lock_acquire)
  (lock_acquire) from (_raw_spin_lock)
  (_raw_spin_lock) from (tegra_pm_set_cpu_in_lp2)
  (tegra_pm_set_cpu_in_lp2) from (tegra_cpuidle_enter)
  (tegra_cpuidle_enter) from (cpuidle_enter_state)
  (cpuidle_enter_state) from (cpuidle_enter_state_coupled)
  (cpuidle_enter_state_coupled) from (cpuidle_enter)
  (cpuidle_enter) from (do_idle)
 ...

Tested-by: Peter Geis <pgwipeout@gmail.com>
Reported-by: Peter Geis <pgwipeout@gmail.com>
Signed-off-by: Dmitry Osipenko <digetx@gmail.com>
Signed-off-by: Rafael J. Wysocki <rafael.j.wysocki@intel.com>
This commit is contained in:
Dmitry Osipenko 2020-11-04 16:21:26 +03:00 committed by Rafael J. Wysocki
parent 09162bc32c
commit c39de538a0

View File

@ -189,7 +189,7 @@ static int tegra_cpuidle_state_enter(struct cpuidle_device *dev,
} }
local_fiq_disable(); local_fiq_disable();
tegra_pm_set_cpu_in_lp2(); RCU_NONIDLE(tegra_pm_set_cpu_in_lp2());
cpu_pm_enter(); cpu_pm_enter();
switch (index) { switch (index) {
@ -207,7 +207,7 @@ static int tegra_cpuidle_state_enter(struct cpuidle_device *dev,
} }
cpu_pm_exit(); cpu_pm_exit();
tegra_pm_clear_cpu_in_lp2(); RCU_NONIDLE(tegra_pm_clear_cpu_in_lp2());
local_fiq_enable(); local_fiq_enable();
return err ?: index; return err ?: index;