(arm_is_longcall_p): Update comment describing this funciton's behaviour.
[official-gcc.git] / libiberty / xmemdup.c
blob9e9d66b715dbccafcef28f11a368af2ef64a3f1c
1 /* xmemdup.c -- Duplicate a memory buffer, using xcalloc.
2 This trivial function is in the public domain.
3 Jeff Garzik, September 1999. */
5 /*
7 @deftypefn Replacement void* xmemdup (void *@var{input}, size_t @var{copy_size}, size_t @var{alloc_size})
9 Duplicates a region of memory without fail. First, @var{alloc_size} bytes
10 are allocated, then @var{copy_size} bytes from @var{input} are copied into
11 it, and the new memory is returned. If fewer bytes are copied than were
12 allocated, the remaining memory is zeroed.
14 @end deftypefn
18 #ifdef HAVE_CONFIG_H
19 #include "config.h"
20 #endif
21 #include "ansidecl.h"
22 #include "libiberty.h"
24 #include <sys/types.h> /* For size_t. */
25 #ifdef HAVE_STRING_H
26 #include <string.h>
27 #endif
29 PTR
30 xmemdup (input, copy_size, alloc_size)
31 const PTR input;
32 size_t copy_size;
33 size_t alloc_size;
35 PTR output = xcalloc (1, alloc_size);
36 memcpy (output, input, copy_size);
37 return output;