annotate gcc/testsuite/jit.dg/test-pr66779.c @ 158:494b0b89df80 default tip

...
author Shinji KONO <kono@ie.u-ryukyu.ac.jp>
date Mon, 25 May 2020 18:13:55 +0900
parents 04ced10e8804
children
Ignore whitespace changes - Everywhere: Within whitespace: At end of lines:
rev   line source
111
kono
parents:
diff changeset
1 #include <stdlib.h>
kono
parents:
diff changeset
2 #include <stdio.h>
kono
parents:
diff changeset
3
kono
parents:
diff changeset
4 #include "libgccjit.h"
kono
parents:
diff changeset
5
kono
parents:
diff changeset
6 #include "harness.h"
kono
parents:
diff changeset
7
kono
parents:
diff changeset
8 /* Reproducer for PR jit/66779.
kono
parents:
diff changeset
9
kono
parents:
diff changeset
10 Inject the equivalent of:
kono
parents:
diff changeset
11 T FUNCNAME (T i, T j, T k)
kono
parents:
diff changeset
12 {
kono
parents:
diff changeset
13 bool comp0 = i & 0x40;
kono
parents:
diff changeset
14 bool comp1 = (j == k);
kono
parents:
diff changeset
15 if (comp0 && comp1)
kono
parents:
diff changeset
16 return 7;
kono
parents:
diff changeset
17 else
kono
parents:
diff changeset
18 return 22;
kono
parents:
diff changeset
19 }
kono
parents:
diff changeset
20 for some type T; this was segfaulting during the expansion to RTL
kono
parents:
diff changeset
21 due to missing handling for some machine modes in
kono
parents:
diff changeset
22 jit_langhook_type_for_mode. */
kono
parents:
diff changeset
23
kono
parents:
diff changeset
24 void
kono
parents:
diff changeset
25 create_fn (gcc_jit_context *ctxt,
kono
parents:
diff changeset
26 const char *funcname,
kono
parents:
diff changeset
27 enum gcc_jit_types jit_type)
kono
parents:
diff changeset
28 {
kono
parents:
diff changeset
29 gcc_jit_type *the_type =
kono
parents:
diff changeset
30 gcc_jit_context_get_type (ctxt, jit_type);
kono
parents:
diff changeset
31 gcc_jit_type *t_bool =
kono
parents:
diff changeset
32 gcc_jit_context_get_type (ctxt, GCC_JIT_TYPE_BOOL);
kono
parents:
diff changeset
33 gcc_jit_param *param_i =
kono
parents:
diff changeset
34 gcc_jit_context_new_param (ctxt, NULL, the_type, "i");
kono
parents:
diff changeset
35 gcc_jit_param *param_j =
kono
parents:
diff changeset
36 gcc_jit_context_new_param (ctxt, NULL, the_type, "j");
kono
parents:
diff changeset
37 gcc_jit_param *param_k =
kono
parents:
diff changeset
38 gcc_jit_context_new_param (ctxt, NULL, the_type, "k");
kono
parents:
diff changeset
39 gcc_jit_param *params[3] = {
kono
parents:
diff changeset
40 param_i,
kono
parents:
diff changeset
41 param_j,
kono
parents:
diff changeset
42 param_k
kono
parents:
diff changeset
43 };
kono
parents:
diff changeset
44 gcc_jit_function *func =
kono
parents:
diff changeset
45 gcc_jit_context_new_function (ctxt, NULL,
kono
parents:
diff changeset
46 GCC_JIT_FUNCTION_EXPORTED,
kono
parents:
diff changeset
47 the_type,
kono
parents:
diff changeset
48 funcname,
kono
parents:
diff changeset
49 3, params,
kono
parents:
diff changeset
50 0);
kono
parents:
diff changeset
51 gcc_jit_block *b_entry = gcc_jit_function_new_block (func, "entry");
kono
parents:
diff changeset
52 gcc_jit_block *b_on_true = gcc_jit_function_new_block (func, "on_true");
kono
parents:
diff changeset
53 gcc_jit_block *b_on_false = gcc_jit_function_new_block (func, "on_false");
kono
parents:
diff changeset
54
kono
parents:
diff changeset
55 gcc_jit_lvalue *comp0 =
kono
parents:
diff changeset
56 gcc_jit_function_new_local (func, NULL, t_bool, "comp0");
kono
parents:
diff changeset
57
kono
parents:
diff changeset
58 gcc_jit_block_add_assignment (
kono
parents:
diff changeset
59 b_entry, NULL,
kono
parents:
diff changeset
60 comp0,
kono
parents:
diff changeset
61 gcc_jit_context_new_comparison (
kono
parents:
diff changeset
62 ctxt, NULL,
kono
parents:
diff changeset
63 GCC_JIT_COMPARISON_NE,
kono
parents:
diff changeset
64 gcc_jit_context_new_binary_op (
kono
parents:
diff changeset
65 ctxt, NULL,
kono
parents:
diff changeset
66 GCC_JIT_BINARY_OP_BITWISE_AND,
kono
parents:
diff changeset
67 the_type,
kono
parents:
diff changeset
68 gcc_jit_param_as_rvalue (param_i),
kono
parents:
diff changeset
69 gcc_jit_context_new_rvalue_from_int (ctxt, the_type, 0x40)),
kono
parents:
diff changeset
70 gcc_jit_context_zero (ctxt, the_type)));
kono
parents:
diff changeset
71
kono
parents:
diff changeset
72 gcc_jit_lvalue *comp1 =
kono
parents:
diff changeset
73 gcc_jit_function_new_local (func, NULL, t_bool, "comp1");
kono
parents:
diff changeset
74
kono
parents:
diff changeset
75 gcc_jit_block_add_assignment (
kono
parents:
diff changeset
76 b_entry, NULL,
kono
parents:
diff changeset
77 comp1,
kono
parents:
diff changeset
78 gcc_jit_context_new_comparison (ctxt, NULL,
kono
parents:
diff changeset
79 GCC_JIT_COMPARISON_EQ,
kono
parents:
diff changeset
80 gcc_jit_param_as_rvalue (param_j),
kono
parents:
diff changeset
81 gcc_jit_param_as_rvalue (param_k)));
kono
parents:
diff changeset
82
kono
parents:
diff changeset
83 gcc_jit_rvalue *cond =
kono
parents:
diff changeset
84 gcc_jit_context_new_binary_op (ctxt, NULL,
kono
parents:
diff changeset
85 GCC_JIT_BINARY_OP_LOGICAL_AND,
kono
parents:
diff changeset
86 t_bool,
kono
parents:
diff changeset
87 gcc_jit_lvalue_as_rvalue (comp0),
kono
parents:
diff changeset
88 gcc_jit_lvalue_as_rvalue (comp1));
kono
parents:
diff changeset
89
kono
parents:
diff changeset
90 gcc_jit_block_end_with_conditional (b_entry, NULL,
kono
parents:
diff changeset
91 cond,
kono
parents:
diff changeset
92 b_on_true,
kono
parents:
diff changeset
93 b_on_false);
kono
parents:
diff changeset
94
kono
parents:
diff changeset
95 gcc_jit_block_end_with_return (
kono
parents:
diff changeset
96 b_on_true, NULL,
kono
parents:
diff changeset
97 gcc_jit_context_new_rvalue_from_int (ctxt, the_type, 7));
kono
parents:
diff changeset
98
kono
parents:
diff changeset
99 gcc_jit_block_end_with_return (
kono
parents:
diff changeset
100 b_on_false, NULL,
kono
parents:
diff changeset
101 gcc_jit_context_new_rvalue_from_int (ctxt, the_type, 22));
kono
parents:
diff changeset
102 }
kono
parents:
diff changeset
103
kono
parents:
diff changeset
104 void
kono
parents:
diff changeset
105 create_code (gcc_jit_context *ctxt, void *user_data)
kono
parents:
diff changeset
106 {
kono
parents:
diff changeset
107 create_fn (ctxt, "pr66779_signed_char", GCC_JIT_TYPE_SIGNED_CHAR);
kono
parents:
diff changeset
108 create_fn (ctxt, "pr66779_unsigned_char", GCC_JIT_TYPE_UNSIGNED_CHAR);
kono
parents:
diff changeset
109
kono
parents:
diff changeset
110 create_fn (ctxt, "pr66779_short", GCC_JIT_TYPE_SHORT);
kono
parents:
diff changeset
111 create_fn (ctxt, "pr66779_unsigned_short", GCC_JIT_TYPE_UNSIGNED_SHORT);
kono
parents:
diff changeset
112
kono
parents:
diff changeset
113 create_fn (ctxt, "pr66779_int", GCC_JIT_TYPE_INT);
kono
parents:
diff changeset
114 create_fn (ctxt, "pr66779_unsigned_int", GCC_JIT_TYPE_UNSIGNED_INT);
kono
parents:
diff changeset
115
kono
parents:
diff changeset
116 create_fn (ctxt, "pr66779_long", GCC_JIT_TYPE_LONG);
kono
parents:
diff changeset
117 create_fn (ctxt, "pr66779_unsigned_long", GCC_JIT_TYPE_UNSIGNED_LONG);
kono
parents:
diff changeset
118
kono
parents:
diff changeset
119 create_fn (ctxt, "pr66779_long_long",
kono
parents:
diff changeset
120 GCC_JIT_TYPE_LONG_LONG);
kono
parents:
diff changeset
121 create_fn (ctxt, "pr66779_unsigned_long_long",
kono
parents:
diff changeset
122 GCC_JIT_TYPE_UNSIGNED_LONG_LONG);
kono
parents:
diff changeset
123
kono
parents:
diff changeset
124 create_fn (ctxt, "pr66779_size_t", GCC_JIT_TYPE_SIZE_T);
kono
parents:
diff changeset
125 }
kono
parents:
diff changeset
126
kono
parents:
diff changeset
127 extern void
kono
parents:
diff changeset
128 verify_code (gcc_jit_context *ctxt, gcc_jit_result *result)
kono
parents:
diff changeset
129 {
kono
parents:
diff changeset
130 typedef int (*fn_type) (int, int, int);
kono
parents:
diff changeset
131 CHECK_NON_NULL (result);
kono
parents:
diff changeset
132 /* Sanity-check the "int" case. */
kono
parents:
diff changeset
133 fn_type fn =
kono
parents:
diff changeset
134 (fn_type)gcc_jit_result_get_code (result, "pr66779_int");
kono
parents:
diff changeset
135 CHECK_NON_NULL (fn);
kono
parents:
diff changeset
136 CHECK_VALUE (fn (0, 0, 0), 22);
kono
parents:
diff changeset
137 CHECK_VALUE (fn (0, 0, 1), 22);
kono
parents:
diff changeset
138 CHECK_VALUE (fn (0x40, 0, 0), 7);
kono
parents:
diff changeset
139 CHECK_VALUE (fn (0x40, 0, 1), 22);
kono
parents:
diff changeset
140 CHECK_VALUE (fn (0x40, 1, 1), 7);
kono
parents:
diff changeset
141 CHECK_VALUE (fn (0x3f, 0, 0), 22);
kono
parents:
diff changeset
142 CHECK_VALUE (fn (0x3f, 1, 1), 22);
kono
parents:
diff changeset
143 }