2004-04-10 18:53:55 +00:00
|
|
|
.TH MALLOC 3
|
|
|
|
.SH NAME
|
2005-01-03 06:40:20 +00:00
|
|
|
malloc, mallocz, free, realloc, calloc, setmalloctag, setrealloctag, getmalloctag, getrealloctag \- memory allocator
|
2004-04-10 18:53:55 +00:00
|
|
|
.SH SYNOPSIS
|
|
|
|
.B #include <u.h>
|
|
|
|
.br
|
|
|
|
.B #include <libc.h>
|
|
|
|
.PP
|
|
|
|
.ta \w'\fLvoid* 'u
|
|
|
|
.B
|
|
|
|
void* malloc(ulong size)
|
|
|
|
.PP
|
|
|
|
.B
|
|
|
|
void* mallocz(ulong size, int clr)
|
|
|
|
.PP
|
|
|
|
.B
|
|
|
|
void free(void *ptr)
|
|
|
|
.PP
|
|
|
|
.B
|
|
|
|
void* realloc(void *ptr, ulong size)
|
|
|
|
.PP
|
|
|
|
.B
|
|
|
|
void* calloc(ulong nelem, ulong elsize)
|
|
|
|
.PP
|
|
|
|
.B
|
|
|
|
void setmalloctag(void *ptr, ulong tag)
|
|
|
|
.PP
|
|
|
|
.B
|
2005-01-03 06:40:20 +00:00
|
|
|
ulong getmalloctag(void *ptr)
|
2004-04-10 18:53:55 +00:00
|
|
|
.PP
|
|
|
|
.B
|
|
|
|
void setrealloctag(void *ptr, ulong tag)
|
|
|
|
.PP
|
|
|
|
.B
|
2005-01-03 06:40:20 +00:00
|
|
|
ulong getrealloctag(void *ptr)
|
2004-04-10 18:53:55 +00:00
|
|
|
.SH DESCRIPTION
|
|
|
|
.I Malloc
|
|
|
|
and
|
|
|
|
.I free
|
|
|
|
provide a simple memory allocation package.
|
|
|
|
.I Malloc
|
|
|
|
returns a pointer to a new block of at least
|
|
|
|
.I size
|
|
|
|
bytes.
|
|
|
|
The block is suitably aligned for storage of any type of object.
|
|
|
|
No two active pointers from
|
|
|
|
.I malloc
|
|
|
|
will have the same value.
|
|
|
|
The call
|
|
|
|
.B malloc(0)
|
|
|
|
returns a valid pointer rather than null.
|
|
|
|
.PP
|
|
|
|
The argument to
|
|
|
|
.I free
|
|
|
|
is a pointer to a block previously allocated by
|
|
|
|
.IR malloc ;
|
|
|
|
this space is made available for further allocation.
|
|
|
|
It is legal to free a null pointer; the effect is a no-op.
|
|
|
|
The contents of the space returned by
|
|
|
|
.I malloc
|
|
|
|
are undefined.
|
|
|
|
.I Mallocz
|
|
|
|
behaves as
|
|
|
|
.IR malloc ,
|
|
|
|
except that if
|
|
|
|
.I clr
|
|
|
|
is non-zero, the memory returned will be zeroed.
|
|
|
|
.PP
|
|
|
|
.I Realloc
|
|
|
|
changes the size of the block pointed to by
|
|
|
|
.I ptr
|
|
|
|
to
|
|
|
|
.I size
|
|
|
|
bytes and returns a pointer to the (possibly moved)
|
|
|
|
block.
|
|
|
|
The contents will be unchanged up to the
|
|
|
|
lesser of the new and old sizes.
|
|
|
|
.I Realloc
|
|
|
|
takes on special meanings when one or both arguments are zero:
|
|
|
|
.TP
|
|
|
|
.B "realloc(0,\ size)
|
|
|
|
means
|
|
|
|
.LR malloc(size) ;
|
|
|
|
returns a pointer to the newly-allocated memory
|
|
|
|
.TP
|
|
|
|
.B "realloc(ptr,\ 0)
|
|
|
|
means
|
|
|
|
.LR free(ptr) ;
|
|
|
|
returns null
|
|
|
|
.TP
|
|
|
|
.B "realloc(0,\ 0)
|
|
|
|
no-op; returns null
|
|
|
|
.PD
|
|
|
|
.PP
|
|
|
|
.I Calloc
|
|
|
|
allocates space for
|
|
|
|
an array of
|
|
|
|
.I nelem
|
|
|
|
elements of size
|
|
|
|
.IR elsize .
|
|
|
|
The space is initialized to zeros.
|
|
|
|
.I Free
|
|
|
|
frees such a block.
|
|
|
|
.PP
|
2005-01-03 06:40:20 +00:00
|
|
|
The memory allocator on Plan 9 maintains two word-sized fields
|
2004-04-10 18:53:55 +00:00
|
|
|
associated with each block, the ``malloc tag'' and the ``realloc tag''.
|
|
|
|
By convention, the malloc tag is the PC that allocated the block,
|
|
|
|
and the realloc tag the PC that last reallocated the block.
|
|
|
|
These may be set or examined with
|
|
|
|
.IR setmalloctag ,
|
|
|
|
.IR getmalloctag ,
|
|
|
|
.IR setrealloctag ,
|
|
|
|
and
|
|
|
|
.IR getrealloctag .
|
|
|
|
When allocating blocks directly with
|
|
|
|
.I malloc
|
|
|
|
and
|
|
|
|
.IR realloc ,
|
|
|
|
these tags will be set properly.
|
|
|
|
If a custom allocator wrapper is used,
|
|
|
|
the allocator wrapper can set the tags
|
|
|
|
itself (usually by passing the result of
|
2004-04-11 03:42:27 +00:00
|
|
|
.IR getcallerpc (3)
|
2004-04-10 18:53:55 +00:00
|
|
|
to
|
|
|
|
.IR setmalloctag )
|
|
|
|
to provide more useful information about
|
|
|
|
the source of allocation.
|
|
|
|
.SH SOURCE
|
2005-01-11 17:37:33 +00:00
|
|
|
.B \*9/src/lib9/malloc.c
|
2005-01-03 06:40:20 +00:00
|
|
|
.br
|
2005-01-11 17:37:33 +00:00
|
|
|
.B \*9/src/lib9/malloctag.c
|
2004-04-10 18:53:55 +00:00
|
|
|
.SH SEE ALSO
|
|
|
|
.I trump
|
|
|
|
(in
|
|
|
|
.IR acid (1)),
|
2005-01-03 06:40:20 +00:00
|
|
|
.IR getcallerpc (3)
|
2004-04-10 18:53:55 +00:00
|
|
|
.SH DIAGNOSTICS
|
|
|
|
.I Malloc, realloc
|
|
|
|
and
|
|
|
|
.I calloc
|
|
|
|
return 0 if there is no available memory.
|
|
|
|
.I Errstr
|
|
|
|
is likely to be set.
|
|
|
|
If the allocated blocks have no malloc or realloc tags,
|
|
|
|
.I getmalloctag
|
|
|
|
and
|
|
|
|
.I getrealloctag
|
|
|
|
return
|
|
|
|
.BR ~0 .
|
|
|
|
.PP
|
|
|
|
The
|
|
|
|
.I trump
|
|
|
|
library for
|
|
|
|
.I acid
|
|
|
|
can be used to obtain traces of malloc execution; see
|
|
|
|
.IR acid (1).
|
|
|
|
.SH BUGS
|
|
|
|
The different specification of
|
|
|
|
.I calloc
|
|
|
|
is bizarre.
|
|
|
|
.PP
|
|
|
|
User errors can corrupt the storage arena.
|
|
|
|
The most common gaffes are (1) freeing an already freed block,
|
2005-01-03 06:40:20 +00:00
|
|
|
(2) storing beyond the bounds of an allocated block, and (3)
|
2004-04-10 18:53:55 +00:00
|
|
|
freeing data that was not obtained from the allocator.
|
|
|
|
When
|
|
|
|
.I malloc
|
|
|
|
and
|
|
|
|
.I free
|
|
|
|
detect such corruption, they abort.
|