2013-05-29 17:15:39 +08:00
|
|
|
//===-- sanitizer_allocator_internal.h -------------------------- C++ -----===//
|
|
|
|
//
|
|
|
|
// The LLVM Compiler Infrastructure
|
|
|
|
//
|
|
|
|
// 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 {
|
|
|
|
|
2013-05-29 17:40:07 +08:00
|
|
|
// FIXME: Check if we may use even more compact size class map for internal
|
2013-05-29 17:15:39 +08:00
|
|
|
// purposes.
|
|
|
|
typedef CompactSizeClassMap InternalSizeClassMap;
|
|
|
|
|
|
|
|
static const uptr kInternalAllocatorSpace = 0;
|
2013-12-26 21:52:38 +08:00
|
|
|
static const u64 kInternalAllocatorSize = SANITIZER_MMAP_RANGE_SIZE;
|
2013-05-29 17:15:39 +08:00
|
|
|
#if SANITIZER_WORDSIZE == 32
|
|
|
|
static const uptr kInternalAllocatorRegionSizeLog = 20;
|
2013-11-25 19:33:41 +08:00
|
|
|
static const uptr kInternalAllocatorNumRegions =
|
|
|
|
kInternalAllocatorSize >> kInternalAllocatorRegionSizeLog;
|
|
|
|
typedef FlatByteMap<kInternalAllocatorNumRegions> ByteMap;
|
2013-05-29 17:15:39 +08:00
|
|
|
#else
|
|
|
|
static const uptr kInternalAllocatorRegionSizeLog = 24;
|
2013-11-25 19:33:41 +08:00
|
|
|
static const uptr kInternalAllocatorNumRegions =
|
2013-05-29 17:15:39 +08:00
|
|
|
kInternalAllocatorSize >> kInternalAllocatorRegionSizeLog;
|
2013-11-25 19:33:41 +08:00
|
|
|
typedef TwoLevelByteMap<(kInternalAllocatorNumRegions >> 12), 1 << 12> ByteMap;
|
|
|
|
#endif
|
2013-05-29 17:15:39 +08:00
|
|
|
typedef SizeClassAllocator32<
|
|
|
|
kInternalAllocatorSpace, kInternalAllocatorSize, 16, InternalSizeClassMap,
|
2013-11-25 19:33:41 +08:00
|
|
|
kInternalAllocatorRegionSizeLog, ByteMap> PrimaryInternalAllocator;
|
2013-05-29 17:15:39 +08:00
|
|
|
|
|
|
|
typedef SizeClassAllocatorLocalCache<PrimaryInternalAllocator>
|
|
|
|
InternalAllocatorCache;
|
|
|
|
|
2013-11-25 19:33:41 +08:00
|
|
|
// We don't want our internal allocator to do any map/unmap operations from
|
|
|
|
// LargeMmapAllocator.
|
2013-05-29 17:15:39 +08:00
|
|
|
struct CrashOnMapUnmap {
|
|
|
|
void OnMap(uptr p, uptr size) const {
|
2014-02-28 14:29:42 +08:00
|
|
|
RAW_CHECK_MSG(0, "Unexpected mmap in InternalAllocator!\n");
|
2013-05-29 17:15:39 +08:00
|
|
|
}
|
|
|
|
void OnUnmap(uptr p, uptr size) const {
|
2014-02-28 14:29:42 +08:00
|
|
|
RAW_CHECK_MSG(0, "Unexpected munmap in InternalAllocator!\n");
|
2013-05-29 17:15:39 +08:00
|
|
|
}
|
|
|
|
};
|
|
|
|
|
|
|
|
typedef CombinedAllocator<PrimaryInternalAllocator, InternalAllocatorCache,
|
|
|
|
LargeMmapAllocator<CrashOnMapUnmap> >
|
|
|
|
InternalAllocator;
|
|
|
|
|
|
|
|
void *InternalAlloc(uptr size, InternalAllocatorCache *cache = 0);
|
|
|
|
void InternalFree(void *p, InternalAllocatorCache *cache = 0);
|
|
|
|
InternalAllocator *internal_allocator();
|
|
|
|
|
|
|
|
} // namespace __sanitizer
|
|
|
|
|
|
|
|
#endif // SANITIZER_ALLOCATOR_INTERNAL_H
|