diff options
author | Deepak Saxena <dsaxena@net.rmk.(none)> | 2005-04-25 18:40:05 -0400 |
---|---|---|
committer | Russell King <rmk@dyn-67.arm.linux.org.uk> | 2005-04-25 18:40:05 -0400 |
commit | 2fac6f3fec2303649e9cd572255776cb93d3f888 (patch) | |
tree | 091344bb955417f32aa60f9693612fc06d1079a4 /include/asm-arm/string.h | |
parent | 41130d37a449dbff3593c8585a102d5e9173eea7 (diff) |
[PATCH] ARM: 2653/1: Fix memset and memzero macro double-reference of parameters
Patch from Deepak Saxena
The current memset() and memzero() macros on ARM reference the
incoming parameters more than once and this can cause uninted
side-effects. The issue was found while debugging SCTP protocol
and with the specific usage of memzero(skb_put(skb,size),size).
This call would call skb_put(skb,size) twice leading to badness.
The fixed version copies the incoming parameters into local
variables and uses those instead.
Signed-off-by: Deepak Saxena
Signed-off-by: Russell King
Diffstat (limited to 'include/asm-arm/string.h')
-rw-r--r-- | include/asm-arm/string.h | 17 |
1 files changed, 12 insertions, 5 deletions
diff --git a/include/asm-arm/string.h b/include/asm-arm/string.h index 2a8ab162412f..e50c4a39b699 100644 --- a/include/asm-arm/string.h +++ b/include/asm-arm/string.h | |||
@@ -29,15 +29,22 @@ extern void __memzero(void *ptr, __kernel_size_t n); | |||
29 | 29 | ||
30 | #define memset(p,v,n) \ | 30 | #define memset(p,v,n) \ |
31 | ({ \ | 31 | ({ \ |
32 | if ((n) != 0) { \ | 32 | void *__p = (p); size_t __n = n; \ |
33 | if ((__n) != 0) { \ | ||
33 | if (__builtin_constant_p((v)) && (v) == 0) \ | 34 | if (__builtin_constant_p((v)) && (v) == 0) \ |
34 | __memzero((p),(n)); \ | 35 | __memzero((__p),(__n)); \ |
35 | else \ | 36 | else \ |
36 | memset((p),(v),(n)); \ | 37 | memset((__p),(v),(__n)); \ |
37 | } \ | 38 | } \ |
38 | (p); \ | 39 | (__p); \ |
39 | }) | 40 | }) |
40 | 41 | ||
41 | #define memzero(p,n) ({ if ((n) != 0) __memzero((p),(n)); (p); }) | 42 | #define memzero(p,n) \ |
43 | ({ \ | ||
44 | void *__p = (p); size_t __n = n; \ | ||
45 | if ((__n) != 0) \ | ||
46 | __memzero((__p),(__n)); \ | ||
47 | (__p); \ | ||
48 | }) | ||
42 | 49 | ||
43 | #endif | 50 | #endif |