[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
This commit is contained in:
Deepak Saxena 2005-04-25 23:40:05 +01:00 committed by Russell King
parent 41130d37a4
commit 2fac6f3fec

View File

@ -29,15 +29,22 @@ extern void __memzero(void *ptr, __kernel_size_t n);
#define memset(p,v,n) \ #define memset(p,v,n) \
({ \ ({ \
if ((n) != 0) { \ void *__p = (p); size_t __n = n; \
if ((__n) != 0) { \
if (__builtin_constant_p((v)) && (v) == 0) \ if (__builtin_constant_p((v)) && (v) == 0) \
__memzero((p),(n)); \ __memzero((__p),(__n)); \
else \ else \
memset((p),(v),(n)); \ memset((__p),(v),(__n)); \
} \ } \
(p); \ (__p); \
}) })
#define memzero(p,n) ({ if ((n) != 0) __memzero((p),(n)); (p); }) #define memzero(p,n) \
({ \
void *__p = (p); size_t __n = n; \
if ((__n) != 0) \
__memzero((__p),(__n)); \
(__p); \
})
#endif #endif