/* -*- C++ -*- */ /* Heap Layers: An Extensible Memory Allocation Infrastructure Copyright (C) 2000-2003 by Emery Berger http://www.cs.umass.edu/~emery emery@cs.umass.edu This program is free software; you can redistribute it and/or modify it under the terms of the GNU General Public License as published by the Free Software Foundation; either version 2 of the License, or (at your option) any later version. This program is distributed in the hope that it will be useful, but WITHOUT ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License for more details. You should have received a copy of the GNU General Public License along with this program; if not, write to the Free Software Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA 02111-1307 USA */ #ifndef _SIZEHEAP_H_ #define _SIZEHEAP_H_ /** * @file sizeheap.h * @brief Contains UseSizeHeap and SizeHeap. */ #include #include "addheap.h" #if 1 /** * @class UseSizeHeap * @brief Adds a getSize method to access the size of an allocated object. * @see SizeHeap */ namespace HL { template class UseSizeHeap : public Super { public: inline UseSizeHeap (void) {} inline static size_t getSize (const void * ptr) { return ((freeObject *) ptr - 1)->sz; } protected: union freeObject { size_t sz; double _dummy; // for alignment. }; }; /** * @class SizeHeap * @brief Allocates extra room for the size of an object. */ template class SizeHeap : public UseSizeHeap { typedef typename UseSizeHeap::freeObject freeObject; public: inline SizeHeap (void) {} inline void * malloc (const size_t sz) { // Add room for a size field. freeObject * ptr = (freeObject *) SuperHeap::malloc (sz + sizeof(freeObject)); // Store the requested size. ptr->sz = sz; return (void *) (ptr + 1); } inline void free (void * ptr) { SuperHeap::free ((freeObject *) ptr - 1); } }; }; #else template class SizeHeap : public Super { public: inline void * malloc (size_t sz) { // Add room for a size field. assert (sizeof(size_t) <= sizeof(double)); void * ptr = Super::malloc (sz + sizeof(double)); // Store the requested size. *((size_t *) ptr) = sz; return (void *) ((double *) ptr + 1); } inline void free (void * ptr) { void * origPtr = (void *) ((double *) ptr - 1); Super::free (origPtr); } inline static size_t getSize (void * ptr) { return *((size_t *) ((double *) ptr - 1)); } }; template class UseSizeHeap : public Super { public: inline static size_t getSize (void * ptr) { return *((size_t *) ((double *) ptr - 1)); } }; #endif #endif