dovecot-2.2: lib: array/hash - protect macro parameters
dovecot at dovecot.org
dovecot at dovecot.org
Fri Nov 14 22:13:48 UTC 2014
details: http://hg.dovecot.org/dovecot-2.2/rev/922ac3245e17
changeset: 18089:922ac3245e17
user: Phil Carmody <phil at dovecot.fi>
date: Sat Nov 15 00:06:09 2014 +0200
description:
lib: array/hash - protect macro parameters
If a pointer parameter p is ``ptr + offset'', then sizeof(*p) becomes
sizeof(*ptr + offset), which isn't what was wanted. sizeof(*(p)) is the
safe expression to use instead. Ditto for just ``*data'' in array.h.
The macros in hash.h which have been changed have been reindented for
better readability and consistency.
The bracketting of elem in (elem)++ in both of the array_foreach* macros
isn't actually useful, as elem participates in token-pasting elsewhere.
However, the two macros have been made more similar to each other for
better parallelism.
Signed-off-by: Phil Carmody <phil at dovecot.fi>
diffstat:
src/lib/array.h | 4 ++--
src/lib/hash.h | 20 ++++++++++++--------
2 files changed, 14 insertions(+), 10 deletions(-)
diffs (58 lines):
diff -r 19b9ecfffb39 -r 922ac3245e17 src/lib/array.h
--- a/src/lib/array.h Fri Nov 14 00:59:57 2014 -0800
+++ b/src/lib/array.h Sat Nov 15 00:06:09 2014 +0200
@@ -46,7 +46,7 @@
(typeof(*(array)->v_modifiable))
# define ARRAY_TYPE_CHECK(array, data) \
COMPILE_ERROR_IF_TYPES_NOT_COMPATIBLE( \
- **(array)->v_modifiable, *data)
+ **(array)->v_modifiable, *(data))
#else
# define ARRAY_TYPE_CAST_CONST(array)
# define ARRAY_TYPE_CAST_MODIFIABLE(array)
@@ -64,7 +64,7 @@
(const char *)(elem = ARRAY_TYPE_CAST_MODIFIABLE(array) \
buffer_get_modifiable_data((array)->arr.buffer, NULL)) + \
(array)->arr.buffer->used; \
- elem != elem ## _end; elem++)
+ elem != elem ## _end; (elem)++)
#else
# define array_foreach(array, elem) \
for (elem = *(array)->v; \
diff -r 19b9ecfffb39 -r 922ac3245e17 src/lib/hash.h
--- a/src/lib/hash.h Fri Nov 14 00:59:57 2014 -0800
+++ b/src/lib/hash.h Sat Nov 15 00:06:09 2014 +0200
@@ -85,11 +85,14 @@
#ifndef __cplusplus
# define hash_table_lookup_full(table, lookup_key, orig_key_r, value_r) \
hash_table_lookup_full((table)._table, \
- (void *)((const char *)(lookup_key) + COMPILE_ERROR_IF_TYPES2_NOT_COMPATIBLE((table)._const_key, (table)._key, lookup_key)), \
- (void *)((orig_key_r) + COMPILE_ERROR_IF_TYPES_NOT_COMPATIBLE((table)._keyp, orig_key_r) + \
- COMPILE_ERROR_IF_TRUE(sizeof(*orig_key_r) != sizeof(void *))), \
- (void *)((value_r) + COMPILE_ERROR_IF_TYPES_NOT_COMPATIBLE((table)._valuep, value_r) + \
- COMPILE_ERROR_IF_TRUE(sizeof(*value_r) != sizeof(void *))))
+ (void *)((const char *)(lookup_key) + \
+ COMPILE_ERROR_IF_TYPES2_NOT_COMPATIBLE((table)._const_key, (table)._key, lookup_key)), \
+ (void *)((orig_key_r) + \
+ COMPILE_ERROR_IF_TYPES_NOT_COMPATIBLE((table)._keyp, orig_key_r) + \
+ COMPILE_ERROR_IF_TRUE(sizeof(*(orig_key_r)) != sizeof(void *))), \
+ (void *)((value_r) + \
+ COMPILE_ERROR_IF_TYPES_NOT_COMPATIBLE((table)._valuep, value_r) + \
+ COMPILE_ERROR_IF_TRUE(sizeof(*(value_r)) != sizeof(void *))))
#else
/* C++ requires (void **) casting, but that's not possible with strict
aliasing, so .. we'll just disable the type checks */
@@ -134,9 +137,10 @@
#ifndef __cplusplus
# define hash_table_iterate(ctx, table, key_r, value_r) \
hash_table_iterate(ctx, \
- (void *)((key_r) + COMPILE_ERROR_IF_TYPES_NOT_COMPATIBLE((table)._keyp, key_r) + \
- COMPILE_ERROR_IF_TRUE(sizeof(*key_r) != sizeof(void *)) + \
- COMPILE_ERROR_IF_TRUE(sizeof(*value_r) != sizeof(void *))), \
+ (void *)((key_r) + \
+ COMPILE_ERROR_IF_TYPES_NOT_COMPATIBLE((table)._keyp, key_r) + \
+ COMPILE_ERROR_IF_TRUE(sizeof(*(key_r)) != sizeof(void *)) + \
+ COMPILE_ERROR_IF_TRUE(sizeof(*(value_r)) != sizeof(void *))), \
(void *)((value_r) + COMPILE_ERROR_IF_TYPES_NOT_COMPATIBLE((table)._valuep, value_r)))
#else
/* C++ requires (void **) casting, but that's not possible with strict
More information about the dovecot-cvs
mailing list