/** * This file has no copyright assigned and is placed in the Public Domain. * This file is part of the mingw-w64 runtime package. * No warranty is given; refer to the file DISCLAIMER.PD within this package. */ #ifndef _MALLOC_H_ #define _MALLOC_H_ #include <crtdefs.h> #pragma pack(push,_CRT_PACKING) #ifdef __cplusplus extern "C" { #endif #ifdef _WIN64 #define _HEAP_MAXREQ 0xFFFFFFFFFFFFFFE0 #else #define _HEAP_MAXREQ 0xFFFFFFE0 #endif #ifndef _STATIC_ASSERT #if defined(_MSC_VER) #define _STATIC_ASSERT(expr) typedef char __static_assert_t[(expr)] #else #define _STATIC_ASSERT(expr) extern void __static_assert_t(int [(expr)?1:-1]) #endif #endif /* Return codes for _heapwalk() */ #define _HEAPEMPTY (-1) #define _HEAPOK (-2) #define _HEAPBADBEGIN (-3) #define _HEAPBADNODE (-4) #define _HEAPEND (-5) #define _HEAPBADPTR (-6) /* Values for _heapinfo.useflag */ #define _FREEENTRY 0 #define _USEDENTRY 1 #ifndef _HEAPINFO_DEFINED #define _HEAPINFO_DEFINED /* The structure used to walk through the heap with _heapwalk. */ typedef struct _heapinfo { int *_pentry; size_t _size; int _useflag; } _HEAPINFO; #endif extern unsigned int _amblksiz; /* Make sure that X86intrin.h doesn't produce here collisions. */ #if (!defined (_XMMINTRIN_H_INCLUDED) && !defined (_MM_MALLOC_H_INCLUDED)) || defined(_aligned_malloc) #define __DO_ALIGN_DEFINES #endif #ifndef _MM_MALLOC_H_INCLUDED #define _MM_MALLOC_H_INCLUDED #endif #ifdef __DO_ALIGN_DEFINES #pragma push_macro("_aligned_free") #pragma push_macro("_aligned_malloc") #undef _aligned_free #undef _aligned_malloc #endif #define _mm_free(a) _aligned_free(a) #define _mm_malloc(a,b) _aligned_malloc(a,b) #ifndef _CRT_ALLOCATION_DEFINED #define _CRT_ALLOCATION_DEFINED void *__cdecl calloc(size_t _NumOfElements,size_t _SizeOfElements); void __cdecl free(void *_Memory); void *__cdecl malloc(size_t _Size); void *__cdecl realloc(void *_Memory,size_t _NewSize); _CRTIMP void *__cdecl _recalloc(void *_Memory,size_t _Count,size_t _Size); #ifdef __DO_ALIGN_DEFINES _CRTIMP void __cdecl _aligned_free(void *_Memory); _CRTIMP void *__cdecl _aligned_malloc(size_t _Size,size_t _Alignment); #endif _CRTIMP void *__cdecl _aligned_offset_malloc(size_t _Size,size_t _Alignment,size_t _Offset); _CRTIMP void *__cdecl _aligned_realloc(void *_Memory,size_t _Size,size_t _Alignment); _CRTIMP void *__cdecl _aligned_recalloc(void *_Memory,size_t _Count,size_t _Size,size_t _Alignment); _CRTIMP void *__cdecl _aligned_offset_realloc(void *_Memory,size_t _Size,size_t _Alignment,size_t _Offset); _CRTIMP void *__cdecl _aligned_offset_recalloc(void *_Memory,size_t _Count,size_t _Size,size_t _Alignment,size_t _Offset); #endif #ifdef __DO_ALIGN_DEFINES #undef __DO_ALIGN_DEFINES #pragma pop_macro("_aligned_malloc") #pragma pop_macro("_aligned_free") #endif /* Users should really use MS provided versions */ void * __mingw_aligned_malloc (size_t _Size, size_t _Alignment); void __mingw_aligned_free (void *_Memory); void * __mingw_aligned_offset_realloc (void *_Memory, size_t _Size, size_t _Alignment, size_t _Offset); void * __mingw_aligned_realloc (void *_Memory, size_t _Size, size_t _Offset); #define _MAX_WAIT_MALLOC_CRT 60000 _CRTIMP int __cdecl _resetstkoflw (void); _CRTIMP unsigned long __cdecl _set_malloc_crt_max_wait(unsigned long _NewValue); _CRTIMP void *__cdecl _expand(void *_Memory,size_t _NewSize); _CRTIMP size_t __cdecl _msize(void *_Memory); #ifdef __GNUC__ #undef _alloca #define _alloca(x) __builtin_alloca((x)) #else void *__cdecl _alloca(size_t _Size) __MINGW_ATTRIB_DEPRECATED_SEC_WARN; #endif _CRTIMP size_t __cdecl _get_sbh_threshold(void); _CRTIMP int __cdecl _set_sbh_threshold(size_t _NewValue); _CRTIMP errno_t __cdecl _set_amblksiz(size_t _Value); _CRTIMP errno_t __cdecl _get_amblksiz(size_t *_Value); _CRTIMP int __cdecl _heapadd(void *_Memory,size_t _Size); _CRTIMP int __cdecl _heapchk(void); _CRTIMP int __cdecl _heapmin(void); _CRTIMP int __cdecl _heapset(unsigned int _Fill); _CRTIMP int __cdecl _heapwalk(_HEAPINFO *_EntryInfo); _CRTIMP size_t __cdecl _heapused(size_t *_Used,size_t *_Commit); _CRTIMP intptr_t __cdecl _get_heap_handle(void); #define _ALLOCA_S_THRESHOLD 1024 #define _ALLOCA_S_STACK_MARKER 0xCCCC #define _ALLOCA_S_HEAP_MARKER 0xDDDD #if defined(_ARM_) || (defined(_X86_) && !defined(__x86_64)) #define _ALLOCA_S_MARKER_SIZE 8 #elif defined(__ia64__) || defined(__x86_64) #define _ALLOCA_S_MARKER_SIZE 16 #endif #if !defined(RC_INVOKED) static __inline void *_MarkAllocaS(void *_Ptr,unsigned int _Marker) { if(_Ptr) { *((unsigned int*)_Ptr) = _Marker; _Ptr = (char*)_Ptr + _ALLOCA_S_MARKER_SIZE; } return _Ptr; } #endif #undef _malloca #define _malloca(size) \ ((((size) + _ALLOCA_S_MARKER_SIZE) <= _ALLOCA_S_THRESHOLD) ? \ _MarkAllocaS(_alloca((size) + _ALLOCA_S_MARKER_SIZE),_ALLOCA_S_STACK_MARKER) : \ _MarkAllocaS(malloc((size) + _ALLOCA_S_MARKER_SIZE),_ALLOCA_S_HEAP_MARKER)) #undef _FREEA_INLINE #define _FREEA_INLINE #ifndef RC_INVOKED #undef _freea static __inline void __cdecl _freea(void *_Memory) { unsigned int _Marker; if(_Memory) { _Memory = (char*)_Memory - _ALLOCA_S_MARKER_SIZE; _Marker = *(unsigned int *)_Memory; if(_Marker==_ALLOCA_S_HEAP_MARKER) { free(_Memory); } #ifdef _ASSERTE else if(_Marker!=_ALLOCA_S_STACK_MARKER) { _ASSERTE(("Corrupted pointer passed to _freea",0)); } #endif } } #endif /* RC_INVOKED */ #ifndef NO_OLDNAMES #undef alloca #ifdef __GNUC__ #define alloca(x) __builtin_alloca((x)) #else #define alloca _alloca #endif #endif #ifdef HEAPHOOK #ifndef _HEAPHOOK_DEFINED #define _HEAPHOOK_DEFINED typedef int (__cdecl *_HEAPHOOK)(int,size_t,void *,void **); #endif _CRTIMP _HEAPHOOK __cdecl _setheaphook(_HEAPHOOK _NewHook); #define _HEAP_MALLOC 1 #define _HEAP_CALLOC 2 #define _HEAP_FREE 3 #define _HEAP_REALLOC 4 #define _HEAP_MSIZE 5 #define _HEAP_EXPAND 6 #endif #ifdef __cplusplus } #endif #pragma pack(pop) #endif /* _MALLOC_H_ */