#include <lttng/ust-compiler.h>
struct lttng_ust_lib_ring_buffer;
-struct channel;
+struct lttng_ust_lib_ring_buffer_channel;
struct lttng_ust_lib_ring_buffer_config;
struct lttng_ust_lib_ring_buffer_ctx;
struct lttng_ust_shm_handle;
/* Mandatory callbacks */
/* A static inline version is also required for fast path */
- uint64_t (*ring_buffer_clock_read) (struct channel *chan);
+ uint64_t (*ring_buffer_clock_read) (struct lttng_ust_lib_ring_buffer_channel *chan);
size_t (*record_header_size) (const struct lttng_ust_lib_ring_buffer_config *config,
- struct channel *chan, size_t offset,
+ struct lttng_ust_lib_ring_buffer_channel *chan,
+ size_t offset,
size_t *pre_header_padding,
struct lttng_ust_lib_ring_buffer_ctx *ctx,
void *client_ctx);
* iterator.
*/
void (*record_get) (const struct lttng_ust_lib_ring_buffer_config *config,
- struct channel *chan, struct lttng_ust_lib_ring_buffer *buf,
+ struct lttng_ust_lib_ring_buffer_channel *chan,
+ struct lttng_ust_lib_ring_buffer *buf,
size_t offset, size_t *header_len,
size_t *payload_len, uint64_t *timestamp,
struct lttng_ust_shm_handle *handle);
* UST. Fields need to be only added at the end, never reordered, never
* removed.
*/
-#define LTTNG_UST_RING_BUFFER_CTX_PADDING \
- (24 - sizeof(int) - sizeof(void *) - sizeof(void *))
+#define LTTNG_UST_RING_BUFFER_CTX_PADDING 64
struct lttng_ust_lib_ring_buffer_ctx {
+ uint32_t struct_size; /* Size of this structure. */
+
/* input received by lib_ring_buffer_reserve(), saved here. */
- struct channel *chan; /* channel */
+ struct lttng_ust_lib_ring_buffer_channel *chan; /* channel */
void *priv; /* client private data */
struct lttng_ust_shm_handle *handle; /* shared-memory handle */
size_t data_size; /* size of payload */
*/
uint64_t tsc; /* time-stamp counter value */
unsigned int rflags; /* reservation flags */
- /*
- * The field ctx_len is the length of struct
- * lttng_ust_lib_ring_buffer_ctx as known by the user of
- * lib_ring_buffer_ctx_init.
- */
- unsigned int ctx_len;
void *ip; /* caller ip address */
- void *priv2; /* 2nd priv data */
- char padding2[LTTNG_UST_RING_BUFFER_CTX_PADDING];
- /*
- * This is the end of the initial fields expected by the original ABI
- * between probes and UST. Only the fields above can be used if
- * ctx_len is 0. Use the value of ctx_len to find out which of the
- * following fields may be used.
- */
struct lttng_ust_lib_ring_buffer_backend_pages *backend_pages;
};
*/
static inline lttng_ust_notrace
void lib_ring_buffer_ctx_init(struct lttng_ust_lib_ring_buffer_ctx *ctx,
- struct channel *chan, void *priv,
- size_t data_size, int largest_align,
- int cpu, struct lttng_ust_shm_handle *handle,
- void *priv2);
+ struct lttng_ust_lib_ring_buffer_channel *chan,
+ void *priv, size_t data_size, int largest_align,
+ int cpu, struct lttng_ust_shm_handle *handle);
static inline
void lib_ring_buffer_ctx_init(struct lttng_ust_lib_ring_buffer_ctx *ctx,
- struct channel *chan, void *priv,
- size_t data_size, int largest_align,
- int cpu, struct lttng_ust_shm_handle *handle,
- void *priv2)
+ struct lttng_ust_lib_ring_buffer_channel *chan,
+ void *priv, size_t data_size, int largest_align,
+ int cpu, struct lttng_ust_shm_handle *handle)
{
+ ctx->struct_size = sizeof(struct lttng_ust_lib_ring_buffer_ctx);
ctx->chan = chan;
ctx->priv = priv;
ctx->data_size = data_size;
ctx->cpu = cpu;
ctx->rflags = 0;
ctx->handle = handle;
- ctx->ctx_len = sizeof(struct lttng_ust_lib_ring_buffer_ctx);
ctx->ip = 0;
- ctx->priv2 = priv2;
- memset(ctx->padding2, 0, LTTNG_UST_RING_BUFFER_CTX_PADDING);
}
/*