3 * File name: ir/ir/irop.h
4 * Purpose: Representation of opcode of intermediate operation.
5 * Author: Christian Schaefer
6 * Modified by: Goetz Lindenmaier
9 * Copyright: (c) 1998-2003 Universität Karlsruhe
10 * Licence: This file protected by GPL - GNU GENERAL PUBLIC LICENSE.
16 * Operators of firm nodes.
18 * @author Christian Schaefer
20 * This module specifies the opcodes possible for ir nodes. Their
21 * definition is close to the operations specified in UKA Tech-Report
33 iro_Start, iro_End, iro_Jmp, iro_Cond, iro_Return, iro_Raise,
34 iro_Const, iro_SymConst,
36 iro_Call, iro_Add, iro_Sub, iro_Minus, iro_Mul, iro_Quot, iro_DivMod,
37 iro_Div, iro_Mod, iro_Abs, iro_And, iro_Or, iro_Eor, iro_Not,
38 iro_Cmp, iro_Shl, iro_Shr, iro_Shrs, iro_Rot, iro_Conv, iro_Cast,
40 iro_Load, iro_Store, iro_Alloc, iro_Free, iro_Sync,
41 iro_Proj, iro_Tuple, iro_Id, iro_Bad, iro_Confirm,
42 iro_Unknown, iro_Filter, iro_Break, iro_CallBegin, iro_EndReg, iro_EndExcept,
46 typedef struct ir_op ir_op;
48 extern ir_op *op_Block; ir_op *get_op_Block (void);
50 extern ir_op *op_Start; ir_op *get_op_Start (void);
51 extern ir_op *op_End; ir_op *get_op_End (void);
52 extern ir_op *op_Jmp; ir_op *get_op_Jmp (void);
53 extern ir_op *op_Cond; ir_op *get_op_Cond (void);
54 extern ir_op *op_Return; ir_op *get_op_Return (void);
55 extern ir_op *op_Raise; ir_op *get_op_Raise (void);
56 extern ir_op *op_Sel; ir_op *get_op_Sel (void);
57 extern ir_op *op_InstOf; ir_op *get_op_InstOf (void);
59 extern ir_op *op_Const; ir_op *get_op_Const (void);
60 extern ir_op *op_SymConst; ir_op *get_op_SymConst (void);
62 extern ir_op *op_Call; ir_op *get_op_Call (void);
63 extern ir_op *op_Add; ir_op *get_op_Add (void);
64 extern ir_op *op_Sub; ir_op *get_op_Sub (void);
65 extern ir_op *op_Minus; ir_op *get_op_Minus (void);
66 extern ir_op *op_Mul; ir_op *get_op_Mul (void);
67 extern ir_op *op_Quot; ir_op *get_op_Quot (void);
68 extern ir_op *op_DivMod; ir_op *get_op_DivMod (void);
69 extern ir_op *op_Div; ir_op *get_op_Div (void);
70 extern ir_op *op_Mod; ir_op *get_op_Mod (void);
71 extern ir_op *op_Abs; ir_op *get_op_Abs (void);
72 extern ir_op *op_And; ir_op *get_op_And (void);
73 extern ir_op *op_Or; ir_op *get_op_Or (void);
74 extern ir_op *op_Eor; ir_op *get_op_Eor (void);
75 extern ir_op *op_Not; ir_op *get_op_Not (void);
76 extern ir_op *op_Cmp; ir_op *get_op_Cmp (void);
77 extern ir_op *op_Shl; ir_op *get_op_Shl (void);
78 extern ir_op *op_Shr; ir_op *get_op_Shr (void);
79 extern ir_op *op_Shrs; ir_op *get_op_Shrs (void);
80 extern ir_op *op_Rot; ir_op *get_op_Rot (void);
81 extern ir_op *op_Conv; ir_op *get_op_Conv (void);
82 extern ir_op *op_Cast; ir_op *get_op_Cast (void);
84 extern ir_op *op_Phi; ir_op *get_op_Phi (void);
86 extern ir_op *op_Load; ir_op *get_op_Load (void);
87 extern ir_op *op_Store; ir_op *get_op_Store (void);
88 extern ir_op *op_Alloc; ir_op *get_op_Alloc (void);
89 extern ir_op *op_Free; ir_op *get_op_Free (void);
91 extern ir_op *op_Sync; ir_op *get_op_Sync (void);
93 extern ir_op *op_Tuple; ir_op *get_op_Tuple (void);
94 extern ir_op *op_Proj; ir_op *get_op_Proj (void);
95 extern ir_op *op_Id; ir_op *get_op_Id (void);
96 extern ir_op *op_Bad; ir_op *get_op_Bad (void);
97 extern ir_op *op_Confirm; ir_op *get_op_Confirm (void);
99 extern ir_op *op_Unknown; ir_op *get_op_Unknown (void);
100 extern ir_op *op_Filter; ir_op *get_op_Filter (void);
101 extern ir_op *op_Break; ir_op *get_op_Break (void);
102 extern ir_op *op_CallBegin; ir_op *get_op_CallBegin (void);
103 extern ir_op *op_EndReg; ir_op *get_op_EndReg (void);
104 extern ir_op *op_EndExcept; ir_op *get_op_EndExcept (void);
106 extern ir_op *op_FuncCall; ir_op *get_op_FuncCall (void);
108 /** Returns the ident for the opcode name */
109 ident *get_op_ident(ir_op *op);
111 /** Returns the string for the opcode. */
112 const char *get_op_name(const ir_op *op);
114 /** Returns the enum for the opcode */
115 opcode get_op_code(const ir_op *op);
119 floats = 0, /**< Nodes of this opcode can be placed in any basic block. */
120 pinned /**< Nodes must remain in this basic block. */
123 /** gets pinned state of an opcode */
124 op_pinned get_op_pinned(const ir_op *op);
126 /** Sets pinned in the opcode. Setting it to floating has no effect
127 for Block, Phi and control flow nodes. */
128 void set_op_pinned(ir_op *op, op_pinned pinned);
130 /** Returns true if op is one of Start, End, Jmp, Cond, Return, Raise or Bad. */
131 int is_cfopcode(const ir_op *op);
133 /** Returns true if the operation manipulates interprocedural control flow:
134 CallBegin, EndReg, EndExcept */
135 int is_ip_cfopcode(const ir_op *op);
137 /** Returns the attribute size of nodes of this opcode.
138 @note Use not encouraged, internal feature. */
139 int get_op_attr_size (const ir_op *op);
141 # endif /* _IROP_H_ */