diff options
author | Alan Modra <amodra@gmail.com> | 2016-05-31 20:38:54 +0930 |
---|---|---|
committer | Alan Modra <amodra@gcc.gnu.org> | 2016-05-31 20:38:54 +0930 |
commit | 051154a1f6be0f597b7da235d6fe13463e7629be (patch) | |
tree | f758ddd570f167d4bb72b1a7dd142bde79ce4ec9 /libiberty/xmemdup.c | |
parent | cd78b3dd1824d0c7a77891365c756d67a9d5c1dc (diff) | |
download | gcc-051154a1f6be0f597b7da235d6fe13463e7629be.tar.gz |
Don't needlessly clear xmemdup allocated memory.
* xmemdup.c (xmemdup): Use xmalloc rather than xcalloc.
From-SVN: r236917
Diffstat (limited to 'libiberty/xmemdup.c')
-rw-r--r-- | libiberty/xmemdup.c | 6 |
1 files changed, 4 insertions, 2 deletions
diff --git a/libiberty/xmemdup.c b/libiberty/xmemdup.c index aa56f0bf572..4602afd7d9f 100644 --- a/libiberty/xmemdup.c +++ b/libiberty/xmemdup.c @@ -1,4 +1,4 @@ -/* xmemdup.c -- Duplicate a memory buffer, using xcalloc. +/* xmemdup.c -- Duplicate a memory buffer, using xmalloc. This trivial function is in the public domain. Jeff Garzik, September 1999. */ @@ -34,6 +34,8 @@ allocated, the remaining memory is zeroed. PTR xmemdup (const PTR input, size_t copy_size, size_t alloc_size) { - PTR output = xcalloc (1, alloc_size); + PTR output = xmalloc (alloc_size); + if (alloc_size > copy_size) + memset ((char *) output + copy_size, 0, alloc_size - copy_size); return (PTR) memcpy (output, input, copy_size); } |