Implement talloc_pool()
commit1ed4fcb271b7885c274bd88bafed8116779d8eb6
authorVolker Lendecke <vl@samba.org>
Sat, 5 Jan 2008 17:26:54 +0000 (5 18:26 +0100)
committerJeremy Allison <jra@samba.org>
Thu, 10 Jan 2008 01:05:19 +0000 (9 17:05 -0800)
tree11a2bf2be3acbd22e866abdf3001746bf69ba80d
parent6a1022288217304ebf4f3a3e59a1efa472ff2c5b
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
(This used to be commit 287e29d988813007eeebc0c2bef3b46ab8bedee9)
source3/lib/talloc/talloc.c
source3/lib/talloc/talloc.h
source3/lib/talloc/testsuite.c