diff --git a/libc/src/__support/CMakeLists.txt b/libc/src/__support/CMakeLists.txt --- a/libc/src/__support/CMakeLists.txt +++ b/libc/src/__support/CMakeLists.txt @@ -88,6 +88,7 @@ libc.src.__support.CPP.span libc.src.__support.CPP.string_view libc.src.__support.CPP.type_traits + libc.src.__support.common ) @@ -139,6 +140,8 @@ arg_list HDRS arg_list.h + DEPENDS + libc.src.__support.common ) add_header_library( @@ -153,6 +156,8 @@ char_vector HDRS char_vector.h + DEPENDS + libc.src.__support.common ) add_header_library( @@ -172,6 +177,7 @@ .builtin_wrappers .number_pair libc.src.__support.CPP.type_traits + libc.src.__support.common ) add_header_library( diff --git a/libc/src/__support/FPUtil/CMakeLists.txt b/libc/src/__support/FPUtil/CMakeLists.txt --- a/libc/src/__support/FPUtil/CMakeLists.txt +++ b/libc/src/__support/FPUtil/CMakeLists.txt @@ -164,6 +164,7 @@ multiply_add.h DEPENDS .fma + libc.src.__support.common ) add_header_library( diff --git a/libc/src/__support/FPUtil/aarch64/sqrt.h b/libc/src/__support/FPUtil/aarch64/sqrt.h --- a/libc/src/__support/FPUtil/aarch64/sqrt.h +++ b/libc/src/__support/FPUtil/aarch64/sqrt.h @@ -10,6 +10,7 @@ #define LLVM_LIBC_SRC_SUPPORT_FPUTIL_AARCH64_SQRT_H #include "src/__support/architectures.h" +#include "src/__support/common.h" #if !defined(LLVM_LIBC_ARCH_AARCH64) #error "Invalid include" @@ -20,13 +21,13 @@ namespace __llvm_libc { namespace fputil { -template <> inline float sqrt(float x) { +template <> LIBC_INLINE float sqrt(float x) { float y; __asm__ __volatile__("fsqrt %s0, %s1\n\t" : "=w"(y) : "w"(x)); return y; } -template <> inline double sqrt(double x) { +template <> LIBC_INLINE double sqrt(double x) { double y; __asm__ __volatile__("fsqrt %d0, %d1\n\t" : "=w"(y) : "w"(x)); return y; diff --git a/libc/src/__support/FPUtil/generic/CMakeLists.txt b/libc/src/__support/FPUtil/generic/CMakeLists.txt --- a/libc/src/__support/FPUtil/generic/CMakeLists.txt +++ b/libc/src/__support/FPUtil/generic/CMakeLists.txt @@ -10,6 +10,7 @@ libc.src.__support.FPUtil.fp_bits libc.src.__support.FPUtil.platform_defs libc.src.__support.builtin_wrappers + libc.src.__support.common libc.src.__support.uint128 libc.include.fenv ) diff --git a/libc/src/__support/FPUtil/generic/FMA.h b/libc/src/__support/FPUtil/generic/FMA.h --- a/libc/src/__support/FPUtil/generic/FMA.h +++ b/libc/src/__support/FPUtil/generic/FMA.h @@ -26,7 +26,7 @@ // TODO(lntue): Implement fmaf that is correctly rounded to all rounding modes. // The implementation below only is only correct for the default rounding mode, // round-to-nearest tie-to-even. -template <> inline float fma(float x, float y, float z) { +template <> LIBC_INLINE float fma(float x, float y, float z) { // Product is exact. double prod = static_cast(x) * static_cast(y); double z_d = static_cast(z); @@ -91,7 +91,7 @@ } // namespace internal -template <> inline double fma(double x, double y, double z) { +template <> LIBC_INLINE double fma(double x, double y, double z) { using FPBits = fputil::FPBits; using FloatProp = fputil::FloatProperties; diff --git a/libc/src/__support/FPUtil/generic/sqrt.h b/libc/src/__support/FPUtil/generic/sqrt.h --- a/libc/src/__support/FPUtil/generic/sqrt.h +++ b/libc/src/__support/FPUtil/generic/sqrt.h @@ -17,6 +17,7 @@ #include "src/__support/FPUtil/PlatformDefs.h" #include "src/__support/UInt128.h" #include "src/__support/builtin_wrappers.h" +#include "src/__support/common.h" namespace __llvm_libc { namespace fputil { @@ -44,12 +45,12 @@ #ifdef LONG_DOUBLE_IS_DOUBLE template <> -inline void normalize(int &exponent, uint64_t &mantissa) { +LIBC_INLINE void normalize(int &exponent, uint64_t &mantissa) { normalize(exponent, mantissa); } #elif !defined(SPECIAL_X86_LONG_DOUBLE) template <> -inline void normalize(int &exponent, UInt128 &mantissa) { +LIBC_INLINE void normalize(int &exponent, UInt128 &mantissa) { const uint64_t hi_bits = static_cast(mantissa >> 64); const int shift = hi_bits ? (unsafe_clz(hi_bits) - 15) diff --git a/libc/src/__support/FPUtil/generic/sqrt_80_bit_long_double.h b/libc/src/__support/FPUtil/generic/sqrt_80_bit_long_double.h --- a/libc/src/__support/FPUtil/generic/sqrt_80_bit_long_double.h +++ b/libc/src/__support/FPUtil/generic/sqrt_80_bit_long_double.h @@ -14,12 +14,13 @@ #include "src/__support/FPUtil/PlatformDefs.h" #include "src/__support/UInt128.h" #include "src/__support/builtin_wrappers.h" +#include "src/__support/common.h" namespace __llvm_libc { namespace fputil { namespace x86 { -inline void normalize(int &exponent, UInt128 &mantissa) { +LIBC_INLINE void normalize(int &exponent, UInt128 &mantissa) { const int shift = unsafe_clz(static_cast(mantissa)) - (8 * sizeof(uint64_t) - 1 - MantissaWidth::VALUE); diff --git a/libc/src/__support/FPUtil/multiply_add.h b/libc/src/__support/FPUtil/multiply_add.h --- a/libc/src/__support/FPUtil/multiply_add.h +++ b/libc/src/__support/FPUtil/multiply_add.h @@ -34,11 +34,12 @@ namespace __llvm_libc { namespace fputil { -template <> inline float multiply_add(float x, float y, float z) { +template <> LIBC_INLINE float multiply_add(float x, float y, float z) { return fma(x, y, z); } -template <> inline double multiply_add(double x, double y, double z) { +template <> +LIBC_INLINE double multiply_add(double x, double y, double z) { return fma(x, y, z); } diff --git a/libc/src/__support/FPUtil/x86_64/PolyEval.h b/libc/src/__support/FPUtil/x86_64/PolyEval.h --- a/libc/src/__support/FPUtil/x86_64/PolyEval.h +++ b/libc/src/__support/FPUtil/x86_64/PolyEval.h @@ -10,6 +10,7 @@ #define LLVM_LIBC_SRC_SUPPORT_FPUTIL_X86_64_POLYEVAL_H #include "src/__support/architectures.h" +#include "src/__support/common.h" #if !defined(LLVM_LIBC_ARCH_X86_64) #error "Invalid include" @@ -23,7 +24,7 @@ // Cubic polynomials: // polyeval(x, a0, a1, a2, a3) = a3*x^3 + a2*x^2 + a1*x + a0 template <> -inline float polyeval(float x, float a0, float a1, float a2, float a3) { +LIBC_INLINE float polyeval(float x, float a0, float a1, float a2, float a3) { __m128 xmm = _mm_set1_ps(x); // NOLINT __m128 a13 = _mm_set_ps(0.0f, x, a3, a1); // NOLINT __m128 a02 = _mm_set_ps(0.0f, 0.0f, a2, a0); // NOLINT @@ -34,7 +35,8 @@ } template <> -inline double polyeval(double x, double a0, double a1, double a2, double a3) { +LIBC_INLINE double polyeval(double x, double a0, double a1, double a2, + double a3) { __m256d xmm = _mm256_set1_pd(x); // NOLINT __m256d a13 = _mm256_set_pd(0.0, x, a3, a1); // NOLINT __m256d a02 = _mm256_set_pd(0.0, 0.0, a2, a0); // NOLINT @@ -48,8 +50,8 @@ // polyeval(x, a0, a1, a2, a3, a4, a5) = a5*x^5 + a4*x^4 + a3*x^3 + a2*x^2 + // + a1*x + a0 template <> -inline float polyeval(float x, float a0, float a1, float a2, float a3, float a4, - float a5) { +LIBC_INLINE float polyeval(float x, float a0, float a1, float a2, float a3, + float a4, float a5) { __m128 xmm = _mm_set1_ps(x); // NOLINT __m128 a25 = _mm_set_ps(0.0f, x, a5, a2); // NOLINT __m128 a14 = _mm_set_ps(0.0f, 0.0f, a4, a1); // NOLINT @@ -63,8 +65,8 @@ } template <> -inline double polyeval(double x, double a0, double a1, double a2, double a3, - double a4, double a5) { +LIBC_INLINE double polyeval(double x, double a0, double a1, double a2, + double a3, double a4, double a5) { __m256d xmm = _mm256_set1_pd(x); // NOLINT __m256d a25 = _mm256_set_pd(0.0, x, a5, a2); // NOLINT __m256d a14 = _mm256_set_pd(0.0, 0.0, a4, a1); // NOLINT diff --git a/libc/src/__support/FPUtil/x86_64/sqrt.h b/libc/src/__support/FPUtil/x86_64/sqrt.h --- a/libc/src/__support/FPUtil/x86_64/sqrt.h +++ b/libc/src/__support/FPUtil/x86_64/sqrt.h @@ -10,6 +10,7 @@ #define LLVM_LIBC_SRC_SUPPORT_FPUTIL_X86_64_SQRT_H #include "src/__support/architectures.h" +#include "src/__support/common.h" #if !defined(LLVM_LIBC_ARCH_X86) #error "Invalid include" @@ -20,26 +21,26 @@ namespace __llvm_libc { namespace fputil { -template <> inline float sqrt(float x) { +template <> LIBC_INLINE float sqrt(float x) { float result; __asm__ __volatile__("sqrtss %x1, %x0" : "=x"(result) : "x"(x)); return result; } -template <> inline double sqrt(double x) { +template <> LIBC_INLINE double sqrt(double x) { double result; __asm__ __volatile__("sqrtsd %x1, %x0" : "=x"(result) : "x"(x)); return result; } #ifdef LONG_DOUBLE_IS_DOUBLE -template <> inline long double sqrt(long double x) { +template <> LIBC_INLINE long double sqrt(long double x) { long double result; __asm__ __volatile__("sqrtsd %x1, %x0" : "=x"(result) : "x"(x)); return result; } #else -template <> inline long double sqrt(long double x) { +template <> LIBC_INLINE long double sqrt(long double x) { __asm__ __volatile__("fsqrt" : "+t"(x)); return x; } diff --git a/libc/src/__support/OSUtil/linux/syscall.h b/libc/src/__support/OSUtil/linux/syscall.h --- a/libc/src/__support/OSUtil/linux/syscall.h +++ b/libc/src/__support/OSUtil/linux/syscall.h @@ -10,6 +10,7 @@ #define LLVM_LIBC_SRC_SUPPORT_OSUTIL_LINUX_SYSCALL_H #include "src/__support/architectures.h" +#include "src/__support/common.h" #ifdef LLVM_LIBC_ARCH_X86_64 #include "x86_64/syscall.h" @@ -22,8 +23,7 @@ namespace __llvm_libc { template -__attribute__((always_inline)) inline long syscall_impl(long __number, - Ts... ts) { +LIBC_INLINE long syscall_impl(long __number, Ts... ts) { static_assert(sizeof...(Ts) <= 6, "Too many arguments for syscall"); return syscall_impl(__number, (long)ts...); } diff --git a/libc/src/__support/arg_list.h b/libc/src/__support/arg_list.h --- a/libc/src/__support/arg_list.h +++ b/libc/src/__support/arg_list.h @@ -9,6 +9,8 @@ #ifndef LLVM_LIBC_SRC_SUPPORT_ARG_LIST_H #define LLVM_LIBC_SRC_SUPPORT_ARG_LIST_H +#include "src/__support/common.h" + #include namespace __llvm_libc { @@ -18,16 +20,16 @@ va_list vlist; public: - ArgList(va_list vlist) { va_copy(this->vlist, vlist); } - ArgList(ArgList &other) { va_copy(this->vlist, other.vlist); } - ~ArgList() { va_end(this->vlist); } + LIBC_INLINE ArgList(va_list vlist) { va_copy(this->vlist, vlist); } + LIBC_INLINE ArgList(ArgList &other) { va_copy(this->vlist, other.vlist); } + LIBC_INLINE ~ArgList() { va_end(this->vlist); } - ArgList &operator=(ArgList &rhs) { + LIBC_INLINE ArgList &operator=(ArgList &rhs) { va_copy(vlist, rhs.vlist); return *this; } - template T inline next_var() { return va_arg(vlist, T); } + template LIBC_INLINE T next_var() { return va_arg(vlist, T); } }; } // namespace internal diff --git a/libc/src/__support/char_vector.h b/libc/src/__support/char_vector.h --- a/libc/src/__support/char_vector.h +++ b/libc/src/__support/char_vector.h @@ -9,6 +9,8 @@ #ifndef LLVM_LIBC_SRC_SUPPORT_CHARVECTOR_H #define LLVM_LIBC_SRC_SUPPORT_CHARVECTOR_H +#include "src/__support/common.h" + #include #include // For allocation. @@ -29,13 +31,13 @@ public: CharVector() = default; - ~CharVector() { + LIBC_INLINE ~CharVector() { if (cur_str != local_buffer) free(cur_str); } // append returns true on success and false on allocation failure. - bool append(char new_char) { + LIBC_INLINE bool append(char new_char) { // Subtract 1 for index starting at 0 and another for the null terminator. if (index >= cur_buff_size - 2) { // If the new character would cause the string to be longer than the @@ -63,12 +65,12 @@ return true; } - char *c_str() { + LIBC_INLINE char *c_str() { cur_str[index] = '\0'; return cur_str; } - size_t length() { return index; } + LIBC_INLINE size_t length() { return index; } }; } // namespace __llvm_libc diff --git a/libc/src/__support/float_to_string.h b/libc/src/__support/float_to_string.h --- a/libc/src/__support/float_to_string.h +++ b/libc/src/__support/float_to_string.h @@ -59,7 +59,7 @@ namespace internal { // Returns floor(log_10(2^e)); requires 0 <= e <= 1650. -constexpr inline uint32_t log10_pow2(const uint32_t e) { +LIBC_INLINE constexpr uint32_t log10_pow2(const uint32_t e) { // The first value this approximation fails for is 2^1651 which is just // greater than 10^297. assert(e >= 0); assert(e <= 1650); return (e * 78913) >> 18; @@ -69,14 +69,14 @@ // power of 2 was also a power of 10, but since that doesn't exist this is // always accurate. This is used to calculate the maximum number of base-10 // digits a given e-bit number could have. -constexpr inline uint32_t ceil_log10_pow2(const uint32_t e) { +LIBC_INLINE constexpr uint32_t ceil_log10_pow2(const uint32_t e) { return log10_pow2(e) + 1; } // Returns the maximum number of 9 digit blocks a number described by the given // index (which is ceil(exponent/16)) and mantissa width could need. -constexpr inline uint32_t length_for_num(const uint32_t idx, - const uint32_t mantissa_width) { +LIBC_INLINE constexpr uint32_t length_for_num(const uint32_t idx, + const uint32_t mantissa_width) { //+8 to round up when dividing by 9 return (ceil_log10_pow2(16 * idx) + ceil_log10_pow2(mantissa_width) + (BLOCK_SIZE - 1)) / @@ -90,7 +90,7 @@ // floor(5^(-9i) * 2^(e + c_1 - 9i) + 1) % (10^9 * 2^c_1) template -constexpr inline cpp::UInt +LIBC_INLINE constexpr cpp::UInt get_table_positive(int exponent, size_t i, const size_t constant) { // INT_SIZE is the size of int that is used for the internal calculations of // this function. It should be large enough to hold 2^(exponent+constant), so @@ -131,8 +131,8 @@ // calculations. // The formula being used looks more like this: // floor(10^(9*(-i)) * 2^(c_0 + (-e))) % (10^9 * 2^c_0) -inline cpp::UInt get_table_negative(int exponent, size_t i, - const size_t constant) { +LIBC_INLINE cpp::UInt get_table_negative(int exponent, size_t i, + const size_t constant) { constexpr size_t INT_SIZE = 1024; int shift_amount = constant - exponent; cpp::UInt num(1); @@ -234,7 +234,7 @@ // constexpr void init_convert(); public: - constexpr FloatToString(T init_float) : float_bits(init_float) { + LIBC_INLINE constexpr FloatToString(T init_float) : float_bits(init_float) { is_negative = float_bits.get_sign(); exponent = float_bits.get_exponent(); mantissa = float_bits.get_explicit_mantissa(); @@ -254,13 +254,15 @@ // init_convert(); } - constexpr bool is_nan() { return float_bits.is_nan(); } - constexpr bool is_inf() { return float_bits.is_inf(); } - constexpr bool is_inf_or_nan() { return float_bits.is_inf_or_nan(); } + LIBC_INLINE constexpr bool is_nan() { return float_bits.is_nan(); } + LIBC_INLINE constexpr bool is_inf() { return float_bits.is_inf(); } + LIBC_INLINE constexpr bool is_inf_or_nan() { + return float_bits.is_inf_or_nan(); + } // get_block returns an integer that represents the digits in the requested // block. - constexpr BlockInt get_positive_block(int block_index) { + LIBC_INLINE constexpr BlockInt get_positive_block(int block_index) { if (exponent >= -MANT_WIDTH) { // idx is ceil(exponent/16) or 0 if exponent is negative. This is used to // find the coarse section of the POW10_SPLIT table that will be used to @@ -285,7 +287,8 @@ return 0; } } - constexpr BlockInt get_negative_block(int block_index) { + + LIBC_INLINE constexpr BlockInt get_negative_block(int block_index) { if (exponent < 0) { const int32_t idx = -exponent / 16; uint32_t i = block_index; @@ -312,7 +315,7 @@ } } - constexpr BlockInt get_block(int block_index) { + LIBC_INLINE constexpr BlockInt get_block(int block_index) { if (block_index >= 0) { return get_positive_block(block_index); } else { @@ -320,7 +323,7 @@ } } - constexpr size_t get_positive_blocks() { + LIBC_INLINE constexpr size_t get_positive_blocks() { if (exponent >= -MANT_WIDTH) { const uint32_t idx = exponent < 0 ? 0 : static_cast(exponent + 15) / 16; @@ -333,14 +336,14 @@ // This takes the index of a block after the decimal point (a negative block) // and return if it's sure that all of the digits after it are zero. - constexpr bool is_lowest_block(size_t block_index) { + LIBC_INLINE constexpr bool is_lowest_block(size_t block_index) { const int32_t idx = -exponent / 16; const uint32_t p = POW10_OFFSET_2[idx] + block_index - MIN_BLOCK_2[idx]; // If the remaining digits are all 0, then this is the lowest block. return p >= POW10_OFFSET_2[idx + 1]; } - constexpr size_t zero_blocks_after_point() { + LIBC_INLINE constexpr size_t zero_blocks_after_point() { return MIN_BLOCK_2[-exponent / 16]; } }; @@ -355,17 +358,18 @@ // } template <> -constexpr size_t FloatToString::zero_blocks_after_point() { +LIBC_INLINE constexpr size_t +FloatToString::zero_blocks_after_point() { return 0; } template <> -constexpr bool FloatToString::is_lowest_block(size_t) { +LIBC_INLINE constexpr bool FloatToString::is_lowest_block(size_t) { return false; } template <> -constexpr BlockInt +LIBC_INLINE constexpr BlockInt FloatToString::get_positive_block(int block_index) { if (exponent >= -MANT_WIDTH) { const uint32_t pos_exp = (exponent < 0 ? 0 : exponent); @@ -401,7 +405,7 @@ } template <> -constexpr BlockInt +LIBC_INLINE constexpr BlockInt FloatToString::get_negative_block(int block_index) { if (exponent < 0) { const int32_t idx = -exponent / 16; diff --git a/libc/src/__support/integer_to_string.h b/libc/src/__support/integer_to_string.h --- a/libc/src/__support/integer_to_string.h +++ b/libc/src/__support/integer_to_string.h @@ -15,6 +15,7 @@ #include "src/__support/CPP/span.h" #include "src/__support/CPP/string_view.h" #include "src/__support/CPP/type_traits.h" +#include "src/__support/common.h" namespace __llvm_libc { @@ -44,10 +45,10 @@ // char b30buf[IntegerToString::bufsize<30, int>(a)]; // auto str = IntegerToString::convert<30>(a, b30buf); class IntegerToString { - static cpp::string_view convert_uintmax(uintmax_t uval, - cpp::span &buffer, - bool lowercase, - const uint8_t conv_base) { + LIBC_INLINE static cpp::string_view convert_uintmax(uintmax_t uval, + cpp::span &buffer, + bool lowercase, + const uint8_t conv_base) { const char a = lowercase ? 'a' : 'A'; size_t len = 0; @@ -67,9 +68,10 @@ return cpp::string_view(buffer.data() + buffer.size() - len, len); } - static cpp::string_view convert_intmax(intmax_t val, cpp::span &buffer, - bool lowercase, - const uint8_t conv_base) { + LIBC_INLINE static cpp::string_view convert_intmax(intmax_t val, + cpp::span &buffer, + bool lowercase, + const uint8_t conv_base) { if (val >= 0) return convert_uintmax(uintmax_t(val), buffer, lowercase, conv_base); uintmax_t uval = uintmax_t(-val); @@ -80,7 +82,7 @@ return cpp::string_view(buffer.data() + buffer.size() - len, len); } - static constexpr inline size_t floor_log_2(size_t num) { + LIBC_INLINE static constexpr size_t floor_log_2(size_t num) { size_t i = 0; for (; num > 1; num /= 2) { ++i; @@ -110,7 +112,8 @@ // For other bases, we approximate by rounding down to the nearest power of // two base, since the space needed is easy to calculate and it won't // overestimate by too much. - template static constexpr size_t bufsize() { + template + LIBC_INLINE static constexpr size_t bufsize() { constexpr size_t BITS_PER_DIGIT = floor_log_2(BASE); constexpr size_t BUFSIZE_COMMON = ((sizeof(T) * 8 + (BITS_PER_DIGIT - 1)) / BITS_PER_DIGIT); @@ -119,27 +122,27 @@ (BASE == 10 ? BUFSIZE_BASE10 : BUFSIZE_COMMON); } - template static constexpr size_t dec_bufsize() { + template LIBC_INLINE static constexpr size_t dec_bufsize() { return bufsize<10, T>(); } - template static constexpr size_t hex_bufsize() { + template LIBC_INLINE static constexpr size_t hex_bufsize() { return bufsize<16, T>(); } - template static constexpr size_t oct_bufsize() { + template LIBC_INLINE static constexpr size_t oct_bufsize() { return bufsize<8, T>(); } - template static constexpr size_t bin_bufsize() { + template LIBC_INLINE static constexpr size_t bin_bufsize() { return bufsize<2, T>(); } template , int> = 0> - static cpp::optional convert(T val, cpp::span buffer, - bool lowercase = true) { + LIBC_INLINE static cpp::optional + convert(T val, cpp::span buffer, bool lowercase = true) { if (buffer.size() < bufsize()) return cpp::optional(); if (cpp::is_signed_v) @@ -149,23 +152,26 @@ } template , int> = 0> - static cpp::optional dec(T val, cpp::span buffer) { + LIBC_INLINE static cpp::optional + dec(T val, cpp::span buffer) { return convert<10>(val, buffer); } template , int> = 0> - static cpp::optional hex(T val, cpp::span buffer, - bool lowercase = true) { + LIBC_INLINE static cpp::optional + hex(T val, cpp::span buffer, bool lowercase = true) { return convert<16>(val, buffer, lowercase); } template , int> = 0> - static cpp::optional oct(T val, cpp::span buffer) { + LIBC_INLINE static cpp::optional + oct(T val, cpp::span buffer) { return convert<8>(val, buffer); } template , int> = 0> - static cpp::optional bin(T val, cpp::span buffer) { + LIBC_INLINE static cpp::optional + bin(T val, cpp::span buffer) { return convert<2>(val, buffer); } }; diff --git a/libc/src/__support/integer_utils.h b/libc/src/__support/integer_utils.h --- a/libc/src/__support/integer_utils.h +++ b/libc/src/__support/integer_utils.h @@ -9,7 +9,9 @@ #ifndef LLVM_LIBC_SRC_SUPPORT_INTEGER_UTILS_H #define LLVM_LIBC_SRC_SUPPORT_INTEGER_UTILS_H -#include "CPP/type_traits.h" +#include "src/__support/CPP/type_traits.h" +#include "src/__support/common.h" + #include "builtin_wrappers.h" #include "number_pair.h" @@ -20,7 +22,7 @@ template NumberPair full_mul(T a, T b); template <> -inline NumberPair full_mul(uint32_t a, uint32_t b) { +LIBC_INLINE NumberPair full_mul(uint32_t a, uint32_t b) { uint64_t prod = uint64_t(a) * uint64_t(b); NumberPair result; result.lo = uint32_t(prod); @@ -29,7 +31,7 @@ } template <> -inline NumberPair full_mul(uint64_t a, uint64_t b) { +LIBC_INLINE NumberPair full_mul(uint64_t a, uint64_t b) { #ifdef __SIZEOF_INT128__ __uint128_t prod = __uint128_t(a) * __uint128_t(b); NumberPair result; diff --git a/libc/src/__support/str_to_float.h b/libc/src/__support/str_to_float.h --- a/libc/src/__support/str_to_float.h +++ b/libc/src/__support/str_to_float.h @@ -76,7 +76,8 @@ #if defined(SPECIAL_X86_LONG_DOUBLE) template <> -inline void set_implicit_bit(fputil::FPBits &result) { +LIBC_INLINE void +set_implicit_bit(fputil::FPBits &result) { result.set_implicit_bit(result.get_unbiased_exponent() != 0); } #endif @@ -190,7 +191,7 @@ #if !defined(LONG_DOUBLE_IS_DOUBLE) template <> -inline bool eisel_lemire( +LIBC_INLINE bool eisel_lemire( typename fputil::FPBits::UIntType mantissa, int32_t exp10, typename fputil::FPBits::UIntType *outputMantissa, uint32_t *outputExp2) { diff --git a/libc/src/stdio/printf_core/CMakeLists.txt b/libc/src/stdio/printf_core/CMakeLists.txt --- a/libc/src/stdio/printf_core/CMakeLists.txt +++ b/libc/src/stdio/printf_core/CMakeLists.txt @@ -22,6 +22,7 @@ libc.src.__support.CPP.bit libc.src.__support.CPP.string_view libc.src.__support.CPP.type_traits + libc.src.__support.common ) add_object_library( diff --git a/libc/src/stdio/printf_core/char_converter.h b/libc/src/stdio/printf_core/char_converter.h --- a/libc/src/stdio/printf_core/char_converter.h +++ b/libc/src/stdio/printf_core/char_converter.h @@ -10,6 +10,7 @@ #define LLVM_LIBC_SRC_STDIO_PRINTF_CORE_CHAR_CONVERTER_H #include "src/__support/CPP/string_view.h" +#include "src/__support/common.h" #include "src/stdio/printf_core/converter_utils.h" #include "src/stdio/printf_core/core_structs.h" #include "src/stdio/printf_core/writer.h" @@ -17,7 +18,7 @@ namespace __llvm_libc { namespace printf_core { -int inline convert_char(Writer *writer, const FormatSection &to_conv) { +LIBC_INLINE int convert_char(Writer *writer, const FormatSection &to_conv) { char c = to_conv.conv_val_raw; constexpr int string_len = 1; diff --git a/libc/src/stdio/printf_core/converter_utils.h b/libc/src/stdio/printf_core/converter_utils.h --- a/libc/src/stdio/printf_core/converter_utils.h +++ b/libc/src/stdio/printf_core/converter_utils.h @@ -10,6 +10,7 @@ #define LLVM_LIBC_SRC_STDIO_PRINTF_CORE_CONVERTER_UTILS_H #include "src/__support/CPP/limits.h" +#include "src/__support/common.h" #include "src/stdio/printf_core/core_structs.h" #include @@ -18,7 +19,7 @@ namespace __llvm_libc { namespace printf_core { -inline uintmax_t apply_length_modifier(uintmax_t num, LengthModifier lm) { +LIBC_INLINE uintmax_t apply_length_modifier(uintmax_t num, LengthModifier lm) { switch (lm) { case LengthModifier::none: return num & cpp::numeric_limits::max(); diff --git a/libc/src/stdio/printf_core/parser.h b/libc/src/stdio/printf_core/parser.h --- a/libc/src/stdio/printf_core/parser.h +++ b/libc/src/stdio/printf_core/parser.h @@ -11,6 +11,7 @@ #include "src/__support/CPP/type_traits.h" #include "src/__support/arg_list.h" +#include "src/__support/common.h" #include "src/stdio/printf_core/core_structs.h" #include "src/stdio/printf_core/printf_config.h" @@ -39,7 +40,7 @@ struct TypeDesc { uint8_t size; PrimaryType primary_type; - constexpr bool operator==(const TypeDesc &other) const { + LIBC_INLINE constexpr bool operator==(const TypeDesc &other) const { return (size == other.size) && (primary_type == other.primary_type); } }; @@ -60,10 +61,10 @@ public: #ifndef LLVM_LIBC_PRINTF_DISABLE_INDEX_MODE - Parser(const char *__restrict new_str, internal::ArgList &args) + LIBC_INLINE Parser(const char *__restrict new_str, internal::ArgList &args) : str(new_str), args_cur(args), args_start(args) {} #else - Parser(const char *__restrict new_str, internal::ArgList &args) + LIBC_INLINE Parser(const char *__restrict new_str, internal::ArgList &args) : str(new_str), args_cur(args) {} #endif // LLVM_LIBC_PRINTF_DISABLE_INDEX_MODE @@ -87,7 +88,7 @@ LengthModifier parse_length_modifier(size_t *local_pos); // get_next_arg_value gets the next value from the arg list as type T. - template T inline get_next_arg_value() { + template LIBC_INLINE T get_next_arg_value() { return args_cur.next_var(); } @@ -104,7 +105,7 @@ // local_pos. size_t parse_index(size_t *local_pos); - template static constexpr TypeDesc get_type_desc() { + template LIBC_INLINE static constexpr TypeDesc get_type_desc() { if constexpr (cpp::is_same_v) { return TypeDesc{0, PrimaryType::Integer}; } else { @@ -117,7 +118,7 @@ } } - void inline set_type_desc(size_t index, TypeDesc value) { + LIBC_INLINE void set_type_desc(size_t index, TypeDesc value) { if (index != 0 && index <= DESC_ARR_LEN) desc_arr[index - 1] = value; } @@ -125,7 +126,7 @@ // get_arg_value gets the value from the arg list at index (starting at 1). // This may require parsing the format string. An index of 0 is interpreted as // the next value. - template T inline get_arg_value(size_t index) { + template LIBC_INLINE T get_arg_value(size_t index) { if (!(index == 0 || index == args_index)) args_to_index(index); diff --git a/libc/src/stdio/printf_core/string_converter.h b/libc/src/stdio/printf_core/string_converter.h --- a/libc/src/stdio/printf_core/string_converter.h +++ b/libc/src/stdio/printf_core/string_converter.h @@ -10,6 +10,7 @@ #define LLVM_LIBC_SRC_STDIO_PRINTF_CORE_STRING_CONVERTER_H #include "src/__support/CPP/string_view.h" +#include "src/__support/common.h" #include "src/stdio/printf_core/converter_utils.h" #include "src/stdio/printf_core/core_structs.h" #include "src/stdio/printf_core/writer.h" @@ -19,7 +20,7 @@ namespace __llvm_libc { namespace printf_core { -int inline convert_string(Writer *writer, const FormatSection &to_conv) { +LIBC_INLINE int convert_string(Writer *writer, const FormatSection &to_conv) { size_t string_len = 0; for (char *cur_str = reinterpret_cast(to_conv.conv_val_ptr); diff --git a/libc/src/stdio/scanf_core/parser.h b/libc/src/stdio/scanf_core/parser.h --- a/libc/src/stdio/scanf_core/parser.h +++ b/libc/src/stdio/scanf_core/parser.h @@ -10,6 +10,7 @@ #define LLVM_LIBC_SRC_STDIO_SCANF_CORE_PARSER_H #include "src/__support/arg_list.h" +#include "src/__support/common.h" #include "src/stdio/scanf_core/core_structs.h" #include "src/stdio/scanf_core/scanf_config.h" @@ -34,10 +35,10 @@ public: #ifndef LLVM_LIBC_SCANF_DISABLE_INDEX_MODE - Parser(const char *__restrict new_str, internal::ArgList &args) + LIBC_INLINE Parser(const char *__restrict new_str, internal::ArgList &args) : str(new_str), args_cur(args), args_start(args) {} #else - Parser(const char *__restrict new_str, internal::ArgList &args) + LIBC_INLINE Parser(const char *__restrict new_str, internal::ArgList &args) : str(new_str), args_cur(args) {} #endif // LLVM_LIBC_SCANF_DISABLE_INDEX_MODE @@ -55,7 +56,7 @@ LengthModifier parse_length_modifier(size_t *local_pos); // get_next_arg_value gets the next value from the arg list as type T. - template T inline get_next_arg_value() { + template LIBC_INLINE T get_next_arg_value() { return args_cur.next_var(); } @@ -75,7 +76,7 @@ // get_arg_value gets the value from the arg list at index (starting at 1). // This may require parsing the format string. An index of 0 is interpreted as // the next value. - template T inline get_arg_value(size_t index) { + template LIBC_INLINE T get_arg_value(size_t index) { if (!(index == 0 || index == args_index)) args_to_index(index);