Move definitions to per-file structure
authorMathieu Desnoyers <mathieu.desnoyers@efficios.com>
Mon, 23 May 2011 23:18:20 +0000 (19:18 -0400)
committerMathieu Desnoyers <mathieu.desnoyers@efficios.com>
Mon, 23 May 2011 23:18:20 +0000 (19:18 -0400)
Otherwise, causes problem due to read of multiple files and interaction
with priority heap: the notion of "current" event and current packet is
only valid on a per-file basis.

Signed-off-by: Mathieu Desnoyers <mathieu.desnoyers@efficios.com>
formats/ctf-text/ctf-text.c
formats/ctf/ctf.c
formats/ctf/metadata/ctf-visitor-generate-io-struct.c
include/babeltrace/ctf/metadata.h

index 82578dca139afb4aeae48e35edebdb48d6942dc8..0d551179710dafc368ed9059cbe2a40b62d5facf 100644 (file)
@@ -62,28 +62,29 @@ int ctf_text_write_event(struct stream_pos *ppos,
        struct ctf_stream_class *stream_class = stream->stream_class;
        int field_nr_saved;
        struct ctf_event *event_class;
        struct ctf_stream_class *stream_class = stream->stream_class;
        int field_nr_saved;
        struct ctf_event *event_class;
+       struct ctf_file_event *event;
        uint64_t id = 0;
        int ret;
 
        /* print event header */
        uint64_t id = 0;
        int ret;
 
        /* print event header */
-       if (stream_class->event_header) {
+       if (stream->stream_event_header) {
                struct definition_integer *integer_definition;
                struct definition *variant;
 
                /* lookup event id */
                struct definition_integer *integer_definition;
                struct definition *variant;
 
                /* lookup event id */
-               integer_definition = lookup_integer(&stream_class->event_header->p, "id", FALSE);
+               integer_definition = lookup_integer(&stream->stream_event_header->p, "id", FALSE);
                if (integer_definition) {
                        id = integer_definition->value._unsigned;
                } else {
                        struct definition_enum *enum_definition;
 
                if (integer_definition) {
                        id = integer_definition->value._unsigned;
                } else {
                        struct definition_enum *enum_definition;
 
-                       enum_definition = lookup_enum(&stream_class->event_header->p, "id", FALSE);
+                       enum_definition = lookup_enum(&stream->stream_event_header->p, "id", FALSE);
                        if (enum_definition) {
                                id = enum_definition->integer->value._unsigned;
                        }
                }
 
                        if (enum_definition) {
                                id = enum_definition->integer->value._unsigned;
                        }
                }
 
-               variant = lookup_variant(&stream_class->event_header->p, "v");
+               variant = lookup_variant(&stream->stream_event_header->p, "v");
                if (variant) {
                        integer_definition = lookup_integer(variant, "id", FALSE);
                        if (integer_definition) {
                if (variant) {
                        integer_definition = lookup_integer(variant, "id", FALSE);
                        if (integer_definition) {
@@ -96,8 +97,13 @@ int ctf_text_write_event(struct stream_pos *ppos,
                fprintf(stdout, "[error] Event id %" PRIu64 " is outside range.\n", id);
                return -EINVAL;
        }
                fprintf(stdout, "[error] Event id %" PRIu64 " is outside range.\n", id);
                return -EINVAL;
        }
+       event = g_ptr_array_index(stream->events_by_id, id);
+       if (!event) {
+               fprintf(stdout, "[error] Event id %" PRIu64 " is unknown.\n", id);
+               return -EINVAL;
+       }
        event_class = g_ptr_array_index(stream_class->events_by_id, id);
        event_class = g_ptr_array_index(stream_class->events_by_id, id);
-       if (!event_class) {
+       if (!event) {
                fprintf(stdout, "[error] Event id %" PRIu64 " is unknown.\n", id);
                return -EINVAL;
        }
                fprintf(stdout, "[error] Event id %" PRIu64 " is unknown.\n", id);
                return -EINVAL;
        }
@@ -124,57 +130,71 @@ int ctf_text_write_event(struct stream_pos *ppos,
        else
                fprintf(pos->fp, ":");
 
        else
                fprintf(pos->fp, ":");
 
+       /* print cpuid field from packet context */
+       if (stream->stream_packet_context) {
+               if (pos->field_nr++ != 0)
+                       fprintf(pos->fp, ",");
+               if (pos->print_names)
+                       fprintf(pos->fp, " stream.packet.context =");
+               field_nr_saved = pos->field_nr;
+               pos->field_nr = 0;
+               ret = generic_rw(ppos, &stream->stream_packet_context->p);
+               if (ret)
+                       goto error;
+               pos->field_nr = field_nr_saved;
+       }
+
        /* Only show the event header in verbose mode */
        /* Only show the event header in verbose mode */
-       if (babeltrace_verbose && stream_class->event_header) {
+       if (babeltrace_verbose && stream->stream_event_header) {
                if (pos->field_nr++ != 0)
                        fprintf(pos->fp, ",");
                if (pos->print_names)
                        fprintf(pos->fp, " stream.event.header =");
                field_nr_saved = pos->field_nr;
                pos->field_nr = 0;
                if (pos->field_nr++ != 0)
                        fprintf(pos->fp, ",");
                if (pos->print_names)
                        fprintf(pos->fp, " stream.event.header =");
                field_nr_saved = pos->field_nr;
                pos->field_nr = 0;
-               ret = generic_rw(ppos, &stream_class->event_header->p);
+               ret = generic_rw(ppos, &stream->stream_event_header->p);
                if (ret)
                        goto error;
                pos->field_nr = field_nr_saved;
        }
 
        /* print stream-declared event context */
                if (ret)
                        goto error;
                pos->field_nr = field_nr_saved;
        }
 
        /* print stream-declared event context */
-       if (stream_class->event_context) {
+       if (stream->stream_event_context) {
                if (pos->field_nr++ != 0)
                        fprintf(pos->fp, ",");
                if (pos->print_names)
                        fprintf(pos->fp, " stream.event.context =");
                field_nr_saved = pos->field_nr;
                pos->field_nr = 0;
                if (pos->field_nr++ != 0)
                        fprintf(pos->fp, ",");
                if (pos->print_names)
                        fprintf(pos->fp, " stream.event.context =");
                field_nr_saved = pos->field_nr;
                pos->field_nr = 0;
-               ret = generic_rw(ppos, &stream_class->event_context->p);
+               ret = generic_rw(ppos, &stream->stream_event_context->p);
                if (ret)
                        goto error;
                pos->field_nr = field_nr_saved;
        }
 
        /* print event-declared event context */
                if (ret)
                        goto error;
                pos->field_nr = field_nr_saved;
        }
 
        /* print event-declared event context */
-       if (event_class->context) {
+       if (event->event_context) {
                if (pos->field_nr++ != 0)
                        fprintf(pos->fp, ",");
                if (pos->print_names)
                        fprintf(pos->fp, " event.context =");
                field_nr_saved = pos->field_nr;
                pos->field_nr = 0;
                if (pos->field_nr++ != 0)
                        fprintf(pos->fp, ",");
                if (pos->print_names)
                        fprintf(pos->fp, " event.context =");
                field_nr_saved = pos->field_nr;
                pos->field_nr = 0;
-               ret = generic_rw(ppos, &event_class->context->p);
+               ret = generic_rw(ppos, &event->event_context->p);
                if (ret)
                        goto error;
                pos->field_nr = field_nr_saved;
        }
 
        /* Read and print event payload */
                if (ret)
                        goto error;
                pos->field_nr = field_nr_saved;
        }
 
        /* Read and print event payload */
-       if (event_class->fields) {
+       if (event->event_fields) {
                if (pos->field_nr++ != 0)
                        fprintf(pos->fp, ",");
                if (pos->print_names)
                        fprintf(pos->fp, " event.fields =");
                field_nr_saved = pos->field_nr;
                pos->field_nr = 0;
                if (pos->field_nr++ != 0)
                        fprintf(pos->fp, ",");
                if (pos->print_names)
                        fprintf(pos->fp, " event.fields =");
                field_nr_saved = pos->field_nr;
                pos->field_nr = 0;
-               ret = generic_rw(ppos, &event_class->fields->p);
+               ret = generic_rw(ppos, &event->event_fields->p);
                if (ret)
                        goto error;
                pos->field_nr = field_nr_saved;
                if (ret)
                        goto error;
                pos->field_nr = field_nr_saved;
index 29f95fec1bcae16ba7a8dcc53665c51d18d7729b..a85a5f3695118c7ed5d23bff7452da4a9e435d78 100644 (file)
@@ -119,7 +119,7 @@ int ctf_read_event(struct stream_pos *ppos, struct ctf_stream *stream)
        struct ctf_stream_pos *pos =
                container_of(ppos, struct ctf_stream_pos, parent);
        struct ctf_stream_class *stream_class = stream->stream_class;
        struct ctf_stream_pos *pos =
                container_of(ppos, struct ctf_stream_pos, parent);
        struct ctf_stream_class *stream_class = stream->stream_class;
-       struct ctf_event *event_class;
+       struct ctf_file_event *event;
        uint64_t id = 0;
        int ret;
 
        uint64_t id = 0;
        int ret;
 
@@ -127,27 +127,27 @@ int ctf_read_event(struct stream_pos *ppos, struct ctf_stream *stream)
                return EOF;
 
        /* Read event header */
                return EOF;
 
        /* Read event header */
-       if (stream_class->event_header) {
+       if (stream->stream_event_header) {
                struct definition_integer *integer_definition;
                struct definition *variant;
 
                struct definition_integer *integer_definition;
                struct definition *variant;
 
-               ret = generic_rw(ppos, &stream_class->event_header->p);
+               ret = generic_rw(ppos, &stream->stream_event_header->p);
                if (ret)
                        goto error;
                /* lookup event id */
                if (ret)
                        goto error;
                /* lookup event id */
-               integer_definition = lookup_integer(&stream_class->event_header->p, "id", FALSE);
+               integer_definition = lookup_integer(&stream->stream_event_header->p, "id", FALSE);
                if (integer_definition) {
                        id = integer_definition->value._unsigned;
                } else {
                        struct definition_enum *enum_definition;
 
                if (integer_definition) {
                        id = integer_definition->value._unsigned;
                } else {
                        struct definition_enum *enum_definition;
 
-                       enum_definition = lookup_enum(&stream_class->event_header->p, "id", FALSE);
+                       enum_definition = lookup_enum(&stream->stream_event_header->p, "id", FALSE);
                        if (enum_definition) {
                                id = enum_definition->integer->value._unsigned;
                        }
                }
 
                        if (enum_definition) {
                                id = enum_definition->integer->value._unsigned;
                        }
                }
 
-               variant = lookup_variant(&stream_class->event_header->p, "v");
+               variant = lookup_variant(&stream->stream_event_header->p, "v");
                if (variant) {
                        integer_definition = lookup_integer(variant, "id", FALSE);
                        if (integer_definition) {
                if (variant) {
                        integer_definition = lookup_integer(variant, "id", FALSE);
                        if (integer_definition) {
@@ -156,7 +156,7 @@ int ctf_read_event(struct stream_pos *ppos, struct ctf_stream *stream)
                }
 
                /* lookup timestamp */
                }
 
                /* lookup timestamp */
-               integer_definition = lookup_integer(&stream_class->event_header->p, "timestamp", FALSE);
+               integer_definition = lookup_integer(&stream->stream_event_header->p, "timestamp", FALSE);
                if (integer_definition) {
                        ctf_update_timestamp(stream, integer_definition);
                } else {
                if (integer_definition) {
                        ctf_update_timestamp(stream, integer_definition);
                } else {
@@ -170,8 +170,8 @@ int ctf_read_event(struct stream_pos *ppos, struct ctf_stream *stream)
        }
 
        /* Read stream-declared event context */
        }
 
        /* Read stream-declared event context */
-       if (stream_class->event_context) {
-               ret = generic_rw(ppos, &stream_class->event_context->p);
+       if (stream->stream_event_context) {
+               ret = generic_rw(ppos, &stream->stream_event_context->p);
                if (ret)
                        goto error;
        }
                if (ret)
                        goto error;
        }
@@ -180,22 +180,22 @@ int ctf_read_event(struct stream_pos *ppos, struct ctf_stream *stream)
                fprintf(stdout, "[error] Event id %" PRIu64 " is outside range.\n", id);
                return -EINVAL;
        }
                fprintf(stdout, "[error] Event id %" PRIu64 " is outside range.\n", id);
                return -EINVAL;
        }
-       event_class = g_ptr_array_index(stream_class->events_by_id, id);
-       if (!event_class) {
+       event = g_ptr_array_index(stream->events_by_id, id);
+       if (!event) {
                fprintf(stdout, "[error] Event id %" PRIu64 " is unknown.\n", id);
                return -EINVAL;
        }
 
        /* Read event-declared event context */
                fprintf(stdout, "[error] Event id %" PRIu64 " is unknown.\n", id);
                return -EINVAL;
        }
 
        /* Read event-declared event context */
-       if (event_class->context) {
-               ret = generic_rw(ppos, &event_class->context->p);
+       if (event->event_context) {
+               ret = generic_rw(ppos, &event->event_context->p);
                if (ret)
                        goto error;
        }
 
        /* Read event payload */
                if (ret)
                        goto error;
        }
 
        /* Read event payload */
-       if (event_class->fields) {
-               ret = generic_rw(ppos, &event_class->fields->p);
+       if (event->event_fields) {
+               ret = generic_rw(ppos, &event->event_fields->p);
                if (ret)
                        goto error;
        }
                if (ret)
                        goto error;
        }
@@ -211,29 +211,29 @@ static
 int ctf_write_event(struct stream_pos *pos, struct ctf_stream *stream)
 {
        struct ctf_stream_class *stream_class = stream->stream_class;
 int ctf_write_event(struct stream_pos *pos, struct ctf_stream *stream)
 {
        struct ctf_stream_class *stream_class = stream->stream_class;
-       struct ctf_event *event_class;
+       struct ctf_file_event *event;
        uint64_t id = 0;
        int ret;
 
        /* print event header */
        uint64_t id = 0;
        int ret;
 
        /* print event header */
-       if (stream_class->event_header) {
+       if (stream->stream_event_header) {
                struct definition_integer *integer_definition;
                struct definition *variant;
 
                /* lookup event id */
                struct definition_integer *integer_definition;
                struct definition *variant;
 
                /* lookup event id */
-               integer_definition = lookup_integer(&stream_class->event_header->p, "id", FALSE);
+               integer_definition = lookup_integer(&stream->stream_event_header->p, "id", FALSE);
                if (integer_definition) {
                        id = integer_definition->value._unsigned;
                } else {
                        struct definition_enum *enum_definition;
 
                if (integer_definition) {
                        id = integer_definition->value._unsigned;
                } else {
                        struct definition_enum *enum_definition;
 
-                       enum_definition = lookup_enum(&stream_class->event_header->p, "id", FALSE);
+                       enum_definition = lookup_enum(&stream->stream_event_header->p, "id", FALSE);
                        if (enum_definition) {
                                id = enum_definition->integer->value._unsigned;
                        }
                }
 
                        if (enum_definition) {
                                id = enum_definition->integer->value._unsigned;
                        }
                }
 
-               variant = lookup_variant(&stream_class->event_header->p, "v");
+               variant = lookup_variant(&stream->stream_event_header->p, "v");
                if (variant) {
                        integer_definition = lookup_integer(variant, "id", FALSE);
                        if (integer_definition) {
                if (variant) {
                        integer_definition = lookup_integer(variant, "id", FALSE);
                        if (integer_definition) {
@@ -241,14 +241,14 @@ int ctf_write_event(struct stream_pos *pos, struct ctf_stream *stream)
                        }
                }
 
                        }
                }
 
-               ret = generic_rw(pos, &stream_class->event_header->p);
+               ret = generic_rw(pos, &stream->stream_event_header->p);
                if (ret)
                        goto error;
        }
 
        /* print stream-declared event context */
                if (ret)
                        goto error;
        }
 
        /* print stream-declared event context */
-       if (stream_class->event_context) {
-               ret = generic_rw(pos, &stream_class->event_context->p);
+       if (stream->stream_event_context) {
+               ret = generic_rw(pos, &stream->stream_event_context->p);
                if (ret)
                        goto error;
        }
                if (ret)
                        goto error;
        }
@@ -257,22 +257,22 @@ int ctf_write_event(struct stream_pos *pos, struct ctf_stream *stream)
                fprintf(stdout, "[error] Event id %" PRIu64 " is outside range.\n", id);
                return -EINVAL;
        }
                fprintf(stdout, "[error] Event id %" PRIu64 " is outside range.\n", id);
                return -EINVAL;
        }
-       event_class = g_ptr_array_index(stream_class->events_by_id, id);
-       if (!event_class) {
+       event = g_ptr_array_index(stream->events_by_id, id);
+       if (!event) {
                fprintf(stdout, "[error] Event id %" PRIu64 " is unknown.\n", id);
                return -EINVAL;
        }
 
        /* print event-declared event context */
                fprintf(stdout, "[error] Event id %" PRIu64 " is unknown.\n", id);
                return -EINVAL;
        }
 
        /* print event-declared event context */
-       if (event_class->context) {
-               ret = generic_rw(pos, &event_class->context->p);
+       if (event->event_context) {
+               ret = generic_rw(pos, &event->event_context->p);
                if (ret)
                        goto error;
        }
 
        /* Read and print event payload */
                if (ret)
                        goto error;
        }
 
        /* Read and print event payload */
-       if (event_class->fields) {
-               ret = generic_rw(pos, &event_class->fields->p);
+       if (event->event_fields) {
+               ret = generic_rw(pos, &event->event_fields->p);
                if (ret)
                        goto error;
        }
                if (ret)
                        goto error;
        }
@@ -631,6 +631,125 @@ end_stream:
        return ret;
 }
 
        return ret;
 }
 
+static
+struct ctf_file_event *create_event_definitions(struct ctf_trace *td,
+                                               struct ctf_stream *stream,
+                                               struct ctf_event *event)
+{
+       struct ctf_file_event *file_event = g_new0(struct ctf_file_event, 1);
+
+       if (event->context_decl) {
+               struct definition *definition =
+                       event->context_decl->p.definition_new(&event->context_decl->p,
+                               stream->parent_def_scope, 0, 0, "event.context");
+               if (!definition) {
+                       goto error;
+               }
+               file_event->event_context = container_of(definition,
+                                       struct definition_struct, p);
+               stream->parent_def_scope = file_event->event_context->p.scope;
+       }
+       if (event->fields_decl) {
+               struct definition *definition =
+                       event->fields_decl->p.definition_new(&event->fields_decl->p,
+                               stream->parent_def_scope, 0, 0, "event.fields");
+               if (!definition) {
+                       goto error;
+               }
+               file_event->event_fields = container_of(definition,
+                                       struct definition_struct, p);
+               stream->parent_def_scope = file_event->event_fields->p.scope;
+       }
+       return file_event;
+
+error:
+       if (file_event->event_fields)
+               definition_unref(&file_event->event_fields->p);
+       if (file_event->event_context)
+               definition_unref(&file_event->event_context->p);
+       return NULL;
+}
+
+static
+int create_stream_definitions(struct ctf_trace *td, struct ctf_stream *stream)
+{
+       struct ctf_stream_class *stream_class;
+       int ret;
+       int i;
+
+       if (stream->stream_definitions_created)
+               return 0;
+
+       stream_class = stream->stream_class;
+
+       if (stream_class->packet_context_decl) {
+               struct definition *definition =
+                       stream_class->packet_context_decl->p.definition_new(&stream_class->packet_context_decl->p,
+                               stream->parent_def_scope, 0, 0, "stream.packet.context");
+               if (!definition) {
+                       ret = -EINVAL;
+                       goto error;
+               }
+               stream->stream_packet_context = container_of(definition,
+                                               struct definition_struct, p);
+               stream->parent_def_scope = stream->stream_packet_context->p.scope;
+       }
+       if (stream_class->event_header_decl) {
+               struct definition *definition =
+                       stream_class->event_header_decl->p.definition_new(&stream_class->event_header_decl->p,
+                               stream->parent_def_scope, 0, 0, "stream.event.header");
+               if (!definition) {
+                       ret = -EINVAL;
+                       goto error;
+               }
+               stream->stream_event_header =
+                       container_of(definition, struct definition_struct, p);
+               stream->parent_def_scope = stream->stream_event_header->p.scope;
+       }
+       if (stream_class->event_context_decl) {
+               struct definition *definition =
+                       stream_class->event_context_decl->p.definition_new(&stream_class->event_context_decl->p,
+                               stream->parent_def_scope, 0, 0, "stream.event.context");
+               if (!definition) {
+                       ret = -EINVAL;
+                       goto error;
+               }
+               stream->stream_event_context =
+                       container_of(definition, struct definition_struct, p);
+               stream->parent_def_scope = stream->stream_event_context->p.scope;
+       }
+       stream->events_by_id = g_ptr_array_new();
+       g_ptr_array_set_size(stream->events_by_id, stream_class->events_by_id->len);
+       for (i = 0; i < stream->events_by_id->len; i++) {
+               struct ctf_event *event = g_ptr_array_index(stream_class->events_by_id, i);
+               struct ctf_file_event *file_event;
+
+               if (!event)
+                       continue;
+               file_event = create_event_definitions(td, stream, event);
+               if (!file_event)
+                       goto error_event;
+               g_ptr_array_index(stream->events_by_id, i) = file_event;
+       }
+       return 0;
+
+error_event:
+       for (i = 0; i < stream->events_by_id->len; i++) {
+               struct ctf_file_event *file_event = g_ptr_array_index(stream->events_by_id, i);
+               if (file_event)
+                       g_free(file_event);
+       }
+       g_ptr_array_free(stream->events_by_id, TRUE);
+error:
+       if (stream->stream_event_context)
+               definition_unref(&stream->stream_event_context->p);
+       if (stream->stream_event_header)
+               definition_unref(&stream->stream_event_header->p);
+       if (stream->stream_packet_context)
+               definition_unref(&stream->stream_packet_context->p);
+       return ret;
+}
+
 
 static
 int create_stream_packet_index(struct ctf_trace *td,
 
 static
 int create_stream_packet_index(struct ctf_trace *td,
@@ -675,17 +794,17 @@ int create_stream_packet_index(struct ctf_trace *td,
                packet_index.packet_size = 0;
 
                /* read and check header, set stream id (and check) */
                packet_index.packet_size = 0;
 
                /* read and check header, set stream id (and check) */
-               if (td->packet_header) {
+               if (file_stream->stream.trace_packet_header) {
                        /* Read packet header */
                        /* Read packet header */
-                       ret = generic_rw(&pos->parent, &td->packet_header->p);
+                       ret = generic_rw(&pos->parent, &file_stream->stream.trace_packet_header->p);
                        if (ret)
                                return ret;
                        if (ret)
                                return ret;
-                       len_index = struct_declaration_lookup_field_index(td->packet_header->declaration, g_quark_from_static_string("magic"));
+                       len_index = struct_declaration_lookup_field_index(file_stream->stream.trace_packet_header->declaration, g_quark_from_static_string("magic"));
                        if (len_index >= 0) {
                                struct definition_integer *defint;
                                struct definition *field;
 
                        if (len_index >= 0) {
                                struct definition_integer *defint;
                                struct definition *field;
 
-                               field = struct_definition_get_field_from_index(td->packet_header, len_index);
+                               field = struct_definition_get_field_from_index(file_stream->stream.trace_packet_header, len_index);
                                assert(field->declaration->id == CTF_TYPE_INTEGER);
                                defint = container_of(field, struct definition_integer, p);
                                assert(defint->declaration->signedness == FALSE);
                                assert(field->declaration->id == CTF_TYPE_INTEGER);
                                defint = container_of(field, struct definition_integer, p);
                                assert(defint->declaration->signedness == FALSE);
@@ -699,14 +818,14 @@ int create_stream_packet_index(struct ctf_trace *td,
                        }
 
                        /* check uuid */
                        }
 
                        /* check uuid */
-                       len_index = struct_declaration_lookup_field_index(td->packet_header->declaration, g_quark_from_static_string("uuid"));
+                       len_index = struct_declaration_lookup_field_index(file_stream->stream.trace_packet_header->declaration, g_quark_from_static_string("uuid"));
                        if (len_index >= 0) {
                                struct definition_array *defarray;
                                struct definition *field;
                                uint64_t i;
                                uint8_t uuidval[UUID_LEN];
 
                        if (len_index >= 0) {
                                struct definition_array *defarray;
                                struct definition *field;
                                uint64_t i;
                                uint8_t uuidval[UUID_LEN];
 
-                               field = struct_definition_get_field_from_index(td->packet_header, len_index);
+                               field = struct_definition_get_field_from_index(file_stream->stream.trace_packet_header, len_index);
                                assert(field->declaration->id == CTF_TYPE_ARRAY);
                                defarray = container_of(field, struct definition_array, p);
                                assert(array_len(defarray) == UUID_LEN);
                                assert(field->declaration->id == CTF_TYPE_ARRAY);
                                defarray = container_of(field, struct definition_array, p);
                                assert(array_len(defarray) == UUID_LEN);
@@ -729,12 +848,12 @@ int create_stream_packet_index(struct ctf_trace *td,
                        }
 
 
                        }
 
 
-                       len_index = struct_declaration_lookup_field_index(td->packet_header->declaration, g_quark_from_static_string("stream_id"));
+                       len_index = struct_declaration_lookup_field_index(file_stream->stream.trace_packet_header->declaration, g_quark_from_static_string("stream_id"));
                        if (len_index >= 0) {
                                struct definition_integer *defint;
                                struct definition *field;
 
                        if (len_index >= 0) {
                                struct definition_integer *defint;
                                struct definition *field;
 
-                               field = struct_definition_get_field_from_index(td->packet_header, len_index);
+                               field = struct_definition_get_field_from_index(file_stream->stream.trace_packet_header, len_index);
                                assert(field->declaration->id == CTF_TYPE_INTEGER);
                                defint = container_of(field, struct definition_integer, p);
                                assert(defint->declaration->signedness == FALSE);
                                assert(field->declaration->id == CTF_TYPE_INTEGER);
                                defint = container_of(field, struct definition_integer, p);
                                assert(defint->declaration->signedness == FALSE);
@@ -761,18 +880,22 @@ int create_stream_packet_index(struct ctf_trace *td,
                }
                first_packet = 0;
 
                }
                first_packet = 0;
 
-               if (stream->packet_context) {
+               ret = create_stream_definitions(td, &file_stream->stream);
+               if (ret)
+                       return ret;
+
+               if (file_stream->stream.stream_packet_context) {
                        /* Read packet context */
                        /* Read packet context */
-                       ret = generic_rw(&pos->parent, &stream->packet_context->p);
+                       ret = generic_rw(&pos->parent, &file_stream->stream.stream_packet_context->p);
                        if (ret)
                                return ret;
                        /* read content size from header */
                        if (ret)
                                return ret;
                        /* read content size from header */
-                       len_index = struct_declaration_lookup_field_index(stream->packet_context->declaration, g_quark_from_static_string("content_size"));
+                       len_index = struct_declaration_lookup_field_index(file_stream->stream.stream_packet_context->declaration, g_quark_from_static_string("content_size"));
                        if (len_index >= 0) {
                                struct definition_integer *defint;
                                struct definition *field;
 
                        if (len_index >= 0) {
                                struct definition_integer *defint;
                                struct definition *field;
 
-                               field = struct_definition_get_field_from_index(stream->packet_context, len_index);
+                               field = struct_definition_get_field_from_index(file_stream->stream.stream_packet_context, len_index);
                                assert(field->declaration->id == CTF_TYPE_INTEGER);
                                defint = container_of(field, struct definition_integer, p);
                                assert(defint->declaration->signedness == FALSE);
                                assert(field->declaration->id == CTF_TYPE_INTEGER);
                                defint = container_of(field, struct definition_integer, p);
                                assert(defint->declaration->signedness == FALSE);
@@ -783,12 +906,12 @@ int create_stream_packet_index(struct ctf_trace *td,
                        }
 
                        /* read packet size from header */
                        }
 
                        /* read packet size from header */
-                       len_index = struct_declaration_lookup_field_index(stream->packet_context->declaration, g_quark_from_static_string("packet_size"));
+                       len_index = struct_declaration_lookup_field_index(file_stream->stream.stream_packet_context->declaration, g_quark_from_static_string("packet_size"));
                        if (len_index >= 0) {
                                struct definition_integer *defint;
                                struct definition *field;
 
                        if (len_index >= 0) {
                                struct definition_integer *defint;
                                struct definition *field;
 
-                               field = struct_definition_get_field_from_index(stream->packet_context, len_index);
+                               field = struct_definition_get_field_from_index(file_stream->stream.stream_packet_context, len_index);
                                assert(field->declaration->id == CTF_TYPE_INTEGER);
                                defint = container_of(field, struct definition_integer, p);
                                assert(defint->declaration->signedness == FALSE);
                                assert(field->declaration->id == CTF_TYPE_INTEGER);
                                defint = container_of(field, struct definition_integer, p);
                                assert(defint->declaration->signedness == FALSE);
@@ -832,6 +955,30 @@ int create_stream_packet_index(struct ctf_trace *td,
        return 0;
 }
 
        return 0;
 }
 
+static
+int create_trace_definitions(struct ctf_trace *td, struct ctf_stream *stream)
+{
+       int ret;
+
+       if (td->packet_header_decl) {
+               struct definition *definition =
+                       td->packet_header_decl->p.definition_new(&td->packet_header_decl->p,
+                               stream->parent_def_scope, 0, 0, "trace.packet.header");
+               if (!definition) {
+                       ret = -EINVAL;
+                       goto error;
+               }
+               stream->trace_packet_header = 
+                       container_of(definition, struct definition_struct, p);
+               stream->parent_def_scope = stream->trace_packet_header->p.scope;
+       }
+
+       return 0;
+
+error:
+       return ret;
+}
+
 /*
  * Note: many file streams can inherit from the same stream class
  * description (metadata).
 /*
  * Note: many file streams can inherit from the same stream class
  * description (metadata).
@@ -847,6 +994,9 @@ int ctf_open_file_stream_read(struct ctf_trace *td, const char *path, int flags)
                goto error;
        file_stream = g_new0(struct ctf_file_stream, 1);
        ctf_init_pos(&file_stream->pos, ret, flags);
                goto error;
        file_stream = g_new0(struct ctf_file_stream, 1);
        ctf_init_pos(&file_stream->pos, ret, flags);
+       ret = create_trace_definitions(td, &file_stream->stream);
+       if (ret)
+               goto error_def;
        ret = create_stream_packet_index(td, file_stream);
        if (ret)
                goto error_index;
        ret = create_stream_packet_index(td, file_stream);
        if (ret)
                goto error_index;
@@ -855,6 +1005,9 @@ int ctf_open_file_stream_read(struct ctf_trace *td, const char *path, int flags)
        return 0;
 
 error_index:
        return 0;
 
 error_index:
+       if (file_stream->stream.trace_packet_header)
+               definition_unref(&file_stream->stream.trace_packet_header->p);
+error_def:
        ctf_fini_pos(&file_stream->pos);
        close(file_stream->pos.fd);
        g_free(file_stream);
        ctf_fini_pos(&file_stream->pos);
        close(file_stream->pos.fd);
        g_free(file_stream);
index b62f33d7354f5649ac01c695cd71d2c64fc737e8..f137f6d32e9d90efe8dcd828435bc20a9450391c 100644 (file)
@@ -1556,7 +1556,6 @@ int ctf_event_visit(FILE *fd, int depth, struct ctf_node *node,
        int ret = 0;
        struct ctf_node *iter;
        struct ctf_event *event;
        int ret = 0;
        struct ctf_node *iter;
        struct ctf_event *event;
-       struct definition_scope *parent_def_scope;
 
        event = g_new0(struct ctf_event, 1);
        event->declaration_scope = new_declaration_scope(parent_declaration_scope);
 
        event = g_new0(struct ctf_event, 1);
        event->declaration_scope = new_declaration_scope(parent_declaration_scope);
@@ -1601,38 +1600,9 @@ int ctf_event_visit(FILE *fd, int depth, struct ctf_node *node,
        g_hash_table_insert(event->stream->event_quark_to_id,
                            (gpointer)(unsigned long) event->name,
                            &event->id);
        g_hash_table_insert(event->stream->event_quark_to_id,
                            (gpointer)(unsigned long) event->name,
                            &event->id);
-       parent_def_scope = event->stream->definition_scope;
-       if (event->context_decl) {
-               struct definition *definition =
-                       event->context_decl->p.definition_new(&event->context_decl->p,
-                               parent_def_scope, 0, 0, "event.context");
-               if (!definition) {
-                       ret = -EINVAL;
-                       goto error;
-               }
-               event->context = container_of(definition,
-                                       struct definition_struct, p);
-               parent_def_scope = event->context->p.scope;
-       }
-       if (event->fields_decl) {
-               struct definition *definition =
-                       event->fields_decl->p.definition_new(&event->fields_decl->p,
-                               parent_def_scope, 0, 0, "event.fields");
-               if (!definition) {
-                       ret = -EINVAL;
-                       goto error;
-               }
-               event->fields = container_of(definition,
-                                       struct definition_struct, p);
-               parent_def_scope = event->fields->p.scope;
-       }
        return 0;
 
 error:
        return 0;
 
 error:
-       if (event->context)
-               definition_unref(&event->context->p);
-       if (event->fields)
-               definition_unref(&event->fields->p);
        if (event->fields_decl)
                declaration_unref(&event->fields_decl->p);
        if (event->context_decl)
        if (event->fields_decl)
                declaration_unref(&event->fields_decl->p);
        if (event->context_decl)
@@ -1772,7 +1742,6 @@ int ctf_stream_visit(FILE *fd, int depth, struct ctf_node *node,
        int ret = 0;
        struct ctf_node *iter;
        struct ctf_stream_class *stream;
        int ret = 0;
        struct ctf_node *iter;
        struct ctf_stream_class *stream;
-       struct definition_scope *parent_def_scope;
 
        stream = g_new0(struct ctf_stream_class, 1);
        stream->declaration_scope = new_declaration_scope(parent_declaration_scope);
 
        stream = g_new0(struct ctf_stream_class, 1);
        stream->declaration_scope = new_declaration_scope(parent_declaration_scope);
@@ -1807,54 +1776,9 @@ int ctf_stream_visit(FILE *fd, int depth, struct ctf_node *node,
                g_ptr_array_set_size(trace->streams, stream->stream_id + 1);
        g_ptr_array_index(trace->streams, stream->stream_id) = stream;
 
                g_ptr_array_set_size(trace->streams, stream->stream_id + 1);
        g_ptr_array_index(trace->streams, stream->stream_id) = stream;
 
-       parent_def_scope = trace->definition_scope;
-       if (stream->packet_context_decl) {
-               struct definition *definition =
-                       stream->packet_context_decl->p.definition_new(&stream->packet_context_decl->p,
-                               parent_def_scope, 0, 0, "stream.packet.context");
-               if (!definition) {
-                       ret = -EINVAL;
-                       goto error;
-               }
-               stream->packet_context = container_of(definition,
-                                               struct definition_struct, p);
-               parent_def_scope = stream->packet_context->p.scope;
-       }
-       if (stream->event_header_decl) {
-               struct definition *definition =
-                       stream->event_header_decl->p.definition_new(&stream->event_header_decl->p,
-                               parent_def_scope, 0, 0, "stream.event.header");
-               if (!definition) {
-                       ret = -EINVAL;
-                       goto error;
-               }
-               stream->event_header =
-                       container_of(definition, struct definition_struct, p);
-               parent_def_scope = stream->event_header->p.scope;
-       }
-       if (stream->event_context_decl) {
-               struct definition *definition =
-                       stream->event_context_decl->p.definition_new(&stream->event_context_decl->p,
-                               parent_def_scope, 0, 0, "stream.event.context");
-               if (!definition) {
-                       ret = -EINVAL;
-                       goto error;
-               }
-               stream->event_context =
-                       container_of(definition, struct definition_struct, p);
-               parent_def_scope = stream->event_context->p.scope;
-       }
-       stream->definition_scope = parent_def_scope;
-
        return 0;
 
 error:
        return 0;
 
 error:
-       if (stream->event_context)
-               definition_unref(&stream->event_context->p);
-       if (stream->event_header)
-               definition_unref(&stream->event_header->p);
-       if (stream->packet_context)
-               definition_unref(&stream->packet_context->p);
        if (stream->event_header_decl)
                declaration_unref(&stream->event_header_decl->p);
        if (stream->event_context_decl)
        if (stream->event_header_decl)
                declaration_unref(&stream->event_header_decl->p);
        if (stream->event_context_decl)
@@ -2001,7 +1925,6 @@ error:
 static
 int ctf_trace_visit(FILE *fd, int depth, struct ctf_node *node, struct ctf_trace *trace)
 {
 static
 int ctf_trace_visit(FILE *fd, int depth, struct ctf_node *node, struct ctf_trace *trace)
 {
-       struct definition_scope *parent_def_scope;
        int ret = 0;
        struct ctf_node *iter;
 
        int ret = 0;
        struct ctf_node *iter;
 
@@ -2035,24 +1958,9 @@ int ctf_trace_visit(FILE *fd, int depth, struct ctf_node *node, struct ctf_trace
                goto error;
        }
 
                goto error;
        }
 
-       parent_def_scope = NULL;
-       if (trace->packet_header_decl) {
-               struct definition *definition =
-                       trace->packet_header_decl->p.definition_new(&trace->packet_header_decl->p,
-                               parent_def_scope, 0, 0, "trace.packet.header");
-               if (!definition) {
-                       ret = -EINVAL;
-                       goto error;
-               }
-               trace->packet_header =
-                       container_of(definition, struct definition_struct, p);
-               parent_def_scope = trace->packet_header->p.scope;
-       }
-       trace->definition_scope = parent_def_scope;
-
        if (!CTF_TRACE_FIELD_IS_SET(trace, byte_order)) {
                /* check that the packet header contains a "magic" field */
        if (!CTF_TRACE_FIELD_IS_SET(trace, byte_order)) {
                /* check that the packet header contains a "magic" field */
-               if (!trace->packet_header
+               if (!trace->packet_header_decl
                    || struct_declaration_lookup_field_index(trace->packet_header_decl, g_quark_from_static_string("magic")) < 0) {
                        ret = -EPERM;
                        fprintf(fd, "[error] %s: missing both byte_order and packet header magic number in trace declaration\n", __func__);
                    || struct_declaration_lookup_field_index(trace->packet_header_decl, g_quark_from_static_string("magic")) < 0) {
                        ret = -EPERM;
                        fprintf(fd, "[error] %s: missing both byte_order and packet header magic number in trace declaration\n", __func__);
@@ -2062,8 +1970,6 @@ int ctf_trace_visit(FILE *fd, int depth, struct ctf_node *node, struct ctf_trace
        return 0;
 
 error:
        return 0;
 
 error:
-       if (trace->packet_header)
-               definition_unref(&trace->packet_header->p);
        if (trace->packet_header_decl)
                declaration_unref(&trace->packet_header_decl->p);
        g_ptr_array_free(trace->streams, TRUE);
        if (trace->packet_header_decl)
                declaration_unref(&trace->packet_header_decl->p);
        g_ptr_array_free(trace->streams, TRUE);
index 453c9f7085276de0b4ba5eb6798b475f5d6d7363..56b0aa22e6f913466de2422a6e65ba45db35caef 100644 (file)
@@ -39,6 +39,19 @@ struct ctf_event;
 struct ctf_stream {
        struct ctf_stream_class *stream_class;
        uint64_t timestamp;                     /* Current timestamp, in ns */
 struct ctf_stream {
        struct ctf_stream_class *stream_class;
        uint64_t timestamp;                     /* Current timestamp, in ns */
+
+       struct definition_struct *trace_packet_header;
+       struct definition_struct *stream_packet_context;
+       struct definition_struct *stream_event_header;
+       struct definition_struct *stream_event_context;
+       GPtrArray *events_by_id;                /* Array of struct ctf_file_event pointers indexed by id */
+       struct definition_scope *parent_def_scope;      /* for initialization */
+       int stream_definitions_created;
+};
+
+struct ctf_file_event {
+       struct definition_struct *event_context;
+       struct definition_struct *event_fields;
 };
 
 struct ctf_file_stream {
 };
 
 struct ctf_file_stream {
@@ -76,9 +89,6 @@ struct ctf_trace {
        /* Declarations only used when parsing */
        struct declaration_struct *packet_header_decl;
 
        /* Declarations only used when parsing */
        struct declaration_struct *packet_header_decl;
 
-       /* Definitions used afterward */
-       struct definition_struct *packet_header;
-
        uint64_t major;
        uint64_t minor;
        uuid_t uuid;
        uint64_t major;
        uint64_t minor;
        uuid_t uuid;
@@ -129,11 +139,6 @@ struct ctf_stream_class {
        struct declaration_struct *event_header_decl;
        struct declaration_struct *event_context_decl;
 
        struct declaration_struct *event_header_decl;
        struct declaration_struct *event_context_decl;
 
-       /* Definitions used afterward */
-       struct definition_struct *packet_context;
-       struct definition_struct *event_header;
-       struct definition_struct *event_context;
-
        uint64_t stream_id;
 
        enum {                                  /* Fields populated mask */
        uint64_t stream_id;
 
        enum {                                  /* Fields populated mask */
@@ -167,10 +172,6 @@ struct ctf_event {
        struct declaration_struct *context_decl;
        struct declaration_struct *fields_decl;
 
        struct declaration_struct *context_decl;
        struct declaration_struct *fields_decl;
 
-       /* Definitions used afterward */
-       struct definition_struct *context;
-       struct definition_struct *fields;
-
        GQuark name;
        uint64_t id;            /* Numeric identifier within the stream */
        uint64_t stream_id;
        GQuark name;
        uint64_t id;            /* Numeric identifier within the stream */
        uint64_t stream_id;
This page took 0.037121 seconds and 4 git commands to generate.