diff options
Diffstat (limited to 'crypto/mem.c')
| -rw-r--r-- | crypto/mem.c | 44 | 
1 files changed, 18 insertions, 26 deletions
| diff --git a/crypto/mem.c b/crypto/mem.c index fdad49b76ec00..06c3960cc6c05 100644 --- a/crypto/mem.c +++ b/crypto/mem.c @@ -82,6 +82,14 @@ static void *default_malloc_ex(size_t num, const char *file, int line)  static void *(*malloc_ex_func) (size_t, const char *file, int line)      = default_malloc_ex; +#ifdef OPENSSL_SYS_VMS +# if __INITIAL_POINTER_SIZE == 64 +#  define realloc _realloc64 +# elif __INITIAL_POINTER_SIZE == 32 +#  define realloc _realloc32 +# endif +#endif +  static void *(*realloc_func) (void *, size_t) = realloc;  static void *default_realloc_ex(void *str, size_t num,                                  const char *file, int line) @@ -92,7 +100,11 @@ static void *default_realloc_ex(void *str, size_t num,  static void *(*realloc_ex_func) (void *, size_t, const char *file, int line)      = default_realloc_ex; -static void (*free_func) (void *) = free; +#ifdef OPENSSL_SYS_VMS +   static void (*free_func) (__void_ptr64) = free; +#else +   static void (*free_func) (void *) = free; +#endif  static void *(*malloc_locked_func) (size_t) = malloc;  static void *default_malloc_locked_ex(size_t num, const char *file, int line) @@ -103,7 +115,11 @@ static void *default_malloc_locked_ex(size_t num, const char *file, int line)  static void *(*malloc_locked_ex_func) (size_t, const char *file, int line)      = default_malloc_locked_ex; -static void (*free_locked_func) (void *) = free; +#ifdef OPENSSL_SYS_VMS +   static void (*free_locked_func) (__void_ptr64) = free; +#else +   static void (*free_locked_func) (void *) = free; +#endif  /* may be changed as long as 'allow_customize_debug' is set */  /* XXX use correct function pointer types */ @@ -298,18 +314,6 @@ void *CRYPTO_malloc_locked(int num, const char *file, int line)      if (malloc_debug_func != NULL)          malloc_debug_func(ret, num, file, line, 1); -#ifndef OPENSSL_CPUID_OBJ -    /* -     * Create a dependency on the value of 'cleanse_ctr' so our memory -     * sanitisation function can't be optimised out. NB: We only do this for -     * >2Kb so the overhead doesn't bother us. -     */ -    if (ret && (num > 2048)) { -        extern unsigned char cleanse_ctr; -        ((unsigned char *)ret)[0] = cleanse_ctr; -    } -#endif -      return ret;  } @@ -346,18 +350,6 @@ void *CRYPTO_malloc(int num, const char *file, int line)      if (malloc_debug_func != NULL)          malloc_debug_func(ret, num, file, line, 1); -#ifndef OPENSSL_CPUID_OBJ -    /* -     * Create a dependency on the value of 'cleanse_ctr' so our memory -     * sanitisation function can't be optimised out. NB: We only do this for -     * >2Kb so the overhead doesn't bother us. -     */ -    if (ret && (num > 2048)) { -        extern unsigned char cleanse_ctr; -        ((unsigned char *)ret)[0] = cleanse_ctr; -    } -#endif -      return ret;  } | 
