zig.h: drop dependency on deleted compiler_rt functions

It turns out we did use these in the C backend. However, it's really
just as easy, if not easier, to replicate the logic directly in C.

Synchronizes stage1/zig.h to make sure the bootstrap doesn't depend on
these functions either. The actual zig1 tarball is unmodified because
regenerating it is unnecessary in this instance.
This commit is contained in:
Matthew Lugg 2025-11-09 20:46:06 +00:00
parent 69f39868b4
commit 5df5e2ed26
No known key found for this signature in database
GPG Key ID: 3F5B7DCCBF4AF02E
2 changed files with 37 additions and 58 deletions

View File

@ -809,15 +809,13 @@ static inline bool zig_addo_u32(uint32_t *res, uint32_t lhs, uint32_t rhs, uint8
#endif #endif
} }
zig_extern int32_t __addosi4(int32_t lhs, int32_t rhs, int *overflow);
static inline bool zig_addo_i32(int32_t *res, int32_t lhs, int32_t rhs, uint8_t bits) { static inline bool zig_addo_i32(int32_t *res, int32_t lhs, int32_t rhs, uint8_t bits) {
#if zig_has_builtin(add_overflow) || defined(zig_gcc) #if zig_has_builtin(add_overflow) || defined(zig_gcc)
int32_t full_res; int32_t full_res;
bool overflow = __builtin_add_overflow(lhs, rhs, &full_res); bool overflow = __builtin_add_overflow(lhs, rhs, &full_res);
#else #else
int overflow_int; int32_t full_res = (int32_t)((uint32_t)lhs + (uint32_t)rhs);
int32_t full_res = __addosi4(lhs, rhs, &overflow_int); bool overflow = ((full_res ^ lhs) & (full_res ^ rhs)) < 0;
bool overflow = overflow_int != 0;
#endif #endif
*res = zig_wrap_i32(full_res, bits); *res = zig_wrap_i32(full_res, bits);
return overflow || full_res < zig_minInt_i(32, bits) || full_res > zig_maxInt_i(32, bits); return overflow || full_res < zig_minInt_i(32, bits) || full_res > zig_maxInt_i(32, bits);
@ -835,15 +833,13 @@ static inline bool zig_addo_u64(uint64_t *res, uint64_t lhs, uint64_t rhs, uint8
#endif #endif
} }
zig_extern int64_t __addodi4(int64_t lhs, int64_t rhs, int *overflow);
static inline bool zig_addo_i64(int64_t *res, int64_t lhs, int64_t rhs, uint8_t bits) { static inline bool zig_addo_i64(int64_t *res, int64_t lhs, int64_t rhs, uint8_t bits) {
#if zig_has_builtin(add_overflow) || defined(zig_gcc) #if zig_has_builtin(add_overflow) || defined(zig_gcc)
int64_t full_res; int64_t full_res;
bool overflow = __builtin_add_overflow(lhs, rhs, &full_res); bool overflow = __builtin_add_overflow(lhs, rhs, &full_res);
#else #else
int overflow_int; int64_t full_res = (int64_t)((uint64_t)lhs + (uint64_t)rhs);
int64_t full_res = __addodi4(lhs, rhs, &overflow_int); bool overflow = ((full_res ^ lhs) & (full_res ^ rhs)) < 0;
bool overflow = overflow_int != 0;
#endif #endif
*res = zig_wrap_i64(full_res, bits); *res = zig_wrap_i64(full_res, bits);
return overflow || full_res < zig_minInt_i(64, bits) || full_res > zig_maxInt_i(64, bits); return overflow || full_res < zig_minInt_i(64, bits) || full_res > zig_maxInt_i(64, bits);
@ -917,15 +913,13 @@ static inline bool zig_subo_u32(uint32_t *res, uint32_t lhs, uint32_t rhs, uint8
#endif #endif
} }
zig_extern int32_t __subosi4(int32_t lhs, int32_t rhs, int *overflow);
static inline bool zig_subo_i32(int32_t *res, int32_t lhs, int32_t rhs, uint8_t bits) { static inline bool zig_subo_i32(int32_t *res, int32_t lhs, int32_t rhs, uint8_t bits) {
#if zig_has_builtin(sub_overflow) || defined(zig_gcc) #if zig_has_builtin(sub_overflow) || defined(zig_gcc)
int32_t full_res; int32_t full_res;
bool overflow = __builtin_sub_overflow(lhs, rhs, &full_res); bool overflow = __builtin_sub_overflow(lhs, rhs, &full_res);
#else #else
int overflow_int; int32_t full_res = (int32_t)((uint32_t)lhs - (uint32_t)rhs);
int32_t full_res = __subosi4(lhs, rhs, &overflow_int); bool overflow = ((lhs ^ rhs) & (full_res ^ lhs)) < 0;
bool overflow = overflow_int != 0;
#endif #endif
*res = zig_wrap_i32(full_res, bits); *res = zig_wrap_i32(full_res, bits);
return overflow || full_res < zig_minInt_i(32, bits) || full_res > zig_maxInt_i(32, bits); return overflow || full_res < zig_minInt_i(32, bits) || full_res > zig_maxInt_i(32, bits);
@ -943,15 +937,13 @@ static inline bool zig_subo_u64(uint64_t *res, uint64_t lhs, uint64_t rhs, uint8
#endif #endif
} }
zig_extern int64_t __subodi4(int64_t lhs, int64_t rhs, int *overflow);
static inline bool zig_subo_i64(int64_t *res, int64_t lhs, int64_t rhs, uint8_t bits) { static inline bool zig_subo_i64(int64_t *res, int64_t lhs, int64_t rhs, uint8_t bits) {
#if zig_has_builtin(sub_overflow) || defined(zig_gcc) #if zig_has_builtin(sub_overflow) || defined(zig_gcc)
int64_t full_res; int64_t full_res;
bool overflow = __builtin_sub_overflow(lhs, rhs, &full_res); bool overflow = __builtin_sub_overflow(lhs, rhs, &full_res);
#else #else
int overflow_int; int64_t full_res = (int64_t)((uint64_t)lhs - (uint64_t)rhs);
int64_t full_res = __subodi4(lhs, rhs, &overflow_int); bool overflow = ((lhs ^ rhs) & (full_res ^ lhs)) < 0;
bool overflow = overflow_int != 0;
#endif #endif
*res = zig_wrap_i64(full_res, bits); *res = zig_wrap_i64(full_res, bits);
return overflow || full_res < zig_minInt_i(64, bits) || full_res > zig_maxInt_i(64, bits); return overflow || full_res < zig_minInt_i(64, bits) || full_res > zig_maxInt_i(64, bits);
@ -1755,15 +1747,13 @@ static inline bool zig_addo_u128(zig_u128 *res, zig_u128 lhs, zig_u128 rhs, uint
#endif #endif
} }
zig_extern zig_i128 __addoti4(zig_i128 lhs, zig_i128 rhs, int *overflow);
static inline bool zig_addo_i128(zig_i128 *res, zig_i128 lhs, zig_i128 rhs, uint8_t bits) { static inline bool zig_addo_i128(zig_i128 *res, zig_i128 lhs, zig_i128 rhs, uint8_t bits) {
#if zig_has_builtin(add_overflow) #if zig_has_builtin(add_overflow)
zig_i128 full_res; zig_i128 full_res;
bool overflow = __builtin_add_overflow(lhs, rhs, &full_res); bool overflow = __builtin_add_overflow(lhs, rhs, &full_res);
#else #else
int overflow_int; zig_i128 full_res = (zig_i128)((zig_u128)lhs + (zig_u128)rhs);
zig_i128 full_res = __addoti4(lhs, rhs, &overflow_int); bool overflow = ((full_res ^ lhs) & (full_res ^ rhs)) < 0;
bool overflow = overflow_int != 0;
#endif #endif
*res = zig_wrap_i128(full_res, bits); *res = zig_wrap_i128(full_res, bits);
return overflow || full_res < zig_minInt_i(128, bits) || full_res > zig_maxInt_i(128, bits); return overflow || full_res < zig_minInt_i(128, bits) || full_res > zig_maxInt_i(128, bits);
@ -1781,15 +1771,13 @@ static inline bool zig_subo_u128(zig_u128 *res, zig_u128 lhs, zig_u128 rhs, uint
#endif #endif
} }
zig_extern zig_i128 __suboti4(zig_i128 lhs, zig_i128 rhs, int *overflow);
static inline bool zig_subo_i128(zig_i128 *res, zig_i128 lhs, zig_i128 rhs, uint8_t bits) { static inline bool zig_subo_i128(zig_i128 *res, zig_i128 lhs, zig_i128 rhs, uint8_t bits) {
#if zig_has_builtin(sub_overflow) #if zig_has_builtin(sub_overflow)
zig_i128 full_res; zig_i128 full_res;
bool overflow = __builtin_sub_overflow(lhs, rhs, &full_res); bool overflow = __builtin_sub_overflow(lhs, rhs, &full_res);
#else #else
int overflow_int; zig_i128 full_res = (zig_i128)((zig_u128)lhs - (zig_u128)rhs);
zig_i128 full_res = __suboti4(lhs, rhs, &overflow_int); bool overflow = ((lhs ^ rhs) & (full_res ^ lhs)) < 0;
bool overflow = overflow_int != 0;
#endif #endif
*res = zig_wrap_i128(full_res, bits); *res = zig_wrap_i128(full_res, bits);
return overflow || full_res < zig_minInt_i(128, bits) || full_res > zig_maxInt_i(128, bits); return overflow || full_res < zig_minInt_i(128, bits) || full_res > zig_maxInt_i(128, bits);

View File

@ -40,6 +40,8 @@
#elif defined(__mips__) #elif defined(__mips__)
#define zig_mips32 #define zig_mips32
#define zig_mips #define zig_mips
#elif defined(__or1k__)
#define zig_or1k
#elif defined(__powerpc64__) #elif defined(__powerpc64__)
#define zig_powerpc64 #define zig_powerpc64
#define zig_powerpc #define zig_powerpc
@ -72,6 +74,9 @@
#elif defined (__x86_64__) || (defined(zig_msvc) && defined(_M_X64)) #elif defined (__x86_64__) || (defined(zig_msvc) && defined(_M_X64))
#define zig_x86_64 #define zig_x86_64
#define zig_x86 #define zig_x86
#elif defined(__I86__)
#define zig_x86_16
#define zig_x86
#endif #endif
#if defined(zig_msvc) || __BYTE_ORDER__ == __ORDER_LITTLE_ENDIAN__ #if defined(zig_msvc) || __BYTE_ORDER__ == __ORDER_LITTLE_ENDIAN__
@ -82,9 +87,7 @@
#define zig_big_endian 1 #define zig_big_endian 1
#endif #endif
#if defined(_AIX) #if defined(__MACH__)
#define zig_aix
#elif defined(__MACH__)
#define zig_darwin #define zig_darwin
#elif defined(__DragonFly__) #elif defined(__DragonFly__)
#define zig_dragonfly #define zig_dragonfly
@ -114,20 +117,14 @@
#define zig_wasi #define zig_wasi
#elif defined(_WIN32) #elif defined(_WIN32)
#define zig_windows #define zig_windows
#elif defined(__MVS__)
#define zig_zos
#endif #endif
#if defined(zig_windows) #if defined(zig_windows)
#define zig_coff #define zig_coff
#elif defined(__ELF__) #elif defined(__ELF__)
#define zig_elf #define zig_elf
#elif defined(zig_zos)
#define zig_goff
#elif defined(zig_darwin) #elif defined(zig_darwin)
#define zig_macho #define zig_macho
#elif defined(zig_aix)
#define zig_xcoff
#endif #endif
#define zig_concat(lhs, rhs) lhs##rhs #define zig_concat(lhs, rhs) lhs##rhs
@ -390,12 +387,16 @@
#define zig_trap() __asm__ volatile(".word 0x0") #define zig_trap() __asm__ volatile(".word 0x0")
#elif defined(zig_mips) #elif defined(zig_mips)
#define zig_trap() __asm__ volatile(".word 0x3d") #define zig_trap() __asm__ volatile(".word 0x3d")
#elif defined(zig_or1k)
#define zig_trap() __asm__ volatile("l.cust8")
#elif defined(zig_riscv) #elif defined(zig_riscv)
#define zig_trap() __asm__ volatile("unimp") #define zig_trap() __asm__ volatile("unimp")
#elif defined(zig_s390x) #elif defined(zig_s390x)
#define zig_trap() __asm__ volatile("j 0x2") #define zig_trap() __asm__ volatile("j 0x2")
#elif defined(zig_sparc) #elif defined(zig_sparc)
#define zig_trap() __asm__ volatile("illtrap") #define zig_trap() __asm__ volatile("illtrap")
#elif defined(zig_x86_16)
#define zig_trap() __asm__ volatile("int $0x3")
#elif defined(zig_x86) #elif defined(zig_x86)
#define zig_trap() __asm__ volatile("ud2") #define zig_trap() __asm__ volatile("ud2")
#else #else
@ -422,6 +423,8 @@
#define zig_breakpoint() __asm__ volatile("break 0x0") #define zig_breakpoint() __asm__ volatile("break 0x0")
#elif defined(zig_mips) #elif defined(zig_mips)
#define zig_breakpoint() __asm__ volatile("break") #define zig_breakpoint() __asm__ volatile("break")
#elif defined(zig_or1k)
#define zig_breakpoint() __asm__ volatile("l.trap 0x0")
#elif defined(zig_powerpc) #elif defined(zig_powerpc)
#define zig_breakpoint() __asm__ volatile("trap") #define zig_breakpoint() __asm__ volatile("trap")
#elif defined(zig_riscv) #elif defined(zig_riscv)
@ -804,15 +807,13 @@ static inline bool zig_addo_u32(uint32_t *res, uint32_t lhs, uint32_t rhs, uint8
#endif #endif
} }
zig_extern int32_t __addosi4(int32_t lhs, int32_t rhs, int *overflow);
static inline bool zig_addo_i32(int32_t *res, int32_t lhs, int32_t rhs, uint8_t bits) { static inline bool zig_addo_i32(int32_t *res, int32_t lhs, int32_t rhs, uint8_t bits) {
#if zig_has_builtin(add_overflow) || defined(zig_gcc) #if zig_has_builtin(add_overflow) || defined(zig_gcc)
int32_t full_res; int32_t full_res;
bool overflow = __builtin_add_overflow(lhs, rhs, &full_res); bool overflow = __builtin_add_overflow(lhs, rhs, &full_res);
#else #else
int overflow_int; int32_t full_res = (int32_t)((uint32_t)lhs + (uint32_t)rhs);
int32_t full_res = __addosi4(lhs, rhs, &overflow_int); bool overflow = ((full_res ^ lhs) & (full_res ^ rhs)) < 0;
bool overflow = overflow_int != 0;
#endif #endif
*res = zig_wrap_i32(full_res, bits); *res = zig_wrap_i32(full_res, bits);
return overflow || full_res < zig_minInt_i(32, bits) || full_res > zig_maxInt_i(32, bits); return overflow || full_res < zig_minInt_i(32, bits) || full_res > zig_maxInt_i(32, bits);
@ -830,15 +831,13 @@ static inline bool zig_addo_u64(uint64_t *res, uint64_t lhs, uint64_t rhs, uint8
#endif #endif
} }
zig_extern int64_t __addodi4(int64_t lhs, int64_t rhs, int *overflow);
static inline bool zig_addo_i64(int64_t *res, int64_t lhs, int64_t rhs, uint8_t bits) { static inline bool zig_addo_i64(int64_t *res, int64_t lhs, int64_t rhs, uint8_t bits) {
#if zig_has_builtin(add_overflow) || defined(zig_gcc) #if zig_has_builtin(add_overflow) || defined(zig_gcc)
int64_t full_res; int64_t full_res;
bool overflow = __builtin_add_overflow(lhs, rhs, &full_res); bool overflow = __builtin_add_overflow(lhs, rhs, &full_res);
#else #else
int overflow_int; int64_t full_res = (int64_t)((uint64_t)lhs + (uint64_t)rhs);
int64_t full_res = __addodi4(lhs, rhs, &overflow_int); bool overflow = ((full_res ^ lhs) & (full_res ^ rhs)) < 0;
bool overflow = overflow_int != 0;
#endif #endif
*res = zig_wrap_i64(full_res, bits); *res = zig_wrap_i64(full_res, bits);
return overflow || full_res < zig_minInt_i(64, bits) || full_res > zig_maxInt_i(64, bits); return overflow || full_res < zig_minInt_i(64, bits) || full_res > zig_maxInt_i(64, bits);
@ -912,15 +911,13 @@ static inline bool zig_subo_u32(uint32_t *res, uint32_t lhs, uint32_t rhs, uint8
#endif #endif
} }
zig_extern int32_t __subosi4(int32_t lhs, int32_t rhs, int *overflow);
static inline bool zig_subo_i32(int32_t *res, int32_t lhs, int32_t rhs, uint8_t bits) { static inline bool zig_subo_i32(int32_t *res, int32_t lhs, int32_t rhs, uint8_t bits) {
#if zig_has_builtin(sub_overflow) || defined(zig_gcc) #if zig_has_builtin(sub_overflow) || defined(zig_gcc)
int32_t full_res; int32_t full_res;
bool overflow = __builtin_sub_overflow(lhs, rhs, &full_res); bool overflow = __builtin_sub_overflow(lhs, rhs, &full_res);
#else #else
int overflow_int; int32_t full_res = (int32_t)((uint32_t)lhs - (uint32_t)rhs);
int32_t full_res = __subosi4(lhs, rhs, &overflow_int); bool overflow = ((lhs ^ rhs) & (full_res ^ lhs)) < 0;
bool overflow = overflow_int != 0;
#endif #endif
*res = zig_wrap_i32(full_res, bits); *res = zig_wrap_i32(full_res, bits);
return overflow || full_res < zig_minInt_i(32, bits) || full_res > zig_maxInt_i(32, bits); return overflow || full_res < zig_minInt_i(32, bits) || full_res > zig_maxInt_i(32, bits);
@ -938,15 +935,13 @@ static inline bool zig_subo_u64(uint64_t *res, uint64_t lhs, uint64_t rhs, uint8
#endif #endif
} }
zig_extern int64_t __subodi4(int64_t lhs, int64_t rhs, int *overflow);
static inline bool zig_subo_i64(int64_t *res, int64_t lhs, int64_t rhs, uint8_t bits) { static inline bool zig_subo_i64(int64_t *res, int64_t lhs, int64_t rhs, uint8_t bits) {
#if zig_has_builtin(sub_overflow) || defined(zig_gcc) #if zig_has_builtin(sub_overflow) || defined(zig_gcc)
int64_t full_res; int64_t full_res;
bool overflow = __builtin_sub_overflow(lhs, rhs, &full_res); bool overflow = __builtin_sub_overflow(lhs, rhs, &full_res);
#else #else
int overflow_int; int64_t full_res = (int64_t)((uint64_t)lhs - (uint64_t)rhs);
int64_t full_res = __subodi4(lhs, rhs, &overflow_int); bool overflow = ((lhs ^ rhs) & (full_res ^ lhs)) < 0;
bool overflow = overflow_int != 0;
#endif #endif
*res = zig_wrap_i64(full_res, bits); *res = zig_wrap_i64(full_res, bits);
return overflow || full_res < zig_minInt_i(64, bits) || full_res > zig_maxInt_i(64, bits); return overflow || full_res < zig_minInt_i(64, bits) || full_res > zig_maxInt_i(64, bits);
@ -1750,15 +1745,13 @@ static inline bool zig_addo_u128(zig_u128 *res, zig_u128 lhs, zig_u128 rhs, uint
#endif #endif
} }
zig_extern zig_i128 __addoti4(zig_i128 lhs, zig_i128 rhs, int *overflow);
static inline bool zig_addo_i128(zig_i128 *res, zig_i128 lhs, zig_i128 rhs, uint8_t bits) { static inline bool zig_addo_i128(zig_i128 *res, zig_i128 lhs, zig_i128 rhs, uint8_t bits) {
#if zig_has_builtin(add_overflow) #if zig_has_builtin(add_overflow)
zig_i128 full_res; zig_i128 full_res;
bool overflow = __builtin_add_overflow(lhs, rhs, &full_res); bool overflow = __builtin_add_overflow(lhs, rhs, &full_res);
#else #else
int overflow_int; zig_i128 full_res = (zig_i128)((zig_u128)lhs + (zig_u128)rhs);
zig_i128 full_res = __addoti4(lhs, rhs, &overflow_int); bool overflow = ((full_res ^ lhs) & (full_res ^ rhs)) < 0;
bool overflow = overflow_int != 0;
#endif #endif
*res = zig_wrap_i128(full_res, bits); *res = zig_wrap_i128(full_res, bits);
return overflow || full_res < zig_minInt_i(128, bits) || full_res > zig_maxInt_i(128, bits); return overflow || full_res < zig_minInt_i(128, bits) || full_res > zig_maxInt_i(128, bits);
@ -1776,15 +1769,13 @@ static inline bool zig_subo_u128(zig_u128 *res, zig_u128 lhs, zig_u128 rhs, uint
#endif #endif
} }
zig_extern zig_i128 __suboti4(zig_i128 lhs, zig_i128 rhs, int *overflow);
static inline bool zig_subo_i128(zig_i128 *res, zig_i128 lhs, zig_i128 rhs, uint8_t bits) { static inline bool zig_subo_i128(zig_i128 *res, zig_i128 lhs, zig_i128 rhs, uint8_t bits) {
#if zig_has_builtin(sub_overflow) #if zig_has_builtin(sub_overflow)
zig_i128 full_res; zig_i128 full_res;
bool overflow = __builtin_sub_overflow(lhs, rhs, &full_res); bool overflow = __builtin_sub_overflow(lhs, rhs, &full_res);
#else #else
int overflow_int; zig_i128 full_res = (zig_i128)((zig_u128)lhs - (zig_u128)rhs);
zig_i128 full_res = __suboti4(lhs, rhs, &overflow_int); bool overflow = ((lhs ^ rhs) & (full_res ^ lhs)) < 0;
bool overflow = overflow_int != 0;
#endif #endif
*res = zig_wrap_i128(full_res, bits); *res = zig_wrap_i128(full_res, bits);
return overflow || full_res < zig_minInt_i(128, bits) || full_res > zig_maxInt_i(128, bits); return overflow || full_res < zig_minInt_i(128, bits) || full_res > zig_maxInt_i(128, bits);
@ -4213,7 +4204,7 @@ static inline void zig_loongarch_cpucfg(uint32_t word, uint32_t* result) {
#endif #endif
} }
#elif defined(zig_x86) #elif defined(zig_x86) && !defined(zig_x86_16)
static inline void zig_x86_cpuid(uint32_t leaf_id, uint32_t subid, uint32_t* eax, uint32_t* ebx, uint32_t* ecx, uint32_t* edx) { static inline void zig_x86_cpuid(uint32_t leaf_id, uint32_t subid, uint32_t* eax, uint32_t* ebx, uint32_t* ecx, uint32_t* edx) {
#if defined(zig_msvc) #if defined(zig_msvc)