aboutsummaryrefslogtreecommitdiffstats
path: root/kernel/trace
diff options
context:
space:
mode:
authorSteven Rostedt <srostedt@redhat.com>2009-09-02 10:56:15 -0400
committerSteven Rostedt <rostedt@goodmis.org>2009-09-04 11:22:47 -0400
commit98277991a99734f3a31d638afb47d4484ac73e43 (patch)
tree6688cb3c43562d6bd7b67961478ac337297064e5 /kernel/trace
parent41b6a95d693319f804607b559893fbbd27498548 (diff)
ring-buffer: do not swap buffers during a commit
If a commit is taking place on a CPU ring buffer, do not allow it to be swapped. Return -EBUSY when this is detected instead. Signed-off-by: Steven Rostedt <rostedt@goodmis.org>
Diffstat (limited to 'kernel/trace')
-rw-r--r--kernel/trace/ring_buffer.c11
1 files changed, 9 insertions, 2 deletions
diff --git a/kernel/trace/ring_buffer.c b/kernel/trace/ring_buffer.c
index 79d6012bb1f1..2878bd43a59c 100644
--- a/kernel/trace/ring_buffer.c
+++ b/kernel/trace/ring_buffer.c
@@ -3519,16 +3519,23 @@ int ring_buffer_swap_cpu(struct ring_buffer *buffer_a,
3519 atomic_inc(&cpu_buffer_a->record_disabled); 3519 atomic_inc(&cpu_buffer_a->record_disabled);
3520 atomic_inc(&cpu_buffer_b->record_disabled); 3520 atomic_inc(&cpu_buffer_b->record_disabled);
3521 3521
3522 ret = -EBUSY;
3523 if (local_read(&cpu_buffer_a->committing))
3524 goto out_dec;
3525 if (local_read(&cpu_buffer_b->committing))
3526 goto out_dec;
3527
3522 buffer_a->buffers[cpu] = cpu_buffer_b; 3528 buffer_a->buffers[cpu] = cpu_buffer_b;
3523 buffer_b->buffers[cpu] = cpu_buffer_a; 3529 buffer_b->buffers[cpu] = cpu_buffer_a;
3524 3530
3525 cpu_buffer_b->buffer = buffer_a; 3531 cpu_buffer_b->buffer = buffer_a;
3526 cpu_buffer_a->buffer = buffer_b; 3532 cpu_buffer_a->buffer = buffer_b;
3527 3533
3534 ret = 0;
3535
3536out_dec:
3528 atomic_dec(&cpu_buffer_a->record_disabled); 3537 atomic_dec(&cpu_buffer_a->record_disabled);
3529 atomic_dec(&cpu_buffer_b->record_disabled); 3538 atomic_dec(&cpu_buffer_b->record_disabled);
3530
3531 ret = 0;
3532out: 3539out:
3533 return ret; 3540 return ret;
3534} 3541}