summaryrefslogtreecommitdiff
path: root/lib/crypto
diff options
context:
space:
mode:
authorPatrik Nyblom <pan@erlang.org>2011-02-28 11:57:02 +0100
committerPatrik Nyblom <pan@erlang.org>2011-02-28 11:57:02 +0100
commit5dd7bdee141803099b5a9b4eba18c6f04048ba40 (patch)
tree5b32545be6af648de3deda4c562d827e4bff452c /lib/crypto
parent1b161433719e79d812b61672f1a864886a5aa8d3 (diff)
downloaderlang-5dd7bdee141803099b5a9b4eba18c6f04048ba40.tar.gz
Make crypto.c work with valgrind 3.6 and correct cerl.src
Diffstat (limited to 'lib/crypto')
-rw-r--r--lib/crypto/c_src/crypto.c14
1 files changed, 10 insertions, 4 deletions
diff --git a/lib/crypto/c_src/crypto.c b/lib/crypto/c_src/crypto.c
index 92cc2b4dd9..0e7e63eb73 100644
--- a/lib/crypto/c_src/crypto.c
+++ b/lib/crypto/c_src/crypto.c
@@ -62,10 +62,16 @@
# define ERL_VALGRIND_MAKE_MEM_DEFINED(ptr,size) \
VALGRIND_MAKE_MEM_DEFINED(ptr,size)
- # define ERL_VALGRIND_ASSERT_MEM_DEFINED(ptr,size) \
- ((void) ((VALGRIND_CHECK_MEM_IS_DEFINED(ptr,size) == 0) ? 1 : \
- (fprintf(stderr,"\r\n####### VALGRIND_ASSSERT(%p,%ld) failed at %s:%d\r\n",\
- (ptr),(long)(size), __FILE__, __LINE__), abort(), 0)))
+ # define ERL_VALGRIND_ASSERT_MEM_DEFINED(Ptr,Size) \
+ do { \
+ int __erl_valgrind_mem_defined = VALGRIND_CHECK_MEM_IS_DEFINED((Ptr),(Size)); \
+ if (__erl_valgrind_mem_defined != 0) { \
+ fprintf(stderr,"\r\n####### VALGRIND_ASSSERT(%p,%ld) failed at %s:%d\r\n", \
+ (Ptr),(long)(Size), __FILE__, __LINE__); \
+ abort(); \
+ } \
+ } while (0)
+
#else
# define ERL_VALGRIND_MAKE_MEM_DEFINED(ptr,size)
# define ERL_VALGRIND_ASSERT_MEM_DEFINED(ptr,size)