X-Git-Url: https://git.lttng.org/?p=lttng-tools.git;a=blobdiff_plain;f=src%2Fcommon%2Fconsumer.h;h=ac3b4903f6b8c3e945432b35a471100a8998aede;hp=a80bc40ab9128e8ae3c5987bd4c8870736cc35bb;hb=b83e03c49920557f292d3861f42d0109e6fa03ea;hpb=d7ba13889c8692b14f99238ddf2721ed78df89d2 diff --git a/src/common/consumer.h b/src/common/consumer.h index a80bc40ab..ac3b4903f 100644 --- a/src/common/consumer.h +++ b/src/common/consumer.h @@ -207,6 +207,9 @@ struct lttng_consumer_channel { /* Timer value in usec for live streaming. */ unsigned int live_timer_interval; + int *stream_fds; + int nr_stream_fds; + char root_shm_path[PATH_MAX]; char shm_path[PATH_MAX]; }; @@ -239,6 +242,21 @@ struct lttng_consumer_stream { int shm_fd_is_copy; int data_read; int hangup_flush_done; + + /* + * metadata_timer_lock protects flags waiting_on_metadata and + * missed_metadata_flush. + */ + pthread_mutex_t metadata_timer_lock; + /* + * Flag set when awaiting metadata to be pushed. Used in the + * timer thread to skip waiting on the stream (and stream lock) to + * ensure we can proceed to flushing metadata in live mode. + */ + bool waiting_on_metadata; + /* Raised when a timer misses a metadata flush. */ + bool missed_metadata_flush; + enum lttng_event_output output; /* Maximum subbuffer size. */ unsigned long max_sb_size; @@ -602,6 +620,7 @@ struct lttng_consumer_channel *consumer_allocate_channel(uint64_t key, uint64_t session_id_per_pid, unsigned int monitor, unsigned int live_timer_interval, + const char *root_shm_path, const char *shm_path); void consumer_del_stream(struct lttng_consumer_stream *stream, struct lttng_ht *ht);