uprobes: Allocate ->utask before handler_chain() for tracing handlers
uprobe_trace_print() and uprobe_perf_print() need to pass the additional info to call_fetch() methods, currently there is no simple way to do this. current->utask looks like a natural place to hold this info, but we need to allocate it before handler_chain(). This is a bit unfortunate, perhaps we will find a better solution later, but this is simple and should work right now. Signed-off-by: Oleg Nesterov <oleg@redhat.com> Acked-by: Masami Hiramatsu <masami.hiramatsu.pt@hitachi.com> Acked-by: Oleg Nesterov <oleg@redhat.com> Cc: Srikar Dronamraju <srikar@linux.vnet.ibm.com> Signed-off-by: Namhyung Kim <namhyung@kernel.org>
This commit is contained in:
parent
b079d374fd
commit
72fd293aa9
@ -1828,6 +1828,10 @@ static void handle_swbp(struct pt_regs *regs)
|
|||||||
if (unlikely(!test_bit(UPROBE_COPY_INSN, &uprobe->flags)))
|
if (unlikely(!test_bit(UPROBE_COPY_INSN, &uprobe->flags)))
|
||||||
goto out;
|
goto out;
|
||||||
|
|
||||||
|
/* Tracing handlers use ->utask to communicate with fetch methods */
|
||||||
|
if (!get_utask())
|
||||||
|
goto out;
|
||||||
|
|
||||||
handler_chain(uprobe, regs);
|
handler_chain(uprobe, regs);
|
||||||
if (can_skip_sstep(uprobe, regs))
|
if (can_skip_sstep(uprobe, regs))
|
||||||
goto out;
|
goto out;
|
||||||
|
Loading…
Reference in New Issue
Block a user