From: David Goulet Date: Thu, 13 Dec 2012 21:41:57 +0000 (-0500) Subject: Fix: add packed attribute to filter structure X-Git-Tag: v2.1.0~55 X-Git-Url: https://git.lttng.org/?p=lttng-tools.git;a=commitdiff_plain;h=6f30f9b8bcf68f2c4c8b796c38751ab3f59583fb Fix: add packed attribute to filter structure Also fix the internal UST abi by swapping two variables and fit the upstream UST abi. Signed-off-by: David Goulet --- diff --git a/src/bin/lttng-sessiond/lttng-ust-abi.h b/src/bin/lttng-sessiond/lttng-ust-abi.h index 0a80abe30..81143504e 100644 --- a/src/bin/lttng-sessiond/lttng-ust-abi.h +++ b/src/bin/lttng-sessiond/lttng-ust-abi.h @@ -56,9 +56,9 @@ struct lttng_ust_tracer_version { #define LTTNG_UST_CHANNEL_PADDING LTTNG_UST_SYM_NAME_LEN + 32 struct lttng_ust_channel { - int overwrite; /* 1: overwrite, 0: discard */ uint64_t subbuf_size; /* in bytes */ uint64_t num_subbuf; + int overwrite; /* 1: overwrite, 0: discard */ unsigned int switch_timer_interval; /* usecs */ unsigned int read_timer_interval; /* usecs */ enum lttng_ust_output output; /* output mode */ @@ -132,9 +132,9 @@ struct lttng_ust_context { */ #define LTTNG_UST_CHANNEL_ATTR_PADDING LTTNG_UST_SYM_NAME_LEN + 32 struct lttng_ust_channel_attr { - int overwrite; /* 1: overwrite, 0: discard */ uint64_t subbuf_size; /* bytes */ uint64_t num_subbuf; /* power of 2 */ + int overwrite; /* 1: overwrite, 0: discard */ unsigned int switch_timer_interval; /* usec */ unsigned int read_timer_interval; /* usec */ enum lttng_ust_output output; /* splice, mmap */ diff --git a/src/lib/lttng-ctl/filter/filter-bytecode.h b/src/lib/lttng-ctl/filter/filter-bytecode.h index 06dace84c..786174484 100644 --- a/src/lib/lttng-ctl/filter/filter-bytecode.h +++ b/src/lib/lttng-ctl/filter/filter-bytecode.h @@ -33,19 +33,19 @@ struct field_ref { /* Initially, symbol offset. After link, field offset. */ uint16_t offset; -} __attribute__((packed)); +} LTTNG_PACKED; struct literal_numeric { int64_t v; -} __attribute__((packed)); +} LTTNG_PACKED; struct literal_double { double v; -} __attribute__((packed)); +} LTTNG_PACKED; struct literal_string { char string[0]; -} __attribute__((packed)); +} LTTNG_PACKED; enum filter_op { FILTER_OP_UNKNOWN = 0, @@ -151,29 +151,29 @@ struct load_op { filter_opcode_t op; char data[0]; /* data to load. Size known by enum filter_opcode and null-term char. */ -} __attribute__((packed)); +} LTTNG_PACKED; struct binary_op { filter_opcode_t op; -} __attribute__((packed)); +} LTTNG_PACKED; struct unary_op { filter_opcode_t op; -} __attribute__((packed)); +} LTTNG_PACKED; /* skip_offset is absolute from start of bytecode */ struct logical_op { filter_opcode_t op; uint16_t skip_offset; /* bytecode insn, if skip second test */ -} __attribute__((packed)); +} LTTNG_PACKED; struct cast_op { filter_opcode_t op; -} __attribute__((packed)); +} LTTNG_PACKED; struct return_op { filter_opcode_t op; -} __attribute__((packed)); +} LTTNG_PACKED; struct lttng_filter_bytecode_alloc { uint32_t alloc_len;