xref: /aosp_15_r20/external/mesa3d/src/freedreno/ir3/ir3_parser.y (revision 6104692788411f58d303aa86923a9ff6ecaded22)
1*61046927SAndroid Build Coastguard Worker /*
2*61046927SAndroid Build Coastguard Worker  * Copyright (c) 2013 Rob Clark <[email protected]>
3*61046927SAndroid Build Coastguard Worker  *
4*61046927SAndroid Build Coastguard Worker  * Permission is hereby granted, free of charge, to any person obtaining a
5*61046927SAndroid Build Coastguard Worker  * copy of this software and associated documentation files (the "Software"),
6*61046927SAndroid Build Coastguard Worker  * to deal in the Software without restriction, including without limitation
7*61046927SAndroid Build Coastguard Worker  * the rights to use, copy, modify, merge, publish, distribute, sublicense,
8*61046927SAndroid Build Coastguard Worker  * and/or sell copies of the Software, and to permit persons to whom the
9*61046927SAndroid Build Coastguard Worker  * Software is furnished to do so, subject to the following conditions:
10*61046927SAndroid Build Coastguard Worker  *
11*61046927SAndroid Build Coastguard Worker  * The above copyright notice and this permission notice (including the next
12*61046927SAndroid Build Coastguard Worker  * paragraph) shall be included in all copies or substantial portions of the
13*61046927SAndroid Build Coastguard Worker  * Software.
14*61046927SAndroid Build Coastguard Worker  *
15*61046927SAndroid Build Coastguard Worker  * THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR
16*61046927SAndroid Build Coastguard Worker  * IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY,
17*61046927SAndroid Build Coastguard Worker  * FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT.  IN NO EVENT SHALL
18*61046927SAndroid Build Coastguard Worker  * THE AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER
19*61046927SAndroid Build Coastguard Worker  * LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM,
20*61046927SAndroid Build Coastguard Worker  * OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE
21*61046927SAndroid Build Coastguard Worker  * SOFTWARE.
22*61046927SAndroid Build Coastguard Worker  */
23*61046927SAndroid Build Coastguard Worker 
24*61046927SAndroid Build Coastguard Worker %code requires {
25*61046927SAndroid Build Coastguard Worker #include "ir3/ir3_assembler.h"
26*61046927SAndroid Build Coastguard Worker #include "ir3/ir3_shader.h"
27*61046927SAndroid Build Coastguard Worker 
28*61046927SAndroid Build Coastguard Worker struct ir3 * ir3_parse(struct ir3_shader_variant *v,
29*61046927SAndroid Build Coastguard Worker 		struct ir3_kernel_info *k, FILE *f);
30*61046927SAndroid Build Coastguard Worker }
31*61046927SAndroid Build Coastguard Worker 
32*61046927SAndroid Build Coastguard Worker %{
33*61046927SAndroid Build Coastguard Worker #define YYDEBUG 0
34*61046927SAndroid Build Coastguard Worker 
35*61046927SAndroid Build Coastguard Worker #include <stdlib.h>
36*61046927SAndroid Build Coastguard Worker #include <stdio.h>
37*61046927SAndroid Build Coastguard Worker #include <string.h>
38*61046927SAndroid Build Coastguard Worker #include <math.h>
39*61046927SAndroid Build Coastguard Worker 
40*61046927SAndroid Build Coastguard Worker #include "util/half_float.h"
41*61046927SAndroid Build Coastguard Worker #include "util/u_math.h"
42*61046927SAndroid Build Coastguard Worker 
43*61046927SAndroid Build Coastguard Worker #include "ir3/ir3.h"
44*61046927SAndroid Build Coastguard Worker #include "ir3/ir3_shader.h"
45*61046927SAndroid Build Coastguard Worker #include "ir3/instr-a3xx.h"
46*61046927SAndroid Build Coastguard Worker 
47*61046927SAndroid Build Coastguard Worker #include "ir3_parser.h"
48*61046927SAndroid Build Coastguard Worker 
49*61046927SAndroid Build Coastguard Worker #define swap(a, b) \
50*61046927SAndroid Build Coastguard Worker 	do { __typeof(a) __tmp = (a); (a) = (b); (b) = __tmp; } while (0)
51*61046927SAndroid Build Coastguard Worker 
52*61046927SAndroid Build Coastguard Worker /* ir3 treats the abs/neg flags as separate flags for float vs integer,
53*61046927SAndroid Build Coastguard Worker  * but in the instruction encoding they are the same thing.  Tracking
54*61046927SAndroid Build Coastguard Worker  * them separately is only for the benefit of ir3 opt passes, and not
55*61046927SAndroid Build Coastguard Worker  * required here, so just use the float versions:
56*61046927SAndroid Build Coastguard Worker  */
57*61046927SAndroid Build Coastguard Worker #define IR3_REG_ABS     IR3_REG_FABS
58*61046927SAndroid Build Coastguard Worker #define IR3_REG_NEGATE  IR3_REG_FNEG
59*61046927SAndroid Build Coastguard Worker 
60*61046927SAndroid Build Coastguard Worker static struct ir3_kernel_info    *info;
61*61046927SAndroid Build Coastguard Worker static struct ir3_shader_variant *variant;
62*61046927SAndroid Build Coastguard Worker /* NOTE the assembler doesn't really use the ir3_block construction
63*61046927SAndroid Build Coastguard Worker  * like the compiler does.  Everything is treated as one large block.
64*61046927SAndroid Build Coastguard Worker  * Which might happen to contain flow control.  But since we don't
65*61046927SAndroid Build Coastguard Worker  * use any of the ir3 backend passes (sched, RA, etc) this doesn't
66*61046927SAndroid Build Coastguard Worker  * really matter.
67*61046927SAndroid Build Coastguard Worker  */
68*61046927SAndroid Build Coastguard Worker static struct ir3_block          *block;   /* current shader block */
69*61046927SAndroid Build Coastguard Worker static struct ir3_instruction    *instr;   /* current instruction */
70*61046927SAndroid Build Coastguard Worker static unsigned ip; /* current instruction pointer */
71*61046927SAndroid Build Coastguard Worker static struct hash_table *labels;
72*61046927SAndroid Build Coastguard Worker 
73*61046927SAndroid Build Coastguard Worker void *ir3_parser_dead_ctx;
74*61046927SAndroid Build Coastguard Worker 
75*61046927SAndroid Build Coastguard Worker static struct {
76*61046927SAndroid Build Coastguard Worker 	unsigned flags;
77*61046927SAndroid Build Coastguard Worker 	unsigned repeat;
78*61046927SAndroid Build Coastguard Worker 	unsigned nop;
79*61046927SAndroid Build Coastguard Worker } iflags;
80*61046927SAndroid Build Coastguard Worker 
81*61046927SAndroid Build Coastguard Worker static struct {
82*61046927SAndroid Build Coastguard Worker 	unsigned flags;
83*61046927SAndroid Build Coastguard Worker 	unsigned wrmask;
84*61046927SAndroid Build Coastguard Worker } rflags;
85*61046927SAndroid Build Coastguard Worker 
86*61046927SAndroid Build Coastguard Worker static struct {
87*61046927SAndroid Build Coastguard Worker         uint32_t reg_address_hi;
88*61046927SAndroid Build Coastguard Worker         uint32_t reg_address_lo;
89*61046927SAndroid Build Coastguard Worker         uint32_t reg_tmp;
90*61046927SAndroid Build Coastguard Worker 
91*61046927SAndroid Build Coastguard Worker         uint32_t regs_to_dump[128];
92*61046927SAndroid Build Coastguard Worker         uint32_t regs_count;
93*61046927SAndroid Build Coastguard Worker } meta_print_data;
94*61046927SAndroid Build Coastguard Worker 
95*61046927SAndroid Build Coastguard Worker int ir3_yyget_lineno(void);
96*61046927SAndroid Build Coastguard Worker 
new_label(const char * name)97*61046927SAndroid Build Coastguard Worker static void new_label(const char *name)
98*61046927SAndroid Build Coastguard Worker {
99*61046927SAndroid Build Coastguard Worker 	ralloc_steal(labels, (void *) name);
100*61046927SAndroid Build Coastguard Worker 	_mesa_hash_table_insert(labels, name, (void *)(uintptr_t)ip);
101*61046927SAndroid Build Coastguard Worker }
102*61046927SAndroid Build Coastguard Worker 
new_instr(opc_t opc)103*61046927SAndroid Build Coastguard Worker static struct ir3_instruction * new_instr(opc_t opc)
104*61046927SAndroid Build Coastguard Worker {
105*61046927SAndroid Build Coastguard Worker 	instr = ir3_instr_create_at_end(block, opc, 4, 6);
106*61046927SAndroid Build Coastguard Worker 	instr->flags = iflags.flags;
107*61046927SAndroid Build Coastguard Worker 	instr->repeat = iflags.repeat;
108*61046927SAndroid Build Coastguard Worker 	instr->nop = iflags.nop;
109*61046927SAndroid Build Coastguard Worker 	instr->line = ir3_yyget_lineno();
110*61046927SAndroid Build Coastguard Worker 	iflags.flags = iflags.repeat = iflags.nop = 0;
111*61046927SAndroid Build Coastguard Worker 	ip++;
112*61046927SAndroid Build Coastguard Worker 	return instr;
113*61046927SAndroid Build Coastguard Worker }
114*61046927SAndroid Build Coastguard Worker 
new_shader(void)115*61046927SAndroid Build Coastguard Worker static void new_shader(void)
116*61046927SAndroid Build Coastguard Worker {
117*61046927SAndroid Build Coastguard Worker 	variant->ir = ir3_create(variant->compiler, variant);
118*61046927SAndroid Build Coastguard Worker 	block = ir3_block_create(variant->ir);
119*61046927SAndroid Build Coastguard Worker 	list_addtail(&block->node, &variant->ir->block_list);
120*61046927SAndroid Build Coastguard Worker 	ip = 0;
121*61046927SAndroid Build Coastguard Worker 	labels = _mesa_hash_table_create(variant, _mesa_hash_string, _mesa_key_string_equal);
122*61046927SAndroid Build Coastguard Worker 	ir3_parser_dead_ctx = ralloc_context(NULL);
123*61046927SAndroid Build Coastguard Worker }
124*61046927SAndroid Build Coastguard Worker 
parse_type(const char ** type)125*61046927SAndroid Build Coastguard Worker static type_t parse_type(const char **type)
126*61046927SAndroid Build Coastguard Worker {
127*61046927SAndroid Build Coastguard Worker 	if (!strncmp("f16", *type, 3)) {
128*61046927SAndroid Build Coastguard Worker 		*type += 3;
129*61046927SAndroid Build Coastguard Worker 		return TYPE_F16;
130*61046927SAndroid Build Coastguard Worker 	} else if (!strncmp("f32", *type, 3)) {
131*61046927SAndroid Build Coastguard Worker 		*type += 3;
132*61046927SAndroid Build Coastguard Worker 		return TYPE_F32;
133*61046927SAndroid Build Coastguard Worker 	} else if (!strncmp("u16", *type, 3)) {
134*61046927SAndroid Build Coastguard Worker 		*type += 3;
135*61046927SAndroid Build Coastguard Worker 		return TYPE_U16;
136*61046927SAndroid Build Coastguard Worker 	} else if (!strncmp("u32", *type, 3)) {
137*61046927SAndroid Build Coastguard Worker 		*type += 3;
138*61046927SAndroid Build Coastguard Worker 		return TYPE_U32;
139*61046927SAndroid Build Coastguard Worker 	} else if (!strncmp("s16", *type, 3)) {
140*61046927SAndroid Build Coastguard Worker 		*type += 3;
141*61046927SAndroid Build Coastguard Worker 		return TYPE_S16;
142*61046927SAndroid Build Coastguard Worker 	} else if (!strncmp("s32", *type, 3)) {
143*61046927SAndroid Build Coastguard Worker 		*type += 3;
144*61046927SAndroid Build Coastguard Worker 		return TYPE_S32;
145*61046927SAndroid Build Coastguard Worker 	} else if (!strncmp("u8", *type, 2)) {
146*61046927SAndroid Build Coastguard Worker 		*type += 2;
147*61046927SAndroid Build Coastguard Worker 		return TYPE_U8;
148*61046927SAndroid Build Coastguard Worker 	} else if (!strncmp("u8_32", *type, 5)) {
149*61046927SAndroid Build Coastguard Worker 		*type += 5;
150*61046927SAndroid Build Coastguard Worker 		return TYPE_U8_32;
151*61046927SAndroid Build Coastguard Worker 	} else {
152*61046927SAndroid Build Coastguard Worker 		assert(0);  /* shouldn't get here */
153*61046927SAndroid Build Coastguard Worker 		return ~0;
154*61046927SAndroid Build Coastguard Worker 	}
155*61046927SAndroid Build Coastguard Worker }
156*61046927SAndroid Build Coastguard Worker 
parse_type_type(struct ir3_instruction * instr,const char * type_type)157*61046927SAndroid Build Coastguard Worker static struct ir3_instruction * parse_type_type(struct ir3_instruction *instr,
158*61046927SAndroid Build Coastguard Worker 		const char *type_type)
159*61046927SAndroid Build Coastguard Worker {
160*61046927SAndroid Build Coastguard Worker 	instr->cat1.src_type = parse_type(&type_type);
161*61046927SAndroid Build Coastguard Worker 	instr->cat1.dst_type = parse_type(&type_type);
162*61046927SAndroid Build Coastguard Worker 	return instr;
163*61046927SAndroid Build Coastguard Worker }
164*61046927SAndroid Build Coastguard Worker 
new_src(int num,unsigned flags)165*61046927SAndroid Build Coastguard Worker static struct ir3_register * new_src(int num, unsigned flags)
166*61046927SAndroid Build Coastguard Worker {
167*61046927SAndroid Build Coastguard Worker 	struct ir3_register *reg;
168*61046927SAndroid Build Coastguard Worker 	flags |= rflags.flags;
169*61046927SAndroid Build Coastguard Worker 	if (num & 0x1)
170*61046927SAndroid Build Coastguard Worker 		flags |= IR3_REG_HALF;
171*61046927SAndroid Build Coastguard Worker 	reg = ir3_src_create(instr, num>>1, flags);
172*61046927SAndroid Build Coastguard Worker 	reg->wrmask = MAX2(1, rflags.wrmask);
173*61046927SAndroid Build Coastguard Worker 	rflags.flags = rflags.wrmask = 0;
174*61046927SAndroid Build Coastguard Worker 	return reg;
175*61046927SAndroid Build Coastguard Worker }
176*61046927SAndroid Build Coastguard Worker 
new_dst(int num,unsigned flags)177*61046927SAndroid Build Coastguard Worker static struct ir3_register * new_dst(int num, unsigned flags)
178*61046927SAndroid Build Coastguard Worker {
179*61046927SAndroid Build Coastguard Worker 	struct ir3_register *reg;
180*61046927SAndroid Build Coastguard Worker 	flags |= rflags.flags;
181*61046927SAndroid Build Coastguard Worker 	if (num & 0x1)
182*61046927SAndroid Build Coastguard Worker 		flags |= IR3_REG_HALF;
183*61046927SAndroid Build Coastguard Worker 	reg = ir3_dst_create(instr, num>>1, flags);
184*61046927SAndroid Build Coastguard Worker 	reg->wrmask = MAX2(1, rflags.wrmask);
185*61046927SAndroid Build Coastguard Worker 	rflags.flags = rflags.wrmask = 0;
186*61046927SAndroid Build Coastguard Worker 	return reg;
187*61046927SAndroid Build Coastguard Worker }
188*61046927SAndroid Build Coastguard Worker 
dummy_dst(void)189*61046927SAndroid Build Coastguard Worker static struct ir3_register * dummy_dst(void)
190*61046927SAndroid Build Coastguard Worker {
191*61046927SAndroid Build Coastguard Worker 	return new_dst(0, 0);
192*61046927SAndroid Build Coastguard Worker }
193*61046927SAndroid Build Coastguard Worker 
fixup_cat5_s2en(void)194*61046927SAndroid Build Coastguard Worker static void fixup_cat5_s2en(void)
195*61046927SAndroid Build Coastguard Worker {
196*61046927SAndroid Build Coastguard Worker 	assert(opc_cat(instr->opc) == 5);
197*61046927SAndroid Build Coastguard Worker 	if (!(instr->flags & IR3_INSTR_S2EN))
198*61046927SAndroid Build Coastguard Worker 		return;
199*61046927SAndroid Build Coastguard Worker 	/* For various reasons (ie. mainly to make the .s2en src easier to
200*61046927SAndroid Build Coastguard Worker 	 * find, given that various different cat5 tex instructions can have
201*61046927SAndroid Build Coastguard Worker 	 * different # of src registers), in ir3 the samp/tex src register
202*61046927SAndroid Build Coastguard Worker 	 * is first, rather than last.  So we have to detect this case and
203*61046927SAndroid Build Coastguard Worker 	 * fix things up.
204*61046927SAndroid Build Coastguard Worker 	 */
205*61046927SAndroid Build Coastguard Worker 	struct ir3_register *s2en_src = instr->srcs[instr->srcs_count - 1];
206*61046927SAndroid Build Coastguard Worker 
207*61046927SAndroid Build Coastguard Worker 	if (instr->flags & IR3_INSTR_B)
208*61046927SAndroid Build Coastguard Worker 		assert(!(s2en_src->flags & IR3_REG_HALF));
209*61046927SAndroid Build Coastguard Worker 	else
210*61046927SAndroid Build Coastguard Worker 		assert(s2en_src->flags & IR3_REG_HALF);
211*61046927SAndroid Build Coastguard Worker 
212*61046927SAndroid Build Coastguard Worker 	for (int i = 0; i < instr->srcs_count - 1; i++) {
213*61046927SAndroid Build Coastguard Worker 		instr->srcs[i+1] = instr->srcs[i];
214*61046927SAndroid Build Coastguard Worker 	}
215*61046927SAndroid Build Coastguard Worker 	instr->srcs[0] = s2en_src;
216*61046927SAndroid Build Coastguard Worker }
217*61046927SAndroid Build Coastguard Worker 
add_const(unsigned reg,unsigned c0,unsigned c1,unsigned c2,unsigned c3)218*61046927SAndroid Build Coastguard Worker static void add_const(unsigned reg, unsigned c0, unsigned c1, unsigned c2, unsigned c3)
219*61046927SAndroid Build Coastguard Worker {
220*61046927SAndroid Build Coastguard Worker 	struct ir3_const_state *const_state = ir3_const_state_mut(variant);
221*61046927SAndroid Build Coastguard Worker 	assert((reg & 0x7) == 0);
222*61046927SAndroid Build Coastguard Worker 	int idx = reg >> (1 + 2); /* low bit is half vs full, next two bits are swiz */
223*61046927SAndroid Build Coastguard Worker 	if (idx * 4 + 4 > const_state->immediates_size) {
224*61046927SAndroid Build Coastguard Worker 		const_state->immediates = rerzalloc(const_state,
225*61046927SAndroid Build Coastguard Worker 				const_state->immediates,
226*61046927SAndroid Build Coastguard Worker 				__typeof__(const_state->immediates[0]),
227*61046927SAndroid Build Coastguard Worker 				const_state->immediates_size,
228*61046927SAndroid Build Coastguard Worker 				idx * 4 + 4);
229*61046927SAndroid Build Coastguard Worker 		for (unsigned i = const_state->immediates_size; i < idx * 4; i++)
230*61046927SAndroid Build Coastguard Worker 			const_state->immediates[i] = 0xd0d0d0d0;
231*61046927SAndroid Build Coastguard Worker 		const_state->immediates_size = const_state->immediates_count = idx * 4 + 4;
232*61046927SAndroid Build Coastguard Worker 	}
233*61046927SAndroid Build Coastguard Worker 	const_state->immediates[idx * 4 + 0] = c0;
234*61046927SAndroid Build Coastguard Worker 	const_state->immediates[idx * 4 + 1] = c1;
235*61046927SAndroid Build Coastguard Worker 	const_state->immediates[idx * 4 + 2] = c2;
236*61046927SAndroid Build Coastguard Worker 	const_state->immediates[idx * 4 + 3] = c3;
237*61046927SAndroid Build Coastguard Worker }
238*61046927SAndroid Build Coastguard Worker 
add_buf_init_val(uint32_t val)239*61046927SAndroid Build Coastguard Worker static void add_buf_init_val(uint32_t val)
240*61046927SAndroid Build Coastguard Worker {
241*61046927SAndroid Build Coastguard Worker 	assert(info->num_bufs > 0);
242*61046927SAndroid Build Coastguard Worker 	unsigned idx = info->num_bufs - 1;
243*61046927SAndroid Build Coastguard Worker 
244*61046927SAndroid Build Coastguard Worker 	if (!info->buf_init_data[idx]) {
245*61046927SAndroid Build Coastguard Worker 		unsigned sz = info->buf_sizes[idx] * 4;
246*61046927SAndroid Build Coastguard Worker 		info->buf_init_data[idx] = malloc(sz);
247*61046927SAndroid Build Coastguard Worker 		memset(info->buf_init_data[idx], 0, sz);
248*61046927SAndroid Build Coastguard Worker 	}
249*61046927SAndroid Build Coastguard Worker 
250*61046927SAndroid Build Coastguard Worker 	assert(info->buf_init_data_sizes[idx] < info->buf_sizes[idx]);
251*61046927SAndroid Build Coastguard Worker 	info->buf_init_data[idx][info->buf_init_data_sizes[idx]++] = val;
252*61046927SAndroid Build Coastguard Worker }
253*61046927SAndroid Build Coastguard Worker 
add_sysval(unsigned reg,unsigned compmask,gl_system_value sysval)254*61046927SAndroid Build Coastguard Worker static void add_sysval(unsigned reg, unsigned compmask, gl_system_value sysval)
255*61046927SAndroid Build Coastguard Worker {
256*61046927SAndroid Build Coastguard Worker 	unsigned n = variant->inputs_count++;
257*61046927SAndroid Build Coastguard Worker 	variant->inputs[n].regid = reg;
258*61046927SAndroid Build Coastguard Worker 	variant->inputs[n].sysval = true;
259*61046927SAndroid Build Coastguard Worker 	variant->inputs[n].slot = sysval;
260*61046927SAndroid Build Coastguard Worker 	variant->inputs[n].compmask = compmask;
261*61046927SAndroid Build Coastguard Worker 	variant->total_in++;
262*61046927SAndroid Build Coastguard Worker }
263*61046927SAndroid Build Coastguard Worker 
resolve_labels(void)264*61046927SAndroid Build Coastguard Worker static bool resolve_labels(void)
265*61046927SAndroid Build Coastguard Worker {
266*61046927SAndroid Build Coastguard Worker 	int instr_ip = 0;
267*61046927SAndroid Build Coastguard Worker 	foreach_instr (instr, &block->instr_list) {
268*61046927SAndroid Build Coastguard Worker 		if (opc_cat(instr->opc) == 0 && instr->cat0.target_label) {
269*61046927SAndroid Build Coastguard Worker 			struct hash_entry *entry = _mesa_hash_table_search(labels, instr->cat0.target_label);
270*61046927SAndroid Build Coastguard Worker 			if (!entry) {
271*61046927SAndroid Build Coastguard Worker 				fprintf(stderr, "unknown label %s\n", instr->cat0.target_label);
272*61046927SAndroid Build Coastguard Worker 				return false;
273*61046927SAndroid Build Coastguard Worker 			}
274*61046927SAndroid Build Coastguard Worker 			int target_ip = (uintptr_t)entry->data;
275*61046927SAndroid Build Coastguard Worker 			instr->cat0.immed = target_ip - instr_ip;
276*61046927SAndroid Build Coastguard Worker 		}
277*61046927SAndroid Build Coastguard Worker 		instr_ip++;
278*61046927SAndroid Build Coastguard Worker 	}
279*61046927SAndroid Build Coastguard Worker 	return true;
280*61046927SAndroid Build Coastguard Worker }
281*61046927SAndroid Build Coastguard Worker 
282*61046927SAndroid Build Coastguard Worker #ifdef YYDEBUG
283*61046927SAndroid Build Coastguard Worker int yydebug;
284*61046927SAndroid Build Coastguard Worker #endif
285*61046927SAndroid Build Coastguard Worker 
286*61046927SAndroid Build Coastguard Worker extern int yylex(void);
287*61046927SAndroid Build Coastguard Worker void ir3_yyset_lineno(int _line_number);
288*61046927SAndroid Build Coastguard Worker void ir3_yyset_input(FILE *f);
289*61046927SAndroid Build Coastguard Worker 
290*61046927SAndroid Build Coastguard Worker int yyparse(void);
291*61046927SAndroid Build Coastguard Worker 
yyerror(const char * error)292*61046927SAndroid Build Coastguard Worker static void yyerror(const char *error)
293*61046927SAndroid Build Coastguard Worker {
294*61046927SAndroid Build Coastguard Worker 	fprintf(stderr, "error at line %d: %s\n", ir3_yyget_lineno(), error);
295*61046927SAndroid Build Coastguard Worker }
296*61046927SAndroid Build Coastguard Worker 
ir3_parse(struct ir3_shader_variant * v,struct ir3_kernel_info * k,FILE * f)297*61046927SAndroid Build Coastguard Worker struct ir3 * ir3_parse(struct ir3_shader_variant *v,
298*61046927SAndroid Build Coastguard Worker 		struct ir3_kernel_info *k, FILE *f)
299*61046927SAndroid Build Coastguard Worker {
300*61046927SAndroid Build Coastguard Worker 	ir3_yyset_lineno(1);
301*61046927SAndroid Build Coastguard Worker 	ir3_yyset_input(f);
302*61046927SAndroid Build Coastguard Worker #ifdef YYDEBUG
303*61046927SAndroid Build Coastguard Worker 	yydebug = 1;
304*61046927SAndroid Build Coastguard Worker #endif
305*61046927SAndroid Build Coastguard Worker 	info = k;
306*61046927SAndroid Build Coastguard Worker 	variant = v;
307*61046927SAndroid Build Coastguard Worker 	if (yyparse() || !resolve_labels()) {
308*61046927SAndroid Build Coastguard Worker 		ir3_destroy(variant->ir);
309*61046927SAndroid Build Coastguard Worker 		variant->ir = NULL;
310*61046927SAndroid Build Coastguard Worker 	}
311*61046927SAndroid Build Coastguard Worker 	ralloc_free(labels);
312*61046927SAndroid Build Coastguard Worker 	ralloc_free(ir3_parser_dead_ctx);
313*61046927SAndroid Build Coastguard Worker 	return variant->ir;
314*61046927SAndroid Build Coastguard Worker }
315*61046927SAndroid Build Coastguard Worker %}
316*61046927SAndroid Build Coastguard Worker 
317*61046927SAndroid Build Coastguard Worker %union {
318*61046927SAndroid Build Coastguard Worker 	int tok;
319*61046927SAndroid Build Coastguard Worker 	int num;
320*61046927SAndroid Build Coastguard Worker 	uint32_t unum;
321*61046927SAndroid Build Coastguard Worker 	uint64_t u64;
322*61046927SAndroid Build Coastguard Worker 	double flt;
323*61046927SAndroid Build Coastguard Worker 	const char *str;
324*61046927SAndroid Build Coastguard Worker 	struct ir3_register *reg;
325*61046927SAndroid Build Coastguard Worker 	struct {
326*61046927SAndroid Build Coastguard Worker 		int start;
327*61046927SAndroid Build Coastguard Worker 		int num;
328*61046927SAndroid Build Coastguard Worker 	} range;
329*61046927SAndroid Build Coastguard Worker 	type_t type;
330*61046927SAndroid Build Coastguard Worker }
331*61046927SAndroid Build Coastguard Worker 
332*61046927SAndroid Build Coastguard Worker %{
333*61046927SAndroid Build Coastguard Worker #if YYDEBUG
print_token(FILE * file,int type,YYSTYPE value)334*61046927SAndroid Build Coastguard Worker static void print_token(FILE *file, int type, YYSTYPE value)
335*61046927SAndroid Build Coastguard Worker {
336*61046927SAndroid Build Coastguard Worker 	fprintf(file, "\ntype: %d\n", type);
337*61046927SAndroid Build Coastguard Worker }
338*61046927SAndroid Build Coastguard Worker 
339*61046927SAndroid Build Coastguard Worker #define YYPRINT(file, type, value) print_token(file, type, value)
340*61046927SAndroid Build Coastguard Worker #endif
341*61046927SAndroid Build Coastguard Worker %}
342*61046927SAndroid Build Coastguard Worker 
343*61046927SAndroid Build Coastguard Worker %token <num> T_INT
344*61046927SAndroid Build Coastguard Worker %token <unum> T_HEX
345*61046927SAndroid Build Coastguard Worker %token <flt> T_FLOAT
346*61046927SAndroid Build Coastguard Worker %token <str> T_IDENTIFIER
347*61046927SAndroid Build Coastguard Worker %token <num> T_REGISTER
348*61046927SAndroid Build Coastguard Worker %token <num> T_CONSTANT
349*61046927SAndroid Build Coastguard Worker 
350*61046927SAndroid Build Coastguard Worker /* @ headers (@const/@sampler/@uniform/@varying) */
351*61046927SAndroid Build Coastguard Worker %token <tok> T_A_LOCALSIZE
352*61046927SAndroid Build Coastguard Worker %token <tok> T_A_CONST
353*61046927SAndroid Build Coastguard Worker %token <tok> T_A_BUF
354*61046927SAndroid Build Coastguard Worker %token <tok> T_A_INVOCATIONID
355*61046927SAndroid Build Coastguard Worker %token <tok> T_A_WGID
356*61046927SAndroid Build Coastguard Worker %token <tok> T_A_NUMWG
357*61046927SAndroid Build Coastguard Worker %token <tok> T_A_BRANCHSTACK
358*61046927SAndroid Build Coastguard Worker %token <tok> T_A_IN
359*61046927SAndroid Build Coastguard Worker %token <tok> T_A_OUT
360*61046927SAndroid Build Coastguard Worker %token <tok> T_A_TEX
361*61046927SAndroid Build Coastguard Worker %token <tok> T_A_PVTMEM
362*61046927SAndroid Build Coastguard Worker %token <tok> T_A_EARLYPREAMBLE
363*61046927SAndroid Build Coastguard Worker /* todo, re-add @sampler/@uniform/@varying if needed someday */
364*61046927SAndroid Build Coastguard Worker 
365*61046927SAndroid Build Coastguard Worker /* src register flags */
366*61046927SAndroid Build Coastguard Worker %token <tok> T_ABSNEG
367*61046927SAndroid Build Coastguard Worker %token <tok> T_NEG
368*61046927SAndroid Build Coastguard Worker %token <tok> T_ABS
369*61046927SAndroid Build Coastguard Worker %token <tok> T_R
370*61046927SAndroid Build Coastguard Worker %token <tok> T_LAST
371*61046927SAndroid Build Coastguard Worker 
372*61046927SAndroid Build Coastguard Worker %token <tok> T_HR
373*61046927SAndroid Build Coastguard Worker %token <tok> T_HC
374*61046927SAndroid Build Coastguard Worker 
375*61046927SAndroid Build Coastguard Worker /* dst register flags */
376*61046927SAndroid Build Coastguard Worker %token <tok> T_EVEN
377*61046927SAndroid Build Coastguard Worker %token <tok> T_POS_INFINITY
378*61046927SAndroid Build Coastguard Worker %token <tok> T_NEG_INFINITY
379*61046927SAndroid Build Coastguard Worker %token <tok> T_EI
380*61046927SAndroid Build Coastguard Worker %token <num> T_WRMASK
381*61046927SAndroid Build Coastguard Worker 
382*61046927SAndroid Build Coastguard Worker /* Float LUT values accepted as immed: */
383*61046927SAndroid Build Coastguard Worker %token <num> T_FLUT_0_0
384*61046927SAndroid Build Coastguard Worker %token <num> T_FLUT_0_5
385*61046927SAndroid Build Coastguard Worker %token <num> T_FLUT_1_0
386*61046927SAndroid Build Coastguard Worker %token <num> T_FLUT_2_0
387*61046927SAndroid Build Coastguard Worker %token <num> T_FLUT_E
388*61046927SAndroid Build Coastguard Worker %token <num> T_FLUT_PI
389*61046927SAndroid Build Coastguard Worker %token <num> T_FLUT_INV_PI
390*61046927SAndroid Build Coastguard Worker %token <num> T_FLUT_INV_LOG2_E
391*61046927SAndroid Build Coastguard Worker %token <num> T_FLUT_LOG2_E
392*61046927SAndroid Build Coastguard Worker %token <num> T_FLUT_INV_LOG2_10
393*61046927SAndroid Build Coastguard Worker %token <num> T_FLUT_LOG2_10
394*61046927SAndroid Build Coastguard Worker %token <num> T_FLUT_4_0
395*61046927SAndroid Build Coastguard Worker 
396*61046927SAndroid Build Coastguard Worker /* instruction flags */
397*61046927SAndroid Build Coastguard Worker %token <tok> T_SY
398*61046927SAndroid Build Coastguard Worker %token <tok> T_SS
399*61046927SAndroid Build Coastguard Worker %token <tok> T_JP
400*61046927SAndroid Build Coastguard Worker %token <tok> T_EQ_FLAG
401*61046927SAndroid Build Coastguard Worker %token <tok> T_SAT
402*61046927SAndroid Build Coastguard Worker %token <num> T_RPT
403*61046927SAndroid Build Coastguard Worker %token <tok> T_UL
404*61046927SAndroid Build Coastguard Worker %token <tok> T_NOP
405*61046927SAndroid Build Coastguard Worker 
406*61046927SAndroid Build Coastguard Worker /* category 0: */
407*61046927SAndroid Build Coastguard Worker %token <tok> T_OP_NOP
408*61046927SAndroid Build Coastguard Worker %token <tok> T_OP_BR
409*61046927SAndroid Build Coastguard Worker %token <tok> T_OP_BRAO
410*61046927SAndroid Build Coastguard Worker %token <tok> T_OP_BRAA
411*61046927SAndroid Build Coastguard Worker %token <tok> T_OP_BRAC
412*61046927SAndroid Build Coastguard Worker %token <tok> T_OP_BANY
413*61046927SAndroid Build Coastguard Worker %token <tok> T_OP_BALL
414*61046927SAndroid Build Coastguard Worker %token <tok> T_OP_BRAX
415*61046927SAndroid Build Coastguard Worker %token <tok> T_OP_JUMP
416*61046927SAndroid Build Coastguard Worker %token <tok> T_OP_CALL
417*61046927SAndroid Build Coastguard Worker %token <tok> T_OP_RET
418*61046927SAndroid Build Coastguard Worker %token <tok> T_OP_KILL
419*61046927SAndroid Build Coastguard Worker %token <tok> T_OP_END
420*61046927SAndroid Build Coastguard Worker %token <tok> T_OP_EMIT
421*61046927SAndroid Build Coastguard Worker %token <tok> T_OP_CUT
422*61046927SAndroid Build Coastguard Worker %token <tok> T_OP_CHMASK
423*61046927SAndroid Build Coastguard Worker %token <tok> T_OP_CHSH
424*61046927SAndroid Build Coastguard Worker %token <tok> T_OP_FLOW_REV
425*61046927SAndroid Build Coastguard Worker %token <tok> T_OP_BKT
426*61046927SAndroid Build Coastguard Worker %token <tok> T_OP_STKS
427*61046927SAndroid Build Coastguard Worker %token <tok> T_OP_STKR
428*61046927SAndroid Build Coastguard Worker %token <tok> T_OP_XSET
429*61046927SAndroid Build Coastguard Worker %token <tok> T_OP_XCLR
430*61046927SAndroid Build Coastguard Worker %token <tok> T_OP_GETLAST
431*61046927SAndroid Build Coastguard Worker %token <tok> T_OP_GETONE
432*61046927SAndroid Build Coastguard Worker %token <tok> T_OP_DBG
433*61046927SAndroid Build Coastguard Worker %token <tok> T_OP_SHPS
434*61046927SAndroid Build Coastguard Worker %token <tok> T_OP_SHPE
435*61046927SAndroid Build Coastguard Worker %token <tok> T_OP_PREDT
436*61046927SAndroid Build Coastguard Worker %token <tok> T_OP_PREDF
437*61046927SAndroid Build Coastguard Worker %token <tok> T_OP_PREDE
438*61046927SAndroid Build Coastguard Worker 
439*61046927SAndroid Build Coastguard Worker /* category 1: */
440*61046927SAndroid Build Coastguard Worker %token <tok> T_OP_MOVMSK
441*61046927SAndroid Build Coastguard Worker %token <tok> T_OP_MOVA1
442*61046927SAndroid Build Coastguard Worker %token <tok> T_OP_MOVA
443*61046927SAndroid Build Coastguard Worker %token <tok> T_OP_MOV
444*61046927SAndroid Build Coastguard Worker %token <tok> T_OP_COV
445*61046927SAndroid Build Coastguard Worker %token <tok> T_OP_SWZ
446*61046927SAndroid Build Coastguard Worker %token <tok> T_OP_GAT
447*61046927SAndroid Build Coastguard Worker %token <tok> T_OP_SCT
448*61046927SAndroid Build Coastguard Worker 
449*61046927SAndroid Build Coastguard Worker /* category 2: */
450*61046927SAndroid Build Coastguard Worker %token <tok> T_OP_ADD_F
451*61046927SAndroid Build Coastguard Worker %token <tok> T_OP_MIN_F
452*61046927SAndroid Build Coastguard Worker %token <tok> T_OP_MAX_F
453*61046927SAndroid Build Coastguard Worker %token <tok> T_OP_MUL_F
454*61046927SAndroid Build Coastguard Worker %token <tok> T_OP_SIGN_F
455*61046927SAndroid Build Coastguard Worker %token <tok> T_OP_CMPS_F
456*61046927SAndroid Build Coastguard Worker %token <tok> T_OP_ABSNEG_F
457*61046927SAndroid Build Coastguard Worker %token <tok> T_OP_CMPV_F
458*61046927SAndroid Build Coastguard Worker %token <tok> T_OP_FLOOR_F
459*61046927SAndroid Build Coastguard Worker %token <tok> T_OP_CEIL_F
460*61046927SAndroid Build Coastguard Worker %token <tok> T_OP_RNDNE_F
461*61046927SAndroid Build Coastguard Worker %token <tok> T_OP_RNDAZ_F
462*61046927SAndroid Build Coastguard Worker %token <tok> T_OP_TRUNC_F
463*61046927SAndroid Build Coastguard Worker %token <tok> T_OP_ADD_U
464*61046927SAndroid Build Coastguard Worker %token <tok> T_OP_ADD_S
465*61046927SAndroid Build Coastguard Worker %token <tok> T_OP_SUB_U
466*61046927SAndroid Build Coastguard Worker %token <tok> T_OP_SUB_S
467*61046927SAndroid Build Coastguard Worker %token <tok> T_OP_CMPS_U
468*61046927SAndroid Build Coastguard Worker %token <tok> T_OP_CMPS_S
469*61046927SAndroid Build Coastguard Worker %token <tok> T_OP_MIN_U
470*61046927SAndroid Build Coastguard Worker %token <tok> T_OP_MIN_S
471*61046927SAndroid Build Coastguard Worker %token <tok> T_OP_MAX_U
472*61046927SAndroid Build Coastguard Worker %token <tok> T_OP_MAX_S
473*61046927SAndroid Build Coastguard Worker %token <tok> T_OP_ABSNEG_S
474*61046927SAndroid Build Coastguard Worker %token <tok> T_OP_AND_B
475*61046927SAndroid Build Coastguard Worker %token <tok> T_OP_OR_B
476*61046927SAndroid Build Coastguard Worker %token <tok> T_OP_NOT_B
477*61046927SAndroid Build Coastguard Worker %token <tok> T_OP_XOR_B
478*61046927SAndroid Build Coastguard Worker %token <tok> T_OP_CMPV_U
479*61046927SAndroid Build Coastguard Worker %token <tok> T_OP_CMPV_S
480*61046927SAndroid Build Coastguard Worker %token <tok> T_OP_MUL_U24
481*61046927SAndroid Build Coastguard Worker %token <tok> T_OP_MUL_S24
482*61046927SAndroid Build Coastguard Worker %token <tok> T_OP_MULL_U
483*61046927SAndroid Build Coastguard Worker %token <tok> T_OP_BFREV_B
484*61046927SAndroid Build Coastguard Worker %token <tok> T_OP_CLZ_S
485*61046927SAndroid Build Coastguard Worker %token <tok> T_OP_CLZ_B
486*61046927SAndroid Build Coastguard Worker %token <tok> T_OP_SHL_B
487*61046927SAndroid Build Coastguard Worker %token <tok> T_OP_SHR_B
488*61046927SAndroid Build Coastguard Worker %token <tok> T_OP_ASHR_B
489*61046927SAndroid Build Coastguard Worker %token <tok> T_OP_BARY_F
490*61046927SAndroid Build Coastguard Worker %token <tok> T_OP_FLAT_B
491*61046927SAndroid Build Coastguard Worker %token <tok> T_OP_MGEN_B
492*61046927SAndroid Build Coastguard Worker %token <tok> T_OP_GETBIT_B
493*61046927SAndroid Build Coastguard Worker %token <tok> T_OP_SETRM
494*61046927SAndroid Build Coastguard Worker %token <tok> T_OP_CBITS_B
495*61046927SAndroid Build Coastguard Worker %token <tok> T_OP_SHB
496*61046927SAndroid Build Coastguard Worker %token <tok> T_OP_MSAD
497*61046927SAndroid Build Coastguard Worker 
498*61046927SAndroid Build Coastguard Worker /* category 3: */
499*61046927SAndroid Build Coastguard Worker %token <tok> T_OP_MAD_U16
500*61046927SAndroid Build Coastguard Worker %token <tok> T_OP_MADSH_U16
501*61046927SAndroid Build Coastguard Worker %token <tok> T_OP_MAD_S16
502*61046927SAndroid Build Coastguard Worker %token <tok> T_OP_MADSH_M16
503*61046927SAndroid Build Coastguard Worker %token <tok> T_OP_MAD_U24
504*61046927SAndroid Build Coastguard Worker %token <tok> T_OP_MAD_S24
505*61046927SAndroid Build Coastguard Worker %token <tok> T_OP_MAD_F16
506*61046927SAndroid Build Coastguard Worker %token <tok> T_OP_MAD_F32
507*61046927SAndroid Build Coastguard Worker %token <tok> T_OP_SEL_B16
508*61046927SAndroid Build Coastguard Worker %token <tok> T_OP_SEL_B32
509*61046927SAndroid Build Coastguard Worker %token <tok> T_OP_SEL_S16
510*61046927SAndroid Build Coastguard Worker %token <tok> T_OP_SEL_S32
511*61046927SAndroid Build Coastguard Worker %token <tok> T_OP_SEL_F16
512*61046927SAndroid Build Coastguard Worker %token <tok> T_OP_SEL_F32
513*61046927SAndroid Build Coastguard Worker %token <tok> T_OP_SAD_S16
514*61046927SAndroid Build Coastguard Worker %token <tok> T_OP_SAD_S32
515*61046927SAndroid Build Coastguard Worker %token <tok> T_OP_SHRM
516*61046927SAndroid Build Coastguard Worker %token <tok> T_OP_SHLM
517*61046927SAndroid Build Coastguard Worker %token <tok> T_OP_SHRG
518*61046927SAndroid Build Coastguard Worker %token <tok> T_OP_SHLG
519*61046927SAndroid Build Coastguard Worker %token <tok> T_OP_ANDG
520*61046927SAndroid Build Coastguard Worker %token <tok> T_OP_DP2ACC
521*61046927SAndroid Build Coastguard Worker %token <tok> T_OP_DP4ACC
522*61046927SAndroid Build Coastguard Worker %token <tok> T_OP_WMM
523*61046927SAndroid Build Coastguard Worker %token <tok> T_OP_WMM_ACCU
524*61046927SAndroid Build Coastguard Worker 
525*61046927SAndroid Build Coastguard Worker /* category 4: */
526*61046927SAndroid Build Coastguard Worker %token <tok> T_OP_RCP
527*61046927SAndroid Build Coastguard Worker %token <tok> T_OP_RSQ
528*61046927SAndroid Build Coastguard Worker %token <tok> T_OP_LOG2
529*61046927SAndroid Build Coastguard Worker %token <tok> T_OP_EXP2
530*61046927SAndroid Build Coastguard Worker %token <tok> T_OP_SIN
531*61046927SAndroid Build Coastguard Worker %token <tok> T_OP_COS
532*61046927SAndroid Build Coastguard Worker %token <tok> T_OP_SQRT
533*61046927SAndroid Build Coastguard Worker %token <tok> T_OP_HRSQ
534*61046927SAndroid Build Coastguard Worker %token <tok> T_OP_HLOG2
535*61046927SAndroid Build Coastguard Worker %token <tok> T_OP_HEXP2
536*61046927SAndroid Build Coastguard Worker 
537*61046927SAndroid Build Coastguard Worker /* category 5: */
538*61046927SAndroid Build Coastguard Worker %token <tok> T_OP_ISAM
539*61046927SAndroid Build Coastguard Worker %token <tok> T_OP_ISAML
540*61046927SAndroid Build Coastguard Worker %token <tok> T_OP_ISAMM
541*61046927SAndroid Build Coastguard Worker %token <tok> T_OP_SAM
542*61046927SAndroid Build Coastguard Worker %token <tok> T_OP_SAMB
543*61046927SAndroid Build Coastguard Worker %token <tok> T_OP_SAML
544*61046927SAndroid Build Coastguard Worker %token <tok> T_OP_SAMGQ
545*61046927SAndroid Build Coastguard Worker %token <tok> T_OP_GETLOD
546*61046927SAndroid Build Coastguard Worker %token <tok> T_OP_CONV
547*61046927SAndroid Build Coastguard Worker %token <tok> T_OP_CONVM
548*61046927SAndroid Build Coastguard Worker %token <tok> T_OP_GETSIZE
549*61046927SAndroid Build Coastguard Worker %token <tok> T_OP_GETBUF
550*61046927SAndroid Build Coastguard Worker %token <tok> T_OP_GETPOS
551*61046927SAndroid Build Coastguard Worker %token <tok> T_OP_GETINFO
552*61046927SAndroid Build Coastguard Worker %token <tok> T_OP_DSX
553*61046927SAndroid Build Coastguard Worker %token <tok> T_OP_DSY
554*61046927SAndroid Build Coastguard Worker %token <tok> T_OP_GATHER4R
555*61046927SAndroid Build Coastguard Worker %token <tok> T_OP_GATHER4G
556*61046927SAndroid Build Coastguard Worker %token <tok> T_OP_GATHER4B
557*61046927SAndroid Build Coastguard Worker %token <tok> T_OP_GATHER4A
558*61046927SAndroid Build Coastguard Worker %token <tok> T_OP_SAMGP0
559*61046927SAndroid Build Coastguard Worker %token <tok> T_OP_SAMGP1
560*61046927SAndroid Build Coastguard Worker %token <tok> T_OP_SAMGP2
561*61046927SAndroid Build Coastguard Worker %token <tok> T_OP_SAMGP3
562*61046927SAndroid Build Coastguard Worker %token <tok> T_OP_DSXPP_1
563*61046927SAndroid Build Coastguard Worker %token <tok> T_OP_DSYPP_1
564*61046927SAndroid Build Coastguard Worker %token <tok> T_OP_RGETPOS
565*61046927SAndroid Build Coastguard Worker %token <tok> T_OP_RGETINFO
566*61046927SAndroid Build Coastguard Worker %token <tok> T_OP_BRCST_A
567*61046927SAndroid Build Coastguard Worker %token <tok> T_OP_QSHUFFLE_BRCST
568*61046927SAndroid Build Coastguard Worker %token <tok> T_OP_QSHUFFLE_H
569*61046927SAndroid Build Coastguard Worker %token <tok> T_OP_QSHUFFLE_V
570*61046927SAndroid Build Coastguard Worker %token <tok> T_OP_QSHUFFLE_DIAG
571*61046927SAndroid Build Coastguard Worker %token <tok> T_OP_TCINV
572*61046927SAndroid Build Coastguard Worker 
573*61046927SAndroid Build Coastguard Worker /* category 6: */
574*61046927SAndroid Build Coastguard Worker %token <tok> T_OP_LDG
575*61046927SAndroid Build Coastguard Worker %token <tok> T_OP_LDG_A
576*61046927SAndroid Build Coastguard Worker %token <tok> T_OP_LDG_K
577*61046927SAndroid Build Coastguard Worker %token <tok> T_OP_LDL
578*61046927SAndroid Build Coastguard Worker %token <tok> T_OP_LDP
579*61046927SAndroid Build Coastguard Worker %token <tok> T_OP_STG
580*61046927SAndroid Build Coastguard Worker %token <tok> T_OP_STG_A
581*61046927SAndroid Build Coastguard Worker %token <tok> T_OP_STL
582*61046927SAndroid Build Coastguard Worker %token <tok> T_OP_STP
583*61046927SAndroid Build Coastguard Worker %token <tok> T_OP_LDIB
584*61046927SAndroid Build Coastguard Worker %token <tok> T_OP_G2L
585*61046927SAndroid Build Coastguard Worker %token <tok> T_OP_L2G
586*61046927SAndroid Build Coastguard Worker %token <tok> T_OP_PREFETCH
587*61046927SAndroid Build Coastguard Worker %token <tok> T_OP_LDLW
588*61046927SAndroid Build Coastguard Worker %token <tok> T_OP_STLW
589*61046927SAndroid Build Coastguard Worker %token <tok> T_OP_RESFMT
590*61046927SAndroid Build Coastguard Worker %token <tok> T_OP_RESINFO
591*61046927SAndroid Build Coastguard Worker %token <tok> T_OP_ATOMIC_ADD
592*61046927SAndroid Build Coastguard Worker %token <tok> T_OP_ATOMIC_SUB
593*61046927SAndroid Build Coastguard Worker %token <tok> T_OP_ATOMIC_XCHG
594*61046927SAndroid Build Coastguard Worker %token <tok> T_OP_ATOMIC_INC
595*61046927SAndroid Build Coastguard Worker %token <tok> T_OP_ATOMIC_DEC
596*61046927SAndroid Build Coastguard Worker %token <tok> T_OP_ATOMIC_CMPXCHG
597*61046927SAndroid Build Coastguard Worker %token <tok> T_OP_ATOMIC_MIN
598*61046927SAndroid Build Coastguard Worker %token <tok> T_OP_ATOMIC_MAX
599*61046927SAndroid Build Coastguard Worker %token <tok> T_OP_ATOMIC_AND
600*61046927SAndroid Build Coastguard Worker %token <tok> T_OP_ATOMIC_OR
601*61046927SAndroid Build Coastguard Worker %token <tok> T_OP_ATOMIC_XOR
602*61046927SAndroid Build Coastguard Worker %token <tok> T_OP_RESINFO_B
603*61046927SAndroid Build Coastguard Worker %token <tok> T_OP_LDIB_B
604*61046927SAndroid Build Coastguard Worker %token <tok> T_OP_STIB_B
605*61046927SAndroid Build Coastguard Worker %token <tok> T_OP_ATOMIC_B_ADD
606*61046927SAndroid Build Coastguard Worker %token <tok> T_OP_ATOMIC_B_SUB
607*61046927SAndroid Build Coastguard Worker %token <tok> T_OP_ATOMIC_B_XCHG
608*61046927SAndroid Build Coastguard Worker %token <tok> T_OP_ATOMIC_B_INC
609*61046927SAndroid Build Coastguard Worker %token <tok> T_OP_ATOMIC_B_DEC
610*61046927SAndroid Build Coastguard Worker %token <tok> T_OP_ATOMIC_B_CMPXCHG
611*61046927SAndroid Build Coastguard Worker %token <tok> T_OP_ATOMIC_B_MIN
612*61046927SAndroid Build Coastguard Worker %token <tok> T_OP_ATOMIC_B_MAX
613*61046927SAndroid Build Coastguard Worker %token <tok> T_OP_ATOMIC_B_AND
614*61046927SAndroid Build Coastguard Worker %token <tok> T_OP_ATOMIC_B_OR
615*61046927SAndroid Build Coastguard Worker %token <tok> T_OP_ATOMIC_B_XOR
616*61046927SAndroid Build Coastguard Worker %token <tok> T_OP_ATOMIC_S_ADD
617*61046927SAndroid Build Coastguard Worker %token <tok> T_OP_ATOMIC_S_SUB
618*61046927SAndroid Build Coastguard Worker %token <tok> T_OP_ATOMIC_S_XCHG
619*61046927SAndroid Build Coastguard Worker %token <tok> T_OP_ATOMIC_S_INC
620*61046927SAndroid Build Coastguard Worker %token <tok> T_OP_ATOMIC_S_DEC
621*61046927SAndroid Build Coastguard Worker %token <tok> T_OP_ATOMIC_S_CMPXCHG
622*61046927SAndroid Build Coastguard Worker %token <tok> T_OP_ATOMIC_S_MIN
623*61046927SAndroid Build Coastguard Worker %token <tok> T_OP_ATOMIC_S_MAX
624*61046927SAndroid Build Coastguard Worker %token <tok> T_OP_ATOMIC_S_AND
625*61046927SAndroid Build Coastguard Worker %token <tok> T_OP_ATOMIC_S_OR
626*61046927SAndroid Build Coastguard Worker %token <tok> T_OP_ATOMIC_S_XOR
627*61046927SAndroid Build Coastguard Worker %token <tok> T_OP_ATOMIC_G_ADD
628*61046927SAndroid Build Coastguard Worker %token <tok> T_OP_ATOMIC_G_SUB
629*61046927SAndroid Build Coastguard Worker %token <tok> T_OP_ATOMIC_G_XCHG
630*61046927SAndroid Build Coastguard Worker %token <tok> T_OP_ATOMIC_G_INC
631*61046927SAndroid Build Coastguard Worker %token <tok> T_OP_ATOMIC_G_DEC
632*61046927SAndroid Build Coastguard Worker %token <tok> T_OP_ATOMIC_G_CMPXCHG
633*61046927SAndroid Build Coastguard Worker %token <tok> T_OP_ATOMIC_G_MIN
634*61046927SAndroid Build Coastguard Worker %token <tok> T_OP_ATOMIC_G_MAX
635*61046927SAndroid Build Coastguard Worker %token <tok> T_OP_ATOMIC_G_AND
636*61046927SAndroid Build Coastguard Worker %token <tok> T_OP_ATOMIC_G_OR
637*61046927SAndroid Build Coastguard Worker %token <tok> T_OP_ATOMIC_G_XOR
638*61046927SAndroid Build Coastguard Worker %token <tok> T_OP_LDGB
639*61046927SAndroid Build Coastguard Worker %token <tok> T_OP_STGB
640*61046927SAndroid Build Coastguard Worker %token <tok> T_OP_STIB
641*61046927SAndroid Build Coastguard Worker %token <tok> T_OP_LDC
642*61046927SAndroid Build Coastguard Worker %token <tok> T_OP_LDLV
643*61046927SAndroid Build Coastguard Worker %token <tok> T_OP_GETSPID
644*61046927SAndroid Build Coastguard Worker %token <tok> T_OP_GETWID
645*61046927SAndroid Build Coastguard Worker %token <tok> T_OP_GETFIBERID
646*61046927SAndroid Build Coastguard Worker %token <tok> T_OP_STC
647*61046927SAndroid Build Coastguard Worker %token <tok> T_OP_STSC
648*61046927SAndroid Build Coastguard Worker 
649*61046927SAndroid Build Coastguard Worker /* category 7: */
650*61046927SAndroid Build Coastguard Worker %token <tok> T_OP_BAR
651*61046927SAndroid Build Coastguard Worker %token <tok> T_OP_FENCE
652*61046927SAndroid Build Coastguard Worker %token <tok> T_OP_SLEEP
653*61046927SAndroid Build Coastguard Worker %token <tok> T_OP_ICINV
654*61046927SAndroid Build Coastguard Worker %token <tok> T_OP_DCCLN
655*61046927SAndroid Build Coastguard Worker %token <tok> T_OP_DCINV
656*61046927SAndroid Build Coastguard Worker %token <tok> T_OP_DCFLU
657*61046927SAndroid Build Coastguard Worker %token <tok> T_OP_CCINV
658*61046927SAndroid Build Coastguard Worker %token <tok> T_OP_LOCK
659*61046927SAndroid Build Coastguard Worker %token <tok> T_OP_UNLOCK
660*61046927SAndroid Build Coastguard Worker %token <tok> T_OP_ALIAS
661*61046927SAndroid Build Coastguard Worker 
662*61046927SAndroid Build Coastguard Worker %token <u64> T_RAW
663*61046927SAndroid Build Coastguard Worker 
664*61046927SAndroid Build Coastguard Worker %token <tok> T_OP_PRINT
665*61046927SAndroid Build Coastguard Worker 
666*61046927SAndroid Build Coastguard Worker /* type qualifiers: */
667*61046927SAndroid Build Coastguard Worker %token <tok> T_TYPE_F16
668*61046927SAndroid Build Coastguard Worker %token <tok> T_TYPE_F32
669*61046927SAndroid Build Coastguard Worker %token <tok> T_TYPE_U16
670*61046927SAndroid Build Coastguard Worker %token <tok> T_TYPE_U32
671*61046927SAndroid Build Coastguard Worker %token <tok> T_TYPE_S16
672*61046927SAndroid Build Coastguard Worker %token <tok> T_TYPE_S32
673*61046927SAndroid Build Coastguard Worker %token <tok> T_TYPE_U8
674*61046927SAndroid Build Coastguard Worker %token <tok> T_TYPE_U8_32
675*61046927SAndroid Build Coastguard Worker 
676*61046927SAndroid Build Coastguard Worker %token <tok> T_UNTYPED
677*61046927SAndroid Build Coastguard Worker %token <tok> T_TYPED
678*61046927SAndroid Build Coastguard Worker 
679*61046927SAndroid Build Coastguard Worker %token <tok> T_MIXED
680*61046927SAndroid Build Coastguard Worker %token <tok> T_UNSIGNED
681*61046927SAndroid Build Coastguard Worker %token <tok> T_LOW
682*61046927SAndroid Build Coastguard Worker %token <tok> T_HIGH
683*61046927SAndroid Build Coastguard Worker 
684*61046927SAndroid Build Coastguard Worker %token <tok> T_1D
685*61046927SAndroid Build Coastguard Worker %token <tok> T_2D
686*61046927SAndroid Build Coastguard Worker %token <tok> T_3D
687*61046927SAndroid Build Coastguard Worker %token <tok> T_4D
688*61046927SAndroid Build Coastguard Worker 
689*61046927SAndroid Build Coastguard Worker /* condition qualifiers: */
690*61046927SAndroid Build Coastguard Worker %token <tok> T_LT
691*61046927SAndroid Build Coastguard Worker %token <tok> T_LE
692*61046927SAndroid Build Coastguard Worker %token <tok> T_GT
693*61046927SAndroid Build Coastguard Worker %token <tok> T_GE
694*61046927SAndroid Build Coastguard Worker %token <tok> T_EQ
695*61046927SAndroid Build Coastguard Worker %token <tok> T_NE
696*61046927SAndroid Build Coastguard Worker 
697*61046927SAndroid Build Coastguard Worker %token <tok> T_S2EN
698*61046927SAndroid Build Coastguard Worker %token <tok> T_SAMP
699*61046927SAndroid Build Coastguard Worker %token <tok> T_TEX
700*61046927SAndroid Build Coastguard Worker %token <tok> T_BASE
701*61046927SAndroid Build Coastguard Worker %token <tok> T_OFFSET
702*61046927SAndroid Build Coastguard Worker %token <tok> T_UNIFORM
703*61046927SAndroid Build Coastguard Worker %token <tok> T_NONUNIFORM
704*61046927SAndroid Build Coastguard Worker %token <tok> T_IMM
705*61046927SAndroid Build Coastguard Worker 
706*61046927SAndroid Build Coastguard Worker %token <tok> T_NAN
707*61046927SAndroid Build Coastguard Worker %token <tok> T_INF
708*61046927SAndroid Build Coastguard Worker %token <num> T_A0
709*61046927SAndroid Build Coastguard Worker %token <num> T_A1
710*61046927SAndroid Build Coastguard Worker %token <num> T_P0
711*61046927SAndroid Build Coastguard Worker %token <num> T_W
712*61046927SAndroid Build Coastguard Worker %token <str> T_CAT1_TYPE_TYPE
713*61046927SAndroid Build Coastguard Worker %token <str> T_INSTR_TYPE
714*61046927SAndroid Build Coastguard Worker 
715*61046927SAndroid Build Coastguard Worker %token <tok> T_MOD_TEX
716*61046927SAndroid Build Coastguard Worker %token <tok> T_MOD_MEM
717*61046927SAndroid Build Coastguard Worker %token <tok> T_MOD_RT
718*61046927SAndroid Build Coastguard Worker 
719*61046927SAndroid Build Coastguard Worker %type <num> integer offset uoffset
720*61046927SAndroid Build Coastguard Worker %type <num> flut_immed
721*61046927SAndroid Build Coastguard Worker %type <flt> float
722*61046927SAndroid Build Coastguard Worker %type <reg> src dst const cat0_src1 cat0_src2
723*61046927SAndroid Build Coastguard Worker %type <tok> cat1_opc
724*61046927SAndroid Build Coastguard Worker %type <tok> cat2_opc_1src cat2_opc_2src_cnd cat2_opc_2src
725*61046927SAndroid Build Coastguard Worker %type <tok> cat3_opc
726*61046927SAndroid Build Coastguard Worker %type <tok> cat4_opc
727*61046927SAndroid Build Coastguard Worker %type <tok> cat5_opc cat5_samp cat5_tex cat5_type
728*61046927SAndroid Build Coastguard Worker %type <type> type
729*61046927SAndroid Build Coastguard Worker %type <unum> const_val
730*61046927SAndroid Build Coastguard Worker 
731*61046927SAndroid Build Coastguard Worker %error-verbose
732*61046927SAndroid Build Coastguard Worker 
733*61046927SAndroid Build Coastguard Worker %start shader
734*61046927SAndroid Build Coastguard Worker 
735*61046927SAndroid Build Coastguard Worker %%
736*61046927SAndroid Build Coastguard Worker 
737*61046927SAndroid Build Coastguard Worker shader:            { new_shader(); } headers instrs
738*61046927SAndroid Build Coastguard Worker 
739*61046927SAndroid Build Coastguard Worker headers:
740*61046927SAndroid Build Coastguard Worker |                  header headers
741*61046927SAndroid Build Coastguard Worker 
742*61046927SAndroid Build Coastguard Worker header:            localsize_header
743*61046927SAndroid Build Coastguard Worker |                  const_header
744*61046927SAndroid Build Coastguard Worker |                  buf_header
745*61046927SAndroid Build Coastguard Worker |                  invocationid_header
746*61046927SAndroid Build Coastguard Worker |                  wgid_header
747*61046927SAndroid Build Coastguard Worker |                  numwg_header
748*61046927SAndroid Build Coastguard Worker |                  branchstack_header
749*61046927SAndroid Build Coastguard Worker |                  in_header
750*61046927SAndroid Build Coastguard Worker |                  out_header
751*61046927SAndroid Build Coastguard Worker |                  tex_header
752*61046927SAndroid Build Coastguard Worker |                  pvtmem_header
753*61046927SAndroid Build Coastguard Worker |                  earlypreamble_header
754*61046927SAndroid Build Coastguard Worker 
755*61046927SAndroid Build Coastguard Worker const_val:         T_FLOAT   { $$ = fui($1); }
756*61046927SAndroid Build Coastguard Worker |                  T_INT     { $$ = $1;      }
757*61046927SAndroid Build Coastguard Worker |                  '-' T_INT { $$ = -$2;     }
758*61046927SAndroid Build Coastguard Worker |                  T_HEX     { $$ = $1;      }
759*61046927SAndroid Build Coastguard Worker 
760*61046927SAndroid Build Coastguard Worker localsize_header:  T_A_LOCALSIZE const_val ',' const_val ',' const_val {
761*61046927SAndroid Build Coastguard Worker                        variant->local_size[0] = $2;
762*61046927SAndroid Build Coastguard Worker                        variant->local_size[1] = $4;
763*61046927SAndroid Build Coastguard Worker                        variant->local_size[2] = $6;
764*61046927SAndroid Build Coastguard Worker }
765*61046927SAndroid Build Coastguard Worker 
766*61046927SAndroid Build Coastguard Worker const_header:      T_A_CONST '(' T_CONSTANT ')' const_val ',' const_val ',' const_val ',' const_val {
767*61046927SAndroid Build Coastguard Worker                        add_const($3, $5, $7, $9, $11);
768*61046927SAndroid Build Coastguard Worker }
769*61046927SAndroid Build Coastguard Worker 
770*61046927SAndroid Build Coastguard Worker buf_header_init_val:  const_val { add_buf_init_val($1); }
771*61046927SAndroid Build Coastguard Worker buf_header_init_vals: buf_header_init_val
772*61046927SAndroid Build Coastguard Worker |                     buf_header_init_val ',' buf_header_init_vals
773*61046927SAndroid Build Coastguard Worker |
774*61046927SAndroid Build Coastguard Worker 
775*61046927SAndroid Build Coastguard Worker buf_header_addr_reg:
776*61046927SAndroid Build Coastguard Worker                    '(' T_CONSTANT ')' {
777*61046927SAndroid Build Coastguard Worker                        assert(($2 & 0x1) == 0);  /* half-reg not allowed */
778*61046927SAndroid Build Coastguard Worker                        unsigned reg = $2 >> 1;
779*61046927SAndroid Build Coastguard Worker 
780*61046927SAndroid Build Coastguard Worker                        info->buf_addr_regs[info->num_bufs - 1] = reg;
781*61046927SAndroid Build Coastguard Worker                        /* reserve space in immediates for the actual value to be plugged in later: */
782*61046927SAndroid Build Coastguard Worker                        add_const($2, 0, 0, 0, 0);
783*61046927SAndroid Build Coastguard Worker }
784*61046927SAndroid Build Coastguard Worker |
785*61046927SAndroid Build Coastguard Worker 
786*61046927SAndroid Build Coastguard Worker buf_header:        T_A_BUF const_val {
787*61046927SAndroid Build Coastguard Worker                        int idx = info->num_bufs++;
788*61046927SAndroid Build Coastguard Worker                        assert(idx < MAX_BUFS);
789*61046927SAndroid Build Coastguard Worker                        info->buf_sizes[idx] = $2;
790*61046927SAndroid Build Coastguard Worker } buf_header_addr_reg buf_header_init_vals
791*61046927SAndroid Build Coastguard Worker 
792*61046927SAndroid Build Coastguard Worker invocationid_header: T_A_INVOCATIONID '(' T_REGISTER ')' {
793*61046927SAndroid Build Coastguard Worker                        assert(($3 & 0x1) == 0);  /* half-reg not allowed */
794*61046927SAndroid Build Coastguard Worker                        unsigned reg = $3 >> 1;
795*61046927SAndroid Build Coastguard Worker                        add_sysval(reg, 0x7, SYSTEM_VALUE_LOCAL_INVOCATION_ID);
796*61046927SAndroid Build Coastguard Worker }
797*61046927SAndroid Build Coastguard Worker 
798*61046927SAndroid Build Coastguard Worker wgid_header:       T_A_WGID '(' T_REGISTER ')' {
799*61046927SAndroid Build Coastguard Worker                        assert(($3 & 0x1) == 0);  /* half-reg not allowed */
800*61046927SAndroid Build Coastguard Worker                        unsigned reg = $3 >> 1;
801*61046927SAndroid Build Coastguard Worker                        assert(variant->compiler->gen >= 5);
802*61046927SAndroid Build Coastguard Worker                        assert(reg >= regid(48, 0)); /* must be a high reg */
803*61046927SAndroid Build Coastguard Worker                        add_sysval(reg, 0x7, SYSTEM_VALUE_WORKGROUP_ID);
804*61046927SAndroid Build Coastguard Worker }
805*61046927SAndroid Build Coastguard Worker |                  T_A_WGID '(' T_CONSTANT ')' {
806*61046927SAndroid Build Coastguard Worker                        assert(($3 & 0x1) == 0);  /* half-reg not allowed */
807*61046927SAndroid Build Coastguard Worker                        unsigned reg = $3 >> 1;
808*61046927SAndroid Build Coastguard Worker                        assert(variant->compiler->gen < 5);
809*61046927SAndroid Build Coastguard Worker                        info->wgid = reg;
810*61046927SAndroid Build Coastguard Worker }
811*61046927SAndroid Build Coastguard Worker 
812*61046927SAndroid Build Coastguard Worker numwg_header:      T_A_NUMWG '(' T_CONSTANT ')' {
813*61046927SAndroid Build Coastguard Worker                        assert(($3 & 0x1) == 0);  /* half-reg not allowed */
814*61046927SAndroid Build Coastguard Worker                        unsigned reg = $3 >> 1;
815*61046927SAndroid Build Coastguard Worker                        info->numwg = reg;
816*61046927SAndroid Build Coastguard Worker                        /* reserve space in immediates for the actual value to be plugged in later: */
817*61046927SAndroid Build Coastguard Worker                        if (variant->compiler->gen >= 5)
818*61046927SAndroid Build Coastguard Worker                           add_const($3, 0, 0, 0, 0);
819*61046927SAndroid Build Coastguard Worker }
820*61046927SAndroid Build Coastguard Worker 
821*61046927SAndroid Build Coastguard Worker branchstack_header: T_A_BRANCHSTACK const_val { variant->branchstack = $2; }
822*61046927SAndroid Build Coastguard Worker 
823*61046927SAndroid Build Coastguard Worker pvtmem_header: T_A_PVTMEM const_val { variant->pvtmem_size = $2; }
824*61046927SAndroid Build Coastguard Worker 
825*61046927SAndroid Build Coastguard Worker earlypreamble_header: T_A_EARLYPREAMBLE { variant->early_preamble = 1; }
826*61046927SAndroid Build Coastguard Worker 
827*61046927SAndroid Build Coastguard Worker /* Stubs for now */
828*61046927SAndroid Build Coastguard Worker in_header:         T_A_IN '(' T_REGISTER ')' T_IDENTIFIER '(' T_IDENTIFIER '=' integer ')' { }
829*61046927SAndroid Build Coastguard Worker 
830*61046927SAndroid Build Coastguard Worker out_header:        T_A_OUT '(' T_REGISTER ')' T_IDENTIFIER '(' T_IDENTIFIER '=' integer ')' { }
831*61046927SAndroid Build Coastguard Worker 
832*61046927SAndroid Build Coastguard Worker tex_header:        T_A_TEX '(' T_REGISTER ')'
833*61046927SAndroid Build Coastguard Worker                        T_IDENTIFIER '=' integer ',' /* src */
834*61046927SAndroid Build Coastguard Worker                        T_IDENTIFIER '=' integer ',' /* samp */
835*61046927SAndroid Build Coastguard Worker                        T_IDENTIFIER '=' integer ',' /* tex */
836*61046927SAndroid Build Coastguard Worker                        T_IDENTIFIER '=' integer ',' /* wrmask */
837*61046927SAndroid Build Coastguard Worker                        T_IDENTIFIER '=' integer     /* cmd */ { }
838*61046927SAndroid Build Coastguard Worker 
839*61046927SAndroid Build Coastguard Worker iflag:             T_SY   { iflags.flags |= IR3_INSTR_SY; }
840*61046927SAndroid Build Coastguard Worker |                  T_SS   { iflags.flags |= IR3_INSTR_SS; }
841*61046927SAndroid Build Coastguard Worker |                  T_JP   { iflags.flags |= IR3_INSTR_JP; }
842*61046927SAndroid Build Coastguard Worker |                  T_EQ_FLAG { iflags.flags |= IR3_INSTR_EQ; }
843*61046927SAndroid Build Coastguard Worker |                  T_SAT  { iflags.flags |= IR3_INSTR_SAT; }
844*61046927SAndroid Build Coastguard Worker |                  T_RPT  { iflags.repeat = $1; }
845*61046927SAndroid Build Coastguard Worker |                  T_UL   { iflags.flags |= IR3_INSTR_UL; }
846*61046927SAndroid Build Coastguard Worker |                  T_NOP  { iflags.nop = $1; }
847*61046927SAndroid Build Coastguard Worker 
848*61046927SAndroid Build Coastguard Worker iflags:
849*61046927SAndroid Build Coastguard Worker |                  iflag iflags
850*61046927SAndroid Build Coastguard Worker 
851*61046927SAndroid Build Coastguard Worker instrs:            instrs instr
852*61046927SAndroid Build Coastguard Worker |                  instr
853*61046927SAndroid Build Coastguard Worker 
854*61046927SAndroid Build Coastguard Worker instr:             iflags cat0_instr
855*61046927SAndroid Build Coastguard Worker |                  iflags cat1_instr
856*61046927SAndroid Build Coastguard Worker |                  iflags cat2_instr
857*61046927SAndroid Build Coastguard Worker |                  iflags cat3_instr
858*61046927SAndroid Build Coastguard Worker |                  iflags cat4_instr
859*61046927SAndroid Build Coastguard Worker |                  iflags cat5_instr { fixup_cat5_s2en(); }
860*61046927SAndroid Build Coastguard Worker |                  iflags cat6_instr
861*61046927SAndroid Build Coastguard Worker |                  iflags cat7_instr
862*61046927SAndroid Build Coastguard Worker |                  raw_instr
863*61046927SAndroid Build Coastguard Worker |                  meta_print
864*61046927SAndroid Build Coastguard Worker |                  label
865*61046927SAndroid Build Coastguard Worker 
866*61046927SAndroid Build Coastguard Worker label:             T_IDENTIFIER ':' { new_label($1); }
867*61046927SAndroid Build Coastguard Worker 
868*61046927SAndroid Build Coastguard Worker cat0_src1:         '!' T_P0        { instr->cat0.inv1 = true; $$ = new_src((62 << 3) + $2, IR3_REG_PREDICATE); }
869*61046927SAndroid Build Coastguard Worker |                  T_P0            { $$ = new_src((62 << 3) + $1, IR3_REG_PREDICATE); }
870*61046927SAndroid Build Coastguard Worker 
871*61046927SAndroid Build Coastguard Worker cat0_src2:         '!' T_P0        { instr->cat0.inv2 = true; $$ = new_src((62 << 3) + $2, IR3_REG_PREDICATE); }
872*61046927SAndroid Build Coastguard Worker |                  T_P0            { $$ = new_src((62 << 3) + $1, IR3_REG_PREDICATE); }
873*61046927SAndroid Build Coastguard Worker 
874*61046927SAndroid Build Coastguard Worker cat0_immed:        '#' integer     { instr->cat0.immed = $2; }
875*61046927SAndroid Build Coastguard Worker |                  '#' T_IDENTIFIER { ralloc_steal(instr, (void *)$2); instr->cat0.target_label = $2; }
876*61046927SAndroid Build Coastguard Worker 
877*61046927SAndroid Build Coastguard Worker cat0_instr:        T_OP_NOP        { new_instr(OPC_NOP); }
878*61046927SAndroid Build Coastguard Worker |                  T_OP_BR         { new_instr(OPC_BR);   } cat0_src1 ',' cat0_immed
879*61046927SAndroid Build Coastguard Worker |                  T_OP_BRAO       { new_instr(OPC_BRAO); } cat0_src1 ',' cat0_src2 ',' cat0_immed
880*61046927SAndroid Build Coastguard Worker |                  T_OP_BRAA       { new_instr(OPC_BRAA); } cat0_src1 ',' cat0_src2 ',' cat0_immed
881*61046927SAndroid Build Coastguard Worker |                  T_OP_BRAC '.' integer { new_instr(OPC_BRAC)->cat0.idx = $3; } cat0_immed
882*61046927SAndroid Build Coastguard Worker |                  T_OP_BANY       { new_instr(OPC_BANY); } cat0_src1 ',' cat0_immed
883*61046927SAndroid Build Coastguard Worker |                  T_OP_BALL       { new_instr(OPC_BALL); } cat0_src1 ',' cat0_immed
884*61046927SAndroid Build Coastguard Worker |                  T_OP_BRAX       { new_instr(OPC_BRAX); } cat0_immed
885*61046927SAndroid Build Coastguard Worker |                  T_OP_JUMP       { new_instr(OPC_JUMP); }  cat0_immed
886*61046927SAndroid Build Coastguard Worker |                  T_OP_CALL       { new_instr(OPC_CALL); }  cat0_immed
887*61046927SAndroid Build Coastguard Worker |                  T_OP_RET        { new_instr(OPC_RET); }
888*61046927SAndroid Build Coastguard Worker |                  T_OP_KILL       { new_instr(OPC_KILL); }  cat0_src1
889*61046927SAndroid Build Coastguard Worker |                  T_OP_END        { new_instr(OPC_END); }
890*61046927SAndroid Build Coastguard Worker |                  T_OP_EMIT       { new_instr(OPC_EMIT); }
891*61046927SAndroid Build Coastguard Worker |                  T_OP_CUT        { new_instr(OPC_CUT); }
892*61046927SAndroid Build Coastguard Worker |                  T_OP_CHMASK     { new_instr(OPC_CHMASK); }
893*61046927SAndroid Build Coastguard Worker |                  T_OP_CHSH       { new_instr(OPC_CHSH); }
894*61046927SAndroid Build Coastguard Worker |                  T_OP_FLOW_REV   { new_instr(OPC_FLOW_REV); }
895*61046927SAndroid Build Coastguard Worker |                  T_OP_BKT        { new_instr(OPC_BKT); }      cat0_immed
896*61046927SAndroid Build Coastguard Worker |                  T_OP_STKS       { new_instr(OPC_STKS); }
897*61046927SAndroid Build Coastguard Worker |                  T_OP_STKR       { new_instr(OPC_STKR); }
898*61046927SAndroid Build Coastguard Worker |                  T_OP_XSET       { new_instr(OPC_XSET); }
899*61046927SAndroid Build Coastguard Worker |                  T_OP_XCLR       { new_instr(OPC_XCLR); }
900*61046927SAndroid Build Coastguard Worker |                  T_OP_GETONE     { new_instr(OPC_GETONE); }   cat0_immed
901*61046927SAndroid Build Coastguard Worker |                  T_OP_DBG        { new_instr(OPC_DBG); }
902*61046927SAndroid Build Coastguard Worker |                  T_OP_SHPS       { new_instr(OPC_SHPS); }     cat0_immed
903*61046927SAndroid Build Coastguard Worker |                  T_OP_SHPE       { new_instr(OPC_SHPE); }
904*61046927SAndroid Build Coastguard Worker |                  T_OP_PREDT      { new_instr(OPC_PREDT); }
905*61046927SAndroid Build Coastguard Worker |                  T_OP_PREDF      { new_instr(OPC_PREDF); }
906*61046927SAndroid Build Coastguard Worker |                  T_OP_PREDE      { new_instr(OPC_PREDE); }
907*61046927SAndroid Build Coastguard Worker |                  T_OP_GETLAST '.' T_W { new_instr(OPC_GETLAST); }   cat0_immed
908*61046927SAndroid Build Coastguard Worker 
909*61046927SAndroid Build Coastguard Worker cat1_opc:          T_OP_MOV '.' T_CAT1_TYPE_TYPE {
910*61046927SAndroid Build Coastguard Worker                        parse_type_type(new_instr(OPC_MOV), $3);
911*61046927SAndroid Build Coastguard Worker }
912*61046927SAndroid Build Coastguard Worker |                  T_OP_COV '.' T_CAT1_TYPE_TYPE {
913*61046927SAndroid Build Coastguard Worker                        parse_type_type(new_instr(OPC_MOV), $3);
914*61046927SAndroid Build Coastguard Worker }
915*61046927SAndroid Build Coastguard Worker 
916*61046927SAndroid Build Coastguard Worker cat1_src:          src_reg_or_const_or_rel
917*61046927SAndroid Build Coastguard Worker |                  immediate_cat1
918*61046927SAndroid Build Coastguard Worker 
919*61046927SAndroid Build Coastguard Worker cat1_movmsk:       T_OP_MOVMSK '.' T_W {
920*61046927SAndroid Build Coastguard Worker                        new_instr(OPC_MOVMSK);
921*61046927SAndroid Build Coastguard Worker                        instr->cat1.src_type = TYPE_U32;
922*61046927SAndroid Build Coastguard Worker                        instr->cat1.dst_type = TYPE_U32;
923*61046927SAndroid Build Coastguard Worker                    } dst_reg {
924*61046927SAndroid Build Coastguard Worker                        if (($3 % 32) != 0)
925*61046927SAndroid Build Coastguard Worker                           yyerror("w# must be multiple of 32");
926*61046927SAndroid Build Coastguard Worker                        if ($3 < 32)
927*61046927SAndroid Build Coastguard Worker                           yyerror("w# must be at least 32");
928*61046927SAndroid Build Coastguard Worker 
929*61046927SAndroid Build Coastguard Worker                        int num = $3 / 32;
930*61046927SAndroid Build Coastguard Worker 
931*61046927SAndroid Build Coastguard Worker                        instr->repeat = num - 1;
932*61046927SAndroid Build Coastguard Worker                        instr->dsts[0]->wrmask = (1 << num) - 1;
933*61046927SAndroid Build Coastguard Worker                    }
934*61046927SAndroid Build Coastguard Worker 
935*61046927SAndroid Build Coastguard Worker mova_src:          src_reg_or_const_or_rel
936*61046927SAndroid Build Coastguard Worker |                  immediate_cat1
937*61046927SAndroid Build Coastguard Worker |                  src_reg_flags immediate_cat1
938*61046927SAndroid Build Coastguard Worker 
939*61046927SAndroid Build Coastguard Worker cat1_mova1:        T_OP_MOVA1 T_A1 ',' {
940*61046927SAndroid Build Coastguard Worker                        new_instr(OPC_MOV);
941*61046927SAndroid Build Coastguard Worker                        instr->cat1.src_type = TYPE_U16;
942*61046927SAndroid Build Coastguard Worker                        instr->cat1.dst_type = TYPE_U16;
943*61046927SAndroid Build Coastguard Worker                        new_dst((61 << 3) + 2, IR3_REG_HALF);
944*61046927SAndroid Build Coastguard Worker                    } mova_src
945*61046927SAndroid Build Coastguard Worker 
946*61046927SAndroid Build Coastguard Worker cat1_mova:         T_OP_MOVA T_A0 ',' {
947*61046927SAndroid Build Coastguard Worker                        new_instr(OPC_MOV);
948*61046927SAndroid Build Coastguard Worker                        instr->cat1.src_type = TYPE_S16;
949*61046927SAndroid Build Coastguard Worker                        instr->cat1.dst_type = TYPE_S16;
950*61046927SAndroid Build Coastguard Worker                        new_dst((61 << 3), IR3_REG_HALF);
951*61046927SAndroid Build Coastguard Worker                    } mova_src
952*61046927SAndroid Build Coastguard Worker 
953*61046927SAndroid Build Coastguard Worker cat1_swz:          T_OP_SWZ '.' T_CAT1_TYPE_TYPE { parse_type_type(new_instr(OPC_SWZ), $3); } dst_reg ',' dst_reg ',' src_reg ',' src_reg
954*61046927SAndroid Build Coastguard Worker 
955*61046927SAndroid Build Coastguard Worker cat1_gat:          T_OP_GAT '.' T_CAT1_TYPE_TYPE { parse_type_type(new_instr(OPC_GAT), $3); } dst_reg ',' src_reg ',' src_reg ',' src_reg ',' src_reg
956*61046927SAndroid Build Coastguard Worker 
957*61046927SAndroid Build Coastguard Worker cat1_sct:          T_OP_SCT '.' T_CAT1_TYPE_TYPE { parse_type_type(new_instr(OPC_SCT), $3); } dst_reg ',' dst_reg ',' dst_reg ',' dst_reg ',' src_reg
958*61046927SAndroid Build Coastguard Worker 
959*61046927SAndroid Build Coastguard Worker                    /* NOTE: cat1 can also *write* to relative gpr */
960*61046927SAndroid Build Coastguard Worker cat1_instr:        cat1_movmsk
961*61046927SAndroid Build Coastguard Worker |                  cat1_mova1
962*61046927SAndroid Build Coastguard Worker |                  cat1_mova
963*61046927SAndroid Build Coastguard Worker |                  cat1_swz
964*61046927SAndroid Build Coastguard Worker |                  cat1_gat
965*61046927SAndroid Build Coastguard Worker |                  cat1_sct
966*61046927SAndroid Build Coastguard Worker |                  cat1_opc dst_reg ',' cat1_src
967*61046927SAndroid Build Coastguard Worker |                  cat1_opc relative_gpr_dst ',' cat1_src
968*61046927SAndroid Build Coastguard Worker 
969*61046927SAndroid Build Coastguard Worker cat2_opc_1src:     T_OP_ABSNEG_F  { new_instr(OPC_ABSNEG_F); }
970*61046927SAndroid Build Coastguard Worker |                  T_OP_ABSNEG_S  { new_instr(OPC_ABSNEG_S); }
971*61046927SAndroid Build Coastguard Worker |                  T_OP_CLZ_B     { new_instr(OPC_CLZ_B); }
972*61046927SAndroid Build Coastguard Worker |                  T_OP_CLZ_S     { new_instr(OPC_CLZ_S); }
973*61046927SAndroid Build Coastguard Worker |                  T_OP_SIGN_F    { new_instr(OPC_SIGN_F); }
974*61046927SAndroid Build Coastguard Worker |                  T_OP_FLOOR_F   { new_instr(OPC_FLOOR_F); }
975*61046927SAndroid Build Coastguard Worker |                  T_OP_CEIL_F    { new_instr(OPC_CEIL_F); }
976*61046927SAndroid Build Coastguard Worker |                  T_OP_RNDNE_F   { new_instr(OPC_RNDNE_F); }
977*61046927SAndroid Build Coastguard Worker |                  T_OP_RNDAZ_F   { new_instr(OPC_RNDAZ_F); }
978*61046927SAndroid Build Coastguard Worker |                  T_OP_TRUNC_F   { new_instr(OPC_TRUNC_F); }
979*61046927SAndroid Build Coastguard Worker |                  T_OP_NOT_B     { new_instr(OPC_NOT_B); }
980*61046927SAndroid Build Coastguard Worker |                  T_OP_BFREV_B   { new_instr(OPC_BFREV_B); }
981*61046927SAndroid Build Coastguard Worker |                  T_OP_SETRM     { new_instr(OPC_SETRM); }
982*61046927SAndroid Build Coastguard Worker |                  T_OP_CBITS_B   { new_instr(OPC_CBITS_B); }
983*61046927SAndroid Build Coastguard Worker 
984*61046927SAndroid Build Coastguard Worker cat2_opc_2src_cnd: T_OP_CMPS_F    { new_instr(OPC_CMPS_F); }
985*61046927SAndroid Build Coastguard Worker |                  T_OP_CMPS_U    { new_instr(OPC_CMPS_U); }
986*61046927SAndroid Build Coastguard Worker |                  T_OP_CMPS_S    { new_instr(OPC_CMPS_S); }
987*61046927SAndroid Build Coastguard Worker |                  T_OP_CMPV_F    { new_instr(OPC_CMPV_F); }
988*61046927SAndroid Build Coastguard Worker |                  T_OP_CMPV_U    { new_instr(OPC_CMPV_U); }
989*61046927SAndroid Build Coastguard Worker |                  T_OP_CMPV_S    { new_instr(OPC_CMPV_S); }
990*61046927SAndroid Build Coastguard Worker 
991*61046927SAndroid Build Coastguard Worker cat2_opc_2src:     T_OP_ADD_F     { new_instr(OPC_ADD_F); }
992*61046927SAndroid Build Coastguard Worker |                  T_OP_MIN_F     { new_instr(OPC_MIN_F); }
993*61046927SAndroid Build Coastguard Worker |                  T_OP_MAX_F     { new_instr(OPC_MAX_F); }
994*61046927SAndroid Build Coastguard Worker |                  T_OP_MUL_F     { new_instr(OPC_MUL_F); }
995*61046927SAndroid Build Coastguard Worker |                  T_OP_ADD_U     { new_instr(OPC_ADD_U); }
996*61046927SAndroid Build Coastguard Worker |                  T_OP_ADD_S     { new_instr(OPC_ADD_S); }
997*61046927SAndroid Build Coastguard Worker |                  T_OP_SUB_U     { new_instr(OPC_SUB_U); }
998*61046927SAndroid Build Coastguard Worker |                  T_OP_SUB_S     { new_instr(OPC_SUB_S); }
999*61046927SAndroid Build Coastguard Worker |                  T_OP_MIN_U     { new_instr(OPC_MIN_U); }
1000*61046927SAndroid Build Coastguard Worker |                  T_OP_MIN_S     { new_instr(OPC_MIN_S); }
1001*61046927SAndroid Build Coastguard Worker |                  T_OP_MAX_U     { new_instr(OPC_MAX_U); }
1002*61046927SAndroid Build Coastguard Worker |                  T_OP_MAX_S     { new_instr(OPC_MAX_S); }
1003*61046927SAndroid Build Coastguard Worker |                  T_OP_AND_B     { new_instr(OPC_AND_B); }
1004*61046927SAndroid Build Coastguard Worker |                  T_OP_OR_B      { new_instr(OPC_OR_B); }
1005*61046927SAndroid Build Coastguard Worker |                  T_OP_XOR_B     { new_instr(OPC_XOR_B); }
1006*61046927SAndroid Build Coastguard Worker |                  T_OP_MUL_U24   { new_instr(OPC_MUL_U24); }
1007*61046927SAndroid Build Coastguard Worker |                  T_OP_MUL_S24   { new_instr(OPC_MUL_S24); }
1008*61046927SAndroid Build Coastguard Worker |                  T_OP_MULL_U    { new_instr(OPC_MULL_U); }
1009*61046927SAndroid Build Coastguard Worker |                  T_OP_SHL_B     { new_instr(OPC_SHL_B); }
1010*61046927SAndroid Build Coastguard Worker |                  T_OP_SHR_B     { new_instr(OPC_SHR_B); }
1011*61046927SAndroid Build Coastguard Worker |                  T_OP_ASHR_B    { new_instr(OPC_ASHR_B); }
1012*61046927SAndroid Build Coastguard Worker |                  T_OP_BARY_F    { new_instr(OPC_BARY_F); }
1013*61046927SAndroid Build Coastguard Worker |                  T_OP_FLAT_B    { new_instr(OPC_FLAT_B); }
1014*61046927SAndroid Build Coastguard Worker |                  T_OP_MGEN_B    { new_instr(OPC_MGEN_B); }
1015*61046927SAndroid Build Coastguard Worker |                  T_OP_GETBIT_B  { new_instr(OPC_GETBIT_B); }
1016*61046927SAndroid Build Coastguard Worker |                  T_OP_SHB       { new_instr(OPC_SHB); }
1017*61046927SAndroid Build Coastguard Worker |                  T_OP_MSAD      { new_instr(OPC_MSAD); }
1018*61046927SAndroid Build Coastguard Worker 
1019*61046927SAndroid Build Coastguard Worker cond:              T_LT           { instr->cat2.condition = IR3_COND_LT; }
1020*61046927SAndroid Build Coastguard Worker |                  T_LE           { instr->cat2.condition = IR3_COND_LE; }
1021*61046927SAndroid Build Coastguard Worker |                  T_GT           { instr->cat2.condition = IR3_COND_GT; }
1022*61046927SAndroid Build Coastguard Worker |                  T_GE           { instr->cat2.condition = IR3_COND_GE; }
1023*61046927SAndroid Build Coastguard Worker |                  T_EQ           { instr->cat2.condition = IR3_COND_EQ; }
1024*61046927SAndroid Build Coastguard Worker |                  T_NE           { instr->cat2.condition = IR3_COND_NE; }
1025*61046927SAndroid Build Coastguard Worker 
1026*61046927SAndroid Build Coastguard Worker cat2_instr:        cat2_opc_1src dst_reg ',' src_reg_or_const_or_rel_or_imm
1027*61046927SAndroid Build Coastguard Worker |                  cat2_opc_2src_cnd '.' cond dst_reg ',' src_reg_or_const_or_rel_or_imm ',' src_reg_or_const_or_rel_or_imm
1028*61046927SAndroid Build Coastguard Worker |                  cat2_opc_2src dst_reg ',' src_reg_or_const_or_rel_or_imm ',' src_reg_or_const_or_rel_or_imm
1029*61046927SAndroid Build Coastguard Worker 
1030*61046927SAndroid Build Coastguard Worker cat3_dp_signedness:'.' T_MIXED   { instr->cat3.signedness = IR3_SRC_MIXED; }
1031*61046927SAndroid Build Coastguard Worker |                  '.' T_UNSIGNED{ instr->cat3.signedness = IR3_SRC_UNSIGNED; }
1032*61046927SAndroid Build Coastguard Worker 
1033*61046927SAndroid Build Coastguard Worker cat3_dp_pack:      '.' T_LOW     { instr->cat3.packed = IR3_SRC_PACKED_LOW; }
1034*61046927SAndroid Build Coastguard Worker |                  '.' T_HIGH    { instr->cat3.packed = IR3_SRC_PACKED_HIGH; }
1035*61046927SAndroid Build Coastguard Worker 
1036*61046927SAndroid Build Coastguard Worker cat3_opc:          T_OP_MAD_U16   { new_instr(OPC_MAD_U16); }
1037*61046927SAndroid Build Coastguard Worker |                  T_OP_MADSH_U16 { new_instr(OPC_MADSH_U16); }
1038*61046927SAndroid Build Coastguard Worker |                  T_OP_MAD_S16   { new_instr(OPC_MAD_S16); }
1039*61046927SAndroid Build Coastguard Worker |                  T_OP_MADSH_M16 { new_instr(OPC_MADSH_M16); }
1040*61046927SAndroid Build Coastguard Worker |                  T_OP_MAD_U24   { new_instr(OPC_MAD_U24); }
1041*61046927SAndroid Build Coastguard Worker |                  T_OP_MAD_S24   { new_instr(OPC_MAD_S24); }
1042*61046927SAndroid Build Coastguard Worker |                  T_OP_MAD_F16   { new_instr(OPC_MAD_F16); }
1043*61046927SAndroid Build Coastguard Worker |                  T_OP_MAD_F32   { new_instr(OPC_MAD_F32); }
1044*61046927SAndroid Build Coastguard Worker |                  T_OP_SEL_B16   { new_instr(OPC_SEL_B16); }
1045*61046927SAndroid Build Coastguard Worker |                  T_OP_SEL_B32   { new_instr(OPC_SEL_B32); }
1046*61046927SAndroid Build Coastguard Worker |                  T_OP_SEL_S16   { new_instr(OPC_SEL_S16); }
1047*61046927SAndroid Build Coastguard Worker |                  T_OP_SEL_S32   { new_instr(OPC_SEL_S32); }
1048*61046927SAndroid Build Coastguard Worker |                  T_OP_SEL_F16   { new_instr(OPC_SEL_F16); }
1049*61046927SAndroid Build Coastguard Worker |                  T_OP_SEL_F32   { new_instr(OPC_SEL_F32); }
1050*61046927SAndroid Build Coastguard Worker |                  T_OP_SAD_S16   { new_instr(OPC_SAD_S16); }
1051*61046927SAndroid Build Coastguard Worker |                  T_OP_SAD_S32   { new_instr(OPC_SAD_S32); }
1052*61046927SAndroid Build Coastguard Worker 
1053*61046927SAndroid Build Coastguard Worker cat3_imm_reg_opc:  T_OP_SHRM      { new_instr(OPC_SHRM); }
1054*61046927SAndroid Build Coastguard Worker |                  T_OP_SHLM      { new_instr(OPC_SHLM); }
1055*61046927SAndroid Build Coastguard Worker |                  T_OP_SHRG      { new_instr(OPC_SHRG); }
1056*61046927SAndroid Build Coastguard Worker |                  T_OP_SHLG      { new_instr(OPC_SHLG); }
1057*61046927SAndroid Build Coastguard Worker |                  T_OP_ANDG      { new_instr(OPC_ANDG); }
1058*61046927SAndroid Build Coastguard Worker 
1059*61046927SAndroid Build Coastguard Worker cat3_wmm:          T_OP_WMM       { new_instr(OPC_WMM); }
1060*61046927SAndroid Build Coastguard Worker |                  T_OP_WMM_ACCU  { new_instr(OPC_WMM_ACCU); }
1061*61046927SAndroid Build Coastguard Worker 
1062*61046927SAndroid Build Coastguard Worker cat3_dp:           T_OP_DP2ACC    { new_instr(OPC_DP2ACC); }
1063*61046927SAndroid Build Coastguard Worker |                  T_OP_DP4ACC    { new_instr(OPC_DP4ACC); }
1064*61046927SAndroid Build Coastguard Worker 
1065*61046927SAndroid Build Coastguard Worker cat3_instr:        cat3_opc dst_reg ',' src_reg_or_const_or_rel ',' src_reg_or_const ',' src_reg_or_const_or_rel
1066*61046927SAndroid Build Coastguard Worker |                  cat3_imm_reg_opc dst_reg ',' src_reg_or_rel_or_imm ',' src_reg_or_const ',' src_reg_or_rel_or_imm
1067*61046927SAndroid Build Coastguard Worker |                  cat3_wmm         dst_reg ',' src_reg_gpr ',' src_reg ',' immediate
1068*61046927SAndroid Build Coastguard Worker |                  cat3_dp cat3_dp_signedness cat3_dp_pack dst_reg ',' src_reg_or_rel_or_imm ',' src_reg_or_const ',' src_reg_or_rel_or_imm
1069*61046927SAndroid Build Coastguard Worker 
1070*61046927SAndroid Build Coastguard Worker cat4_opc:          T_OP_RCP       { new_instr(OPC_RCP); }
1071*61046927SAndroid Build Coastguard Worker |                  T_OP_RSQ       { new_instr(OPC_RSQ); }
1072*61046927SAndroid Build Coastguard Worker |                  T_OP_LOG2      { new_instr(OPC_LOG2); }
1073*61046927SAndroid Build Coastguard Worker |                  T_OP_EXP2      { new_instr(OPC_EXP2); }
1074*61046927SAndroid Build Coastguard Worker |                  T_OP_SIN       { new_instr(OPC_SIN); }
1075*61046927SAndroid Build Coastguard Worker |                  T_OP_COS       { new_instr(OPC_COS); }
1076*61046927SAndroid Build Coastguard Worker |                  T_OP_SQRT      { new_instr(OPC_SQRT); }
1077*61046927SAndroid Build Coastguard Worker |                  T_OP_HRSQ      { new_instr(OPC_HRSQ); }
1078*61046927SAndroid Build Coastguard Worker |                  T_OP_HLOG2     { new_instr(OPC_HLOG2); }
1079*61046927SAndroid Build Coastguard Worker |                  T_OP_HEXP2     { new_instr(OPC_HEXP2); }
1080*61046927SAndroid Build Coastguard Worker 
1081*61046927SAndroid Build Coastguard Worker cat4_instr:        cat4_opc dst_reg ',' src_reg_or_const_or_rel_or_imm
1082*61046927SAndroid Build Coastguard Worker 
1083*61046927SAndroid Build Coastguard Worker cat5_opc_dsxypp:   T_OP_DSXPP_1   { new_instr(OPC_DSXPP_1)->cat5.type = TYPE_F32; }
1084*61046927SAndroid Build Coastguard Worker |                  T_OP_DSYPP_1   { new_instr(OPC_DSYPP_1)->cat5.type = TYPE_F32; }
1085*61046927SAndroid Build Coastguard Worker 
1086*61046927SAndroid Build Coastguard Worker cat5_opc_isam:     T_OP_ISAM      { new_instr(OPC_ISAM)->flags |= IR3_INSTR_INV_1D; }
1087*61046927SAndroid Build Coastguard Worker 
1088*61046927SAndroid Build Coastguard Worker cat5_opc:          T_OP_ISAML     { new_instr(OPC_ISAML); }
1089*61046927SAndroid Build Coastguard Worker |                  T_OP_ISAMM     { new_instr(OPC_ISAMM); }
1090*61046927SAndroid Build Coastguard Worker |                  T_OP_SAM       { new_instr(OPC_SAM); }
1091*61046927SAndroid Build Coastguard Worker |                  T_OP_SAMB      { new_instr(OPC_SAMB); }
1092*61046927SAndroid Build Coastguard Worker |                  T_OP_SAML      { new_instr(OPC_SAML); }
1093*61046927SAndroid Build Coastguard Worker |                  T_OP_SAMGQ     { new_instr(OPC_SAMGQ); }
1094*61046927SAndroid Build Coastguard Worker |                  T_OP_GETLOD    { new_instr(OPC_GETLOD); }
1095*61046927SAndroid Build Coastguard Worker |                  T_OP_CONV      { new_instr(OPC_CONV); }
1096*61046927SAndroid Build Coastguard Worker |                  T_OP_CONVM     { new_instr(OPC_CONVM); }
1097*61046927SAndroid Build Coastguard Worker |                  T_OP_GETSIZE   { new_instr(OPC_GETSIZE); }
1098*61046927SAndroid Build Coastguard Worker |                  T_OP_GETBUF    { new_instr(OPC_GETBUF); }
1099*61046927SAndroid Build Coastguard Worker |                  T_OP_GETPOS    { new_instr(OPC_GETPOS); }
1100*61046927SAndroid Build Coastguard Worker |                  T_OP_GETINFO   { new_instr(OPC_GETINFO); }
1101*61046927SAndroid Build Coastguard Worker |                  T_OP_DSX       { new_instr(OPC_DSX); }
1102*61046927SAndroid Build Coastguard Worker |                  T_OP_DSY       { new_instr(OPC_DSY); }
1103*61046927SAndroid Build Coastguard Worker |                  T_OP_GATHER4R  { new_instr(OPC_GATHER4R); }
1104*61046927SAndroid Build Coastguard Worker |                  T_OP_GATHER4G  { new_instr(OPC_GATHER4G); }
1105*61046927SAndroid Build Coastguard Worker |                  T_OP_GATHER4B  { new_instr(OPC_GATHER4B); }
1106*61046927SAndroid Build Coastguard Worker |                  T_OP_GATHER4A  { new_instr(OPC_GATHER4A); }
1107*61046927SAndroid Build Coastguard Worker |                  T_OP_SAMGP0    { new_instr(OPC_SAMGP0); }
1108*61046927SAndroid Build Coastguard Worker |                  T_OP_SAMGP1    { new_instr(OPC_SAMGP1); }
1109*61046927SAndroid Build Coastguard Worker |                  T_OP_SAMGP2    { new_instr(OPC_SAMGP2); }
1110*61046927SAndroid Build Coastguard Worker |                  T_OP_SAMGP3    { new_instr(OPC_SAMGP3); }
1111*61046927SAndroid Build Coastguard Worker |                  T_OP_RGETPOS   { new_instr(OPC_RGETPOS); }
1112*61046927SAndroid Build Coastguard Worker |                  T_OP_RGETINFO  { new_instr(OPC_RGETINFO); }
1113*61046927SAndroid Build Coastguard Worker |                  T_OP_BRCST_A   { new_instr(OPC_BRCST_ACTIVE); }
1114*61046927SAndroid Build Coastguard Worker |                  T_OP_QSHUFFLE_BRCST { new_instr(OPC_QUAD_SHUFFLE_BRCST); }
1115*61046927SAndroid Build Coastguard Worker |                  T_OP_QSHUFFLE_H     { new_instr(OPC_QUAD_SHUFFLE_HORIZ); }
1116*61046927SAndroid Build Coastguard Worker |                  T_OP_QSHUFFLE_V     { new_instr(OPC_QUAD_SHUFFLE_VERT); }
1117*61046927SAndroid Build Coastguard Worker |                  T_OP_QSHUFFLE_DIAG  { new_instr(OPC_QUAD_SHUFFLE_DIAG); }
1118*61046927SAndroid Build Coastguard Worker 
1119*61046927SAndroid Build Coastguard Worker cat5_flag:         '.' T_3D       { instr->flags |= IR3_INSTR_3D; }
1120*61046927SAndroid Build Coastguard Worker |                  '.' 'a'        { instr->flags |= IR3_INSTR_A; }
1121*61046927SAndroid Build Coastguard Worker |                  '.' 'o'        { instr->flags |= IR3_INSTR_O; }
1122*61046927SAndroid Build Coastguard Worker |                  '.' 'p'        { instr->flags |= IR3_INSTR_P; }
1123*61046927SAndroid Build Coastguard Worker |                  '.' 's'        { instr->flags |= IR3_INSTR_S; }
1124*61046927SAndroid Build Coastguard Worker |                  '.' T_S2EN     { instr->flags |= IR3_INSTR_S2EN; }
1125*61046927SAndroid Build Coastguard Worker |                  '.' T_1D       { instr->flags &= ~IR3_INSTR_INV_1D; }
1126*61046927SAndroid Build Coastguard Worker |                  '.' T_UNIFORM  { }
1127*61046927SAndroid Build Coastguard Worker |                  '.' T_NONUNIFORM  { instr->flags |= IR3_INSTR_NONUNIF; }
1128*61046927SAndroid Build Coastguard Worker |                  '.' T_BASE     { instr->flags |= IR3_INSTR_B; instr->cat5.tex_base = $2; }
1129*61046927SAndroid Build Coastguard Worker |                  '.' T_W        { instr->cat5.cluster_size = $2; }
1130*61046927SAndroid Build Coastguard Worker cat5_flags:
1131*61046927SAndroid Build Coastguard Worker |                  cat5_flag cat5_flags
1132*61046927SAndroid Build Coastguard Worker 
1133*61046927SAndroid Build Coastguard Worker cat5_samp:         T_SAMP         { instr->cat5.samp = $1; }
1134*61046927SAndroid Build Coastguard Worker cat5_tex:          T_TEX          { instr->cat5.tex = $1; }
1135*61046927SAndroid Build Coastguard Worker cat5_type:         '(' type ')'   { instr->cat5.type = $2; }
1136*61046927SAndroid Build Coastguard Worker cat5_a1:           src_reg        { instr->flags |= IR3_INSTR_A1EN; }
1137*61046927SAndroid Build Coastguard Worker 
1138*61046927SAndroid Build Coastguard Worker cat5_samp_tex:     src_reg
1139*61046927SAndroid Build Coastguard Worker |                  cat5_samp ',' cat5_tex
1140*61046927SAndroid Build Coastguard Worker |                  cat5_samp
1141*61046927SAndroid Build Coastguard Worker |                  cat5_tex
1142*61046927SAndroid Build Coastguard Worker 
1143*61046927SAndroid Build Coastguard Worker cat5_samp_tex_all: cat5_samp_tex
1144*61046927SAndroid Build Coastguard Worker |                  cat5_samp ',' cat5_a1
1145*61046927SAndroid Build Coastguard Worker |                  cat5_tex ',' cat5_a1
1146*61046927SAndroid Build Coastguard Worker 
1147*61046927SAndroid Build Coastguard Worker cat5_instr:        cat5_opc_dsxypp cat5_flags dst_reg ',' src_reg
1148*61046927SAndroid Build Coastguard Worker |                  cat5_opc cat5_flags cat5_type dst_reg ',' src_reg ',' src_reg ',' cat5_samp_tex_all
1149*61046927SAndroid Build Coastguard Worker |                  cat5_opc cat5_flags cat5_type dst_reg ',' src_reg ',' cat5_samp_tex_all
1150*61046927SAndroid Build Coastguard Worker |                  cat5_opc cat5_flags cat5_type dst_reg ',' cat5_samp_tex
1151*61046927SAndroid Build Coastguard Worker |                  cat5_opc cat5_flags cat5_type dst_reg
1152*61046927SAndroid Build Coastguard Worker |                  cat5_opc_isam cat5_flags cat5_type dst_reg ',' src_reg ',' src_reg ',' cat5_samp_tex_all
1153*61046927SAndroid Build Coastguard Worker |                  cat5_opc_isam cat5_flags cat5_type dst_reg ',' src_reg ',' cat5_samp_tex_all
1154*61046927SAndroid Build Coastguard Worker |                  cat5_opc_isam '.' 'v' cat5_flags cat5_type dst_reg ',' src_reg src_uoffset ',' cat5_samp_tex_all { instr->flags |= IR3_INSTR_V; }
1155*61046927SAndroid Build Coastguard Worker |                  T_OP_TCINV { new_instr(OPC_TCINV); }
1156*61046927SAndroid Build Coastguard Worker 
1157*61046927SAndroid Build Coastguard Worker cat6_typed:        '.' T_UNTYPED  { instr->cat6.typed = 0; }
1158*61046927SAndroid Build Coastguard Worker |                  '.' T_TYPED    { instr->cat6.typed = 1; }
1159*61046927SAndroid Build Coastguard Worker 
1160*61046927SAndroid Build Coastguard Worker cat6_dim:          '.' T_1D  { instr->cat6.d = 1; }
1161*61046927SAndroid Build Coastguard Worker |                  '.' T_2D  { instr->cat6.d = 2; }
1162*61046927SAndroid Build Coastguard Worker |                  '.' T_3D  { instr->cat6.d = 3; }
1163*61046927SAndroid Build Coastguard Worker |                  '.' T_4D  { instr->cat6.d = 4; }
1164*61046927SAndroid Build Coastguard Worker 
1165*61046927SAndroid Build Coastguard Worker cat6_type:         '.' type  { instr->cat6.type = $2; }
1166*61046927SAndroid Build Coastguard Worker cat6_imm_offset:   offset    { new_src(0, IR3_REG_IMMED)->iim_val = $1; }
1167*61046927SAndroid Build Coastguard Worker cat6_offset:       cat6_imm_offset
1168*61046927SAndroid Build Coastguard Worker |                  '+' src
1169*61046927SAndroid Build Coastguard Worker cat6_dst_offset:   offset    { instr->cat6.dst_offset = $1; }
1170*61046927SAndroid Build Coastguard Worker |                  '+' src
1171*61046927SAndroid Build Coastguard Worker 
1172*61046927SAndroid Build Coastguard Worker cat6_immed:        integer   { instr->cat6.iim_val = $1; }
1173*61046927SAndroid Build Coastguard Worker 
1174*61046927SAndroid Build Coastguard Worker cat6_a6xx_global_address_pt3:
1175*61046927SAndroid Build Coastguard Worker                    '<' '<' integer offset '<' '<' integer {
1176*61046927SAndroid Build Coastguard Worker                         assert($7 == 2);
1177*61046927SAndroid Build Coastguard Worker                         new_src(0, IR3_REG_IMMED)->uim_val = $3 - 2;
1178*61046927SAndroid Build Coastguard Worker                         new_src(0, IR3_REG_IMMED)->uim_val = $4;
1179*61046927SAndroid Build Coastguard Worker                    }
1180*61046927SAndroid Build Coastguard Worker |                  '+' cat6_reg_or_immed {
1181*61046927SAndroid Build Coastguard Worker                         // Dummy src to smooth the difference between a6xx and a7xx
1182*61046927SAndroid Build Coastguard Worker                         new_src(0, IR3_REG_IMMED)->uim_val = 0;
1183*61046927SAndroid Build Coastguard Worker                    }
1184*61046927SAndroid Build Coastguard Worker 
1185*61046927SAndroid Build Coastguard Worker cat6_a6xx_global_address_pt2:
1186*61046927SAndroid Build Coastguard Worker                    '(' src offset ')' '<' '<' integer {
1187*61046927SAndroid Build Coastguard Worker                         assert($7 == 2);
1188*61046927SAndroid Build Coastguard Worker                         new_src(0, IR3_REG_IMMED)->uim_val = 0;
1189*61046927SAndroid Build Coastguard Worker                         new_src(0, IR3_REG_IMMED)->uim_val = $3;
1190*61046927SAndroid Build Coastguard Worker                    }
1191*61046927SAndroid Build Coastguard Worker 
1192*61046927SAndroid Build Coastguard Worker |                  src cat6_a6xx_global_address_pt3
1193*61046927SAndroid Build Coastguard Worker 
1194*61046927SAndroid Build Coastguard Worker cat6_a6xx_global_address:
1195*61046927SAndroid Build Coastguard Worker                    src_reg_or_const '+' cat6_a6xx_global_address_pt2
1196*61046927SAndroid Build Coastguard Worker 
1197*61046927SAndroid Build Coastguard Worker cat6_load:         T_OP_LDG   { new_instr(OPC_LDG); }   cat6_type dst_reg ',' 'g' '[' src cat6_offset ']' ',' immediate
1198*61046927SAndroid Build Coastguard Worker |                  T_OP_LDG_A { new_instr(OPC_LDG_A); } cat6_type dst_reg ',' 'g' '[' cat6_a6xx_global_address ']' ',' immediate
1199*61046927SAndroid Build Coastguard Worker |                  T_OP_LDG_K { new_instr(OPC_LDG_K); } cat6_type 'c' '[' const_dst ']' ',' 'g' '[' src cat6_offset ']' ',' immediate
1200*61046927SAndroid Build Coastguard Worker |                  T_OP_LDP   { new_instr(OPC_LDP); }   cat6_type dst_reg ',' 'p' '[' src cat6_offset ']' ',' immediate
1201*61046927SAndroid Build Coastguard Worker |                  T_OP_LDL   { new_instr(OPC_LDL); }   cat6_type dst_reg ',' 'l' '[' src cat6_offset ']' ',' immediate
1202*61046927SAndroid Build Coastguard Worker |                  T_OP_LDLW  { new_instr(OPC_LDLW); }  cat6_type dst_reg ',' 'l' '[' src cat6_offset ']' ',' immediate
1203*61046927SAndroid Build Coastguard Worker |                  T_OP_LDLV  { new_instr(OPC_LDLV); }  cat6_type dst_reg ',' 'l' '[' integer ']' {
1204*61046927SAndroid Build Coastguard Worker                        new_src(0, IR3_REG_IMMED)->iim_val = $8;
1205*61046927SAndroid Build Coastguard Worker                    } ',' immediate
1206*61046927SAndroid Build Coastguard Worker 
1207*61046927SAndroid Build Coastguard Worker cat6_store:        T_OP_STG   { new_instr(OPC_STG); dummy_dst(); }   cat6_type 'g' '[' src cat6_imm_offset ']' ',' src ',' immediate
1208*61046927SAndroid Build Coastguard Worker |                  T_OP_STG_A { new_instr(OPC_STG_A); dummy_dst(); } cat6_type 'g' '[' cat6_a6xx_global_address ']' ',' src ',' immediate
1209*61046927SAndroid Build Coastguard Worker |                  T_OP_STP  { new_instr(OPC_STP); dummy_dst(); }  cat6_type 'p' '[' src cat6_dst_offset ']' ',' src ',' immediate
1210*61046927SAndroid Build Coastguard Worker |                  T_OP_STL  { new_instr(OPC_STL); dummy_dst(); }  cat6_type 'l' '[' src cat6_dst_offset ']' ',' src ',' immediate
1211*61046927SAndroid Build Coastguard Worker |                  T_OP_STLW { new_instr(OPC_STLW); dummy_dst(); } cat6_type 'l' '[' src cat6_dst_offset ']' ',' src ',' immediate
1212*61046927SAndroid Build Coastguard Worker 
1213*61046927SAndroid Build Coastguard Worker cat6_loadib:       T_OP_LDIB { new_instr(OPC_LDIB); } cat6_typed cat6_dim cat6_type '.' cat6_immed dst_reg ',' 'g' '[' immediate ']' ',' src ',' src
1214*61046927SAndroid Build Coastguard Worker cat6_storeib:      T_OP_STIB { new_instr(OPC_STIB); dummy_dst(); } cat6_typed cat6_dim cat6_type '.' cat6_immed'g' '[' immediate ']' ',' src ',' src ',' src
1215*61046927SAndroid Build Coastguard Worker 
1216*61046927SAndroid Build Coastguard Worker cat6_prefetch:     T_OP_PREFETCH { new_instr(OPC_PREFETCH); new_dst(0,0); /* dummy dst */ } 'g' '[' src cat6_offset ']' ',' cat6_immed
1217*61046927SAndroid Build Coastguard Worker 
1218*61046927SAndroid Build Coastguard Worker cat6_atomic_opc:   T_OP_ATOMIC_ADD     { new_instr(OPC_ATOMIC_ADD); }
1219*61046927SAndroid Build Coastguard Worker |                  T_OP_ATOMIC_SUB     { new_instr(OPC_ATOMIC_SUB); }
1220*61046927SAndroid Build Coastguard Worker |                  T_OP_ATOMIC_XCHG    { new_instr(OPC_ATOMIC_XCHG); }
1221*61046927SAndroid Build Coastguard Worker |                  T_OP_ATOMIC_INC     { new_instr(OPC_ATOMIC_INC); }
1222*61046927SAndroid Build Coastguard Worker |                  T_OP_ATOMIC_DEC     { new_instr(OPC_ATOMIC_DEC); }
1223*61046927SAndroid Build Coastguard Worker |                  T_OP_ATOMIC_CMPXCHG { new_instr(OPC_ATOMIC_CMPXCHG); }
1224*61046927SAndroid Build Coastguard Worker |                  T_OP_ATOMIC_MIN     { new_instr(OPC_ATOMIC_MIN); }
1225*61046927SAndroid Build Coastguard Worker |                  T_OP_ATOMIC_MAX     { new_instr(OPC_ATOMIC_MAX); }
1226*61046927SAndroid Build Coastguard Worker |                  T_OP_ATOMIC_AND     { new_instr(OPC_ATOMIC_AND); }
1227*61046927SAndroid Build Coastguard Worker |                  T_OP_ATOMIC_OR      { new_instr(OPC_ATOMIC_OR); }
1228*61046927SAndroid Build Coastguard Worker |                  T_OP_ATOMIC_XOR     { new_instr(OPC_ATOMIC_XOR); }
1229*61046927SAndroid Build Coastguard Worker 
1230*61046927SAndroid Build Coastguard Worker cat6_a3xx_atomic_opc:   T_OP_ATOMIC_S_ADD     { new_instr(OPC_ATOMIC_S_ADD); }
1231*61046927SAndroid Build Coastguard Worker |                       T_OP_ATOMIC_S_SUB     { new_instr(OPC_ATOMIC_S_SUB); }
1232*61046927SAndroid Build Coastguard Worker |                       T_OP_ATOMIC_S_XCHG    { new_instr(OPC_ATOMIC_S_XCHG); }
1233*61046927SAndroid Build Coastguard Worker |                       T_OP_ATOMIC_S_INC     { new_instr(OPC_ATOMIC_S_INC); }
1234*61046927SAndroid Build Coastguard Worker |                       T_OP_ATOMIC_S_DEC     { new_instr(OPC_ATOMIC_S_DEC); }
1235*61046927SAndroid Build Coastguard Worker |                       T_OP_ATOMIC_S_CMPXCHG { new_instr(OPC_ATOMIC_S_CMPXCHG); }
1236*61046927SAndroid Build Coastguard Worker |                       T_OP_ATOMIC_S_MIN     { new_instr(OPC_ATOMIC_S_MIN); }
1237*61046927SAndroid Build Coastguard Worker |                       T_OP_ATOMIC_S_MAX     { new_instr(OPC_ATOMIC_S_MAX); }
1238*61046927SAndroid Build Coastguard Worker |                       T_OP_ATOMIC_S_AND     { new_instr(OPC_ATOMIC_S_AND); }
1239*61046927SAndroid Build Coastguard Worker |                       T_OP_ATOMIC_S_OR      { new_instr(OPC_ATOMIC_S_OR); }
1240*61046927SAndroid Build Coastguard Worker |                       T_OP_ATOMIC_S_XOR     { new_instr(OPC_ATOMIC_S_XOR); }
1241*61046927SAndroid Build Coastguard Worker 
1242*61046927SAndroid Build Coastguard Worker cat6_a6xx_atomic_opc:   T_OP_ATOMIC_G_ADD     { new_instr(OPC_ATOMIC_G_ADD); }
1243*61046927SAndroid Build Coastguard Worker |                       T_OP_ATOMIC_G_SUB     { new_instr(OPC_ATOMIC_G_SUB); }
1244*61046927SAndroid Build Coastguard Worker |                       T_OP_ATOMIC_G_XCHG    { new_instr(OPC_ATOMIC_G_XCHG); }
1245*61046927SAndroid Build Coastguard Worker |                       T_OP_ATOMIC_G_INC     { new_instr(OPC_ATOMIC_G_INC); }
1246*61046927SAndroid Build Coastguard Worker |                       T_OP_ATOMIC_G_DEC     { new_instr(OPC_ATOMIC_G_DEC); }
1247*61046927SAndroid Build Coastguard Worker |                       T_OP_ATOMIC_G_CMPXCHG { new_instr(OPC_ATOMIC_G_CMPXCHG); }
1248*61046927SAndroid Build Coastguard Worker |                       T_OP_ATOMIC_G_MIN     { new_instr(OPC_ATOMIC_G_MIN); }
1249*61046927SAndroid Build Coastguard Worker |                       T_OP_ATOMIC_G_MAX     { new_instr(OPC_ATOMIC_G_MAX); }
1250*61046927SAndroid Build Coastguard Worker |                       T_OP_ATOMIC_G_AND     { new_instr(OPC_ATOMIC_G_AND); }
1251*61046927SAndroid Build Coastguard Worker |                       T_OP_ATOMIC_G_OR      { new_instr(OPC_ATOMIC_G_OR); }
1252*61046927SAndroid Build Coastguard Worker |                       T_OP_ATOMIC_G_XOR     { new_instr(OPC_ATOMIC_G_XOR); }
1253*61046927SAndroid Build Coastguard Worker 
1254*61046927SAndroid Build Coastguard Worker cat6_a3xx_atomic_s: cat6_a3xx_atomic_opc cat6_typed cat6_dim cat6_type '.' cat6_immed '.' 'g' dst_reg ',' 'g' '[' cat6_reg_or_immed ']' ',' src ',' src ',' src
1255*61046927SAndroid Build Coastguard Worker 
1256*61046927SAndroid Build Coastguard Worker cat6_a6xx_atomic_g: cat6_a6xx_atomic_opc cat6_typed cat6_dim cat6_type '.' cat6_immed '.' 'g' dst_reg ',' src ',' src
1257*61046927SAndroid Build Coastguard Worker 
1258*61046927SAndroid Build Coastguard Worker cat6_atomic_l:     cat6_atomic_opc cat6_typed cat6_dim cat6_type '.' cat6_immed '.' 'l' dst_reg ',' 'l' '[' cat6_reg_or_immed ']' ',' src
1259*61046927SAndroid Build Coastguard Worker 
1260*61046927SAndroid Build Coastguard Worker cat6_atomic:       cat6_atomic_l
1261*61046927SAndroid Build Coastguard Worker |                  cat6_a3xx_atomic_s
1262*61046927SAndroid Build Coastguard Worker |                  cat6_a6xx_atomic_g
1263*61046927SAndroid Build Coastguard Worker 
1264*61046927SAndroid Build Coastguard Worker cat6_ibo_opc_1src: T_OP_RESINFO   { new_instr(OPC_RESINFO); }
1265*61046927SAndroid Build Coastguard Worker 
1266*61046927SAndroid Build Coastguard Worker cat6_ibo_opc_ldgb: T_OP_LDGB      { new_instr(OPC_LDGB); }
1267*61046927SAndroid Build Coastguard Worker cat6_ibo_opc_stgb: T_OP_STGB      { new_instr(OPC_STGB); }
1268*61046927SAndroid Build Coastguard Worker 
1269*61046927SAndroid Build Coastguard Worker cat6_ibo:          cat6_ibo_opc_1src cat6_type cat6_dim dst_reg ',' 'g' '[' cat6_reg_or_immed ']'
1270*61046927SAndroid Build Coastguard Worker |                  cat6_ibo_opc_ldgb cat6_typed cat6_dim cat6_type '.' cat6_immed dst_reg ',' 'g' '[' cat6_reg_or_immed ']' ',' src ',' src
1271*61046927SAndroid Build Coastguard Worker |                  cat6_ibo_opc_stgb cat6_typed cat6_dim cat6_type '.' cat6_immed { dummy_dst(); } 'g' '[' cat6_reg_or_immed ']' ',' src ',' cat6_reg_or_immed ',' src
1272*61046927SAndroid Build Coastguard Worker 
1273*61046927SAndroid Build Coastguard Worker cat6_id_opc:
1274*61046927SAndroid Build Coastguard Worker                    T_OP_GETSPID { new_instr(OPC_GETSPID); }
1275*61046927SAndroid Build Coastguard Worker |                  T_OP_GETWID  { new_instr(OPC_GETWID); }
1276*61046927SAndroid Build Coastguard Worker |                  T_OP_GETFIBERID { new_instr(OPC_GETFIBERID); }
1277*61046927SAndroid Build Coastguard Worker 
1278*61046927SAndroid Build Coastguard Worker cat6_id:           cat6_id_opc cat6_type dst_reg
1279*61046927SAndroid Build Coastguard Worker 
1280*61046927SAndroid Build Coastguard Worker cat6_bindless_base:
1281*61046927SAndroid Build Coastguard Worker |                  '.' T_BASE { instr->flags |= IR3_INSTR_B; instr->cat6.base = $2; }
1282*61046927SAndroid Build Coastguard Worker 
1283*61046927SAndroid Build Coastguard Worker cat6_bindless_mode: T_IMM cat6_bindless_base
1284*61046927SAndroid Build Coastguard Worker |                  T_UNIFORM cat6_bindless_base
1285*61046927SAndroid Build Coastguard Worker |                  T_NONUNIFORM cat6_bindless_base { instr->flags |= IR3_INSTR_NONUNIF; }
1286*61046927SAndroid Build Coastguard Worker 
1287*61046927SAndroid Build Coastguard Worker cat6_reg_or_immed: src
1288*61046927SAndroid Build Coastguard Worker |                  integer { new_src(0, IR3_REG_IMMED)->iim_val = $1; }
1289*61046927SAndroid Build Coastguard Worker 
1290*61046927SAndroid Build Coastguard Worker cat6_bindless_ibo_opc_1src: T_OP_RESINFO_B       { new_instr(OPC_RESINFO); }
1291*61046927SAndroid Build Coastguard Worker 
1292*61046927SAndroid Build Coastguard Worker cat6_bindless_ibo_opc_2src: T_OP_ATOMIC_B_ADD        { new_instr(OPC_ATOMIC_B_ADD); dummy_dst(); }
1293*61046927SAndroid Build Coastguard Worker |                  T_OP_ATOMIC_B_SUB        { new_instr(OPC_ATOMIC_B_SUB); dummy_dst(); }
1294*61046927SAndroid Build Coastguard Worker |                  T_OP_ATOMIC_B_XCHG       { new_instr(OPC_ATOMIC_B_XCHG); dummy_dst(); }
1295*61046927SAndroid Build Coastguard Worker |                  T_OP_ATOMIC_B_INC        { new_instr(OPC_ATOMIC_B_INC); dummy_dst(); }
1296*61046927SAndroid Build Coastguard Worker |                  T_OP_ATOMIC_B_DEC        { new_instr(OPC_ATOMIC_B_DEC); dummy_dst(); }
1297*61046927SAndroid Build Coastguard Worker |                  T_OP_ATOMIC_B_CMPXCHG    { new_instr(OPC_ATOMIC_B_CMPXCHG); dummy_dst(); }
1298*61046927SAndroid Build Coastguard Worker |                  T_OP_ATOMIC_B_MIN        { new_instr(OPC_ATOMIC_B_MIN); dummy_dst(); }
1299*61046927SAndroid Build Coastguard Worker |                  T_OP_ATOMIC_B_MAX        { new_instr(OPC_ATOMIC_B_MAX); dummy_dst(); }
1300*61046927SAndroid Build Coastguard Worker |                  T_OP_ATOMIC_B_AND        { new_instr(OPC_ATOMIC_B_AND); dummy_dst(); }
1301*61046927SAndroid Build Coastguard Worker |                  T_OP_ATOMIC_B_OR         { new_instr(OPC_ATOMIC_B_OR); dummy_dst(); }
1302*61046927SAndroid Build Coastguard Worker |                  T_OP_ATOMIC_B_XOR        { new_instr(OPC_ATOMIC_B_XOR); dummy_dst(); }
1303*61046927SAndroid Build Coastguard Worker 
1304*61046927SAndroid Build Coastguard Worker cat6_bindless_ibo_opc_3src: T_OP_STIB_B     { new_instr(OPC_STIB); dummy_dst(); }
1305*61046927SAndroid Build Coastguard Worker 
1306*61046927SAndroid Build Coastguard Worker cat6_bindless_ibo_opc_3src_dst: T_OP_LDIB_B              { new_instr(OPC_LDIB); }
1307*61046927SAndroid Build Coastguard Worker 
1308*61046927SAndroid Build Coastguard Worker cat6_bindless_ibo: cat6_bindless_ibo_opc_1src cat6_typed cat6_dim cat6_type '.' cat6_immed '.' cat6_bindless_mode dst_reg ',' cat6_reg_or_immed
1309*61046927SAndroid Build Coastguard Worker |                  cat6_bindless_ibo_opc_2src cat6_typed cat6_dim cat6_type '.' cat6_immed '.' cat6_bindless_mode src_reg ',' cat6_reg_or_immed ',' cat6_reg_or_immed { swap(instr->srcs[0], instr->srcs[2]); }
1310*61046927SAndroid Build Coastguard Worker |                  cat6_bindless_ibo_opc_3src cat6_typed cat6_dim cat6_type '.' cat6_immed '.' cat6_bindless_mode src_reg ',' cat6_reg_or_immed src_uoffset ',' cat6_reg_or_immed { swap(instr->srcs[0], instr->srcs[3]); }
1311*61046927SAndroid Build Coastguard Worker |                  cat6_bindless_ibo_opc_3src_dst cat6_typed cat6_dim cat6_type '.' cat6_immed '.' cat6_bindless_mode dst_reg ',' cat6_reg_or_immed src_uoffset ',' cat6_reg_or_immed { swap(instr->srcs[0], instr->srcs[2]); swap(instr->srcs[1], instr->srcs[2]); }
1312*61046927SAndroid Build Coastguard Worker 
1313*61046927SAndroid Build Coastguard Worker cat6_bindless_ldc_opc: T_OP_LDC  { new_instr(OPC_LDC); }
1314*61046927SAndroid Build Coastguard Worker 
1315*61046927SAndroid Build Coastguard Worker /* This is separated from the opcode to avoid lookahead/shift-reduce conflicts */
1316*61046927SAndroid Build Coastguard Worker cat6_bindless_ldc_middle:
1317*61046927SAndroid Build Coastguard Worker                         T_OFFSET '.' cat6_immed '.' cat6_bindless_mode dst_reg { instr->cat6.d = $1; }
1318*61046927SAndroid Build Coastguard Worker |                       'u' '.' T_OFFSET '.' cat6_immed '.' cat6_bindless_mode dst_reg { instr->flags |= IR3_INSTR_U; instr->cat6.d = $3; }
1319*61046927SAndroid Build Coastguard Worker |                       cat6_immed '.' 'k' '.' cat6_bindless_mode 'c' '[' T_A1 ']' { instr->opc = OPC_LDC_K; }
1320*61046927SAndroid Build Coastguard Worker 
1321*61046927SAndroid Build Coastguard Worker cat6_bindless_ldc: cat6_bindless_ldc_opc '.' cat6_bindless_ldc_middle ',' cat6_reg_or_immed ',' cat6_reg_or_immed {
1322*61046927SAndroid Build Coastguard Worker                       instr->cat6.type = TYPE_U32;
1323*61046927SAndroid Build Coastguard Worker                       /* TODO cleanup ir3 src order: */
1324*61046927SAndroid Build Coastguard Worker                       swap(instr->srcs[0], instr->srcs[1]);
1325*61046927SAndroid Build Coastguard Worker                    }
1326*61046927SAndroid Build Coastguard Worker 
1327*61046927SAndroid Build Coastguard Worker const_dst:        integer { new_src(0, IR3_REG_IMMED)->iim_val = $1; }
1328*61046927SAndroid Build Coastguard Worker |                 T_A1 { new_src(0, IR3_REG_IMMED)->iim_val = 0; instr->flags |= IR3_INSTR_A1EN; }
1329*61046927SAndroid Build Coastguard Worker |                 T_A1 '+' integer { new_src(0, IR3_REG_IMMED)->iim_val = $3; instr->flags |= IR3_INSTR_A1EN; }
1330*61046927SAndroid Build Coastguard Worker 
1331*61046927SAndroid Build Coastguard Worker cat6_stc:
1332*61046927SAndroid Build Coastguard Worker               T_OP_STC  { new_instr(OPC_STC); }  cat6_type 'c' '[' const_dst ']' ',' src_reg ',' cat6_immed
1333*61046927SAndroid Build Coastguard Worker |             T_OP_STSC { new_instr(OPC_STSC); } cat6_type 'c' '[' const_dst ']' ',' immediate ',' cat6_immed
1334*61046927SAndroid Build Coastguard Worker 
1335*61046927SAndroid Build Coastguard Worker cat6_todo:         T_OP_G2L                 { new_instr(OPC_G2L); }
1336*61046927SAndroid Build Coastguard Worker |                  T_OP_L2G                 { new_instr(OPC_L2G); }
1337*61046927SAndroid Build Coastguard Worker |                  T_OP_RESFMT              { new_instr(OPC_RESFMT); }
1338*61046927SAndroid Build Coastguard Worker 
1339*61046927SAndroid Build Coastguard Worker cat6_instr:        cat6_load
1340*61046927SAndroid Build Coastguard Worker |                  cat6_loadib
1341*61046927SAndroid Build Coastguard Worker |                  cat6_store
1342*61046927SAndroid Build Coastguard Worker |                  cat6_storeib
1343*61046927SAndroid Build Coastguard Worker |                  cat6_prefetch
1344*61046927SAndroid Build Coastguard Worker |                  cat6_atomic
1345*61046927SAndroid Build Coastguard Worker |                  cat6_ibo
1346*61046927SAndroid Build Coastguard Worker |                  cat6_id
1347*61046927SAndroid Build Coastguard Worker |                  cat6_bindless_ldc
1348*61046927SAndroid Build Coastguard Worker |                  cat6_bindless_ibo
1349*61046927SAndroid Build Coastguard Worker |                  cat6_stc
1350*61046927SAndroid Build Coastguard Worker |                  cat6_todo
1351*61046927SAndroid Build Coastguard Worker 
1352*61046927SAndroid Build Coastguard Worker cat7_scope:        '.' 'w'  { instr->cat7.w = true; }
1353*61046927SAndroid Build Coastguard Worker |                  '.' 'r'  { instr->cat7.r = true; }
1354*61046927SAndroid Build Coastguard Worker |                  '.' 'l'  { instr->cat7.l = true; }
1355*61046927SAndroid Build Coastguard Worker |                  '.' 'g'  { instr->cat7.g = true; }
1356*61046927SAndroid Build Coastguard Worker 
1357*61046927SAndroid Build Coastguard Worker cat7_scopes:
1358*61046927SAndroid Build Coastguard Worker |                  cat7_scope cat7_scopes
1359*61046927SAndroid Build Coastguard Worker 
1360*61046927SAndroid Build Coastguard Worker cat7_barrier:      T_OP_BAR                { new_instr(OPC_BAR); } cat7_scopes
1361*61046927SAndroid Build Coastguard Worker |                  T_OP_FENCE              { new_instr(OPC_FENCE); } cat7_scopes
1362*61046927SAndroid Build Coastguard Worker 
1363*61046927SAndroid Build Coastguard Worker cat7_data_cache:   T_OP_DCCLN              { new_instr(OPC_DCCLN); }
1364*61046927SAndroid Build Coastguard Worker |                  T_OP_DCINV              { new_instr(OPC_DCINV); }
1365*61046927SAndroid Build Coastguard Worker |                  T_OP_DCFLU              { new_instr(OPC_DCFLU); }
1366*61046927SAndroid Build Coastguard Worker 
1367*61046927SAndroid Build Coastguard Worker cat7_alias_src:    src_reg_or_const
1368*61046927SAndroid Build Coastguard Worker |                  immediate_cat1
1369*61046927SAndroid Build Coastguard Worker 
1370*61046927SAndroid Build Coastguard Worker cat7_alias_scope: T_MOD_TEX	{ instr->cat7.alias_scope = ALIAS_TEX; }
1371*61046927SAndroid Build Coastguard Worker |                 T_MOD_MEM	{ instr->cat7.alias_scope = ALIAS_MEM; }
1372*61046927SAndroid Build Coastguard Worker |                 T_MOD_RT	{ instr->cat7.alias_scope = ALIAS_RT; }
1373*61046927SAndroid Build Coastguard Worker 
1374*61046927SAndroid Build Coastguard Worker cat7_instr:        cat7_barrier
1375*61046927SAndroid Build Coastguard Worker |                  cat7_data_cache
1376*61046927SAndroid Build Coastguard Worker |                  T_OP_SLEEP              { new_instr(OPC_SLEEP); }
1377*61046927SAndroid Build Coastguard Worker |                  T_OP_CCINV              { new_instr(OPC_CCINV); }
1378*61046927SAndroid Build Coastguard Worker |                  T_OP_ICINV              { new_instr(OPC_ICINV); }
1379*61046927SAndroid Build Coastguard Worker |                  T_OP_LOCK               { new_instr(OPC_LOCK); }
1380*61046927SAndroid Build Coastguard Worker |                  T_OP_UNLOCK             { new_instr(OPC_UNLOCK); }
1381*61046927SAndroid Build Coastguard Worker |                  T_OP_ALIAS {
1382*61046927SAndroid Build Coastguard Worker                        /* TODO: handle T_INSTR_TYPE */
1383*61046927SAndroid Build Coastguard Worker                        new_instr(OPC_ALIAS);
1384*61046927SAndroid Build Coastguard Worker                    } '.' cat7_alias_scope '.' T_INSTR_TYPE '.' integer dst_reg ',' cat7_alias_src {
1385*61046927SAndroid Build Coastguard Worker                        new_src(0, IR3_REG_IMMED)->uim_val = $8;
1386*61046927SAndroid Build Coastguard Worker                    }
1387*61046927SAndroid Build Coastguard Worker 
1388*61046927SAndroid Build Coastguard Worker raw_instr: T_RAW   {new_instr(OPC_META_RAW)->raw.value = $1;}
1389*61046927SAndroid Build Coastguard Worker 
1390*61046927SAndroid Build Coastguard Worker meta_print_regs:	meta_print_reg
1391*61046927SAndroid Build Coastguard Worker |					meta_print_reg meta_print_regs
1392*61046927SAndroid Build Coastguard Worker 
1393*61046927SAndroid Build Coastguard Worker meta_print_reg: ',' T_REGISTER {
1394*61046927SAndroid Build Coastguard Worker 	meta_print_data.regs_to_dump[meta_print_data.regs_count++] = $2;
1395*61046927SAndroid Build Coastguard Worker }
1396*61046927SAndroid Build Coastguard Worker 
1397*61046927SAndroid Build Coastguard Worker meta_print_start: T_OP_PRINT T_REGISTER {
1398*61046927SAndroid Build Coastguard Worker 	meta_print_data.reg_address_lo = $2;
1399*61046927SAndroid Build Coastguard Worker 	meta_print_data.reg_address_hi = $2 + 2;
1400*61046927SAndroid Build Coastguard Worker 	meta_print_data.reg_tmp = $2 + 4;
1401*61046927SAndroid Build Coastguard Worker 	meta_print_data.regs_count = 0;
1402*61046927SAndroid Build Coastguard Worker }
1403*61046927SAndroid Build Coastguard Worker 
1404*61046927SAndroid Build Coastguard Worker meta_print: meta_print_start meta_print_regs {
1405*61046927SAndroid Build Coastguard Worker 	/* low */
1406*61046927SAndroid Build Coastguard Worker 	new_instr(OPC_MOV);
1407*61046927SAndroid Build Coastguard Worker 	instr->cat1.src_type = TYPE_U32;
1408*61046927SAndroid Build Coastguard Worker 	instr->cat1.dst_type = TYPE_U32;
1409*61046927SAndroid Build Coastguard Worker 	new_dst(meta_print_data.reg_address_lo, 0);
1410*61046927SAndroid Build Coastguard Worker 	new_src(0, IR3_REG_IMMED)->uim_val = info->shader_print_buffer_iova & 0xffffffff;
1411*61046927SAndroid Build Coastguard Worker 
1412*61046927SAndroid Build Coastguard Worker 	/* high */
1413*61046927SAndroid Build Coastguard Worker 	new_instr(OPC_MOV);
1414*61046927SAndroid Build Coastguard Worker 	instr->cat1.src_type = TYPE_U32;
1415*61046927SAndroid Build Coastguard Worker 	instr->cat1.dst_type = TYPE_U32;
1416*61046927SAndroid Build Coastguard Worker 	new_dst(meta_print_data.reg_address_hi, 0);
1417*61046927SAndroid Build Coastguard Worker 	new_src(0, IR3_REG_IMMED)->uim_val = info->shader_print_buffer_iova >> 32;
1418*61046927SAndroid Build Coastguard Worker 
1419*61046927SAndroid Build Coastguard Worker 	/* offset */
1420*61046927SAndroid Build Coastguard Worker 	new_instr(OPC_MOV);
1421*61046927SAndroid Build Coastguard Worker 	instr->cat1.src_type = TYPE_U32;
1422*61046927SAndroid Build Coastguard Worker 	instr->cat1.dst_type = TYPE_U32;
1423*61046927SAndroid Build Coastguard Worker 	new_dst(meta_print_data.reg_tmp, 0);
1424*61046927SAndroid Build Coastguard Worker 	new_src(0, IR3_REG_IMMED)->uim_val = 4 * meta_print_data.regs_count;
1425*61046927SAndroid Build Coastguard Worker 
1426*61046927SAndroid Build Coastguard Worker 	new_instr(OPC_NOP);
1427*61046927SAndroid Build Coastguard Worker 	instr->repeat = 5;
1428*61046927SAndroid Build Coastguard Worker 
1429*61046927SAndroid Build Coastguard Worker 	/* Increment and get current offset into print buffer */
1430*61046927SAndroid Build Coastguard Worker 	new_instr(OPC_ATOMIC_G_ADD);
1431*61046927SAndroid Build Coastguard Worker 	instr->cat6.d = 1;
1432*61046927SAndroid Build Coastguard Worker 	instr->cat6.typed = 0;
1433*61046927SAndroid Build Coastguard Worker 	instr->cat6.type = TYPE_U32;
1434*61046927SAndroid Build Coastguard Worker 	instr->cat6.iim_val = 1;
1435*61046927SAndroid Build Coastguard Worker 
1436*61046927SAndroid Build Coastguard Worker 	new_dst(meta_print_data.reg_address_lo, 0);
1437*61046927SAndroid Build Coastguard Worker 	new_src(meta_print_data.reg_address_lo, 0);
1438*61046927SAndroid Build Coastguard Worker 	new_src(meta_print_data.reg_tmp, 0);
1439*61046927SAndroid Build Coastguard Worker 
1440*61046927SAndroid Build Coastguard Worker 	/* Store all regs */
1441*61046927SAndroid Build Coastguard Worker 	for (uint32_t i = 0; i < meta_print_data.regs_count; i++) {
1442*61046927SAndroid Build Coastguard Worker 		new_instr(OPC_STG);
1443*61046927SAndroid Build Coastguard Worker 		dummy_dst();
1444*61046927SAndroid Build Coastguard Worker 		instr->cat6.type = TYPE_U32;
1445*61046927SAndroid Build Coastguard Worker 		instr->flags = IR3_INSTR_SY;
1446*61046927SAndroid Build Coastguard Worker 		new_src(meta_print_data.reg_address_lo, 0);
1447*61046927SAndroid Build Coastguard Worker 		new_src(0, IR3_REG_IMMED)->iim_val = 0;
1448*61046927SAndroid Build Coastguard Worker 		new_src(meta_print_data.regs_to_dump[i], IR3_REG_R);
1449*61046927SAndroid Build Coastguard Worker 		new_src(0, IR3_REG_IMMED)->iim_val = 1;
1450*61046927SAndroid Build Coastguard Worker 
1451*61046927SAndroid Build Coastguard Worker 		new_instr(OPC_ADD_U);
1452*61046927SAndroid Build Coastguard Worker 		instr->flags = IR3_INSTR_SS;
1453*61046927SAndroid Build Coastguard Worker 		new_dst(meta_print_data.reg_address_lo, 0);
1454*61046927SAndroid Build Coastguard Worker 		new_src(meta_print_data.reg_address_lo, 0);
1455*61046927SAndroid Build Coastguard Worker 		new_src(0, IR3_REG_IMMED)->uim_val = 4;
1456*61046927SAndroid Build Coastguard Worker 
1457*61046927SAndroid Build Coastguard Worker 		new_instr(OPC_NOP);
1458*61046927SAndroid Build Coastguard Worker 		instr->repeat = 5;
1459*61046927SAndroid Build Coastguard Worker 	}
1460*61046927SAndroid Build Coastguard Worker }
1461*61046927SAndroid Build Coastguard Worker 
1462*61046927SAndroid Build Coastguard Worker src:               T_REGISTER     { $$ = new_src($1, 0); }
1463*61046927SAndroid Build Coastguard Worker |                  T_A0           { $$ = new_src((61 << 3), IR3_REG_HALF); }
1464*61046927SAndroid Build Coastguard Worker |                  T_A1           { $$ = new_src((61 << 3) + 1, IR3_REG_HALF); }
1465*61046927SAndroid Build Coastguard Worker |                  T_P0           { $$ = new_src((62 << 3) + $1, IR3_REG_PREDICATE); }
1466*61046927SAndroid Build Coastguard Worker 
1467*61046927SAndroid Build Coastguard Worker dst:               T_REGISTER     { $$ = new_dst($1, 0); }
1468*61046927SAndroid Build Coastguard Worker |                  T_A0           { $$ = new_dst((61 << 3), IR3_REG_HALF); }
1469*61046927SAndroid Build Coastguard Worker |                  T_A1           { $$ = new_dst((61 << 3) + 1, IR3_REG_HALF); }
1470*61046927SAndroid Build Coastguard Worker |                  T_P0           { $$ = new_dst((62 << 3) + $1, IR3_REG_PREDICATE); }
1471*61046927SAndroid Build Coastguard Worker 
1472*61046927SAndroid Build Coastguard Worker const:             T_CONSTANT     { $$ = new_src($1, IR3_REG_CONST); }
1473*61046927SAndroid Build Coastguard Worker 
1474*61046927SAndroid Build Coastguard Worker dst_reg_flag:      T_EVEN         { instr->cat1.round = ROUND_EVEN; }
1475*61046927SAndroid Build Coastguard Worker |                  T_POS_INFINITY { instr->cat1.round = ROUND_POS_INF; }
1476*61046927SAndroid Build Coastguard Worker |                  T_NEG_INFINITY { instr->cat1.round = ROUND_NEG_INF; }
1477*61046927SAndroid Build Coastguard Worker |                  T_EI           { rflags.flags |= IR3_REG_EI; }
1478*61046927SAndroid Build Coastguard Worker |                  T_WRMASK       { rflags.wrmask = $1; }
1479*61046927SAndroid Build Coastguard Worker 
1480*61046927SAndroid Build Coastguard Worker dst_reg_flags:     dst_reg_flag
1481*61046927SAndroid Build Coastguard Worker |                  dst_reg_flag dst_reg_flags
1482*61046927SAndroid Build Coastguard Worker 
1483*61046927SAndroid Build Coastguard Worker                    /* note: destination registers are always incremented in repeat */
1484*61046927SAndroid Build Coastguard Worker dst_reg:           dst                 { $1->flags |= IR3_REG_R; }
1485*61046927SAndroid Build Coastguard Worker |                  dst_reg_flags dst   { $2->flags |= IR3_REG_R; }
1486*61046927SAndroid Build Coastguard Worker 
1487*61046927SAndroid Build Coastguard Worker src_reg_flag:      T_ABSNEG       { rflags.flags |= IR3_REG_ABS|IR3_REG_NEGATE; }
1488*61046927SAndroid Build Coastguard Worker |                  T_NEG          { rflags.flags |= IR3_REG_NEGATE; }
1489*61046927SAndroid Build Coastguard Worker |                  T_ABS          { rflags.flags |= IR3_REG_ABS; }
1490*61046927SAndroid Build Coastguard Worker |                  T_R            { rflags.flags |= IR3_REG_R; }
1491*61046927SAndroid Build Coastguard Worker |                  T_LAST         { rflags.flags |= IR3_REG_LAST_USE; }
1492*61046927SAndroid Build Coastguard Worker 
1493*61046927SAndroid Build Coastguard Worker src_reg_flags:     src_reg_flag
1494*61046927SAndroid Build Coastguard Worker |                  src_reg_flag src_reg_flags
1495*61046927SAndroid Build Coastguard Worker 
1496*61046927SAndroid Build Coastguard Worker src_reg:           src
1497*61046927SAndroid Build Coastguard Worker |                  src_reg_flags src
1498*61046927SAndroid Build Coastguard Worker 
1499*61046927SAndroid Build Coastguard Worker src_reg_gpr:       src_reg
1500*61046927SAndroid Build Coastguard Worker |                  relative_gpr_src
1501*61046927SAndroid Build Coastguard Worker 
1502*61046927SAndroid Build Coastguard Worker src_const:         const
1503*61046927SAndroid Build Coastguard Worker |                  src_reg_flags const
1504*61046927SAndroid Build Coastguard Worker 
1505*61046927SAndroid Build Coastguard Worker src_reg_or_const:  src_reg
1506*61046927SAndroid Build Coastguard Worker |                  src_const
1507*61046927SAndroid Build Coastguard Worker 
1508*61046927SAndroid Build Coastguard Worker src_reg_or_const_or_rel: src_reg_or_const
1509*61046927SAndroid Build Coastguard Worker |                  relative
1510*61046927SAndroid Build Coastguard Worker |                  src_reg_flags relative
1511*61046927SAndroid Build Coastguard Worker 
1512*61046927SAndroid Build Coastguard Worker src_reg_or_const_or_rel_or_imm: src_reg_or_const_or_rel
1513*61046927SAndroid Build Coastguard Worker |                  src_reg_flags immediate
1514*61046927SAndroid Build Coastguard Worker |                  immediate
1515*61046927SAndroid Build Coastguard Worker 
1516*61046927SAndroid Build Coastguard Worker src_reg_or_rel_or_imm: src_reg
1517*61046927SAndroid Build Coastguard Worker |                  relative
1518*61046927SAndroid Build Coastguard Worker |                  immediate
1519*61046927SAndroid Build Coastguard Worker 
1520*61046927SAndroid Build Coastguard Worker uoffset:           { $$ = 0; }
1521*61046927SAndroid Build Coastguard Worker |                  '+' integer { $$ = $2; }
1522*61046927SAndroid Build Coastguard Worker 
1523*61046927SAndroid Build Coastguard Worker offset:            uoffset
1524*61046927SAndroid Build Coastguard Worker |                  '-' integer { $$ = -$2; }
1525*61046927SAndroid Build Coastguard Worker 
1526*61046927SAndroid Build Coastguard Worker src_uoffset:       uoffset { new_src(0, IR3_REG_IMMED)->uim_val = $1; if ($1) instr->flags |= IR3_INSTR_IMM_OFFSET; }
1527*61046927SAndroid Build Coastguard Worker 
1528*61046927SAndroid Build Coastguard Worker relative_gpr_src:  'r' '<' T_A0 offset '>'  { new_src(0, IR3_REG_RELATIV)->array.offset = $4; }
1529*61046927SAndroid Build Coastguard Worker |                  T_HR '<' T_A0 offset '>'  { new_src(0, IR3_REG_RELATIV | IR3_REG_HALF)->array.offset = $4; }
1530*61046927SAndroid Build Coastguard Worker 
1531*61046927SAndroid Build Coastguard Worker relative_gpr_dst:  'r' '<' T_A0 offset '>'  { new_dst(0, IR3_REG_RELATIV)->array.offset = $4; }
1532*61046927SAndroid Build Coastguard Worker |                  T_HR '<' T_A0 offset '>'  { new_dst(0, IR3_REG_RELATIV | IR3_REG_HALF)->array.offset = $4; }
1533*61046927SAndroid Build Coastguard Worker 
1534*61046927SAndroid Build Coastguard Worker relative_const:    'c' '<' T_A0 offset '>'  { new_src(0, IR3_REG_RELATIV | IR3_REG_CONST)->array.offset = $4; }
1535*61046927SAndroid Build Coastguard Worker |                  T_HC '<' T_A0 offset '>'  { new_src(0, IR3_REG_RELATIV | IR3_REG_CONST | IR3_REG_HALF)->array.offset = $4; }
1536*61046927SAndroid Build Coastguard Worker 
1537*61046927SAndroid Build Coastguard Worker relative:          relative_gpr_src
1538*61046927SAndroid Build Coastguard Worker |                  relative_const
1539*61046927SAndroid Build Coastguard Worker 
1540*61046927SAndroid Build Coastguard Worker /* cat1 immediates differ slighly in the floating point case from the cat2
1541*61046927SAndroid Build Coastguard Worker  * case which can only encode certain predefined values (ie. and index into
1542*61046927SAndroid Build Coastguard Worker  * the FLUT table)
1543*61046927SAndroid Build Coastguard Worker  */
1544*61046927SAndroid Build Coastguard Worker immediate_cat1:    integer             { new_src(0, IR3_REG_IMMED)->iim_val = type_size(instr->cat1.src_type) < 32 ? $1 & 0xffff : $1; }
1545*61046927SAndroid Build Coastguard Worker |                  '(' integer ')'     { new_src(0, IR3_REG_IMMED)->fim_val = $2; }
1546*61046927SAndroid Build Coastguard Worker |                  '(' float ')'       { new_src(0, IR3_REG_IMMED)->fim_val = $2; }
1547*61046927SAndroid Build Coastguard Worker |                  'h' '(' integer ')' { new_src(0, IR3_REG_IMMED | IR3_REG_HALF)->iim_val = $3 & 0xffff; }
1548*61046927SAndroid Build Coastguard Worker |                  'h' '(' float ')'   { new_src(0, IR3_REG_IMMED | IR3_REG_HALF)->uim_val = _mesa_float_to_half($3); }
1549*61046927SAndroid Build Coastguard Worker |                  '(' T_NAN ')'       { new_src(0, IR3_REG_IMMED)->fim_val = NAN; }
1550*61046927SAndroid Build Coastguard Worker |                  '(' T_INF ')'       { new_src(0, IR3_REG_IMMED)->fim_val = INFINITY; }
1551*61046927SAndroid Build Coastguard Worker 
1552*61046927SAndroid Build Coastguard Worker immediate:         integer             { new_src(0, IR3_REG_IMMED)->iim_val = $1; }
1553*61046927SAndroid Build Coastguard Worker |                  '(' integer ')'     { new_src(0, IR3_REG_IMMED)->fim_val = $2; }
1554*61046927SAndroid Build Coastguard Worker |                  flut_immed          { new_src(0, IR3_REG_IMMED)->uim_val = $1; }
1555*61046927SAndroid Build Coastguard Worker |                  'h' '(' integer ')' { new_src(0, IR3_REG_IMMED | IR3_REG_HALF)->iim_val = $3; }
1556*61046927SAndroid Build Coastguard Worker |                  'h' flut_immed      { new_src(0, IR3_REG_IMMED | IR3_REG_HALF)->uim_val = $2; }
1557*61046927SAndroid Build Coastguard Worker 
1558*61046927SAndroid Build Coastguard Worker /* Float LUT values accepted as immed: */
1559*61046927SAndroid Build Coastguard Worker flut_immed:        T_FLUT_0_0
1560*61046927SAndroid Build Coastguard Worker |                  T_FLUT_0_5
1561*61046927SAndroid Build Coastguard Worker |                  T_FLUT_1_0
1562*61046927SAndroid Build Coastguard Worker |                  T_FLUT_2_0
1563*61046927SAndroid Build Coastguard Worker |                  T_FLUT_E
1564*61046927SAndroid Build Coastguard Worker |                  T_FLUT_PI
1565*61046927SAndroid Build Coastguard Worker |                  T_FLUT_INV_PI
1566*61046927SAndroid Build Coastguard Worker |                  T_FLUT_INV_LOG2_E
1567*61046927SAndroid Build Coastguard Worker |                  T_FLUT_LOG2_E
1568*61046927SAndroid Build Coastguard Worker |                  T_FLUT_INV_LOG2_10
1569*61046927SAndroid Build Coastguard Worker |                  T_FLUT_LOG2_10
1570*61046927SAndroid Build Coastguard Worker |                  T_FLUT_4_0
1571*61046927SAndroid Build Coastguard Worker 
1572*61046927SAndroid Build Coastguard Worker integer:           T_INT       { $$ = $1; }
1573*61046927SAndroid Build Coastguard Worker |                  '-' T_INT   { $$ = -$2; }
1574*61046927SAndroid Build Coastguard Worker |                  T_HEX       { $$ = $1; }
1575*61046927SAndroid Build Coastguard Worker |                  '-' T_HEX   { $$ = -$2; }
1576*61046927SAndroid Build Coastguard Worker 
1577*61046927SAndroid Build Coastguard Worker float:             T_FLOAT     { $$ = $1; }
1578*61046927SAndroid Build Coastguard Worker |                  '-' T_FLOAT { $$ = -$2; }
1579*61046927SAndroid Build Coastguard Worker 
1580*61046927SAndroid Build Coastguard Worker type:              T_TYPE_F16   { $$ = TYPE_F16;   }
1581*61046927SAndroid Build Coastguard Worker |                  T_TYPE_F32   { $$ = TYPE_F32;   }
1582*61046927SAndroid Build Coastguard Worker |                  T_TYPE_U16   { $$ = TYPE_U16;   }
1583*61046927SAndroid Build Coastguard Worker |                  T_TYPE_U32   { $$ = TYPE_U32;   }
1584*61046927SAndroid Build Coastguard Worker |                  T_TYPE_S16   { $$ = TYPE_S16;   }
1585*61046927SAndroid Build Coastguard Worker |                  T_TYPE_S32   { $$ = TYPE_S32;   }
1586*61046927SAndroid Build Coastguard Worker |                  T_TYPE_U8    { $$ = TYPE_U8;    }
1587*61046927SAndroid Build Coastguard Worker |                  T_TYPE_U8_32 { $$ = TYPE_U8_32; }
1588