summaryrefslogtreecommitdiff
path: root/kernel
diff options
context:
space:
mode:
authorZe Gao <zegao2021@gmail.com>2023-05-17 11:45:06 +0800
committerMasami Hiramatsu (Google) <mhiramat@kernel.org>2023-05-18 07:08:01 +0900
commitbe243bacfb25f5219f2396d787408e8cf1301dd1 (patch)
treeadeceea8d080d6086af432f8ca5aa6b01d716e46 /kernel
parent6049674b5720edbbb13a7cb3e2f3d2affaa40c19 (diff)
downloadlwn-be243bacfb25f5219f2396d787408e8cf1301dd1.tar.gz
lwn-be243bacfb25f5219f2396d787408e8cf1301dd1.zip
rethook: use preempt_{disable, enable}_notrace in rethook_trampoline_handler
This patch replaces preempt_{disable, enable} with its corresponding notrace version in rethook_trampoline_handler so no worries about stack recursion or overflow introduced by preempt_count_{add, sub} under fprobe + rethook context. Link: https://lore.kernel.org/all/20230517034510.15639-2-zegao@tencent.com/ Fixes: 54ecbe6f1ed5 ("rethook: Add a generic return hook") Signed-off-by: Ze Gao <zegao@tencent.com> Acked-by: Masami Hiramatsu (Google) <mhiramat@kernel.org> Cc: <stable@vger.kernel.org> Signed-off-by: Masami Hiramatsu (Google) <mhiramat@kernel.org>
Diffstat (limited to 'kernel')
-rw-r--r--kernel/trace/rethook.c4
1 files changed, 2 insertions, 2 deletions
diff --git a/kernel/trace/rethook.c b/kernel/trace/rethook.c
index 32c3dfdb4d6a..60f6cb2b486b 100644
--- a/kernel/trace/rethook.c
+++ b/kernel/trace/rethook.c
@@ -288,7 +288,7 @@ unsigned long rethook_trampoline_handler(struct pt_regs *regs,
* These loops must be protected from rethook_free_rcu() because those
* are accessing 'rhn->rethook'.
*/
- preempt_disable();
+ preempt_disable_notrace();
/*
* Run the handler on the shadow stack. Do not unlink the list here because
@@ -321,7 +321,7 @@ unsigned long rethook_trampoline_handler(struct pt_regs *regs,
first = first->next;
rethook_recycle(rhn);
}
- preempt_enable();
+ preempt_enable_notrace();
return correct_ret_addr;
}