mirror of
https://git.kernel.org/pub/scm/linux/kernel/git/torvalds/linux.git
synced 2025-01-23 16:53:58 -05:00
Misc fixes to kprobes and the faddr2line script, plus a cleanup.
Signed-off-by: Ingo Molnar <mingo@kernel.org> -----BEGIN PGP SIGNATURE----- iQJFBAABCgAvFiEEBpT5eoXrXCwVQwEKEnMQ0APhK1gFAmLuu5MRHG1pbmdvQGtl cm5lbC5vcmcACgkQEnMQ0APhK1gFbA//ZppMR0/26/d+KqhdbVND6wtuTzGb5krZ m3QynlRQ+x7CZJNJeiNSTo/Dup/KwBUpJFT5sKLtpfOQILxlEt0hdYMiD+/oxgxd K0Vb0QrZhwFCju+OpcDAVlWNcQ5P8MMdoGUkOr5ekZ9FFalabW+bVUuM2Yf0Cok8 e20MGoZa2jcd+AZkp9jPUtCTURpW3Ew1WcVuJIgLH3EUMNrQNiPdia6xBzFyOPAw L0G14RDkd/POGF90dUGY1Ta4WeQCNYp2Rgu5DLo6l3eJJ/oeqoIUBUoNRT9AOJHH 0SVNHkrrNlRJe9HD/Jdc6RVBMM+FFNU4rw1uxOPU2OtG0MyMsj39Nzw+xmvB9QsG mwnMoeeDOJmFRnAyhETe4meR5mA8cPQDoNNlHL51I9JTJTUutIrfd+gQIgVgYrM2 oVfLW7Y0Eew8qYbAd2kfGnFNHDSH90RHG4beTz4zW3y4shembKhiPU7bgJ8lkke7 u4NgDOE+qTmtC1DznuV4Av8/27W6OMt/j1IWeR78IN7YBko99Ekog3zsWrAJgA/E Y08JVrUpUU47tMl4uC9Y0AUvm1Tb2ZyDqcdlEEzF9txtdNa6cAJtJkPaO6nUrr4+ qLCbhBBADP+oQNESi6vRHRmxmk5Z/m2ybfnAuYNNraWY01Imp4kNvLFvB01ARGaF Qin7dCjqz+E= =S41z -----END PGP SIGNATURE----- Merge tag 'perf-urgent-2022-08-06' of git://git.kernel.org/pub/scm/linux/kernel/git/tip/tip Pull perf fixes from Ingo Molnar: "Misc fixes to kprobes and the faddr2line script, plus a cleanup" * tag 'perf-urgent-2022-08-06' of git://git.kernel.org/pub/scm/linux/kernel/git/tip/tip: perf/core: Fix ';;' typo scripts/faddr2line: Add CONFIG_DEBUG_INFO check scripts/faddr2line: Fix vmlinux detection on arm64 x86/kprobes: Update kcb status flag after singlestepping kprobes: Forbid probing on trampoline and BPF code areas
This commit is contained in:
commit
592d8362bc
4 changed files with 20 additions and 10 deletions
|
@ -814,16 +814,20 @@ set_current_kprobe(struct kprobe *p, struct pt_regs *regs,
|
||||||
static void kprobe_post_process(struct kprobe *cur, struct pt_regs *regs,
|
static void kprobe_post_process(struct kprobe *cur, struct pt_regs *regs,
|
||||||
struct kprobe_ctlblk *kcb)
|
struct kprobe_ctlblk *kcb)
|
||||||
{
|
{
|
||||||
if ((kcb->kprobe_status != KPROBE_REENTER) && cur->post_handler) {
|
|
||||||
kcb->kprobe_status = KPROBE_HIT_SSDONE;
|
|
||||||
cur->post_handler(cur, regs, 0);
|
|
||||||
}
|
|
||||||
|
|
||||||
/* Restore back the original saved kprobes variables and continue. */
|
/* Restore back the original saved kprobes variables and continue. */
|
||||||
if (kcb->kprobe_status == KPROBE_REENTER)
|
if (kcb->kprobe_status == KPROBE_REENTER) {
|
||||||
|
/* This will restore both kcb and current_kprobe */
|
||||||
restore_previous_kprobe(kcb);
|
restore_previous_kprobe(kcb);
|
||||||
else
|
} else {
|
||||||
|
/*
|
||||||
|
* Always update the kcb status because
|
||||||
|
* reset_curent_kprobe() doesn't update kcb.
|
||||||
|
*/
|
||||||
|
kcb->kprobe_status = KPROBE_HIT_SSDONE;
|
||||||
|
if (cur->post_handler)
|
||||||
|
cur->post_handler(cur, regs, 0);
|
||||||
reset_current_kprobe();
|
reset_current_kprobe();
|
||||||
|
}
|
||||||
}
|
}
|
||||||
NOKPROBE_SYMBOL(kprobe_post_process);
|
NOKPROBE_SYMBOL(kprobe_post_process);
|
||||||
|
|
||||||
|
|
|
@ -4457,7 +4457,7 @@ int perf_event_read_local(struct perf_event *event, u64 *value,
|
||||||
|
|
||||||
*value = local64_read(&event->count);
|
*value = local64_read(&event->count);
|
||||||
if (enabled || running) {
|
if (enabled || running) {
|
||||||
u64 __enabled, __running, __now;;
|
u64 __enabled, __running, __now;
|
||||||
|
|
||||||
calc_timer_values(event, &__now, &__enabled, &__running);
|
calc_timer_values(event, &__now, &__enabled, &__running);
|
||||||
if (enabled)
|
if (enabled)
|
||||||
|
|
|
@ -1560,7 +1560,8 @@ static int check_kprobe_address_safe(struct kprobe *p,
|
||||||
preempt_disable();
|
preempt_disable();
|
||||||
|
|
||||||
/* Ensure it is not in reserved area nor out of text */
|
/* Ensure it is not in reserved area nor out of text */
|
||||||
if (!kernel_text_address((unsigned long) p->addr) ||
|
if (!(core_kernel_text((unsigned long) p->addr) ||
|
||||||
|
is_module_text_address((unsigned long) p->addr)) ||
|
||||||
within_kprobe_blacklist((unsigned long) p->addr) ||
|
within_kprobe_blacklist((unsigned long) p->addr) ||
|
||||||
jump_label_text_reserved(p->addr, p->addr) ||
|
jump_label_text_reserved(p->addr, p->addr) ||
|
||||||
static_call_text_reserved(p->addr, p->addr) ||
|
static_call_text_reserved(p->addr, p->addr) ||
|
||||||
|
|
|
@ -61,6 +61,7 @@ die() {
|
||||||
READELF="${CROSS_COMPILE:-}readelf"
|
READELF="${CROSS_COMPILE:-}readelf"
|
||||||
ADDR2LINE="${CROSS_COMPILE:-}addr2line"
|
ADDR2LINE="${CROSS_COMPILE:-}addr2line"
|
||||||
AWK="awk"
|
AWK="awk"
|
||||||
|
GREP="grep"
|
||||||
|
|
||||||
command -v ${AWK} >/dev/null 2>&1 || die "${AWK} isn't installed"
|
command -v ${AWK} >/dev/null 2>&1 || die "${AWK} isn't installed"
|
||||||
command -v ${READELF} >/dev/null 2>&1 || die "${READELF} isn't installed"
|
command -v ${READELF} >/dev/null 2>&1 || die "${READELF} isn't installed"
|
||||||
|
@ -112,7 +113,9 @@ __faddr2line() {
|
||||||
# section offsets.
|
# section offsets.
|
||||||
local file_type=$(${READELF} --file-header $objfile |
|
local file_type=$(${READELF} --file-header $objfile |
|
||||||
${AWK} '$1 == "Type:" { print $2; exit }')
|
${AWK} '$1 == "Type:" { print $2; exit }')
|
||||||
[[ $file_type = "EXEC" ]] && is_vmlinux=1
|
if [[ $file_type = "EXEC" ]] || [[ $file_type == "DYN" ]]; then
|
||||||
|
is_vmlinux=1
|
||||||
|
fi
|
||||||
|
|
||||||
# Go through each of the object's symbols which match the func name.
|
# Go through each of the object's symbols which match the func name.
|
||||||
# In rare cases there might be duplicates, in which case we print all
|
# In rare cases there might be duplicates, in which case we print all
|
||||||
|
@ -269,6 +272,8 @@ LIST=0
|
||||||
[[ ! -f $objfile ]] && die "can't find objfile $objfile"
|
[[ ! -f $objfile ]] && die "can't find objfile $objfile"
|
||||||
shift
|
shift
|
||||||
|
|
||||||
|
${READELF} --section-headers --wide $objfile | ${GREP} -q '\.debug_info' || die "CONFIG_DEBUG_INFO not enabled"
|
||||||
|
|
||||||
DIR_PREFIX=supercalifragilisticexpialidocious
|
DIR_PREFIX=supercalifragilisticexpialidocious
|
||||||
find_dir_prefix $objfile
|
find_dir_prefix $objfile
|
||||||
|
|
||||||
|
|
Loading…
Add table
Reference in a new issue