提交 dc892f73 编写于 作者: S Steven Rostedt 提交者: Steven Rostedt

ring-buffer: remove ring_buffer_event_discard

The function ring_buffer_event_discard can be used on any item in the
ring buffer, even after the item was committed. This function provides
no safety nets and is very race prone.

An item may be safely removed from the ring buffer before it is committed
with the ring_buffer_discard_commit.

Since there are currently no users of this function, and because this
function is racey and error prone, this patch removes it altogether.

Note, removing this function also allows the counters to ignore
all discarded events (patches will follow).
Signed-off-by: NSteven Rostedt <rostedt@goodmis.org>
上级 7e9391cf
...@@ -74,20 +74,6 @@ ring_buffer_event_time_delta(struct ring_buffer_event *event) ...@@ -74,20 +74,6 @@ ring_buffer_event_time_delta(struct ring_buffer_event *event)
return event->time_delta; return event->time_delta;
} }
/*
* ring_buffer_event_discard can discard any event in the ring buffer.
* it is up to the caller to protect against a reader from
* consuming it or a writer from wrapping and replacing it.
*
* No external protection is needed if this is called before
* the event is commited. But in that case it would be better to
* use ring_buffer_discard_commit.
*
* Note, if an event that has not been committed is discarded
* with ring_buffer_event_discard, it must still be committed.
*/
void ring_buffer_event_discard(struct ring_buffer_event *event);
/* /*
* ring_buffer_discard_commit will remove an event that has not * ring_buffer_discard_commit will remove an event that has not
* ben committed yet. If this is used, then ring_buffer_unlock_commit * ben committed yet. If this is used, then ring_buffer_unlock_commit
......
...@@ -2327,32 +2327,17 @@ static inline void rb_event_discard(struct ring_buffer_event *event) ...@@ -2327,32 +2327,17 @@ static inline void rb_event_discard(struct ring_buffer_event *event)
event->time_delta = 1; event->time_delta = 1;
} }
/**
* ring_buffer_event_discard - discard any event in the ring buffer
* @event: the event to discard
*
* Sometimes a event that is in the ring buffer needs to be ignored.
* This function lets the user discard an event in the ring buffer
* and then that event will not be read later.
*
* Note, it is up to the user to be careful with this, and protect
* against races. If the user discards an event that has been consumed
* it is possible that it could corrupt the ring buffer.
*/
void ring_buffer_event_discard(struct ring_buffer_event *event)
{
rb_event_discard(event);
}
EXPORT_SYMBOL_GPL(ring_buffer_event_discard);
/** /**
* ring_buffer_commit_discard - discard an event that has not been committed * ring_buffer_commit_discard - discard an event that has not been committed
* @buffer: the ring buffer * @buffer: the ring buffer
* @event: non committed event to discard * @event: non committed event to discard
* *
* This is similar to ring_buffer_event_discard but must only be * Sometimes an event that is in the ring buffer needs to be ignored.
* performed on an event that has not been committed yet. The difference * This function lets the user discard an event in the ring buffer
* is that this will also try to free the event from the ring buffer * and then that event will not be read later.
*
* This function only works if it is called before the the item has been
* committed. It will try to free the event from the ring buffer
* if another event has not been added behind it. * if another event has not been added behind it.
* *
* If another event has been added behind it, it will set the event * If another event has been added behind it, it will set the event
......
Markdown is supported
0% .
You are about to add 0 people to the discussion. Proceed with caution.
先完成此消息的编辑!
想要评论请 注册