ir_spec.py 11 KB
Newer Older
1
nodes = dict(
2
3
4
5
6
7
8

#
# Abstract node types
#
unop = dict(
	abstract = True,
	ins      = [ "op" ]
9
10
),

11
12
13
binop = dict(
	abstract = True,
	ins      = [ "left", "right" ]
14
15
),

16
17
18
19
20
#
# Real node types
#
Abs = dict(
	is_a     = "unop"
21
22
),

23
24
Add = dict(
	is_a     = "binop"
25
26
),

27
28
29
30
Alloc = dict(
	ins   = [ "mem", "size" ],
	outs  = [ "M", "X_regular", "X_except", "res" ],
	attrs = [
31
32
33
34
35
36
		dict(
			name = "state",
			type = "op_pin_state",
			initname = ".exc.pin_state",
			init = "op_pin_state_pinned"
		),
37
38
39
40
41
42
43
44
		dict(
			name = "type",
			type = "ir_type*"
		),
		dict(
			name = "where",
			type = "ir_where_alloc"
		)
45
46
47
48
49
50
	],
	d_post = '''
	#if PRECISE_EXC_CONTEXT
	firm_alloc_frag_arr(res, op_Alloc, &res->attr.alloc.exc.frag_arr);
	#endif
	'''
51
52
),

53
54
55
56
57
58
59
60
Anchor = dict(
	mode       = "mode_ANY",
	ins        = [ "end_block", "start_block", "end", "start",
	               "end_reg", "end_except", "initial_exec",
				   "frame", "tls", "initial_mem", "args",
				   "bad", "no_mem" ],
	knownBlock = True,
	noconstr   = True
61
62
),

63
64
65
66
67
68
And = dict(
	is_a     = "binop"
),

Bad = dict(
	mode       = "mode_Bad",
69
70
71
72
	knownBlock = True,
),

Block = dict(
73
	mode       = "mode_BB",
74
	knownBlock = True,
75
	block      = "NULL",
76
	noconstr   = True,
Moritz Kroll's avatar
Moritz Kroll committed
77
	optimize   = False,
78
	arity      = "variable",
Moritz Kroll's avatar
Moritz Kroll committed
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98

	init = '''
	/* macroblock header */
	res->in[0] = res;

	res->attr.block.is_dead     = 0;
	res->attr.block.is_mb_head  = 1;
	res->attr.block.has_label   = 0;
	res->attr.block.irg         = irg;
	res->attr.block.backedge    = new_backedge_arr(irg->obst, arity);
	res->attr.block.in_cg       = NULL;
	res->attr.block.cg_backedge = NULL;
	res->attr.block.extblk      = NULL;
	res->attr.block.mb_depth    = 0;
	res->attr.block.label       = 0;

	set_Block_matured(res, 1);
	set_Block_block_visited(res, 0);
	''',

99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
	d_pre = '''
	int i;
	int has_unknown = 0;
	''',

	d_post = '''
	/* Create and initialize array for Phi-node construction. */
	if (get_irg_phase_state(current_ir_graph) == phase_building) {
		res->attr.block.graph_arr = NEW_ARR_D(ir_node *, current_ir_graph->obst,
		                                      current_ir_graph->n_loc);
		memset(res->attr.block.graph_arr, 0, sizeof(ir_node *)*current_ir_graph->n_loc);
	}

	for (i = arity - 1; i >= 0; i--)
		if (is_Unknown(in[i])) {
			has_unknown = 1;
			break;
		}

	if (!has_unknown) res = optimize_node(res);

Moritz Kroll's avatar
Moritz Kroll committed
120
121
	current_ir_graph->current_block = res;

122
123
124
	IRN_VRFY_IRG(res, current_ir_graph);
	''',

125
126
127
128
129
130
131
132
133
134
135
136
137
138
139
140
141
142
143
144
145
146
147
	java_add   = '''
	public void addPred(Node node) {
		binding_cons.add_immBlock_pred(ptr, node.ptr);
	}

	public void mature() {
		binding_cons.mature_immBlock(ptr);
	}

	@Override
	public Block getBlock() {
		return null;
	}

	public boolean blockVisited() {
		return 0 != binding.Block_block_visited(ptr);
	}

	public void markBlockVisited() {
		binding.mark_Block_block_visited(ptr);
	}''',
),

148
149
Borrow = dict(
	is_a     = "binop"
150
151
),

152
153
154
155
156
157
158
159
160
161
162
163
164
165
166
167
168
169
170
Bound = dict(
	ins   = [ "mem", "index", "lower", "upper" ],
	outs  = [ "M", "X_regular", "X_except", "res" ],
	attrs = [
		dict(
			name = "state",
			type = "op_pin_state",
			initname = ".exc.pin_state",
			init = "op_pin_state_pinned"
		)
	],
	d_post = '''
	#if PRECISE_EXC_CONTEXT
	firm_alloc_frag_arr(res, op_Bound, &res->attr.bound.exc.frag_arr);
	#endif
	'''
),


171
172
173
174
Break = dict(
	mode = "mode_X"
),

175
176
Builtin = dict(
	ins      = [ "mem" ],
177
178
179
	arity    = "variable",
	outs     = [ "M_regular", "X_regular", "X_except", "T_result", "M_except", "P_value_res_base" ],
	attrs    = [
180
181
182
183
184
185
		dict(
			name = "state",
			type = "op_pin_state",
			initname = ".exc.pin_state",
			init = "op_pin_state_pinned"
		),
186
187
188
189
		dict(
			type = "ir_builtin_kind",
			name = "kind"
		),
190
		dict(
191
192
193
			type = "ir_type*",
			name = "type"
		)
194
195
196
197
198
199
	],
	init = '''
	assert((get_unknown_type() == type) || is_Method_type(type));
	'''

	# TODO: No firm_alloc_frag_arr??
200
201
),

202
203
Call = dict(
	ins      = [ "mem", "ptr" ],
204
205
206
	arity    = "variable",
	outs     = [ "M_regular", "X_regular", "X_except", "T_result", "M_except", "P_value_res_base" ],
	attrs    = [
207
208
209
210
211
		dict(
			name = "state",
			type = "op_pin_state",
			initname = ".exc.pin_state",
			init = "op_pin_state_pinned"
212
213
214
215
		),
		dict(
			type = "ir_type*",
			name = "type"
216
		)
217
218
219
220
221
222
223
224
225
	],
	init = '''
	assert((get_unknown_type() == type) || is_Method_type(type));
	''',
	d_post = '''
	#if PRECISE_EXC_CONTEXT
	firm_alloc_frag_arr(res, op_Call, &res->attr.call.exc.frag_arr);
	#endif
	'''
226
227
228
229
230
231
),

Carry = dict(
	is_a     = "binop"
),

232
233
234
235
236
237
238
239
240
241
242
243
Cast = dict(
	ins      = [ "op" ],
	mode     = "get_irn_mode(irn_op)",
	attrs    = [
		dict(
			type = "ir_type*",
			name = "type"
		)
	],
	init     = "assert(is_atomic_type(type));"
),

244
245
246
Cmp = dict(
	is_a     = "binop",
	outs     = [ "False", "Eq", "Lt", "Le", "Gt", "Ge", "Lg", "Leg", "Uo", "Ue", "Ul", "Ule", "Ug", "Uge", "Ne", "True" ],
247
248
),

249
250
251
252
253
254
255
256
257
258
259
260
261
262
263
264
265
266
267
268
Cond = dict(
	ins      = [ "selector" ],
	outs     = [ "false", "true" ],
	attrs    = [
		dict(
			name = "kind",
			type = "cond_kind",
			init = "dense"
		),
		dict(
			name = "default_proj",
			type = "long",
			init = "0"
		),
		dict(
			name = "jmp_pred",
			type = "cond_jmp_predicate",
			init = "COND_JMP_PRED_NONE"
		)
	]
269
270
),

271
272
273
274
275
276
277
278
279
Confirm = dict(
	ins      = [ "value", "bound" ],
	mode     = "get_irn_mode(irn_value)",
	attrs    = [
		dict(
			name = "cmp",
			type = "pn_Cmp"
		),
	],
280
281
),

282
283
284
285
286
287
288
289
290
291
Const = dict(
	mode       = "",
	knownBlock = True,
	attrs_name = "con",
	attrs      = [
		dict(
			type = "tarval*",
			name = "tarval",
		)
	],
292
293
),

294
295
296
297
298
299
300
301
302
303
304
305
306
Conv = dict(
	is_a     = "unop",
	attrs = [
		dict(
			name = "strict",
			type = "int",
			init = "0",
			special = dict(
				prefix = "strict",
				init = "1"
			)
		)
	]
307
308
),

309
310
311
CopyB = dict(
	ins   = [ "mem", "dst", "src" ],
	outs  = [ "M", "X_regular", "X_except" ],
312
	attrs = [
313
314
315
316
317
318
		dict(
			name = "state",
			type = "op_pin_state",
			initname = ".exc.pin_state",
			init = "op_pin_state_pinned"
		),
319
		dict(
320
321
			name = "type",
			type = "ir_type*"
322
		)
323
324
325
326
327
328
	],
	d_post = '''
	#if PRECISE_EXC_CONTEXT
	firm_alloc_frag_arr(res, op_CopyB, &res->attr.copyb.exc.frag_arr);
	#endif
	'''
329
330
),

331
332
333
Div = dict(
	ins   = [ "mem", "dividend", "divisor" ],
	outs  = [ "M", "X_regular", "X_except", "res" ],
334
	attrs_name = "divmod",
335
336
337
338
339
340
341
	attrs = [
		dict(
			type = "ir_mode*",
			name = "resmode"
		),
		dict(
			name = "state",
342
343
			type = "op_pin_state",
			initname = ".exc.pin_state"
Moritz Kroll's avatar
Moritz Kroll committed
344
345
346
347
348
349
350
351
352
		),
		dict(
			name = "no_remainder",
			type = "int",
			init = "0",
			special = dict(
				suffix = "RL",
				init = "1"
			)
353
		)
354
355
356
357
358
359
	],
	d_post = '''
	#if PRECISE_EXC_CONTEXT
	firm_alloc_frag_arr(res, op_Div, &res->attr.except.frag_arr);
	#endif
	'''
360
361
362
363
364
),

DivMod = dict(
	ins   = [ "mem", "dividend", "divisor" ],
	outs  = [ "M", "X_regular", "X_except", "res_div", "res_mod" ],
365
	attrs_name = "divmod",
366
367
368
369
370
371
372
	attrs = [
		dict(
			type = "ir_mode*",
			name = "resmode"
		),
		dict(
			name = "state",
373
374
			type = "op_pin_state",
			initname = ".exc.pin_state"
375
		)
376
377
378
379
380
381
	],
	d_post = '''
	#if PRECISE_EXC_CONTEXT
	firm_alloc_frag_arr(res, op_DivMod, &res->attr.except.frag_arr);
	#endif
	'''
382
383
),

384
385
386
387
388
389
390
391
392
393
394
395
396
End = dict(
	mode       = "mode_X",
	op_flags   = "cfopcode",
	state      = "pinned",
	arity      = "dynamic",
	noconstr   = True,
	optimize   = False
),

Eor = dict(
	is_a     = "binop"
),

397
398
399
400
401
402
403
404
405
406
407
408
409
410
Filter = dict(
	ins   = [ "pred" ],
	attrs = [
		dict(
			name = "proj",
			type = "long"
		)
	]

	# TODO: Broken asserts in original:
	# assert(get_Proj_pred(res));
	# assert(get_nodes_block(get_Proj_pred(res)));
),

411
412
413
Free = dict(
	ins   = [ "mem", "ptr", "size" ],
	mode  = "mode_M",
414
415
	attrs = [
		dict(
416
417
			name = "type",
			type = "ir_type*"
418
419
		),
		dict(
420
421
			name = "where",
			type = "ir_where_alloc"
422
423
424
425
		)
	]
),

426
427
428
429
430
431
432
433
434
435
436
Id = dict(
	ins = [ "pred" ]
),

IJmp = dict(
	mode     = "mode_X",
	op_flags = "cfopcode",
	state    = "pinned",
	ins      = [ "target" ],
),

437
438
439
440
441
442
443
444
445
446
447
448
449
450
451
452
453
454
455
InstOf = dict(
	ins   = [ "store", "objptr" ],
	outs  = [ "M", "X_regular", "X_except", "res", "M_except" ],
	attrs = [
		dict(
			name = "state",
			type = "op_pin_state",
			initname = ".exc.pin_state",
			init = "op_pin_state_floats"
		),
		dict(
			name = "type",
			type = "ir_type*"
		)
	]

	# TODO: No firm_alloc_frag_arr???
),

456
457
458
459
460
461
462
Jmp = dict(
	mode     = "mode_X",
	op_flags = "cfopcode",
	state    = "pinned",
	ins      = [],
),

463
464
465
466
467
468
469
470
471
472
473
474
Load = dict(
	ins      = [ "mem", "ptr" ],
	outs     = [ "M", "X_regular", "X_except", "res" ],
	attrs    = [
		dict(
			type = "ir_mode*",
			name = "mode",
			java_name = "load_mode"
		),
	],
	constructor_args = [
		dict(
Moritz Kroll's avatar
Moritz Kroll committed
475
			type = "ir_cons_flags",
476
477
478
			name = "flags",
		),
	],
479
480
481
482
483
	d_post = '''
#if PRECISE_EXC_CONTEXT
	firm_alloc_frag_arr(res, op_Load, &res->attr.load.exc.frag_arr);
#endif
	'''
484
485
),

486
487
488
489
490
491
492
Minus = dict(
	is_a     = "unop"
),

Mod = dict(
	ins   = [ "mem", "dividend", "divisor" ],
	outs  = [ "M", "X_regular", "X_except", "res" ],
493
	attrs_name = "divmod",
494
	attrs = [
495
		dict(
496
497
			type = "ir_mode*",
			name = "resmode"
498
		),
499
500
		dict(
			name = "state",
501
502
			type = "op_pin_state",
			initname = ".exc.pin_state"
503
		)
504
505
506
507
508
509
	],
	d_post = '''
	#if PRECISE_EXC_CONTEXT
	firm_alloc_frag_arr(res, op_Mod, &res->attr.except.frag_arr);
	#endif
	'''
510
511
),

512
513
514
515
516
517
518
519
520
521
Mul = dict(
	is_a     = "binop"
),

Mulh = dict(
	is_a     = "binop"
),

Mux = dict(
	ins      = [ "sel", "false", "true" ]
522
523
524
525
526
527
528
),

NoMem = dict(
	mode       = "mode_M",
	knownBlock = True,
),

529
530
531
532
533
534
535
536
537
538
539
540
Not = dict(
	is_a     = "unop"
),

Or = dict(
	is_a     = "binop"
),

Phi = dict(
	noconstr = True,
	state    = "pinned",
	arity    = "variable",
541
542
543
544
),

Pin = dict(
	ins      = [ "op" ],
545
	mode     = "get_irn_mode(irn_op)"
546
547
548
549
550
551
552
),

Proj = dict(
	ins      = [ "pred" ],
	attrs    = [
		dict(
			type = "long",
553
554
			name = "proj",
			initname = ""
555
556
557
558
		)
	]
),

559
560
561
Quot = dict(
	ins   = [ "mem", "dividend", "divisor" ],
	outs  = [ "M", "X_regular", "X_except", "res" ],
562
	attrs_name = "divmod",
563
	attrs = [
564
		dict(
565
566
567
568
569
			type = "ir_mode*",
			name = "resmode"
		),
		dict(
			name = "state",
570
571
			type = "op_pin_state",
			initname = ".exc.pin_state"
572
		)
573
574
575
576
577
578
	],
	d_post = '''
	#if PRECISE_EXC_CONTEXT
	firm_alloc_frag_arr(res, op_Quot, &res->attr.except.frag_arr);
	#endif
	'''
579
580
),

581
582
583
584
585
Raise = dict(
	ins   = [ "mem", "exo_ptr" ],
	outs  = [ "M", "X" ]
),

586
587
Return = dict(
	ins      = [ "mem" ],
588
	arity    = "variable",
589
	mode     = "mode_X"
590
591
),

592
593
Rotl = dict(
	is_a     = "binop"
594
595
),

596
597
598
599
Sel = dict(
	ins    = [ "mem", "ptr" ],
	arity  = "variable",
	mode   = "is_Method_type(get_entity_type(entity)) ? mode_P_code : mode_P_data",
600
601
	attrs    = [
		dict(
602
603
604
605
			type = "ir_entity*",
			name = "entity"
		)
	]
606
607
),

608
609
Shl = dict(
	is_a     = "binop"
610
611
),

612
613
Shr = dict(
	is_a     = "binop"
614
615
),

616
617
Shrs = dict(
	is_a     = "binop"
618
619
),

620
621
622
623
624
625
Start = dict(
	mode       = "mode_T",
	op_flags   = "cfopcode",
	state      = "pinned",
	noconstr   = True,
	optimize   = False
626
627
),

628
629
630
631
Store = dict(
	ins      = [ "mem", "ptr", "value" ],
	outs     = [ "M", "X_regular", "X_except" ],
	constructor_args = [
632
		dict(
633
634
			type = "ir_cons_flags",
			name = "flags",
635
		),
636
637
638
639
640
641
	],
	d_post = '''
#if PRECISE_EXC_CONTEXT
	firm_alloc_frag_arr(res, op_Store, &res->attr.store.exc.frag_arr);
#endif
	'''
642
643
),

644
645
Sub = dict(
	is_a     = "binop"
646
647
),

648
649
650
651
652
SymConst = dict(
	mode       = "mode_P",
	knownBlock = True,
	noconstr   = True,
	attrs      = [
653
		dict(
654
655
			type = "ir_entity*",
			name = "entity"
656
		)
657
	],
658
659
),

660
661
662
663
Sync = dict(
	mode     = "mode_M",
	optimize = False,
	arity    = "dynamic"
664
665
),

666
667
668
Tuple = dict(
	arity    = "variable",
	mode     = "mode_T",
669
),
Moritz Kroll's avatar
Moritz Kroll committed
670

671
672
673
674
Unknown = dict(
	knownBlock = True,
	block      = "get_irg_start_block(irg)",
	nodbginfo  = True
Moritz Kroll's avatar
Moritz Kroll committed
675
),
676
)