ring buffer: handle shmp errors
[lttng-ust.git] / libringbuffer / frontend.h
index 770090770e9de16081a351db63f571616c4627b3..160fd45532f39573b09178f6924bba71b1f65264 100644 (file)
@@ -65,7 +65,7 @@ struct lttng_ust_shm_handle *channel_create(const struct lttng_ust_lib_ring_buff
                                size_t subbuf_size, size_t num_subbuf,
                                unsigned int switch_timer_interval,
                                unsigned int read_timer_interval,
-                               const char *shm_path);
+                               const int *stream_fds, int nr_stream_fds);
 
 /*
  * channel_destroy finalizes all channel's buffers, waits for readers to
@@ -162,9 +162,14 @@ static inline
 void lib_ring_buffer_put_next_subbuf(struct lttng_ust_lib_ring_buffer *buf,
                                     struct lttng_ust_shm_handle *handle)
 {
+       struct channel *chan;
+
+       chan = shmp(handle, buf->backend.chan);
+       if (!chan)
+               return;
        lib_ring_buffer_put_subbuf(buf, handle);
-       lib_ring_buffer_move_consumer(buf, subbuf_align(buf->cons_snapshot,
-                                                       shmp(handle, buf->backend.chan)), handle);
+       lib_ring_buffer_move_consumer(buf, subbuf_align(buf->cons_snapshot, chan),
+                       handle);
 }
 
 extern void channel_reset(struct channel *chan);
This page took 0.023264 seconds and 4 git commands to generate.