annotate gcc/hsa-dump.c @ 111:04ced10e8804

gcc 7
author kono
date Fri, 27 Oct 2017 22:46:09 +0900
parents
children 84e7813d76e9
Ignore whitespace changes - Everywhere: Within whitespace: At end of lines:
rev   line source
111
kono
parents:
diff changeset
1 /* Infrastructure to dump our HSAIL IL
kono
parents:
diff changeset
2 Copyright (C) 2013-2017 Free Software Foundation, Inc.
kono
parents:
diff changeset
3 Contributed by Martin Jambor <mjambor@suse.cz> and
kono
parents:
diff changeset
4 Martin Liska <mliska@suse.cz>.
kono
parents:
diff changeset
5
kono
parents:
diff changeset
6 This file is part of GCC.
kono
parents:
diff changeset
7
kono
parents:
diff changeset
8 GCC is free software; you can redistribute it and/or modify
kono
parents:
diff changeset
9 it under the terms of the GNU General Public License as published by
kono
parents:
diff changeset
10 the Free Software Foundation; either version 3, or (at your option)
kono
parents:
diff changeset
11 any later version.
kono
parents:
diff changeset
12
kono
parents:
diff changeset
13 GCC is distributed in the hope that it will be useful,
kono
parents:
diff changeset
14 but WITHOUT ANY WARRANTY; without even the implied warranty of
kono
parents:
diff changeset
15 MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
kono
parents:
diff changeset
16 GNU General Public License for more details.
kono
parents:
diff changeset
17
kono
parents:
diff changeset
18 You should have received a copy of the GNU General Public License
kono
parents:
diff changeset
19 along with GCC; see the file COPYING3. If not see
kono
parents:
diff changeset
20 <http://www.gnu.org/licenses/>. */
kono
parents:
diff changeset
21
kono
parents:
diff changeset
22 #include "config.h"
kono
parents:
diff changeset
23 #include "system.h"
kono
parents:
diff changeset
24 #include "coretypes.h"
kono
parents:
diff changeset
25 #include "tm.h"
kono
parents:
diff changeset
26 #include "is-a.h"
kono
parents:
diff changeset
27 #include "vec.h"
kono
parents:
diff changeset
28 #include "tree.h"
kono
parents:
diff changeset
29 #include "basic-block.h"
kono
parents:
diff changeset
30 #include "cfg.h"
kono
parents:
diff changeset
31 #include "function.h"
kono
parents:
diff changeset
32 #include "dumpfile.h"
kono
parents:
diff changeset
33 #include "gimple-pretty-print.h"
kono
parents:
diff changeset
34 #include "cgraph.h"
kono
parents:
diff changeset
35 #include "print-tree.h"
kono
parents:
diff changeset
36 #include "symbol-summary.h"
kono
parents:
diff changeset
37 #include "hsa-common.h"
kono
parents:
diff changeset
38
kono
parents:
diff changeset
39 /* Return textual name of TYPE. */
kono
parents:
diff changeset
40
kono
parents:
diff changeset
41 static const char *
kono
parents:
diff changeset
42 hsa_type_name (BrigType16_t type)
kono
parents:
diff changeset
43 {
kono
parents:
diff changeset
44 switch (type)
kono
parents:
diff changeset
45 {
kono
parents:
diff changeset
46 case BRIG_TYPE_NONE:
kono
parents:
diff changeset
47 return "none";
kono
parents:
diff changeset
48 case BRIG_TYPE_U8:
kono
parents:
diff changeset
49 return "u8";
kono
parents:
diff changeset
50 case BRIG_TYPE_U16:
kono
parents:
diff changeset
51 return "u16";
kono
parents:
diff changeset
52 case BRIG_TYPE_U32:
kono
parents:
diff changeset
53 return "u32";
kono
parents:
diff changeset
54 case BRIG_TYPE_U64:
kono
parents:
diff changeset
55 return "u64";
kono
parents:
diff changeset
56 case BRIG_TYPE_S8:
kono
parents:
diff changeset
57 return "s8";
kono
parents:
diff changeset
58 case BRIG_TYPE_S16:
kono
parents:
diff changeset
59 return "s16";
kono
parents:
diff changeset
60 case BRIG_TYPE_S32:
kono
parents:
diff changeset
61 return "s32";
kono
parents:
diff changeset
62 case BRIG_TYPE_S64:
kono
parents:
diff changeset
63 return "s64";
kono
parents:
diff changeset
64 case BRIG_TYPE_F16:
kono
parents:
diff changeset
65 return "f16";
kono
parents:
diff changeset
66 case BRIG_TYPE_F32:
kono
parents:
diff changeset
67 return "f32";
kono
parents:
diff changeset
68 case BRIG_TYPE_F64:
kono
parents:
diff changeset
69 return "f64";
kono
parents:
diff changeset
70 case BRIG_TYPE_B1:
kono
parents:
diff changeset
71 return "b1";
kono
parents:
diff changeset
72 case BRIG_TYPE_B8:
kono
parents:
diff changeset
73 return "b8";
kono
parents:
diff changeset
74 case BRIG_TYPE_B16:
kono
parents:
diff changeset
75 return "b16";
kono
parents:
diff changeset
76 case BRIG_TYPE_B32:
kono
parents:
diff changeset
77 return "b32";
kono
parents:
diff changeset
78 case BRIG_TYPE_B64:
kono
parents:
diff changeset
79 return "b64";
kono
parents:
diff changeset
80 case BRIG_TYPE_B128:
kono
parents:
diff changeset
81 return "b128";
kono
parents:
diff changeset
82 case BRIG_TYPE_SAMP:
kono
parents:
diff changeset
83 return "samp";
kono
parents:
diff changeset
84 case BRIG_TYPE_ROIMG:
kono
parents:
diff changeset
85 return "roimg";
kono
parents:
diff changeset
86 case BRIG_TYPE_WOIMG:
kono
parents:
diff changeset
87 return "woimg";
kono
parents:
diff changeset
88 case BRIG_TYPE_RWIMG:
kono
parents:
diff changeset
89 return "rwimg";
kono
parents:
diff changeset
90 case BRIG_TYPE_SIG32:
kono
parents:
diff changeset
91 return "sig32";
kono
parents:
diff changeset
92 case BRIG_TYPE_SIG64:
kono
parents:
diff changeset
93 return "sig64";
kono
parents:
diff changeset
94 case BRIG_TYPE_U8X4:
kono
parents:
diff changeset
95 return "u8x4";
kono
parents:
diff changeset
96 case BRIG_TYPE_U8X8:
kono
parents:
diff changeset
97 return "u8x8";
kono
parents:
diff changeset
98 case BRIG_TYPE_U8X16:
kono
parents:
diff changeset
99 return "u8x16";
kono
parents:
diff changeset
100 case BRIG_TYPE_U16X2:
kono
parents:
diff changeset
101 return "u16x2";
kono
parents:
diff changeset
102 case BRIG_TYPE_U16X4:
kono
parents:
diff changeset
103 return "u16x4";
kono
parents:
diff changeset
104 case BRIG_TYPE_U16X8:
kono
parents:
diff changeset
105 return "u16x8";
kono
parents:
diff changeset
106 case BRIG_TYPE_U32X2:
kono
parents:
diff changeset
107 return "u32x2";
kono
parents:
diff changeset
108 case BRIG_TYPE_U32X4:
kono
parents:
diff changeset
109 return "u32x4";
kono
parents:
diff changeset
110 case BRIG_TYPE_U64X2:
kono
parents:
diff changeset
111 return "u64x2";
kono
parents:
diff changeset
112 case BRIG_TYPE_S8X4:
kono
parents:
diff changeset
113 return "s8x4";
kono
parents:
diff changeset
114 case BRIG_TYPE_S8X8:
kono
parents:
diff changeset
115 return "s8x8";
kono
parents:
diff changeset
116 case BRIG_TYPE_S8X16:
kono
parents:
diff changeset
117 return "s8x16";
kono
parents:
diff changeset
118 case BRIG_TYPE_S16X2:
kono
parents:
diff changeset
119 return "s16x2";
kono
parents:
diff changeset
120 case BRIG_TYPE_S16X4:
kono
parents:
diff changeset
121 return "s16x4";
kono
parents:
diff changeset
122 case BRIG_TYPE_S16X8:
kono
parents:
diff changeset
123 return "s16x8";
kono
parents:
diff changeset
124 case BRIG_TYPE_S32X2:
kono
parents:
diff changeset
125 return "s32x2";
kono
parents:
diff changeset
126 case BRIG_TYPE_S32X4:
kono
parents:
diff changeset
127 return "s32x4";
kono
parents:
diff changeset
128 case BRIG_TYPE_S64X2:
kono
parents:
diff changeset
129 return "s64x2";
kono
parents:
diff changeset
130 case BRIG_TYPE_F16X2:
kono
parents:
diff changeset
131 return "f16x2";
kono
parents:
diff changeset
132 case BRIG_TYPE_F16X4:
kono
parents:
diff changeset
133 return "f16x4";
kono
parents:
diff changeset
134 case BRIG_TYPE_F16X8:
kono
parents:
diff changeset
135 return "f16x8";
kono
parents:
diff changeset
136 case BRIG_TYPE_F32X2:
kono
parents:
diff changeset
137 return "f32x2";
kono
parents:
diff changeset
138 case BRIG_TYPE_F32X4:
kono
parents:
diff changeset
139 return "f32x4";
kono
parents:
diff changeset
140 case BRIG_TYPE_F64X2:
kono
parents:
diff changeset
141 return "f64x2";
kono
parents:
diff changeset
142 default:
kono
parents:
diff changeset
143 return "UNKNOWN_TYPE";
kono
parents:
diff changeset
144 }
kono
parents:
diff changeset
145 }
kono
parents:
diff changeset
146
kono
parents:
diff changeset
147 /* Return textual name of OPCODE. */
kono
parents:
diff changeset
148
kono
parents:
diff changeset
149 static const char *
kono
parents:
diff changeset
150 hsa_opcode_name (BrigOpcode16_t opcode)
kono
parents:
diff changeset
151 {
kono
parents:
diff changeset
152 switch (opcode)
kono
parents:
diff changeset
153 {
kono
parents:
diff changeset
154 case BRIG_OPCODE_NOP:
kono
parents:
diff changeset
155 return "nop";
kono
parents:
diff changeset
156 case BRIG_OPCODE_ABS:
kono
parents:
diff changeset
157 return "abs";
kono
parents:
diff changeset
158 case BRIG_OPCODE_ADD:
kono
parents:
diff changeset
159 return "add";
kono
parents:
diff changeset
160 case BRIG_OPCODE_BORROW:
kono
parents:
diff changeset
161 return "borrow";
kono
parents:
diff changeset
162 case BRIG_OPCODE_CARRY:
kono
parents:
diff changeset
163 return "carry";
kono
parents:
diff changeset
164 case BRIG_OPCODE_CEIL:
kono
parents:
diff changeset
165 return "ceil";
kono
parents:
diff changeset
166 case BRIG_OPCODE_COPYSIGN:
kono
parents:
diff changeset
167 return "copysign";
kono
parents:
diff changeset
168 case BRIG_OPCODE_DIV:
kono
parents:
diff changeset
169 return "div";
kono
parents:
diff changeset
170 case BRIG_OPCODE_FLOOR:
kono
parents:
diff changeset
171 return "floor";
kono
parents:
diff changeset
172 case BRIG_OPCODE_FMA:
kono
parents:
diff changeset
173 return "fma";
kono
parents:
diff changeset
174 case BRIG_OPCODE_FRACT:
kono
parents:
diff changeset
175 return "fract";
kono
parents:
diff changeset
176 case BRIG_OPCODE_MAD:
kono
parents:
diff changeset
177 return "mad";
kono
parents:
diff changeset
178 case BRIG_OPCODE_MAX:
kono
parents:
diff changeset
179 return "max";
kono
parents:
diff changeset
180 case BRIG_OPCODE_MIN:
kono
parents:
diff changeset
181 return "min";
kono
parents:
diff changeset
182 case BRIG_OPCODE_MUL:
kono
parents:
diff changeset
183 return "mul";
kono
parents:
diff changeset
184 case BRIG_OPCODE_MULHI:
kono
parents:
diff changeset
185 return "mulhi";
kono
parents:
diff changeset
186 case BRIG_OPCODE_NEG:
kono
parents:
diff changeset
187 return "neg";
kono
parents:
diff changeset
188 case BRIG_OPCODE_REM:
kono
parents:
diff changeset
189 return "rem";
kono
parents:
diff changeset
190 case BRIG_OPCODE_RINT:
kono
parents:
diff changeset
191 return "rint";
kono
parents:
diff changeset
192 case BRIG_OPCODE_SQRT:
kono
parents:
diff changeset
193 return "sqrt";
kono
parents:
diff changeset
194 case BRIG_OPCODE_SUB:
kono
parents:
diff changeset
195 return "sub";
kono
parents:
diff changeset
196 case BRIG_OPCODE_TRUNC:
kono
parents:
diff changeset
197 return "trunc";
kono
parents:
diff changeset
198 case BRIG_OPCODE_MAD24:
kono
parents:
diff changeset
199 return "mad24";
kono
parents:
diff changeset
200 case BRIG_OPCODE_MAD24HI:
kono
parents:
diff changeset
201 return "mad24hi";
kono
parents:
diff changeset
202 case BRIG_OPCODE_MUL24:
kono
parents:
diff changeset
203 return "mul24";
kono
parents:
diff changeset
204 case BRIG_OPCODE_MUL24HI:
kono
parents:
diff changeset
205 return "mul24hi";
kono
parents:
diff changeset
206 case BRIG_OPCODE_SHL:
kono
parents:
diff changeset
207 return "shl";
kono
parents:
diff changeset
208 case BRIG_OPCODE_SHR:
kono
parents:
diff changeset
209 return "shr";
kono
parents:
diff changeset
210 case BRIG_OPCODE_AND:
kono
parents:
diff changeset
211 return "and";
kono
parents:
diff changeset
212 case BRIG_OPCODE_NOT:
kono
parents:
diff changeset
213 return "not";
kono
parents:
diff changeset
214 case BRIG_OPCODE_OR:
kono
parents:
diff changeset
215 return "or";
kono
parents:
diff changeset
216 case BRIG_OPCODE_POPCOUNT:
kono
parents:
diff changeset
217 return "popcount";
kono
parents:
diff changeset
218 case BRIG_OPCODE_XOR:
kono
parents:
diff changeset
219 return "xor";
kono
parents:
diff changeset
220 case BRIG_OPCODE_BITEXTRACT:
kono
parents:
diff changeset
221 return "bitextract";
kono
parents:
diff changeset
222 case BRIG_OPCODE_BITINSERT:
kono
parents:
diff changeset
223 return "bitinsert";
kono
parents:
diff changeset
224 case BRIG_OPCODE_BITMASK:
kono
parents:
diff changeset
225 return "bitmask";
kono
parents:
diff changeset
226 case BRIG_OPCODE_BITREV:
kono
parents:
diff changeset
227 return "bitrev";
kono
parents:
diff changeset
228 case BRIG_OPCODE_BITSELECT:
kono
parents:
diff changeset
229 return "bitselect";
kono
parents:
diff changeset
230 case BRIG_OPCODE_FIRSTBIT:
kono
parents:
diff changeset
231 return "firstbit";
kono
parents:
diff changeset
232 case BRIG_OPCODE_LASTBIT:
kono
parents:
diff changeset
233 return "lastbit";
kono
parents:
diff changeset
234 case BRIG_OPCODE_COMBINE:
kono
parents:
diff changeset
235 return "combine";
kono
parents:
diff changeset
236 case BRIG_OPCODE_EXPAND:
kono
parents:
diff changeset
237 return "expand";
kono
parents:
diff changeset
238 case BRIG_OPCODE_LDA:
kono
parents:
diff changeset
239 return "lda";
kono
parents:
diff changeset
240 case BRIG_OPCODE_MOV:
kono
parents:
diff changeset
241 return "mov";
kono
parents:
diff changeset
242 case BRIG_OPCODE_SHUFFLE:
kono
parents:
diff changeset
243 return "shuffle";
kono
parents:
diff changeset
244 case BRIG_OPCODE_UNPACKHI:
kono
parents:
diff changeset
245 return "unpackhi";
kono
parents:
diff changeset
246 case BRIG_OPCODE_UNPACKLO:
kono
parents:
diff changeset
247 return "unpacklo";
kono
parents:
diff changeset
248 case BRIG_OPCODE_PACK:
kono
parents:
diff changeset
249 return "pack";
kono
parents:
diff changeset
250 case BRIG_OPCODE_UNPACK:
kono
parents:
diff changeset
251 return "unpack";
kono
parents:
diff changeset
252 case BRIG_OPCODE_CMOV:
kono
parents:
diff changeset
253 return "cmov";
kono
parents:
diff changeset
254 case BRIG_OPCODE_CLASS:
kono
parents:
diff changeset
255 return "class";
kono
parents:
diff changeset
256 case BRIG_OPCODE_NCOS:
kono
parents:
diff changeset
257 return "ncos";
kono
parents:
diff changeset
258 case BRIG_OPCODE_NEXP2:
kono
parents:
diff changeset
259 return "nexp2";
kono
parents:
diff changeset
260 case BRIG_OPCODE_NFMA:
kono
parents:
diff changeset
261 return "nfma";
kono
parents:
diff changeset
262 case BRIG_OPCODE_NLOG2:
kono
parents:
diff changeset
263 return "nlog2";
kono
parents:
diff changeset
264 case BRIG_OPCODE_NRCP:
kono
parents:
diff changeset
265 return "nrcp";
kono
parents:
diff changeset
266 case BRIG_OPCODE_NRSQRT:
kono
parents:
diff changeset
267 return "nrsqrt";
kono
parents:
diff changeset
268 case BRIG_OPCODE_NSIN:
kono
parents:
diff changeset
269 return "nsin";
kono
parents:
diff changeset
270 case BRIG_OPCODE_NSQRT:
kono
parents:
diff changeset
271 return "nsqrt";
kono
parents:
diff changeset
272 case BRIG_OPCODE_BITALIGN:
kono
parents:
diff changeset
273 return "bitalign";
kono
parents:
diff changeset
274 case BRIG_OPCODE_BYTEALIGN:
kono
parents:
diff changeset
275 return "bytealign";
kono
parents:
diff changeset
276 case BRIG_OPCODE_PACKCVT:
kono
parents:
diff changeset
277 return "packcvt";
kono
parents:
diff changeset
278 case BRIG_OPCODE_UNPACKCVT:
kono
parents:
diff changeset
279 return "unpackcvt";
kono
parents:
diff changeset
280 case BRIG_OPCODE_LERP:
kono
parents:
diff changeset
281 return "lerp";
kono
parents:
diff changeset
282 case BRIG_OPCODE_SAD:
kono
parents:
diff changeset
283 return "sad";
kono
parents:
diff changeset
284 case BRIG_OPCODE_SADHI:
kono
parents:
diff changeset
285 return "sadhi";
kono
parents:
diff changeset
286 case BRIG_OPCODE_SEGMENTP:
kono
parents:
diff changeset
287 return "segmentp";
kono
parents:
diff changeset
288 case BRIG_OPCODE_FTOS:
kono
parents:
diff changeset
289 return "ftos";
kono
parents:
diff changeset
290 case BRIG_OPCODE_STOF:
kono
parents:
diff changeset
291 return "stof";
kono
parents:
diff changeset
292 case BRIG_OPCODE_CMP:
kono
parents:
diff changeset
293 return "cmp";
kono
parents:
diff changeset
294 case BRIG_OPCODE_CVT:
kono
parents:
diff changeset
295 return "cvt";
kono
parents:
diff changeset
296 case BRIG_OPCODE_LD:
kono
parents:
diff changeset
297 return "ld";
kono
parents:
diff changeset
298 case BRIG_OPCODE_ST:
kono
parents:
diff changeset
299 return "st";
kono
parents:
diff changeset
300 case BRIG_OPCODE_ATOMIC:
kono
parents:
diff changeset
301 return "atomic";
kono
parents:
diff changeset
302 case BRIG_OPCODE_ATOMICNORET:
kono
parents:
diff changeset
303 return "atomicnoret";
kono
parents:
diff changeset
304 case BRIG_OPCODE_SIGNAL:
kono
parents:
diff changeset
305 return "signal";
kono
parents:
diff changeset
306 case BRIG_OPCODE_SIGNALNORET:
kono
parents:
diff changeset
307 return "signalnoret";
kono
parents:
diff changeset
308 case BRIG_OPCODE_MEMFENCE:
kono
parents:
diff changeset
309 return "memfence";
kono
parents:
diff changeset
310 case BRIG_OPCODE_RDIMAGE:
kono
parents:
diff changeset
311 return "rdimage";
kono
parents:
diff changeset
312 case BRIG_OPCODE_LDIMAGE:
kono
parents:
diff changeset
313 return "ldimage";
kono
parents:
diff changeset
314 case BRIG_OPCODE_STIMAGE:
kono
parents:
diff changeset
315 return "stimage";
kono
parents:
diff changeset
316 case BRIG_OPCODE_QUERYIMAGE:
kono
parents:
diff changeset
317 return "queryimage";
kono
parents:
diff changeset
318 case BRIG_OPCODE_QUERYSAMPLER:
kono
parents:
diff changeset
319 return "querysampler";
kono
parents:
diff changeset
320 case BRIG_OPCODE_CBR:
kono
parents:
diff changeset
321 return "cbr";
kono
parents:
diff changeset
322 case BRIG_OPCODE_BR:
kono
parents:
diff changeset
323 return "br";
kono
parents:
diff changeset
324 case BRIG_OPCODE_SBR:
kono
parents:
diff changeset
325 return "sbr";
kono
parents:
diff changeset
326 case BRIG_OPCODE_BARRIER:
kono
parents:
diff changeset
327 return "barrier";
kono
parents:
diff changeset
328 case BRIG_OPCODE_WAVEBARRIER:
kono
parents:
diff changeset
329 return "wavebarrier";
kono
parents:
diff changeset
330 case BRIG_OPCODE_ARRIVEFBAR:
kono
parents:
diff changeset
331 return "arrivefbar";
kono
parents:
diff changeset
332 case BRIG_OPCODE_INITFBAR:
kono
parents:
diff changeset
333 return "initfbar";
kono
parents:
diff changeset
334 case BRIG_OPCODE_JOINFBAR:
kono
parents:
diff changeset
335 return "joinfbar";
kono
parents:
diff changeset
336 case BRIG_OPCODE_LEAVEFBAR:
kono
parents:
diff changeset
337 return "leavefbar";
kono
parents:
diff changeset
338 case BRIG_OPCODE_RELEASEFBAR:
kono
parents:
diff changeset
339 return "releasefbar";
kono
parents:
diff changeset
340 case BRIG_OPCODE_WAITFBAR:
kono
parents:
diff changeset
341 return "waitfbar";
kono
parents:
diff changeset
342 case BRIG_OPCODE_LDF:
kono
parents:
diff changeset
343 return "ldf";
kono
parents:
diff changeset
344 case BRIG_OPCODE_ACTIVELANECOUNT:
kono
parents:
diff changeset
345 return "activelanecount";
kono
parents:
diff changeset
346 case BRIG_OPCODE_ACTIVELANEID:
kono
parents:
diff changeset
347 return "activelaneid";
kono
parents:
diff changeset
348 case BRIG_OPCODE_ACTIVELANEMASK:
kono
parents:
diff changeset
349 return "activelanemask";
kono
parents:
diff changeset
350 case BRIG_OPCODE_CALL:
kono
parents:
diff changeset
351 return "call";
kono
parents:
diff changeset
352 case BRIG_OPCODE_SCALL:
kono
parents:
diff changeset
353 return "scall";
kono
parents:
diff changeset
354 case BRIG_OPCODE_ICALL:
kono
parents:
diff changeset
355 return "icall";
kono
parents:
diff changeset
356 case BRIG_OPCODE_RET:
kono
parents:
diff changeset
357 return "ret";
kono
parents:
diff changeset
358 case BRIG_OPCODE_ALLOCA:
kono
parents:
diff changeset
359 return "alloca";
kono
parents:
diff changeset
360 case BRIG_OPCODE_CURRENTWORKGROUPSIZE:
kono
parents:
diff changeset
361 return "currentworkgroupsize";
kono
parents:
diff changeset
362 case BRIG_OPCODE_DIM:
kono
parents:
diff changeset
363 return "dim";
kono
parents:
diff changeset
364 case BRIG_OPCODE_GRIDGROUPS:
kono
parents:
diff changeset
365 return "gridgroups";
kono
parents:
diff changeset
366 case BRIG_OPCODE_GRIDSIZE:
kono
parents:
diff changeset
367 return "gridsize";
kono
parents:
diff changeset
368 case BRIG_OPCODE_PACKETCOMPLETIONSIG:
kono
parents:
diff changeset
369 return "packetcompletionsig";
kono
parents:
diff changeset
370 case BRIG_OPCODE_PACKETID:
kono
parents:
diff changeset
371 return "packetid";
kono
parents:
diff changeset
372 case BRIG_OPCODE_WORKGROUPID:
kono
parents:
diff changeset
373 return "workgroupid";
kono
parents:
diff changeset
374 case BRIG_OPCODE_WORKGROUPSIZE:
kono
parents:
diff changeset
375 return "workgroupsize";
kono
parents:
diff changeset
376 case BRIG_OPCODE_WORKITEMABSID:
kono
parents:
diff changeset
377 return "workitemabsid";
kono
parents:
diff changeset
378 case BRIG_OPCODE_WORKITEMFLATABSID:
kono
parents:
diff changeset
379 return "workitemflatabsid";
kono
parents:
diff changeset
380 case BRIG_OPCODE_WORKITEMFLATID:
kono
parents:
diff changeset
381 return "workitemflatid";
kono
parents:
diff changeset
382 case BRIG_OPCODE_WORKITEMID:
kono
parents:
diff changeset
383 return "workitemid";
kono
parents:
diff changeset
384 case BRIG_OPCODE_CLEARDETECTEXCEPT:
kono
parents:
diff changeset
385 return "cleardetectexcept";
kono
parents:
diff changeset
386 case BRIG_OPCODE_GETDETECTEXCEPT:
kono
parents:
diff changeset
387 return "getdetectexcept";
kono
parents:
diff changeset
388 case BRIG_OPCODE_SETDETECTEXCEPT:
kono
parents:
diff changeset
389 return "setdetectexcept";
kono
parents:
diff changeset
390 case BRIG_OPCODE_ADDQUEUEWRITEINDEX:
kono
parents:
diff changeset
391 return "addqueuewriteindex";
kono
parents:
diff changeset
392 case BRIG_OPCODE_CASQUEUEWRITEINDEX:
kono
parents:
diff changeset
393 return "casqueuewriteindex";
kono
parents:
diff changeset
394 case BRIG_OPCODE_LDQUEUEREADINDEX:
kono
parents:
diff changeset
395 return "ldqueuereadindex";
kono
parents:
diff changeset
396 case BRIG_OPCODE_LDQUEUEWRITEINDEX:
kono
parents:
diff changeset
397 return "ldqueuewriteindex";
kono
parents:
diff changeset
398 case BRIG_OPCODE_STQUEUEREADINDEX:
kono
parents:
diff changeset
399 return "stqueuereadindex";
kono
parents:
diff changeset
400 case BRIG_OPCODE_STQUEUEWRITEINDEX:
kono
parents:
diff changeset
401 return "stqueuewriteindex";
kono
parents:
diff changeset
402 case BRIG_OPCODE_CLOCK:
kono
parents:
diff changeset
403 return "clock";
kono
parents:
diff changeset
404 case BRIG_OPCODE_CUID:
kono
parents:
diff changeset
405 return "cuid";
kono
parents:
diff changeset
406 case BRIG_OPCODE_DEBUGTRAP:
kono
parents:
diff changeset
407 return "debugtrap";
kono
parents:
diff changeset
408 case BRIG_OPCODE_GROUPBASEPTR:
kono
parents:
diff changeset
409 return "groupbaseptr";
kono
parents:
diff changeset
410 case BRIG_OPCODE_KERNARGBASEPTR:
kono
parents:
diff changeset
411 return "kernargbaseptr";
kono
parents:
diff changeset
412 case BRIG_OPCODE_LANEID:
kono
parents:
diff changeset
413 return "laneid";
kono
parents:
diff changeset
414 case BRIG_OPCODE_MAXCUID:
kono
parents:
diff changeset
415 return "maxcuid";
kono
parents:
diff changeset
416 case BRIG_OPCODE_MAXWAVEID:
kono
parents:
diff changeset
417 return "maxwaveid";
kono
parents:
diff changeset
418 case BRIG_OPCODE_NULLPTR:
kono
parents:
diff changeset
419 return "nullptr";
kono
parents:
diff changeset
420 case BRIG_OPCODE_WAVEID:
kono
parents:
diff changeset
421 return "waveid";
kono
parents:
diff changeset
422 default:
kono
parents:
diff changeset
423 return "UNKNOWN_OPCODE";
kono
parents:
diff changeset
424 }
kono
parents:
diff changeset
425 }
kono
parents:
diff changeset
426
kono
parents:
diff changeset
427 /* Return textual name of SEG. */
kono
parents:
diff changeset
428
kono
parents:
diff changeset
429 const char *
kono
parents:
diff changeset
430 hsa_seg_name (BrigSegment8_t seg)
kono
parents:
diff changeset
431 {
kono
parents:
diff changeset
432 switch (seg)
kono
parents:
diff changeset
433 {
kono
parents:
diff changeset
434 case BRIG_SEGMENT_NONE:
kono
parents:
diff changeset
435 return "none";
kono
parents:
diff changeset
436 case BRIG_SEGMENT_FLAT:
kono
parents:
diff changeset
437 return "flat";
kono
parents:
diff changeset
438 case BRIG_SEGMENT_GLOBAL:
kono
parents:
diff changeset
439 return "global";
kono
parents:
diff changeset
440 case BRIG_SEGMENT_READONLY:
kono
parents:
diff changeset
441 return "readonly";
kono
parents:
diff changeset
442 case BRIG_SEGMENT_KERNARG:
kono
parents:
diff changeset
443 return "kernarg";
kono
parents:
diff changeset
444 case BRIG_SEGMENT_GROUP:
kono
parents:
diff changeset
445 return "group";
kono
parents:
diff changeset
446 case BRIG_SEGMENT_PRIVATE:
kono
parents:
diff changeset
447 return "private";
kono
parents:
diff changeset
448 case BRIG_SEGMENT_SPILL:
kono
parents:
diff changeset
449 return "spill";
kono
parents:
diff changeset
450 case BRIG_SEGMENT_ARG:
kono
parents:
diff changeset
451 return "arg";
kono
parents:
diff changeset
452 default:
kono
parents:
diff changeset
453 return "UNKNOWN_SEGMENT";
kono
parents:
diff changeset
454 }
kono
parents:
diff changeset
455 }
kono
parents:
diff changeset
456
kono
parents:
diff changeset
457 /* Return textual name of CMPOP. */
kono
parents:
diff changeset
458
kono
parents:
diff changeset
459 static const char *
kono
parents:
diff changeset
460 hsa_cmpop_name (BrigCompareOperation8_t cmpop)
kono
parents:
diff changeset
461 {
kono
parents:
diff changeset
462 switch (cmpop)
kono
parents:
diff changeset
463 {
kono
parents:
diff changeset
464 case BRIG_COMPARE_EQ:
kono
parents:
diff changeset
465 return "eq";
kono
parents:
diff changeset
466 case BRIG_COMPARE_NE:
kono
parents:
diff changeset
467 return "ne";
kono
parents:
diff changeset
468 case BRIG_COMPARE_LT:
kono
parents:
diff changeset
469 return "lt";
kono
parents:
diff changeset
470 case BRIG_COMPARE_LE:
kono
parents:
diff changeset
471 return "le";
kono
parents:
diff changeset
472 case BRIG_COMPARE_GT:
kono
parents:
diff changeset
473 return "gt";
kono
parents:
diff changeset
474 case BRIG_COMPARE_GE:
kono
parents:
diff changeset
475 return "ge";
kono
parents:
diff changeset
476 case BRIG_COMPARE_EQU:
kono
parents:
diff changeset
477 return "equ";
kono
parents:
diff changeset
478 case BRIG_COMPARE_NEU:
kono
parents:
diff changeset
479 return "neu";
kono
parents:
diff changeset
480 case BRIG_COMPARE_LTU:
kono
parents:
diff changeset
481 return "ltu";
kono
parents:
diff changeset
482 case BRIG_COMPARE_LEU:
kono
parents:
diff changeset
483 return "leu";
kono
parents:
diff changeset
484 case BRIG_COMPARE_GTU:
kono
parents:
diff changeset
485 return "gtu";
kono
parents:
diff changeset
486 case BRIG_COMPARE_GEU:
kono
parents:
diff changeset
487 return "geu";
kono
parents:
diff changeset
488 case BRIG_COMPARE_NUM:
kono
parents:
diff changeset
489 return "num";
kono
parents:
diff changeset
490 case BRIG_COMPARE_NAN:
kono
parents:
diff changeset
491 return "nan";
kono
parents:
diff changeset
492 case BRIG_COMPARE_SEQ:
kono
parents:
diff changeset
493 return "seq";
kono
parents:
diff changeset
494 case BRIG_COMPARE_SNE:
kono
parents:
diff changeset
495 return "sne";
kono
parents:
diff changeset
496 case BRIG_COMPARE_SLT:
kono
parents:
diff changeset
497 return "slt";
kono
parents:
diff changeset
498 case BRIG_COMPARE_SLE:
kono
parents:
diff changeset
499 return "sle";
kono
parents:
diff changeset
500 case BRIG_COMPARE_SGT:
kono
parents:
diff changeset
501 return "sgt";
kono
parents:
diff changeset
502 case BRIG_COMPARE_SGE:
kono
parents:
diff changeset
503 return "sge";
kono
parents:
diff changeset
504 case BRIG_COMPARE_SGEU:
kono
parents:
diff changeset
505 return "sgeu";
kono
parents:
diff changeset
506 case BRIG_COMPARE_SEQU:
kono
parents:
diff changeset
507 return "sequ";
kono
parents:
diff changeset
508 case BRIG_COMPARE_SNEU:
kono
parents:
diff changeset
509 return "sneu";
kono
parents:
diff changeset
510 case BRIG_COMPARE_SLTU:
kono
parents:
diff changeset
511 return "sltu";
kono
parents:
diff changeset
512 case BRIG_COMPARE_SLEU:
kono
parents:
diff changeset
513 return "sleu";
kono
parents:
diff changeset
514 case BRIG_COMPARE_SNUM:
kono
parents:
diff changeset
515 return "snum";
kono
parents:
diff changeset
516 case BRIG_COMPARE_SNAN:
kono
parents:
diff changeset
517 return "snan";
kono
parents:
diff changeset
518 case BRIG_COMPARE_SGTU:
kono
parents:
diff changeset
519 return "sgtu";
kono
parents:
diff changeset
520 default:
kono
parents:
diff changeset
521 return "UNKNOWN_COMPARISON";
kono
parents:
diff changeset
522 }
kono
parents:
diff changeset
523 }
kono
parents:
diff changeset
524
kono
parents:
diff changeset
525 /* Return textual name for memory order. */
kono
parents:
diff changeset
526
kono
parents:
diff changeset
527 static const char *
kono
parents:
diff changeset
528 hsa_memsem_name (enum BrigMemoryOrder mo)
kono
parents:
diff changeset
529 {
kono
parents:
diff changeset
530 switch (mo)
kono
parents:
diff changeset
531 {
kono
parents:
diff changeset
532 case BRIG_MEMORY_ORDER_NONE:
kono
parents:
diff changeset
533 return "";
kono
parents:
diff changeset
534 case BRIG_MEMORY_ORDER_RELAXED:
kono
parents:
diff changeset
535 return "rlx";
kono
parents:
diff changeset
536 case BRIG_MEMORY_ORDER_SC_ACQUIRE:
kono
parents:
diff changeset
537 return "scacq";
kono
parents:
diff changeset
538 case BRIG_MEMORY_ORDER_SC_RELEASE:
kono
parents:
diff changeset
539 return "screl";
kono
parents:
diff changeset
540 case BRIG_MEMORY_ORDER_SC_ACQUIRE_RELEASE:
kono
parents:
diff changeset
541 return "scar";
kono
parents:
diff changeset
542 default:
kono
parents:
diff changeset
543 return "UNKNOWN_MEMORY_ORDER";
kono
parents:
diff changeset
544 }
kono
parents:
diff changeset
545 }
kono
parents:
diff changeset
546
kono
parents:
diff changeset
547 /* Return textual name for memory scope. */
kono
parents:
diff changeset
548
kono
parents:
diff changeset
549 static const char *
kono
parents:
diff changeset
550 hsa_memscope_name (enum BrigMemoryScope scope)
kono
parents:
diff changeset
551 {
kono
parents:
diff changeset
552 switch (scope)
kono
parents:
diff changeset
553 {
kono
parents:
diff changeset
554 case BRIG_MEMORY_SCOPE_NONE:
kono
parents:
diff changeset
555 return "";
kono
parents:
diff changeset
556 case BRIG_MEMORY_SCOPE_WORKITEM:
kono
parents:
diff changeset
557 return "wi";
kono
parents:
diff changeset
558 case BRIG_MEMORY_SCOPE_WAVEFRONT:
kono
parents:
diff changeset
559 return "wave";
kono
parents:
diff changeset
560 case BRIG_MEMORY_SCOPE_WORKGROUP:
kono
parents:
diff changeset
561 return "wg";
kono
parents:
diff changeset
562 case BRIG_MEMORY_SCOPE_AGENT:
kono
parents:
diff changeset
563 return "agent";
kono
parents:
diff changeset
564 case BRIG_MEMORY_SCOPE_SYSTEM:
kono
parents:
diff changeset
565 return "sys";
kono
parents:
diff changeset
566 default:
kono
parents:
diff changeset
567 return "UNKNOWN_SCOPE";
kono
parents:
diff changeset
568 }
kono
parents:
diff changeset
569 }
kono
parents:
diff changeset
570
kono
parents:
diff changeset
571 /* Return textual name for atomic operation. */
kono
parents:
diff changeset
572
kono
parents:
diff changeset
573 static const char *
kono
parents:
diff changeset
574 hsa_m_atomicop_name (enum BrigAtomicOperation op)
kono
parents:
diff changeset
575 {
kono
parents:
diff changeset
576 switch (op)
kono
parents:
diff changeset
577 {
kono
parents:
diff changeset
578 case BRIG_ATOMIC_ADD:
kono
parents:
diff changeset
579 return "add";
kono
parents:
diff changeset
580 case BRIG_ATOMIC_AND:
kono
parents:
diff changeset
581 return "and";
kono
parents:
diff changeset
582 case BRIG_ATOMIC_CAS:
kono
parents:
diff changeset
583 return "cas";
kono
parents:
diff changeset
584 case BRIG_ATOMIC_EXCH:
kono
parents:
diff changeset
585 return "exch";
kono
parents:
diff changeset
586 case BRIG_ATOMIC_LD:
kono
parents:
diff changeset
587 return "ld";
kono
parents:
diff changeset
588 case BRIG_ATOMIC_MAX:
kono
parents:
diff changeset
589 return "max";
kono
parents:
diff changeset
590 case BRIG_ATOMIC_MIN:
kono
parents:
diff changeset
591 return "min";
kono
parents:
diff changeset
592 case BRIG_ATOMIC_OR:
kono
parents:
diff changeset
593 return "or";
kono
parents:
diff changeset
594 case BRIG_ATOMIC_ST:
kono
parents:
diff changeset
595 return "st";
kono
parents:
diff changeset
596 case BRIG_ATOMIC_SUB:
kono
parents:
diff changeset
597 return "sub";
kono
parents:
diff changeset
598 case BRIG_ATOMIC_WRAPDEC:
kono
parents:
diff changeset
599 return "wrapdec";
kono
parents:
diff changeset
600 case BRIG_ATOMIC_WRAPINC:
kono
parents:
diff changeset
601 return "wrapinc";
kono
parents:
diff changeset
602 case BRIG_ATOMIC_XOR:
kono
parents:
diff changeset
603 return "xor";
kono
parents:
diff changeset
604 case BRIG_ATOMIC_WAIT_EQ:
kono
parents:
diff changeset
605 return "wait_eq";
kono
parents:
diff changeset
606 case BRIG_ATOMIC_WAIT_NE:
kono
parents:
diff changeset
607 return "wait_ne";
kono
parents:
diff changeset
608 case BRIG_ATOMIC_WAIT_LT:
kono
parents:
diff changeset
609 return "wait_lt";
kono
parents:
diff changeset
610 case BRIG_ATOMIC_WAIT_GTE:
kono
parents:
diff changeset
611 return "wait_gte";
kono
parents:
diff changeset
612 case BRIG_ATOMIC_WAITTIMEOUT_EQ:
kono
parents:
diff changeset
613 return "waittimeout_eq";
kono
parents:
diff changeset
614 case BRIG_ATOMIC_WAITTIMEOUT_NE:
kono
parents:
diff changeset
615 return "waittimeout_ne";
kono
parents:
diff changeset
616 case BRIG_ATOMIC_WAITTIMEOUT_LT:
kono
parents:
diff changeset
617 return "waittimeout_lt";
kono
parents:
diff changeset
618 case BRIG_ATOMIC_WAITTIMEOUT_GTE:
kono
parents:
diff changeset
619 return "waittimeout_gte";
kono
parents:
diff changeset
620 default:
kono
parents:
diff changeset
621 return "UNKNOWN_ATOMIC_OP";
kono
parents:
diff changeset
622 }
kono
parents:
diff changeset
623 }
kono
parents:
diff changeset
624
kono
parents:
diff changeset
625 /* Return textual name for atomic operation. */
kono
parents:
diff changeset
626
kono
parents:
diff changeset
627 static const char *
kono
parents:
diff changeset
628 hsa_width_specifier_name (BrigWidth8_t width)
kono
parents:
diff changeset
629 {
kono
parents:
diff changeset
630 switch (width)
kono
parents:
diff changeset
631 {
kono
parents:
diff changeset
632 case BRIG_WIDTH_NONE:
kono
parents:
diff changeset
633 return "none";
kono
parents:
diff changeset
634 case BRIG_WIDTH_1:
kono
parents:
diff changeset
635 return "1";
kono
parents:
diff changeset
636 case BRIG_WIDTH_2:
kono
parents:
diff changeset
637 return "2";
kono
parents:
diff changeset
638 case BRIG_WIDTH_4:
kono
parents:
diff changeset
639 return "4";
kono
parents:
diff changeset
640 case BRIG_WIDTH_8:
kono
parents:
diff changeset
641 return "8";
kono
parents:
diff changeset
642 case BRIG_WIDTH_16:
kono
parents:
diff changeset
643 return "16";
kono
parents:
diff changeset
644 case BRIG_WIDTH_32:
kono
parents:
diff changeset
645 return "32";
kono
parents:
diff changeset
646 case BRIG_WIDTH_64:
kono
parents:
diff changeset
647 return "64";
kono
parents:
diff changeset
648 case BRIG_WIDTH_128:
kono
parents:
diff changeset
649 return "128";
kono
parents:
diff changeset
650 case BRIG_WIDTH_256:
kono
parents:
diff changeset
651 return "256";
kono
parents:
diff changeset
652 case BRIG_WIDTH_512:
kono
parents:
diff changeset
653 return "512";
kono
parents:
diff changeset
654 case BRIG_WIDTH_1024:
kono
parents:
diff changeset
655 return "1024";
kono
parents:
diff changeset
656 case BRIG_WIDTH_2048:
kono
parents:
diff changeset
657 return "2048";
kono
parents:
diff changeset
658 case BRIG_WIDTH_4096:
kono
parents:
diff changeset
659 return "4096";
kono
parents:
diff changeset
660 case BRIG_WIDTH_8192:
kono
parents:
diff changeset
661 return "8192";
kono
parents:
diff changeset
662 case BRIG_WIDTH_16384:
kono
parents:
diff changeset
663 return "16384";
kono
parents:
diff changeset
664 case BRIG_WIDTH_32768:
kono
parents:
diff changeset
665 return "32768";
kono
parents:
diff changeset
666 case BRIG_WIDTH_65536:
kono
parents:
diff changeset
667 return "65536";
kono
parents:
diff changeset
668 case BRIG_WIDTH_131072:
kono
parents:
diff changeset
669 return "131072";
kono
parents:
diff changeset
670 case BRIG_WIDTH_262144:
kono
parents:
diff changeset
671 return "262144";
kono
parents:
diff changeset
672 case BRIG_WIDTH_524288:
kono
parents:
diff changeset
673 return "524288";
kono
parents:
diff changeset
674 case BRIG_WIDTH_1048576:
kono
parents:
diff changeset
675 return "1048576";
kono
parents:
diff changeset
676 case BRIG_WIDTH_2097152:
kono
parents:
diff changeset
677 return "2097152";
kono
parents:
diff changeset
678 case BRIG_WIDTH_4194304:
kono
parents:
diff changeset
679 return "4194304";
kono
parents:
diff changeset
680 case BRIG_WIDTH_8388608:
kono
parents:
diff changeset
681 return "8388608";
kono
parents:
diff changeset
682 case BRIG_WIDTH_16777216:
kono
parents:
diff changeset
683 return "16777216";
kono
parents:
diff changeset
684 case BRIG_WIDTH_33554432:
kono
parents:
diff changeset
685 return "33554432";
kono
parents:
diff changeset
686 case BRIG_WIDTH_67108864:
kono
parents:
diff changeset
687 return "67108864";
kono
parents:
diff changeset
688 case BRIG_WIDTH_134217728:
kono
parents:
diff changeset
689 return "134217728";
kono
parents:
diff changeset
690 case BRIG_WIDTH_268435456:
kono
parents:
diff changeset
691 return "268435456";
kono
parents:
diff changeset
692 case BRIG_WIDTH_536870912:
kono
parents:
diff changeset
693 return "536870912";
kono
parents:
diff changeset
694 case BRIG_WIDTH_1073741824:
kono
parents:
diff changeset
695 return "1073741824";
kono
parents:
diff changeset
696 case BRIG_WIDTH_2147483648:
kono
parents:
diff changeset
697 return "2147483648";
kono
parents:
diff changeset
698 case BRIG_WIDTH_WAVESIZE:
kono
parents:
diff changeset
699 return "wavesize";
kono
parents:
diff changeset
700 case BRIG_WIDTH_ALL:
kono
parents:
diff changeset
701 return "all";
kono
parents:
diff changeset
702 default:
kono
parents:
diff changeset
703 return "UNKNOWN_WIDTH";
kono
parents:
diff changeset
704 }
kono
parents:
diff changeset
705 }
kono
parents:
diff changeset
706
kono
parents:
diff changeset
707 /* Dump textual representation of HSA IL register REG to file F. */
kono
parents:
diff changeset
708
kono
parents:
diff changeset
709 static void
kono
parents:
diff changeset
710 dump_hsa_reg (FILE *f, hsa_op_reg *reg, bool dump_type = false)
kono
parents:
diff changeset
711 {
kono
parents:
diff changeset
712 if (reg->m_reg_class)
kono
parents:
diff changeset
713 fprintf (f, "$%c%i", reg->m_reg_class, reg->m_hard_num);
kono
parents:
diff changeset
714 else
kono
parents:
diff changeset
715 fprintf (f, "$_%i", reg->m_order);
kono
parents:
diff changeset
716 if (dump_type)
kono
parents:
diff changeset
717 fprintf (f, " (%s)", hsa_type_name (reg->m_type));
kono
parents:
diff changeset
718 }
kono
parents:
diff changeset
719
kono
parents:
diff changeset
720 /* Dump textual representation of HSA IL immediate operand IMM to file F. */
kono
parents:
diff changeset
721
kono
parents:
diff changeset
722 static void
kono
parents:
diff changeset
723 dump_hsa_immed (FILE *f, hsa_op_immed *imm)
kono
parents:
diff changeset
724 {
kono
parents:
diff changeset
725 bool unsigned_int_type
kono
parents:
diff changeset
726 = (BRIG_TYPE_U8 | BRIG_TYPE_U16 | BRIG_TYPE_U32 | BRIG_TYPE_U64)
kono
parents:
diff changeset
727 & imm->m_type;
kono
parents:
diff changeset
728
kono
parents:
diff changeset
729 if (imm->m_tree_value)
kono
parents:
diff changeset
730 print_generic_expr (f, imm->m_tree_value);
kono
parents:
diff changeset
731 else
kono
parents:
diff changeset
732 {
kono
parents:
diff changeset
733 if (unsigned_int_type)
kono
parents:
diff changeset
734 fprintf (f, HOST_WIDE_INT_PRINT_DEC, imm->m_int_value);
kono
parents:
diff changeset
735 else
kono
parents:
diff changeset
736 fprintf (f, HOST_WIDE_INT_PRINT_UNSIGNED,
kono
parents:
diff changeset
737 (unsigned HOST_WIDE_INT) imm->m_int_value);
kono
parents:
diff changeset
738 }
kono
parents:
diff changeset
739
kono
parents:
diff changeset
740 fprintf (f, " (%s)", hsa_type_name (imm->m_type));
kono
parents:
diff changeset
741 }
kono
parents:
diff changeset
742
kono
parents:
diff changeset
743 /* Dump textual representation of HSA IL address operand ADDR to file F. */
kono
parents:
diff changeset
744
kono
parents:
diff changeset
745 static void
kono
parents:
diff changeset
746 dump_hsa_address (FILE *f, hsa_op_address *addr)
kono
parents:
diff changeset
747 {
kono
parents:
diff changeset
748 bool sth = false;
kono
parents:
diff changeset
749
kono
parents:
diff changeset
750 if (addr->m_symbol)
kono
parents:
diff changeset
751 {
kono
parents:
diff changeset
752 sth = true;
kono
parents:
diff changeset
753 if (addr->m_symbol->m_name)
kono
parents:
diff changeset
754 fprintf (f, "[%%%s]", addr->m_symbol->m_name);
kono
parents:
diff changeset
755 else
kono
parents:
diff changeset
756 fprintf (f, "[%%__%s_%i]", hsa_seg_name (addr->m_symbol->m_segment),
kono
parents:
diff changeset
757 addr->m_symbol->m_name_number);
kono
parents:
diff changeset
758 }
kono
parents:
diff changeset
759
kono
parents:
diff changeset
760 if (addr->m_reg)
kono
parents:
diff changeset
761 {
kono
parents:
diff changeset
762 fprintf (f, "[");
kono
parents:
diff changeset
763 dump_hsa_reg (f, addr->m_reg);
kono
parents:
diff changeset
764 if (addr->m_imm_offset != 0)
kono
parents:
diff changeset
765 fprintf (f, " + " HOST_WIDE_INT_PRINT_DEC "]", addr->m_imm_offset);
kono
parents:
diff changeset
766 else
kono
parents:
diff changeset
767 fprintf (f, "]");
kono
parents:
diff changeset
768 }
kono
parents:
diff changeset
769 else if (!sth || addr->m_imm_offset != 0)
kono
parents:
diff changeset
770 fprintf (f, "[" HOST_WIDE_INT_PRINT_DEC "]", addr->m_imm_offset);
kono
parents:
diff changeset
771 }
kono
parents:
diff changeset
772
kono
parents:
diff changeset
773 /* Dump textual representation of HSA IL symbol SYMBOL to file F. */
kono
parents:
diff changeset
774
kono
parents:
diff changeset
775 static void
kono
parents:
diff changeset
776 dump_hsa_symbol (FILE *f, hsa_symbol *symbol)
kono
parents:
diff changeset
777 {
kono
parents:
diff changeset
778 const char *name;
kono
parents:
diff changeset
779 if (symbol->m_name)
kono
parents:
diff changeset
780 name = symbol->m_name;
kono
parents:
diff changeset
781 else
kono
parents:
diff changeset
782 {
kono
parents:
diff changeset
783 char buf[64];
kono
parents:
diff changeset
784 sprintf (buf, "__%s_%i", hsa_seg_name (symbol->m_segment),
kono
parents:
diff changeset
785 symbol->m_name_number);
kono
parents:
diff changeset
786
kono
parents:
diff changeset
787 name = buf;
kono
parents:
diff changeset
788 }
kono
parents:
diff changeset
789
kono
parents:
diff changeset
790 fprintf (f, "align(%u) %s_%s %s", hsa_byte_alignment (symbol->m_align),
kono
parents:
diff changeset
791 hsa_seg_name (symbol->m_segment),
kono
parents:
diff changeset
792 hsa_type_name (symbol->m_type & ~BRIG_TYPE_ARRAY_MASK), name);
kono
parents:
diff changeset
793
kono
parents:
diff changeset
794 if (symbol->m_type & BRIG_TYPE_ARRAY_MASK)
kono
parents:
diff changeset
795 fprintf (f, "[%lu]", (unsigned long) symbol->m_dim);
kono
parents:
diff changeset
796
kono
parents:
diff changeset
797 if (symbol->m_directive_offset)
kono
parents:
diff changeset
798 fprintf (f, " /* BRIG offset: %u */", symbol->m_directive_offset);
kono
parents:
diff changeset
799 }
kono
parents:
diff changeset
800
kono
parents:
diff changeset
801 /* Dump textual representation of HSA IL operand OP to file F. */
kono
parents:
diff changeset
802
kono
parents:
diff changeset
803 static void
kono
parents:
diff changeset
804 dump_hsa_operand (FILE *f, hsa_op_base *op, bool dump_reg_type = false)
kono
parents:
diff changeset
805 {
kono
parents:
diff changeset
806 if (is_a <hsa_op_immed *> (op))
kono
parents:
diff changeset
807 dump_hsa_immed (f, as_a <hsa_op_immed *> (op));
kono
parents:
diff changeset
808 else if (is_a <hsa_op_reg *> (op))
kono
parents:
diff changeset
809 dump_hsa_reg (f, as_a <hsa_op_reg *> (op), dump_reg_type);
kono
parents:
diff changeset
810 else if (is_a <hsa_op_address *> (op))
kono
parents:
diff changeset
811 dump_hsa_address (f, as_a <hsa_op_address *> (op));
kono
parents:
diff changeset
812 else
kono
parents:
diff changeset
813 fprintf (f, "UNKNOWN_OP_KIND");
kono
parents:
diff changeset
814 }
kono
parents:
diff changeset
815
kono
parents:
diff changeset
816 /* Dump textual representation of HSA IL operands in VEC to file F. */
kono
parents:
diff changeset
817
kono
parents:
diff changeset
818 static void
kono
parents:
diff changeset
819 dump_hsa_operands (FILE *f, hsa_insn_basic *insn, int start = 0,
kono
parents:
diff changeset
820 int end = -1, bool dump_reg_type = false)
kono
parents:
diff changeset
821 {
kono
parents:
diff changeset
822 if (end == -1)
kono
parents:
diff changeset
823 end = insn->operand_count ();
kono
parents:
diff changeset
824
kono
parents:
diff changeset
825 for (int i = start; i < end; i++)
kono
parents:
diff changeset
826 {
kono
parents:
diff changeset
827 dump_hsa_operand (f, insn->get_op (i), dump_reg_type);
kono
parents:
diff changeset
828 if (i != end - 1)
kono
parents:
diff changeset
829 fprintf (f, ", ");
kono
parents:
diff changeset
830 }
kono
parents:
diff changeset
831 }
kono
parents:
diff changeset
832
kono
parents:
diff changeset
833 /* Indent F stream with INDENT spaces. */
kono
parents:
diff changeset
834
kono
parents:
diff changeset
835 static void indent_stream (FILE *f, int indent)
kono
parents:
diff changeset
836 {
kono
parents:
diff changeset
837 for (int i = 0; i < indent; i++)
kono
parents:
diff changeset
838 fputc (' ', f);
kono
parents:
diff changeset
839 }
kono
parents:
diff changeset
840
kono
parents:
diff changeset
841 /* Dump textual representation of HSA IL instruction INSN to file F. Prepend
kono
parents:
diff changeset
842 the instruction with *INDENT spaces and adjust the indentation for call
kono
parents:
diff changeset
843 instructions as appropriate. */
kono
parents:
diff changeset
844
kono
parents:
diff changeset
845 static void
kono
parents:
diff changeset
846 dump_hsa_insn_1 (FILE *f, hsa_insn_basic *insn, int *indent)
kono
parents:
diff changeset
847 {
kono
parents:
diff changeset
848 gcc_checking_assert (insn);
kono
parents:
diff changeset
849
kono
parents:
diff changeset
850 if (insn->m_number)
kono
parents:
diff changeset
851 fprintf (f, "%5d: ", insn->m_number);
kono
parents:
diff changeset
852
kono
parents:
diff changeset
853 indent_stream (f, *indent);
kono
parents:
diff changeset
854
kono
parents:
diff changeset
855 if (is_a <hsa_insn_phi *> (insn))
kono
parents:
diff changeset
856 {
kono
parents:
diff changeset
857 hsa_insn_phi *phi = as_a <hsa_insn_phi *> (insn);
kono
parents:
diff changeset
858 bool first = true;
kono
parents:
diff changeset
859 dump_hsa_reg (f, phi->m_dest, true);
kono
parents:
diff changeset
860 fprintf (f, " = PHI <");
kono
parents:
diff changeset
861 unsigned count = phi->operand_count ();
kono
parents:
diff changeset
862 for (unsigned i = 0; i < count; i++)
kono
parents:
diff changeset
863 {
kono
parents:
diff changeset
864 if (!phi->get_op (i))
kono
parents:
diff changeset
865 break;
kono
parents:
diff changeset
866 if (!first)
kono
parents:
diff changeset
867 fprintf (f, ", ");
kono
parents:
diff changeset
868 else
kono
parents:
diff changeset
869 first = false;
kono
parents:
diff changeset
870 dump_hsa_operand (f, phi->get_op (i), true);
kono
parents:
diff changeset
871 }
kono
parents:
diff changeset
872 fprintf (f, ">");
kono
parents:
diff changeset
873 }
kono
parents:
diff changeset
874 else if (is_a <hsa_insn_signal *> (insn))
kono
parents:
diff changeset
875 {
kono
parents:
diff changeset
876 hsa_insn_signal *mem = as_a <hsa_insn_signal *> (insn);
kono
parents:
diff changeset
877
kono
parents:
diff changeset
878 fprintf (f, "%s", hsa_opcode_name (mem->m_opcode));
kono
parents:
diff changeset
879 fprintf (f, "_%s", hsa_m_atomicop_name (mem->m_signalop));
kono
parents:
diff changeset
880 if (mem->m_memory_order != BRIG_MEMORY_ORDER_NONE)
kono
parents:
diff changeset
881 fprintf (f, "_%s", hsa_memsem_name (mem->m_memory_order));
kono
parents:
diff changeset
882 fprintf (f, "_%s ", hsa_type_name (mem->m_type));
kono
parents:
diff changeset
883
kono
parents:
diff changeset
884 dump_hsa_operands (f, mem);
kono
parents:
diff changeset
885 }
kono
parents:
diff changeset
886
kono
parents:
diff changeset
887 else if (is_a <hsa_insn_atomic *> (insn))
kono
parents:
diff changeset
888 {
kono
parents:
diff changeset
889 hsa_insn_atomic *mem = as_a <hsa_insn_atomic *> (insn);
kono
parents:
diff changeset
890
kono
parents:
diff changeset
891 /* Either operand[0] or operand[1] must be an address operand. */
kono
parents:
diff changeset
892 hsa_op_address *addr = NULL;
kono
parents:
diff changeset
893 if (is_a <hsa_op_address *> (mem->get_op (0)))
kono
parents:
diff changeset
894 addr = as_a <hsa_op_address *> (mem->get_op (0));
kono
parents:
diff changeset
895 else
kono
parents:
diff changeset
896 addr = as_a <hsa_op_address *> (mem->get_op (1));
kono
parents:
diff changeset
897
kono
parents:
diff changeset
898 fprintf (f, "%s", hsa_opcode_name (mem->m_opcode));
kono
parents:
diff changeset
899 fprintf (f, "_%s", hsa_m_atomicop_name (mem->m_atomicop));
kono
parents:
diff changeset
900 if (addr->m_symbol)
kono
parents:
diff changeset
901 fprintf (f, "_%s", hsa_seg_name (addr->m_symbol->m_segment));
kono
parents:
diff changeset
902 if (mem->m_memoryorder != BRIG_MEMORY_ORDER_NONE)
kono
parents:
diff changeset
903 fprintf (f, "_%s", hsa_memsem_name (mem->m_memoryorder));
kono
parents:
diff changeset
904 if (mem->m_memoryscope != BRIG_MEMORY_SCOPE_NONE)
kono
parents:
diff changeset
905 fprintf (f, "_%s", hsa_memscope_name (mem->m_memoryscope));
kono
parents:
diff changeset
906 fprintf (f, "_%s ", hsa_type_name (mem->m_type));
kono
parents:
diff changeset
907
kono
parents:
diff changeset
908 dump_hsa_operands (f, mem);
kono
parents:
diff changeset
909 }
kono
parents:
diff changeset
910 else if (is_a <hsa_insn_mem *> (insn))
kono
parents:
diff changeset
911 {
kono
parents:
diff changeset
912 hsa_insn_mem *mem = as_a <hsa_insn_mem *> (insn);
kono
parents:
diff changeset
913 hsa_op_address *addr = as_a <hsa_op_address *> (mem->get_op (1));
kono
parents:
diff changeset
914
kono
parents:
diff changeset
915 fprintf (f, "%s", hsa_opcode_name (mem->m_opcode));
kono
parents:
diff changeset
916 if (addr->m_symbol)
kono
parents:
diff changeset
917 fprintf (f, "_%s", hsa_seg_name (addr->m_symbol->m_segment));
kono
parents:
diff changeset
918 if (mem->m_align != BRIG_ALIGNMENT_NONE)
kono
parents:
diff changeset
919 fprintf (f, "_align(%u)", hsa_byte_alignment (mem->m_align));
kono
parents:
diff changeset
920 if (mem->m_equiv_class != 0)
kono
parents:
diff changeset
921 fprintf (f, "_equiv(%i)", mem->m_equiv_class);
kono
parents:
diff changeset
922 fprintf (f, "_%s ", hsa_type_name (mem->m_type));
kono
parents:
diff changeset
923
kono
parents:
diff changeset
924 dump_hsa_operand (f, mem->get_op (0));
kono
parents:
diff changeset
925 fprintf (f, ", ");
kono
parents:
diff changeset
926 dump_hsa_address (f, addr);
kono
parents:
diff changeset
927 }
kono
parents:
diff changeset
928 else if (insn->m_opcode == BRIG_OPCODE_LDA)
kono
parents:
diff changeset
929 {
kono
parents:
diff changeset
930 hsa_op_address *addr = as_a <hsa_op_address *> (insn->get_op (1));
kono
parents:
diff changeset
931
kono
parents:
diff changeset
932 fprintf (f, "%s", hsa_opcode_name (insn->m_opcode));
kono
parents:
diff changeset
933 if (addr->m_symbol)
kono
parents:
diff changeset
934 fprintf (f, "_%s", hsa_seg_name (addr->m_symbol->m_segment));
kono
parents:
diff changeset
935 fprintf (f, "_%s ", hsa_type_name (insn->m_type));
kono
parents:
diff changeset
936
kono
parents:
diff changeset
937 dump_hsa_operand (f, insn->get_op (0));
kono
parents:
diff changeset
938 fprintf (f, ", ");
kono
parents:
diff changeset
939 dump_hsa_address (f, addr);
kono
parents:
diff changeset
940 }
kono
parents:
diff changeset
941 else if (is_a <hsa_insn_seg *> (insn))
kono
parents:
diff changeset
942 {
kono
parents:
diff changeset
943 hsa_insn_seg *seg = as_a <hsa_insn_seg *> (insn);
kono
parents:
diff changeset
944 fprintf (f, "%s_%s_%s_%s ", hsa_opcode_name (seg->m_opcode),
kono
parents:
diff changeset
945 hsa_seg_name (seg->m_segment),
kono
parents:
diff changeset
946 hsa_type_name (seg->m_type), hsa_type_name (seg->m_src_type));
kono
parents:
diff changeset
947 dump_hsa_reg (f, as_a <hsa_op_reg *> (seg->get_op (0)));
kono
parents:
diff changeset
948 fprintf (f, ", ");
kono
parents:
diff changeset
949 dump_hsa_operand (f, seg->get_op (1));
kono
parents:
diff changeset
950 }
kono
parents:
diff changeset
951 else if (is_a <hsa_insn_cmp *> (insn))
kono
parents:
diff changeset
952 {
kono
parents:
diff changeset
953 hsa_insn_cmp *cmp = as_a <hsa_insn_cmp *> (insn);
kono
parents:
diff changeset
954 BrigType16_t src_type;
kono
parents:
diff changeset
955
kono
parents:
diff changeset
956 if (is_a <hsa_op_reg *> (cmp->get_op (1)))
kono
parents:
diff changeset
957 src_type = as_a <hsa_op_reg *> (cmp->get_op (1))->m_type;
kono
parents:
diff changeset
958 else
kono
parents:
diff changeset
959 src_type = as_a <hsa_op_immed *> (cmp->get_op (1))->m_type;
kono
parents:
diff changeset
960
kono
parents:
diff changeset
961 fprintf (f, "%s_%s_%s_%s ", hsa_opcode_name (cmp->m_opcode),
kono
parents:
diff changeset
962 hsa_cmpop_name (cmp->m_compare),
kono
parents:
diff changeset
963 hsa_type_name (cmp->m_type), hsa_type_name (src_type));
kono
parents:
diff changeset
964 dump_hsa_reg (f, as_a <hsa_op_reg *> (cmp->get_op (0)));
kono
parents:
diff changeset
965 fprintf (f, ", ");
kono
parents:
diff changeset
966 dump_hsa_operand (f, cmp->get_op (1));
kono
parents:
diff changeset
967 fprintf (f, ", ");
kono
parents:
diff changeset
968 dump_hsa_operand (f, cmp->get_op (2));
kono
parents:
diff changeset
969 }
kono
parents:
diff changeset
970 else if (is_a <hsa_insn_cbr *> (insn))
kono
parents:
diff changeset
971 {
kono
parents:
diff changeset
972 hsa_insn_cbr *br = as_a <hsa_insn_cbr *> (insn);
kono
parents:
diff changeset
973 basic_block target = NULL;
kono
parents:
diff changeset
974 edge_iterator ei;
kono
parents:
diff changeset
975 edge e;
kono
parents:
diff changeset
976
kono
parents:
diff changeset
977 fprintf (f, "%s ", hsa_opcode_name (br->m_opcode));
kono
parents:
diff changeset
978 if (br->m_opcode == BRIG_OPCODE_CBR)
kono
parents:
diff changeset
979 {
kono
parents:
diff changeset
980 dump_hsa_reg (f, as_a <hsa_op_reg *> (br->get_op (0)));
kono
parents:
diff changeset
981 fprintf (f, ", ");
kono
parents:
diff changeset
982 }
kono
parents:
diff changeset
983
kono
parents:
diff changeset
984 FOR_EACH_EDGE (e, ei, br->m_bb->succs)
kono
parents:
diff changeset
985 if (e->flags & EDGE_TRUE_VALUE)
kono
parents:
diff changeset
986 {
kono
parents:
diff changeset
987 target = e->dest;
kono
parents:
diff changeset
988 break;
kono
parents:
diff changeset
989 }
kono
parents:
diff changeset
990 fprintf (f, "BB %i", hsa_bb_for_bb (target)->m_index);
kono
parents:
diff changeset
991 }
kono
parents:
diff changeset
992 else if (is_a <hsa_insn_sbr *> (insn))
kono
parents:
diff changeset
993 {
kono
parents:
diff changeset
994 hsa_insn_sbr *sbr = as_a <hsa_insn_sbr *> (insn);
kono
parents:
diff changeset
995
kono
parents:
diff changeset
996 fprintf (f, "%s ", hsa_opcode_name (sbr->m_opcode));
kono
parents:
diff changeset
997 dump_hsa_reg (f, as_a <hsa_op_reg *> (sbr->get_op (0)));
kono
parents:
diff changeset
998 fprintf (f, ", [");
kono
parents:
diff changeset
999
kono
parents:
diff changeset
1000 for (unsigned i = 0; i < sbr->m_jump_table.length (); i++)
kono
parents:
diff changeset
1001 {
kono
parents:
diff changeset
1002 fprintf (f, "BB %i", hsa_bb_for_bb (sbr->m_jump_table[i])->m_index);
kono
parents:
diff changeset
1003 if (i != sbr->m_jump_table.length () - 1)
kono
parents:
diff changeset
1004 fprintf (f, ", ");
kono
parents:
diff changeset
1005 }
kono
parents:
diff changeset
1006 }
kono
parents:
diff changeset
1007 else if (is_a <hsa_insn_br *> (insn))
kono
parents:
diff changeset
1008 {
kono
parents:
diff changeset
1009 hsa_insn_br *br = as_a <hsa_insn_br *> (insn);
kono
parents:
diff changeset
1010 fprintf (f, "%s_width(%s) ", hsa_opcode_name (br->m_opcode),
kono
parents:
diff changeset
1011 hsa_width_specifier_name (br->m_width));
kono
parents:
diff changeset
1012 }
kono
parents:
diff changeset
1013 else if (is_a <hsa_insn_arg_block *> (insn))
kono
parents:
diff changeset
1014 {
kono
parents:
diff changeset
1015 hsa_insn_arg_block *arg_block = as_a <hsa_insn_arg_block *> (insn);
kono
parents:
diff changeset
1016 bool start_p = arg_block->m_kind == BRIG_KIND_DIRECTIVE_ARG_BLOCK_START;
kono
parents:
diff changeset
1017 char c = start_p ? '{' : '}';
kono
parents:
diff changeset
1018
kono
parents:
diff changeset
1019 if (start_p)
kono
parents:
diff changeset
1020 {
kono
parents:
diff changeset
1021 *indent += 2;
kono
parents:
diff changeset
1022 indent_stream (f, 2);
kono
parents:
diff changeset
1023 }
kono
parents:
diff changeset
1024
kono
parents:
diff changeset
1025 if (!start_p)
kono
parents:
diff changeset
1026 *indent -= 2;
kono
parents:
diff changeset
1027
kono
parents:
diff changeset
1028 fprintf (f, "%c", c);
kono
parents:
diff changeset
1029 }
kono
parents:
diff changeset
1030 else if (is_a <hsa_insn_call *> (insn))
kono
parents:
diff changeset
1031 {
kono
parents:
diff changeset
1032 hsa_insn_call *call = as_a <hsa_insn_call *> (insn);
kono
parents:
diff changeset
1033 if (call->m_called_function)
kono
parents:
diff changeset
1034 {
kono
parents:
diff changeset
1035 const char *name = hsa_get_declaration_name (call->m_called_function);
kono
parents:
diff changeset
1036 fprintf (f, "call &%s", name);
kono
parents:
diff changeset
1037 }
kono
parents:
diff changeset
1038 else
kono
parents:
diff changeset
1039 {
kono
parents:
diff changeset
1040 char *name = call->m_called_internal_fn->name ();
kono
parents:
diff changeset
1041 fprintf (f, "call &%s", name);
kono
parents:
diff changeset
1042 free (name);
kono
parents:
diff changeset
1043 }
kono
parents:
diff changeset
1044
kono
parents:
diff changeset
1045 if (call->m_output_arg)
kono
parents:
diff changeset
1046 fprintf (f, "(%%res) ");
kono
parents:
diff changeset
1047
kono
parents:
diff changeset
1048 fprintf (f, "(");
kono
parents:
diff changeset
1049 for (unsigned i = 0; i < call->m_input_args.length (); i++)
kono
parents:
diff changeset
1050 {
kono
parents:
diff changeset
1051 fprintf (f, "%%__arg_%u", i);
kono
parents:
diff changeset
1052
kono
parents:
diff changeset
1053 if (i != call->m_input_args.length () - 1)
kono
parents:
diff changeset
1054 fprintf (f, ", ");
kono
parents:
diff changeset
1055 }
kono
parents:
diff changeset
1056 fprintf (f, ")");
kono
parents:
diff changeset
1057 }
kono
parents:
diff changeset
1058 else if (is_a <hsa_insn_comment *> (insn))
kono
parents:
diff changeset
1059 {
kono
parents:
diff changeset
1060 hsa_insn_comment *c = as_a <hsa_insn_comment *> (insn);
kono
parents:
diff changeset
1061 fprintf (f, "%s", c->m_comment);
kono
parents:
diff changeset
1062 }
kono
parents:
diff changeset
1063 else if (is_a <hsa_insn_srctype *> (insn))
kono
parents:
diff changeset
1064 {
kono
parents:
diff changeset
1065 hsa_insn_srctype *srctype = as_a <hsa_insn_srctype *> (insn);
kono
parents:
diff changeset
1066
kono
parents:
diff changeset
1067 fprintf (f, "%s_%s_%s ", hsa_opcode_name (srctype->m_opcode),
kono
parents:
diff changeset
1068 hsa_type_name (srctype->m_type),
kono
parents:
diff changeset
1069 hsa_type_name (srctype->m_source_type));
kono
parents:
diff changeset
1070
kono
parents:
diff changeset
1071 dump_hsa_operands (f, insn);
kono
parents:
diff changeset
1072 }
kono
parents:
diff changeset
1073 else if (is_a <hsa_insn_packed *> (insn))
kono
parents:
diff changeset
1074 {
kono
parents:
diff changeset
1075 hsa_insn_packed *packed = as_a <hsa_insn_packed *> (insn);
kono
parents:
diff changeset
1076
kono
parents:
diff changeset
1077 fprintf (f, "%s_v%u_%s_%s ", hsa_opcode_name (packed->m_opcode),
kono
parents:
diff changeset
1078 packed->operand_count () - 1,
kono
parents:
diff changeset
1079 hsa_type_name (packed->m_type),
kono
parents:
diff changeset
1080 hsa_type_name (packed->m_source_type));
kono
parents:
diff changeset
1081
kono
parents:
diff changeset
1082 if (packed->m_opcode == BRIG_OPCODE_COMBINE)
kono
parents:
diff changeset
1083 {
kono
parents:
diff changeset
1084 dump_hsa_operand (f, insn->get_op (0));
kono
parents:
diff changeset
1085 fprintf (f, ", (");
kono
parents:
diff changeset
1086 dump_hsa_operands (f, insn, 1);
kono
parents:
diff changeset
1087 fprintf (f, ")");
kono
parents:
diff changeset
1088 }
kono
parents:
diff changeset
1089 else if (packed->m_opcode == BRIG_OPCODE_EXPAND)
kono
parents:
diff changeset
1090 {
kono
parents:
diff changeset
1091 fprintf (f, "(");
kono
parents:
diff changeset
1092 dump_hsa_operands (f, insn, 0, insn->operand_count () - 1);
kono
parents:
diff changeset
1093 fprintf (f, "), ");
kono
parents:
diff changeset
1094 dump_hsa_operand (f, insn->get_op (insn->operand_count () - 1));
kono
parents:
diff changeset
1095
kono
parents:
diff changeset
1096 }
kono
parents:
diff changeset
1097 else
kono
parents:
diff changeset
1098 gcc_unreachable ();
kono
parents:
diff changeset
1099 }
kono
parents:
diff changeset
1100 else if (is_a <hsa_insn_alloca *> (insn))
kono
parents:
diff changeset
1101 {
kono
parents:
diff changeset
1102 hsa_insn_alloca *alloca = as_a <hsa_insn_alloca *> (insn);
kono
parents:
diff changeset
1103
kono
parents:
diff changeset
1104 fprintf (f, "%s_align(%u)_%s ", hsa_opcode_name (insn->m_opcode),
kono
parents:
diff changeset
1105 hsa_byte_alignment (alloca->m_align),
kono
parents:
diff changeset
1106 hsa_type_name (insn->m_type));
kono
parents:
diff changeset
1107
kono
parents:
diff changeset
1108 dump_hsa_operands (f, insn);
kono
parents:
diff changeset
1109 }
kono
parents:
diff changeset
1110 else if (hsa_insn_queue *qi = dyn_cast <hsa_insn_queue *> (insn))
kono
parents:
diff changeset
1111 {
kono
parents:
diff changeset
1112 fprintf (f, "%s_%s_%s_%s ", hsa_opcode_name (qi->m_opcode),
kono
parents:
diff changeset
1113 hsa_seg_name (qi->m_segment),
kono
parents:
diff changeset
1114 hsa_memsem_name (qi->m_memory_order),
kono
parents:
diff changeset
1115 hsa_type_name (qi->m_type));
kono
parents:
diff changeset
1116
kono
parents:
diff changeset
1117 dump_hsa_operands (f, qi);
kono
parents:
diff changeset
1118 }
kono
parents:
diff changeset
1119 else
kono
parents:
diff changeset
1120 {
kono
parents:
diff changeset
1121 fprintf (f, "%s_%s ", hsa_opcode_name (insn->m_opcode),
kono
parents:
diff changeset
1122 hsa_type_name (insn->m_type));
kono
parents:
diff changeset
1123
kono
parents:
diff changeset
1124 dump_hsa_operands (f, insn);
kono
parents:
diff changeset
1125 }
kono
parents:
diff changeset
1126
kono
parents:
diff changeset
1127 if (insn->m_brig_offset)
kono
parents:
diff changeset
1128 {
kono
parents:
diff changeset
1129 fprintf (f, " /* BRIG offset: %u", insn->m_brig_offset);
kono
parents:
diff changeset
1130
kono
parents:
diff changeset
1131 for (unsigned i = 0; i < insn->operand_count (); i++)
kono
parents:
diff changeset
1132 fprintf (f, ", op%u: %u", i, insn->get_op (i)->m_brig_op_offset);
kono
parents:
diff changeset
1133
kono
parents:
diff changeset
1134 fprintf (f, " */");
kono
parents:
diff changeset
1135 }
kono
parents:
diff changeset
1136
kono
parents:
diff changeset
1137 fprintf (f, "\n");
kono
parents:
diff changeset
1138 }
kono
parents:
diff changeset
1139
kono
parents:
diff changeset
1140 /* Dump textual representation of HSA IL instruction INSN to file F. */
kono
parents:
diff changeset
1141
kono
parents:
diff changeset
1142 void
kono
parents:
diff changeset
1143 dump_hsa_insn (FILE *f, hsa_insn_basic *insn)
kono
parents:
diff changeset
1144 {
kono
parents:
diff changeset
1145 int indent = 0;
kono
parents:
diff changeset
1146 dump_hsa_insn_1 (f, insn, &indent);
kono
parents:
diff changeset
1147 }
kono
parents:
diff changeset
1148
kono
parents:
diff changeset
1149 /* Dump textual representation of HSA IL in HBB to file F. */
kono
parents:
diff changeset
1150
kono
parents:
diff changeset
1151 void
kono
parents:
diff changeset
1152 dump_hsa_bb (FILE *f, hsa_bb *hbb)
kono
parents:
diff changeset
1153 {
kono
parents:
diff changeset
1154 hsa_insn_basic *insn;
kono
parents:
diff changeset
1155 edge_iterator ei;
kono
parents:
diff changeset
1156 edge e;
kono
parents:
diff changeset
1157 basic_block true_bb = NULL, other = NULL;
kono
parents:
diff changeset
1158
kono
parents:
diff changeset
1159 fprintf (f, "BB %i:\n", hbb->m_index);
kono
parents:
diff changeset
1160
kono
parents:
diff changeset
1161 int indent = 2;
kono
parents:
diff changeset
1162 for (insn = hbb->m_first_phi; insn; insn = insn->m_next)
kono
parents:
diff changeset
1163 dump_hsa_insn_1 (f, insn, &indent);
kono
parents:
diff changeset
1164
kono
parents:
diff changeset
1165 for (insn = hbb->m_first_insn; insn; insn = insn->m_next)
kono
parents:
diff changeset
1166 dump_hsa_insn_1 (f, insn, &indent);
kono
parents:
diff changeset
1167
kono
parents:
diff changeset
1168 if (hbb->m_last_insn && is_a <hsa_insn_sbr *> (hbb->m_last_insn))
kono
parents:
diff changeset
1169 goto exit;
kono
parents:
diff changeset
1170
kono
parents:
diff changeset
1171 FOR_EACH_EDGE (e, ei, hbb->m_bb->succs)
kono
parents:
diff changeset
1172 if (e->flags & EDGE_TRUE_VALUE)
kono
parents:
diff changeset
1173 {
kono
parents:
diff changeset
1174 gcc_assert (!true_bb);
kono
parents:
diff changeset
1175 true_bb = e->dest;
kono
parents:
diff changeset
1176 }
kono
parents:
diff changeset
1177 else
kono
parents:
diff changeset
1178 {
kono
parents:
diff changeset
1179 gcc_assert (!other);
kono
parents:
diff changeset
1180 other = e->dest;
kono
parents:
diff changeset
1181 }
kono
parents:
diff changeset
1182
kono
parents:
diff changeset
1183 if (true_bb)
kono
parents:
diff changeset
1184 {
kono
parents:
diff changeset
1185 if (!hbb->m_last_insn
kono
parents:
diff changeset
1186 || hbb->m_last_insn->m_opcode != BRIG_OPCODE_CBR)
kono
parents:
diff changeset
1187 fprintf (f, "WARNING: No branch insn for a true edge. \n");
kono
parents:
diff changeset
1188 }
kono
parents:
diff changeset
1189 else if (hbb->m_last_insn
kono
parents:
diff changeset
1190 && hbb->m_last_insn->m_opcode == BRIG_OPCODE_CBR)
kono
parents:
diff changeset
1191 fprintf (f, "WARNING: No true edge for a cbr statement\n");
kono
parents:
diff changeset
1192
kono
parents:
diff changeset
1193 if (other && other->aux)
kono
parents:
diff changeset
1194 fprintf (f, " Fall-through to BB %i\n",
kono
parents:
diff changeset
1195 hsa_bb_for_bb (other)->m_index);
kono
parents:
diff changeset
1196 else if (hbb->m_last_insn
kono
parents:
diff changeset
1197 && hbb->m_last_insn->m_opcode != BRIG_OPCODE_RET)
kono
parents:
diff changeset
1198 fprintf (f, " WARNING: Fall through to a BB with no aux!\n");
kono
parents:
diff changeset
1199
kono
parents:
diff changeset
1200 exit:
kono
parents:
diff changeset
1201 fprintf (f, "\n");
kono
parents:
diff changeset
1202 }
kono
parents:
diff changeset
1203
kono
parents:
diff changeset
1204 /* Dump textual representation of HSA IL of the current function to file F. */
kono
parents:
diff changeset
1205
kono
parents:
diff changeset
1206 void
kono
parents:
diff changeset
1207 dump_hsa_cfun (FILE *f)
kono
parents:
diff changeset
1208 {
kono
parents:
diff changeset
1209 basic_block bb;
kono
parents:
diff changeset
1210
kono
parents:
diff changeset
1211 if (hsa_cfun->m_global_symbols.length () > 0)
kono
parents:
diff changeset
1212 fprintf (f, "\nHSAIL in global scope\n");
kono
parents:
diff changeset
1213
kono
parents:
diff changeset
1214 for (unsigned i = 0; i < hsa_cfun->m_global_symbols.length (); i++)
kono
parents:
diff changeset
1215 {
kono
parents:
diff changeset
1216 fprintf (f, " ");
kono
parents:
diff changeset
1217 dump_hsa_symbol (f, hsa_cfun->m_global_symbols[i]);
kono
parents:
diff changeset
1218 fprintf (f, "\n");
kono
parents:
diff changeset
1219 }
kono
parents:
diff changeset
1220
kono
parents:
diff changeset
1221 fprintf (f, "\nHSAIL IL for %s\n", hsa_cfun->m_name);
kono
parents:
diff changeset
1222
kono
parents:
diff changeset
1223 for (unsigned i = 0; i < hsa_cfun->m_private_variables.length (); i++)
kono
parents:
diff changeset
1224 {
kono
parents:
diff changeset
1225 fprintf (f, " ");
kono
parents:
diff changeset
1226 dump_hsa_symbol (f, hsa_cfun->m_private_variables[i]);
kono
parents:
diff changeset
1227 fprintf (f, "\n");
kono
parents:
diff changeset
1228 }
kono
parents:
diff changeset
1229
kono
parents:
diff changeset
1230 FOR_ALL_BB_FN (bb, cfun)
kono
parents:
diff changeset
1231 {
kono
parents:
diff changeset
1232 hsa_bb *hbb = (struct hsa_bb *) bb->aux;
kono
parents:
diff changeset
1233 dump_hsa_bb (f, hbb);
kono
parents:
diff changeset
1234 }
kono
parents:
diff changeset
1235 }
kono
parents:
diff changeset
1236
kono
parents:
diff changeset
1237 /* Dump textual representation of HSA IL instruction INSN to stderr. */
kono
parents:
diff changeset
1238
kono
parents:
diff changeset
1239 DEBUG_FUNCTION void
kono
parents:
diff changeset
1240 debug_hsa_insn (hsa_insn_basic *insn)
kono
parents:
diff changeset
1241 {
kono
parents:
diff changeset
1242 dump_hsa_insn (stderr, insn);
kono
parents:
diff changeset
1243 }
kono
parents:
diff changeset
1244
kono
parents:
diff changeset
1245 /* Dump textual representation of HSA IL in HBB to stderr. */
kono
parents:
diff changeset
1246
kono
parents:
diff changeset
1247 DEBUG_FUNCTION void
kono
parents:
diff changeset
1248 debug_hsa_bb (hsa_bb *hbb)
kono
parents:
diff changeset
1249 {
kono
parents:
diff changeset
1250 dump_hsa_bb (stderr, hbb);
kono
parents:
diff changeset
1251 }
kono
parents:
diff changeset
1252
kono
parents:
diff changeset
1253 /* Dump textual representation of HSA IL of the current function to stderr. */
kono
parents:
diff changeset
1254
kono
parents:
diff changeset
1255 DEBUG_FUNCTION void
kono
parents:
diff changeset
1256 debug_hsa_cfun (void)
kono
parents:
diff changeset
1257 {
kono
parents:
diff changeset
1258 dump_hsa_cfun (stderr);
kono
parents:
diff changeset
1259 }
kono
parents:
diff changeset
1260
kono
parents:
diff changeset
1261 /* Dump textual representation of an HSA operand to stderr. */
kono
parents:
diff changeset
1262
kono
parents:
diff changeset
1263 DEBUG_FUNCTION void
kono
parents:
diff changeset
1264 debug_hsa_operand (hsa_op_base *opc)
kono
parents:
diff changeset
1265 {
kono
parents:
diff changeset
1266 dump_hsa_operand (stderr, opc, true);
kono
parents:
diff changeset
1267 fprintf (stderr, "\n");
kono
parents:
diff changeset
1268 }
kono
parents:
diff changeset
1269
kono
parents:
diff changeset
1270 /* Dump textual representation of as HSA symbol. */
kono
parents:
diff changeset
1271
kono
parents:
diff changeset
1272 DEBUG_FUNCTION void
kono
parents:
diff changeset
1273 debug_hsa_symbol (hsa_symbol *symbol)
kono
parents:
diff changeset
1274 {
kono
parents:
diff changeset
1275 dump_hsa_symbol (stderr, symbol);
kono
parents:
diff changeset
1276 fprintf (stderr, "\n");
kono
parents:
diff changeset
1277 }