2 using System.Reflection;
5 * Regression tests for the mono JIT.
7 * Each test needs to be of the form:
9 * static int test_<result>_<name> ();
11 * where <result> is an integer (the value that needs to be returned by
12 * the method to make it pass.
13 * <name> is a user-displayed name used to identify the test.
15 * The tests can be driven in two ways:
16 * *) running the program directly: Main() uses reflection to find and invoke
17 * the test methods (this is useful mostly to check that the tests are correct)
18 * *) with the --regression switch of the jit (this is the preferred way since
19 * all the tests will be run with optimizations on and off)
21 * The reflection logic could be moved to a .dll since we need at least another
22 * regression test file written in IL code to have better control on how
29 return TestDriver.RunTests (typeof (Tests));
32 static int test_10_simple_cast () {
37 static int test_1_bigmul1 () {
43 c = (long)a * (long)b;
49 static int test_1_bigmul2 () {
50 int a = System.Int32.MaxValue, b = System.Int32.MaxValue;
51 long s = System.Int64.MinValue;
53 c = s + (long) a * (long) b;
54 if (c == -4611686022722355199)
59 static int test_1_bigmul3 () {
62 c = (ulong) a * (ulong) b;
68 static int test_1_bigmul4 () {
69 int a = System.Int32.MaxValue, b = System.Int32.MaxValue;
71 c = (ulong) a * (ulong) b;
72 if (c == 4611686014132420609)
77 static int test_1_bigmul5 () {
78 int a = System.Int32.MaxValue, b = System.Int32.MinValue;
80 c = (long) a * (long) b;
81 if (c == -4611686016279904256)
86 static int test_1_bigmul6 () {
87 uint a = System.UInt32.MaxValue, b = System.UInt32.MaxValue/(uint)2;
89 c = (ulong) a * (ulong) b;
90 if (c == 9223372030412324865)
95 static int test_0_beq () {
96 long a = 0xffffffffff;
97 if (a != 0xffffffffff)
102 static int test_0_bne_un () {
103 long a = 0xffffffffff;
104 if (a == 0xfffffffffe)
109 static int test_0_ble () {
110 long a = 0xffffffffff;
111 if (a > 0xffffffffff)
116 static int test_0_ble_un () {
117 ulong a = 0xffffffffff;
118 if (a > 0xffffffffff)
123 static int test_0_bge () {
124 long a = 0xffffffffff;
125 if (a < 0xffffffffff)
130 static int test_0_bge_un () {
131 ulong a = 0xffffffffff;
132 if (a < 0xffffffffff)
137 static int test_0_blt () {
138 long a = 0xfffffffffe;
139 if (a >= 0xffffffffff)
144 static int test_0_blt_un () {
145 ulong a = 0xfffffffffe;
146 if (a >= 0xffffffffff)
151 static int test_0_bgt () {
152 long a = 0xffffffffff;
153 if (a <= 0xfffffffffe)
158 static int test_0_conv_to_i4 () {
163 static int test_0_conv_from_i4 () {
175 static int test_0_conv_from_i4_negative () {
188 static int test_0_conv_from_r8 () {
197 static int test_0_conv_from_r4 () {
207 static int test_8_and () {
208 long a = 0xffffffffff;
213 static int test_8_and_imm () {
214 long a = 0xffffffffff;
218 static int test_10_or () {
224 static int test_10_or_imm () {
229 static int test_5_xor () {
235 static int test_5_xor_imm () {
240 static int test_5_add () {
246 static int test_5_add_imm () {
251 static int test_0_add_imm_carry () {
256 static int test_0_add_imm_no_inc () {
257 // we can't blindly convert an add x, 1 to an inc x
258 long a = 0x1ffffffff;
261 if (c == ((a + 1) + 1))
266 static int test_4_addcc_imm () {
269 return (int)(a - b + 1);
272 static int test_5_sub () {
278 static int test_5_sub_imm () {
283 static int test_0_sub_imm_carry () {
285 return (int)((a - 1) + 1);
288 static int test_2_neg () {
293 static int test_0_neg_large () {
294 long min = -9223372036854775808;
296 ulong ul = (ulong)min;
297 return (min == -(long)ul) ? 0 : 1;
301 static int test_0_shl () {
312 static int test_1_rshift ()
322 static int test_5_shift ()
352 static int test_1_simple_neg () {
360 static int test_2_compare () {
369 static int test_9_alu ()
414 static int test_24_mul () {
420 static int test_24_mul_ovf () {
431 static int test_24_mul_un () {
437 static int test_24_mul_ovf_un () {
448 static int test_4_divun () {
454 static int test_1431655764_bigdivun_imm () {
461 static int test_1431655764_bigdivun () {
469 static int test_1_remun () {
475 static int test_2_bigremun () {
483 static int test_0_ceq () {
487 long d = 0xff00000002;
489 bool val = (a == b); // this should produce a ceq
493 val = (a == c); // this should produce a ceq
497 val = (a == d); // this should produce a ceq
504 static int test_0_ceq_complex () {
513 static int test_0_clt () {
517 long d = 0xff00000002L;
520 bool val = (a < b); // this should produce a clt
524 val = (a < c); // this should produce a clt
528 val = (c < a); // this should produce a clt
532 val = (e < d); // this should produce a clt
536 val = (d < e); // this should produce a clt
543 static int test_0_clt_un () {
547 ulong d = 0xff00000002;
548 ulong e = 0xffffffffffffffff;
550 bool val = (a < b); // this should produce a clt_un
554 val = (a < c); // this should produce a clt_un
558 val = (d < e); // this should produce a clt_un
562 val = (e < d); // this should produce a clt_un
569 static int test_0_cgt () {
573 long d = 0xff00000002L;
576 bool val = (a > b); // this should produce a cgt
580 val = (a > c); // this should produce a cgt
584 val = (c > a); // this should produce a cgt
588 val = (e > d); // this should produce a cgt
592 val = (d > e); // this should produce a cgt
599 static int test_0_cgt_un () {
603 ulong d = 0xff00000002;
604 ulong e = 0xffffffffffffffff;
606 bool val = (a > b); // this should produce a cgt_un
610 val = (a > c); // this should produce a cgt_un
614 val = (d > e); // this should produce a cgt_un
618 val = (e > d); // this should produce a cgt_un
625 static long return_5low () {
629 static long return_5high () {
633 static int test_3_long_ret () {
634 long val = return_5low ();
635 return (int) (val - 2);
638 static int test_1_long_ret2 () {
639 long val = return_5high ();
640 if (val > 0xffffffff)
645 static int test_3_byte_cast () {
646 ulong val = 0xff00ff00f0f0f0f0;
648 b = (byte) (val & 0xFF);
654 static int test_4_ushort_cast () {
655 ulong val = 0xff00ff00f0f0f0f0;
657 b = (ushort) (val & 0xFFFF);
663 static int test_500_mul_div () {
667 long res = val * exp / maxexp;
672 static long position = 0;
674 static int test_4_static_inc_long () {
682 return (int)position;
685 static void doit (double value, out long m) {
689 static int test_3_checked_cast_un () {
693 checked { j = (long)i; }
700 static int test_4_checked_cast () {
704 checked { j = (ulong)i; }
711 static int test_10_int_uint_compare () {
714 for (int i = 0; i < size; ++i) {
720 static int test_0_ftol_clobber () {
728 static int test_71_long_shift_right () {
729 ulong value = 38654838087;
731 byte [] buffer = new byte [1];
732 buffer [x] = ((byte)(value >> x));
736 static int test_0_ulong_regress () {
737 ulong u = 4257145737;
739 return (u == 4257145736) ? 0 : 1;