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_0_return () {
36 static int test_100000_return_large () {
40 static int test_1_load_bool () {
45 static int test_0_load_bool_false () {
50 static int test_200_load_byte () {
55 static int test_100_load_sbyte () {
60 static int test_200_load_short () {
65 static int test_100_load_ushort () {
70 static int test_3_add_simple () {
76 static int test_3_add_imm () {
81 static int test_13407573_add_largeimm () {
86 static int test_1_sub_simple () {
92 static int test_1_sub_simple_un () {
98 static int test_1_sub_imm () {
103 static int test_2_sub_large_imm () {
108 static int test_0_sub_inv_imm () {
113 static int test_2_and () {
119 static int test_0_and_imm () {
124 static int test_0_and_large_imm () {
126 return b & 0x10000000;
129 static int test_0_and_large_imm2 () {
131 return b & 0x100000f0;
134 static int test_2_div () {
140 static int test_4_div_imm () {
145 static int test_4_divun_imm () {
150 static int test_0_div_fold () {
155 static int test_1_remun_imm () {
160 static int test_2_bigremun_imm () {
165 static int test_2_rem () {
171 static int test_4_rem_imm () {
176 static int test_9_mul () {
182 static int test_15_mul_imm () {
187 static int test_24_mul () {
197 static int test_24_mul_ovf () {
209 static int test_24_mul_un () {
219 static int test_24_mul_ovf_un () {
231 static int test_3_or () {
237 static int test_3_or_un () {
243 static int test_3_or_short_un () {
249 static int test_18_or_imm () {
254 static int test_268435458_or_large_imm () {
256 return b | 0x10000000;
259 static int test_268435459_or_large_imm2 () {
261 return b | 0x10000001;
264 static int test_1_xor () {
270 static int test_1_xor_imm () {
275 static int test_983041_xor_imm_large () {
280 static int test_1_neg () {
286 static int test_2_not () {
292 static int test_16_shift () {
298 static int test_16_shift_add () {
305 static int test_16_shift_add2 () {
312 static int test_16_shift_imm () {
317 static int test_12_shift_imm_inv () {
322 static int test_12_shift_imm_inv_sbyte () {
327 static int test_1_rshift_imm () {
332 static int test_2_unrshift_imm () {
334 return (int)(b >> 3);
337 static int test_0_bigunrshift_imm () {
345 static int test_0_bigrshift_imm () {
353 static int test_1_rshift () {
359 static int test_2_unrshift () {
362 return (int)(b >> a);
365 static int test_0_bigunrshift () {
374 static int test_0_bigrshift () {
383 static int test_2_cond () {
390 static int test_2_cond_short () {
391 short b = 2, a = 3, c;
397 static int test_2_cond_sbyte () {
398 sbyte b = 2, a = 3, c;
404 static int test_6_cascade_cond () {
418 static int test_6_cascade_short () {
419 short b = 2, a = 3, c;
432 static int test_15_for_loop () {
434 for (i = 0; i < 15; ++i) {
439 static int test_11_nested_for_loop () {
440 int i, j = 0; /* mcs bug here if j not set */
441 for (i = 0; i < 15; ++i) {
442 for (j = 200; j >= 5; --j) ;
447 static int test_11_several_nested_for_loops () {
448 int i, j = 0; /* mcs bug here if j not set */
449 for (i = 0; i < 15; ++i) {
450 for (j = 200; j >= 5; --j) ;
453 for (i = 0; i < 15; ++i) {
454 for (j = 200; j >= 5; --j) ;
459 static int test_0_conv_ovf_i1 () {
462 //for (int j = 0; j < 10000000; j++)
473 static int test_0_conv_ovf_i1_un () {
484 static int test_0_conv_ovf_i2 () {
497 static int test_0_conv_ovf_i2_un () {
508 static int test_0_conv_ovf_u2 () {
513 UInt16 b = (UInt16)c;
519 static int test_0_conv_ovf_u2_un () {
524 UInt16 b = (UInt16)c;
530 static int test_0_conv_ovf_u4 () {
541 static int test_0_bool () {
548 static int test_1_bool_inverted () {
555 static int test_1_bool_assign () {
557 val = !val; // this should produce a ceq
563 static int test_1_bool_multi () {
567 if ((val && !val2) && (!val2 && val))
572 static int test_16_spill () {
579 return (1 + (a + (b + (c + (d + e)))));
582 static int test_1_switch () {
596 static int test_0_while_loop_1 () {
602 } while (value != 0);
607 static int test_0_while_loop_2 () {
613 } while (value != 0 && position > 1);
618 static int test_0_char_conv () {
621 char tc = (char) ('0' + i);
629 static int test_3_shift_regalloc () {
634 orig &= ~(0xff << shift);
635 orig |= value << shift;
644 static int test_2_optimize_branches () {
654 static int test_0_checked_byte_cast () {
656 int b = checked ((byte) (v));
663 static int test_0_checked_byte_cast_un () {
665 uint b = checked ((byte) (v));
672 static int test_0_checked_short_cast () {
674 int b = checked ((ushort) (v));
681 static int test_0_checked_short_cast_un () {
683 uint b = checked ((ushort) (v));