mirror of
https://github.com/AuxXxilium/linux_dsm_epyc7002.git
synced 2024-11-30 11:36:40 +07:00
26660a4046
Pull 'objtool' stack frame validation from Ingo Molnar: "This tree adds a new kernel build-time object file validation feature (ONFIG_STACK_VALIDATION=y): kernel stack frame correctness validation. It was written by and is maintained by Josh Poimboeuf. The motivation: there's a category of hard to find kernel bugs, most of them in assembly code (but also occasionally in C code), that degrades the quality of kernel stack dumps/backtraces. These bugs are hard to detect at the source code level. Such bugs result in incorrect/incomplete backtraces most of time - but can also in some rare cases result in crashes or other undefined behavior. The build time correctness checking is done via the new 'objtool' user-space utility that was written for this purpose and which is hosted in the kernel repository in tools/objtool/. The tool's (very simple) UI and source code design is shaped after Git and perf and shares quite a bit of infrastructure with tools/perf (which tooling infrastructure sharing effort got merged via perf and is already upstream). Objtool follows the well-known kernel coding style. Objtool does not try to check .c or .S files, it instead analyzes the resulting .o generated machine code from first principles: it decodes the instruction stream and interprets it. (Right now objtool supports the x86-64 architecture.) From tools/objtool/Documentation/stack-validation.txt: "The kernel CONFIG_STACK_VALIDATION option enables a host tool named objtool which runs at compile time. It has a "check" subcommand which analyzes every .o file and ensures the validity of its stack metadata. It enforces a set of rules on asm code and C inline assembly code so that stack traces can be reliable. Currently it only checks frame pointer usage, but there are plans to add CFI validation for C files and CFI generation for asm files. For each function, it recursively follows all possible code paths and validates the correct frame pointer state at each instruction. It also follows code paths involving special sections, like .altinstructions, __jump_table, and __ex_table, which can add alternative execution paths to a given instruction (or set of instructions). Similarly, it knows how to follow switch statements, for which gcc sometimes uses jump tables." When this new kernel option is enabled (it's disabled by default), the tool, if it finds any suspicious assembly code pattern, outputs warnings in compiler warning format: warning: objtool: rtlwifi_rate_mapping()+0x2e7: frame pointer state mismatch warning: objtool: cik_tiling_mode_table_init()+0x6ce: call without frame pointer save/setup warning: objtool:__schedule()+0x3c0: duplicate frame pointer save warning: objtool:__schedule()+0x3fd: sibling call from callable instruction with changed frame pointer ... so that scripts that pick up compiler warnings will notice them. All known warnings triggered by the tool are fixed by the tree, most of the commits in fact prepare the kernel to be warning-free. Most of them are bugfixes or cleanups that stand on their own, but there are also some annotations of 'special' stack frames for justified cases such entries to JIT-ed code (BPF) or really special boot time code. There are two other long-term motivations behind this tool as well: - To improve the quality and reliability of kernel stack frames, so that they can be used for optimized live patching. - To create independent infrastructure to check the correctness of CFI stack frames at build time. CFI debuginfo is notoriously unreliable and we cannot use it in the kernel as-is without extra checking done both on the kernel side and on the build side. The quality of kernel stack frames matters to debuggability as well, so IMO we can merge this without having to consider the live patching or CFI debuginfo angle" * 'core-objtool-for-linus' of git://git.kernel.org/pub/scm/linux/kernel/git/tip/tip: (52 commits) objtool: Only print one warning per function objtool: Add several performance improvements tools: Copy hashtable.h into tools directory objtool: Fix false positive warnings for functions with multiple switch statements objtool: Rename some variables and functions objtool: Remove superflous INIT_LIST_HEAD objtool: Add helper macros for traversing instructions objtool: Fix false positive warnings related to sibling calls objtool: Compile with debugging symbols objtool: Detect infinite recursion objtool: Prevent infinite recursion in noreturn detection objtool: Detect and warn if libelf is missing and don't break the build tools: Support relative directory path for 'O=' objtool: Support CROSS_COMPILE x86/asm/decoder: Use explicitly signed chars objtool: Enable stack metadata validation on 64-bit x86 objtool: Add CONFIG_STACK_VALIDATION option objtool: Add tool to perform compile-time stack metadata validation x86/kprobes: Mark kretprobe_trampoline() stack frame as non-standard sched: Always inline context_switch() ...
164 lines
4.8 KiB
Makefile
164 lines
4.8 KiB
Makefile
# Some of the tools (perf) use same make variables
|
|
# as in kernel build.
|
|
export srctree=
|
|
export objtree=
|
|
|
|
include scripts/Makefile.include
|
|
|
|
help:
|
|
@echo 'Possible targets:'
|
|
@echo ''
|
|
@echo ' acpi - ACPI tools'
|
|
@echo ' cgroup - cgroup tools'
|
|
@echo ' cpupower - a tool for all things x86 CPU power'
|
|
@echo ' firewire - the userspace part of nosy, an IEEE-1394 traffic sniffer'
|
|
@echo ' freefall - laptop accelerometer program for disk protection'
|
|
@echo ' gpio - GPIO tools'
|
|
@echo ' hv - tools used when in Hyper-V clients'
|
|
@echo ' iio - IIO tools'
|
|
@echo ' lguest - a minimal 32-bit x86 hypervisor'
|
|
@echo ' net - misc networking tools'
|
|
@echo ' perf - Linux performance measurement and analysis tool'
|
|
@echo ' selftests - various kernel selftests'
|
|
@echo ' spi - spi tools'
|
|
@echo ' objtool - an ELF object analysis tool'
|
|
@echo ' tmon - thermal monitoring and tuning tool'
|
|
@echo ' turbostat - Intel CPU idle stats and freq reporting tool'
|
|
@echo ' usb - USB testing tools'
|
|
@echo ' virtio - vhost test module'
|
|
@echo ' vm - misc vm tools'
|
|
@echo ' x86_energy_perf_policy - Intel energy policy tool'
|
|
@echo ''
|
|
@echo 'You can do:'
|
|
@echo ' $$ make -C tools/ <tool>_install'
|
|
@echo ''
|
|
@echo ' from the kernel command line to build and install one of'
|
|
@echo ' the tools above'
|
|
@echo ''
|
|
@echo ' $$ make tools/all'
|
|
@echo ''
|
|
@echo ' builds all tools.'
|
|
@echo ''
|
|
@echo ' $$ make tools/install'
|
|
@echo ''
|
|
@echo ' installs all tools.'
|
|
@echo ''
|
|
@echo 'Cleaning targets:'
|
|
@echo ''
|
|
@echo ' all of the above with the "_clean" string appended cleans'
|
|
@echo ' the respective build directory.'
|
|
@echo ' clean: a summary clean target to clean _all_ folders'
|
|
|
|
acpi: FORCE
|
|
$(call descend,power/$@)
|
|
|
|
cpupower: FORCE
|
|
$(call descend,power/$@)
|
|
|
|
cgroup firewire hv guest spi usb virtio vm net iio gpio objtool: FORCE
|
|
$(call descend,$@)
|
|
|
|
liblockdep: FORCE
|
|
$(call descend,lib/lockdep)
|
|
|
|
libapi: FORCE
|
|
$(call descend,lib/api)
|
|
|
|
# The perf build does not follow the descend function setup,
|
|
# invoking it via it's own make rule.
|
|
PERF_O = $(if $(O),$(O)/tools/perf,)
|
|
|
|
perf: FORCE
|
|
$(Q)mkdir -p $(PERF_O) .
|
|
$(Q)$(MAKE) --no-print-directory -C perf O=$(PERF_O) subdir=
|
|
|
|
selftests: FORCE
|
|
$(call descend,testing/$@)
|
|
|
|
turbostat x86_energy_perf_policy: FORCE
|
|
$(call descend,power/x86/$@)
|
|
|
|
tmon: FORCE
|
|
$(call descend,thermal/$@)
|
|
|
|
freefall: FORCE
|
|
$(call descend,laptop/$@)
|
|
|
|
all: acpi cgroup cpupower hv firewire lguest \
|
|
perf selftests turbostat usb \
|
|
virtio vm net x86_energy_perf_policy \
|
|
tmon freefall objtool
|
|
|
|
acpi_install:
|
|
$(call descend,power/$(@:_install=),install)
|
|
|
|
cpupower_install:
|
|
$(call descend,power/$(@:_install=),install)
|
|
|
|
cgroup_install firewire_install hv_install lguest_install perf_install usb_install virtio_install vm_install net_install objtool_install:
|
|
$(call descend,$(@:_install=),install)
|
|
|
|
selftests_install:
|
|
$(call descend,testing/$(@:_install=),install)
|
|
|
|
turbostat_install x86_energy_perf_policy_install:
|
|
$(call descend,power/x86/$(@:_install=),install)
|
|
|
|
tmon_install:
|
|
$(call descend,thermal/$(@:_install=),install)
|
|
|
|
freefall_install:
|
|
$(call descend,laptop/$(@:_install=),install)
|
|
|
|
install: acpi_install cgroup_install cpupower_install hv_install firewire_install lguest_install \
|
|
perf_install selftests_install turbostat_install usb_install \
|
|
virtio_install vm_install net_install x86_energy_perf_policy_install \
|
|
tmon_install freefall_install objtool_install
|
|
|
|
acpi_clean:
|
|
$(call descend,power/acpi,clean)
|
|
|
|
cpupower_clean:
|
|
$(call descend,power/cpupower,clean)
|
|
|
|
cgroup_clean hv_clean firewire_clean lguest_clean spi_clean usb_clean virtio_clean vm_clean net_clean iio_clean gpio_clean objtool_clean:
|
|
$(call descend,$(@:_clean=),clean)
|
|
|
|
liblockdep_clean:
|
|
$(call descend,lib/lockdep,clean)
|
|
|
|
libapi_clean:
|
|
$(call descend,lib/api,clean)
|
|
|
|
libbpf_clean:
|
|
$(call descend,lib/bpf,clean)
|
|
|
|
libsubcmd_clean:
|
|
$(call descend,lib/subcmd,clean)
|
|
|
|
perf_clean:
|
|
$(call descend,$(@:_clean=),clean)
|
|
|
|
selftests_clean:
|
|
$(call descend,testing/$(@:_clean=),clean)
|
|
|
|
turbostat_clean x86_energy_perf_policy_clean:
|
|
$(call descend,power/x86/$(@:_clean=),clean)
|
|
|
|
tmon_clean:
|
|
$(call descend,thermal/tmon,clean)
|
|
|
|
freefall_clean:
|
|
$(call descend,laptop/freefall,clean)
|
|
|
|
build_clean:
|
|
$(call descend,build,clean)
|
|
|
|
clean: acpi_clean cgroup_clean cpupower_clean hv_clean firewire_clean lguest_clean \
|
|
perf_clean selftests_clean turbostat_clean spi_clean usb_clean virtio_clean \
|
|
vm_clean net_clean iio_clean x86_energy_perf_policy_clean tmon_clean \
|
|
freefall_clean build_clean libbpf_clean libsubcmd_clean liblockdep_clean \
|
|
gpio_clean objtool_clean
|
|
|
|
.PHONY: FORCE
|