X-Git-Url: http://git.efficios.com/?a=blobdiff_plain;f=include%2Fbabeltrace%2Fgraph%2Fnotification-internal.h;h=243aac09cb1ffdfa40a8adf611060fe21128d56f;hb=3fea54f69edd1780566230255da196cb6e82df62;hp=c37d2f10b4c0a65beee806e43644038c8caeef05;hpb=f6ccaed94e575af57fe6bf38154771bee4871a2a;p=babeltrace.git diff --git a/include/babeltrace/graph/notification-internal.h b/include/babeltrace/graph/notification-internal.h index c37d2f10..243aac09 100644 --- a/include/babeltrace/graph/notification-internal.h +++ b/include/babeltrace/graph/notification-internal.h @@ -1,5 +1,5 @@ -#ifndef BABELTRACE_COMPONENT_NOTIFICATION_NOTIFICATION_INTERNAL_H -#define BABELTRACE_COMPONENT_NOTIFICATION_NOTIFICATION_INTERNAL_H +#ifndef BABELTRACE_GRAPH_NOTIFICATION_NOTIFICATION_INTERNAL_H +#define BABELTRACE_GRAPH_NOTIFICATION_NOTIFICATION_INTERNAL_H /* * BabelTrace - Plug-in Notification internal @@ -27,11 +27,12 @@ * SOFTWARE. */ -#include #include #include +#include #include #include +#include #include typedef struct bt_stream *(*get_stream_func)( @@ -40,8 +41,11 @@ typedef struct bt_stream *(*get_stream_func)( struct bt_notification { struct bt_object base; enum bt_notification_type type; - get_stream_func get_stream; + uint64_t seq_num; bt_bool frozen; + + /* Owned by this; keeps the graph alive while the notif. is alive */ + struct bt_graph *graph; }; #define BT_ASSERT_PRE_NOTIF_IS_TYPE(_notif, _type) \ @@ -53,23 +57,67 @@ struct bt_notification { BT_HIDDEN void bt_notification_init(struct bt_notification *notification, enum bt_notification_type type, - bt_object_release_func release); + bt_object_release_func release, + struct bt_graph *graph); + +static inline +void bt_notification_reset(struct bt_notification *notification) +{ + BT_ASSERT(notification); + +#ifdef BT_DEV_MODE + notification->frozen = BT_FALSE; + notification->seq_num = UINT64_C(-1); +#endif +} + +static inline +struct bt_notification *bt_notification_create_from_pool( + struct bt_object_pool *pool, struct bt_graph *graph) +{ + struct bt_notification *notif = bt_object_pool_create_object(pool); + + if (!notif) { +#ifdef BT_LIB_LOGE + BT_LIB_LOGE("Cannot allocate one notification from notification pool: " + "%![pool-]+o, %![graph-]+g", pool, graph); +#endif + goto error; + } + + if (!notif->graph) { + notif->graph = graph; + } + + goto end; + +error: + BT_PUT(notif); -static inline void bt_notification_freeze(struct bt_notification *notification) +end: + return notif; +} + +static inline void _bt_notification_freeze(struct bt_notification *notification) { notification->frozen = BT_TRUE; } +BT_HIDDEN +void bt_notification_unlink_graph(struct bt_notification *notif); + +#ifdef BT_DEV_MODE +# define bt_notification_freeze _bt_notification_freeze +#else +# define bt_notification_freeze(_x) +#endif /* BT_DEV_MODE */ + static inline const char *bt_notification_type_string(enum bt_notification_type type) { switch (type) { - case BT_NOTIFICATION_TYPE_SENTINEL: - return "BT_NOTIFICATION_TYPE_SENTINEL"; case BT_NOTIFICATION_TYPE_UNKNOWN: return "BT_NOTIFICATION_TYPE_UNKNOWN"; - case BT_NOTIFICATION_TYPE_ALL: - return "BT_NOTIFICATION_TYPE_ALL"; case BT_NOTIFICATION_TYPE_EVENT: return "BT_NOTIFICATION_TYPE_EVENT"; case BT_NOTIFICATION_TYPE_INACTIVITY: @@ -91,4 +139,4 @@ const char *bt_notification_type_string(enum bt_notification_type type) } } -#endif /* BABELTRACE_COMPONENT_NOTIFICATION_NOTIFICATION_INTERNAL_H */ +#endif /* BABELTRACE_GRAPH_NOTIFICATION_NOTIFICATION_INTERNAL_H */