From: Peter Zijlstra Date: Tue, 28 Sep 2021 08:40:22 +0000 (+0200) Subject: rcu: Fix rcu_dynticks_curr_cpu_in_eqs() vs noinstr X-Git-Tag: v6.1-rc5~2772^2~1 X-Git-Url: http://review.tizen.org/git/?a=commitdiff_plain;h=74aece72f95f399dd29363669dc32a1344c8fab4;p=platform%2Fkernel%2Flinux-starfive.git rcu: Fix rcu_dynticks_curr_cpu_in_eqs() vs noinstr vmlinux.o: warning: objtool: rcu_nmi_enter()+0x36: call to __kasan_check_read() leaves .noinstr.text section noinstr cannot have atomic_*() functions in because they're explicitly annotated, use arch_atomic_*(). Fixes: 2be57f732889 ("rcu: Weaken ->dynticks accesses and updates") Reported-by: Stephen Rothwell Reviewed-by: Thomas Gleixner Signed-off-by: Peter Zijlstra (Intel) Signed-off-by: Paul E. McKenney --- diff --git a/kernel/rcu/tree.c b/kernel/rcu/tree.c index 6a1e9d3..ef8d36f 100644 --- a/kernel/rcu/tree.c +++ b/kernel/rcu/tree.c @@ -327,7 +327,7 @@ static void rcu_dynticks_eqs_online(void) */ static __always_inline bool rcu_dynticks_curr_cpu_in_eqs(void) { - return !(atomic_read(this_cpu_ptr(&rcu_data.dynticks)) & 0x1); + return !(arch_atomic_read(this_cpu_ptr(&rcu_data.dynticks)) & 0x1); } /*