Re: [tip: objtool/urgent] compiler.h: Fix annotation macro misplacement with Clang

From: Borislav Petkov
Date: Mon Jan 03 2022 - 12:58:10 EST


I wonder if clang folks have seen this and perhaps have a comment as to
why the volatile gets ingored... Added.

On Wed, Dec 22, 2021 at 09:10:30AM -0000, tip-bot2 for Josh Poimboeuf wrote:
> The following commit has been merged into the objtool/urgent branch of tip:
>
> Commit-ID: dcce50e6cc4d86a63dc0a9a6ee7d4f948ccd53a1
> Gitweb: https://git.kernel.org/tip/dcce50e6cc4d86a63dc0a9a6ee7d4f948ccd53a1
> Author: Josh Poimboeuf <jpoimboe@xxxxxxxxxx>
> AuthorDate: Mon, 08 Nov 2021 14:35:59 -08:00
> Committer: Josh Poimboeuf <jpoimboe@xxxxxxxxxx>
> CommitterDate: Tue, 21 Dec 2021 15:09:46 -08:00
>
> compiler.h: Fix annotation macro misplacement with Clang
>
> When building with Clang and CONFIG_TRACE_BRANCH_PROFILING, there are a
> lot of unreachable warnings, like:
>
> arch/x86/kernel/traps.o: warning: objtool: handle_xfd_event()+0x134: unreachable instruction
>
> Without an input to the inline asm, 'volatile' is ignored for some
> reason and Clang feels free to move the reachable() annotation away from
> its intended location.
>
> Fix that by re-adding the counter value to the inputs.
>
> Fixes: f1069a8756b9 ("compiler.h: Avoid using inline asm operand modifiers")
> Fixes: c199f64ff93c ("instrumentation.h: Avoid using inline asm operand modifiers")
> Reported-by: kernel test robot <lkp@xxxxxxxxx>
> Signed-off-by: Josh Poimboeuf <jpoimboe@xxxxxxxxxx>
> Link: https://lore.kernel.org/r/0417e96909b97a406323409210de7bf13df0b170.1636410380.git.jpoimboe@xxxxxxxxxx
> Cc: Peter Zijlstra <peterz@xxxxxxxxxxxxx>
> Cc: x86@xxxxxxxxxx
> Cc: Vasily Gorbik <gor@xxxxxxxxxxxxx>
> Cc: Miroslav Benes <mbenes@xxxxxxx>
> ---
> include/linux/compiler.h | 4 ++--
> include/linux/instrumentation.h | 4 ++--
> 2 files changed, 4 insertions(+), 4 deletions(-)
>
> diff --git a/include/linux/compiler.h b/include/linux/compiler.h
> index 3d5af56..429dceb 100644
> --- a/include/linux/compiler.h
> +++ b/include/linux/compiler.h
> @@ -121,7 +121,7 @@ void ftrace_likely_update(struct ftrace_likely_data *f, int val,
> asm volatile(__stringify_label(c) ":\n\t" \
> ".pushsection .discard.reachable\n\t" \
> ".long " __stringify_label(c) "b - .\n\t" \
> - ".popsection\n\t"); \
> + ".popsection\n\t" : : "i" (c)); \
> })
> #define annotate_reachable() __annotate_reachable(__COUNTER__)
>
> @@ -129,7 +129,7 @@ void ftrace_likely_update(struct ftrace_likely_data *f, int val,
> asm volatile(__stringify_label(c) ":\n\t" \
> ".pushsection .discard.unreachable\n\t" \
> ".long " __stringify_label(c) "b - .\n\t" \
> - ".popsection\n\t"); \
> + ".popsection\n\t" : : "i" (c)); \
> })
> #define annotate_unreachable() __annotate_unreachable(__COUNTER__)
>
> diff --git a/include/linux/instrumentation.h b/include/linux/instrumentation.h
> index fa2cd8c..24359b4 100644
> --- a/include/linux/instrumentation.h
> +++ b/include/linux/instrumentation.h
> @@ -11,7 +11,7 @@
> asm volatile(__stringify(c) ": nop\n\t" \
> ".pushsection .discard.instr_begin\n\t" \
> ".long " __stringify(c) "b - .\n\t" \
> - ".popsection\n\t"); \
> + ".popsection\n\t" : : "i" (c)); \
> })
> #define instrumentation_begin() __instrumentation_begin(__COUNTER__)
>
> @@ -50,7 +50,7 @@
> asm volatile(__stringify(c) ": nop\n\t" \
> ".pushsection .discard.instr_end\n\t" \
> ".long " __stringify(c) "b - .\n\t" \
> - ".popsection\n\t"); \
> + ".popsection\n\t" : : "i" (c)); \
> })
> #define instrumentation_end() __instrumentation_end(__COUNTER__)
> #else

--
Regards/Gruss,
Boris.

https://people.kernel.org/tglx/notes-about-netiquette