mirror of
https://github.com/microsoft/mimalloc.git
synced 2025-07-01 17:24:38 +03:00
mark assert_fail as cold and noreturn; move assert to internal.h (see issue #1091, and python/cpython#134586)
This commit is contained in:
parent
3e32b4c385
commit
715acc0329
3 changed files with 69 additions and 48 deletions
|
@ -8,7 +8,6 @@ terms of the MIT license. A copy of the license can be found in the file
|
||||||
#ifndef MIMALLOC_INTERNAL_H
|
#ifndef MIMALLOC_INTERNAL_H
|
||||||
#define MIMALLOC_INTERNAL_H
|
#define MIMALLOC_INTERNAL_H
|
||||||
|
|
||||||
|
|
||||||
// --------------------------------------------------------------------------
|
// --------------------------------------------------------------------------
|
||||||
// This file contains the internal API's of mimalloc and various utility
|
// This file contains the internal API's of mimalloc and various utility
|
||||||
// functions and macros.
|
// functions and macros.
|
||||||
|
@ -17,6 +16,11 @@ terms of the MIT license. A copy of the license can be found in the file
|
||||||
#include "types.h"
|
#include "types.h"
|
||||||
#include "track.h"
|
#include "track.h"
|
||||||
|
|
||||||
|
|
||||||
|
// --------------------------------------------------------------------------
|
||||||
|
// Compiler defines
|
||||||
|
// --------------------------------------------------------------------------
|
||||||
|
|
||||||
#if (MI_DEBUG>0)
|
#if (MI_DEBUG>0)
|
||||||
#define mi_trace_message(...) _mi_trace_message(__VA_ARGS__)
|
#define mi_trace_message(...) _mi_trace_message(__VA_ARGS__)
|
||||||
#else
|
#else
|
||||||
|
@ -30,37 +34,69 @@ terms of the MIT license. A copy of the license can be found in the file
|
||||||
#define mi_decl_noinline __declspec(noinline)
|
#define mi_decl_noinline __declspec(noinline)
|
||||||
#define mi_decl_thread __declspec(thread)
|
#define mi_decl_thread __declspec(thread)
|
||||||
#define mi_decl_cache_align __declspec(align(MI_CACHE_LINE))
|
#define mi_decl_cache_align __declspec(align(MI_CACHE_LINE))
|
||||||
|
#define mi_decl_noreturn __declspec(noreturn)
|
||||||
#define mi_decl_weak
|
#define mi_decl_weak
|
||||||
#define mi_decl_hidden
|
#define mi_decl_hidden
|
||||||
|
#define mi_decl_cold
|
||||||
#elif (defined(__GNUC__) && (__GNUC__ >= 3)) || defined(__clang__) // includes clang and icc
|
#elif (defined(__GNUC__) && (__GNUC__ >= 3)) || defined(__clang__) // includes clang and icc
|
||||||
#define mi_decl_noinline __attribute__((noinline))
|
#define mi_decl_noinline __attribute__((noinline))
|
||||||
#define mi_decl_thread __thread
|
#define mi_decl_thread __thread
|
||||||
#define mi_decl_cache_align __attribute__((aligned(MI_CACHE_LINE)))
|
#define mi_decl_cache_align __attribute__((aligned(MI_CACHE_LINE)))
|
||||||
|
#define mi_decl_noreturn __attribute__((noreturn))
|
||||||
#define mi_decl_weak __attribute__((weak))
|
#define mi_decl_weak __attribute__((weak))
|
||||||
#define mi_decl_hidden __attribute__((visibility("hidden")))
|
#define mi_decl_hidden __attribute__((visibility("hidden")))
|
||||||
|
#if (__GNUC__ >= 4) || defined(__clang__)
|
||||||
|
#define mi_decl_cold __attribute__((cold))
|
||||||
|
#else
|
||||||
|
#define mi_decl_cold
|
||||||
|
#endif
|
||||||
#elif __cplusplus >= 201103L // c++11
|
#elif __cplusplus >= 201103L // c++11
|
||||||
#define mi_decl_noinline
|
#define mi_decl_noinline
|
||||||
#define mi_decl_thread thread_local
|
#define mi_decl_thread thread_local
|
||||||
#define mi_decl_cache_align alignas(MI_CACHE_LINE)
|
#define mi_decl_cache_align alignas(MI_CACHE_LINE)
|
||||||
|
#define mi_decl_noreturn [[noreturn]]
|
||||||
#define mi_decl_weak
|
#define mi_decl_weak
|
||||||
#define mi_decl_hidden
|
#define mi_decl_hidden
|
||||||
|
#define mi_decl_cold
|
||||||
#else
|
#else
|
||||||
#define mi_decl_noinline
|
#define mi_decl_noinline
|
||||||
#define mi_decl_thread __thread // hope for the best :-)
|
#define mi_decl_thread __thread // hope for the best :-)
|
||||||
#define mi_decl_cache_align
|
#define mi_decl_cache_align
|
||||||
|
#define mi_decl_noreturn
|
||||||
#define mi_decl_weak
|
#define mi_decl_weak
|
||||||
#define mi_decl_hidden
|
#define mi_decl_hidden
|
||||||
|
#define mi_decl_cold
|
||||||
|
#endif
|
||||||
|
|
||||||
|
#if defined(__GNUC__) || defined(__clang__)
|
||||||
|
#define mi_unlikely(x) (__builtin_expect(!!(x),false))
|
||||||
|
#define mi_likely(x) (__builtin_expect(!!(x),true))
|
||||||
|
#elif (defined(__cplusplus) && (__cplusplus >= 202002L)) || (defined(_MSVC_LANG) && _MSVC_LANG >= 202002L)
|
||||||
|
#define mi_unlikely(x) (x) [[unlikely]]
|
||||||
|
#define mi_likely(x) (x) [[likely]]
|
||||||
|
#else
|
||||||
|
#define mi_unlikely(x) (x)
|
||||||
|
#define mi_likely(x) (x)
|
||||||
|
#endif
|
||||||
|
|
||||||
|
#ifndef __has_builtin
|
||||||
|
#define __has_builtin(x) 0
|
||||||
|
#endif
|
||||||
|
|
||||||
|
#if defined(__cplusplus)
|
||||||
|
#define mi_decl_externc extern "C"
|
||||||
|
#else
|
||||||
|
#define mi_decl_externc
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
#if defined(__EMSCRIPTEN__) && !defined(__wasi__)
|
#if defined(__EMSCRIPTEN__) && !defined(__wasi__)
|
||||||
#define __wasi__
|
#define __wasi__
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
#if defined(__cplusplus)
|
|
||||||
#define mi_decl_externc extern "C"
|
// --------------------------------------------------------------------------
|
||||||
#else
|
// Internal functions
|
||||||
#define mi_decl_externc
|
// --------------------------------------------------------------------------
|
||||||
#endif
|
|
||||||
|
|
||||||
// "libc.c"
|
// "libc.c"
|
||||||
#include <stdarg.h>
|
#include <stdarg.h>
|
||||||
|
@ -256,26 +292,6 @@ bool _mi_page_is_valid(mi_page_t* page);
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
|
|
||||||
// ------------------------------------------------------
|
|
||||||
// Branches
|
|
||||||
// ------------------------------------------------------
|
|
||||||
|
|
||||||
#if defined(__GNUC__) || defined(__clang__)
|
|
||||||
#define mi_unlikely(x) (__builtin_expect(!!(x),false))
|
|
||||||
#define mi_likely(x) (__builtin_expect(!!(x),true))
|
|
||||||
#elif (defined(__cplusplus) && (__cplusplus >= 202002L)) || (defined(_MSVC_LANG) && _MSVC_LANG >= 202002L)
|
|
||||||
#define mi_unlikely(x) (x) [[unlikely]]
|
|
||||||
#define mi_likely(x) (x) [[likely]]
|
|
||||||
#else
|
|
||||||
#define mi_unlikely(x) (x)
|
|
||||||
#define mi_likely(x) (x)
|
|
||||||
#endif
|
|
||||||
|
|
||||||
#ifndef __has_builtin
|
|
||||||
#define __has_builtin(x) 0
|
|
||||||
#endif
|
|
||||||
|
|
||||||
|
|
||||||
/* -----------------------------------------------------------
|
/* -----------------------------------------------------------
|
||||||
Error codes passed to `_mi_fatal_error`
|
Error codes passed to `_mi_fatal_error`
|
||||||
All are recoverable but EFAULT is a serious error and aborts by default in secure mode.
|
All are recoverable but EFAULT is a serious error and aborts by default in secure mode.
|
||||||
|
@ -300,6 +316,32 @@ bool _mi_page_is_valid(mi_page_t* page);
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
|
|
||||||
|
// ------------------------------------------------------
|
||||||
|
// Assertions
|
||||||
|
// ------------------------------------------------------
|
||||||
|
|
||||||
|
#if (MI_DEBUG)
|
||||||
|
// use our own assertion to print without memory allocation
|
||||||
|
mi_decl_noreturn mi_decl_cold void _mi_assert_fail(const char* assertion, const char* fname, unsigned int line, const char* func) mi_attr_noexcept;
|
||||||
|
#define mi_assert(expr) ((expr) ? (void)0 : _mi_assert_fail(#expr,__FILE__,__LINE__,__func__))
|
||||||
|
#else
|
||||||
|
#define mi_assert(x)
|
||||||
|
#endif
|
||||||
|
|
||||||
|
#if (MI_DEBUG>1)
|
||||||
|
#define mi_assert_internal mi_assert
|
||||||
|
#else
|
||||||
|
#define mi_assert_internal(x)
|
||||||
|
#endif
|
||||||
|
|
||||||
|
#if (MI_DEBUG>2)
|
||||||
|
#define mi_assert_expensive mi_assert
|
||||||
|
#else
|
||||||
|
#define mi_assert_expensive(x)
|
||||||
|
#endif
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
/* -----------------------------------------------------------
|
/* -----------------------------------------------------------
|
||||||
Inlined definitions
|
Inlined definitions
|
||||||
----------------------------------------------------------- */
|
----------------------------------------------------------- */
|
||||||
|
|
|
@ -574,7 +574,6 @@ struct mi_tld_s {
|
||||||
};
|
};
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
// ------------------------------------------------------
|
// ------------------------------------------------------
|
||||||
// Debug
|
// Debug
|
||||||
// ------------------------------------------------------
|
// ------------------------------------------------------
|
||||||
|
@ -589,26 +588,6 @@ struct mi_tld_s {
|
||||||
#define MI_DEBUG_PADDING (0xDE)
|
#define MI_DEBUG_PADDING (0xDE)
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
#if (MI_DEBUG)
|
|
||||||
// use our own assertion to print without memory allocation
|
|
||||||
void _mi_assert_fail(const char* assertion, const char* fname, unsigned int line, const char* func );
|
|
||||||
#define mi_assert(expr) ((expr) ? (void)0 : _mi_assert_fail(#expr,__FILE__,__LINE__,__func__))
|
|
||||||
#else
|
|
||||||
#define mi_assert(x)
|
|
||||||
#endif
|
|
||||||
|
|
||||||
#if (MI_DEBUG>1)
|
|
||||||
#define mi_assert_internal mi_assert
|
|
||||||
#else
|
|
||||||
#define mi_assert_internal(x)
|
|
||||||
#endif
|
|
||||||
|
|
||||||
#if (MI_DEBUG>2)
|
|
||||||
#define mi_assert_expensive mi_assert
|
|
||||||
#else
|
|
||||||
#define mi_assert_expensive(x)
|
|
||||||
#endif
|
|
||||||
|
|
||||||
|
|
||||||
// ------------------------------------------------------
|
// ------------------------------------------------------
|
||||||
// Statistics
|
// Statistics
|
||||||
|
|
|
@ -525,7 +525,7 @@ void _mi_warning_message(const char* fmt, ...) {
|
||||||
|
|
||||||
|
|
||||||
#if MI_DEBUG
|
#if MI_DEBUG
|
||||||
void _mi_assert_fail(const char* assertion, const char* fname, unsigned line, const char* func ) {
|
mi_decl_noreturn mi_decl_cold void _mi_assert_fail(const char* assertion, const char* fname, unsigned line, const char* func ) mi_attr_noexcept {
|
||||||
_mi_fprintf(NULL, NULL, "mimalloc: assertion failed: at \"%s\":%u, %s\n assertion: \"%s\"\n", fname, line, (func==NULL?"":func), assertion);
|
_mi_fprintf(NULL, NULL, "mimalloc: assertion failed: at \"%s\":%u, %s\n assertion: \"%s\"\n", fname, line, (func==NULL?"":func), assertion);
|
||||||
abort();
|
abort();
|
||||||
}
|
}
|
||||||
|
|
Loading…
Add table
Reference in a new issue