diff options
| author | Andrew Kelley <andrew@ziglang.org> | 2023-01-02 17:55:46 -0700 |
|---|---|---|
| committer | Andrew Kelley <andrew@ziglang.org> | 2023-01-03 03:21:53 -0500 |
| commit | 5bd69c655d9e04102c8a64ced1215c9d69f4f03f (patch) | |
| tree | f9cc0357049aa717d27f001758c5401f57a46f4c /lib/zig.h | |
| parent | c9ef277fa7e43f119a7f2896635b4fdf9c97edbe (diff) | |
| download | zig-5bd69c655d9e04102c8a64ced1215c9d69f4f03f.tar.gz zig-5bd69c655d9e04102c8a64ced1215c9d69f4f03f.zip | |
zig.h: support GCC compilers that lack __has_builtin
Diffstat (limited to 'lib/zig.h')
| -rw-r--r-- | lib/zig.h | 100 |
1 files changed, 48 insertions, 52 deletions
@@ -90,7 +90,7 @@ typedef char bool; #define zig_align_fn zig_align_fn_unavailable #endif -#if zig_has_builtin(unreachable) +#if zig_has_builtin(unreachable) || defined(__GNUC__) #define zig_unreachable() __builtin_unreachable() #else #define zig_unreachable() @@ -113,7 +113,7 @@ typedef char bool; #if zig_has_builtin(debugtrap) #define zig_breakpoint() __builtin_debugtrap() -#elif zig_has_builtin(trap) +#elif zig_has_builtin(trap) || defined(__GNUC__) #define zig_breakpoint() __builtin_trap() #elif defined(_MSC_VER) || defined(__MINGW32__) || defined(__MINGW64__) #define zig_breakpoint() __debugbreak() @@ -123,7 +123,7 @@ typedef char bool; #define zig_breakpoint() raise(SIGTRAP) #endif -#if zig_has_builtin(return_address) +#if zig_has_builtin(return_address) || defined(__GNUC__) #define zig_return_address() __builtin_extract_return_addr(__builtin_return_address(0)) #elif defined(_MSC_VER) #define zig_return_address() _ReturnAddress() @@ -131,13 +131,13 @@ typedef char bool; #define zig_return_address() 0 #endif -#if zig_has_builtin(frame_address) +#if zig_has_builtin(frame_address) || defined(__GNUC__) #define zig_frame_address() __builtin_frame_address(0) #else #define zig_frame_address() 0 #endif -#if zig_has_builtin(prefetch) +#if zig_has_builtin(prefetch) || defined(__GNUC__) #define zig_prefetch(addr, rw, locality) __builtin_prefetch(addr, rw, locality) #else #define zig_prefetch(addr, rw, locality) @@ -412,7 +412,7 @@ zig_int_helpers(32) zig_int_helpers(64) static inline bool zig_addo_u32(zig_u32 *res, zig_u32 lhs, zig_u32 rhs, zig_u8 bits) { -#if zig_has_builtin(add_overflow) +#if zig_has_builtin(add_overflow) || defined(__GNUC__) zig_u32 full_res; bool overflow = __builtin_add_overflow(lhs, rhs, &full_res); *res = zig_wrap_u32(full_res, bits); @@ -431,7 +431,7 @@ static inline void zig_vaddo_u32(zig_u8 *ov, zig_u32 *res, int n, zig_extern zig_i32 __addosi4(zig_i32 lhs, zig_i32 rhs, zig_c_int *overflow); static inline bool zig_addo_i32(zig_i32 *res, zig_i32 lhs, zig_i32 rhs, zig_u8 bits) { -#if zig_has_builtin(add_overflow) +#if zig_has_builtin(add_overflow) || defined(__GNUC__) zig_i32 full_res; bool overflow = __builtin_add_overflow(lhs, rhs, &full_res); #else @@ -450,7 +450,7 @@ static inline void zig_vaddo_i32(zig_u8 *ov, zig_i32 *res, int n, } static inline bool zig_addo_u64(zig_u64 *res, zig_u64 lhs, zig_u64 rhs, zig_u8 bits) { -#if zig_has_builtin(add_overflow) +#if zig_has_builtin(add_overflow) || defined(__GNUC__) zig_u64 full_res; bool overflow = __builtin_add_overflow(lhs, rhs, &full_res); *res = zig_wrap_u64(full_res, bits); @@ -469,7 +469,7 @@ static inline void zig_vaddo_u64(zig_u8 *ov, zig_u64 *res, int n, zig_extern zig_i64 __addodi4(zig_i64 lhs, zig_i64 rhs, zig_c_int *overflow); static inline bool zig_addo_i64(zig_i64 *res, zig_i64 lhs, zig_i64 rhs, zig_u8 bits) { -#if zig_has_builtin(add_overflow) +#if zig_has_builtin(add_overflow) || defined(__GNUC__) zig_i64 full_res; bool overflow = __builtin_add_overflow(lhs, rhs, &full_res); #else @@ -488,7 +488,7 @@ static inline void zig_vaddo_i64(zig_u8 *ov, zig_i64 *res, int n, } static inline bool zig_addo_u8(zig_u8 *res, zig_u8 lhs, zig_u8 rhs, zig_u8 bits) { -#if zig_has_builtin(add_overflow) +#if zig_has_builtin(add_overflow) || defined(__GNUC__) zig_u8 full_res; bool overflow = __builtin_add_overflow(lhs, rhs, &full_res); *res = zig_wrap_u8(full_res, bits); @@ -508,7 +508,7 @@ static inline void zig_vaddo_u8(zig_u8 *ov, zig_u8 *res, int n, } static inline bool zig_addo_i8(zig_i8 *res, zig_i8 lhs, zig_i8 rhs, zig_u8 bits) { -#if zig_has_builtin(add_overflow) +#if zig_has_builtin(add_overflow) || defined(__GNUC__) zig_i8 full_res; bool overflow = __builtin_add_overflow(lhs, rhs, &full_res); *res = zig_wrap_i8(full_res, bits); @@ -528,7 +528,7 @@ static inline void zig_vaddo_i8(zig_u8 *ov, zig_i8 *res, int n, } static inline bool zig_addo_u16(zig_u16 *res, zig_u16 lhs, zig_u16 rhs, zig_u8 bits) { -#if zig_has_builtin(add_overflow) +#if zig_has_builtin(add_overflow) || defined(__GNUC__) zig_u16 full_res; bool overflow = __builtin_add_overflow(lhs, rhs, &full_res); *res = zig_wrap_u16(full_res, bits); @@ -548,7 +548,7 @@ static inline void zig_vaddo_u16(zig_u8 *ov, zig_u16 *res, int n, } static inline bool zig_addo_i16(zig_i16 *res, zig_i16 lhs, zig_i16 rhs, zig_u8 bits) { -#if zig_has_builtin(add_overflow) +#if zig_has_builtin(add_overflow) || defined(__GNUC__) zig_i16 full_res; bool overflow = __builtin_add_overflow(lhs, rhs, &full_res); *res = zig_wrap_i16(full_res, bits); @@ -568,7 +568,7 @@ static inline void zig_vaddo_i16(zig_u8 *ov, zig_i16 *res, int n, } static inline bool zig_subo_u32(zig_u32 *res, zig_u32 lhs, zig_u32 rhs, zig_u8 bits) { -#if zig_has_builtin(sub_overflow) +#if zig_has_builtin(sub_overflow) || defined(__GNUC__) zig_u32 full_res; bool overflow = __builtin_sub_overflow(lhs, rhs, &full_res); *res = zig_wrap_u32(full_res, bits); @@ -587,7 +587,7 @@ static inline void zig_vsubo_u32(zig_u8 *ov, zig_u32 *res, int n, zig_extern zig_i32 __subosi4(zig_i32 lhs, zig_i32 rhs, zig_c_int *overflow); static inline bool zig_subo_i32(zig_i32 *res, zig_i32 lhs, zig_i32 rhs, zig_u8 bits) { -#if zig_has_builtin(sub_overflow) +#if zig_has_builtin(sub_overflow) || defined(__GNUC__) zig_i32 full_res; bool overflow = __builtin_sub_overflow(lhs, rhs, &full_res); #else @@ -606,7 +606,7 @@ static inline void zig_vsubo_i32(zig_u8 *ov, zig_i32 *res, int n, } static inline bool zig_subo_u64(zig_u64 *res, zig_u64 lhs, zig_u64 rhs, zig_u8 bits) { -#if zig_has_builtin(sub_overflow) +#if zig_has_builtin(sub_overflow) || defined(__GNUC__) zig_u64 full_res; bool overflow = __builtin_sub_overflow(lhs, rhs, &full_res); *res = zig_wrap_u64(full_res, bits); @@ -625,7 +625,7 @@ static inline void zig_vsubo_u64(zig_u8 *ov, zig_u64 *res, int n, zig_extern zig_i64 __subodi4(zig_i64 lhs, zig_i64 rhs, zig_c_int *overflow); static inline bool zig_subo_i64(zig_i64 *res, zig_i64 lhs, zig_i64 rhs, zig_u8 bits) { -#if zig_has_builtin(sub_overflow) +#if zig_has_builtin(sub_overflow) || defined(__GNUC__) zig_i64 full_res; bool overflow = __builtin_sub_overflow(lhs, rhs, &full_res); #else @@ -644,7 +644,7 @@ static inline void zig_vsubo_i64(zig_u8 *ov, zig_i64 *res, int n, } static inline bool zig_subo_u8(zig_u8 *res, zig_u8 lhs, zig_u8 rhs, zig_u8 bits) { -#if zig_has_builtin(sub_overflow) +#if zig_has_builtin(sub_overflow) || defined(__GNUC__) zig_u8 full_res; bool overflow = __builtin_sub_overflow(lhs, rhs, &full_res); *res = zig_wrap_u8(full_res, bits); @@ -664,7 +664,7 @@ static inline void zig_vsubo_u8(zig_u8 *ov, zig_u8 *res, int n, } static inline bool zig_subo_i8(zig_i8 *res, zig_i8 lhs, zig_i8 rhs, zig_u8 bits) { -#if zig_has_builtin(sub_overflow) +#if zig_has_builtin(sub_overflow) || defined(__GNUC__) zig_i8 full_res; bool overflow = __builtin_sub_overflow(lhs, rhs, &full_res); *res = zig_wrap_i8(full_res, bits); @@ -685,7 +685,7 @@ static inline void zig_vsubo_i8(zig_u8 *ov, zig_i8 *res, int n, static inline bool zig_subo_u16(zig_u16 *res, zig_u16 lhs, zig_u16 rhs, zig_u8 bits) { -#if zig_has_builtin(sub_overflow) +#if zig_has_builtin(sub_overflow) || defined(__GNUC__) zig_u16 full_res; bool overflow = __builtin_sub_overflow(lhs, rhs, &full_res); *res = zig_wrap_u16(full_res, bits); @@ -706,7 +706,7 @@ static inline void zig_vsubo_u16(zig_u8 *ov, zig_u16 *res, int n, static inline bool zig_subo_i16(zig_i16 *res, zig_i16 lhs, zig_i16 rhs, zig_u8 bits) { -#if zig_has_builtin(sub_overflow) +#if zig_has_builtin(sub_overflow) || defined(__GNUC__) zig_i16 full_res; bool overflow = __builtin_sub_overflow(lhs, rhs, &full_res); *res = zig_wrap_i16(full_res, bits); @@ -726,7 +726,7 @@ static inline void zig_vsubo_i16(zig_u8 *ov, zig_i16 *res, int n, } static inline bool zig_mulo_u32(zig_u32 *res, zig_u32 lhs, zig_u32 rhs, zig_u8 bits) { -#if zig_has_builtin(mul_overflow) +#if zig_has_builtin(mul_overflow) || defined(__GNUC__) zig_u32 full_res; bool overflow = __builtin_mul_overflow(lhs, rhs, &full_res); *res = zig_wrap_u32(full_res, bits); @@ -745,7 +745,7 @@ static inline void zig_vmulo_u32(zig_u8 *ov, zig_u32 *res, int n, zig_extern zig_i32 __mulosi4(zig_i32 lhs, zig_i32 rhs, zig_c_int *overflow); static inline bool zig_mulo_i32(zig_i32 *res, zig_i32 lhs, zig_i32 rhs, zig_u8 bits) { -#if zig_has_builtin(mul_overflow) +#if zig_has_builtin(mul_overflow) || defined(__GNUC__) zig_i32 full_res; bool overflow = __builtin_mul_overflow(lhs, rhs, &full_res); #else @@ -764,7 +764,7 @@ static inline void zig_vmulo_i32(zig_u8 *ov, zig_i32 *res, int n, } static inline bool zig_mulo_u64(zig_u64 *res, zig_u64 lhs, zig_u64 rhs, zig_u8 bits) { -#if zig_has_builtin(mul_overflow) +#if zig_has_builtin(mul_overflow) || defined(__GNUC__) zig_u64 full_res; bool overflow = __builtin_mul_overflow(lhs, rhs, &full_res); *res = zig_wrap_u64(full_res, bits); @@ -783,7 +783,7 @@ static inline void zig_vmulo_u64(zig_u8 *ov, zig_u64 *res, int n, zig_extern zig_i64 __mulodi4(zig_i64 lhs, zig_i64 rhs, zig_c_int *overflow); static inline bool zig_mulo_i64(zig_i64 *res, zig_i64 lhs, zig_i64 rhs, zig_u8 bits) { -#if zig_has_builtin(mul_overflow) +#if zig_has_builtin(mul_overflow) || defined(__GNUC__) zig_i64 full_res; bool overflow = __builtin_mul_overflow(lhs, rhs, &full_res); #else @@ -802,7 +802,7 @@ static inline void zig_vmulo_i64(zig_u8 *ov, zig_i64 *res, int n, } static inline bool zig_mulo_u8(zig_u8 *res, zig_u8 lhs, zig_u8 rhs, zig_u8 bits) { -#if zig_has_builtin(mul_overflow) +#if zig_has_builtin(mul_overflow) || defined(__GNUC__) zig_u8 full_res; bool overflow = __builtin_mul_overflow(lhs, rhs, &full_res); *res = zig_wrap_u8(full_res, bits); @@ -822,7 +822,7 @@ static inline void zig_vmulo_u8(zig_u8 *ov, zig_u8 *res, int n, } static inline bool zig_mulo_i8(zig_i8 *res, zig_i8 lhs, zig_i8 rhs, zig_u8 bits) { -#if zig_has_builtin(mul_overflow) +#if zig_has_builtin(mul_overflow) || defined(__GNUC__) zig_i8 full_res; bool overflow = __builtin_mul_overflow(lhs, rhs, &full_res); *res = zig_wrap_i8(full_res, bits); @@ -842,7 +842,7 @@ static inline void zig_vmulo_i8(zig_u8 *ov, zig_i8 *res, int n, } static inline bool zig_mulo_u16(zig_u16 *res, zig_u16 lhs, zig_u16 rhs, zig_u8 bits) { -#if zig_has_builtin(mul_overflow) +#if zig_has_builtin(mul_overflow) || defined(__GNUC__) zig_u16 full_res; bool overflow = __builtin_mul_overflow(lhs, rhs, &full_res); *res = zig_wrap_u16(full_res, bits); @@ -862,7 +862,7 @@ static inline void zig_vmulo_u16(zig_u8 *ov, zig_u16 *res, int n, } static inline bool zig_mulo_i16(zig_i16 *res, zig_i16 lhs, zig_i16 rhs, zig_u8 bits) { -#if zig_has_builtin(mul_overflow) +#if zig_has_builtin(mul_overflow) || defined(__GNUC__) zig_i16 full_res; bool overflow = __builtin_mul_overflow(lhs, rhs, &full_res); *res = zig_wrap_i16(full_res, bits); @@ -977,7 +977,7 @@ static inline zig_i8 zig_byte_swap_i8(zig_i8 val, zig_u8 bits) { static inline zig_u16 zig_byte_swap_u16(zig_u16 val, zig_u8 bits) { zig_u16 full_res; -#if zig_has_builtin(bswap16) +#if zig_has_builtin(bswap16) || defined(__GNUC__) full_res = __builtin_bswap16(val); #else full_res = (zig_u16)zig_byte_swap_u8((zig_u8)(val >> 0), 8) << 8 | @@ -992,7 +992,7 @@ static inline zig_i16 zig_byte_swap_i16(zig_i16 val, zig_u8 bits) { static inline zig_u32 zig_byte_swap_u32(zig_u32 val, zig_u8 bits) { zig_u32 full_res; -#if zig_has_builtin(bswap32) +#if zig_has_builtin(bswap32) || defined(__GNUC__) full_res = __builtin_bswap32(val); #else full_res = (zig_u32)zig_byte_swap_u16((zig_u16)(val >> 0), 16) << 16 | @@ -1007,7 +1007,7 @@ static inline zig_i32 zig_byte_swap_i32(zig_i32 val, zig_u8 bits) { static inline zig_u64 zig_byte_swap_u64(zig_u64 val, zig_u8 bits) { zig_u64 full_res; -#if zig_has_builtin(bswap64) +#if zig_has_builtin(bswap64) || defined(__GNUC__) full_res = __builtin_bswap64(val); #else full_res = (zig_u64)zig_byte_swap_u32((zig_u32)(val >> 0), 32) << 32 | @@ -1087,7 +1087,7 @@ static inline zig_i64 zig_bit_reverse_i64(zig_i64 val, zig_u8 bits) { static inline zig_u8 zig_popcount_i##w(zig_i##w val, zig_u8 bits) { \ return zig_popcount_u##w((zig_u##w)val, bits); \ } -#if zig_has_builtin(popcount) +#if zig_has_builtin(popcount) || defined(__GNUC__) #define zig_builtin_popcount(w) \ static inline zig_u8 zig_popcount_u##w(zig_u##w val, zig_u8 bits) { \ (void)bits; \ @@ -1116,7 +1116,7 @@ zig_builtin_popcount(64) static inline zig_u8 zig_ctz_i##w(zig_i##w val, zig_u8 bits) { \ return zig_ctz_u##w((zig_u##w)val, bits); \ } -#if zig_has_builtin(ctz) +#if zig_has_builtin(ctz) || defined(__GNUC__) #define zig_builtin_ctz(w) \ static inline zig_u8 zig_ctz_u##w(zig_u##w val, zig_u8 bits) { \ if (val == 0) return bits; \ @@ -1141,7 +1141,7 @@ zig_builtin_ctz(64) static inline zig_u8 zig_clz_i##w(zig_i##w val, zig_u8 bits) { \ return zig_clz_u##w((zig_u##w)val, bits); \ } -#if zig_has_builtin(clz) +#if zig_has_builtin(clz) || defined(__GNUC__) #define zig_builtin_clz(w) \ static inline zig_u8 zig_clz_u##w(zig_u##w val, zig_u8 bits) { \ if (val == 0) return bits; \ @@ -1764,8 +1764,8 @@ static inline zig_i128 zig_bit_reverse_i128(zig_i128 val, zig_u8 bits) { #define __builtin_infl() zig_msvc_flt_infl #endif -#define zig_has_float_builtins (zig_has_builtin(nan) && zig_has_builtin(nans) && zig_has_builtin(inf)) -#if zig_has_float_builtins + +#if (zig_has_builtin(nan) && zig_has_builtin(nans) && zig_has_builtin(inf)) || defined(__GNUC__) #define zig_as_special_f16(sign, name, arg, repr) sign zig_as_f16(__builtin_##name, )(arg) #define zig_as_special_f32(sign, name, arg, repr) sign zig_as_f32(__builtin_##name, )(arg) #define zig_as_special_f64(sign, name, arg, repr) sign zig_as_f64(__builtin_##name, )(arg) @@ -1773,6 +1773,16 @@ static inline zig_i128 zig_bit_reverse_i128(zig_i128 val, zig_u8 bits) { #define zig_as_special_f128(sign, name, arg, repr) sign zig_as_f128(__builtin_##name, )(arg) #define zig_as_special_c_longdouble(sign, name, arg, repr) sign zig_as_c_longdouble(__builtin_##name, )(arg) #else +#define zig_float_from_repr(Type, ReprType) \ + static inline zig_##Type zig_float_from_repr_##Type(zig_##ReprType repr) { \ + return *((zig_##Type*)&repr); \ + } +zig_float_from_repr(f16, u16) +zig_float_from_repr(f32, u32) +zig_float_from_repr(f64, u64) +zig_float_from_repr(f80, u128) +zig_float_from_repr(f128, u128) +zig_float_from_repr(c_longdouble, u128) #define zig_as_special_f16(sign, name, arg, repr) zig_float_from_repr_f16(repr) #define zig_as_special_f32(sign, name, arg, repr) zig_float_from_repr_f32(repr) #define zig_as_special_f64(sign, name, arg, repr) zig_float_from_repr_f64(repr) @@ -1795,7 +1805,7 @@ typedef double zig_f16; #define zig_bitSizeOf_c_longdouble 16 typedef long double zig_f16; #define zig_as_f16(fp, repr) fp##l -#elif FLT16_MANT_DIG == 11 && zig_has_builtin(inff16) +#elif FLT16_MANT_DIG == 11 && (zig_has_builtin(inff16) || defined(__GNUC__)) typedef _Float16 zig_f16; #define zig_as_f16(fp, repr) fp##f16 #elif defined(__SIZEOF_FP16__) @@ -1974,20 +1984,6 @@ typedef zig_i128 zig_c_longdouble; #define zig_as_special_constant_c_longdouble(sign, name, arg, repr) repr #endif -#if !zig_has_float_builtins -#define zig_float_from_repr(Type, ReprType) \ - static inline zig_##Type zig_float_from_repr_##Type(zig_##ReprType repr) { \ - return *((zig_##Type*)&repr); \ - } - -zig_float_from_repr(f16, u16) -zig_float_from_repr(f32, u32) -zig_float_from_repr(f64, u64) -zig_float_from_repr(f80, u128) -zig_float_from_repr(f128, u128) -zig_float_from_repr(c_longdouble, u128) -#endif - #define zig_cast_f16 (zig_f16) #define zig_cast_f32 (zig_f32) #define zig_cast_f64 (zig_f64) |
