|  | /* | 
|  | * Interface for configuring and controlling the state of tracing events. | 
|  | * | 
|  | * Copyright (C) 2011-2014 LluĂs Vilanova <vilanova@ac.upc.edu> | 
|  | * | 
|  | * This work is licensed under the terms of the GNU GPL, version 2 or later. | 
|  | * See the COPYING file in the top-level directory. | 
|  | */ | 
|  |  | 
|  | #ifndef TRACE__CONTROL_H | 
|  | #define TRACE__CONTROL_H | 
|  |  | 
|  | #include "qemu-common.h" | 
|  | #include "trace/generated-events.h" | 
|  |  | 
|  |  | 
|  | /** | 
|  | * TraceEventID: | 
|  | * | 
|  | * Unique tracing event identifier. | 
|  | * | 
|  | * These are named as 'TRACE_${EVENT_NAME}'. | 
|  | * | 
|  | * See also: "trace/generated-events.h" | 
|  | */ | 
|  | enum TraceEventID; | 
|  |  | 
|  | /** | 
|  | * trace_event_id: | 
|  | * @id: Event identifier. | 
|  | * | 
|  | * Get an event by its identifier. | 
|  | * | 
|  | * This routine has a constant cost, as opposed to trace_event_name and | 
|  | * trace_event_pattern. | 
|  | * | 
|  | * Pre-conditions: The identifier is valid. | 
|  | * | 
|  | * Returns: pointer to #TraceEvent. | 
|  | * | 
|  | */ | 
|  | static TraceEvent *trace_event_id(TraceEventID id); | 
|  |  | 
|  | /** | 
|  | * trace_event_name: | 
|  | * @id: Event name. | 
|  | * | 
|  | * Search an event by its name. | 
|  | * | 
|  | * Returns: pointer to #TraceEvent or NULL if not found. | 
|  | */ | 
|  | TraceEvent *trace_event_name(const char *name); | 
|  |  | 
|  | /** | 
|  | * trace_event_pattern: | 
|  | * @pat: Event name pattern. | 
|  | * @ev: Event to start searching from (not included). | 
|  | * | 
|  | * Get all events with a given name pattern. | 
|  | * | 
|  | * Returns: pointer to #TraceEvent or NULL if not found. | 
|  | */ | 
|  | TraceEvent *trace_event_pattern(const char *pat, TraceEvent *ev); | 
|  |  | 
|  | /** | 
|  | * trace_event_is_pattern: | 
|  | * | 
|  | * Whether the given string is an event name pattern. | 
|  | */ | 
|  | static bool trace_event_is_pattern(const char *str); | 
|  |  | 
|  | /** | 
|  | * trace_event_count: | 
|  | * | 
|  | * Return the number of events. | 
|  | */ | 
|  | static TraceEventID trace_event_count(void); | 
|  |  | 
|  |  | 
|  |  | 
|  | /** | 
|  | * trace_event_get_id: | 
|  | * | 
|  | * Get the identifier of an event. | 
|  | */ | 
|  | static TraceEventID trace_event_get_id(TraceEvent *ev); | 
|  |  | 
|  | /** | 
|  | * trace_event_get_name: | 
|  | * | 
|  | * Get the name of an event. | 
|  | */ | 
|  | static const char * trace_event_get_name(TraceEvent *ev); | 
|  |  | 
|  | /** | 
|  | * trace_event_get_state: | 
|  | * @id: Event identifier. | 
|  | * | 
|  | * Get the tracing state of an event (both static and dynamic). | 
|  | * | 
|  | * If the event has the disabled property, the check will have no performance | 
|  | * impact. | 
|  | * | 
|  | * As a down side, you must always use an immediate #TraceEventID value. | 
|  | */ | 
|  | #define trace_event_get_state(id)                       \ | 
|  | ((id ##_ENABLED) && trace_event_get_state_dynamic(trace_event_id(id))) | 
|  |  | 
|  | /** | 
|  | * trace_event_get_state_static: | 
|  | * @id: Event identifier. | 
|  | * | 
|  | * Get the static tracing state of an event. | 
|  | * | 
|  | * Use the define 'TRACE_${EVENT_NAME}_ENABLED' for compile-time checks (it will | 
|  | * be set to 1 or 0 according to the presence of the disabled property). | 
|  | */ | 
|  | static bool trace_event_get_state_static(TraceEvent *ev); | 
|  |  | 
|  | /** | 
|  | * trace_event_get_state_dynamic: | 
|  | * | 
|  | * Get the dynamic tracing state of an event. | 
|  | */ | 
|  | static bool trace_event_get_state_dynamic(TraceEvent *ev); | 
|  |  | 
|  | /** | 
|  | * trace_event_set_state: | 
|  | * | 
|  | * Set the tracing state of an event (only if possible). | 
|  | */ | 
|  | #define trace_event_set_state(id, state)                \ | 
|  | do {                                                \ | 
|  | if ((id ##_ENABLED)) {                          \ | 
|  | TraceEvent *_e = trace_event_id(id);        \ | 
|  | trace_event_set_state_dynamic(_e, state);   \ | 
|  | }                                               \ | 
|  | } while (0) | 
|  |  | 
|  | /** | 
|  | * trace_event_set_state_dynamic: | 
|  | * | 
|  | * Set the dynamic tracing state of an event. | 
|  | * | 
|  | * Pre-condition: trace_event_get_state_static(ev) == true | 
|  | */ | 
|  | static void trace_event_set_state_dynamic(TraceEvent *ev, bool state); | 
|  |  | 
|  |  | 
|  |  | 
|  | /** | 
|  | * trace_init_backends: | 
|  | * @events: Name of file with events to be enabled at startup; may be NULL. | 
|  | *          Corresponds to commandline option "-trace events=...". | 
|  | * @file:   Name of trace output file; may be NULL. | 
|  | *          Corresponds to commandline option "-trace file=...". | 
|  | * | 
|  | * Initialize the tracing backend. | 
|  | * | 
|  | * Returns: Whether the backends could be successfully initialized. | 
|  | */ | 
|  | bool trace_init_backends(const char *events, const char *file); | 
|  |  | 
|  |  | 
|  | #include "trace/control-internal.h" | 
|  |  | 
|  | #endif  /* TRACE__CONTROL_H */ |