From 51796ccbedd6b4f76dd47964ad9241e300c9f1fe Mon Sep 17 00:00:00 2001 From: Chris Robinson Date: Wed, 30 Mar 2022 01:33:32 -0700 Subject: [PATCH] Move assume_aligned to opthelpers.h and define force_inline --- common/almalloc.h | 36 ------------------------------------ common/opthelpers.h | 42 ++++++++++++++++++++++++++++++++++++++---- 2 files changed, 38 insertions(+), 40 deletions(-) diff --git a/common/almalloc.h b/common/almalloc.h index ddbd72f4..711d02fd 100644 --- a/common/almalloc.h +++ b/common/almalloc.h @@ -101,42 +101,6 @@ constexpr bool operator==(const allocator&, const allocator&) noexcept template constexpr bool operator!=(const allocator&, const allocator&) noexcept { return false; } -#ifdef __cpp_lib_assume_aligned -template -using assume_aligned = std::assume_aligned; - -#elif defined(__clang__) || (defined(__GNUC__) && !defined(__ICC)) - -template -[[gnu::always_inline/*,nodiscard*/]] constexpr T* assume_aligned(T *ptr) noexcept -{ return static_cast(__builtin_assume_aligned(ptr, alignment)); } - -#elif defined(_MSC_VER) - -template -__forceinline /*[[nodiscard]]*/ constexpr T* assume_aligned(T *ptr) noexcept -{ - static constexpr std::size_t alignment_mask{(1<(ptr)&alignment_mask) == 0) - return ptr; - __assume(0); -} - -#elif defined(__ICC) - -template -/*[[nodiscard]]*/ constexpr T* assume_aligned(T *ptr) noexcept -{ - __assume_aligned(ptr, alignment); - return ptr; -} - -#else - -template -/*[[nodiscard]]*/ constexpr T* assume_aligned(T *ptr) noexcept { return ptr; } -#endif - template constexpr T* construct_at(T *ptr, Args&& ...args) diff --git a/common/opthelpers.h b/common/opthelpers.h index 726179de..e4945c2b 100644 --- a/common/opthelpers.h +++ b/common/opthelpers.h @@ -10,27 +10,37 @@ #define HAS_BUILTIN(x) (0) #endif +#ifdef __GNUC__ +#define force_inline [[gnu::always_inline]] +#elif defined(_MSC_VER) +#define force_inline __forceinline +#else +#define force_inline inline +#endif + #if defined(__GNUC__) || HAS_BUILTIN(__builtin_expect) /* likely() optimizes for 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. */ template -constexpr bool likely(T&& expr) noexcept +force_inline constexpr bool likely(T&& expr) noexcept { return __builtin_expect(static_cast(std::forward(expr)), true); } /* The opposite of likely(), optimizing for the case where the condition is * false. */ template -constexpr bool unlikely(T&& expr) noexcept +force_inline constexpr bool unlikely(T&& expr) noexcept { return __builtin_expect(static_cast(std::forward(expr)), false); } #else template -constexpr bool likely(T&& expr) noexcept { return static_cast(std::forward(expr)); } +force_inline constexpr bool likely(T&& expr) noexcept +{ return static_cast(std::forward(expr)); } template -constexpr bool unlikely(T&& expr) noexcept { return static_cast(std::forward(expr)); } +force_inline constexpr bool unlikely(T&& expr) noexcept +{ return static_cast(std::forward(expr)); } #endif #define LIKELY(x) (likely(x)) #define UNLIKELY(x) (unlikely(x)) @@ -49,4 +59,28 @@ constexpr bool unlikely(T&& expr) noexcept { return static_cast(std::forwa #define ASSUME(x) ((void)0) #endif +namespace al { + +template +force_inline constexpr auto assume_aligned(T *ptr) noexcept +{ +#ifdef __cpp_lib_assume_aligned + return std::assume_aligned(ptr); +#elif defined(__clang__) || (defined(__GNUC__) && !defined(__ICC)) + return static_cast(__builtin_assume_aligned(ptr, alignment)); +#elif defined(_MSC_VER) + constexpr std::size_t alignment_mask{(1<(ptr)&alignment_mask) == 0) + return ptr; + __assume(0); +#elif defined(__ICC) + __assume_aligned(ptr, alignment); + return ptr; +#else + return ptr; +#endif +} + +} // namespace al + #endif /* OPTHELPERS_H */