Skip to content

Commit c9b7a4a

Browse files
committed
ring-buffer/tracing: Have iterator acknowledge dropped events
Have the ring_buffer_iterator set a flag if events were dropped as it were to go and peek at the next event. Have the trace file display this fact if it happened with a "LOST EVENTS" message. Link: http://lkml.kernel.org/r/[email protected] Signed-off-by: Steven Rostedt (VMware) <[email protected]>
1 parent 06e0a54 commit c9b7a4a

File tree

3 files changed

+29
-4
lines changed

3 files changed

+29
-4
lines changed

include/linux/ring_buffer.h

Lines changed: 1 addition & 0 deletions
Original file line numberDiff line numberDiff line change
@@ -138,6 +138,7 @@ ring_buffer_iter_peek(struct ring_buffer_iter *iter, u64 *ts);
138138
void ring_buffer_iter_advance(struct ring_buffer_iter *iter);
139139
void ring_buffer_iter_reset(struct ring_buffer_iter *iter);
140140
int ring_buffer_iter_empty(struct ring_buffer_iter *iter);
141+
bool ring_buffer_iter_dropped(struct ring_buffer_iter *iter);
141142

142143
unsigned long ring_buffer_size(struct trace_buffer *buffer, int cpu);
143144

kernel/trace/ring_buffer.c

Lines changed: 16 additions & 0 deletions
Original file line numberDiff line numberDiff line change
@@ -510,6 +510,7 @@ struct ring_buffer_iter {
510510
u64 read_stamp;
511511
u64 page_stamp;
512512
struct ring_buffer_event *event;
513+
int missed_events;
513514
};
514515

515516
/**
@@ -1988,6 +1989,7 @@ rb_iter_head_event(struct ring_buffer_iter *iter)
19881989
iter->page_stamp = iter->read_stamp = iter->head_page->page->time_stamp;
19891990
iter->head = 0;
19901991
iter->next_event = 0;
1992+
iter->missed_events = 1;
19911993
return NULL;
19921994
}
19931995

@@ -4191,6 +4193,20 @@ ring_buffer_peek(struct trace_buffer *buffer, int cpu, u64 *ts,
41914193
return event;
41924194
}
41934195

4196+
/** ring_buffer_iter_dropped - report if there are dropped events
4197+
* @iter: The ring buffer iterator
4198+
*
4199+
* Returns true if there was dropped events since the last peek.
4200+
*/
4201+
bool ring_buffer_iter_dropped(struct ring_buffer_iter *iter)
4202+
{
4203+
bool ret = iter->missed_events != 0;
4204+
4205+
iter->missed_events = 0;
4206+
return ret;
4207+
}
4208+
EXPORT_SYMBOL_GPL(ring_buffer_iter_dropped);
4209+
41944210
/**
41954211
* ring_buffer_iter_peek - peek at the next event to be read
41964212
* @iter: The ring buffer iterator

kernel/trace/trace.c

Lines changed: 12 additions & 4 deletions
Original file line numberDiff line numberDiff line change
@@ -3388,11 +3388,15 @@ peek_next_entry(struct trace_iterator *iter, int cpu, u64 *ts,
33883388
struct ring_buffer_event *event;
33893389
struct ring_buffer_iter *buf_iter = trace_buffer_iter(iter, cpu);
33903390

3391-
if (buf_iter)
3391+
if (buf_iter) {
33923392
event = ring_buffer_iter_peek(buf_iter, ts);
3393-
else
3393+
if (lost_events)
3394+
*lost_events = ring_buffer_iter_dropped(buf_iter) ?
3395+
(unsigned long)-1 : 0;
3396+
} else {
33943397
event = ring_buffer_peek(iter->array_buffer->buffer, cpu, ts,
33953398
lost_events);
3399+
}
33963400

33973401
if (event) {
33983402
iter->ent_size = ring_buffer_event_length(event);
@@ -4005,8 +4009,12 @@ enum print_line_t print_trace_line(struct trace_iterator *iter)
40054009
enum print_line_t ret;
40064010

40074011
if (iter->lost_events) {
4008-
trace_seq_printf(&iter->seq, "CPU:%d [LOST %lu EVENTS]\n",
4009-
iter->cpu, iter->lost_events);
4012+
if (iter->lost_events == (unsigned long)-1)
4013+
trace_seq_printf(&iter->seq, "CPU:%d [LOST EVENTS]\n",
4014+
iter->cpu);
4015+
else
4016+
trace_seq_printf(&iter->seq, "CPU:%d [LOST %lu EVENTS]\n",
4017+
iter->cpu, iter->lost_events);
40104018
if (trace_seq_has_overflowed(&iter->seq))
40114019
return TRACE_TYPE_PARTIAL_LINE;
40124020
}

0 commit comments

Comments
 (0)