Commit 8e7abf1c authored by Steven Rostedt's avatar Steven Rostedt Committed by Steven Rostedt

ring-buffer: remove unneeded conditional in rb_reserve_next

The code in __rb_reserve_next checks on page overflow if it is the
original commiter and then resets the page back to the original
setting.  Although this is fine, and the code is correct, it is
a bit fragil. Some experimental work I did breaks it easily.

The better and more robust solution is to have all commiters that
overflow the page, simply subtract what they added.

[ Impact: more robust ring buffer account management ]
Signed-off-by: default avatarSteven Rostedt <rostedt@goodmis.org>
parent 35cf723e
...@@ -1290,9 +1290,8 @@ __rb_reserve_next(struct ring_buffer_per_cpu *cpu_buffer, ...@@ -1290,9 +1290,8 @@ __rb_reserve_next(struct ring_buffer_per_cpu *cpu_buffer,
rb_event_set_padding(event); rb_event_set_padding(event);
} }
if (tail <= BUF_PAGE_SIZE) /* Set the write back to the previous setting */
/* Set the write back to the previous setting */ local_sub(length, &tail_page->write);
local_set(&tail_page->write, tail);
/* /*
* If this was a commit entry that failed, * If this was a commit entry that failed,
...@@ -1311,8 +1310,7 @@ __rb_reserve_next(struct ring_buffer_per_cpu *cpu_buffer, ...@@ -1311,8 +1310,7 @@ __rb_reserve_next(struct ring_buffer_per_cpu *cpu_buffer,
out_reset: out_reset:
/* reset write */ /* reset write */
if (tail <= BUF_PAGE_SIZE) local_sub(length, &tail_page->write);
local_set(&tail_page->write, tail);
if (likely(lock_taken)) if (likely(lock_taken))
__raw_spin_unlock(&cpu_buffer->lock); __raw_spin_unlock(&cpu_buffer->lock);
......
Markdown is supported
0%
or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment