X-Git-Url: http://git.efficios.com/?p=babeltrace.git;a=blobdiff_plain;f=include%2Fbabeltrace%2Fctf-ir%2Fmetadata.h;h=63a6c2a9b4a9b9aa0d28259fd9ca8adb39937e3e;hp=fb78439b5491e0c2d907775899fa5ebea253f5ec;hb=32cfb8adf760170061946d1f802677fb02f6dc96;hpb=9e88d150c4119a0c6d6288cad6d6db87df7bac4b diff --git a/include/babeltrace/ctf-ir/metadata.h b/include/babeltrace/ctf-ir/metadata.h index fb78439b..63a6c2a9 100644 --- a/include/babeltrace/ctf-ir/metadata.h +++ b/include/babeltrace/ctf-ir/metadata.h @@ -30,18 +30,16 @@ struct ctf_trace; struct ctf_stream_declaration; -struct ctf_stream_definition; -struct ctf_event; -struct ctf_stream_definition; +struct ctf_event_declaration; struct ctf_clock; struct ctf_stream_definition { struct ctf_stream_declaration *stream_class; - uint64_t timestamp; /* Current timestamp, in ns */ + uint64_t real_timestamp; /* Current timestamp, in ns */ + uint64_t cycles_timestamp; /* Current timestamp, in cycles */ uint64_t event_id; /* Current event ID */ int has_timestamp; uint64_t stream_id; - int consumed; /* Last packet used by caller */ struct definition_struct *trace_packet_header; struct definition_struct *stream_packet_context; @@ -54,12 +52,15 @@ struct ctf_stream_definition { struct ctf_clock *current_clock; /* Event discarded information */ - uint32_t events_discarded; - uint64_t prev_timestamp; /* Last event */ - uint64_t prev_timestamp_end; /* End-of-packet timestamp */ + uint64_t events_discarded; + uint64_t prev_real_timestamp; /* Start-of-last-packet timestamp in ns */ + uint64_t prev_real_timestamp_end; /* End-of-last-packet timestamp in ns */ + uint64_t prev_cycles_timestamp; /* Start-of-last-packet timestamp in cycles */ + uint64_t prev_cycles_timestamp_end; /* End-of-last-packet timestamp in cycles */ }; struct ctf_event_definition { + struct ctf_stream_definition *stream; struct definition_struct *event_context; struct definition_struct *event_fields; }; @@ -122,6 +123,7 @@ struct ctf_tracer_env { /* All strings below: "" if unset. */ char procname[TRACER_ENV_LEN]; + char hostname[TRACER_ENV_LEN]; char domain[TRACER_ENV_LEN]; char sysname[TRACER_ENV_LEN]; char release[TRACER_ENV_LEN]; @@ -141,6 +143,7 @@ struct ctf_trace { GHashTable *clocks; struct ctf_clock *single_clock; /* currently supports only one clock */ struct trace_collection *collection; /* Container of this trace */ + GPtrArray *event_declarations; /* Array of all the struct bt_ctf_event_decl */ struct declaration_struct *packet_header_decl; @@ -191,7 +194,7 @@ struct ctf_stream_declaration { struct declaration_scope *declaration_scope; /* innermost definition scope. to be used as parent of event. */ struct definition_scope *definition_scope; - GPtrArray *events_by_id; /* Array of struct ctf_event pointers indexed by id */ + GPtrArray *events_by_id; /* Array of struct ctf_event_declaration pointers indexed by id */ GHashTable *event_quark_to_id; /* GQuark to numeric id */ struct declaration_struct *packet_context_decl; @@ -221,7 +224,7 @@ struct ctf_stream_declaration { (ctf_event)->(field); \ }) -struct ctf_event { +struct ctf_event_declaration { /* stream mapped by stream_id */ struct ctf_stream_declaration *stream; /* parent is lexical scope conaining the event scope */