Function report |
Source Code:kernel\trace\ring_buffer.c |
Create Date:2022-07-28 11:55:21 |
Last Modify:2020-03-17 19:30:04 | Copyright©Brick |
home page | Tree |
Annotation kernel can get tool activity | Download SCCT | Chinese |
Name:g_buffer_consume - return an event and consume it*@buffer: The ring buffer to get the next event from*@cpu: the cpu to read the buffer from*@ts: a variable to store the timestamp (may be NULL)*@lost_events: a variable to store if events were lost (may be
Proto:struct ring_buffer_event *ring_buffer_consume(struct ring_buffer *buffer, int cpu, u64 *ts, unsigned long *lost_events)
Type:struct ring_buffer_event
Parameter:
Type | Parameter | Name |
---|---|---|
struct ring_buffer * | buffer | |
int | cpu | |
u64 * | ts | |
unsigned long * | lost_events |
4148 | struct ring_buffer_event * event = NULL |
4152 | again : |
4156 | If Not pumask_test_cpu - test for a cpu in a cpumask*@cpu: cpu number (< nr_cpu_ids)*@cpumask: the cpumask pointer* Returns 1 if @cpu is set in @cpumask, else returns 0 Then Go to out |
4159 | cpu_buffer = buffers[cpu] |
4160 | local_irq_save(flags) |
4161 | dolock = rb_reader_lock(cpu_buffer) |
4163 | event = rb_buffer_peek(cpu_buffer, ts, lost_events) |
4164 | If event Then |
4165 | lost_events = 0 |
4166 | rb_advance_reader(cpu_buffer) |
4169 | rb_reader_unlock(cpu_buffer, dolock) |
4170 | local_irq_restore(flags) |
4172 | out : |
4173 | preempt_enable() |
4175 | If event && type_len == RINGBUF_TYPE_PADDING Then Go to again |
4178 | Return event |
Name | Describe |
---|---|
read_event | |
trace_consume | |
get_return_for_leaf |
Source code conversion tool public plug-in interface | X |
---|---|
Support c/c++/esqlc/java Oracle/Informix/Mysql Plug-in can realize: logical Report Code generation and batch code conversion |