mirror of
https://git.kernel.org/pub/scm/linux/kernel/git/next/linux-next.git
synced 2025-01-16 13:34:30 +00:00
Documentation: probes: Add a new ret_ip callback parameter
Add a new ret_ip callback parameter description. Link: https://lore.kernel.org/all/169556257133.146934.13560704846459957726.stgit@devnote2/ Fixes: cb16330d1274 ("fprobe: Pass return address to the handlers") Signed-off-by: Masami Hiramatsu (Google) <mhiramat@kernel.org> Acked-by: Florent Revest <revest@chromium.org>
This commit is contained in:
parent
58720809f5
commit
2a86ac30a6
@ -91,9 +91,9 @@ The prototype of the entry/exit callback function are as follows:
|
|||||||
|
|
||||||
.. code-block:: c
|
.. code-block:: c
|
||||||
|
|
||||||
int entry_callback(struct fprobe *fp, unsigned long entry_ip, struct pt_regs *regs, void *entry_data);
|
int entry_callback(struct fprobe *fp, unsigned long entry_ip, unsigned long ret_ip, struct pt_regs *regs, void *entry_data);
|
||||||
|
|
||||||
void exit_callback(struct fprobe *fp, unsigned long entry_ip, struct pt_regs *regs, void *entry_data);
|
void exit_callback(struct fprobe *fp, unsigned long entry_ip, unsigned long ret_ip, struct pt_regs *regs, void *entry_data);
|
||||||
|
|
||||||
Note that the @entry_ip is saved at function entry and passed to exit handler.
|
Note that the @entry_ip is saved at function entry and passed to exit handler.
|
||||||
If the entry callback function returns !0, the corresponding exit callback will be cancelled.
|
If the entry callback function returns !0, the corresponding exit callback will be cancelled.
|
||||||
@ -108,6 +108,10 @@ If the entry callback function returns !0, the corresponding exit callback will
|
|||||||
Note that this may not be the actual entry address of the function but
|
Note that this may not be the actual entry address of the function but
|
||||||
the address where the ftrace is instrumented.
|
the address where the ftrace is instrumented.
|
||||||
|
|
||||||
|
@ret_ip
|
||||||
|
This is the return address that the traced function will return to,
|
||||||
|
somewhere in the caller. This can be used at both entry and exit.
|
||||||
|
|
||||||
@regs
|
@regs
|
||||||
This is the `pt_regs` data structure at the entry and exit. Note that
|
This is the `pt_regs` data structure at the entry and exit. Note that
|
||||||
the instruction pointer of @regs may be different from the @entry_ip
|
the instruction pointer of @regs may be different from the @entry_ip
|
||||||
|
Loading…
x
Reference in New Issue
Block a user