* [GIT PULL] objtool changes for v5.19 @ 2022-05-23 16:32 Ingo Molnar 2022-05-24 5:34 ` Ingo Molnar 2022-05-24 19:53 ` pr-tracker-bot 0 siblings, 2 replies; 7+ messages in thread From: Ingo Molnar @ 2022-05-23 16:32 UTC (permalink / raw) To: Linus Torvalds Cc: linux-kernel, Peter Zijlstra, Josh Poimboeuf, Thomas Gleixner, Borislav Petkov, Andrew Morton Linus, Please pull the latest objtool/core git tree from: git://git.kernel.org/pub/scm/linux/kernel/git/tip/tip.git objtool-core-2022-05-23 # HEAD: 22682a07acc308ef78681572e19502ce8893c4d4 objtool: Fix objtool regression on x32 systems Objtool changes for this cycle were: - Comprehensive interface overhaul: ================================= Objtool's interface has some issues: - Several features are done unconditionally, without any way to turn them off. Some of them might be surprising. This makes objtool tricky to use, and prevents porting individual features to other arches. - The config dependencies are too coarse-grained. Objtool enablement is tied to CONFIG_STACK_VALIDATION, but it has several other features independent of that. - The objtool subcmds ("check" and "orc") are clumsy: "check" is really a subset of "orc", so it has all the same options. The subcmd model has never really worked for objtool, as it only has a single purpose: "do some combination of things on an object file". - The '--lto' and '--vmlinux' options are nonsensical and have surprising behavior. Overhaul the interface: - get rid of subcmds - make all features individually selectable - remove and/or clarify confusing/obsolete options - update the documentation - fix some bugs found along the way - Fix x32 regression - Fix Kbuild cleanup bugs - Add scripts/objdump-func helper script to disassemble a single function from an object file. - Rewrite scripts/faddr2line to be section-aware, by basing it on 'readelf', moving it away from 'nm', which doesn't handle multiple sections well, which can result in decoding failure. - Rewrite & fix symbol handling - which had a number of bugs wrt. object files that don't have global symbols - which is rare but possible. Also fix a bunch of symbol handling bugs found along the way. Signed-off-by: Ingo Molnar <mingo@kernel.org> Thanks, Ingo ------------------> Borislav Petkov (1): x86/cpu: Load microcode during restore_processor_state() Dmitry Monakhov (1): x86/unwind/orc: Recheck address range after stack info was updated Josh Poimboeuf (27): MAINTAINERS: Add x86 unwinding entry objtool: Enable unreachable warnings for CLANG LTO x86/static_call: Add ANNOTATE_NOENDBR to static call trampoline x86/retpoline: Add ANNOTATE_NOENDBR for retpolines x86/uaccess: Add ENDBR to __put_user_nocheck*() x86/xen: Add ANNOTATE_NOENDBR to startup_xen() objtool: Print data address for "!ENDBR" data warnings objtool: Use offstr() to print address of missing ENDBR libsubcmd: Fix OPTION_GROUP sorting objtool: Reorganize cmdline options objtool: Ditch subcommands objtool: Don't print parentheses in function addresses objtool: Add option to print section addresses objtool: Make stack validation optional objtool: Rework ibt and extricate from stack validation objtool: Extricate sls from stack validation objtool: Add CONFIG_OBJTOOL objtool: Make stack validation frame-pointer-specific objtool: Make static call annotation optional objtool: Make jump label hack optional objtool: Make noinstr hacks optional objtool: Rename "VMLINUX_VALIDATION" -> "NOINSTR_VALIDATION" objtool: Add HAVE_NOINSTR_VALIDATION objtool: Remove --lto and --vmlinux in favor of --link objtool: Update documentation scripts: Create objdump-func helper script scripts/faddr2line: Fix overlapping text section failures Mikulas Patocka (1): objtool: Fix objtool regression on x32 systems Nur Hussein (1): x86/Kconfig: fix the spelling of 'becoming' in X86_KERNEL_IBT config Peter Zijlstra (5): lib/strn*,objtool: Enforce user_access_begin() rules x86,xen,objtool: Add UNWIND hint x86,objtool: Mark cpu_startup_entry() __noreturn x86,objtool: Explicitly mark idtentry_body()s tail REACHABLE objtool: Fix symbol creation Tiezhu Yang (2): objtool: Remove inat-tables.c when make clean objtool: Remove libsubcmd.a when make clean Tony Luck (1): x86/cpu: Add new Alderlake and Raptorlake CPU model numbers MAINTAINERS | 9 + Makefile | 2 +- arch/Kconfig | 18 +- arch/x86/Kconfig | 23 +- arch/x86/Kconfig.debug | 2 +- arch/x86/entry/entry_64.S | 3 + arch/x86/include/asm/intel-family.h | 3 + arch/x86/include/asm/jump_label.h | 6 +- arch/x86/include/asm/microcode.h | 2 + arch/x86/include/asm/static_call.h | 1 + arch/x86/kernel/alternative.c | 6 +- arch/x86/kernel/cpu/microcode/core.c | 6 +- arch/x86/kernel/unwind_orc.c | 8 +- arch/x86/lib/putuser.S | 4 + arch/x86/lib/retpoline.S | 2 +- arch/x86/platform/pvh/head.S | 1 + arch/x86/power/cpu.c | 10 +- arch/x86/xen/xen-head.S | 1 + include/linux/compiler.h | 6 +- include/linux/cpu.h | 2 +- include/linux/instrumentation.h | 6 +- include/linux/objtool.h | 6 +- kernel/trace/Kconfig | 1 + lib/Kconfig.debug | 22 +- lib/Kconfig.kcsan | 4 +- lib/Kconfig.ubsan | 2 +- lib/strncpy_from_user.c | 2 +- lib/strnlen_user.c | 2 +- scripts/Makefile.build | 23 +- scripts/faddr2line | 150 ++++--- scripts/link-vmlinux.sh | 66 +-- scripts/objdump-func | 29 ++ scripts/package/builddeb | 2 +- tools/include/linux/objtool.h | 6 +- tools/lib/subcmd/parse-options.c | 17 +- tools/objtool/Build | 12 +- .../{stack-validation.txt => objtool.txt} | 122 +++++- tools/objtool/Makefile | 10 +- tools/objtool/arch/x86/decode.c | 2 +- tools/objtool/arch/x86/special.c | 2 +- tools/objtool/builtin-check.c | 156 +++++-- tools/objtool/builtin-orc.c | 73 ---- tools/objtool/check.c | 466 +++++++++++---------- tools/objtool/elf.c | 211 ++++++---- tools/objtool/include/objtool/builtin.h | 34 +- tools/objtool/include/objtool/elf.h | 16 +- tools/objtool/include/objtool/warn.h | 35 +- tools/objtool/objtool.c | 103 +---- tools/objtool/weak.c | 9 +- 49 files changed, 1004 insertions(+), 700 deletions(-) create mode 100755 scripts/objdump-func rename tools/objtool/Documentation/{stack-validation.txt => objtool.txt} (80%) delete mode 100644 tools/objtool/builtin-orc.c ^ permalink raw reply [flat|nested] 7+ messages in thread
* Re: [GIT PULL] objtool changes for v5.19 2022-05-23 16:32 [GIT PULL] objtool changes for v5.19 Ingo Molnar @ 2022-05-24 5:34 ` Ingo Molnar 2022-05-24 6:02 ` Ingo Molnar 2022-05-24 19:53 ` pr-tracker-bot 1 sibling, 1 reply; 7+ messages in thread From: Ingo Molnar @ 2022-05-24 5:34 UTC (permalink / raw) To: Linus Torvalds Cc: linux-kernel, Peter Zijlstra, Josh Poimboeuf, Thomas Gleixner, Borislav Petkov, Andrew Morton * Ingo Molnar <mingo@kernel.org> wrote: > Linus, > > Please pull the latest objtool/core git tree from: > > git://git.kernel.org/pub/scm/linux/kernel/git/tip/tip.git objtool-core-2022-05-23 > > # HEAD: 22682a07acc308ef78681572e19502ce8893c4d4 objtool: Fix objtool regression on x32 systems > > Objtool changes for this cycle were: > > - Comprehensive interface overhaul: > ================================= > > Objtool's interface has some issues: > > - Several features are done unconditionally, without any way to turn > them off. Some of them might be surprising. This makes objtool > tricky to use, and prevents porting individual features to other > arches. > > - The config dependencies are too coarse-grained. Objtool enablement is > tied to CONFIG_STACK_VALIDATION, but it has several other features > independent of that. > > - The objtool subcmds ("check" and "orc") are clumsy: "check" is really > a subset of "orc", so it has all the same options. The subcmd model > has never really worked for objtool, as it only has a single purpose: > "do some combination of things on an object file". > > - The '--lto' and '--vmlinux' options are nonsensical and have > surprising behavior. > > Overhaul the interface: > > - get rid of subcmds > > - make all features individually selectable > > - remove and/or clarify confusing/obsolete options > > - update the documentation > > - fix some bugs found along the way > > - Fix x32 regression > > - Fix Kbuild cleanup bugs > > - Add scripts/objdump-func helper script to disassemble a single function from an object file. > > - Rewrite scripts/faddr2line to be section-aware, by basing it on 'readelf', > moving it away from 'nm', which doesn't handle multiple sections well, > which can result in decoding failure. > > - Rewrite & fix symbol handling - which had a number of bugs wrt. object files > that don't have global symbols - which is rare but possible. Also fix a > bunch of symbol handling bugs found along the way. > > Signed-off-by: Ingo Molnar <mingo@kernel.org> > Thanks, > > Ingo > > ------------------> > Borislav Petkov (1): > x86/cpu: Load microcode during restore_processor_state() > > Dmitry Monakhov (1): > x86/unwind/orc: Recheck address range after stack info was updated > > Josh Poimboeuf (27): > MAINTAINERS: Add x86 unwinding entry > objtool: Enable unreachable warnings for CLANG LTO > x86/static_call: Add ANNOTATE_NOENDBR to static call trampoline > x86/retpoline: Add ANNOTATE_NOENDBR for retpolines > x86/uaccess: Add ENDBR to __put_user_nocheck*() > x86/xen: Add ANNOTATE_NOENDBR to startup_xen() > objtool: Print data address for "!ENDBR" data warnings > objtool: Use offstr() to print address of missing ENDBR > libsubcmd: Fix OPTION_GROUP sorting > objtool: Reorganize cmdline options > objtool: Ditch subcommands > objtool: Don't print parentheses in function addresses > objtool: Add option to print section addresses > objtool: Make stack validation optional > objtool: Rework ibt and extricate from stack validation > objtool: Extricate sls from stack validation > objtool: Add CONFIG_OBJTOOL > objtool: Make stack validation frame-pointer-specific > objtool: Make static call annotation optional > objtool: Make jump label hack optional > objtool: Make noinstr hacks optional > objtool: Rename "VMLINUX_VALIDATION" -> "NOINSTR_VALIDATION" > objtool: Add HAVE_NOINSTR_VALIDATION > objtool: Remove --lto and --vmlinux in favor of --link > objtool: Update documentation > scripts: Create objdump-func helper script > scripts/faddr2line: Fix overlapping text section failures > > Mikulas Patocka (1): > objtool: Fix objtool regression on x32 systems > > Nur Hussein (1): > x86/Kconfig: fix the spelling of 'becoming' in X86_KERNEL_IBT config > > Peter Zijlstra (5): > lib/strn*,objtool: Enforce user_access_begin() rules > x86,xen,objtool: Add UNWIND hint > x86,objtool: Mark cpu_startup_entry() __noreturn > x86,objtool: Explicitly mark idtentry_body()s tail REACHABLE > objtool: Fix symbol creation > > Tiezhu Yang (2): > objtool: Remove inat-tables.c when make clean > objtool: Remove libsubcmd.a when make clean > > Tony Luck (1): > x86/cpu: Add new Alderlake and Raptorlake CPU model numbers > > > MAINTAINERS | 9 + > Makefile | 2 +- > arch/Kconfig | 18 +- > arch/x86/Kconfig | 23 +- > arch/x86/Kconfig.debug | 2 +- > arch/x86/entry/entry_64.S | 3 + > arch/x86/include/asm/intel-family.h | 3 + > arch/x86/include/asm/jump_label.h | 6 +- > arch/x86/include/asm/microcode.h | 2 + > arch/x86/include/asm/static_call.h | 1 + > arch/x86/kernel/alternative.c | 6 +- > arch/x86/kernel/cpu/microcode/core.c | 6 +- > arch/x86/kernel/unwind_orc.c | 8 +- > arch/x86/lib/putuser.S | 4 + > arch/x86/lib/retpoline.S | 2 +- > arch/x86/platform/pvh/head.S | 1 + > arch/x86/power/cpu.c | 10 +- > arch/x86/xen/xen-head.S | 1 + > include/linux/compiler.h | 6 +- > include/linux/cpu.h | 2 +- > include/linux/instrumentation.h | 6 +- > include/linux/objtool.h | 6 +- > kernel/trace/Kconfig | 1 + > lib/Kconfig.debug | 22 +- > lib/Kconfig.kcsan | 4 +- > lib/Kconfig.ubsan | 2 +- > lib/strncpy_from_user.c | 2 +- > lib/strnlen_user.c | 2 +- > scripts/Makefile.build | 23 +- > scripts/faddr2line | 150 ++++--- > scripts/link-vmlinux.sh | 66 +-- > scripts/objdump-func | 29 ++ > scripts/package/builddeb | 2 +- > tools/include/linux/objtool.h | 6 +- > tools/lib/subcmd/parse-options.c | 17 +- > tools/objtool/Build | 12 +- > .../{stack-validation.txt => objtool.txt} | 122 +++++- > tools/objtool/Makefile | 10 +- > tools/objtool/arch/x86/decode.c | 2 +- > tools/objtool/arch/x86/special.c | 2 +- > tools/objtool/builtin-check.c | 156 +++++-- > tools/objtool/builtin-orc.c | 73 ---- > tools/objtool/check.c | 466 +++++++++++---------- > tools/objtool/elf.c | 211 ++++++---- > tools/objtool/include/objtool/builtin.h | 34 +- > tools/objtool/include/objtool/elf.h | 16 +- > tools/objtool/include/objtool/warn.h | 35 +- > tools/objtool/objtool.c | 103 +---- > tools/objtool/weak.c | 9 +- > 49 files changed, 1004 insertions(+), 700 deletions(-) > create mode 100755 scripts/objdump-func > rename tools/objtool/Documentation/{stack-validation.txt => objtool.txt} (80%) > delete mode 100644 tools/objtool/builtin-orc.c Not sure what happened there, a previous x86/urgent got mixed into the shortlog & diffstat - this is the correct shortlog & diffstat you should get when pulling objtool-core-2022-05-23: Josh Poimboeuf (19): libsubcmd: Fix OPTION_GROUP sorting objtool: Reorganize cmdline options objtool: Ditch subcommands objtool: Don't print parentheses in function addresses objtool: Add option to print section addresses objtool: Make stack validation optional objtool: Rework ibt and extricate from stack validation objtool: Extricate sls from stack validation objtool: Add CONFIG_OBJTOOL objtool: Make stack validation frame-pointer-specific objtool: Make static call annotation optional objtool: Make jump label hack optional objtool: Make noinstr hacks optional objtool: Rename "VMLINUX_VALIDATION" -> "NOINSTR_VALIDATION" objtool: Add HAVE_NOINSTR_VALIDATION objtool: Remove --lto and --vmlinux in favor of --link objtool: Update documentation scripts: Create objdump-func helper script scripts/faddr2line: Fix overlapping text section failures Mikulas Patocka (1): objtool: Fix objtool regression on x32 systems Peter Zijlstra (2): Merge branch 'tip/x86/urgent' objtool: Fix symbol creation Tiezhu Yang (2): objtool: Remove inat-tables.c when make clean objtool: Remove libsubcmd.a when make clean ================> Makefile | 2 +- arch/Kconfig | 18 ++++++- arch/x86/Kconfig | 21 +++++--- arch/x86/Kconfig.debug | 2 +- arch/x86/include/asm/jump_label.h | 6 +-- arch/x86/kernel/alternative.c | 6 +-- include/linux/compiler.h | 6 +-- include/linux/instrumentation.h | 6 +-- include/linux/objtool.h | 6 +-- kernel/trace/Kconfig | 1 + lib/Kconfig.debug | 22 ++++---- lib/Kconfig.kcsan | 4 +- lib/Kconfig.ubsan | 2 +- scripts/Makefile.build | 23 +++++---- scripts/faddr2line | 150 +++++++++++++++++++++++++++++++++++------------------- scripts/link-vmlinux.sh | 66 +++++++++++++++--------- scripts/objdump-func | 29 +++++++++++ scripts/package/builddeb | 2 +- tools/include/linux/objtool.h | 6 +-- tools/lib/subcmd/parse-options.c | 17 +++++-- tools/objtool/Build | 12 ++--- tools/objtool/Documentation/{stack-validation.txt => objtool.txt} | 122 ++++++++++++++++++++++++++++++++++++-------- tools/objtool/Makefile | 10 ++-- tools/objtool/arch/x86/decode.c | 2 +- tools/objtool/arch/x86/special.c | 2 +- tools/objtool/builtin-check.c | 156 +++++++++++++++++++++++++++++++++++++++++++++----------- tools/objtool/builtin-orc.c | 73 -------------------------- tools/objtool/check.c | 463 ++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++--------------------------------------------------------------------------- tools/objtool/elf.c | 211 ++++++++++++++++++++++++++++++++++++++++++++++++--------------------------- tools/objtool/include/objtool/builtin.h | 34 +++++++++++-- tools/objtool/include/objtool/elf.h | 16 ++++-- tools/objtool/include/objtool/warn.h | 35 +++++++------ tools/objtool/objtool.c | 103 ++----------------------------------- tools/objtool/weak.c | 9 +--- 34 files changed, 959 insertions(+), 684 deletions(-) create mode 100755 scripts/objdump-func rename tools/objtool/Documentation/{stack-validation.txt => objtool.txt} (80%) delete mode 100644 tools/objtool/builtin-orc.c Thanks, Ingo ^ permalink raw reply [flat|nested] 7+ messages in thread
* Re: [GIT PULL] objtool changes for v5.19 2022-05-24 5:34 ` Ingo Molnar @ 2022-05-24 6:02 ` Ingo Molnar 2022-05-24 17:53 ` Linus Torvalds 0 siblings, 1 reply; 7+ messages in thread From: Ingo Molnar @ 2022-05-24 6:02 UTC (permalink / raw) To: Linus Torvalds Cc: linux-kernel, Peter Zijlstra, Josh Poimboeuf, Thomas Gleixner, Borislav Petkov, Andrew Morton * Ingo Molnar <mingo@kernel.org> wrote: > 34 files changed, 959 insertions(+), 684 deletions(-) Note that with your latest tree you'll get 3 new conflicts: CONFLICT (content): Merge conflict in scripts/link-vmlinux.sh CONFLICT (content): Merge conflict in scripts/Makefile.build CONFLICT (content): Merge conflict in arch/x86/Kconfig If you want to double check, you can find our resolution in tip:x86/merge: a1df7cc57786 Merge branch 'objtool/core' into x86/merge, to resolve conflicts At: git://git.kernel.org/pub/scm/linux/kernel/git/tip/tip.git x86/merge # INTERNAL MERGE TREE, DO NOT PULL Here's the merge description: =================== The following commits between objtool/core and various x86 branches conflict: 968b493173ac x86/mm: Make DMA memory shared for TD guest 77a512e35db7 x86/boot: Avoid #VE during boot for TDX platforms 65fab5bc033a x86/tdx: Exclude shared bit from __PHYSICAL_MASK 41394e33f3a0 x86/tdx: Extend the confidential computing API to support TDX guests 59bd54a84d15 x86/tdx: Detect running as a TDX guest in early boot dbae0a934f09 x86/cpu: Remove CONFIG_X86_SMAP and "nosmap" and: 753da4179d08 objtool: Remove --lto and --vmlinux in favor of --link 489e355b4225 objtool: Add HAVE_NOINSTR_VALIDATION 0f620cefd775 objtool: Rename "VMLINUX_VALIDATION" -> "NOINSTR_VALIDATION" 22102f4559be objtool: Make noinstr hacks optional 4ab7674f5951 objtool: Make jump label hack optional 26e176896a5b objtool: Make static call annotation optional 720644749647 objtool: Make stack validation frame-pointer-specific 03f16cd020eb objtool: Add CONFIG_OBJTOOL 7dce62041ac3 objtool: Make stack validation optional b51277eb9775 objtool: Ditch subcommands 2daf7faba7de objtool: Reorganize cmdline options 4cdfc11b2836 x86/Kconfig: fix the spelling of 'becoming' in X86_KERNEL_IBT config 4a5de9b76fcb objtool: Enable unreachable warnings for CLANG LTO Resolve them: - overlapping modifications - modifying removed functionality Conflicts: arch/x86/Kconfig scripts/Makefile.build scripts/link-vmlinux.sh =================== Thanks, Ingo ^ permalink raw reply [flat|nested] 7+ messages in thread
* Re: [GIT PULL] objtool changes for v5.19 2022-05-24 6:02 ` Ingo Molnar @ 2022-05-24 17:53 ` Linus Torvalds 2022-05-24 18:08 ` Peter Zijlstra 0 siblings, 1 reply; 7+ messages in thread From: Linus Torvalds @ 2022-05-24 17:53 UTC (permalink / raw) To: Ingo Molnar Cc: Linux Kernel Mailing List, Peter Zijlstra, Josh Poimboeuf, Thomas Gleixner, Borislav Petkov, Andrew Morton [-- Attachment #1: Type: text/plain, Size: 1060 bytes --] On Mon, May 23, 2022 at 11:02 PM Ingo Molnar <mingo@kernel.org> wrote: > > Note that with your latest tree you'll get 3 new conflicts: No problem, but the conflicts did make something clear: the objtool code should just get rid of the "--uaccess" flag that is now unconditional when CONFIG_X86_SMAP has been removed. I didn't actually do that, and instead just did the mindless merge conflict resolution, but it might be a good idea. See commit dbae0a934f09 ("x86/cpu: Remove CONFIG_X86_SMAP and 'nosmap'") for when it was removed. Josh? The patch *might* be something like the attached, but this is (a) untested and (b) that 'opts.noinstr' part of the patch is a bit dodgy (ie I made the previous 'if' unconditional, but then changed the follow 'else if ()' to just 'if ()' instead of deleting it, which is what "uaccess is always set" would technically have done. Again: I did *not* do this as part of the merge, the attached patch is just a suggestion of something that I think should now be done after the merge. Hmm? Linus [-- Attachment #2: patch.diff --] [-- Type: text/x-patch, Size: 4744 bytes --] scripts/Makefile.build | 1 - scripts/link-vmlinux.sh | 2 -- tools/objtool/arch/x86/special.c | 8 ++------ tools/objtool/builtin-check.c | 4 +--- tools/objtool/check.c | 30 +++++++++++++----------------- tools/objtool/include/objtool/builtin.h | 1 - 6 files changed, 16 insertions(+), 30 deletions(-) diff --git a/scripts/Makefile.build b/scripts/Makefile.build index f89d3fcff39f..4d96dea9ff31 100644 --- a/scripts/Makefile.build +++ b/scripts/Makefile.build @@ -236,7 +236,6 @@ objtool_args = \ $(if $(CONFIG_SLS), --sls) \ $(if $(CONFIG_STACK_VALIDATION), --stackval) \ $(if $(CONFIG_HAVE_STATIC_CALL_INLINE), --static-call) \ - --uaccess \ $(if $(linked-object), --link) \ $(if $(part-of-module), --module) \ $(if $(CONFIG_GCOV_KERNEL), --no-unreachable) diff --git a/scripts/link-vmlinux.sh b/scripts/link-vmlinux.sh index d7f26f02f142..add98ce9e1e5 100755 --- a/scripts/link-vmlinux.sh +++ b/scripts/link-vmlinux.sh @@ -152,8 +152,6 @@ objtool_link() if is_enabled CONFIG_HAVE_STATIC_CALL_INLINE; then objtoolopt="${objtoolopt} --static-call" fi - - objtoolopt="${objtoolopt} --uaccess" fi if is_enabled CONFIG_NOINSTR_VALIDATION; then diff --git a/tools/objtool/arch/x86/special.c b/tools/objtool/arch/x86/special.c index 7c97b7391279..b070edb5fd8f 100644 --- a/tools/objtool/arch/x86/special.c +++ b/tools/objtool/arch/x86/special.c @@ -12,18 +12,14 @@ void arch_handle_alternative(unsigned short feature, struct special_alt *alt) switch (feature) { case X86_FEATURE_SMAP: /* - * If UACCESS validation is enabled; force that alternative; - * otherwise force it the other way. + * Force the uaccess alternative. * * What we want to avoid is having both the original and the * alternative code flow at the same time, in that case we can * find paths that see the STAC but take the NOP instead of * CLAC and the other way around. */ - if (opts.uaccess) - alt->skip_orig = true; - else - alt->skip_alt = true; + alt->skip_orig = true; break; case X86_FEATURE_POPCNT: /* diff --git a/tools/objtool/builtin-check.c b/tools/objtool/builtin-check.c index f4c3a5091737..ae28905dc17a 100644 --- a/tools/objtool/builtin-check.c +++ b/tools/objtool/builtin-check.c @@ -71,7 +71,6 @@ const struct option check_options[] = { OPT_BOOLEAN('l', "sls", &opts.sls, "validate straight-line-speculation mitigations"), OPT_BOOLEAN('s', "stackval", &opts.stackval, "validate frame pointer rules"), OPT_BOOLEAN('t', "static-call", &opts.static_call, "annotate static calls"), - OPT_BOOLEAN('u', "uaccess", &opts.uaccess, "validate uaccess rules for SMAP"), OPT_CALLBACK_OPTARG(0, "dump", NULL, NULL, "orc", "dump metadata", parse_dump), OPT_GROUP("Options:"), @@ -125,8 +124,7 @@ static bool opts_valid(void) opts.retpoline || opts.sls || opts.stackval || - opts.static_call || - opts.uaccess) { + opts.static_call) { if (opts.dump_orc) { ERROR("--dump can't be combined with other options"); return false; diff --git a/tools/objtool/check.c b/tools/objtool/check.c index 190b2f6e360a..86f01f86cd13 100644 --- a/tools/objtool/check.c +++ b/tools/objtool/check.c @@ -1030,9 +1030,6 @@ static void add_uaccess_safe(struct objtool_file *file) struct symbol *func; const char **name; - if (!opts.uaccess) - return; - for (name = uaccess_safe_builtin; *name; name++) { func = find_symbol_by_name(file->elf, *name); if (!func) @@ -3919,25 +3916,24 @@ int check(struct objtool_file *file) warnings += ret; } - if (opts.stackval || opts.orc || opts.uaccess) { - ret = validate_functions(file); - if (ret < 0) - goto out; - warnings += ret; + ret = validate_functions(file); + if (ret < 0) + goto out; + warnings += ret; - ret = validate_unwind_hints(file, NULL); + ret = validate_unwind_hints(file, NULL); + if (ret < 0) + goto out; + warnings += ret; + + if (!warnings) { + ret = validate_reachable_instructions(file); if (ret < 0) goto out; warnings += ret; + } - if (!warnings) { - ret = validate_reachable_instructions(file); - if (ret < 0) - goto out; - warnings += ret; - } - - } else if (opts.noinstr) { + if (opts.noinstr) { ret = validate_noinstr_sections(file); if (ret < 0) goto out; diff --git a/tools/objtool/include/objtool/builtin.h b/tools/objtool/include/objtool/builtin.h index 280ea18b7f2b..8054f3dc7712 100644 --- a/tools/objtool/include/objtool/builtin.h +++ b/tools/objtool/include/objtool/builtin.h @@ -22,7 +22,6 @@ struct opts { bool sls; bool stackval; bool static_call; - bool uaccess; /* options: */ bool backtrace; ^ permalink raw reply related [flat|nested] 7+ messages in thread
* Re: [GIT PULL] objtool changes for v5.19 2022-05-24 17:53 ` Linus Torvalds @ 2022-05-24 18:08 ` Peter Zijlstra 2022-05-24 18:14 ` Josh Poimboeuf 0 siblings, 1 reply; 7+ messages in thread From: Peter Zijlstra @ 2022-05-24 18:08 UTC (permalink / raw) To: Linus Torvalds Cc: Ingo Molnar, Linux Kernel Mailing List, Josh Poimboeuf, Thomas Gleixner, Borislav Petkov, Andrew Morton On Tue, May 24, 2022 at 10:53:40AM -0700, Linus Torvalds wrote: > On Mon, May 23, 2022 at 11:02 PM Ingo Molnar <mingo@kernel.org> wrote: > > > > Note that with your latest tree you'll get 3 new conflicts: > > No problem, but the conflicts did make something clear: the objtool > code should just get rid of the "--uaccess" flag that is now > unconditional when CONFIG_X86_SMAP has been removed. > > I didn't actually do that, and instead just did the mindless merge > conflict resolution, but it might be a good idea. Yes, I think there is patch pending for that, but given the total merge pain we already had, I was waiting for all the dust to settle before taking it further. ^ permalink raw reply [flat|nested] 7+ messages in thread
* Re: [GIT PULL] objtool changes for v5.19 2022-05-24 18:08 ` Peter Zijlstra @ 2022-05-24 18:14 ` Josh Poimboeuf 0 siblings, 0 replies; 7+ messages in thread From: Josh Poimboeuf @ 2022-05-24 18:14 UTC (permalink / raw) To: Peter Zijlstra Cc: Linus Torvalds, Ingo Molnar, Linux Kernel Mailing List, Thomas Gleixner, Borislav Petkov, Andrew Morton On Tue, May 24, 2022 at 08:08:05PM +0200, Peter Zijlstra wrote: > On Tue, May 24, 2022 at 10:53:40AM -0700, Linus Torvalds wrote: > > On Mon, May 23, 2022 at 11:02 PM Ingo Molnar <mingo@kernel.org> wrote: > > > > > > Note that with your latest tree you'll get 3 new conflicts: > > > > No problem, but the conflicts did make something clear: the objtool > > code should just get rid of the "--uaccess" flag that is now > > unconditional when CONFIG_X86_SMAP has been removed. > > > > I didn't actually do that, and instead just did the mindless merge > > conflict resolution, but it might be a good idea. > > Yes, I think there is patch pending for that, but given the total merge > pain we already had, I was waiting for all the dust to settle before > taking it further. Actually I think we should go the other direction by keeping '--uaccess' and adding CONFIG_HAVE_UACCESS_VALIDATION or so. The main point of that objtool rewrite was to make all the features modular so other arches could port them piecemeal. -- Josh ^ permalink raw reply [flat|nested] 7+ messages in thread
* Re: [GIT PULL] objtool changes for v5.19 2022-05-23 16:32 [GIT PULL] objtool changes for v5.19 Ingo Molnar 2022-05-24 5:34 ` Ingo Molnar @ 2022-05-24 19:53 ` pr-tracker-bot 1 sibling, 0 replies; 7+ messages in thread From: pr-tracker-bot @ 2022-05-24 19:53 UTC (permalink / raw) To: Ingo Molnar Cc: Linus Torvalds, linux-kernel, Peter Zijlstra, Josh Poimboeuf, Thomas Gleixner, Borislav Petkov, Andrew Morton The pull request you sent on Mon, 23 May 2022 18:32:36 +0200: > git://git.kernel.org/pub/scm/linux/kernel/git/tip/tip.git objtool-core-2022-05-23 has been merged into torvalds/linux.git: https://git.kernel.org/torvalds/c/22922deae13fc8d3769790c2eb388e9afce9771d Thank you! -- Deet-doot-dot, I am a bot. https://korg.docs.kernel.org/prtracker.html ^ permalink raw reply [flat|nested] 7+ messages in thread
end of thread, other threads:[~2022-05-24 19:54 UTC | newest] Thread overview: 7+ messages (download: mbox.gz / follow: Atom feed) -- links below jump to the message on this page -- 2022-05-23 16:32 [GIT PULL] objtool changes for v5.19 Ingo Molnar 2022-05-24 5:34 ` Ingo Molnar 2022-05-24 6:02 ` Ingo Molnar 2022-05-24 17:53 ` Linus Torvalds 2022-05-24 18:08 ` Peter Zijlstra 2022-05-24 18:14 ` Josh Poimboeuf 2022-05-24 19:53 ` pr-tracker-bot
This is an external index of several public inboxes, see mirroring instructions on how to clone and mirror all data and code used by this external index.