X-Git-Url: https://codewiz.org/gitweb?a=blobdiff_plain;f=mware%2Fheap.c;h=f1315505e6eaf06265a8770694eccca4b9c8b9c4;hb=97773847f7c4c8b01a10d1740b9662a5c78181e5;hp=249081b593130921aa07995b8dceaf57d443a938;hpb=0d0eaf2e43aff60f23a662b9ea32525a1eb9fb79;p=bertos.git diff --git a/mware/heap.c b/mware/heap.c index 249081b5..f1315505 100755 --- a/mware/heap.c +++ b/mware/heap.c @@ -15,6 +15,9 @@ /*#* *#* $Log$ + *#* Revision 1.6 2004/10/26 09:02:13 bernie + *#* heap_free(): Handle NULL pointers like free(), write documentation. + *#* *#* Revision 1.5 2004/10/03 20:43:22 bernie *#* Import changes from sc/firmware. *#* @@ -201,11 +204,28 @@ void *heap_calloc(struct Heap* h, size_t size) return mem; } -void heap_free(struct Heap* h, void *mem_) +/*! + * Free a block of memory, determining its size automatically. + * + * \param h Heap from which the block was allocated. + * \param mem Pointer to a block of memory previously allocated with + * either heap_malloc() or heap_calloc(). + * + * \note If \a mem is a NULL pointer, no operation is performed. + * + * \note Freeing the same memory block twice has undefined behavior. + * + * \note This function works like the ANSI C free(). + */ +void heap_free(struct Heap *h, void *mem) { - size_t* mem = (size_t*)mem_; - --mem; - heap_freemem(h, mem, *mem); + size_t *_mem = (size_t *)mem; + + if (_mem) + { + --_mem; + heap_freemem(h, _mem, *_mem); + } } #endif /* CONFIG_HEAP_MALLOC */