4f7f2f54838a41f773b4f2734f86124bbd7e6ccb
[oota-llvm.git] / include / llvm / Instruction.def
1 //===-- llvm/Instruction.def - File that describes Instructions -*- C++ -*-===//
2 // 
3 //                     The LLVM Compiler Infrastructure
4 //
5 // This file was developed by the LLVM research group and is distributed under
6 // the University of Illinois Open Source License. See LICENSE.TXT for details.
7 // 
8 //===----------------------------------------------------------------------===//
9 //
10 // This file contains descriptions of the various LLVM instructions.  This is
11 // used as a central place for enumerating the different instructions and 
12 // should eventually be the place to put comments about the instructions.
13 //
14 //===----------------------------------------------------------------------===//
15
16 // NOTE: NO INCLUDE GUARD DESIRED!
17
18 // Provide definitions of macros so that users of this file do not have to define
19 // everything to use it...
20 //
21 #ifndef FIRST_TERM_INST
22 #define FIRST_TERM_INST(num)
23 #endif
24 #ifndef HANDLE_TERM_INST
25 #ifndef HANDLE_INST
26 #define HANDLE_TERM_INST(num, opcode, Class)
27 #else
28 #define HANDLE_TERM_INST(num, opcode, Class) HANDLE_INST(num, opcode, Class)
29 #endif
30 #endif
31 #ifndef LAST_TERM_INST
32 #define LAST_TERM_INST(num)
33 #endif
34
35 #ifndef FIRST_BINARY_INST
36 #define FIRST_BINARY_INST(num)
37 #endif
38 #ifndef HANDLE_BINARY_INST
39 #ifndef HANDLE_INST
40 #define HANDLE_BINARY_INST(num, opcode, instclass)
41 #else
42 #define HANDLE_BINARY_INST(num, opcode, Class) HANDLE_INST(num, opcode, Class)
43 #endif
44 #endif
45 #ifndef LAST_BINARY_INST
46 #define LAST_BINARY_INST(num)
47 #endif
48
49 #ifndef FIRST_MEMORY_INST
50 #define FIRST_MEMORY_INST(num)
51 #endif
52 #ifndef HANDLE_MEMORY_INST
53 #ifndef HANDLE_INST
54 #define HANDLE_MEMORY_INST(num, opcode, Class)
55 #else
56 #define HANDLE_MEMORY_INST(num, opcode, Class) HANDLE_INST(num, opcode, Class)
57 #endif
58 #endif
59 #ifndef LAST_MEMORY_INST
60 #define LAST_MEMORY_INST(num)
61 #endif
62
63 #ifndef FIRST_OTHER_INST
64 #define FIRST_OTHER_INST(num)
65 #endif
66 #ifndef HANDLE_OTHER_INST
67 #ifndef HANDLE_INST
68 #define HANDLE_OTHER_INST(num, opcode, Class)
69 #else
70 #define HANDLE_OTHER_INST(num, opcode, Class) HANDLE_INST(num, opcode, Class)
71 #endif
72 #endif
73 #ifndef LAST_OTHER_INST
74 #define LAST_OTHER_INST(num)
75 #endif
76
77
78 // Terminator Instructions - These instructions are used to terminate a basic
79 // block of the program.   Every basic block must end with one of these
80 // instructions for it to be a well formed basic block.
81 //
82  FIRST_TERM_INST  ( 1)
83 HANDLE_TERM_INST  ( 1, Ret        , ReturnInst)
84 HANDLE_TERM_INST  ( 2, Br         , BranchInst)
85 HANDLE_TERM_INST  ( 3, Switch     , SwitchInst)
86 HANDLE_TERM_INST  ( 4, Invoke     , InvokeInst)
87 HANDLE_TERM_INST  ( 5, Unwind     , UnwindInst)
88 HANDLE_TERM_INST  ( 6, Unreachable, UnreachableInst)
89   LAST_TERM_INST  ( 6)
90
91 // Standard binary operators...
92  FIRST_BINARY_INST( 7)
93 HANDLE_BINARY_INST( 7, Add  , BinaryOperator)
94 HANDLE_BINARY_INST( 8, Sub  , BinaryOperator)
95 HANDLE_BINARY_INST( 9, Mul  , BinaryOperator)
96 HANDLE_BINARY_INST(10, UDiv , BinaryOperator)
97 HANDLE_BINARY_INST(11, SDiv , BinaryOperator)
98 HANDLE_BINARY_INST(12, FDiv , BinaryOperator)
99 HANDLE_BINARY_INST(13, URem , BinaryOperator)
100 HANDLE_BINARY_INST(14, SRem , BinaryOperator)
101 HANDLE_BINARY_INST(15, FRem , BinaryOperator)
102
103 // Logical operators...
104 HANDLE_BINARY_INST(16, And   , BinaryOperator)
105 HANDLE_BINARY_INST(17, Or    , BinaryOperator)
106 HANDLE_BINARY_INST(18, Xor   , BinaryOperator)
107
108 // Binary comparison operators...
109 HANDLE_BINARY_INST(19, SetEQ , SetCondInst)
110 HANDLE_BINARY_INST(20, SetNE , SetCondInst)
111 HANDLE_BINARY_INST(21, SetLE , SetCondInst)
112 HANDLE_BINARY_INST(22, SetGE , SetCondInst)
113 HANDLE_BINARY_INST(23, SetLT , SetCondInst)
114 HANDLE_BINARY_INST(24, SetGT , SetCondInst)
115   LAST_BINARY_INST(24)
116
117 // Memory operators...
118  FIRST_MEMORY_INST(25)
119 HANDLE_MEMORY_INST(25, Malloc, MallocInst)  // Heap management instructions
120 HANDLE_MEMORY_INST(26, Free  , FreeInst  )
121 HANDLE_MEMORY_INST(27, Alloca, AllocaInst)  // Stack management
122 HANDLE_MEMORY_INST(28, Load  , LoadInst  )  // Memory manipulation instrs
123 HANDLE_MEMORY_INST(29, Store , StoreInst )
124 HANDLE_MEMORY_INST(30, GetElementPtr, GetElementPtrInst)
125   LAST_MEMORY_INST(30)
126
127 // Other operators...
128  FIRST_OTHER_INST(31)
129 HANDLE_OTHER_INST(31, PHI    , PHINode    )  // PHI node instruction
130 HANDLE_OTHER_INST(32, Cast   , CastInst   )  // Type cast
131 HANDLE_OTHER_INST(33, Call   , CallInst   )  // Call a function
132 HANDLE_OTHER_INST(34, Shl    , ShiftInst  )  // Shift operations
133 HANDLE_OTHER_INST(35, Shr    , ShiftInst  )
134 HANDLE_OTHER_INST(36, Select , SelectInst )  // select instruction
135 HANDLE_OTHER_INST(37, UserOp1, Instruction)  // May be used internally in a pass
136 HANDLE_OTHER_INST(38, UserOp2, Instruction)
137 HANDLE_OTHER_INST(39, VAArg  , VAArgInst  )  // vaarg instruction
138 HANDLE_OTHER_INST(40, ExtractElement, ExtractElementInst)// extract from vector.
139 HANDLE_OTHER_INST(41, InsertElement, InsertElementInst)  // insert into vector
140 HANDLE_OTHER_INST(42, ShuffleVector, ShuffleVectorInst)  // shuffle two vectors.
141   LAST_OTHER_INST(42)
142
143 #undef  FIRST_TERM_INST
144 #undef HANDLE_TERM_INST
145 #undef   LAST_TERM_INST
146
147 #undef  FIRST_BINARY_INST
148 #undef HANDLE_BINARY_INST
149 #undef   LAST_BINARY_INST
150
151 #undef  FIRST_MEMORY_INST
152 #undef HANDLE_MEMORY_INST
153 #undef   LAST_MEMORY_INST
154
155 #undef  FIRST_OTHER_INST
156 #undef HANDLE_OTHER_INST
157 #undef   LAST_OTHER_INST
158
159 #ifdef HANDLE_INST
160 #undef HANDLE_INST
161 #endif