1
0

MallocAllocator.h 2.1 KB

1234567891011121314151617181920212223242526272829303132333435363738394041424344454647484950515253545556
  1. /* vim: set expandtab ts=4 sw=4: */
  2. /*
  3. * You may redistribute this program and/or modify it under the terms of
  4. * the GNU General Public License as published by the Free Software Foundation,
  5. * either version 3 of the License, or (at your option) any later version.
  6. *
  7. * This program is distributed in the hope that it will be useful,
  8. * but WITHOUT ANY WARRANTY; without even the implied warranty of
  9. * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
  10. * GNU General Public License for more details.
  11. *
  12. * You should have received a copy of the GNU General Public License
  13. * along with this program. If not, see <http://www.gnu.org/licenses/>.
  14. */
  15. #ifndef MallocAllocator_H
  16. #define MallocAllocator_H
  17. #include "memory/Allocator.h"
  18. #if !defined(MallocAllocator_USE_CANARIES) && defined(PARANOIA)
  19. #define MallocAllocator_USE_CANARIES
  20. #endif
  21. /**
  22. * Create a new Allocator which is a wrapper around malloc().
  23. *
  24. * @param sizeLimit the number of bytes which are allowed to be allocated by
  25. * this allocator or any of its children before the program
  26. * will be halted with an error.
  27. * @param identFile the file where this allocator was created.
  28. * @param identLine the line where this was called from.
  29. */
  30. struct Allocator* MallocAllocator_newWithIdentity(unsigned long sizeLimit,
  31. const char* identFile,
  32. int identLine);
  33. #define MallocAllocator_new(sl) \
  34. MallocAllocator_newWithIdentity((sl), __FILE__, __LINE__)
  35. /**
  36. * Get the number of bytes allocated so far by this allocator,
  37. * all of its parents, and all of its children.
  38. *
  39. * @param allocator this *must* be a MallocAllocator.
  40. * @return the number of bytes which have been allocated so far.
  41. */
  42. unsigned long MallocAllocator_bytesAllocated(struct Allocator* allocator);
  43. /**
  44. * Mix randomness into the canary value.
  45. *
  46. * @param allocator this *must* be a MallocAllocator.
  47. * @param value a random machine size word.
  48. */
  49. void MallocAllocator_setCanary(struct Allocator* alloc, long value);
  50. #endif