4 * Copyright 2011 (c) - Mathieu Desnoyers <mathieu.desnoyers@efficios.com>
6 * LTTng trace/channel/event context management.
8 * Dual LGPL v2.1/GPL v2 license.
11 #include <linux/module.h>
12 #include <linux/list.h>
13 #include <linux/mutex.h>
14 #include <linux/slab.h>
15 #include "wrapper/vmalloc.h" /* for wrapper_vmalloc_sync_all() */
16 #include "ltt-events.h"
17 #include "ltt-tracer.h"
19 int lttng_find_context(struct lttng_ctx
*ctx
, const char *name
)
23 for (i
= 0; i
< ctx
->nr_fields
; i
++) {
24 /* Skip allocated (but non-initialized) contexts */
25 if (!ctx
->fields
[i
].event_field
.name
)
27 if (!strcmp(ctx
->fields
[i
].event_field
.name
, name
))
32 EXPORT_SYMBOL_GPL(lttng_find_context
);
35 * Note: as we append context information, the pointer location may change.
37 struct lttng_ctx_field
*lttng_append_context(struct lttng_ctx
**ctx_p
)
39 struct lttng_ctx_field
*field
;
40 struct lttng_ctx
*ctx
;
43 *ctx_p
= kzalloc(sizeof(struct lttng_ctx
), GFP_KERNEL
);
48 if (ctx
->nr_fields
+ 1 > ctx
->allocated_fields
) {
49 struct lttng_ctx_field
*new_fields
;
51 ctx
->allocated_fields
= max_t(size_t, 1, 2 * ctx
->allocated_fields
);
52 new_fields
= kzalloc(ctx
->allocated_fields
* sizeof(struct lttng_ctx_field
), GFP_KERNEL
);
56 memcpy(new_fields
, ctx
->fields
, sizeof(*ctx
->fields
) * ctx
->nr_fields
);
58 ctx
->fields
= new_fields
;
60 field
= &ctx
->fields
[ctx
->nr_fields
];
64 EXPORT_SYMBOL_GPL(lttng_append_context
);
67 * Remove last context field.
69 void lttng_remove_context_field(struct lttng_ctx
**ctx_p
,
70 struct lttng_ctx_field
*field
)
72 struct lttng_ctx
*ctx
;
76 WARN_ON_ONCE(&ctx
->fields
[ctx
->nr_fields
] != field
);
77 memset(&ctx
->fields
[ctx
->nr_fields
], 0, sizeof(struct lttng_ctx_field
));
79 EXPORT_SYMBOL_GPL(lttng_remove_context_field
);
81 void lttng_destroy_context(struct lttng_ctx
*ctx
)
87 for (i
= 0; i
< ctx
->nr_fields
; i
++) {
88 if (ctx
->fields
[i
].destroy
)
89 ctx
->fields
[i
].destroy(&ctx
->fields
[i
]);