Skip to content

Commit e8dd79c

Browse files
jacobly0andrewrk
authored andcommitted
cbe: fix ub with integer @abs
1 parent a69788b commit e8dd79c

File tree

2 files changed

+71
-228
lines changed

2 files changed

+71
-228
lines changed

lib/zig.h

+26-58
Original file line numberDiff line numberDiff line change
@@ -530,6 +530,10 @@ typedef ptrdiff_t intptr_t;
530530
return (val & UINT##w##_C(1) << (bits - UINT8_C(1))) != 0 \
531531
? val | zig_minInt_i(w, bits) : val & zig_maxInt_i(w, bits); \
532532
} \
533+
\
534+
static inline uint##w##_t zig_abs_i##w(int##w##_t val) { \
535+
return (val < 0) ? -(uint##w##_t)val : (uint##w##_t)val; \
536+
} \
533537
\
534538
zig_basic_operator(uint##w##_t, div_floor_u##w, /) \
535539
\
@@ -990,24 +994,6 @@ typedef unsigned long zig_Builtin64;
990994
typedef unsigned long long zig_Builtin64;
991995
#endif
992996

993-
#define zig_builtin8_rev(name, val) __builtin_##name(val)
994-
995-
#define zig_builtin16_rev(name, val) __builtin_##name(val)
996-
997-
#if INT_MIN <= INT32_MIN
998-
#define zig_builtin32_rev(name, val) __builtin_##name(val)
999-
#elif LONG_MIN <= INT32_MIN
1000-
#define zig_builtin32_rev(name, val) __builtin_l##name(val)
1001-
#endif
1002-
1003-
#if INT_MIN <= INT64_MIN
1004-
#define zig_builtin64_rev(name, val) __builtin_##name(val)
1005-
#elif LONG_MIN <= INT64_MIN
1006-
#define zig_builtin64_rev(name, val) __builtin_l##name(val)
1007-
#elif LLONG_MIN <= INT64_MIN
1008-
#define zig_builtin64_rev(name, val) __builtin_ll##name(val)
1009-
#endif
1010-
1011997
static inline uint8_t zig_byte_swap_u8(uint8_t val, uint8_t bits) {
1012998
return zig_wrap_u8(val >> (8 - bits), bits);
1013999
}
@@ -1203,24 +1189,6 @@ zig_builtin_clz(16)
12031189
zig_builtin_clz(32)
12041190
zig_builtin_clz(64)
12051191

1206-
#if zig_has_builtin(abs) || defined(zig_gnuc)
1207-
#define zig_builtin_abs(w) \
1208-
static inline int##w##_t zig_abs_i##w(int##w##_t val) { \
1209-
return zig_builtin##w##_rev(abs, val); \
1210-
}
1211-
#else
1212-
#define zig_builtin_abs(w) \
1213-
static inline int##w##_t zig_abs_i##w(int##w##_t val) { \
1214-
if (val == INT##w##_MIN) return val; \
1215-
int##w##_t tmp = val >> (w - 1); \
1216-
return (val ^ tmp) - tmp; \
1217-
}
1218-
#endif
1219-
zig_builtin_abs(8)
1220-
zig_builtin_abs(16)
1221-
zig_builtin_abs(32)
1222-
zig_builtin_abs(64)
1223-
12241192
/* ======================== 128-bit Integer Support ========================= */
12251193

