summaryrefslogtreecommitdiffstats
path: root/Documentation/kbuild
diff options
context:
space:
mode:
authorNick Desaulniers <ndesaulniers@google.com>2021-10-04 18:29:33 +0200
committerKees Cook <keescook@chromium.org>2021-10-04 19:58:25 +0200
commit6eb4bd92c1cedcaadd65868b7ade396b422be4be (patch)
tree54abcc94b0704682424904d819b251f3cf48dda9 /Documentation/kbuild
parentgcc-plugins: remove support for GCC 4.9 and older (diff)
downloadlinux-6eb4bd92c1cedcaadd65868b7ade396b422be4be.tar.xz
linux-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 'Documentation/kbuild')
0 files changed, 0 insertions, 0 deletions