char session_name[LTTNG_NAME_MAX];
/* > 0 if a timer is set. */
uint64_t timer_us;
+ /* > 0 if the session should rotate when it has written that many bytes. */
+ uint64_t size;
} LTTNG_PACKED;
/*
* Where the rotated (readable) trace has been stored when the
* rotation is completed.
*/
- struct {
- bool is_set;
- char path[LTTNG_PATH_MAX];
- } archive_location;
+ struct lttng_trace_archive_location *archive_location;
};
/*
struct lttng_rotation_get_info_return {
/* Represents values defined in enum lttng_rotation_state. */
int32_t status;
- char path[LTTNG_PATH_MAX];
+ /* Represents values defined in enum lttng_rotation_state. */
+ int8_t location_type;
+ union {
+ struct {
+ char absolute_path[LTTNG_PATH_MAX];
+ } LTTNG_PACKED local;
+ struct {
+ char host[LTTNG_HOST_NAME_MAX];
+ /*
+ * Represents values defined in
+ * enum lttng_trace_archive_location_relay_protocol_type.
+ */
+ int8_t protocol;
+ struct {
+ uint16_t control;
+ uint16_t data;
+ } LTTNG_PACKED ports;
+ char relative_path[LTTNG_PATH_MAX];
+ } LTTNG_PACKED relay;
+ } location;
} LTTNG_PACKED;
/* For the LTTNG_SESSION_GET_CURRENT_OUTPUT command. */
char path[LTTNG_PATH_MAX];
} LTTNG_PACKED;
+/* For the LTTNG_ROTATION_SCHEDULE_GET_TIMER_PERIOD command. */
+struct lttng_rotation_schedule_get_timer_period {
+ uint64_t rotate_timer;
+} LTTNG_PACKED;
+
+/* For the LTTNG_ROTATION_SCHEDULE_GET_SIZE command. */
+struct lttng_rotation_schedule_get_size {
+ uint64_t rotate_size;
+} LTTNG_PACKED;
+
#endif /* LTTNG_ROTATE_INTERNAL_ABI_H */