12261194
#if !defined(zig_has_int128)
@@ -3375,31 +3343,31 @@ zig_float_negate_builtin(128, zig_make_u128, (UINT64_C(1) << 63, UINT64_C(0)))
33753343
zig_expand_concat(zig_float_binary_builtin_, zig_has_f##w)(f##w, sub, -) \
33763344
zig_expand_concat(zig_float_binary_builtin_, zig_has_f##w)(f##w, mul, *) \
33773345
zig_expand_concat(zig_float_binary_builtin_, zig_has_f##w)(f##w, div, /) \
3378-
zig_expand_concat(zig_expand_import_, zig_expand_has_builtin(zig_libc_name_f##w(sqrt)))(zig_f##w, zig_float_fn_f##w##_sqrt, zig_libc_name_f##w(sqrt), (zig_f##w x), (x)) \
3379-
zig_expand_concat(zig_expand_import_, zig_expand_has_builtin(zig_libc_name_f##w(sin)))(zig_f##w, zig_float_fn_f##w##_sin, zig_libc_name_f##w(sin), (zig_f##w x), (x)) \
3380-
zig_expand_concat(zig_expand_import_, zig_expand_has_builtin(zig_libc_name_f##w(cos)))(zig_f##w, zig_float_fn_f##w##_cos, zig_libc_name_f##w(cos), (zig_f##w x), (x)) \
3381-
zig_expand_concat(zig_expand_import_, zig_expand_has_builtin(zig_libc_name_f##w(tan)))(zig_f##w, zig_float_fn_f##w##_tan, zig_libc_name_f##w(tan), (zig_f##w x), (x)) \
3382-
zig_expand_concat(zig_expand_import_, zig_expand_has_builtin(zig_libc_name_f##w(exp)))(zig_f##w, zig_float_fn_f##w##_exp, zig_libc_name_f##w(exp), (zig_f##w x), (x)) \
3383-
zig_expand_concat(zig_expand_import_, zig_expand_has_builtin(zig_libc_name_f##w(exp2)))(zig_f##w, zig_float_fn_f##w##_exp2, zig_libc_name_f##w(exp2), (zig_f##w x), (x)) \
3384-
zig_expand_concat(zig_expand_import_, zig_expand_has_builtin(zig_libc_name_f##w(log)))(zig_f##w, zig_float_fn_f##w##_log, zig_libc_name_f##w(log), (zig_f##w x), (x)) \
3385-
zig_expand_concat(zig_expand_import_, zig_expand_has_builtin(zig_libc_name_f##w(log2)))(zig_f##w, zig_float_fn_f##w##_log2, zig_libc_name_f##w(log2), (zig_f##w x), (x)) \
3386-
zig_expand_concat(zig_expand_import_, zig_expand_has_builtin(zig_libc_name_f##w(log10)))(zig_f##w, zig_float_fn_f##w##_log10, zig_libc_name_f##w(log10), (zig_f##w x), (x)) \
3387-
zig_expand_concat(zig_expand_import_, zig_expand_has_builtin(zig_libc_name_f##w(fabs)))(zig_f##w, zig_float_fn_f##w##_fabs, zig_libc_name_f##w(fabs), (zig_f##w x), (x)) \
3388-
zig_expand_concat(zig_expand_import_, zig_expand_has_builtin(zig_libc_name_f##w(floor)))(zig_f##w, zig_float_fn_f##w##_floor, zig_libc_name_f##w(floor), (zig_f##w x), (x)) \
3389-
zig_expand_concat(zig_expand_import_, zig_expand_has_builtin(zig_libc_name_f##w(ceil)))(zig_f##w, zig_float_fn_f##w##_ceil, zig_libc_name_f##w(ceil), (zig_f##w x), (x)) \
3390-
zig_expand_concat(zig_expand_import_, zig_expand_has_builtin(zig_libc_name_f##w(round)))(zig_f##w, zig_float_fn_f##w##_round, zig_libc_name_f##w(round), (zig_f##w x), (x)) \
3391-
zig_expand_concat(zig_expand_import_, zig_expand_has_builtin(zig_libc_name_f##w(trunc)))(zig_f##w, zig_float_fn_f##w##_trunc, zig_libc_name_f##w(trunc), (zig_f##w x), (x)) \
3392-
zig_expand_concat(zig_expand_import_, zig_expand_has_builtin(zig_libc_name_f##w(fmod)))(zig_f##w, zig_float_fn_f##w##_fmod, zig_libc_name_f##w(fmod), (zig_f##w x, zig_f##w y), (x, y)) \
3393-
zig_expand_concat(zig_expand_import_, zig_expand_has_builtin(zig_libc_name_f##w(fmin)))(zig_f##w, zig_float_fn_f##w##_fmin, zig_libc_name_f##w(fmin), (zig_f##w x, zig_f##w y), (x, y)) \
3394-
zig_expand_concat(zig_expand_import_, zig_expand_has_builtin(zig_libc_name_f##w(fmax)))(zig_f##w, zig_float_fn_f##w##_fmax, zig_libc_name_f##w(fmax), (zig_f##w x, zig_f##w y), (x, y)) \
3395-
zig_expand_concat(zig_expand_import_, zig_expand_has_builtin(zig_libc_name_f##w(fma)))(zig_f##w, zig_float_fn_f##w##_fma, zig_libc_name_f##w(fma), (zig_f##w x, zig_f##w y, zig_f##w z), (x, y, z)) \
3346+
zig_expand_concat(zig_expand_import_, zig_expand_has_builtin(zig_libc_name_f##w(sqrt)))(zig_f##w, zig_sqrt_f##w, zig_libc_name_f##w(sqrt), (zig_f##w x), (x)) \
3347+
zig_expand_concat(zig_expand_import_, zig_expand_has_builtin(zig_libc_name_f##w(sin)))(zig_f##w, zig_sin_f##w, zig_libc_name_f##w(sin), (zig_f##w x), (x)) \
3348+
zig_expand_concat(zig_expand_import_, zig_expand_has_builtin(zig_libc_name_f##w(cos)))(zig_f##w, zig_cos_f##w, zig_libc_name_f##w(cos), (zig_f##w x), (x)) \
3349+
zig_expand_concat(zig_expand_import_, zig_expand_has_builtin(zig_libc_name_f##w(tan)))(zig_f##w, zig_tan_f##w, zig_libc_name_f##w(tan), (zig_f##w x), (x)) \
3350+
zig_expand_concat(zig_expand_import_, zig_expand_has_builtin(zig_libc_name_f##w(exp)))(zig_f##w, zig_exp_f##w, zig_libc_name_f##w(exp), (zig_f##w x), (x)) \
3351+
zig_expand_concat(zig_expand_import_, zig_expand_has_builtin(zig_libc_name_f##w(exp2)))(zig_f##w, zig_exp2_f##w, zig_libc_name_f##w(exp2), (zig_f##w x), (x)) \
3352+
zig_expand_concat(zig_expand_import_, zig_expand_has_builtin(zig_libc_name_f##w(log)))(zig_f##w, zig_log_f##w, zig_libc_name_f##w(log), (zig_f##w x), (x)) \
3353+
zig_expand_concat(zig_expand_import_, zig_expand_has_builtin(zig_libc_name_f##w(log2)))(zig_f##w, zig_log2_f##w, zig_libc_name_f##w(log2), (zig_f##w x), (x)) \
3354+
zig_expand_concat(zig_expand_import_, zig_expand_has_builtin(zig_libc_name_f##w(log10)))(zig_f##w, zig_log10_f##w, zig_libc_name_f##w(log10), (zig_f##w x), (x)) \
3355+
zig_expand_concat(zig_expand_import_, zig_expand_has_builtin(zig_libc_name_f##w(fabs)))(zig_f##w, zig_abs_f##w, zig_libc_name_f##w(fabs), (zig_f##w x), (x)) \
3356+
zig_expand_concat(zig_expand_import_, zig_expand_has_builtin(zig_libc_name_f##w(floor)))(zig_f##w, zig_floor_f##w, zig_libc_name_f##w(floor), (zig_f##w x), (x)) \
3357+
zig_expand_concat(zig_expand_import_, zig_expand_has_builtin(zig_libc_name_f##w(ceil)))(zig_f##w, zig_ceil_f##w, zig_libc_name_f##w(ceil), (zig_f##w x), (x)) \
3358+
zig_expand_concat(zig_expand_import_, zig_expand_has_builtin(zig_libc_name_f##w(round)))(zig_f##w, zig_round_f##w, zig_libc_name_f##w(round), (zig_f##w x), (x)) \
3359+
zig_expand_concat(zig_expand_import_, zig_expand_has_builtin(zig_libc_name_f##w(trunc)))(zig_f##w, zig_trunc_f##w, zig_libc_name_f##w(trunc), (zig_f##w x), (x)) \
3360+
zig_expand_concat(zig_expand_import_, zig_expand_has_builtin(zig_libc_name_f##w(fmod)))(zig_f##w, zig_fmod_f##w, zig_libc_name_f##w(fmod), (zig_f##w x, zig_f##w y), (x, y)) \
3361+
zig_expand_concat(zig_expand_import_, zig_expand_has_builtin(zig_libc_name_f##w(fmin)))(zig_f##w, zig_min_f##w, zig_libc_name_f##w(fmin), (zig_f##w x, zig_f##w y), (x, y)) \
3362+
zig_expand_concat(zig_expand_import_, zig_expand_has_builtin(zig_libc_name_f##w(fmax)))(zig_f##w, zig_max_f##w, zig_libc_name_f##w(fmax), (zig_f##w x, zig_f##w y), (x, y)) \
3363+
zig_expand_concat(zig_expand_import_, zig_expand_has_builtin(zig_libc_name_f##w(fma)))(zig_f##w, zig_fma_f##w, zig_libc_name_f##w(fma), (zig_f##w x, zig_f##w y, zig_f##w z), (x, y, z)) \
33963364
\
33973365
static inline zig_f##w zig_div_trunc_f##w(zig_f##w lhs, zig_f##w rhs) { \
3398-
return zig_float_fn_f##w##_trunc(zig_div_f##w(lhs, rhs)); \
3366+
return zig_trunc_f##w(zig_div_f##w(lhs, rhs)); \
33993367
} \
34003368
\
34013369
static inline zig_f##w zig_div_floor_f##w(zig_f##w lhs, zig_f##w rhs) { \
3402-
return zig_float_fn_f##w##_floor(zig_div_f##w(lhs, rhs)); \
3370+
return zig_floor_f##w(zig_div_f##w(lhs, rhs)); \
34033371
} \
34043372
\
34053373
static inline zig_f##w zig_mod_f##w(zig_f##w lhs, zig_f##w rhs) { \
@@ -3503,7 +3471,7 @@ zig_float_builtins(64)
35033471
zig_##Type zig_atomicrmw_desired; \
35043472
zig_atomic_load(zig_atomicrmw_expected, obj, zig_memory_order_relaxed, Type, ReprType); \
35053473
do { \
3506-
zig_atomicrmw_desired = zig_float_fn_##Type##_fmin(zig_atomicrmw_expected, arg); \
3474+
zig_atomicrmw_desired = zig_min_##Type(zig_atomicrmw_expected, arg); \
35073475
} while (!zig_cmpxchg_weak(obj, zig_atomicrmw_expected, zig_atomicrmw_desired, order, zig_memory_order_relaxed, Type, ReprType)); \
35083476
res = zig_atomicrmw_expected; \
35093477
} while (0)
@@ -3512,7 +3480,7 @@ zig_float_builtins(64)
35123480
zig_##Type zig_atomicrmw_desired; \
35133481
zig_atomic_load(zig_atomicrmw_expected, obj, zig_memory_order_relaxed, Type, ReprType); \
35143482
do { \
3515-
zig_atomicrmw_desired = zig_float_fn_##Type##_fmax(zig_atomicrmw_expected, arg); \
3483+
zig_atomicrmw_desired = zig_max_##Type(zig_atomicrmw_expected, arg); \
35163484
} while (!zig_cmpxchg_weak(obj, zig_atomicrmw_expected, zig_atomicrmw_desired, order, zig_memory_order_relaxed, Type, ReprType)); \
35173485
res = zig_atomicrmw_expected; \
35183486
} while (0)

0 commit comments

Comments
 (0)