X-Git-Url: http://git.efficios.com/?p=babeltrace.git;a=blobdiff_plain;f=formats%2Fctf%2Fcallbacks.c;h=71e3248868239fd806d6cceb2bdcce48e9e06886;hp=8e0d61e62e36d2c2de9ff451ace8ebcc91cf7551;hb=c462e188f3e7819c7bc74f671038cdbf36e8c3c0;hpb=8a4722b0ccf5cf30ee76a85bdf6bea2fa0515153 diff --git a/formats/ctf/callbacks.c b/formats/ctf/callbacks.c index 8e0d61e6..71e32488 100644 --- a/formats/ctf/callbacks.c +++ b/formats/ctf/callbacks.c @@ -16,6 +16,14 @@ * * The above copyright notice and this permission notice shall be included in * all copies or substantial portions of the Software. + * + * THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR + * IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY, + * FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE + * AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER + * LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM, + * OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE + * SOFTWARE. */ #include @@ -64,7 +72,7 @@ struct bt_dependencies *babeltrace_dependencies_create(const char *first, ...) */ int bt_ctf_iter_add_callback(struct bt_ctf_iter *iter, bt_intern_str event, void *private_data, int flags, - enum bt_cb_ret (*callback)(struct ctf_event_definition *ctf_data, + enum bt_cb_ret (*callback)(struct bt_ctf_event *ctf_data, void *private_data), struct bt_dependencies *depends, struct bt_dependencies *weak_depends, @@ -73,8 +81,12 @@ int bt_ctf_iter_add_callback(struct bt_ctf_iter *iter, int i, stream_id; gpointer *event_id_ptr; unsigned long event_id; - struct trace_collection *tc = iter->parent.ctx->tc; + struct trace_collection *tc; + + if (!iter || !callback) + return -EINVAL; + tc = iter->parent.ctx->tc; for (i = 0; i < tc->array->len; i++) { struct ctf_trace *tin; struct trace_descriptor *td_read; @@ -146,29 +158,29 @@ int bt_ctf_iter_add_callback(struct bt_ctf_iter *iter, } static -struct ctf_event_definition *extract_ctf_stream_event(struct ctf_stream_definition *stream) +int extract_ctf_stream_event(struct ctf_stream_definition *stream, + struct bt_ctf_event *event) { struct ctf_stream_declaration *stream_class = stream->stream_class; struct ctf_event_declaration *event_class; - struct ctf_event_definition *event; uint64_t id = stream->event_id; if (id >= stream_class->events_by_id->len) { fprintf(stderr, "[error] Event id %" PRIu64 " is outside range.\n", id); - return NULL; + return -1; } - event = g_ptr_array_index(stream->events_by_id, id); - if (!event) { + event->parent = g_ptr_array_index(stream->events_by_id, id); + if (!event->parent) { fprintf(stderr, "[error] Event id %" PRIu64 " is unknown.\n", id); - return NULL; + return -1; } event_class = g_ptr_array_index(stream_class->events_by_id, id); if (!event_class) { fprintf(stderr, "[error] Event id %" PRIu64 " is unknown.\n", id); - return NULL; + return -1; } - return event; + return 0; } void process_callbacks(struct bt_ctf_iter *iter, @@ -179,9 +191,13 @@ void process_callbacks(struct bt_ctf_iter *iter, struct bt_callback *cb; int i; enum bt_cb_ret ret; - struct ctf_event_definition *ctf_data; + struct bt_ctf_event ctf_data; - ctf_data = extract_ctf_stream_event(stream); + assert(iter && stream); + + ret = extract_ctf_stream_event(stream, &ctf_data); + if (ret) + goto end; /* process all events callback first */ if (iter->main_callbacks.callback) { @@ -189,7 +205,7 @@ void process_callbacks(struct bt_ctf_iter *iter, cb = &g_array_index(iter->main_callbacks.callback, struct bt_callback, i); if (!cb) goto end; - ret = cb->callback(ctf_data, cb->private_data); + ret = cb->callback(&ctf_data, cb->private_data); switch (ret) { case BT_CB_OK_STOP: case BT_CB_ERROR_STOP: @@ -217,7 +233,7 @@ void process_callbacks(struct bt_ctf_iter *iter, cb = &g_array_index(bt_chain->callback, struct bt_callback, i); if (!cb) goto end; - ret = cb->callback(ctf_data, cb->private_data); + ret = cb->callback(&ctf_data, cb->private_data); switch (ret) { case BT_CB_OK_STOP: case BT_CB_ERROR_STOP: