master
1const mulo = @import("mulo.zig");
2const testing = @import("std").testing;
3
4// ported from https://github.com/llvm-mirror/compiler-rt/tree/release_80/test/builtins/Unit
5
6fn test__muloti4(a: i128, b: i128, expected: i128, expected_overflow: c_int) !void {
7 var overflow: c_int = undefined;
8 const x = mulo.__muloti4(a, b, &overflow);
9 try testing.expect(overflow == expected_overflow and (expected_overflow != 0 or x == expected));
10}
11
12test "muloti4" {
13 try test__muloti4(0, 0, 0, 0);
14 try test__muloti4(0, 1, 0, 0);
15 try test__muloti4(1, 0, 0, 0);
16 try test__muloti4(0, 10, 0, 0);
17 try test__muloti4(10, 0, 0, 0);
18 try test__muloti4(0, 81985529216486895, 0, 0);
19 try test__muloti4(81985529216486895, 0, 0, 0);
20
21 try test__muloti4(0, -1, 0, 0);
22 try test__muloti4(-1, 0, 0, 0);
23 try test__muloti4(0, -10, 0, 0);
24 try test__muloti4(-10, 0, 0, 0);
25 try test__muloti4(0, -81985529216486895, 0, 0);
26 try test__muloti4(-81985529216486895, 0, 0, 0);
27
28 try test__muloti4(1, 1, 1, 0);
29 try test__muloti4(1, 10, 10, 0);
30 try test__muloti4(10, 1, 10, 0);
31 try test__muloti4(1, 81985529216486895, 81985529216486895, 0);
32 try test__muloti4(81985529216486895, 1, 81985529216486895, 0);
33
34 try test__muloti4(1, -1, -1, 0);
35 try test__muloti4(1, -10, -10, 0);
36 try test__muloti4(-10, 1, -10, 0);
37 try test__muloti4(1, -81985529216486895, -81985529216486895, 0);
38 try test__muloti4(-81985529216486895, 1, -81985529216486895, 0);
39
40 try test__muloti4(3037000499, 3037000499, 9223372030926249001, 0);
41 try test__muloti4(-3037000499, 3037000499, -9223372030926249001, 0);
42 try test__muloti4(3037000499, -3037000499, -9223372030926249001, 0);
43 try test__muloti4(-3037000499, -3037000499, 9223372030926249001, 0);
44
45 try test__muloti4(4398046511103, 2097152, 9223372036852678656, 0);
46 try test__muloti4(-4398046511103, 2097152, -9223372036852678656, 0);
47 try test__muloti4(4398046511103, -2097152, -9223372036852678656, 0);
48 try test__muloti4(-4398046511103, -2097152, 9223372036852678656, 0);
49
50 try test__muloti4(2097152, 4398046511103, 9223372036852678656, 0);
51 try test__muloti4(-2097152, 4398046511103, -9223372036852678656, 0);
52 try test__muloti4(2097152, -4398046511103, -9223372036852678656, 0);
53 try test__muloti4(-2097152, -4398046511103, 9223372036852678656, 0);
54
55 try test__muloti4(@as(i128, @bitCast(@as(u128, 0x00000000000000B504F333F9DE5BE000))), @as(i128, @bitCast(@as(u128, 0x000000000000000000B504F333F9DE5B))), @as(i128, @bitCast(@as(u128, 0x7FFFFFFFFFFFF328DF915DA296E8A000))), 0);
56 try test__muloti4(@as(i128, @bitCast(@as(u128, 0x7FFFFFFFFFFFFFFFFFFFFFFFFFFFFFFF))), -2, @as(i128, @bitCast(@as(u128, 0x80000000000000000000000000000001))), 1);
57 try test__muloti4(-2, @as(i128, @bitCast(@as(u128, 0x7FFFFFFFFFFFFFFFFFFFFFFFFFFFFFFF))), @as(i128, @bitCast(@as(u128, 0x80000000000000000000000000000001))), 1);
58
59 try test__muloti4(@as(i128, @bitCast(@as(u128, 0x7FFFFFFFFFFFFFFFFFFFFFFFFFFFFFFF))), -1, @as(i128, @bitCast(@as(u128, 0x80000000000000000000000000000001))), 0);
60 try test__muloti4(-1, @as(i128, @bitCast(@as(u128, 0x7FFFFFFFFFFFFFFFFFFFFFFFFFFFFFFF))), @as(i128, @bitCast(@as(u128, 0x80000000000000000000000000000001))), 0);
61 try test__muloti4(@as(i128, @bitCast(@as(u128, 0x7FFFFFFFFFFFFFFFFFFFFFFFFFFFFFFF))), 0, 0, 0);
62 try test__muloti4(0, @as(i128, @bitCast(@as(u128, 0x7FFFFFFFFFFFFFFFFFFFFFFFFFFFFFFF))), 0, 0);
63 try test__muloti4(@as(i128, @bitCast(@as(u128, 0x7FFFFFFFFFFFFFFFFFFFFFFFFFFFFFFF))), 1, @as(i128, @bitCast(@as(u128, 0x7FFFFFFFFFFFFFFFFFFFFFFFFFFFFFFF))), 0);
64 try test__muloti4(1, @as(i128, @bitCast(@as(u128, 0x7FFFFFFFFFFFFFFFFFFFFFFFFFFFFFFF))), @as(i128, @bitCast(@as(u128, 0x7FFFFFFFFFFFFFFFFFFFFFFFFFFFFFFF))), 0);
65 try test__muloti4(@as(i128, @bitCast(@as(u128, 0x7FFFFFFFFFFFFFFFFFFFFFFFFFFFFFFF))), 2, @as(i128, @bitCast(@as(u128, 0x80000000000000000000000000000001))), 1);
66 try test__muloti4(2, @as(i128, @bitCast(@as(u128, 0x7FFFFFFFFFFFFFFFFFFFFFFFFFFFFFFF))), @as(i128, @bitCast(@as(u128, 0x80000000000000000000000000000001))), 1);
67
68 try test__muloti4(@as(i128, @bitCast(@as(u128, 0x80000000000000000000000000000000))), -2, @as(i128, @bitCast(@as(u128, 0x80000000000000000000000000000000))), 1);
69 try test__muloti4(-2, @as(i128, @bitCast(@as(u128, 0x80000000000000000000000000000000))), @as(i128, @bitCast(@as(u128, 0x80000000000000000000000000000000))), 1);
70 try test__muloti4(@as(i128, @bitCast(@as(u128, 0x80000000000000000000000000000000))), -1, @as(i128, @bitCast(@as(u128, 0x80000000000000000000000000000000))), 1);
71 try test__muloti4(-1, @as(i128, @bitCast(@as(u128, 0x80000000000000000000000000000000))), @as(i128, @bitCast(@as(u128, 0x80000000000000000000000000000000))), 1);
72 try test__muloti4(@as(i128, @bitCast(@as(u128, 0x80000000000000000000000000000000))), 0, 0, 0);
73 try test__muloti4(0, @as(i128, @bitCast(@as(u128, 0x80000000000000000000000000000000))), 0, 0);
74 try test__muloti4(@as(i128, @bitCast(@as(u128, 0x80000000000000000000000000000000))), 1, @as(i128, @bitCast(@as(u128, 0x80000000000000000000000000000000))), 0);
75 try test__muloti4(1, @as(i128, @bitCast(@as(u128, 0x80000000000000000000000000000000))), @as(i128, @bitCast(@as(u128, 0x80000000000000000000000000000000))), 0);
76 try test__muloti4(@as(i128, @bitCast(@as(u128, 0x80000000000000000000000000000000))), 2, @as(i128, @bitCast(@as(u128, 0x80000000000000000000000000000000))), 1);
77 try test__muloti4(2, @as(i128, @bitCast(@as(u128, 0x80000000000000000000000000000000))), @as(i128, @bitCast(@as(u128, 0x80000000000000000000000000000000))), 1);
78
79 try test__muloti4(@as(i128, @bitCast(@as(u128, 0x80000000000000000000000000000001))), -2, @as(i128, @bitCast(@as(u128, 0x80000000000000000000000000000001))), 1);
80 try test__muloti4(-2, @as(i128, @bitCast(@as(u128, 0x80000000000000000000000000000001))), @as(i128, @bitCast(@as(u128, 0x80000000000000000000000000000001))), 1);
81 try test__muloti4(@as(i128, @bitCast(@as(u128, 0x80000000000000000000000000000001))), -1, @as(i128, @bitCast(@as(u128, 0x7FFFFFFFFFFFFFFFFFFFFFFFFFFFFFFF))), 0);
82 try test__muloti4(-1, @as(i128, @bitCast(@as(u128, 0x80000000000000000000000000000001))), @as(i128, @bitCast(@as(u128, 0x7FFFFFFFFFFFFFFFFFFFFFFFFFFFFFFF))), 0);
83 try test__muloti4(@as(i128, @bitCast(@as(u128, 0x80000000000000000000000000000001))), 0, 0, 0);
84 try test__muloti4(0, @as(i128, @bitCast(@as(u128, 0x80000000000000000000000000000001))), 0, 0);
85 try test__muloti4(@as(i128, @bitCast(@as(u128, 0x80000000000000000000000000000001))), 1, @as(i128, @bitCast(@as(u128, 0x80000000000000000000000000000001))), 0);
86 try test__muloti4(1, @as(i128, @bitCast(@as(u128, 0x80000000000000000000000000000001))), @as(i128, @bitCast(@as(u128, 0x80000000000000000000000000000001))), 0);
87 try test__muloti4(@as(i128, @bitCast(@as(u128, 0x80000000000000000000000000000001))), 2, @as(i128, @bitCast(@as(u128, 0x80000000000000000000000000000000))), 1);
88 try test__muloti4(2, @as(i128, @bitCast(@as(u128, 0x80000000000000000000000000000001))), @as(i128, @bitCast(@as(u128, 0x80000000000000000000000000000000))), 1);
89}