1 #ifndef JEMALLOC_INTERNAL_DEFS_H_ 2 #define JEMALLOC_INTERNAL_DEFS_H_ 3 /* 4 * If JEMALLOC_PREFIX is defined via --with-jemalloc-prefix, it will cause all 5 * public APIs to be prefixed. This makes it possible, with some care, to use 6 * multiple allocators simultaneously. 7 */ 8 #undef JEMALLOC_PREFIX 9 #undef JEMALLOC_CPREFIX 10 11 /* 12 * Define overrides for non-standard allocator-related functions if they are 13 * present on the system. 14 */ 15 #undef JEMALLOC_OVERRIDE___LIBC_CALLOC 16 #undef JEMALLOC_OVERRIDE___LIBC_FREE 17 #undef JEMALLOC_OVERRIDE___LIBC_MALLOC 18 #undef JEMALLOC_OVERRIDE___LIBC_MEMALIGN 19 #undef JEMALLOC_OVERRIDE___LIBC_REALLOC 20 #undef JEMALLOC_OVERRIDE___LIBC_VALLOC 21 #undef JEMALLOC_OVERRIDE___POSIX_MEMALIGN 22 23 /* 24 * JEMALLOC_PRIVATE_NAMESPACE is used as a prefix for all library-private APIs. 25 * For shared libraries, symbol visibility mechanisms prevent these symbols 26 * from being exported, but for static libraries, naming collisions are a real 27 * possibility. 28 */ 29 #undef JEMALLOC_PRIVATE_NAMESPACE 30 31 /* 32 * Hyper-threaded CPUs may need a special instruction inside spin loops in 33 * order to yield to another virtual CPU. 34 */ 35 #undef CPU_SPINWAIT 36 /* 1 if CPU_SPINWAIT is defined, 0 otherwise. */ 37 #undef HAVE_CPU_SPINWAIT 38 39 /* 40 * Number of significant bits in virtual addresses. This may be less than the 41 * total number of bits in a pointer, e.g. on x64, for which the uppermost 16 42 * bits are the same as bit 47. 43 */ 44 #undef LG_VADDR 45 46 /* Defined if C11 atomics are available. */ 47 #undef JEMALLOC_C11_ATOMICS 48 49 /* Defined if GCC __atomic atomics are available. */ 50 #undef JEMALLOC_GCC_ATOMIC_ATOMICS 51 52 /* Defined if GCC __sync atomics are available. */ 53 #undef JEMALLOC_GCC_SYNC_ATOMICS 54 55 /* 56 * Defined if __sync_add_and_fetch(uint32_t *, uint32_t) and 57 * __sync_sub_and_fetch(uint32_t *, uint32_t) are available, despite 58 * __GCC_HAVE_SYNC_COMPARE_AND_SWAP_4 not being defined (which means the 59 * functions are defined in libgcc instead of being inlines). 60 */ 61 #undef JE_FORCE_SYNC_COMPARE_AND_SWAP_4 62 63 /* 64 * Defined if __sync_add_and_fetch(uint64_t *, uint64_t) and 65 * __sync_sub_and_fetch(uint64_t *, uint64_t) are available, despite 66 * __GCC_HAVE_SYNC_COMPARE_AND_SWAP_8 not being defined (which means the 67 * functions are defined in libgcc instead of being inlines). 68 */ 69 #undef JE_FORCE_SYNC_COMPARE_AND_SWAP_8 70 71 /* 72 * Defined if __builtin_clz() and __builtin_clzl() are available. 73 */ 74 #undef JEMALLOC_HAVE_BUILTIN_CLZ 75 76 /* 77 * Defined if os_unfair_lock_*() functions are available, as provided by Darwin. 78 */ 79 #undef JEMALLOC_OS_UNFAIR_LOCK 80 81 /* 82 * Defined if OSSpin*() functions are available, as provided by Darwin, and 83 * documented in the spinlock(3) manual page. 84 */ 85 #undef JEMALLOC_OSSPIN 86 87 /* Defined if syscall(2) is usable. */ 88 #undef JEMALLOC_USE_SYSCALL 89 90 /* 91 * Defined if secure_getenv(3) is available. 92 */ 93 #undef JEMALLOC_HAVE_SECURE_GETENV 94 95 /* 96 * Defined if issetugid(2) is available. 97 */ 98 #undef JEMALLOC_HAVE_ISSETUGID 99 100 /* Defined if pthread_atfork(3) is available. */ 101 #undef JEMALLOC_HAVE_PTHREAD_ATFORK 102 103 /* Defined if pthread_setname_np(3) is available. */ 104 #undef JEMALLOC_HAVE_PTHREAD_SETNAME_NP 105 106 /* 107 * Defined if clock_gettime(CLOCK_MONOTONIC_COARSE, ...) is available. 108 */ 109 #undef JEMALLOC_HAVE_CLOCK_MONOTONIC_COARSE 110 111 /* 112 * Defined if clock_gettime(CLOCK_MONOTONIC, ...) is available. 113 */ 114 #undef JEMALLOC_HAVE_CLOCK_MONOTONIC 115 116 /* 117 * Defined if mach_absolute_time() is available. 118 */ 119 #undef JEMALLOC_HAVE_MACH_ABSOLUTE_TIME 120 121 /* 122 * Defined if _malloc_thread_cleanup() exists. At least in the case of 123 * FreeBSD, pthread_key_create() allocates, which if used during malloc 124 * bootstrapping will cause recursion into the pthreads library. Therefore, if 125 * _malloc_thread_cleanup() exists, use it as the basis for thread cleanup in 126 * malloc_tsd. 127 */ 128 #undef JEMALLOC_MALLOC_THREAD_CLEANUP 129 130 /* 131 * Defined if threaded initialization is known to be safe on this platform. 132 * Among other things, it must be possible to initialize a mutex without 133 * triggering allocation in order for threaded allocation to be safe. 134 */ 135 #undef JEMALLOC_THREADED_INIT 136 137 /* 138 * Defined if the pthreads implementation defines 139 * _pthread_mutex_init_calloc_cb(), in which case the function is used in order 140 * to avoid recursive allocation during mutex initialization. 141 */ 142 #undef JEMALLOC_MUTEX_INIT_CB 143 144 /* Non-empty if the tls_model attribute is supported. */ 145 #undef JEMALLOC_TLS_MODEL 146 147 /* 148 * JEMALLOC_DEBUG enables assertions and other sanity checks, and disables 149 * inline functions. 150 */ 151 #undef JEMALLOC_DEBUG 152 153 /* JEMALLOC_STATS enables statistics calculation. */ 154 #undef JEMALLOC_STATS 155 156 /* JEMALLOC_PROF enables allocation profiling. */ 157 #undef JEMALLOC_PROF 158 159 /* Use libunwind for profile backtracing if defined. */ 160 #undef JEMALLOC_PROF_LIBUNWIND 161 162 /* Use libgcc for profile backtracing if defined. */ 163 #undef JEMALLOC_PROF_LIBGCC 164 165 /* Use gcc intrinsics for profile backtracing if defined. */ 166 #undef JEMALLOC_PROF_GCC 167 168 /* 169 * JEMALLOC_DSS enables use of sbrk(2) to allocate extents from the data storage 170 * segment (DSS). 171 */ 172 #undef JEMALLOC_DSS 173 174 /* Support memory filling (junk/zero). */ 175 #undef JEMALLOC_FILL 176 177 /* Support utrace(2)-based tracing. */ 178 #undef JEMALLOC_UTRACE 179 180 /* Support optional abort() on OOM. */ 181 #undef JEMALLOC_XMALLOC 182 183 /* Support lazy locking (avoid locking unless a second thread is launched). */ 184 #undef JEMALLOC_LAZY_LOCK 185 186 /* 187 * Minimum allocation alignment is 2^LG_QUANTUM bytes (ignoring tiny size 188 * classes). 189 */ 190 #undef LG_QUANTUM 191 192 /* One page is 2^LG_PAGE bytes. */ 193 #undef LG_PAGE 194 195 /* 196 * One huge page is 2^LG_HUGEPAGE bytes. Note that this is defined even if the 197 * system does not explicitly support huge pages; system calls that require 198 * explicit huge page support are separately configured. 199 */ 200 #undef LG_HUGEPAGE 201 202 /* 203 * If defined, adjacent virtual memory mappings with identical attributes 204 * automatically coalesce, and they fragment when changes are made to subranges. 205 * This is the normal order of things for mmap()/munmap(), but on Windows 206 * VirtualAlloc()/VirtualFree() operations must be precisely matched, i.e. 207 * mappings do *not* coalesce/fragment. 208 */ 209 #undef JEMALLOC_MAPS_COALESCE 210 211 /* 212 * If defined, retain memory for later reuse by default rather than using e.g. 213 * munmap() to unmap freed extents. This is enabled on 64-bit Linux because 214 * common sequences of mmap()/munmap() calls will cause virtual memory map 215 * holes. 216 */ 217 #undef JEMALLOC_RETAIN 218 219 /* TLS is used to map arenas and magazine caches to threads. */ 220 #undef JEMALLOC_TLS 221 222 /* 223 * Used to mark unreachable code to quiet "end of non-void" compiler warnings. 224 * Don't use this directly; instead use unreachable() from util.h 225 */ 226 #undef JEMALLOC_INTERNAL_UNREACHABLE 227 228 /* 229 * ffs*() functions to use for bitmapping. Don't use these directly; instead, 230 * use ffs_*() from util.h. 231 */ 232 #undef JEMALLOC_INTERNAL_FFSLL 233 #undef JEMALLOC_INTERNAL_FFSL 234 #undef JEMALLOC_INTERNAL_FFS 235 236 /* 237 * If defined, explicitly attempt to more uniformly distribute large allocation 238 * pointer alignments across all cache indices. 239 */ 240 #undef JEMALLOC_CACHE_OBLIVIOUS 241 242 /* 243 * If defined, enable logging facilities. We make this a configure option to 244 * avoid taking extra branches everywhere. 245 */ 246 #undef JEMALLOC_LOG 247 248 /* 249 * Darwin (OS X) uses zones to work around Mach-O symbol override shortcomings. 250 */ 251 #undef JEMALLOC_ZONE 252 253 /* 254 * Methods for determining whether the OS overcommits. 255 * JEMALLOC_PROC_SYS_VM_OVERCOMMIT_MEMORY: Linux's 256 * /proc/sys/vm.overcommit_memory file. 257 * JEMALLOC_SYSCTL_VM_OVERCOMMIT: FreeBSD's vm.overcommit sysctl. 258 */ 259 #undef JEMALLOC_SYSCTL_VM_OVERCOMMIT 260 #undef JEMALLOC_PROC_SYS_VM_OVERCOMMIT_MEMORY 261 262 /* Defined if madvise(2) is available. */ 263 #undef JEMALLOC_HAVE_MADVISE 264 265 /* 266 * Defined if transparent huge pages are supported via the MADV_[NO]HUGEPAGE 267 * arguments to madvise(2). 268 */ 269 #undef JEMALLOC_HAVE_MADVISE_HUGE 270 271 /* 272 * Methods for purging unused pages differ between operating systems. 273 * 274 * madvise(..., MADV_FREE) : This marks pages as being unused, such that they 275 * will be discarded rather than swapped out. 276 * madvise(..., MADV_DONTNEED) : If JEMALLOC_PURGE_MADVISE_DONTNEED_ZEROS is 277 * defined, this immediately discards pages, 278 * such that new pages will be demand-zeroed if 279 * the address region is later touched; 280 * otherwise this behaves similarly to 281 * MADV_FREE, though typically with higher 282 * system overhead. 283 */ 284 #undef JEMALLOC_PURGE_MADVISE_FREE 285 #undef JEMALLOC_PURGE_MADVISE_DONTNEED 286 #undef JEMALLOC_PURGE_MADVISE_DONTNEED_ZEROS 287 288 /* Defined if madvise(2) is available but MADV_FREE is not (x86 Linux only). */ 289 #undef JEMALLOC_DEFINE_MADVISE_FREE 290 291 /* 292 * Defined if MADV_DO[NT]DUMP is supported as an argument to madvise. 293 */ 294 #undef JEMALLOC_MADVISE_DONTDUMP 295 296 /* 297 * Defined if transparent huge pages (THPs) are supported via the 298 * MADV_[NO]HUGEPAGE arguments to madvise(2), and THP support is enabled. 299 */ 300 #undef JEMALLOC_THP 301 302 /* Define if operating system has alloca.h header. */ 303 #undef JEMALLOC_HAS_ALLOCA_H 304 305 /* C99 restrict keyword supported. */ 306 #undef JEMALLOC_HAS_RESTRICT 307 308 /* For use by hash code. */ 309 #undef JEMALLOC_BIG_ENDIAN 310 311 /* sizeof(int) == 2^LG_SIZEOF_INT. */ 312 #undef LG_SIZEOF_INT 313 314 /* sizeof(long) == 2^LG_SIZEOF_LONG. */ 315 #undef LG_SIZEOF_LONG 316 317 /* sizeof(long long) == 2^LG_SIZEOF_LONG_LONG. */ 318 #undef LG_SIZEOF_LONG_LONG 319 320 /* sizeof(intmax_t) == 2^LG_SIZEOF_INTMAX_T. */ 321 #undef LG_SIZEOF_INTMAX_T 322 323 /* glibc malloc hooks (__malloc_hook, __realloc_hook, __free_hook). */ 324 #undef JEMALLOC_GLIBC_MALLOC_HOOK 325 326 /* glibc memalign hook. */ 327 #undef JEMALLOC_GLIBC_MEMALIGN_HOOK 328 329 /* pthread support */ 330 #undef JEMALLOC_HAVE_PTHREAD 331 332 /* dlsym() support */ 333 #undef JEMALLOC_HAVE_DLSYM 334 335 /* Adaptive mutex support in pthreads. */ 336 #undef JEMALLOC_HAVE_PTHREAD_MUTEX_ADAPTIVE_NP 337 338 /* GNU specific sched_getcpu support */ 339 #undef JEMALLOC_HAVE_SCHED_GETCPU 340 341 /* GNU specific sched_setaffinity support */ 342 #undef JEMALLOC_HAVE_SCHED_SETAFFINITY 343 344 /* 345 * If defined, all the features necessary for background threads are present. 346 */ 347 #undef JEMALLOC_BACKGROUND_THREAD 348 349 /* 350 * If defined, jemalloc symbols are not exported (doesn't work when 351 * JEMALLOC_PREFIX is not defined). 352 */ 353 #undef JEMALLOC_EXPORT 354 355 /* config.malloc_conf options string. */ 356 #undef JEMALLOC_CONFIG_MALLOC_CONF 357 358 /* If defined, jemalloc takes the malloc/free/etc. symbol names. */ 359 #undef JEMALLOC_IS_MALLOC 360 361 /* 362 * Defined if strerror_r returns char * if _GNU_SOURCE is defined. 363 */ 364 #undef JEMALLOC_STRERROR_R_RETURNS_CHAR_WITH_GNU_SOURCE 365 366 #endif /* JEMALLOC_INTERNAL_DEFS_H_ */ 367