+objtool folks On Tue, Oct 13, 2020 at 2:35 AM Sami Tolvanen <samitolvanen@xxxxxxxxxx> wrote: > Running objtool --vmlinux --duplicate on vmlinux.o produces a few > warnings about indirect jumps with retpoline: > > vmlinux.o: warning: objtool: wakeup_long64()+0x61: indirect jump > found in RETPOLINE build > ... > > This change adds ANNOTATE_RETPOLINE_SAFE annotations to the jumps > in assembly code to stop the warnings. In other words, this patch deals with the fact that OBJECT_FILES_NON_STANDARD stops being effective for object files that are linked into the main kernel when LTO is on, right? All the files you're touching here are supposed to be excluded from objtool warnings at the moment: $ grep OBJECT_FILES_NON_STANDARD arch/x86/kernel/acpi/Makefile OBJECT_FILES_NON_STANDARD_wakeup_$(BITS).o := y $ grep OBJECT_FILES_NON_STANDARD arch/x86/platform/pvh/Makefile OBJECT_FILES_NON_STANDARD_head.o := y $ grep OBJECT_FILES_NON_STANDARD arch/x86/power/Makefile OBJECT_FILES_NON_STANDARD_hibernate_asm_$(BITS).o := y It would probably be good to keep LTO and non-LTO builds in sync about which files are subjected to objtool checks. So either you should be removing the OBJECT_FILES_NON_STANDARD annotations for anything that is linked into the main kernel (which would be a nice cleanup, if that is possible), or alternatively ensure that code from these files is excluded from objtool checks even with LTO (that'd probably be messy and a bad idea?). Grepping for other files marked as OBJECT_FILES_NON_STANDARD that might be included in the main kernel on x86, I also see stuff like: 5 arch/x86/crypto/Makefile 5 OBJECT_FILES_NON_STANDARD := y 10 arch/x86/kernel/Makefile 39 OBJECT_FILES_NON_STANDARD_ftrace_$(BITS).o := y 12 arch/x86/kvm/Makefile 7 OBJECT_FILES_NON_STANDARD_vmenter.o := y for which I think the same thing applies.