2 * SPDX-License-Identifier: LGPL-2.1-only
4 * Copyright (C) 2009-2012 Mathieu Desnoyers <mathieu.desnoyers@efficios.com>
6 * LTTng UST vpid context.
12 #include <sys/types.h>
14 #include <lttng/ust-events.h>
15 #include <lttng/ust-tracer.h>
16 #include <lttng/ringbuffer-context.h>
18 #include "context-internal.h"
21 * We cache the result to ensure we don't trigger a system call for
24 static pid_t cached_vpid
;
27 pid_t
wrapper_getvpid(void)
31 vpid
= CMM_LOAD_SHARED(cached_vpid
);
32 if (caa_unlikely(!vpid
)) {
34 CMM_STORE_SHARED(cached_vpid
, vpid
);
40 * Upon fork or clone, the PID assigned to our thread is not the same as
43 void lttng_context_vpid_reset(void)
45 CMM_STORE_SHARED(cached_vpid
, 0);
49 size_t vpid_get_size(void *priv
__attribute__((unused
)),
54 size
+= lttng_ust_lib_ring_buffer_align(offset
, lttng_ust_rb_alignof(pid_t
));
55 size
+= sizeof(pid_t
);
60 void vpid_record(void *priv
__attribute__((unused
)),
61 struct lttng_ust_lib_ring_buffer_ctx
*ctx
,
62 struct lttng_ust_channel_buffer
*chan
)
64 pid_t vpid
= wrapper_getvpid();
66 chan
->ops
->event_write(ctx
, &vpid
, sizeof(vpid
), lttng_ust_rb_alignof(vpid
));
70 void vpid_get_value(void *priv
__attribute__((unused
)),
71 struct lttng_ust_ctx_value
*value
)
73 value
->u
.s64
= wrapper_getvpid();
76 static const struct lttng_ust_ctx_field
*ctx_field
= lttng_ust_static_ctx_field(
77 lttng_ust_static_event_field("vpid",
78 lttng_ust_static_type_integer(sizeof(pid_t
) * CHAR_BIT
,
79 lttng_ust_rb_alignof(pid_t
) * CHAR_BIT
,
80 lttng_ust_is_signed_type(pid_t
),
88 int lttng_add_vpid_to_ctx(struct lttng_ust_ctx
**ctx
)
92 if (lttng_find_context(*ctx
, ctx_field
->event_field
->name
)) {
94 goto error_find_context
;
96 ret
= lttng_ust_context_append(ctx
, ctx_field
);