[<prev] [next>] [thread-next>] [day] [month] [year] [list]
Message-ID: <20240730005433.3559731-1-song@kernel.org>
Date: Mon, 29 Jul 2024 17:54:30 -0700
From: Song Liu <song@...nel.org>
To: live-patching@...r.kernel.org,
linux-kernel@...r.kernel.org,
linux-trace-kernel@...r.kernel.org
Cc: jpoimboe@...nel.org,
jikos@...nel.org,
mbenes@...e.cz,
pmladek@...e.com,
joe.lawrence@...hat.com,
nathan@...nel.org,
morbo@...gle.com,
justinstitt@...gle.com,
mcgrof@...nel.org,
thunder.leizhen@...wei.com,
kees@...nel.org,
kernel-team@...a.com,
song@...nel.org,
mmaurer@...gle.com,
samitolvanen@...gle.com,
mhiramat@...nel.org,
rostedt@...dmis.org
Subject: [PATCH 0/3] Fix kallsyms with CONFIG_LTO_CLANG
With CONFIG_LTO_CLANG, the compiler/linker adds .llvm.<hash> suffix to
local symbols to avoid duplications. Existing scripts/kallsyms sorts
symbols without .llvm.<hash> suffix. However, this causes quite some
issues later on. Some users of kallsyms, such as livepatch, have to match
symbols exactly; while other users, such as kprobe, would match symbols
without the suffix.
Address this by sorting full symbols (with .llvm.<hash>) at build time, and
split kallsyms APIs to explicitly match full symbols or without suffix.
Specifically, exiting APIs will match symbols exactly. Two new APIs are
added to match symbols with suffix. Use the new APIs in tracing/kprobes.
Song Liu (3):
kallsyms: Do not cleanup .llvm.<hash> suffix before sorting symbols
kallsyms: Add APIs to match symbol without .llmv.<hash> suffix.
tracing/kprobes: Use APIs that matches symbols with .llvm.<hash>
suffix
include/linux/kallsyms.h | 14 +++++++
kernel/kallsyms.c | 83 ++++++++++++++++++++++++++-----------
kernel/kallsyms_selftest.c | 22 +---------
kernel/trace/trace_kprobe.c | 10 ++++-
scripts/kallsyms.c | 30 +-------------
scripts/link-vmlinux.sh | 4 --
6 files changed, 83 insertions(+), 80 deletions(-)
--
2.43.0
Powered by blists - more mailing lists