xref: /linux/lib/tests/shdi3_kunit.c (revision 2e05544060b9fef5d4d0e0172944e6956c55080f)
1*6bba2ae4SDmitry Antipov // SPDX-License-Identifier: GPL-2.0-or-later OR Apache-2.0
2*6bba2ae4SDmitry Antipov /*
3*6bba2ae4SDmitry Antipov  * Test cases for __ashldi3(), __ashrdi3(), and __lshrdi3().
4*6bba2ae4SDmitry Antipov  */
5*6bba2ae4SDmitry Antipov 
6*6bba2ae4SDmitry Antipov #include <linux/array_size.h>
7*6bba2ae4SDmitry Antipov #include <linux/module.h>
8*6bba2ae4SDmitry Antipov #include <linux/libgcc.h>
9*6bba2ae4SDmitry Antipov #include <kunit/test.h>
10*6bba2ae4SDmitry Antipov 
11*6bba2ae4SDmitry Antipov struct shdi3_test_entry {
12*6bba2ae4SDmitry Antipov 	long long input;
13*6bba2ae4SDmitry Antipov 	int shift;
14*6bba2ae4SDmitry Antipov 	long long result;
15*6bba2ae4SDmitry Antipov };
16*6bba2ae4SDmitry Antipov 
17*6bba2ae4SDmitry Antipov static const struct shdi3_test_entry ashldi3_testdata[] = {
18*6bba2ae4SDmitry Antipov 	/* https://github.com/llvm/llvm-project/compiler-rt/test/builtins/Unit/ashldi3_test.c */
19*6bba2ae4SDmitry Antipov 	{ 0x0123456789ABCDEFLL, 0, 0x123456789ABCDEFLL },
20*6bba2ae4SDmitry Antipov 	{ 0x0123456789ABCDEFLL, 1, 0x2468ACF13579BDELL },
21*6bba2ae4SDmitry Antipov 	{ 0x0123456789ABCDEFLL, 2, 0x48D159E26AF37BCLL },
22*6bba2ae4SDmitry Antipov 	{ 0x0123456789ABCDEFLL, 3, 0x91A2B3C4D5E6F78LL },
23*6bba2ae4SDmitry Antipov 	{ 0x0123456789ABCDEFLL, 4, 0x123456789ABCDEF0LL },
24*6bba2ae4SDmitry Antipov 	{ 0x0123456789ABCDEFLL, 28, 0x789ABCDEF0000000LL },
25*6bba2ae4SDmitry Antipov 	{ 0x0123456789ABCDEFLL, 29, 0xF13579BDE0000000LL },
26*6bba2ae4SDmitry Antipov 	{ 0x0123456789ABCDEFLL, 30, 0xE26AF37BC0000000LL },
27*6bba2ae4SDmitry Antipov 	{ 0x0123456789ABCDEFLL, 31, 0xC4D5E6F780000000LL },
28*6bba2ae4SDmitry Antipov 	{ 0x0123456789ABCDEFLL, 32, 0x89ABCDEF00000000LL },
29*6bba2ae4SDmitry Antipov 	{ 0x0123456789ABCDEFLL, 33, 0x13579BDE00000000LL },
30*6bba2ae4SDmitry Antipov 	{ 0x0123456789ABCDEFLL, 34, 0x26AF37BC00000000LL },
31*6bba2ae4SDmitry Antipov 	{ 0x0123456789ABCDEFLL, 35, 0x4D5E6F7800000000LL },
32*6bba2ae4SDmitry Antipov 	{ 0x0123456789ABCDEFLL, 36, 0x9ABCDEF000000000LL },
33*6bba2ae4SDmitry Antipov 	{ 0x0123456789ABCDEFLL, 60, 0xF000000000000000LL },
34*6bba2ae4SDmitry Antipov 	{ 0x0123456789ABCDEFLL, 61, 0xE000000000000000LL },
35*6bba2ae4SDmitry Antipov 	{ 0x0123456789ABCDEFLL, 62, 0xC000000000000000LL },
36*6bba2ae4SDmitry Antipov 	{ 0x0123456789ABCDEFLL, 63, 0x8000000000000000LL },
37*6bba2ae4SDmitry Antipov };
38*6bba2ae4SDmitry Antipov 
39*6bba2ae4SDmitry Antipov static void shdi3_test_ashldi3(struct kunit *test)
40*6bba2ae4SDmitry Antipov {
41*6bba2ae4SDmitry Antipov 	const struct shdi3_test_entry *e;
42*6bba2ae4SDmitry Antipov 	long long ret;
43*6bba2ae4SDmitry Antipov 
44*6bba2ae4SDmitry Antipov 	for (e = ashldi3_testdata;
45*6bba2ae4SDmitry Antipov 	     e < ashldi3_testdata + ARRAY_SIZE(ashldi3_testdata); e++) {
46*6bba2ae4SDmitry Antipov 		ret = __ashldi3(e->input, e->shift);
47*6bba2ae4SDmitry Antipov 		KUNIT_EXPECT_EQ_MSG(test, ret, e->result,
48*6bba2ae4SDmitry Antipov 				    "    when evaluating __ashldi3(%lld, %d)",
49*6bba2ae4SDmitry Antipov 				    e->input, e->shift);
50*6bba2ae4SDmitry Antipov 	}
51*6bba2ae4SDmitry Antipov }
52*6bba2ae4SDmitry Antipov 
53*6bba2ae4SDmitry Antipov static const struct shdi3_test_entry ashrdi3_testdata[] = {
54*6bba2ae4SDmitry Antipov 	/* https://github.com/llvm/llvm-project/compiler-rt/test/builtins/Unit/ashrdi3_test.c */
55*6bba2ae4SDmitry Antipov 	{ 0x0123456789ABCDEFLL, 0, 0x123456789ABCDEFLL },
56*6bba2ae4SDmitry Antipov 	{ 0x0123456789ABCDEFLL, 1, 0x91A2B3C4D5E6F7LL },
57*6bba2ae4SDmitry Antipov 	{ 0x0123456789ABCDEFLL, 2, 0x48D159E26AF37BLL },
58*6bba2ae4SDmitry Antipov 	{ 0x0123456789ABCDEFLL, 3, 0x2468ACF13579BDLL },
59*6bba2ae4SDmitry Antipov 	{ 0x0123456789ABCDEFLL, 4, 0x123456789ABCDELL },
60*6bba2ae4SDmitry Antipov 	{ 0x0123456789ABCDEFLL, 28, 0x12345678LL },
61*6bba2ae4SDmitry Antipov 	{ 0x0123456789ABCDEFLL, 29, 0x91A2B3CLL },
62*6bba2ae4SDmitry Antipov 	{ 0x0123456789ABCDEFLL, 30, 0x48D159ELL },
63*6bba2ae4SDmitry Antipov 	{ 0x0123456789ABCDEFLL, 31, 0x2468ACFLL },
64*6bba2ae4SDmitry Antipov 	{ 0x0123456789ABCDEFLL, 32, 0x1234567LL },
65*6bba2ae4SDmitry Antipov 	{ 0x0123456789ABCDEFLL, 33, 0x91A2B3LL },
66*6bba2ae4SDmitry Antipov 	{ 0x0123456789ABCDEFLL, 34, 0x48D159LL },
67*6bba2ae4SDmitry Antipov 	{ 0x0123456789ABCDEFLL, 35, 0x2468ACLL },
68*6bba2ae4SDmitry Antipov 	{ 0x0123456789ABCDEFLL, 36, 0x123456LL },
69*6bba2ae4SDmitry Antipov 	{ 0x0123456789ABCDEFLL, 60, 0 },
70*6bba2ae4SDmitry Antipov 	{ 0x0123456789ABCDEFLL, 61, 0 },
71*6bba2ae4SDmitry Antipov 	{ 0x0123456789ABCDEFLL, 62, 0 },
72*6bba2ae4SDmitry Antipov 	{ 0x0123456789ABCDEFLL, 63, 0 },
73*6bba2ae4SDmitry Antipov 	{ 0xFEDCBA9876543210LL, 0, 0xFEDCBA9876543210LL },
74*6bba2ae4SDmitry Antipov 	{ 0xFEDCBA9876543210LL, 1, 0xFF6E5D4C3B2A1908LL },
75*6bba2ae4SDmitry Antipov 	{ 0xFEDCBA9876543210LL, 2, 0xFFB72EA61D950C84LL },
76*6bba2ae4SDmitry Antipov 	{ 0xFEDCBA9876543210LL, 3, 0xFFDB97530ECA8642LL },
77*6bba2ae4SDmitry Antipov 	{ 0xFEDCBA9876543210LL, 4, 0xFFEDCBA987654321LL },
78*6bba2ae4SDmitry Antipov 	{ 0xFEDCBA9876543210LL, 28, 0xFFFFFFFFEDCBA987LL },
79*6bba2ae4SDmitry Antipov 	{ 0xFEDCBA9876543210LL, 29, 0xFFFFFFFFF6E5D4C3LL },
80*6bba2ae4SDmitry Antipov 	{ 0xFEDCBA9876543210LL, 30, 0xFFFFFFFFFB72EA61LL },
81*6bba2ae4SDmitry Antipov 	{ 0xFEDCBA9876543210LL, 31, 0xFFFFFFFFFDB97530LL },
82*6bba2ae4SDmitry Antipov 	{ 0xFEDCBA9876543210LL, 32, 0xFFFFFFFFFEDCBA98LL },
83*6bba2ae4SDmitry Antipov 	{ 0xFEDCBA9876543210LL, 33, 0xFFFFFFFFFF6E5D4CLL },
84*6bba2ae4SDmitry Antipov 	{ 0xFEDCBA9876543210LL, 34, 0xFFFFFFFFFFB72EA6LL },
85*6bba2ae4SDmitry Antipov 	{ 0xFEDCBA9876543210LL, 35, 0xFFFFFFFFFFDB9753LL },
86*6bba2ae4SDmitry Antipov 	{ 0xFEDCBA9876543210LL, 36, 0xFFFFFFFFFFEDCBA9LL },
87*6bba2ae4SDmitry Antipov 	{ 0xAEDCBA9876543210LL, 60, 0xFFFFFFFFFFFFFFFALL },
88*6bba2ae4SDmitry Antipov 	{ 0xAEDCBA9876543210LL, 61, 0xFFFFFFFFFFFFFFFDLL },
89*6bba2ae4SDmitry Antipov 	{ 0xAEDCBA9876543210LL, 62, 0xFFFFFFFFFFFFFFFELL },
90*6bba2ae4SDmitry Antipov 	{ 0xAEDCBA9876543210LL, 63, 0xFFFFFFFFFFFFFFFFLL },
91*6bba2ae4SDmitry Antipov };
92*6bba2ae4SDmitry Antipov 
93*6bba2ae4SDmitry Antipov static void shdi3_test_ashrdi3(struct kunit *test)
94*6bba2ae4SDmitry Antipov {
95*6bba2ae4SDmitry Antipov 	const struct shdi3_test_entry *e;
96*6bba2ae4SDmitry Antipov 	long long ret;
97*6bba2ae4SDmitry Antipov 
98*6bba2ae4SDmitry Antipov 	for (e = ashrdi3_testdata;
99*6bba2ae4SDmitry Antipov 	     e < ashrdi3_testdata + ARRAY_SIZE(ashrdi3_testdata); e++) {
100*6bba2ae4SDmitry Antipov 		ret = __ashrdi3(e->input, e->shift);
101*6bba2ae4SDmitry Antipov 		KUNIT_EXPECT_EQ_MSG(test, ret, e->result,
102*6bba2ae4SDmitry Antipov 				    "    when evaluating __ashrdi3(%lld, %d)",
103*6bba2ae4SDmitry Antipov 				    e->input, e->shift);
104*6bba2ae4SDmitry Antipov 	}
105*6bba2ae4SDmitry Antipov }
106*6bba2ae4SDmitry Antipov 
107*6bba2ae4SDmitry Antipov static const struct shdi3_test_entry lshrdi3_testdata[] = {
108*6bba2ae4SDmitry Antipov 	/* https://github.com/llvm/llvm-project/compiler-rt/test/builtins/Unit/lshrdi3_test.c */
109*6bba2ae4SDmitry Antipov 	{ 0x0123456789ABCDEFLL, 0, 0x123456789ABCDEFLL },
110*6bba2ae4SDmitry Antipov 	{ 0x0123456789ABCDEFLL, 1, 0x91A2B3C4D5E6F7LL },
111*6bba2ae4SDmitry Antipov 	{ 0x0123456789ABCDEFLL, 2, 0x48D159E26AF37BLL },
112*6bba2ae4SDmitry Antipov 	{ 0x0123456789ABCDEFLL, 3, 0x2468ACF13579BDLL },
113*6bba2ae4SDmitry Antipov 	{ 0x0123456789ABCDEFLL, 4, 0x123456789ABCDELL },
114*6bba2ae4SDmitry Antipov 	{ 0x0123456789ABCDEFLL, 28, 0x12345678LL },
115*6bba2ae4SDmitry Antipov 	{ 0x0123456789ABCDEFLL, 29, 0x91A2B3CLL },
116*6bba2ae4SDmitry Antipov 	{ 0x0123456789ABCDEFLL, 30, 0x48D159ELL },
117*6bba2ae4SDmitry Antipov 	{ 0x0123456789ABCDEFLL, 31, 0x2468ACFLL },
118*6bba2ae4SDmitry Antipov 	{ 0x0123456789ABCDEFLL, 32, 0x1234567LL },
119*6bba2ae4SDmitry Antipov 	{ 0x0123456789ABCDEFLL, 33, 0x91A2B3LL },
120*6bba2ae4SDmitry Antipov 	{ 0x0123456789ABCDEFLL, 34, 0x48D159LL },
121*6bba2ae4SDmitry Antipov 	{ 0x0123456789ABCDEFLL, 35, 0x2468ACLL },
122*6bba2ae4SDmitry Antipov 	{ 0x0123456789ABCDEFLL, 36, 0x123456LL },
123*6bba2ae4SDmitry Antipov 	{ 0x0123456789ABCDEFLL, 60, 0 },
124*6bba2ae4SDmitry Antipov 	{ 0x0123456789ABCDEFLL, 61, 0 },
125*6bba2ae4SDmitry Antipov 	{ 0x0123456789ABCDEFLL, 62, 0 },
126*6bba2ae4SDmitry Antipov 	{ 0x0123456789ABCDEFLL, 63, 0 },
127*6bba2ae4SDmitry Antipov 	{ 0xFEDCBA9876543210LL, 0, 0xFEDCBA9876543210LL },
128*6bba2ae4SDmitry Antipov 	{ 0xFEDCBA9876543210LL, 1, 0x7F6E5D4C3B2A1908LL },
129*6bba2ae4SDmitry Antipov 	{ 0xFEDCBA9876543210LL, 2, 0x3FB72EA61D950C84LL },
130*6bba2ae4SDmitry Antipov 	{ 0xFEDCBA9876543210LL, 3, 0x1FDB97530ECA8642LL },
131*6bba2ae4SDmitry Antipov 	{ 0xFEDCBA9876543210LL, 4, 0xFEDCBA987654321LL },
132*6bba2ae4SDmitry Antipov 	{ 0xFEDCBA9876543210LL, 28, 0xFEDCBA987LL },
133*6bba2ae4SDmitry Antipov 	{ 0xFEDCBA9876543210LL, 29, 0x7F6E5D4C3LL },
134*6bba2ae4SDmitry Antipov 	{ 0xFEDCBA9876543210LL, 30, 0x3FB72EA61LL },
135*6bba2ae4SDmitry Antipov 	{ 0xFEDCBA9876543210LL, 31, 0x1FDB97530LL },
136*6bba2ae4SDmitry Antipov 	{ 0xFEDCBA9876543210LL, 32, 0xFEDCBA98LL },
137*6bba2ae4SDmitry Antipov 	{ 0xFEDCBA9876543210LL, 33, 0x7F6E5D4CLL },
138*6bba2ae4SDmitry Antipov 	{ 0xFEDCBA9876543210LL, 34, 0x3FB72EA6LL },
139*6bba2ae4SDmitry Antipov 	{ 0xFEDCBA9876543210LL, 35, 0x1FDB9753LL },
140*6bba2ae4SDmitry Antipov 	{ 0xFEDCBA9876543210LL, 36, 0xFEDCBA9LL },
141*6bba2ae4SDmitry Antipov 	{ 0xAEDCBA9876543210LL, 60, 0xALL },
142*6bba2ae4SDmitry Antipov 	{ 0xAEDCBA9876543210LL, 61, 0x5LL },
143*6bba2ae4SDmitry Antipov 	{ 0xAEDCBA9876543210LL, 62, 0x2LL },
144*6bba2ae4SDmitry Antipov 	{ 0xAEDCBA9876543210LL, 63, 0x1LL },
145*6bba2ae4SDmitry Antipov };
146*6bba2ae4SDmitry Antipov 
147*6bba2ae4SDmitry Antipov static void shdi3_test_lshrdi3(struct kunit *test)
148*6bba2ae4SDmitry Antipov {
149*6bba2ae4SDmitry Antipov 	const struct shdi3_test_entry *e;
150*6bba2ae4SDmitry Antipov 	long long ret;
151*6bba2ae4SDmitry Antipov 
152*6bba2ae4SDmitry Antipov 	for (e = lshrdi3_testdata;
153*6bba2ae4SDmitry Antipov 	     e < lshrdi3_testdata + ARRAY_SIZE(lshrdi3_testdata); e++) {
154*6bba2ae4SDmitry Antipov 		ret = __lshrdi3(e->input, e->shift);
155*6bba2ae4SDmitry Antipov 		KUNIT_EXPECT_EQ_MSG(test, ret, e->result,
156*6bba2ae4SDmitry Antipov 				    "    when evaluating __lshrdi3(%lld, %d)",
157*6bba2ae4SDmitry Antipov 				    e->input, e->shift);
158*6bba2ae4SDmitry Antipov 	}
159*6bba2ae4SDmitry Antipov }
160*6bba2ae4SDmitry Antipov 
161*6bba2ae4SDmitry Antipov static struct kunit_case shdi3_test_cases[] = {
162*6bba2ae4SDmitry Antipov 	KUNIT_CASE(shdi3_test_ashldi3),
163*6bba2ae4SDmitry Antipov 	KUNIT_CASE(shdi3_test_ashrdi3),
164*6bba2ae4SDmitry Antipov 	KUNIT_CASE(shdi3_test_lshrdi3),
165*6bba2ae4SDmitry Antipov 	{}
166*6bba2ae4SDmitry Antipov };
167*6bba2ae4SDmitry Antipov 
168*6bba2ae4SDmitry Antipov static struct kunit_suite shdi3_test_suite = {
169*6bba2ae4SDmitry Antipov 	.name = "shdi3",
170*6bba2ae4SDmitry Antipov 	.test_cases = shdi3_test_cases,
171*6bba2ae4SDmitry Antipov };
172*6bba2ae4SDmitry Antipov kunit_test_suite(shdi3_test_suite);
173*6bba2ae4SDmitry Antipov 
174*6bba2ae4SDmitry Antipov MODULE_DESCRIPTION("Test cases for __ashldi3(), __ashrdi3(), and __lshrdi3()");
175*6bba2ae4SDmitry Antipov MODULE_LICENSE("GPL");
176