projects
/
lttng-ust.git
/ blobdiff
commit
grep
author
committer
pickaxe
?
search:
re
summary
|
shortlog
|
log
|
commit
|
commitdiff
|
tree
raw
|
inline
| side by side
Implement dynamic types, and application context provider support
[lttng-ust.git]
/
liblttng-ust
/
lttng-filter.h
diff --git
a/liblttng-ust/lttng-filter.h
b/liblttng-ust/lttng-filter.h
index fdc8ac67ed1ada4b72996240de380bf1e6bb3ebb..23ccff2318def4a882ee05fc6738a582e5949f0d 100644
(file)
--- a/
liblttng-ust/lttng-filter.h
+++ b/
liblttng-ust/lttng-filter.h
@@
-27,6
+27,7
@@
#include <stdio.h>
#include <helper.h>
#include <lttng/ust-events.h>
#include <stdio.h>
#include <helper.h>
#include <lttng/ust-events.h>
+#include <lttng/ust-context-provider.h>
#include <stdint.h>
#include <assert.h>
#include <errno.h>
#include <stdint.h>
#include <assert.h>
#include <errno.h>
@@
-78,7
+79,7
@@
enum entry_type {
REG_S64,
REG_DOUBLE,
REG_STRING,
REG_S64,
REG_DOUBLE,
REG_STRING,
- REG_
TYPE_
UNKNOWN,
+ REG_UNKNOWN,
};
/* Validation stack */
};
/* Validation stack */
@@
-137,6
+138,7
@@
int vstack_pop(struct vstack *stack)
/* Execution stack */
struct estack_entry {
/* Execution stack */
struct estack_entry {
+ enum entry_type type; /* For dynamic typing. */
union {
int64_t v;
double d;
union {
int64_t v;
double d;
@@
-154,9
+156,18
@@
struct estack {
struct estack_entry e[FILTER_STACK_LEN];
};
struct estack_entry e[FILTER_STACK_LEN];
};
+/*
+ * Always use aliased type for ax/bx (top of stack).
+ * When ax/bx are S64, use aliased value.
+ */
#define estack_ax_v ax
#define estack_bx_v bx
#define estack_ax_v ax
#define estack_bx_v bx
+#define estack_ax_t ax_t
+#define estack_bx_t bx_t
+/*
+ * ax and bx registers can hold either integer, double or string.
+ */
#define estack_ax(stack, top) \
({ \
assert((top) > FILTER_STACK_EMPTY); \
#define estack_ax(stack, top) \
({ \
assert((top) > FILTER_STACK_EMPTY); \
@@
-169,19
+180,26
@@
struct estack {
&(stack)->e[(top) - 1]; \
})
&(stack)->e[(top) - 1]; \
})
-#define estack_push(stack, top, ax, bx) \
+/*
+ * Currently, only integers (REG_S64) can be pushed into the stack.
+ */
+#define estack_push(stack, top, ax, bx, ax_t, bx_t) \
do { \
assert((top) < FILTER_STACK_LEN - 1); \
(stack)->e[(top) - 1].u.v = (bx); \
do { \
assert((top) < FILTER_STACK_LEN - 1); \
(stack)->e[(top) - 1].u.v = (bx); \
+ (stack)->e[(top) - 1].type = (bx_t); \
(bx) = (ax); \
(bx) = (ax); \
+ (bx_t) = (ax_t); \
++(top); \
} while (0)
++(top); \
} while (0)
-#define estack_pop(stack, top, ax, bx
)
\
+#define estack_pop(stack, top, ax, bx
, ax_t, bx_t)
\
do { \
assert((top) > FILTER_STACK_EMPTY); \
(ax) = (bx); \
do { \
assert((top) > FILTER_STACK_EMPTY); \
(ax) = (bx); \
+ (ax_t) = (bx_t); \
(bx) = (stack)->e[(top) - 2].u.v; \
(bx) = (stack)->e[(top) - 2].u.v; \
+ (bx_t) = (stack)->e[(top) - 2].type; \
(top)--; \
} while (0)
(top)--; \
} while (0)
This page took
0.024311 seconds
and
4
git commands to generate.