//===-- memprof_allocator.h ------------------------------------*- C++ -*-===// // // Part of the LLVM Project, under the Apache License v2.0 with LLVM Exceptions. // See https://llvm.org/LICENSE.txt for license information. // SPDX-License-Identifier: Apache-2.0 WITH LLVM-exception // //===----------------------------------------------------------------------===// // // This file is a part of MemProfiler, a memory profiler. // // MemProf-private header for memprof_allocator.cpp. //===----------------------------------------------------------------------===// #ifndef MEMPROF_ALLOCATOR_H #define MEMPROF_ALLOCATOR_H #include "memprof_flags.h" #include "memprof_interceptors.h" #include "memprof_internal.h" #include "sanitizer_common/sanitizer_allocator.h" #include "sanitizer_common/sanitizer_list.h" #if !defined(__x86_64__) #error Unsupported platform #endif #if !SANITIZER_CAN_USE_ALLOCATOR64 #error Only 64-bit allocator supported #endif namespace __memprof { enum AllocType { FROM_MALLOC = 1, // Memory block came from malloc, calloc, realloc, etc. FROM_NEW = 2, // Memory block came from operator new. FROM_NEW_BR = 3 // Memory block came from operator new [ ] }; void InitializeAllocator(); struct MemprofMapUnmapCallback { void OnMap(uptr p, uptr size) const; void OnMapSecondary(uptr p, uptr size, uptr user_begin, uptr user_size) const { OnMap(p, size); } void OnUnmap(uptr p, uptr size) const; }; constexpr uptr kAllocatorSpace = 0x600000000000ULL; constexpr uptr kAllocatorSize = 0x40000000000ULL; // 4T. typedef DefaultSizeClassMap SizeClassMap; template struct AP64 { // Allocator64 parameters. Deliberately using a short name. static const uptr kSpaceBeg = kAllocatorSpace; static const uptr kSpaceSize = kAllocatorSize; static const uptr kMetadataSize = 0; typedef __memprof::SizeClassMap SizeClassMap; typedef MemprofMapUnmapCallback MapUnmapCallback; static const uptr kFlags = 0; using AddressSpaceView = AddressSpaceViewTy; }; template using PrimaryAllocatorASVT = SizeClassAllocator64>; using PrimaryAllocator = PrimaryAllocatorASVT; static const uptr kNumberOfSizeClasses = SizeClassMap::kNumClasses; template using MemprofAllocatorASVT = CombinedAllocator>; using MemprofAllocator = MemprofAllocatorASVT; using AllocatorCache = MemprofAllocator::AllocatorCache; struct MemprofThreadLocalMallocStorage { AllocatorCache allocator_cache; void CommitBack(); private: // These objects are allocated via mmap() and are zero-initialized. MemprofThreadLocalMallocStorage() {} }; void *memprof_memalign(uptr alignment, uptr size, BufferedStackTrace *stack, AllocType alloc_type); void memprof_free(void *ptr, BufferedStackTrace *stack, AllocType alloc_type); void memprof_delete(void *ptr, uptr size, uptr alignment, BufferedStackTrace *stack, AllocType alloc_type); void *memprof_malloc(uptr size, BufferedStackTrace *stack); void *memprof_calloc(uptr nmemb, uptr size, BufferedStackTrace *stack); void *memprof_realloc(void *p, uptr size, BufferedStackTrace *stack); void *memprof_reallocarray(void *p, uptr nmemb, uptr size, BufferedStackTrace *stack); void *memprof_valloc(uptr size, BufferedStackTrace *stack); void *memprof_pvalloc(uptr size, BufferedStackTrace *stack); void *memprof_aligned_alloc(uptr alignment, uptr size, BufferedStackTrace *stack); int memprof_posix_memalign(void **memptr, uptr alignment, uptr size, BufferedStackTrace *stack); uptr memprof_malloc_usable_size(const void *ptr, uptr pc, uptr bp); void PrintInternalAllocatorStats(); } // namespace __memprof #endif // MEMPROF_ALLOCATOR_H