Retro68/gcc/libsanitizer/sanitizer_common/sanitizer_allocator_internal.h

72 lines
2.5 KiB
C
Raw Normal View History

2017-04-10 11:32:00 +00:00
//===-- sanitizer_allocator_internal.h --------------------------*- C++ -*-===//
2014-09-21 17:33:12 +00:00
//
// This file is distributed under the University of Illinois Open Source
// License. See LICENSE.TXT for details.
//
//===----------------------------------------------------------------------===//
//
// This allocator is used inside run-times.
//
//===----------------------------------------------------------------------===//
#ifndef SANITIZER_ALLOCATOR_INTERNAL_H
#define SANITIZER_ALLOCATOR_INTERNAL_H
#include "sanitizer_allocator.h"
#include "sanitizer_internal_defs.h"
namespace __sanitizer {
// FIXME: Check if we may use even more compact size class map for internal
// purposes.
typedef CompactSizeClassMap InternalSizeClassMap;
static const uptr kInternalAllocatorRegionSizeLog = 20;
static const uptr kInternalAllocatorNumRegions =
2018-12-28 15:30:48 +00:00
SANITIZER_MMAP_RANGE_SIZE >> kInternalAllocatorRegionSizeLog;
#if SANITIZER_WORDSIZE == 32
2014-09-21 17:33:12 +00:00
typedef FlatByteMap<kInternalAllocatorNumRegions> ByteMap;
#else
typedef TwoLevelByteMap<(kInternalAllocatorNumRegions >> 12), 1 << 12> ByteMap;
#endif
2018-12-28 15:30:48 +00:00
struct AP32 {
static const uptr kSpaceBeg = 0;
static const u64 kSpaceSize = SANITIZER_MMAP_RANGE_SIZE;
static const uptr kMetadataSize = 0;
typedef InternalSizeClassMap SizeClassMap;
static const uptr kRegionSizeLog = kInternalAllocatorRegionSizeLog;
typedef __sanitizer::ByteMap ByteMap;
typedef NoOpMapUnmapCallback MapUnmapCallback;
static const uptr kFlags = 0;
};
typedef SizeClassAllocator32<AP32> PrimaryInternalAllocator;
2014-09-21 17:33:12 +00:00
typedef SizeClassAllocatorLocalCache<PrimaryInternalAllocator>
InternalAllocatorCache;
typedef CombinedAllocator<PrimaryInternalAllocator, InternalAllocatorCache,
2018-12-28 15:30:48 +00:00
LargeMmapAllocator<NoOpMapUnmapCallback, DieOnFailure>
> InternalAllocator;
2014-09-21 17:33:12 +00:00
void *InternalAlloc(uptr size, InternalAllocatorCache *cache = nullptr,
uptr alignment = 0);
void *InternalRealloc(void *p, uptr size,
InternalAllocatorCache *cache = nullptr);
void *InternalCalloc(uptr countr, uptr size,
InternalAllocatorCache *cache = nullptr);
2017-04-10 11:32:00 +00:00
void InternalFree(void *p, InternalAllocatorCache *cache = nullptr);
2014-09-21 17:33:12 +00:00
InternalAllocator *internal_allocator();
2017-04-10 11:32:00 +00:00
enum InternalAllocEnum {
INTERNAL_ALLOC
};
2014-09-21 17:33:12 +00:00
2017-04-10 11:32:00 +00:00
} // namespace __sanitizer
inline void *operator new(__sanitizer::operator_new_size_type size,
__sanitizer::InternalAllocEnum) {
return __sanitizer::InternalAlloc(size);
2017-04-10 11:32:00 +00:00
}
#endif // SANITIZER_ALLOCATOR_INTERNAL_H