Implement talloc_pool()
commit60ef9a84f0bd18d48e453c08aa420d17275e0881
authorVolker Lendecke <vl@samba.org>
Sat, 5 Jan 2008 17:26:54 +0000 (5 18:26 +0100)
committerMichael Adam <obnox@samba.org>
Mon, 11 Feb 2008 14:07:46 +0000 (11 15:07 +0100)
tree15cdf817a4336de96d77e0105831bf5d998d13c9
parent2a2c28584cdb65fcea8563eb3bf21fea497fdff3
Implement talloc_pool()

A talloc pool is a chunk of memory that can be used as a context for further
talloc calls. Allocations with the pool as the parent just chew from that
memory by incrementing a pointer. If the talloc pool is full, then we fall back
to the normal system-level malloc(3) to get memory.

The use case for talloc pools is the transient memory that is used for handling
a single SMB request. Incrementing a pointer will be way faster than any malloc
implementation.

There is a downside of this: If you use talloc_steal() to move something out of
the pool, the whole pool memory is kept around until the last object inside the
pool is freed. So if you talloc_free() the pool, it might happen that the
memory is freed later. So don't hang anything off a talloc pool that should
live long.

Volker
source/lib/talloc/talloc.c
source/lib/talloc/talloc.h
source/lib/talloc/testsuite.c