ring-buffer: Move resize integrity check under reader lock
authorSteven Rostedt <srostedt@redhat.com>
Fri, 11 Dec 2009 04:20:52 +0000 (23:20 -0500)
committerSteven Rostedt <rostedt@goodmis.org>
Fri, 11 Dec 2009 04:20:52 +0000 (23:20 -0500)
While using an application that does splice on the ftrace ring
buffer at start up, I triggered an integrity check failure.

Looking into this, I discovered that resizing the buffer performs
an integrity check after the buffer is resized. This check unfortunately
is preformed after it releases the reader lock. If a reader is
reading the buffer it may cause the integrity check to trigger a
false failure.

This patch simply moves the integrity checker under the protection
of the ring buffer reader lock.

Signed-off-by: Steven Rostedt <rostedt@goodmis.org>
kernel/trace/ring_buffer.c

index 0d64c51ab4df0d89eaaaab6aef65d3fabe02126d..eccb4cf1e998ef8fe178f9a9286ff28217d7cdfb 100644 (file)
@@ -1208,9 +1208,9 @@ rb_remove_pages(struct ring_buffer_per_cpu *cpu_buffer, unsigned nr_pages)
                return;
 
        rb_reset_cpu(cpu_buffer);
-       spin_unlock_irq(&cpu_buffer->reader_lock);
-
        rb_check_pages(cpu_buffer);
+
+       spin_unlock_irq(&cpu_buffer->reader_lock);
 }
 
 static void
@@ -1233,9 +1233,9 @@ rb_insert_pages(struct ring_buffer_per_cpu *cpu_buffer,
                list_add_tail(&bpage->list, cpu_buffer->pages);
        }
        rb_reset_cpu(cpu_buffer);
-       spin_unlock_irq(&cpu_buffer->reader_lock);
-
        rb_check_pages(cpu_buffer);
+
+       spin_unlock_irq(&cpu_buffer->reader_lock);
 }
 
 /**