trace: add trace event iterator APIs
Currently methods which want to iterate over trace events, do so using the trace_event_count() and trace_event_id() methods. This leaks the concept of a single ID enum to the callers. There is an alternative trace_event_pattern() method which can be used in an iteration context, but its design is stateless, so is not easy to expand it in the future. This defines a formal iterator API will provide a future- proof way of iterating over events. The iterator is also able to apply a pattern match filter to events, further removing the need for the pattern Reviewed-by: Stefan Hajnoczi <stefanha@redhat.com> Reviewed-by: Lluís Vilanova <vilanova@ac.upc.edu> Signed-off-by: Daniel P. Berrange <berrange@redhat.com> Message-id: 1475588159-30598-4-git-send-email-berrange@redhat.com Signed-off-by: Stefan Hajnoczi <stefanha@redhat.com>
This commit is contained in:
		
							parent
							
								
									170f75ad80
								
							
						
					
					
						commit
						6a1b0f3aea
					
				@ -125,6 +125,27 @@ TraceEvent *trace_event_pattern(const char *pat, TraceEvent *ev)
 | 
				
			|||||||
    return NULL;
 | 
					    return NULL;
 | 
				
			||||||
}
 | 
					}
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					void trace_event_iter_init(TraceEventIter *iter, const char *pattern)
 | 
				
			||||||
 | 
					{
 | 
				
			||||||
 | 
					    iter->event = 0;
 | 
				
			||||||
 | 
					    iter->pattern = pattern;
 | 
				
			||||||
 | 
					}
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					TraceEvent *trace_event_iter_next(TraceEventIter *iter)
 | 
				
			||||||
 | 
					{
 | 
				
			||||||
 | 
					    while (iter->event < TRACE_EVENT_COUNT) {
 | 
				
			||||||
 | 
					        TraceEvent *ev = &(trace_events[iter->event]);
 | 
				
			||||||
 | 
					        iter->event++;
 | 
				
			||||||
 | 
					        if (!iter->pattern ||
 | 
				
			||||||
 | 
					            pattern_glob(iter->pattern,
 | 
				
			||||||
 | 
					                         trace_event_get_name(ev))) {
 | 
				
			||||||
 | 
					            return ev;
 | 
				
			||||||
 | 
					        }
 | 
				
			||||||
 | 
					    }
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					    return NULL;
 | 
				
			||||||
 | 
					}
 | 
				
			||||||
 | 
					
 | 
				
			||||||
void trace_list_events(void)
 | 
					void trace_list_events(void)
 | 
				
			||||||
{
 | 
					{
 | 
				
			||||||
    int i;
 | 
					    int i;
 | 
				
			||||||
 | 
				
			|||||||
@ -13,6 +13,10 @@
 | 
				
			|||||||
#include "qemu-common.h"
 | 
					#include "qemu-common.h"
 | 
				
			||||||
#include "trace/generated-events.h"
 | 
					#include "trace/generated-events.h"
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					typedef struct TraceEventIter {
 | 
				
			||||||
 | 
					    size_t event;
 | 
				
			||||||
 | 
					    const char *pattern;
 | 
				
			||||||
 | 
					} TraceEventIter;
 | 
				
			||||||
 | 
					
 | 
				
			||||||
/**
 | 
					/**
 | 
				
			||||||
 * TraceEventID:
 | 
					 * TraceEventID:
 | 
				
			||||||
@ -25,6 +29,29 @@
 | 
				
			|||||||
 */
 | 
					 */
 | 
				
			||||||
enum TraceEventID;
 | 
					enum TraceEventID;
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					/**
 | 
				
			||||||
 | 
					 * trace_event_iter_init:
 | 
				
			||||||
 | 
					 * @iter: the event iterator struct
 | 
				
			||||||
 | 
					 * @pattern: optional pattern to filter events on name
 | 
				
			||||||
 | 
					 *
 | 
				
			||||||
 | 
					 * Initialize the event iterator struct @iter,
 | 
				
			||||||
 | 
					 * optionally using @pattern to filter out events
 | 
				
			||||||
 | 
					 * with non-matching names.
 | 
				
			||||||
 | 
					 */
 | 
				
			||||||
 | 
					void trace_event_iter_init(TraceEventIter *iter, const char *pattern);
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					/**
 | 
				
			||||||
 | 
					 * trace_event_iter_next:
 | 
				
			||||||
 | 
					 * @iter: the event iterator struct
 | 
				
			||||||
 | 
					 *
 | 
				
			||||||
 | 
					 * Get the next event, if any. When this returns NULL,
 | 
				
			||||||
 | 
					 * the iterator should no longer be used.
 | 
				
			||||||
 | 
					 *
 | 
				
			||||||
 | 
					 * Returns: the next event, or NULL if no more events exist
 | 
				
			||||||
 | 
					 */
 | 
				
			||||||
 | 
					TraceEvent *trace_event_iter_next(TraceEventIter *iter);
 | 
				
			||||||
 | 
					
 | 
				
			||||||
/**
 | 
					/**
 | 
				
			||||||
 * trace_event_id:
 | 
					 * trace_event_id:
 | 
				
			||||||
 * @id: Event identifier.
 | 
					 * @id: Event identifier.
 | 
				
			||||||
 | 
				
			|||||||
		Loading…
	
	
			
			x
			
			
		
	
		Reference in New Issue
	
	Block a user