1 #ifndef BABELTRACE_GRAPH_MESSAGE_ITERATOR_INTERNAL_H
2 #define BABELTRACE_GRAPH_MESSAGE_ITERATOR_INTERNAL_H
5 * Copyright 2017-2018 Philippe Proulx <pproulx@efficios.com>
6 * Copyright 2015 Jérémie Galarneau <jeremie.galarneau@efficios.com>
8 * Permission is hereby granted, free of charge, to any person obtaining a copy
9 * of this software and associated documentation files (the "Software"), to deal
10 * in the Software without restriction, including without limitation the rights
11 * to use, copy, modify, merge, publish, distribute, sublicense, and/or sell
12 * copies of the Software, and to permit persons to whom the Software is
13 * furnished to do so, subject to the following conditions:
15 * The above copyright notice and this permission notice shall be included in
16 * all copies or substantial portions of the Software.
18 * THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR
19 * IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY,
20 * FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE
21 * AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER
22 * LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM,
23 * OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE
27 #include "common/macros.h"
28 #include "lib/object.h"
29 #include <babeltrace2/graph/connection-const.h>
30 #include <babeltrace2/graph/message-const.h>
31 #include <babeltrace2/types.h>
32 #include "common/assert.h"
34 #include "common/uuid.h"
39 enum bt_message_iterator_type
{
40 BT_MESSAGE_ITERATOR_TYPE_SELF_COMPONENT_PORT_INPUT
,
41 BT_MESSAGE_ITERATOR_TYPE_PORT_OUTPUT
,
44 enum bt_self_component_port_input_message_iterator_state
{
45 /* Iterator is not initialized */
46 BT_SELF_COMPONENT_PORT_INPUT_MESSAGE_ITERATOR_STATE_NON_INITIALIZED
,
48 /* Iterator is active, not at the end yet, and not finalized */
49 BT_SELF_COMPONENT_PORT_INPUT_MESSAGE_ITERATOR_STATE_ACTIVE
,
52 * Iterator is ended, not finalized yet: the "next" method
53 * returns BT_MESSAGE_ITERATOR_STATUS_END.
55 BT_SELF_COMPONENT_PORT_INPUT_MESSAGE_ITERATOR_STATE_ENDED
,
57 /* Iterator is currently being finalized */
58 BT_SELF_COMPONENT_PORT_INPUT_MESSAGE_ITERATOR_STATE_FINALIZING
,
60 /* Iterator is finalized */
61 BT_SELF_COMPONENT_PORT_INPUT_MESSAGE_ITERATOR_STATE_FINALIZED
,
63 /* Iterator is seeking */
64 BT_SELF_COMPONENT_PORT_INPUT_MESSAGE_ITERATOR_STATE_SEEKING
,
66 /* Iterator did seek, but returned `BT_MESSAGE_ITERATOR_STATUS_AGAIN` */
67 BT_SELF_COMPONENT_PORT_INPUT_MESSAGE_ITERATOR_STATE_LAST_SEEKING_RETURNED_AGAIN
,
69 /* Iterator did seek, but returned error status */
70 BT_SELF_COMPONENT_PORT_INPUT_MESSAGE_ITERATOR_STATE_LAST_SEEKING_RETURNED_ERROR
,
73 struct bt_message_iterator
{
74 struct bt_object base
;
75 enum bt_message_iterator_type type
;
79 typedef enum bt_component_class_message_iterator_next_method_status
80 (*bt_self_component_port_input_message_iterator_next_method
)(
81 void *, bt_message_array_const
, uint64_t, uint64_t *);
83 typedef enum bt_component_class_message_iterator_seek_ns_from_origin_method_status
84 (*bt_self_component_port_input_message_iterator_seek_ns_from_origin_method
)(
87 typedef enum bt_component_class_message_iterator_seek_beginning_method_status
88 (*bt_self_component_port_input_message_iterator_seek_beginning_method
)(
92 (*bt_self_component_port_input_message_iterator_can_seek_ns_from_origin_method
)(
96 (*bt_self_component_port_input_message_iterator_can_seek_beginning_method
)(
99 struct bt_self_component_port_input_message_iterator
{
100 struct bt_message_iterator base
;
101 struct bt_component
*upstream_component
; /* Weak */
102 struct bt_port
*upstream_port
; /* Weak */
103 struct bt_connection
*connection
; /* Weak */
104 struct bt_graph
*graph
; /* Weak */
107 bt_self_component_port_input_message_iterator_next_method next
;
108 bt_self_component_port_input_message_iterator_seek_ns_from_origin_method seek_ns_from_origin
;
109 bt_self_component_port_input_message_iterator_seek_beginning_method seek_beginning
;
110 bt_self_component_port_input_message_iterator_can_seek_ns_from_origin_method can_seek_ns_from_origin
;
111 bt_self_component_port_input_message_iterator_can_seek_beginning_method can_seek_beginning
;
114 enum bt_self_component_port_input_message_iterator_state state
;
117 * Timestamp of the last received message (or INT64_MIN in the
118 * beginning, or after a seek to beginning).
120 int64_t last_ns_from_origin
;
124 /* We haven't recorded clock properties yet. */
125 CLOCK_EXPECTATION_UNSET
,
127 /* Expect to have no clock. */
128 CLOCK_EXPECTATION_NONE
,
130 /* Clock with origin_is_unix_epoch true.*/
131 CLOCK_EXPECTATION_ORIGIN_UNIX
,
133 /* Clock with origin_is_unix_epoch false, with a UUID.*/
134 CLOCK_EXPECTATION_ORIGIN_OTHER_UUID
,
136 /* Clock with origin_is_unix_epoch false, without a UUID.*/
137 CLOCK_EXPECTATION_ORIGIN_OTHER_NO_UUID
,
141 * Expected UUID of the clock, if `type`is CLOCK_EXPECTATION_ORIGIN_OTHER_UUID.
143 * If the clock's origin is the unix epoch, the UUID is
144 * irrelevant (as the clock will be correlatable with other
145 * clocks having the same origin).
151 * Data necessary for auto seek (the seek-to-beginning then fast-forward
156 * Queue of `const bt_message *` (owned by this queue).
158 * When fast-forwarding, we get the messages from upstream in
159 * batches. Once we have found the first message with timestamp
160 * greater or equal to the seek time, we put it and all of the
161 * following message of the batch in this queue. They will be
162 * sent on the next "next" call on this iterator.
164 * The messages are in chronological order (i.e. the first to
165 * send is the first of the queue).
170 * After auto-seeking, we replace the iterator's `next` callback
171 * with our own, which returns the contents of the `msgs` queue.
172 * This field is where we save the original callback, so we can
175 void *original_next_callback
;
181 struct bt_port_output_message_iterator
{
182 struct bt_message_iterator base
;
183 struct bt_graph
*graph
; /* Owned by this */
184 struct bt_component_sink
*colander
; /* Owned by this */
187 * Only used temporarily as a bridge between a colander sink and
194 void bt_self_component_port_input_message_iterator_try_finalize(
195 struct bt_self_component_port_input_message_iterator
*iterator
);
198 void bt_self_component_port_input_message_iterator_set_connection(
199 struct bt_self_component_port_input_message_iterator
*iterator
,
200 struct bt_connection
*connection
);
203 const char *bt_self_component_port_input_message_iterator_state_string(
204 enum bt_self_component_port_input_message_iterator_state state
)
207 case BT_SELF_COMPONENT_PORT_INPUT_MESSAGE_ITERATOR_STATE_ACTIVE
:
208 return "BT_SELF_COMPONENT_PORT_INPUT_MESSAGE_ITERATOR_STATE_ACTIVE";
209 case BT_SELF_COMPONENT_PORT_INPUT_MESSAGE_ITERATOR_STATE_ENDED
:
210 return "BT_SELF_COMPONENT_PORT_INPUT_MESSAGE_ITERATOR_STATE_ENDED";
211 case BT_SELF_COMPONENT_PORT_INPUT_MESSAGE_ITERATOR_STATE_FINALIZING
:
212 return "BT_SELF_COMPONENT_PORT_INPUT_MESSAGE_ITERATOR_STATE_FINALIZING";
213 case BT_SELF_COMPONENT_PORT_INPUT_MESSAGE_ITERATOR_STATE_FINALIZED
:
214 return "BT_SELF_COMPONENT_PORT_INPUT_MESSAGE_ITERATOR_STATE_FINALIZED";
215 case BT_SELF_COMPONENT_PORT_INPUT_MESSAGE_ITERATOR_STATE_SEEKING
:
216 return "BT_SELF_COMPONENT_PORT_INPUT_MESSAGE_ITERATOR_STATE_SEEKING";
217 case BT_SELF_COMPONENT_PORT_INPUT_MESSAGE_ITERATOR_STATE_LAST_SEEKING_RETURNED_AGAIN
:
218 return "BT_SELF_COMPONENT_PORT_INPUT_MESSAGE_ITERATOR_STATE_LAST_SEEKING_RETURNED_AGAIN";
219 case BT_SELF_COMPONENT_PORT_INPUT_MESSAGE_ITERATOR_STATE_LAST_SEEKING_RETURNED_ERROR
:
220 return "BT_SELF_COMPONENT_PORT_INPUT_MESSAGE_ITERATOR_STATE_LAST_SEEKING_RETURNED_ERROR";
226 #endif /* BABELTRACE_GRAPH_MESSAGE_ITERATOR_INTERNAL_H */