Linux kernel mirror (for testing) git.kernel.org/pub/scm/linux/kernel/git/torvalds/linux.git
kernel os linux

context_tracking: Tag context_tracking_enabled_this_cpu() __always_inline

Force context_tracking_enabled_this_cpu() to be inlined so that invoking
it from guest_context_enter_irqoff(), which KVM uses in non-instrumentable
code, doesn't unexpectedly leave a noinstr section.

vmlinux.o: warning: objtool: vmx_vcpu_enter_exit+0x1c7: call to
context_tracking_enabled_this_cpu() leaves .noinstr.text section
vmlinux.o: warning: objtool: svm_vcpu_enter_exit+0x83: call to
context_tracking_enabled_this_cpu() leaves .noinstr.text section

Note, the CONFIG_CONTEXT_TRACKING_USER=n stub is already __always_inline.

Signed-off-by: Sean Christopherson <seanjc@google.com>
Signed-off-by: Paul E. McKenney <paulmck@kernel.org>
Signed-off-by: Neeraj Upadhyay <neeraj.upadhyay@kernel.org>

authored by

Sean Christopherson and committed by
Neeraj Upadhyay
4040b113 4f336dc0

+1 -1
+1 -1
include/linux/context_tracking_state.h
··· 113 113 return context_tracking_enabled() && per_cpu(context_tracking.active, cpu); 114 114 } 115 115 116 - static inline bool context_tracking_enabled_this_cpu(void) 116 + static __always_inline bool context_tracking_enabled_this_cpu(void) 117 117 { 118 118 return context_tracking_enabled() && __this_cpu_read(context_tracking.active); 119 119 }