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_719177_div_destreg () {
157 return ((365* (year-1)) + ((year-1)/4));
160 static int test_1_remun_imm () {
165 static int test_2_bigremun_imm () {
170 static int test_2_rem () {
176 static int test_4_rem_imm () {
181 static int test_4_rem_big_imm () {
186 static int test_9_mul () {
192 static int test_15_mul_imm () {
197 static int test_24_mul () {
207 static int test_24_mul_ovf () {
219 static int test_24_mul_un () {
229 static int test_24_mul_ovf_un () {
241 static int test_3_or () {
247 static int test_3_or_un () {
253 static int test_3_or_short_un () {
259 static int test_18_or_imm () {
264 static int test_268435458_or_large_imm () {
266 return b | 0x10000000;
269 static int test_268435459_or_large_imm2 () {
271 return b | 0x10000001;
274 static int test_1_xor () {
280 static int test_1_xor_imm () {
285 static int test_983041_xor_imm_large () {
290 static int test_1_neg () {
296 static int test_2_not () {
302 static int test_16_shift () {
308 static int test_16_shift_add () {
315 static int test_16_shift_add2 () {
322 static int test_16_shift_imm () {
327 static int test_524288_shift_imm_large () {
332 static int test_12_shift_imm_inv () {
337 static int test_12_shift_imm_inv_sbyte () {
342 static int test_1_rshift_imm () {
347 static int test_2_unrshift_imm () {
349 return (int)(b >> 3);
352 static int test_0_bigunrshift_imm () {
360 static int test_0_bigrshift_imm () {
368 static int test_1_rshift () {
374 static int test_2_unrshift () {
377 return (int)(b >> a);
380 static int test_0_bigunrshift () {
389 static int test_0_bigrshift () {
398 static int test_2_cond () {
405 static int test_2_cond_short () {
406 short b = 2, a = 3, c;
412 static int test_2_cond_sbyte () {
413 sbyte b = 2, a = 3, c;
419 static int test_6_cascade_cond () {
433 static int test_6_cascade_short () {
434 short b = 2, a = 3, c;
447 static int test_15_for_loop () {
449 for (i = 0; i < 15; ++i) {
454 static int test_11_nested_for_loop () {
455 int i, j = 0; /* mcs bug here if j not set */
456 for (i = 0; i < 15; ++i) {
457 for (j = 200; j >= 5; --j) ;
462 static int test_11_several_nested_for_loops () {
463 int i, j = 0; /* mcs bug here if j not set */
464 for (i = 0; i < 15; ++i) {
465 for (j = 200; j >= 5; --j) ;
468 for (i = 0; i < 15; ++i) {
469 for (j = 200; j >= 5; --j) ;
474 static int test_0_conv_ovf_i1 () {
477 //for (int j = 0; j < 10000000; j++)
488 static int test_0_conv_ovf_i1_un () {
499 static int test_0_conv_ovf_i2 () {
512 static int test_0_conv_ovf_i2_un () {
523 static int test_0_conv_ovf_u2 () {
528 UInt16 b = (UInt16)c;
534 static int test_0_conv_ovf_u2_un () {
539 UInt16 b = (UInt16)c;
545 static int test_0_conv_ovf_u4 () {
556 static int test_0_bool () {
563 static int test_1_bool_inverted () {
570 static int test_1_bool_assign () {
572 val = !val; // this should produce a ceq
578 static int test_1_bool_multi () {
582 if ((val && !val2) && (!val2 && val))
587 static int test_16_spill () {
594 return (1 + (a + (b + (c + (d + e)))));
597 static int test_1_switch () {
611 static int test_0_while_loop_1 () {
617 } while (value != 0);
622 static int test_0_while_loop_2 () {
628 } while (value != 0 && position > 1);
633 static int test_0_char_conv () {
636 char tc = (char) ('0' + i);
644 static int test_3_shift_regalloc () {
649 orig &= ~(0xff << shift);
650 orig |= value << shift;
659 static int test_2_optimize_branches () {
669 static int test_0_checked_byte_cast () {
671 int b = checked ((byte) (v));
678 static int test_0_checked_byte_cast_un () {
680 uint b = checked ((byte) (v));
687 static int test_0_checked_short_cast () {
689 int b = checked ((ushort) (v));
696 static int test_0_checked_short_cast_un () {
698 uint b = checked ((ushort) (v));
705 static int test_0_comp_unsigned () {