master
1//! negv - negate oVerflow
2//! * @panic, if result can not be represented
3//! - negvXi4_generic for unoptimized version
4const std = @import("std");
5const builtin = @import("builtin");
6const common = @import("common.zig");
7
8pub const panic = common.panic;
9
10comptime {
11 @export(&__negvsi2, .{ .name = "__negvsi2", .linkage = common.linkage, .visibility = common.visibility });
12 @export(&__negvdi2, .{ .name = "__negvdi2", .linkage = common.linkage, .visibility = common.visibility });
13 @export(&__negvti2, .{ .name = "__negvti2", .linkage = common.linkage, .visibility = common.visibility });
14}
15
16pub fn __negvsi2(a: i32) callconv(.c) i32 {
17 return negvXi(i32, a);
18}
19
20pub fn __negvdi2(a: i64) callconv(.c) i64 {
21 return negvXi(i64, a);
22}
23
24pub fn __negvti2(a: i128) callconv(.c) i128 {
25 return negvXi(i128, a);
26}
27
28inline fn negvXi(comptime ST: type, a: ST) ST {
29 const UT = switch (ST) {
30 i32 => u32,
31 i64 => u64,
32 i128 => u128,
33 else => unreachable,
34 };
35 const N: UT = @bitSizeOf(ST);
36 const min: ST = @as(ST, @bitCast((@as(UT, 1) << (N - 1))));
37 if (a == min)
38 @panic("compiler_rt negv: overflow");
39 return -a;
40}
41
42test {
43 _ = @import("negvsi2_test.zig");
44 _ = @import("negvdi2_test.zig");
45 _ = @import("negvti2_test.zig");
46}