diff options
author | Nick Desaulniers <ndesaulniers@google.com> | 2021-10-04 09:29:33 -0700 |
---|---|---|
committer | Kees Cook <keescook@chromium.org> | 2021-10-04 10:58:25 -0700 |
commit | 6eb4bd92c1cedcaadd65868b7ade396b422be4be (patch) | |
tree | 54abcc94b0704682424904d819b251f3cf48dda9 /security/Kconfig.hardening | |
parent | 4c78c7271f34befd96d2d221c8c356be1bbf132e (diff) | |
download | lwn-6eb4bd92c1cedcaadd65868b7ade396b422be4be.tar.gz lwn-6eb4bd92c1cedcaadd65868b7ade396b422be4be.zip |
kallsyms: strip LTO suffixes from static functions
Similar to:
commit 8b8e6b5d3b01 ("kallsyms: strip ThinLTO hashes from static
functions")
It's very common for compilers to modify the symbol name for static
functions as part of optimizing transformations. That makes hooking
static functions (that weren't inlined or DCE'd) with kprobes difficult.
LLVM has yet another name mangling scheme used by thin LTO.
Combine handling of the various schemes by truncating after the first
'.'. Strip off these suffixes so that we can continue to hook such
static functions. Clang releases prior to clang-13 would use '$'
instead of '.'
Link: https://reviews.llvm.org/rGc6e5c4654bd5045fe22a1a52779e48e2038a404c
Reported-by: KE.LI(Lieke) <like1@oppo.com>
Suggested-by: Nathan Chancellor <nathan@kernel.org>
Suggested-by: Padmanabha Srinivasaiah <treasure4paddy@gmail.com>
Suggested-by: Sami Tolvanen <samitolvanen@google.com>
Reviewed-by: Nathan Chancellor <nathan@kernel.org>
Reviewed-by: Fangrui Song <maskray@google.com>
Reviewed-by: Sami Tolvanen <samitolvanen@google.com>
Signed-off-by: Nick Desaulniers <ndesaulniers@google.com>
Signed-off-by: Kees Cook <keescook@chromium.org>
Link: https://lore.kernel.org/r/20211004162936.21961-1-ndesaulniers@google.com
Diffstat (limited to 'security/Kconfig.hardening')
0 files changed, 0 insertions, 0 deletions