1 /* Copyright (C) 1998 - 2000 by Universitaet Karlsruhe
2 ** All rights reserved.
4 ** Authors: Christian Schaefer
15 # include "irnode_t.h"
75 new_ir_op (opcode code, char *name, op_pinned p, int labeled, size_t attr_size)
79 res = (ir_op *) xmalloc (sizeof (ir_op));
81 res->name = id_from_str(name, strlen(name));
83 res->attr_size = attr_size;
84 res->labeled = labeled; /* For vcg dumping.
85 Set labeled = 1 if the edges should be
86 enumarated in vcg output, otherwise set
95 op_Block = new_ir_op (iro_Block, "Block", pinned, 1, sizeof (block_attr));
97 op_Start = new_ir_op (iro_Start, "Start", pinned, 0, 0);
98 op_End = new_ir_op (iro_End, "End", pinned, 0, 0);
99 op_Jmp = new_ir_op (iro_Jmp, "Jmp", pinned, 0, 0);
100 op_Cond = new_ir_op (iro_Cond, "Cond", pinned, 1, sizeof(cond_attr));
101 op_Return= new_ir_op (iro_Return,"Return", pinned, 1, 0);
102 op_Raise = new_ir_op (iro_Raise, "Raise", pinned, 1, 0);
104 op_Const = new_ir_op (iro_Const, "Const", floats, 0, sizeof (struct tarval *));
105 op_SymConst = new_ir_op (iro_SymConst, "SymConst",
106 floats, 0, sizeof (symconst_attr));
108 op_Sel = new_ir_op (iro_Sel, "Sel", floats, 1, sizeof (sel_attr));
110 op_Call = new_ir_op (iro_Call, "Call", pinned, 1, sizeof (call_attr));
111 op_Add = new_ir_op (iro_Add, "Add", floats, 0, 0);
112 op_Minus = new_ir_op (iro_Minus, "Minus", floats, 0, 0);
113 op_Sub = new_ir_op (iro_Sub, "Sub", floats, 1, 0);
114 op_Mul = new_ir_op (iro_Mul, "Mul", floats, 0, 0);
115 op_Quot = new_ir_op (iro_Quot, "Quot", pinned, 1, sizeof(struct irnode **));
116 op_DivMod= new_ir_op (iro_DivMod,"DivMod", pinned, 1, sizeof(struct irnode **));
117 op_Div = new_ir_op (iro_Div, "Div", pinned, 1, sizeof(struct irnode **));
118 op_Mod = new_ir_op (iro_Mod, "Mod", pinned, 1, sizeof(struct irnode **));
119 op_Abs = new_ir_op (iro_Abs, "Abs", floats, 0, 0);
120 op_And = new_ir_op (iro_And, "And", floats, 0, 0);
121 op_Or = new_ir_op (iro_Or, "Or", floats, 0, 0);
122 op_Eor = new_ir_op (iro_Eor, "Eor", floats, 0, 0);
123 op_Not = new_ir_op (iro_Not, "Not", floats, 0, 0);
124 op_Cmp = new_ir_op (iro_Cmp, "Cmp", floats, 1, 0);
125 op_Shl = new_ir_op (iro_Shl, "Shl", floats, 1, 0);
126 op_Shr = new_ir_op (iro_Shr, "Shr", floats, 1, 0);
127 op_Shrs = new_ir_op (iro_Shrs, "Shrs", floats, 1, 0);
128 op_Rot = new_ir_op (iro_Rot, "Rot", floats, 1, 0);
129 op_Conv = new_ir_op (iro_Conv, "Conv", floats, 0, 0);
131 op_Phi = new_ir_op (iro_Phi, "Phi", pinned, 1, sizeof (int));
133 op_Load = new_ir_op (iro_Load, "Load", pinned, 1, sizeof(struct irnode **));
134 op_Store = new_ir_op (iro_Store, "Store", pinned, 1, sizeof(struct irnode **));
135 op_Alloc = new_ir_op (iro_Alloc, "Alloc", pinned, 1, sizeof (alloc_attr));
136 op_Free = new_ir_op (iro_Free, "Free", pinned, 1, sizeof (type *));
137 op_Sync = new_ir_op (iro_Sync, "Sync", pinned, 0, 0);
139 op_Proj = new_ir_op (iro_Proj, "Proj", floats, 0, sizeof (long));
140 op_Tuple = new_ir_op (iro_Tuple, "Tuple", floats, 1, 0);
141 op_Id = new_ir_op (iro_Id, "Id", floats, 0, 0);
142 op_Bad = new_ir_op (iro_Bad, "Bad", floats, 0, 0);
144 op_Unknown = new_ir_op (iro_Unknown, "Unknown", floats, 0, 0);
145 op_Filter = new_ir_op (iro_Filter, "Filter", pinned, 0, sizeof(filter_attr));
146 op_Break = new_ir_op (iro_Break, "Break", pinned, 0, 0);
147 op_CallBegin = new_ir_op (iro_CallBegin, "CallBegin", pinned, 0, sizeof(callbegin_attr));
148 op_EndReg = new_ir_op (iro_EndReg, "EndReg", pinned, 0, sizeof(end_attr));
149 op_EndExcept = new_ir_op (iro_EndExcept, "EndExcept", pinned, 0, sizeof(end_attr));
152 /* Returns the string for the opcode. */
153 const char *get_op_name (ir_op *op) {
154 return id_to_str(op->name);
157 opcode get_op_code (ir_op *op){
161 ident *get_op_ident(ir_op *op){
165 op_pinned get_op_pinned (ir_op *op){
169 /* Sets pinned in the opcode. Setting it to floating has no effect
170 for Phi, Block and control flow nodes. */
171 void set_op_pinned(ir_op *op, op_pinned pinned) {
172 if (op == op_Block || op == op_Phi || is_cfopcode(op)) return;
177 /* returns the attribute size of the operator. */
178 int get_op_attr_size (ir_op *op) {
179 return op->attr_size;
182 int is_cfopcode(ir_op *op) {
183 return ((op == op_Start)
190 || (op == op_Unknown)
192 || (op == op_CallBegin)
194 || (op == op_EndExcept));