Centos-kernel-stream-9/arch/arm/probes
Joe Lawrence cee7df7bea ARM: kprobes: Make a frame pointer on __kretprobe_trampoline
Bugzilla: https://bugzilla.redhat.com/show_bug.cgi?id=2069373

commit 7e9bf33b812471ee57a03ec7f9b544ca437cc706
Author: Masami Hiramatsu <mhiramat@kernel.org>
Date:   Thu Oct 21 09:55:26 2021 +0900

    ARM: kprobes: Make a frame pointer on __kretprobe_trampoline

    Currently kretprobe on ARM just fills r0-r11 of pt_regs, but
    that is not enough for the stacktrace. Moreover, from the user
    kretprobe handler, stacktrace needs a frame pointer on the
    __kretprobe_trampoline.

    This adds a frame pointer on __kretprobe_trampoline for both gcc
    and clang case. Those have different frame pointer so we need
    different but similar stack on pt_regs.

    Gcc makes the frame pointer (fp) to point the 'pc' address of
    the {fp, ip (=sp), lr, pc}, this means {r11, r13, r14, r15}.
    Thus if we save the r11 (fp) on pt_regs->r12, we can make this
    set on the end of pt_regs.

    On the other hand, Clang makes the frame pointer to point the
    'fp' address of {fp, lr} on stack. Since the next to the
    pt_regs->lr is pt_regs->sp, I reused the pair of pt_regs->fp
    and pt_regs->ip.
    So this stores the 'lr' on pt_regs->ip and make the fp to point
    pt_regs->fp.

    For both cases, saves __kretprobe_trampoline address to
    pt_regs->lr, so that the stack tracer can identify this frame
    pointer has been made by the __kretprobe_trampoline.

    Note that if the CONFIG_FRAME_POINTER is not set, this keeps
    fp as is.

    Signed-off-by: Masami Hiramatsu <mhiramat@kernel.org>
    Reviewed-by: Nick Desaulniers <ndesaulniers@google.com>
    Signed-off-by: Steven Rostedt (VMware) <rostedt@goodmis.org>

Signed-off-by: Joe Lawrence <joe.lawrence@redhat.com>
2022-04-06 21:50:16 -04:00
..
kprobes ARM: kprobes: Make a frame pointer on __kretprobe_trampoline 2022-04-06 21:50:16 -04:00
uprobes ARM: 9071/1: uprobes: Don't hook on thumb instructions 2021-04-18 19:14:45 +01:00
Makefile License cleanup: add SPDX GPL-2.0 license identifier to files with no license 2017-11-02 11:10:55 +01:00
decode-arm.c treewide: Replace GPLv2 boilerplate/reference with SPDX - rule 174 2019-05-30 11:26:41 -07:00
decode-arm.h treewide: Replace GPLv2 boilerplate/reference with SPDX - rule 159 2019-05-30 11:26:37 -07:00
decode-thumb.c treewide: Replace GPLv2 boilerplate/reference with SPDX - rule 500 2019-06-19 17:09:55 +02:00
decode-thumb.h treewide: Replace GPLv2 boilerplate/reference with SPDX - rule 159 2019-05-30 11:26:37 -07:00
decode.c treewide: Use fallthrough pseudo-keyword 2020-08-23 17:36:59 -05:00
decode.h treewide: Replace GPLv2 boilerplate/reference with SPDX - rule 174 2019-05-30 11:26:41 -07:00