diff options
author | Chris Robinson <[email protected]> | 2018-04-17 22:50:50 -0700 |
---|---|---|
committer | Chris Robinson <[email protected]> | 2018-04-17 22:50:50 -0700 |
commit | 150586d7fef722da17b96697ca0c1f78b2d10eb4 (patch) | |
tree | 03ad2bd434e6cfce4bfb2007ffc82ff1dc624639 /OpenAL32 | |
parent | 09194fd4886d81ca28f88760e8ae4efad368227e (diff) |
Add an ASSUME macro that requires a true condition
Diffstat (limited to 'OpenAL32')
-rw-r--r-- | OpenAL32/Include/alMain.h | 17 |
1 files changed, 17 insertions, 0 deletions
diff --git a/OpenAL32/Include/alMain.h b/OpenAL32/Include/alMain.h index 783a90de..77144a29 100644 --- a/OpenAL32/Include/alMain.h +++ b/OpenAL32/Include/alMain.h @@ -42,11 +42,28 @@ #ifdef __GNUC__ +/* LIKELY optimizes the case where the condition is true. The condition is not + * required to be true, but it can result in more optimal code for the true + * path at the expense of a less optimal false path. + */ #define LIKELY(x) __builtin_expect(!!(x), !0) +/* The opposite of LIKELY, optimizing the case where the condition is false. */ #define UNLIKELY(x) __builtin_expect(!!(x), 0) +/* Unlike LIKELY, ASSUME requires the condition to be true or else it invokes + * undefined behavior. It's essentially an assert without actually checking the + * condition at run-time, allowing for stronger optimizations than LIKELY. + */ +#define ASSUME(x) do { if(!(x)) __builtin_unreachable(); } while(0) + #else + #define LIKELY(x) (!!(x)) #define UNLIKELY(x) (!!(x)) +#ifdef _MSC_VER +#define ASSUME __assume +#else +#define ASSUME(x) ((void)0) +#endif #endif #ifndef UINT64_MAX |