tracing: Move ftrace_max_lock into trace_array
In preparation for having tracers enabled in instances, the max_lock should be unique as updating the max for one tracer is a separate operation than updating it for another tracer using a different max. Signed-off-by: Steven Rostedt <rostedt@goodmis.org>
This commit is contained in:
parent
6d9b3fa5e7
commit
0b9b12c1b8
|
@ -963,22 +963,6 @@ static ssize_t trace_seq_to_buffer(struct trace_seq *s, void *buf, size_t cnt)
|
||||||
return cnt;
|
return cnt;
|
||||||
}
|
}
|
||||||
|
|
||||||
/*
|
|
||||||
* ftrace_max_lock is used to protect the swapping of buffers
|
|
||||||
* when taking a max snapshot. The buffers themselves are
|
|
||||||
* protected by per_cpu spinlocks. But the action of the swap
|
|
||||||
* needs its own lock.
|
|
||||||
*
|
|
||||||
* This is defined as a arch_spinlock_t in order to help
|
|
||||||
* with performance when lockdep debugging is enabled.
|
|
||||||
*
|
|
||||||
* It is also used in other places outside the update_max_tr
|
|
||||||
* so it needs to be defined outside of the
|
|
||||||
* CONFIG_TRACER_MAX_TRACE.
|
|
||||||
*/
|
|
||||||
static arch_spinlock_t ftrace_max_lock =
|
|
||||||
(arch_spinlock_t)__ARCH_SPIN_LOCK_UNLOCKED;
|
|
||||||
|
|
||||||
unsigned long __read_mostly tracing_thresh;
|
unsigned long __read_mostly tracing_thresh;
|
||||||
|
|
||||||
#ifdef CONFIG_TRACER_MAX_TRACE
|
#ifdef CONFIG_TRACER_MAX_TRACE
|
||||||
|
@ -1046,14 +1030,14 @@ update_max_tr(struct trace_array *tr, struct task_struct *tsk, int cpu)
|
||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
|
|
||||||
arch_spin_lock(&ftrace_max_lock);
|
arch_spin_lock(&tr->max_lock);
|
||||||
|
|
||||||
buf = tr->trace_buffer.buffer;
|
buf = tr->trace_buffer.buffer;
|
||||||
tr->trace_buffer.buffer = tr->max_buffer.buffer;
|
tr->trace_buffer.buffer = tr->max_buffer.buffer;
|
||||||
tr->max_buffer.buffer = buf;
|
tr->max_buffer.buffer = buf;
|
||||||
|
|
||||||
__update_max_tr(tr, tsk, cpu);
|
__update_max_tr(tr, tsk, cpu);
|
||||||
arch_spin_unlock(&ftrace_max_lock);
|
arch_spin_unlock(&tr->max_lock);
|
||||||
}
|
}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
|
@ -1079,7 +1063,7 @@ update_max_tr_single(struct trace_array *tr, struct task_struct *tsk, int cpu)
|
||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
|
|
||||||
arch_spin_lock(&ftrace_max_lock);
|
arch_spin_lock(&tr->max_lock);
|
||||||
|
|
||||||
ret = ring_buffer_swap_cpu(tr->max_buffer.buffer, tr->trace_buffer.buffer, cpu);
|
ret = ring_buffer_swap_cpu(tr->max_buffer.buffer, tr->trace_buffer.buffer, cpu);
|
||||||
|
|
||||||
|
@ -1097,7 +1081,7 @@ update_max_tr_single(struct trace_array *tr, struct task_struct *tsk, int cpu)
|
||||||
WARN_ON_ONCE(ret && ret != -EAGAIN && ret != -EBUSY);
|
WARN_ON_ONCE(ret && ret != -EAGAIN && ret != -EBUSY);
|
||||||
|
|
||||||
__update_max_tr(tr, tsk, cpu);
|
__update_max_tr(tr, tsk, cpu);
|
||||||
arch_spin_unlock(&ftrace_max_lock);
|
arch_spin_unlock(&tr->max_lock);
|
||||||
}
|
}
|
||||||
#endif /* CONFIG_TRACER_MAX_TRACE */
|
#endif /* CONFIG_TRACER_MAX_TRACE */
|
||||||
|
|
||||||
|
@ -1351,7 +1335,7 @@ void tracing_start(void)
|
||||||
}
|
}
|
||||||
|
|
||||||
/* Prevent the buffers from switching */
|
/* Prevent the buffers from switching */
|
||||||
arch_spin_lock(&ftrace_max_lock);
|
arch_spin_lock(&global_trace.max_lock);
|
||||||
|
|
||||||
buffer = global_trace.trace_buffer.buffer;
|
buffer = global_trace.trace_buffer.buffer;
|
||||||
if (buffer)
|
if (buffer)
|
||||||
|
@ -1363,7 +1347,7 @@ void tracing_start(void)
|
||||||
ring_buffer_record_enable(buffer);
|
ring_buffer_record_enable(buffer);
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
arch_spin_unlock(&ftrace_max_lock);
|
arch_spin_unlock(&global_trace.max_lock);
|
||||||
|
|
||||||
ftrace_start();
|
ftrace_start();
|
||||||
out:
|
out:
|
||||||
|
@ -1418,7 +1402,7 @@ void tracing_stop(void)
|
||||||
goto out;
|
goto out;
|
||||||
|
|
||||||
/* Prevent the buffers from switching */
|
/* Prevent the buffers from switching */
|
||||||
arch_spin_lock(&ftrace_max_lock);
|
arch_spin_lock(&global_trace.max_lock);
|
||||||
|
|
||||||
buffer = global_trace.trace_buffer.buffer;
|
buffer = global_trace.trace_buffer.buffer;
|
||||||
if (buffer)
|
if (buffer)
|
||||||
|
@ -1430,7 +1414,7 @@ void tracing_stop(void)
|
||||||
ring_buffer_record_disable(buffer);
|
ring_buffer_record_disable(buffer);
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
arch_spin_unlock(&ftrace_max_lock);
|
arch_spin_unlock(&global_trace.max_lock);
|
||||||
|
|
||||||
out:
|
out:
|
||||||
raw_spin_unlock_irqrestore(&global_trace.start_lock, flags);
|
raw_spin_unlock_irqrestore(&global_trace.start_lock, flags);
|
||||||
|
@ -3331,7 +3315,7 @@ tracing_cpumask_write(struct file *filp, const char __user *ubuf,
|
||||||
mutex_lock(&tracing_cpumask_update_lock);
|
mutex_lock(&tracing_cpumask_update_lock);
|
||||||
|
|
||||||
local_irq_disable();
|
local_irq_disable();
|
||||||
arch_spin_lock(&ftrace_max_lock);
|
arch_spin_lock(&tr->max_lock);
|
||||||
for_each_tracing_cpu(cpu) {
|
for_each_tracing_cpu(cpu) {
|
||||||
/*
|
/*
|
||||||
* Increase/decrease the disabled counter if we are
|
* Increase/decrease the disabled counter if we are
|
||||||
|
@ -3348,7 +3332,7 @@ tracing_cpumask_write(struct file *filp, const char __user *ubuf,
|
||||||
ring_buffer_record_enable_cpu(tr->trace_buffer.buffer, cpu);
|
ring_buffer_record_enable_cpu(tr->trace_buffer.buffer, cpu);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
arch_spin_unlock(&ftrace_max_lock);
|
arch_spin_unlock(&tr->max_lock);
|
||||||
local_irq_enable();
|
local_irq_enable();
|
||||||
|
|
||||||
cpumask_copy(tr->tracing_cpumask, tracing_cpumask_new);
|
cpumask_copy(tr->tracing_cpumask, tracing_cpumask_new);
|
||||||
|
@ -6129,6 +6113,8 @@ static int new_instance_create(const char *name)
|
||||||
|
|
||||||
raw_spin_lock_init(&tr->start_lock);
|
raw_spin_lock_init(&tr->start_lock);
|
||||||
|
|
||||||
|
tr->max_lock = (arch_spinlock_t)__ARCH_SPIN_LOCK_UNLOCKED;
|
||||||
|
|
||||||
tr->current_trace = &nop_trace;
|
tr->current_trace = &nop_trace;
|
||||||
|
|
||||||
INIT_LIST_HEAD(&tr->systems);
|
INIT_LIST_HEAD(&tr->systems);
|
||||||
|
@ -6627,6 +6613,8 @@ __init static int tracer_alloc_buffers(void)
|
||||||
*/
|
*/
|
||||||
global_trace.current_trace = &nop_trace;
|
global_trace.current_trace = &nop_trace;
|
||||||
|
|
||||||
|
global_trace.max_lock = (arch_spinlock_t)__ARCH_SPIN_LOCK_UNLOCKED;
|
||||||
|
|
||||||
ftrace_init_global_array_ops(&global_trace);
|
ftrace_init_global_array_ops(&global_trace);
|
||||||
|
|
||||||
register_tracer(&nop_trace);
|
register_tracer(&nop_trace);
|
||||||
|
|
|
@ -192,6 +192,20 @@ struct trace_array {
|
||||||
bool allocated_snapshot;
|
bool allocated_snapshot;
|
||||||
unsigned long max_latency;
|
unsigned long max_latency;
|
||||||
#endif
|
#endif
|
||||||
|
/*
|
||||||
|
* max_lock is used to protect the swapping of buffers
|
||||||
|
* when taking a max snapshot. The buffers themselves are
|
||||||
|
* protected by per_cpu spinlocks. But the action of the swap
|
||||||
|
* needs its own lock.
|
||||||
|
*
|
||||||
|
* This is defined as a arch_spinlock_t in order to help
|
||||||
|
* with performance when lockdep debugging is enabled.
|
||||||
|
*
|
||||||
|
* It is also used in other places outside the update_max_tr
|
||||||
|
* so it needs to be defined outside of the
|
||||||
|
* CONFIG_TRACER_MAX_TRACE.
|
||||||
|
*/
|
||||||
|
arch_spinlock_t max_lock;
|
||||||
int buffer_disabled;
|
int buffer_disabled;
|
||||||
#ifdef CONFIG_FTRACE_SYSCALLS
|
#ifdef CONFIG_FTRACE_SYSCALLS
|
||||||
int sys_refcount_enter;
|
int sys_refcount_enter;
|
||||||
|
|
|
@ -65,7 +65,7 @@ static int trace_test_buffer(struct trace_buffer *buf, unsigned long *count)
|
||||||
|
|
||||||
/* Don't allow flipping of max traces now */
|
/* Don't allow flipping of max traces now */
|
||||||
local_irq_save(flags);
|
local_irq_save(flags);
|
||||||
arch_spin_lock(&ftrace_max_lock);
|
arch_spin_lock(&buf->tr->max_lock);
|
||||||
|
|
||||||
cnt = ring_buffer_entries(buf->buffer);
|
cnt = ring_buffer_entries(buf->buffer);
|
||||||
|
|
||||||
|
@ -83,7 +83,7 @@ static int trace_test_buffer(struct trace_buffer *buf, unsigned long *count)
|
||||||
break;
|
break;
|
||||||
}
|
}
|
||||||
tracing_on();
|
tracing_on();
|
||||||
arch_spin_unlock(&ftrace_max_lock);
|
arch_spin_unlock(&buf->tr->max_lock);
|
||||||
local_irq_restore(flags);
|
local_irq_restore(flags);
|
||||||
|
|
||||||
if (count)
|
if (count)
|
||||||
|
|
Loading…
Reference in New Issue