annotate gcc/config/gcn/predicates.md @ 158:494b0b89df80 default tip

...
author Shinji KONO <kono@ie.u-ryukyu.ac.jp>
date Mon, 25 May 2020 18:13:55 +0900
parents 1830386684a0
children
Ignore whitespace changes - Everywhere: Within whitespace: At end of lines:
rev   line source
145
1830386684a0 gcc-9.2.0
anatofuz
parents:
diff changeset
1 ;; Predicate definitions for GCN.
1830386684a0 gcc-9.2.0
anatofuz
parents:
diff changeset
2 ;; Copyright (C) 2016-2020 Free Software Foundation, Inc.
1830386684a0 gcc-9.2.0
anatofuz
parents:
diff changeset
3 ;;
1830386684a0 gcc-9.2.0
anatofuz
parents:
diff changeset
4 ;; This file is part of GCC.
1830386684a0 gcc-9.2.0
anatofuz
parents:
diff changeset
5 ;;
1830386684a0 gcc-9.2.0
anatofuz
parents:
diff changeset
6 ;; GCC is free software; you can redistribute it and/or modify
1830386684a0 gcc-9.2.0
anatofuz
parents:
diff changeset
7 ;; it under the terms of the GNU General Public License as published by
1830386684a0 gcc-9.2.0
anatofuz
parents:
diff changeset
8 ;; the Free Software Foundation; either version 3, or (at your option)
1830386684a0 gcc-9.2.0
anatofuz
parents:
diff changeset
9 ;; any later version.
1830386684a0 gcc-9.2.0
anatofuz
parents:
diff changeset
10 ;;
1830386684a0 gcc-9.2.0
anatofuz
parents:
diff changeset
11 ;; GCC is distributed in the hope that it will be useful,
1830386684a0 gcc-9.2.0
anatofuz
parents:
diff changeset
12 ;; but WITHOUT ANY WARRANTY; without even the implied warranty of
1830386684a0 gcc-9.2.0
anatofuz
parents:
diff changeset
13 ;; MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
1830386684a0 gcc-9.2.0
anatofuz
parents:
diff changeset
14 ;; GNU General Public License for more details.
1830386684a0 gcc-9.2.0
anatofuz
parents:
diff changeset
15 ;;
1830386684a0 gcc-9.2.0
anatofuz
parents:
diff changeset
16 ;; You should have received a copy of the GNU General Public License
1830386684a0 gcc-9.2.0
anatofuz
parents:
diff changeset
17 ;; along with GCC; see the file COPYING3. If not see
1830386684a0 gcc-9.2.0
anatofuz
parents:
diff changeset
18 ;; <http://www.gnu.org/licenses/>.
1830386684a0 gcc-9.2.0
anatofuz
parents:
diff changeset
19 ;; Return true if VALUE can be stored in a sign extended immediate field.
1830386684a0 gcc-9.2.0
anatofuz
parents:
diff changeset
20
1830386684a0 gcc-9.2.0
anatofuz
parents:
diff changeset
21 (define_predicate "gcn_conditional_register_operand"
1830386684a0 gcc-9.2.0
anatofuz
parents:
diff changeset
22 (match_operand 0 "register_operand")
1830386684a0 gcc-9.2.0
anatofuz
parents:
diff changeset
23 {
1830386684a0 gcc-9.2.0
anatofuz
parents:
diff changeset
24 if (GET_CODE (op) == SUBREG)
1830386684a0 gcc-9.2.0
anatofuz
parents:
diff changeset
25 op = SUBREG_REG (op);
1830386684a0 gcc-9.2.0
anatofuz
parents:
diff changeset
26
1830386684a0 gcc-9.2.0
anatofuz
parents:
diff changeset
27 if (!REG_P (op) || GET_MODE (op) != BImode)
1830386684a0 gcc-9.2.0
anatofuz
parents:
diff changeset
28 return 0;
1830386684a0 gcc-9.2.0
anatofuz
parents:
diff changeset
29
1830386684a0 gcc-9.2.0
anatofuz
parents:
diff changeset
30 return REGNO (op) == VCCZ_REG
1830386684a0 gcc-9.2.0
anatofuz
parents:
diff changeset
31 || REGNO (op) == VCC_REG /* Implied VCCZ. */
1830386684a0 gcc-9.2.0
anatofuz
parents:
diff changeset
32 || REGNO (op) == SCC_REG
1830386684a0 gcc-9.2.0
anatofuz
parents:
diff changeset
33 || REGNO (op) == EXECZ_REG
1830386684a0 gcc-9.2.0
anatofuz
parents:
diff changeset
34 || REGNO (op) >= FIRST_PSEUDO_REGISTER;
1830386684a0 gcc-9.2.0
anatofuz
parents:
diff changeset
35 })
1830386684a0 gcc-9.2.0
anatofuz
parents:
diff changeset
36
1830386684a0 gcc-9.2.0
anatofuz
parents:
diff changeset
37 (define_predicate "gcn_ssrc_register_operand"
1830386684a0 gcc-9.2.0
anatofuz
parents:
diff changeset
38 (match_operand 0 "register_operand")
1830386684a0 gcc-9.2.0
anatofuz
parents:
diff changeset
39 {
1830386684a0 gcc-9.2.0
anatofuz
parents:
diff changeset
40 if (GET_CODE (op) == SUBREG)
1830386684a0 gcc-9.2.0
anatofuz
parents:
diff changeset
41 op = SUBREG_REG (op);
1830386684a0 gcc-9.2.0
anatofuz
parents:
diff changeset
42
1830386684a0 gcc-9.2.0
anatofuz
parents:
diff changeset
43 if (!REG_P (op))
1830386684a0 gcc-9.2.0
anatofuz
parents:
diff changeset
44 return false;
1830386684a0 gcc-9.2.0
anatofuz
parents:
diff changeset
45
1830386684a0 gcc-9.2.0
anatofuz
parents:
diff changeset
46 return SSRC_REGNO_P (REGNO (op)) || REGNO (op) >= FIRST_PSEUDO_REGISTER;
1830386684a0 gcc-9.2.0
anatofuz
parents:
diff changeset
47 })
1830386684a0 gcc-9.2.0
anatofuz
parents:
diff changeset
48
1830386684a0 gcc-9.2.0
anatofuz
parents:
diff changeset
49 (define_predicate "gcn_sdst_register_operand"
1830386684a0 gcc-9.2.0
anatofuz
parents:
diff changeset
50 (match_operand 0 "register_operand")
1830386684a0 gcc-9.2.0
anatofuz
parents:
diff changeset
51 {
1830386684a0 gcc-9.2.0
anatofuz
parents:
diff changeset
52 if (GET_CODE (op) == SUBREG)
1830386684a0 gcc-9.2.0
anatofuz
parents:
diff changeset
53 op = SUBREG_REG (op);
1830386684a0 gcc-9.2.0
anatofuz
parents:
diff changeset
54
1830386684a0 gcc-9.2.0
anatofuz
parents:
diff changeset
55 if (!REG_P (op))
1830386684a0 gcc-9.2.0
anatofuz
parents:
diff changeset
56 return false;
1830386684a0 gcc-9.2.0
anatofuz
parents:
diff changeset
57
1830386684a0 gcc-9.2.0
anatofuz
parents:
diff changeset
58 return SDST_REGNO_P (REGNO (op)) || REGNO (op) >= FIRST_PSEUDO_REGISTER;
1830386684a0 gcc-9.2.0
anatofuz
parents:
diff changeset
59 })
1830386684a0 gcc-9.2.0
anatofuz
parents:
diff changeset
60
1830386684a0 gcc-9.2.0
anatofuz
parents:
diff changeset
61 (define_predicate "gcn_vgpr_register_operand"
1830386684a0 gcc-9.2.0
anatofuz
parents:
diff changeset
62 (match_operand 0 "register_operand")
1830386684a0 gcc-9.2.0
anatofuz
parents:
diff changeset
63 {
1830386684a0 gcc-9.2.0
anatofuz
parents:
diff changeset
64 if (GET_CODE (op) == SUBREG)
1830386684a0 gcc-9.2.0
anatofuz
parents:
diff changeset
65 op = SUBREG_REG (op);
1830386684a0 gcc-9.2.0
anatofuz
parents:
diff changeset
66
1830386684a0 gcc-9.2.0
anatofuz
parents:
diff changeset
67 if (!REG_P (op))
1830386684a0 gcc-9.2.0
anatofuz
parents:
diff changeset
68 return false;
1830386684a0 gcc-9.2.0
anatofuz
parents:
diff changeset
69
1830386684a0 gcc-9.2.0
anatofuz
parents:
diff changeset
70 return VGPR_REGNO_P (REGNO (op)) || REGNO (op) >= FIRST_PSEUDO_REGISTER;
1830386684a0 gcc-9.2.0
anatofuz
parents:
diff changeset
71 })
1830386684a0 gcc-9.2.0
anatofuz
parents:
diff changeset
72
1830386684a0 gcc-9.2.0
anatofuz
parents:
diff changeset
73 (define_predicate "gcn_inline_immediate_operand"
1830386684a0 gcc-9.2.0
anatofuz
parents:
diff changeset
74 (match_code "const_int,const_double,const_vector")
1830386684a0 gcc-9.2.0
anatofuz
parents:
diff changeset
75 {
1830386684a0 gcc-9.2.0
anatofuz
parents:
diff changeset
76 return gcn_inline_constant_p (op);
1830386684a0 gcc-9.2.0
anatofuz
parents:
diff changeset
77 })
1830386684a0 gcc-9.2.0
anatofuz
parents:
diff changeset
78
1830386684a0 gcc-9.2.0
anatofuz
parents:
diff changeset
79 (define_predicate "gcn_vop3_operand"
1830386684a0 gcc-9.2.0
anatofuz
parents:
diff changeset
80 (ior (match_operand 0 "gcn_inline_immediate_operand")
1830386684a0 gcc-9.2.0
anatofuz
parents:
diff changeset
81 (match_operand 0 "register_operand")))
1830386684a0 gcc-9.2.0
anatofuz
parents:
diff changeset
82
1830386684a0 gcc-9.2.0
anatofuz
parents:
diff changeset
83 (define_predicate "gcn_vec0_operand"
1830386684a0 gcc-9.2.0
anatofuz
parents:
diff changeset
84 (match_code "const_vector")
1830386684a0 gcc-9.2.0
anatofuz
parents:
diff changeset
85 {
1830386684a0 gcc-9.2.0
anatofuz
parents:
diff changeset
86 return CONST_VECTOR_ELT (op, 0) == const0_rtx && gcn_inline_constant_p (op);
1830386684a0 gcc-9.2.0
anatofuz
parents:
diff changeset
87 })
1830386684a0 gcc-9.2.0
anatofuz
parents:
diff changeset
88
1830386684a0 gcc-9.2.0
anatofuz
parents:
diff changeset
89 (define_predicate "gcn_vec1_operand"
1830386684a0 gcc-9.2.0
anatofuz
parents:
diff changeset
90 (match_code "const_vector")
1830386684a0 gcc-9.2.0
anatofuz
parents:
diff changeset
91 {
1830386684a0 gcc-9.2.0
anatofuz
parents:
diff changeset
92 return CONST_VECTOR_ELT (op, 0) == const1_rtx && gcn_inline_constant_p (op);
1830386684a0 gcc-9.2.0
anatofuz
parents:
diff changeset
93 })
1830386684a0 gcc-9.2.0
anatofuz
parents:
diff changeset
94
1830386684a0 gcc-9.2.0
anatofuz
parents:
diff changeset
95 (define_predicate "gcn_vec1d_operand"
1830386684a0 gcc-9.2.0
anatofuz
parents:
diff changeset
96 (match_code "const_vector")
1830386684a0 gcc-9.2.0
anatofuz
parents:
diff changeset
97 {
1830386684a0 gcc-9.2.0
anatofuz
parents:
diff changeset
98 if (!gcn_inline_constant_p (op))
1830386684a0 gcc-9.2.0
anatofuz
parents:
diff changeset
99 return false;
1830386684a0 gcc-9.2.0
anatofuz
parents:
diff changeset
100
1830386684a0 gcc-9.2.0
anatofuz
parents:
diff changeset
101 rtx elem = CONST_VECTOR_ELT (op, 0);
1830386684a0 gcc-9.2.0
anatofuz
parents:
diff changeset
102 if (!CONST_DOUBLE_P (elem))
1830386684a0 gcc-9.2.0
anatofuz
parents:
diff changeset
103 return false;
1830386684a0 gcc-9.2.0
anatofuz
parents:
diff changeset
104 return real_identical (CONST_DOUBLE_REAL_VALUE (elem), &dconst1);
1830386684a0 gcc-9.2.0
anatofuz
parents:
diff changeset
105 })
1830386684a0 gcc-9.2.0
anatofuz
parents:
diff changeset
106
1830386684a0 gcc-9.2.0
anatofuz
parents:
diff changeset
107 (define_predicate "gcn_const1d_operand"
1830386684a0 gcc-9.2.0
anatofuz
parents:
diff changeset
108 (match_code "const_double")
1830386684a0 gcc-9.2.0
anatofuz
parents:
diff changeset
109 {
1830386684a0 gcc-9.2.0
anatofuz
parents:
diff changeset
110 return gcn_inline_constant_p (op)
1830386684a0 gcc-9.2.0
anatofuz
parents:
diff changeset
111 && real_identical (CONST_DOUBLE_REAL_VALUE (op), &dconst1);
1830386684a0 gcc-9.2.0
anatofuz
parents:
diff changeset
112 })
1830386684a0 gcc-9.2.0
anatofuz
parents:
diff changeset
113
1830386684a0 gcc-9.2.0
anatofuz
parents:
diff changeset
114 (define_predicate "gcn_32bit_immediate_operand"
1830386684a0 gcc-9.2.0
anatofuz
parents:
diff changeset
115 (match_code "const_int,const_double,const_vector,symbol_ref,label_ref")
1830386684a0 gcc-9.2.0
anatofuz
parents:
diff changeset
116 {
1830386684a0 gcc-9.2.0
anatofuz
parents:
diff changeset
117 return gcn_constant_p (op);
1830386684a0 gcc-9.2.0
anatofuz
parents:
diff changeset
118 })
1830386684a0 gcc-9.2.0
anatofuz
parents:
diff changeset
119
1830386684a0 gcc-9.2.0
anatofuz
parents:
diff changeset
120 ; LRA works smoother when exec values are immediate constants
1830386684a0 gcc-9.2.0
anatofuz
parents:
diff changeset
121 ; prior register allocation.
1830386684a0 gcc-9.2.0
anatofuz
parents:
diff changeset
122 (define_predicate "gcn_exec_operand"
1830386684a0 gcc-9.2.0
anatofuz
parents:
diff changeset
123 (ior (match_operand 0 "register_operand")
1830386684a0 gcc-9.2.0
anatofuz
parents:
diff changeset
124 (match_code "const_int")))
1830386684a0 gcc-9.2.0
anatofuz
parents:
diff changeset
125
1830386684a0 gcc-9.2.0
anatofuz
parents:
diff changeset
126 (define_predicate "gcn_exec_reg_operand"
1830386684a0 gcc-9.2.0
anatofuz
parents:
diff changeset
127 (match_operand 0 "register_operand"))
1830386684a0 gcc-9.2.0
anatofuz
parents:
diff changeset
128
1830386684a0 gcc-9.2.0
anatofuz
parents:
diff changeset
129 (define_predicate "gcn_load_operand"
1830386684a0 gcc-9.2.0
anatofuz
parents:
diff changeset
130 (ior (match_operand 0 "nonimmediate_operand")
1830386684a0 gcc-9.2.0
anatofuz
parents:
diff changeset
131 (match_operand 0 "gcn_32bit_immediate_operand")))
1830386684a0 gcc-9.2.0
anatofuz
parents:
diff changeset
132
1830386684a0 gcc-9.2.0
anatofuz
parents:
diff changeset
133 (define_predicate "gcn_alu_operand"
1830386684a0 gcc-9.2.0
anatofuz
parents:
diff changeset
134 (ior (match_operand 0 "register_operand")
1830386684a0 gcc-9.2.0
anatofuz
parents:
diff changeset
135 (match_operand 0 "gcn_32bit_immediate_operand")))
1830386684a0 gcc-9.2.0
anatofuz
parents:
diff changeset
136
1830386684a0 gcc-9.2.0
anatofuz
parents:
diff changeset
137 (define_predicate "gcn_ds_memory_operand"
1830386684a0 gcc-9.2.0
anatofuz
parents:
diff changeset
138 (and (match_code "mem")
1830386684a0 gcc-9.2.0
anatofuz
parents:
diff changeset
139 (and (match_test "AS_ANY_DS_P (MEM_ADDR_SPACE (op))")
1830386684a0 gcc-9.2.0
anatofuz
parents:
diff changeset
140 (match_operand 0 "memory_operand"))))
1830386684a0 gcc-9.2.0
anatofuz
parents:
diff changeset
141
1830386684a0 gcc-9.2.0
anatofuz
parents:
diff changeset
142 (define_predicate "gcn_valu_dst_operand"
1830386684a0 gcc-9.2.0
anatofuz
parents:
diff changeset
143 (ior (match_operand 0 "register_operand")
1830386684a0 gcc-9.2.0
anatofuz
parents:
diff changeset
144 (match_operand 0 "gcn_ds_memory_operand")))
1830386684a0 gcc-9.2.0
anatofuz
parents:
diff changeset
145
1830386684a0 gcc-9.2.0
anatofuz
parents:
diff changeset
146 (define_predicate "gcn_valu_src0_operand"
1830386684a0 gcc-9.2.0
anatofuz
parents:
diff changeset
147 (ior (match_operand 0 "register_operand")
1830386684a0 gcc-9.2.0
anatofuz
parents:
diff changeset
148 (ior (match_operand 0 "gcn_32bit_immediate_operand")
1830386684a0 gcc-9.2.0
anatofuz
parents:
diff changeset
149 (match_operand 0 "gcn_ds_memory_operand"))))
1830386684a0 gcc-9.2.0
anatofuz
parents:
diff changeset
150
1830386684a0 gcc-9.2.0
anatofuz
parents:
diff changeset
151 (define_predicate "gcn_valu_src1_operand"
1830386684a0 gcc-9.2.0
anatofuz
parents:
diff changeset
152 (match_operand 0 "register_operand"))
1830386684a0 gcc-9.2.0
anatofuz
parents:
diff changeset
153
1830386684a0 gcc-9.2.0
anatofuz
parents:
diff changeset
154 (define_predicate "gcn_valu_src1com_operand"
1830386684a0 gcc-9.2.0
anatofuz
parents:
diff changeset
155 (ior (match_operand 0 "register_operand")
1830386684a0 gcc-9.2.0
anatofuz
parents:
diff changeset
156 (match_operand 0 "gcn_32bit_immediate_operand")))
1830386684a0 gcc-9.2.0
anatofuz
parents:
diff changeset
157
1830386684a0 gcc-9.2.0
anatofuz
parents:
diff changeset
158 (define_predicate "gcn_conditional_operator"
1830386684a0 gcc-9.2.0
anatofuz
parents:
diff changeset
159 (match_code "eq,ne"))
1830386684a0 gcc-9.2.0
anatofuz
parents:
diff changeset
160
1830386684a0 gcc-9.2.0
anatofuz
parents:
diff changeset
161 (define_predicate "gcn_compare_64bit_operator"
1830386684a0 gcc-9.2.0
anatofuz
parents:
diff changeset
162 (match_code "eq,ne"))
1830386684a0 gcc-9.2.0
anatofuz
parents:
diff changeset
163
1830386684a0 gcc-9.2.0
anatofuz
parents:
diff changeset
164 (define_predicate "gcn_compare_operator"
1830386684a0 gcc-9.2.0
anatofuz
parents:
diff changeset
165 (match_code "eq,ne,gt,ge,lt,le,gtu,geu,ltu,leu"))
1830386684a0 gcc-9.2.0
anatofuz
parents:
diff changeset
166
1830386684a0 gcc-9.2.0
anatofuz
parents:
diff changeset
167 (define_predicate "gcn_fp_compare_operator"
1830386684a0 gcc-9.2.0
anatofuz
parents:
diff changeset
168 (match_code "eq,ne,gt,ge,lt,le,gtu,geu,ltu,leu,ordered,unordered,ltgt"))
1830386684a0 gcc-9.2.0
anatofuz
parents:
diff changeset
169
1830386684a0 gcc-9.2.0
anatofuz
parents:
diff changeset
170 (define_predicate "unary_operator"
1830386684a0 gcc-9.2.0
anatofuz
parents:
diff changeset
171 (match_code "not,popcount"))
1830386684a0 gcc-9.2.0
anatofuz
parents:
diff changeset
172
1830386684a0 gcc-9.2.0
anatofuz
parents:
diff changeset
173 (define_predicate "binary_operator"
1830386684a0 gcc-9.2.0
anatofuz
parents:
diff changeset
174 (match_code "and,ior,xor,ashift,lshiftrt,ashiftrt,smin,smax,umin,umax"))
1830386684a0 gcc-9.2.0
anatofuz
parents:
diff changeset
175
1830386684a0 gcc-9.2.0
anatofuz
parents:
diff changeset
176 (define_predicate "gcn_unspec_operand"
1830386684a0 gcc-9.2.0
anatofuz
parents:
diff changeset
177 (and (match_code "unspec")
1830386684a0 gcc-9.2.0
anatofuz
parents:
diff changeset
178 (match_test "XINT (op, 1) == UNSPEC_VECTOR")))
1830386684a0 gcc-9.2.0
anatofuz
parents:
diff changeset
179
1830386684a0 gcc-9.2.0
anatofuz
parents:
diff changeset
180 (define_predicate "general_or_unspec_operand"
1830386684a0 gcc-9.2.0
anatofuz
parents:
diff changeset
181 (ior (match_operand 0 "general_operand")
1830386684a0 gcc-9.2.0
anatofuz
parents:
diff changeset
182 (and (match_code "unspec")
1830386684a0 gcc-9.2.0
anatofuz
parents:
diff changeset
183 (match_test "XINT (op, 1) == UNSPEC_VECTOR"))))
1830386684a0 gcc-9.2.0
anatofuz
parents:
diff changeset
184
1830386684a0 gcc-9.2.0
anatofuz
parents:
diff changeset
185 (define_predicate "gcn_register_or_unspec_operand"
1830386684a0 gcc-9.2.0
anatofuz
parents:
diff changeset
186 (ior (match_operand 0 "register_operand")
1830386684a0 gcc-9.2.0
anatofuz
parents:
diff changeset
187 (and (match_code "unspec")
1830386684a0 gcc-9.2.0
anatofuz
parents:
diff changeset
188 (match_test "XINT (op, 1) == UNSPEC_VECTOR"))))
1830386684a0 gcc-9.2.0
anatofuz
parents:
diff changeset
189
1830386684a0 gcc-9.2.0
anatofuz
parents:
diff changeset
190 (define_predicate "gcn_alu_or_unspec_operand"
1830386684a0 gcc-9.2.0
anatofuz
parents:
diff changeset
191 (ior (match_operand 0 "gcn_alu_operand")
1830386684a0 gcc-9.2.0
anatofuz
parents:
diff changeset
192 (and (match_code "unspec")
1830386684a0 gcc-9.2.0
anatofuz
parents:
diff changeset
193 (match_test "XINT (op, 1) == UNSPEC_VECTOR"))))
1830386684a0 gcc-9.2.0
anatofuz
parents:
diff changeset
194
1830386684a0 gcc-9.2.0
anatofuz
parents:
diff changeset
195 (define_predicate "gcn_register_ds_or_unspec_operand"
1830386684a0 gcc-9.2.0
anatofuz
parents:
diff changeset
196 (ior (match_operand 0 "register_operand")
1830386684a0 gcc-9.2.0
anatofuz
parents:
diff changeset
197 (ior (match_operand 0 "gcn_ds_memory_operand")
1830386684a0 gcc-9.2.0
anatofuz
parents:
diff changeset
198 (and (match_code "unspec")
1830386684a0 gcc-9.2.0
anatofuz
parents:
diff changeset
199 (match_test "XINT (op, 1) == UNSPEC_VECTOR")))))