summaryrefslogtreecommitdiffstats
path: root/security
diff options
context:
space:
mode:
authorNick Desaulniers <ndesaulniers@google.com>2021-10-04 09:29:33 -0700
committerKees Cook <keescook@chromium.org>2021-10-04 10:58:25 -0700
commit6eb4bd92c1cedcaadd65868b7ade396b422be4be (patch)
tree54abcc94b0704682424904d819b251f3cf48dda9 /security
parent4c78c7271f34befd96d2d221c8c356be1bbf132e (diff)
downloadlinux-6eb4bd92c1cedcaadd65868b7ade396b422be4be.tar.bz2
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')
0 files changed, 0 insertions, 0 deletions