Two updates.
- A memory fix with left over code from spliting out ftrace_ops and function graph tracer, where the function graph tracer could reset the trampoline pointer, leaving the old trampoline not to be freed (memory leak). - The update to Paul's patch that added the unnecessary READ_ONCE(). This removes the unnecessary READ_ONCE() instead of having to rebase the branch to update the patch that added it. -----BEGIN PGP SIGNATURE----- iQFIBAABCAAyFiEEQEw9Eu0DdyUUkuUUybkF8mrZjcsFAlnU++sUHHJvc3RlZHRA Z29vZG1pcy5vcmcACgkQybkF8mrZjcujzgf/ebIzGKe5vQKNrL4ITAcIz0T7Hvzl pWw4uJp8kqO9x9EHMnztAkltQigvjvgDKZozJpUGgtNsFLuvdgQSBMK24YV8vLHs UmXEnQ2tSB/2Sg2ccEnpjVXaMzL9aqlbeTmACbdd9UgZnvPiUYPejq2jFfECFQjb k/gZT911ukBtx4mXYKzGFbTEZHdc/YUs6Y/wzB1ox5BBIUh71ZDZXxQTUHfXHlwS Cst69/9dKl4nBEGDGas6/95iR+ORVv85osI/pqPtjSj4EkRnWfVRotaH1kNuSQil gDIHSoy35NfXJx77/5IFHfrjFBAkr0IYRNL/jZaWazwM7rdqfAN8TwMQuA== =4CtF -----END PGP SIGNATURE----- Merge tag 'trace-v4.14-rc1-3' of git://git.kernel.org/pub/scm/linux/kernel/git/rostedt/linux-trace Pull tracing fixlets from Steven Rostedt: "Two updates: - A memory fix with left over code from spliting out ftrace_ops and function graph tracer, where the function graph tracer could reset the trampoline pointer, leaving the old trampoline not to be freed (memory leak). - The update to Paul's patch that added the unnecessary READ_ONCE(). This removes the unnecessary READ_ONCE() instead of having to rebase the branch to update the patch that added it" * tag 'trace-v4.14-rc1-3' of git://git.kernel.org/pub/scm/linux/kernel/git/rostedt/linux-trace: rcu: Remove extraneous READ_ONCE()s from rcu_irq_{enter,exit}() ftrace: Fix kmemleak in unregister_ftrace_graph
This commit is contained in:
commit
013a8ee628
|
@ -884,7 +884,7 @@ void rcu_irq_exit(void)
|
||||||
rdtp = this_cpu_ptr(&rcu_dynticks);
|
rdtp = this_cpu_ptr(&rcu_dynticks);
|
||||||
|
|
||||||
/* Page faults can happen in NMI handlers, so check... */
|
/* Page faults can happen in NMI handlers, so check... */
|
||||||
if (READ_ONCE(rdtp->dynticks_nmi_nesting))
|
if (rdtp->dynticks_nmi_nesting)
|
||||||
return;
|
return;
|
||||||
|
|
||||||
WARN_ON_ONCE(IS_ENABLED(CONFIG_RCU_EQS_DEBUG) &&
|
WARN_ON_ONCE(IS_ENABLED(CONFIG_RCU_EQS_DEBUG) &&
|
||||||
|
@ -1022,7 +1022,7 @@ void rcu_irq_enter(void)
|
||||||
rdtp = this_cpu_ptr(&rcu_dynticks);
|
rdtp = this_cpu_ptr(&rcu_dynticks);
|
||||||
|
|
||||||
/* Page faults can happen in NMI handlers, so check... */
|
/* Page faults can happen in NMI handlers, so check... */
|
||||||
if (READ_ONCE(rdtp->dynticks_nmi_nesting))
|
if (rdtp->dynticks_nmi_nesting)
|
||||||
return;
|
return;
|
||||||
|
|
||||||
oldval = rdtp->dynticks_nesting;
|
oldval = rdtp->dynticks_nesting;
|
||||||
|
|
|
@ -4954,9 +4954,6 @@ static char ftrace_graph_buf[FTRACE_FILTER_SIZE] __initdata;
|
||||||
static char ftrace_graph_notrace_buf[FTRACE_FILTER_SIZE] __initdata;
|
static char ftrace_graph_notrace_buf[FTRACE_FILTER_SIZE] __initdata;
|
||||||
static int ftrace_graph_set_hash(struct ftrace_hash *hash, char *buffer);
|
static int ftrace_graph_set_hash(struct ftrace_hash *hash, char *buffer);
|
||||||
|
|
||||||
static unsigned long save_global_trampoline;
|
|
||||||
static unsigned long save_global_flags;
|
|
||||||
|
|
||||||
static int __init set_graph_function(char *str)
|
static int __init set_graph_function(char *str)
|
||||||
{
|
{
|
||||||
strlcpy(ftrace_graph_buf, str, FTRACE_FILTER_SIZE);
|
strlcpy(ftrace_graph_buf, str, FTRACE_FILTER_SIZE);
|
||||||
|
@ -6808,17 +6805,6 @@ void unregister_ftrace_graph(void)
|
||||||
unregister_pm_notifier(&ftrace_suspend_notifier);
|
unregister_pm_notifier(&ftrace_suspend_notifier);
|
||||||
unregister_trace_sched_switch(ftrace_graph_probe_sched_switch, NULL);
|
unregister_trace_sched_switch(ftrace_graph_probe_sched_switch, NULL);
|
||||||
|
|
||||||
#ifdef CONFIG_DYNAMIC_FTRACE
|
|
||||||
/*
|
|
||||||
* Function graph does not allocate the trampoline, but
|
|
||||||
* other global_ops do. We need to reset the ALLOC_TRAMP flag
|
|
||||||
* if one was used.
|
|
||||||
*/
|
|
||||||
global_ops.trampoline = save_global_trampoline;
|
|
||||||
if (save_global_flags & FTRACE_OPS_FL_ALLOC_TRAMP)
|
|
||||||
global_ops.flags |= FTRACE_OPS_FL_ALLOC_TRAMP;
|
|
||||||
#endif
|
|
||||||
|
|
||||||
out:
|
out:
|
||||||
mutex_unlock(&ftrace_lock);
|
mutex_unlock(&ftrace_lock);
|
||||||
}
|
}
|
||||||
|
|
Loading…
Reference in New Issue