Last change
on this file was 2, checked in by bird, 22 years ago |
Initial revision
|
-
Property cvs2svn:cvs-rev
set to
1.1
-
Property svn:eol-style
set to
native
-
Property svn:executable
set to
*
|
File size:
797 bytes
|
Line | |
---|
1 | /* calloc -- allocate memory which has been initialized to zero.
|
---|
2 | This function is in the public domain. */
|
---|
3 |
|
---|
4 | /*
|
---|
5 |
|
---|
6 | @deftypefn Supplemental void* calloc (size_t @var{nelem}, size_t @var{elsize})
|
---|
7 |
|
---|
8 | Uses @code{malloc} to allocate storage for @var{nelem} objects of
|
---|
9 | @var{elsize} bytes each, then zeros the memory.
|
---|
10 |
|
---|
11 | @end deftypefn
|
---|
12 |
|
---|
13 | */
|
---|
14 |
|
---|
15 | #include "ansidecl.h"
|
---|
16 | #include "libiberty.h"
|
---|
17 |
|
---|
18 | #ifdef ANSI_PROTOTYPES
|
---|
19 | #include <stddef.h>
|
---|
20 | #else
|
---|
21 | #define size_t unsigned long
|
---|
22 | #endif
|
---|
23 |
|
---|
24 | /* For systems with larger pointers than ints, this must be declared. */
|
---|
25 | PTR malloc PARAMS ((size_t));
|
---|
26 |
|
---|
27 | PTR
|
---|
28 | calloc (nelem, elsize)
|
---|
29 | size_t nelem, elsize;
|
---|
30 | {
|
---|
31 | register PTR ptr;
|
---|
32 |
|
---|
33 | if (nelem == 0 || elsize == 0)
|
---|
34 | nelem = elsize = 1;
|
---|
35 |
|
---|
36 | ptr = malloc (nelem * elsize);
|
---|
37 | if (ptr) bzero (ptr, nelem * elsize);
|
---|
38 |
|
---|
39 | return ptr;
|
---|
40 | }
|
---|
Note:
See
TracBrowser
for help on using the repository browser.