mirror of
https://git.kernel.org/pub/scm/linux/kernel/git/stable/linux.git
synced 2025-01-04 04:06:26 +00:00
Fix the arm64 usage of ftrace_graph_ret_addr() to pass the
&state->graph_idx pointer instead of NULL, otherwise this function just returns early. -----BEGIN PGP SIGNATURE----- iQIzBAABCgAdFiEE5RElWfyWxS+3PLO2a9axLQDIXvEFAmbbNqMACgkQa9axLQDI XvGDhQ//dxbFGx+5oD7BjX8xoyis4GQmnYS3IkNJXdTbd7gB2MCygobNfDyjOGjV wkCDpgrgs2al+OnldldjqoIwcqkp4e03IKuxamouF3yg2nrPfZl1Z9JkL+0hhk7c ZHvw82cF1EHPF8Su8zyh/XIyBWPwH5x/+YYW1PYsFWS0P17Y2q6B8qU0EfRvNtT2 9168yPlR1vYuXBPg+34OUXlMVXww0KNulVa12vab2EZMI+v8Ql5M6F05SrzVT3JG G/IG4R8QpVuVCcQjMmy0oNPlB56+CScqM7yIUOGTiGgTgvZ3cs+83grd4gqfvVAp 3bgZno4oV9O+V8JrjcGMw9K6sIl5KRmED6+zCjdEwPgkhStV1C6ApcdnUnqst7Gw NkhskzTqRRt5ZVGQsN24AGoybtmFALudmTRmOiL3eOzikK73CZMSK29DNiEP32SD D1mWZj57EnOBkxiUsh36+FbX5zMieJu0hbOy7jLFE5ynb/GpyFPf9pORrLI3fbk1 46/VCvWTrul0fD9iBafm+VGfoy4SQX5T8TWnKEXF4THfvrzu5q6HCPTGMBgBLXDg vRMyL4dIgAK6/HeoLQL7UhkWEYrT3KrBMHeZf/q57oMr+kyQctxFKJg9N8TApk78 GIqWrRpuCPj2E/vrfI6j1szVfMgna3Az2Y2ArVWWFPqY7U8hEl4= =GM7Q -----END PGP SIGNATURE----- Merge tag 'arm64-fixes' of git://git.kernel.org/pub/scm/linux/kernel/git/arm64/linux Pull arm64 fix from Catalin Marinas: "Fix the arm64 usage of ftrace_graph_ret_addr() to pass the &state->graph_idx pointer instead of NULL, otherwise this function just returns early" * tag 'arm64-fixes' of git://git.kernel.org/pub/scm/linux/kernel/git/arm64/linux: arm64: stacktrace: fix the usage of ftrace_graph_ret_addr()
This commit is contained in:
commit
6b8ff511e4
@ -25,6 +25,7 @@
|
|||||||
*
|
*
|
||||||
* @common: Common unwind state.
|
* @common: Common unwind state.
|
||||||
* @task: The task being unwound.
|
* @task: The task being unwound.
|
||||||
|
* @graph_idx: Used by ftrace_graph_ret_addr() for optimized stack unwinding.
|
||||||
* @kr_cur: When KRETPROBES is selected, holds the kretprobe instance
|
* @kr_cur: When KRETPROBES is selected, holds the kretprobe instance
|
||||||
* associated with the most recently encountered replacement lr
|
* associated with the most recently encountered replacement lr
|
||||||
* value.
|
* value.
|
||||||
@ -32,6 +33,7 @@
|
|||||||
struct kunwind_state {
|
struct kunwind_state {
|
||||||
struct unwind_state common;
|
struct unwind_state common;
|
||||||
struct task_struct *task;
|
struct task_struct *task;
|
||||||
|
int graph_idx;
|
||||||
#ifdef CONFIG_KRETPROBES
|
#ifdef CONFIG_KRETPROBES
|
||||||
struct llist_node *kr_cur;
|
struct llist_node *kr_cur;
|
||||||
#endif
|
#endif
|
||||||
@ -106,7 +108,7 @@ kunwind_recover_return_address(struct kunwind_state *state)
|
|||||||
if (state->task->ret_stack &&
|
if (state->task->ret_stack &&
|
||||||
(state->common.pc == (unsigned long)return_to_handler)) {
|
(state->common.pc == (unsigned long)return_to_handler)) {
|
||||||
unsigned long orig_pc;
|
unsigned long orig_pc;
|
||||||
orig_pc = ftrace_graph_ret_addr(state->task, NULL,
|
orig_pc = ftrace_graph_ret_addr(state->task, &state->graph_idx,
|
||||||
state->common.pc,
|
state->common.pc,
|
||||||
(void *)state->common.fp);
|
(void *)state->common.fp);
|
||||||
if (WARN_ON_ONCE(state->common.pc == orig_pc))
|
if (WARN_ON_ONCE(state->common.pc == orig_pc))
|
||||||
|
Loading…
Reference in New Issue
Block a user