aboutsummaryrefslogtreecommitdiffstats
path: root/util/memory.c
diff options
context:
space:
mode:
Diffstat (limited to 'util/memory.c')
-rw-r--r--util/memory.c30
1 files changed, 17 insertions, 13 deletions
diff --git a/util/memory.c b/util/memory.c
index 76368cd97..fef2acc82 100644
--- a/util/memory.c
+++ b/util/memory.c
@@ -475,23 +475,26 @@ FNAME(alloc_secure_clear)( size_t n FNAMEPRT)
void *
FNAME(realloc)( void *a, size_t n FNAMEPRT )
{
- #ifdef M_GUARD
- unsigned char *p = a;
void *b;
- size_t len = m_size(a);
- if( len >= n ) /* we don't shrink for now */
- return a;
- if( p[-1] == MAGIC_SEC_BYTE )
- b = FNAME(alloc_secure_clear)(n FNAMEARG);
+ #ifdef M_GUARD
+ if( a ) {
+ unsigned char *p = a;
+ size_t len = m_size(a);
+
+ if( len >= n ) /* we don't shrink for now */
+ return a;
+ if( p[-1] == MAGIC_SEC_BYTE )
+ b = FNAME(alloc_secure_clear)(n FNAMEARG);
+ else
+ b = FNAME(alloc_clear)(n FNAMEARG);
+ FNAME(check)(NULL FNAMEARG);
+ memcpy(b, a, len );
+ FNAME(free)(p FNAMEARG);
+ }
else
- b = FNAME(alloc_clear)(n FNAMEARG);
- FNAME(check)(NULL FNAMEARG);
- memcpy(b, a, len );
- FNAME(free)(p FNAMEARG);
+ b = FNAME(alloc)(n);
#else
- void *b;
-
if( m_is_secure(a) ) {
if( !(b = secmem_realloc( a, n )) )
out_of_core(n,1);
@@ -501,6 +504,7 @@ FNAME(realloc)( void *a, size_t n FNAMEPRT )
out_of_core(n,0);
}
#endif
+
return b;
}