2 * Copyright (C) 2012 - David Goulet <dgoulet@efficios.com>
4 * This program is free software; you can redistribute it and/or modify it
5 * under the terms of the GNU General Public License, version 2 only, as
6 * published by the Free Software Foundation.
8 * This program is distributed in the hope that it will be useful, but WITHOUT
9 * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
10 * FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License for
13 * You should have received a copy of the GNU General Public License along with
14 * this program; if not, write to the Free Software Foundation, Inc., 51
15 * Franklin Street, Fifth Floor, Boston, MA 02110-1301 USA.
24 #include <common/sessiond-comm/relayd.h>
25 #include <common/sessiond-comm/sessiond-comm.h>
26 #include <common/trace-chunk.h>
27 #include <common/dynamic-array.h>
29 struct relayd_stream_rotation_position
{
32 * Sequence number of the first packet belonging to the new
33 * "destination" trace chunk to which the stream is rotating.
35 * Ignored for metadata streams.
37 uint64_t rotate_at_seq_num
;
40 int relayd_connect(struct lttcomm_relayd_sock
*sock
);
41 int relayd_close(struct lttcomm_relayd_sock
*sock
);
42 int relayd_create_session(struct lttcomm_relayd_sock
*rsock
,
43 uint64_t *relayd_session_id
,
44 const char *session_name
, const char *hostname
,
45 int session_live_timer
,
46 unsigned int snapshot
, uint64_t sessiond_session_id
,
47 const lttng_uuid sessiond_uuid
,
48 const uint64_t *current_chunk_id
,
49 time_t creation_time
);
50 int relayd_add_stream(struct lttcomm_relayd_sock
*sock
, const char *channel_name
,
51 const char *pathname
, uint64_t *stream_id
,
52 uint64_t tracefile_size
, uint64_t tracefile_count
,
53 struct lttng_trace_chunk
*trace_chunk
);
54 int relayd_streams_sent(struct lttcomm_relayd_sock
*rsock
);
55 int relayd_send_close_stream(struct lttcomm_relayd_sock
*sock
, uint64_t stream_id
,
56 uint64_t last_net_seq_num
);
57 int relayd_version_check(struct lttcomm_relayd_sock
*sock
);
58 int relayd_start_data(struct lttcomm_relayd_sock
*sock
);
59 int relayd_send_metadata(struct lttcomm_relayd_sock
*sock
, size_t len
);
60 int relayd_send_data_hdr(struct lttcomm_relayd_sock
*sock
,
61 struct lttcomm_relayd_data_hdr
*hdr
, size_t size
);
62 int relayd_data_pending(struct lttcomm_relayd_sock
*sock
, uint64_t stream_id
,
63 uint64_t last_net_seq_num
);
64 int relayd_quiescent_control(struct lttcomm_relayd_sock
*sock
,
65 uint64_t metadata_stream_id
);
66 int relayd_begin_data_pending(struct lttcomm_relayd_sock
*sock
, uint64_t id
);
67 int relayd_end_data_pending(struct lttcomm_relayd_sock
*sock
, uint64_t id
,
68 unsigned int *is_data_inflight
);
69 int relayd_send_index(struct lttcomm_relayd_sock
*rsock
,
70 struct ctf_packet_index
*index
, uint64_t relay_stream_id
,
71 uint64_t net_seq_num
);
72 int relayd_reset_metadata(struct lttcomm_relayd_sock
*rsock
,
73 uint64_t stream_id
, uint64_t version
);
74 /* `positions` is an array of `stream_count` relayd_stream_rotation_position. */
75 int relayd_rotate_streams(struct lttcomm_relayd_sock
*sock
,
76 unsigned int stream_count
, const uint64_t *new_chunk_id
,
77 const struct relayd_stream_rotation_position
*positions
);
78 int relayd_create_trace_chunk(struct lttcomm_relayd_sock
*sock
,
79 struct lttng_trace_chunk
*chunk
);
80 int relayd_close_trace_chunk(struct lttcomm_relayd_sock
*sock
,
81 struct lttng_trace_chunk
*chunk
);
82 int relayd_trace_chunk_exists(struct lttcomm_relayd_sock
*sock
,
83 uint64_t chunk_id
, bool *chunk_exists
);
85 #endif /* _RELAYD_H */