4 * Babeltrace Sink Component
6 * Copyright 2015 Jérémie Galarneau <jeremie.galarneau@efficios.com>
8 * Author: Jérémie Galarneau <jeremie.galarneau@efficios.com>
10 * Permission is hereby granted, free of charge, to any person obtaining a copy
11 * of this software and associated documentation files (the "Software"), to deal
12 * in the Software without restriction, including without limitation the rights
13 * to use, copy, modify, merge, publish, distribute, sublicense, and/or sell
14 * copies of the Software, and to permit persons to whom the Software is
15 * furnished to do so, subject to the following conditions:
17 * The above copyright notice and this permission notice shall be included in
18 * all copies or substantial portions of the Software.
20 * THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR
21 * IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY,
22 * FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE
23 * AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER
24 * LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM,
25 * OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE
29 #include <babeltrace/compiler.h>
30 #include <babeltrace/plugin/sink-internal.h>
31 #include <babeltrace/plugin/component-internal.h>
32 #include <babeltrace/plugin/notification/notification.h>
35 enum bt_component_status
bt_component_sink_validate(
36 struct bt_component
*component
)
38 enum bt_component_status ret
= BT_COMPONENT_STATUS_OK
;
39 struct bt_component_sink
*sink
;
41 sink
= container_of(component
, struct bt_component_sink
, parent
);
42 if (sink
->registered_notifications_mask
== 0) {
44 * A sink must be registered to at least one notification type.
46 printf_error("Invalid sink component; not registered to any notification");
47 ret
= BT_COMPONENT_STATUS_INVALID
;
51 if (!sink
->handle_notification
) {
52 printf_error("Invalid sink component; no notification handling callback defined.");
53 ret
= BT_COMPONENT_STATUS_INVALID
;
61 struct bt_component
*bt_component_sink_create(
62 struct bt_component_class
*class, struct bt_value
*params
)
64 struct bt_component_sink
*sink
= NULL
;
65 enum bt_component_status ret
;
67 sink
= g_new0(struct bt_component_sink
, 1);
72 ret
= bt_component_init(&sink
->parent
, bt_component_sink_destroy
);
73 if (ret
!= BT_COMPONENT_STATUS_OK
) {
78 return sink
? &sink
->parent
: NULL
;
81 enum bt_component_status
bt_component_sink_handle_notification(
82 struct bt_component
*component
,
83 struct bt_notification
*notification
)
85 enum bt_component_status ret
= BT_COMPONENT_STATUS_OK
;
86 struct bt_component_sink
*sink
= NULL
;
88 if (!component
|| !notification
) {
89 ret
= BT_COMPONENT_STATUS_INVALID
;
93 if (bt_component_get_type(component
) != BT_COMPONENT_TYPE_SINK
) {
94 ret
= BT_COMPONENT_STATUS_UNSUPPORTED
;
98 sink
= container_of(component
, struct bt_component_sink
, parent
);
99 assert(sink
->handle_notification
);
100 ret
= sink
->handle_notification(component
, notification
);
105 enum bt_component_status
bt_component_sink_register_notification_type(
106 struct bt_component
*component
, enum bt_notification_type type
)
108 enum bt_component_status ret
= BT_COMPONENT_STATUS_OK
;
109 struct bt_component_sink
*sink
= NULL
;
112 ret
= BT_COMPONENT_STATUS_INVALID
;
116 if (bt_component_get_type(component
) != BT_COMPONENT_TYPE_SINK
) {
117 ret
= BT_COMPONENT_STATUS_UNSUPPORTED
;
121 if (type
<= BT_NOTIFICATION_TYPE_UNKNOWN
||
122 type
>= BT_NOTIFICATION_TYPE_NR
) {
123 ret
= BT_COMPONENT_STATUS_INVALID
;
126 sink
= container_of(component
, struct bt_component_sink
, parent
);
127 if (type
== BT_NOTIFICATION_TYPE_ALL
) {
128 sink
->registered_notifications_mask
= ~(notification_mask_t
) 0;
130 sink
->registered_notifications_mask
|=
131 (notification_mask_t
) 1 << type
;