99de9e33987d72aa5485d80f36f6e1350b894906
[oota-llvm.git] / include / llvm-c / Core.h
1 /*===-- llvm-c/Core.h - Core Library C Interface ------------------*- C -*-===*\
2 |*                                                                            *|
3 |*                     The LLVM Compiler Infrastructure                       *|
4 |*                                                                            *|
5 |* This file is distributed under the University of Illinois Open Source      *|
6 |* License. See LICENSE.TXT for details.                                      *|
7 |*                                                                            *|
8 |*===----------------------------------------------------------------------===*|
9 |*                                                                            *|
10 |* This header declares the C interface to libLLVMCore.a, which implements    *|
11 |* the LLVM intermediate representation.                                      *|
12 |*                                                                            *|
13 |* LLVM uses a polymorphic type hierarchy which C cannot represent, therefore *|
14 |* parameters must be passed as base types. Despite the declared types, most  *|
15 |* of the functions provided operate only on branches of the type hierarchy.  *|
16 |* The declared parameter names are descriptive and specify which type is     *|
17 |* required. Additionally, each type hierarchy is documented along with the   *|
18 |* functions that operate upon it. For more detail, refer to LLVM's C++ code. *|
19 |* If in doubt, refer to Core.cpp, which performs paramter downcasts in the   *|
20 |* form unwrap<RequiredType>(Param).                                          *|
21 |*                                                                            *|
22 |* Many exotic languages can interoperate with C code but have a harder time  *|
23 |* with C++ due to name mangling. So in addition to C, this interface enables *|
24 |* tools written in such languages.                                           *|
25 |*                                                                            *|
26 |* When included into a C++ source file, also declares 'wrap' and 'unwrap'    *|
27 |* helpers to perform opaque reference<-->pointer conversions. These helpers  *|
28 |* are shorter and more tightly typed than writing the casts by hand when     *|
29 |* authoring bindings. In assert builds, they will do runtime type checking.  *|
30 |*                                                                            *|
31 \*===----------------------------------------------------------------------===*/
32
33 #ifndef LLVM_C_CORE_H
34 #define LLVM_C_CORE_H
35
36 #include "llvm/System/DataTypes.h"
37
38 #ifdef __cplusplus
39
40 /* Need these includes to support the LLVM 'cast' template for the C++ 'wrap' 
41    and 'unwrap' conversion functions. */
42 #include "llvm/Module.h"
43 #include "llvm/Support/IRBuilder.h"
44
45 extern "C" {
46 #endif
47
48
49 typedef int LLVMBool;
50
51 /* Opaque types. */
52
53 /**
54  * The top-level container for all LLVM global data.  See the LLVMContext class.
55  */
56 typedef struct LLVMOpaqueContext *LLVMContextRef;
57
58 /**
59  * The top-level container for all other LLVM Intermediate Representation (IR)
60  * objects. See the llvm::Module class.
61  */
62 typedef struct LLVMOpaqueModule *LLVMModuleRef;
63
64 /**
65  * Each value in the LLVM IR has a type, an LLVMTypeRef. See the llvm::Type
66  * class.
67  */
68 typedef struct LLVMOpaqueType *LLVMTypeRef;
69
70 /**
71  * When building recursive types using LLVMRefineType, LLVMTypeRef values may
72  * become invalid; use LLVMTypeHandleRef to resolve this problem. See the
73  * llvm::AbstractTypeHolder class.
74  */
75 typedef struct LLVMOpaqueTypeHandle *LLVMTypeHandleRef;
76
77 typedef struct LLVMOpaqueValue *LLVMValueRef;
78 typedef struct LLVMOpaqueBasicBlock *LLVMBasicBlockRef;
79 typedef struct LLVMOpaqueBuilder *LLVMBuilderRef;
80
81 /* Interface used to provide a module to JIT or interpreter.  This is now just a
82  * synonym for llvm::Module, but we have to keep using the different type to
83  * keep binary compatibility.
84  */
85 typedef struct LLVMOpaqueModuleProvider *LLVMModuleProviderRef;
86
87 /* Used to provide a module to JIT or interpreter.
88  * See the llvm::MemoryBuffer class.
89  */
90 typedef struct LLVMOpaqueMemoryBuffer *LLVMMemoryBufferRef;
91
92 /** See the llvm::PassManagerBase class. */
93 typedef struct LLVMOpaquePassManager *LLVMPassManagerRef;
94
95 /** Used to get the users and usees of a Value. See the llvm::Use class. */
96 typedef struct LLVMOpaqueUse *LLVMUseRef;
97
98 typedef enum {
99     LLVMZExtAttribute       = 1<<0,
100     LLVMSExtAttribute       = 1<<1,
101     LLVMNoReturnAttribute   = 1<<2,
102     LLVMInRegAttribute      = 1<<3,
103     LLVMStructRetAttribute  = 1<<4,
104     LLVMNoUnwindAttribute   = 1<<5,
105     LLVMNoAliasAttribute    = 1<<6,
106     LLVMByValAttribute      = 1<<7,
107     LLVMNestAttribute       = 1<<8,
108     LLVMReadNoneAttribute   = 1<<9,
109     LLVMReadOnlyAttribute   = 1<<10,
110     LLVMNoInlineAttribute   = 1<<11,
111     LLVMAlwaysInlineAttribute    = 1<<12,
112     LLVMOptimizeForSizeAttribute = 1<<13,
113     LLVMStackProtectAttribute    = 1<<14,
114     LLVMStackProtectReqAttribute = 1<<15,
115     LLVMAlignment = 31<<16,
116     LLVMNoCaptureAttribute  = 1<<21,
117     LLVMNoRedZoneAttribute  = 1<<22,
118     LLVMNoImplicitFloatAttribute = 1<<23,
119     LLVMNakedAttribute      = 1<<24,
120     LLVMInlineHintAttribute = 1<<25,
121     LLVMStackAlignment = 7<<26
122 } LLVMAttribute;
123
124 typedef enum {
125   /* Terminator Instructions */
126   LLVMRet            = 1,
127   LLVMBr             = 2,
128   LLVMSwitch         = 3,
129   LLVMIndirectBr     = 4,
130   LLVMInvoke         = 5,
131   LLVMUnwind         = 6,
132   LLVMUnreachable    = 7,
133
134   /* Standard Binary Operators */
135   LLVMAdd            = 8,
136   LLVMFAdd           = 9,
137   LLVMSub            = 10,
138   LLVMFSub           = 11,
139   LLVMMul            = 12,
140   LLVMFMul           = 13,
141   LLVMUDiv           = 14,
142   LLVMSDiv           = 15,
143   LLVMFDiv           = 16,
144   LLVMURem           = 17,
145   LLVMSRem           = 18,
146   LLVMFRem           = 19,
147
148   /* Logical Operators */
149   LLVMShl            = 20,
150   LLVMLShr           = 21,
151   LLVMAShr           = 22,
152   LLVMAnd            = 23,
153   LLVMOr             = 24,
154   LLVMXor            = 25,
155
156   /* Memory Operators */
157   LLVMAlloca         = 26,
158   LLVMLoad           = 27,
159   LLVMStore          = 28,
160   LLVMGetElementPtr  = 29,
161
162   /* Cast Operators */
163   LLVMTrunc          = 30,
164   LLVMZExt           = 31,
165   LLVMSExt           = 32,
166   LLVMFPToUI         = 33,
167   LLVMFPToSI         = 34,
168   LLVMUIToFP         = 35,
169   LLVMSIToFP         = 36,
170   LLVMFPTrunc        = 37,
171   LLVMFPExt          = 38,
172   LLVMPtrToInt       = 39,
173   LLVMIntToPtr       = 40,
174   LLVMBitCast        = 41,
175
176   /* Other Operators */
177   LLVMICmp           = 42,
178   LLVMFCmp           = 43,
179   LLVMPHI            = 44,
180   LLVMCall           = 45,
181   LLVMSelect         = 46,
182   /* UserOp1 */
183   /* UserOp2 */
184   LLVMVAArg          = 49,
185   LLVMExtractElement = 50,
186   LLVMInsertElement  = 51,
187   LLVMShuffleVector  = 52,
188   LLVMExtractValue   = 53,
189   LLVMInsertValue    = 54
190 } LLVMOpcode;
191
192 typedef enum {
193   LLVMVoidTypeKind,        /**< type with no size */
194   LLVMFloatTypeKind,       /**< 32 bit floating point type */
195   LLVMDoubleTypeKind,      /**< 64 bit floating point type */
196   LLVMX86_FP80TypeKind,    /**< 80 bit floating point type (X87) */
197   LLVMFP128TypeKind,       /**< 128 bit floating point type (112-bit mantissa)*/
198   LLVMPPC_FP128TypeKind,   /**< 128 bit floating point type (two 64-bits) */
199   LLVMLabelTypeKind,       /**< Labels */
200   LLVMIntegerTypeKind,     /**< Arbitrary bit width integers */
201   LLVMFunctionTypeKind,    /**< Functions */
202   LLVMStructTypeKind,      /**< Structures */
203   LLVMArrayTypeKind,       /**< Arrays */
204   LLVMPointerTypeKind,     /**< Pointers */
205   LLVMOpaqueTypeKind,      /**< Opaque: type with unknown structure */
206   LLVMVectorTypeKind,      /**< SIMD 'packed' format, or other vector type */
207   LLVMMetadataTypeKind,    /**< Metadata */
208   LLVMUnionTypeKind        /**< Unions */
209 } LLVMTypeKind;
210
211 typedef enum {
212   LLVMExternalLinkage,    /**< Externally visible function */
213   LLVMAvailableExternallyLinkage,
214   LLVMLinkOnceAnyLinkage, /**< Keep one copy of function when linking (inline)*/
215   LLVMLinkOnceODRLinkage, /**< Same, but only replaced by something
216                             equivalent. */
217   LLVMWeakAnyLinkage,     /**< Keep one copy of function when linking (weak) */
218   LLVMWeakODRLinkage,     /**< Same, but only replaced by something
219                             equivalent. */
220   LLVMAppendingLinkage,   /**< Special purpose, only applies to global arrays */
221   LLVMInternalLinkage,    /**< Rename collisions when linking (static
222                                functions) */
223   LLVMPrivateLinkage,     /**< Like Internal, but omit from symbol table */
224   LLVMDLLImportLinkage,   /**< Function to be imported from DLL */
225   LLVMDLLExportLinkage,   /**< Function to be accessible from DLL */
226   LLVMExternalWeakLinkage,/**< ExternalWeak linkage description */
227   LLVMGhostLinkage,       /**< Obsolete */
228   LLVMCommonLinkage,      /**< Tentative definitions */
229   LLVMLinkerPrivateLinkage, /**< Like Private, but linker removes. */
230   LLVMLinkerPrivateWeakLinkage /**< Like LinkerPrivate, but is weak. */
231 } LLVMLinkage;
232
233 typedef enum {
234   LLVMDefaultVisibility,  /**< The GV is visible */
235   LLVMHiddenVisibility,   /**< The GV is hidden */
236   LLVMProtectedVisibility /**< The GV is protected */
237 } LLVMVisibility;
238
239 typedef enum {
240   LLVMCCallConv           = 0,
241   LLVMFastCallConv        = 8,
242   LLVMColdCallConv        = 9,
243   LLVMX86StdcallCallConv  = 64,
244   LLVMX86FastcallCallConv = 65
245 } LLVMCallConv;
246
247 typedef enum {
248   LLVMIntEQ = 32, /**< equal */
249   LLVMIntNE,      /**< not equal */
250   LLVMIntUGT,     /**< unsigned greater than */
251   LLVMIntUGE,     /**< unsigned greater or equal */
252   LLVMIntULT,     /**< unsigned less than */
253   LLVMIntULE,     /**< unsigned less or equal */
254   LLVMIntSGT,     /**< signed greater than */
255   LLVMIntSGE,     /**< signed greater or equal */
256   LLVMIntSLT,     /**< signed less than */
257   LLVMIntSLE      /**< signed less or equal */
258 } LLVMIntPredicate;
259
260 typedef enum {
261   LLVMRealPredicateFalse, /**< Always false (always folded) */
262   LLVMRealOEQ,            /**< True if ordered and equal */
263   LLVMRealOGT,            /**< True if ordered and greater than */
264   LLVMRealOGE,            /**< True if ordered and greater than or equal */
265   LLVMRealOLT,            /**< True if ordered and less than */
266   LLVMRealOLE,            /**< True if ordered and less than or equal */
267   LLVMRealONE,            /**< True if ordered and operands are unequal */
268   LLVMRealORD,            /**< True if ordered (no nans) */
269   LLVMRealUNO,            /**< True if unordered: isnan(X) | isnan(Y) */
270   LLVMRealUEQ,            /**< True if unordered or equal */
271   LLVMRealUGT,            /**< True if unordered or greater than */
272   LLVMRealUGE,            /**< True if unordered, greater than, or equal */
273   LLVMRealULT,            /**< True if unordered or less than */
274   LLVMRealULE,            /**< True if unordered, less than, or equal */
275   LLVMRealUNE,            /**< True if unordered or not equal */
276   LLVMRealPredicateTrue   /**< Always true (always folded) */
277 } LLVMRealPredicate;
278
279
280 /*===-- Error handling ----------------------------------------------------===*/
281
282 void LLVMDisposeMessage(char *Message);
283
284
285 /*===-- Contexts ----------------------------------------------------------===*/
286
287 /* Create and destroy contexts. */
288 LLVMContextRef LLVMContextCreate(void);
289 LLVMContextRef LLVMGetGlobalContext(void);
290 void LLVMContextDispose(LLVMContextRef C);
291
292 unsigned LLVMGetMDKindIDInContext(LLVMContextRef C, const char* Name,
293                                   unsigned SLen);
294 unsigned LLVMGetMDKindID(const char* Name, unsigned SLen);
295
296 /*===-- Modules -----------------------------------------------------------===*/
297
298 /* Create and destroy modules. */ 
299 /** See llvm::Module::Module. */
300 LLVMModuleRef LLVMModuleCreateWithName(const char *ModuleID);
301 LLVMModuleRef LLVMModuleCreateWithNameInContext(const char *ModuleID,
302                                                 LLVMContextRef C);
303
304 /** See llvm::Module::~Module. */
305 void LLVMDisposeModule(LLVMModuleRef M);
306
307 /** Data layout. See Module::getDataLayout. */
308 const char *LLVMGetDataLayout(LLVMModuleRef M);
309 void LLVMSetDataLayout(LLVMModuleRef M, const char *Triple);
310
311 /** Target triple. See Module::getTargetTriple. */
312 const char *LLVMGetTarget(LLVMModuleRef M);
313 void LLVMSetTarget(LLVMModuleRef M, const char *Triple);
314
315 /** See Module::addTypeName. */
316 LLVMBool LLVMAddTypeName(LLVMModuleRef M, const char *Name, LLVMTypeRef Ty);
317 void LLVMDeleteTypeName(LLVMModuleRef M, const char *Name);
318 LLVMTypeRef LLVMGetTypeByName(LLVMModuleRef M, const char *Name);
319
320 /** See Module::dump. */
321 void LLVMDumpModule(LLVMModuleRef M);
322
323 /** See Module::setModuleInlineAsm. */
324 void LLVMSetModuleInlineAsm(LLVMModuleRef M, const char *Asm);
325
326 /*===-- Types -------------------------------------------------------------===*/
327
328 /* LLVM types conform to the following hierarchy:
329  * 
330  *   types:
331  *     integer type
332  *     real type
333  *     function type
334  *     sequence types:
335  *       array type
336  *       pointer type
337  *       vector type
338  *     void type
339  *     label type
340  *     opaque type
341  */
342
343 /** See llvm::LLVMTypeKind::getTypeID. */
344 LLVMTypeKind LLVMGetTypeKind(LLVMTypeRef Ty);
345
346 /** See llvm::LLVMType::getContext. */
347 LLVMContextRef LLVMGetTypeContext(LLVMTypeRef Ty);
348
349 /* Operations on integer types */
350 LLVMTypeRef LLVMInt1TypeInContext(LLVMContextRef C);
351 LLVMTypeRef LLVMInt8TypeInContext(LLVMContextRef C);
352 LLVMTypeRef LLVMInt16TypeInContext(LLVMContextRef C);
353 LLVMTypeRef LLVMInt32TypeInContext(LLVMContextRef C);
354 LLVMTypeRef LLVMInt64TypeInContext(LLVMContextRef C);
355 LLVMTypeRef LLVMIntTypeInContext(LLVMContextRef C, unsigned NumBits);
356
357 LLVMTypeRef LLVMInt1Type(void);
358 LLVMTypeRef LLVMInt8Type(void);
359 LLVMTypeRef LLVMInt16Type(void);
360 LLVMTypeRef LLVMInt32Type(void);
361 LLVMTypeRef LLVMInt64Type(void);
362 LLVMTypeRef LLVMIntType(unsigned NumBits);
363 unsigned LLVMGetIntTypeWidth(LLVMTypeRef IntegerTy);
364
365 /* Operations on real types */
366 LLVMTypeRef LLVMFloatTypeInContext(LLVMContextRef C);
367 LLVMTypeRef LLVMDoubleTypeInContext(LLVMContextRef C);
368 LLVMTypeRef LLVMX86FP80TypeInContext(LLVMContextRef C);
369 LLVMTypeRef LLVMFP128TypeInContext(LLVMContextRef C);
370 LLVMTypeRef LLVMPPCFP128TypeInContext(LLVMContextRef C);
371
372 LLVMTypeRef LLVMFloatType(void);
373 LLVMTypeRef LLVMDoubleType(void);
374 LLVMTypeRef LLVMX86FP80Type(void);
375 LLVMTypeRef LLVMFP128Type(void);
376 LLVMTypeRef LLVMPPCFP128Type(void);
377
378 /* Operations on function types */
379 LLVMTypeRef LLVMFunctionType(LLVMTypeRef ReturnType,
380                              LLVMTypeRef *ParamTypes, unsigned ParamCount,
381                              LLVMBool IsVarArg);
382 LLVMBool LLVMIsFunctionVarArg(LLVMTypeRef FunctionTy);
383 LLVMTypeRef LLVMGetReturnType(LLVMTypeRef FunctionTy);
384 unsigned LLVMCountParamTypes(LLVMTypeRef FunctionTy);
385 void LLVMGetParamTypes(LLVMTypeRef FunctionTy, LLVMTypeRef *Dest);
386
387 /* Operations on struct types */
388 LLVMTypeRef LLVMStructTypeInContext(LLVMContextRef C, LLVMTypeRef *ElementTypes,
389                                     unsigned ElementCount, LLVMBool Packed);
390 LLVMTypeRef LLVMStructType(LLVMTypeRef *ElementTypes, unsigned ElementCount,
391                            LLVMBool Packed);
392 unsigned LLVMCountStructElementTypes(LLVMTypeRef StructTy);
393 void LLVMGetStructElementTypes(LLVMTypeRef StructTy, LLVMTypeRef *Dest);
394 LLVMBool LLVMIsPackedStruct(LLVMTypeRef StructTy);
395
396 /* Operations on union types */
397 LLVMTypeRef LLVMUnionTypeInContext(LLVMContextRef C, LLVMTypeRef *ElementTypes,
398                                    unsigned ElementCount);
399 LLVMTypeRef LLVMUnionType(LLVMTypeRef *ElementTypes, unsigned ElementCount);
400 unsigned LLVMCountUnionElementTypes(LLVMTypeRef UnionTy);
401 void LLVMGetUnionElementTypes(LLVMTypeRef UnionTy, LLVMTypeRef *Dest);
402
403 /* Operations on array, pointer, and vector types (sequence types) */
404 LLVMTypeRef LLVMArrayType(LLVMTypeRef ElementType, unsigned ElementCount);
405 LLVMTypeRef LLVMPointerType(LLVMTypeRef ElementType, unsigned AddressSpace);
406 LLVMTypeRef LLVMVectorType(LLVMTypeRef ElementType, unsigned ElementCount);
407
408 LLVMTypeRef LLVMGetElementType(LLVMTypeRef Ty);
409 unsigned LLVMGetArrayLength(LLVMTypeRef ArrayTy);
410 unsigned LLVMGetPointerAddressSpace(LLVMTypeRef PointerTy);
411 unsigned LLVMGetVectorSize(LLVMTypeRef VectorTy);
412
413 /* Operations on other types */
414 LLVMTypeRef LLVMVoidTypeInContext(LLVMContextRef C);
415 LLVMTypeRef LLVMLabelTypeInContext(LLVMContextRef C);
416 LLVMTypeRef LLVMOpaqueTypeInContext(LLVMContextRef C);
417
418 LLVMTypeRef LLVMVoidType(void);
419 LLVMTypeRef LLVMLabelType(void);
420 LLVMTypeRef LLVMOpaqueType(void);
421
422 /* Operations on type handles */
423 LLVMTypeHandleRef LLVMCreateTypeHandle(LLVMTypeRef PotentiallyAbstractTy);
424 void LLVMRefineType(LLVMTypeRef AbstractTy, LLVMTypeRef ConcreteTy);
425 LLVMTypeRef LLVMResolveTypeHandle(LLVMTypeHandleRef TypeHandle);
426 void LLVMDisposeTypeHandle(LLVMTypeHandleRef TypeHandle);
427
428
429 /*===-- Values ------------------------------------------------------------===*/
430
431 /* The bulk of LLVM's object model consists of values, which comprise a very
432  * rich type hierarchy.
433  */
434
435 #define LLVM_FOR_EACH_VALUE_SUBCLASS(macro) \
436   macro(Argument)                           \
437   macro(BasicBlock)                         \
438   macro(InlineAsm)                          \
439   macro(User)                               \
440     macro(Constant)                         \
441       macro(ConstantAggregateZero)          \
442       macro(ConstantArray)                  \
443       macro(ConstantExpr)                   \
444       macro(ConstantFP)                     \
445       macro(ConstantInt)                    \
446       macro(ConstantPointerNull)            \
447       macro(ConstantStruct)                 \
448       macro(ConstantVector)                 \
449       macro(GlobalValue)                    \
450         macro(Function)                     \
451         macro(GlobalAlias)                  \
452         macro(GlobalVariable)               \
453       macro(UndefValue)                     \
454     macro(Instruction)                      \
455       macro(BinaryOperator)                 \
456       macro(CallInst)                       \
457         macro(IntrinsicInst)                \
458           macro(DbgInfoIntrinsic)           \
459             macro(DbgDeclareInst)           \
460           macro(EHSelectorInst)             \
461           macro(MemIntrinsic)               \
462             macro(MemCpyInst)               \
463             macro(MemMoveInst)              \
464             macro(MemSetInst)               \
465       macro(CmpInst)                        \
466       macro(FCmpInst)                       \
467       macro(ICmpInst)                       \
468       macro(ExtractElementInst)             \
469       macro(GetElementPtrInst)              \
470       macro(InsertElementInst)              \
471       macro(InsertValueInst)                \
472       macro(PHINode)                        \
473       macro(SelectInst)                     \
474       macro(ShuffleVectorInst)              \
475       macro(StoreInst)                      \
476       macro(TerminatorInst)                 \
477         macro(BranchInst)                   \
478         macro(InvokeInst)                   \
479         macro(ReturnInst)                   \
480         macro(SwitchInst)                   \
481         macro(UnreachableInst)              \
482         macro(UnwindInst)                   \
483     macro(UnaryInstruction)                 \
484       macro(AllocaInst)                     \
485       macro(CastInst)                       \
486         macro(BitCastInst)                  \
487         macro(FPExtInst)                    \
488         macro(FPToSIInst)                   \
489         macro(FPToUIInst)                   \
490         macro(FPTruncInst)                  \
491         macro(IntToPtrInst)                 \
492         macro(PtrToIntInst)                 \
493         macro(SExtInst)                     \
494         macro(SIToFPInst)                   \
495         macro(TruncInst)                    \
496         macro(UIToFPInst)                   \
497         macro(ZExtInst)                     \
498       macro(ExtractValueInst)               \
499       macro(LoadInst)                       \
500       macro(VAArgInst)
501
502 /* Operations on all values */
503 LLVMTypeRef LLVMTypeOf(LLVMValueRef Val);
504 const char *LLVMGetValueName(LLVMValueRef Val);
505 void LLVMSetValueName(LLVMValueRef Val, const char *Name);
506 void LLVMDumpValue(LLVMValueRef Val);
507 void LLVMReplaceAllUsesWith(LLVMValueRef OldVal, LLVMValueRef NewVal);
508 int LLVMHasMetadata(LLVMValueRef Val);
509 LLVMValueRef LLVMGetMetadata(LLVMValueRef Val, unsigned KindID);
510 void LLVMSetMetadata(LLVMValueRef Val, unsigned KindID, LLVMValueRef Node);
511
512 /* Conversion functions. Return the input value if it is an instance of the
513    specified class, otherwise NULL. See llvm::dyn_cast_or_null<>. */
514 #define LLVM_DECLARE_VALUE_CAST(name) \
515   LLVMValueRef LLVMIsA##name(LLVMValueRef Val);
516 LLVM_FOR_EACH_VALUE_SUBCLASS(LLVM_DECLARE_VALUE_CAST)
517
518 /* Operations on Uses */
519 LLVMUseRef LLVMGetFirstUse(LLVMValueRef Val);
520 LLVMUseRef LLVMGetNextUse(LLVMUseRef U);
521 LLVMValueRef LLVMGetUser(LLVMUseRef U);
522 LLVMValueRef LLVMGetUsedValue(LLVMUseRef U);
523
524 /* Operations on Users */
525 LLVMValueRef LLVMGetOperand(LLVMValueRef Val, unsigned Index);
526
527 /* Operations on constants of any type */
528 LLVMValueRef LLVMConstNull(LLVMTypeRef Ty); /* all zeroes */
529 LLVMValueRef LLVMConstAllOnes(LLVMTypeRef Ty); /* only for int/vector */
530 LLVMValueRef LLVMGetUndef(LLVMTypeRef Ty);
531 LLVMBool LLVMIsConstant(LLVMValueRef Val);
532 LLVMBool LLVMIsNull(LLVMValueRef Val);
533 LLVMBool LLVMIsUndef(LLVMValueRef Val);
534 LLVMValueRef LLVMConstPointerNull(LLVMTypeRef Ty);
535
536 /* Operations on metadata */
537 LLVMValueRef LLVMMDStringInContext(LLVMContextRef C, const char *Str,
538                                    unsigned SLen);
539 LLVMValueRef LLVMMDString(const char *Str, unsigned SLen);
540 LLVMValueRef LLVMMDNodeInContext(LLVMContextRef C, LLVMValueRef *Vals,
541                                  unsigned Count);
542 LLVMValueRef LLVMMDNode(LLVMValueRef *Vals, unsigned Count);
543
544 /* Operations on scalar constants */
545 LLVMValueRef LLVMConstInt(LLVMTypeRef IntTy, unsigned long long N,
546                           LLVMBool SignExtend);
547 LLVMValueRef LLVMConstIntOfString(LLVMTypeRef IntTy, const char *Text,
548                                   uint8_t Radix);
549 LLVMValueRef LLVMConstIntOfStringAndSize(LLVMTypeRef IntTy, const char *Text,
550                                          unsigned SLen, uint8_t Radix);
551 LLVMValueRef LLVMConstReal(LLVMTypeRef RealTy, double N);
552 LLVMValueRef LLVMConstRealOfString(LLVMTypeRef RealTy, const char *Text);
553 LLVMValueRef LLVMConstRealOfStringAndSize(LLVMTypeRef RealTy, const char *Text,
554                                           unsigned SLen);
555 unsigned long long LLVMConstIntGetZExtValue(LLVMValueRef ConstantVal);
556 long long LLVMConstIntGetSExtValue(LLVMValueRef ConstantVal);
557
558
559 /* Operations on composite constants */
560 LLVMValueRef LLVMConstStringInContext(LLVMContextRef C, const char *Str,
561                                       unsigned Length, LLVMBool DontNullTerminate);
562 LLVMValueRef LLVMConstStructInContext(LLVMContextRef C, 
563                                       LLVMValueRef *ConstantVals,
564                                       unsigned Count, LLVMBool Packed);
565
566 LLVMValueRef LLVMConstString(const char *Str, unsigned Length,
567                              LLVMBool DontNullTerminate);
568 LLVMValueRef LLVMConstArray(LLVMTypeRef ElementTy,
569                             LLVMValueRef *ConstantVals, unsigned Length);
570 LLVMValueRef LLVMConstStruct(LLVMValueRef *ConstantVals, unsigned Count,
571                              LLVMBool Packed);
572 LLVMValueRef LLVMConstVector(LLVMValueRef *ScalarConstantVals, unsigned Size);
573 LLVMValueRef LLVMConstUnion(LLVMTypeRef Ty, LLVMValueRef Val);
574
575 /* Constant expressions */
576 LLVMOpcode LLVMGetConstOpcode(LLVMValueRef ConstantVal);
577 LLVMValueRef LLVMAlignOf(LLVMTypeRef Ty);
578 LLVMValueRef LLVMSizeOf(LLVMTypeRef Ty);
579 LLVMValueRef LLVMConstNeg(LLVMValueRef ConstantVal);
580 LLVMValueRef LLVMConstNSWNeg(LLVMValueRef ConstantVal);
581 LLVMValueRef LLVMConstNUWNeg(LLVMValueRef ConstantVal);
582 LLVMValueRef LLVMConstFNeg(LLVMValueRef ConstantVal);
583 LLVMValueRef LLVMConstNot(LLVMValueRef ConstantVal);
584 LLVMValueRef LLVMConstAdd(LLVMValueRef LHSConstant, LLVMValueRef RHSConstant);
585 LLVMValueRef LLVMConstNSWAdd(LLVMValueRef LHSConstant, LLVMValueRef RHSConstant);
586 LLVMValueRef LLVMConstNUWAdd(LLVMValueRef LHSConstant, LLVMValueRef RHSConstant);
587 LLVMValueRef LLVMConstFAdd(LLVMValueRef LHSConstant, LLVMValueRef RHSConstant);
588 LLVMValueRef LLVMConstSub(LLVMValueRef LHSConstant, LLVMValueRef RHSConstant);
589 LLVMValueRef LLVMConstNSWSub(LLVMValueRef LHSConstant, LLVMValueRef RHSConstant);
590 LLVMValueRef LLVMConstNUWSub(LLVMValueRef LHSConstant, LLVMValueRef RHSConstant);
591 LLVMValueRef LLVMConstFSub(LLVMValueRef LHSConstant, LLVMValueRef RHSConstant);
592 LLVMValueRef LLVMConstMul(LLVMValueRef LHSConstant, LLVMValueRef RHSConstant);
593 LLVMValueRef LLVMConstNSWMul(LLVMValueRef LHSConstant, LLVMValueRef RHSConstant);
594 LLVMValueRef LLVMConstNUWMul(LLVMValueRef LHSConstant, LLVMValueRef RHSConstant);
595 LLVMValueRef LLVMConstFMul(LLVMValueRef LHSConstant, LLVMValueRef RHSConstant);
596 LLVMValueRef LLVMConstUDiv(LLVMValueRef LHSConstant, LLVMValueRef RHSConstant);
597 LLVMValueRef LLVMConstSDiv(LLVMValueRef LHSConstant, LLVMValueRef RHSConstant);
598 LLVMValueRef LLVMConstExactSDiv(LLVMValueRef LHSConstant, LLVMValueRef RHSConstant);
599 LLVMValueRef LLVMConstFDiv(LLVMValueRef LHSConstant, LLVMValueRef RHSConstant);
600 LLVMValueRef LLVMConstURem(LLVMValueRef LHSConstant, LLVMValueRef RHSConstant);
601 LLVMValueRef LLVMConstSRem(LLVMValueRef LHSConstant, LLVMValueRef RHSConstant);
602 LLVMValueRef LLVMConstFRem(LLVMValueRef LHSConstant, LLVMValueRef RHSConstant);
603 LLVMValueRef LLVMConstAnd(LLVMValueRef LHSConstant, LLVMValueRef RHSConstant);
604 LLVMValueRef LLVMConstOr(LLVMValueRef LHSConstant, LLVMValueRef RHSConstant);
605 LLVMValueRef LLVMConstXor(LLVMValueRef LHSConstant, LLVMValueRef RHSConstant);
606 LLVMValueRef LLVMConstICmp(LLVMIntPredicate Predicate,
607                            LLVMValueRef LHSConstant, LLVMValueRef RHSConstant);
608 LLVMValueRef LLVMConstFCmp(LLVMRealPredicate Predicate,
609                            LLVMValueRef LHSConstant, LLVMValueRef RHSConstant);
610 LLVMValueRef LLVMConstShl(LLVMValueRef LHSConstant, LLVMValueRef RHSConstant);
611 LLVMValueRef LLVMConstLShr(LLVMValueRef LHSConstant, LLVMValueRef RHSConstant);
612 LLVMValueRef LLVMConstAShr(LLVMValueRef LHSConstant, LLVMValueRef RHSConstant);
613 LLVMValueRef LLVMConstGEP(LLVMValueRef ConstantVal,
614                           LLVMValueRef *ConstantIndices, unsigned NumIndices);
615 LLVMValueRef LLVMConstInBoundsGEP(LLVMValueRef ConstantVal,
616                                   LLVMValueRef *ConstantIndices,
617                                   unsigned NumIndices);
618 LLVMValueRef LLVMConstTrunc(LLVMValueRef ConstantVal, LLVMTypeRef ToType);
619 LLVMValueRef LLVMConstSExt(LLVMValueRef ConstantVal, LLVMTypeRef ToType);
620 LLVMValueRef LLVMConstZExt(LLVMValueRef ConstantVal, LLVMTypeRef ToType);
621 LLVMValueRef LLVMConstFPTrunc(LLVMValueRef ConstantVal, LLVMTypeRef ToType);
622 LLVMValueRef LLVMConstFPExt(LLVMValueRef ConstantVal, LLVMTypeRef ToType);
623 LLVMValueRef LLVMConstUIToFP(LLVMValueRef ConstantVal, LLVMTypeRef ToType);
624 LLVMValueRef LLVMConstSIToFP(LLVMValueRef ConstantVal, LLVMTypeRef ToType);
625 LLVMValueRef LLVMConstFPToUI(LLVMValueRef ConstantVal, LLVMTypeRef ToType);
626 LLVMValueRef LLVMConstFPToSI(LLVMValueRef ConstantVal, LLVMTypeRef ToType);
627 LLVMValueRef LLVMConstPtrToInt(LLVMValueRef ConstantVal, LLVMTypeRef ToType);
628 LLVMValueRef LLVMConstIntToPtr(LLVMValueRef ConstantVal, LLVMTypeRef ToType);
629 LLVMValueRef LLVMConstBitCast(LLVMValueRef ConstantVal, LLVMTypeRef ToType);
630 LLVMValueRef LLVMConstZExtOrBitCast(LLVMValueRef ConstantVal,
631                                     LLVMTypeRef ToType);
632 LLVMValueRef LLVMConstSExtOrBitCast(LLVMValueRef ConstantVal,
633                                     LLVMTypeRef ToType);
634 LLVMValueRef LLVMConstTruncOrBitCast(LLVMValueRef ConstantVal,
635                                      LLVMTypeRef ToType);
636 LLVMValueRef LLVMConstPointerCast(LLVMValueRef ConstantVal,
637                                   LLVMTypeRef ToType);
638 LLVMValueRef LLVMConstIntCast(LLVMValueRef ConstantVal, LLVMTypeRef ToType,
639                               LLVMBool isSigned);
640 LLVMValueRef LLVMConstFPCast(LLVMValueRef ConstantVal, LLVMTypeRef ToType);
641 LLVMValueRef LLVMConstSelect(LLVMValueRef ConstantCondition,
642                              LLVMValueRef ConstantIfTrue,
643                              LLVMValueRef ConstantIfFalse);
644 LLVMValueRef LLVMConstExtractElement(LLVMValueRef VectorConstant,
645                                      LLVMValueRef IndexConstant);
646 LLVMValueRef LLVMConstInsertElement(LLVMValueRef VectorConstant,
647                                     LLVMValueRef ElementValueConstant,
648                                     LLVMValueRef IndexConstant);
649 LLVMValueRef LLVMConstShuffleVector(LLVMValueRef VectorAConstant,
650                                     LLVMValueRef VectorBConstant,
651                                     LLVMValueRef MaskConstant);
652 LLVMValueRef LLVMConstExtractValue(LLVMValueRef AggConstant, unsigned *IdxList,
653                                    unsigned NumIdx);
654 LLVMValueRef LLVMConstInsertValue(LLVMValueRef AggConstant,
655                                   LLVMValueRef ElementValueConstant,
656                                   unsigned *IdxList, unsigned NumIdx);
657 LLVMValueRef LLVMConstInlineAsm(LLVMTypeRef Ty,
658                                 const char *AsmString, const char *Constraints,
659                                 LLVMBool HasSideEffects, LLVMBool IsAlignStack);
660 LLVMValueRef LLVMBlockAddress(LLVMValueRef F, LLVMBasicBlockRef BB);
661
662 /* Operations on global variables, functions, and aliases (globals) */
663 LLVMModuleRef LLVMGetGlobalParent(LLVMValueRef Global);
664 LLVMBool LLVMIsDeclaration(LLVMValueRef Global);
665 LLVMLinkage LLVMGetLinkage(LLVMValueRef Global);
666 void LLVMSetLinkage(LLVMValueRef Global, LLVMLinkage Linkage);
667 const char *LLVMGetSection(LLVMValueRef Global);
668 void LLVMSetSection(LLVMValueRef Global, const char *Section);
669 LLVMVisibility LLVMGetVisibility(LLVMValueRef Global);
670 void LLVMSetVisibility(LLVMValueRef Global, LLVMVisibility Viz);
671 unsigned LLVMGetAlignment(LLVMValueRef Global);
672 void LLVMSetAlignment(LLVMValueRef Global, unsigned Bytes);
673
674 /* Operations on global variables */
675 LLVMValueRef LLVMAddGlobal(LLVMModuleRef M, LLVMTypeRef Ty, const char *Name);
676 LLVMValueRef LLVMAddGlobalInAddressSpace(LLVMModuleRef M, LLVMTypeRef Ty,
677                                          const char *Name,
678                                          unsigned AddressSpace);
679 LLVMValueRef LLVMGetNamedGlobal(LLVMModuleRef M, const char *Name);
680 LLVMValueRef LLVMGetFirstGlobal(LLVMModuleRef M);
681 LLVMValueRef LLVMGetLastGlobal(LLVMModuleRef M);
682 LLVMValueRef LLVMGetNextGlobal(LLVMValueRef GlobalVar);
683 LLVMValueRef LLVMGetPreviousGlobal(LLVMValueRef GlobalVar);
684 void LLVMDeleteGlobal(LLVMValueRef GlobalVar);
685 LLVMValueRef LLVMGetInitializer(LLVMValueRef GlobalVar);
686 void LLVMSetInitializer(LLVMValueRef GlobalVar, LLVMValueRef ConstantVal);
687 LLVMBool LLVMIsThreadLocal(LLVMValueRef GlobalVar);
688 void LLVMSetThreadLocal(LLVMValueRef GlobalVar, LLVMBool IsThreadLocal);
689 LLVMBool LLVMIsGlobalConstant(LLVMValueRef GlobalVar);
690 void LLVMSetGlobalConstant(LLVMValueRef GlobalVar, LLVMBool IsConstant);
691
692 /* Operations on aliases */
693 LLVMValueRef LLVMAddAlias(LLVMModuleRef M, LLVMTypeRef Ty, LLVMValueRef Aliasee,
694                           const char *Name);
695
696 /* Operations on functions */
697 LLVMValueRef LLVMAddFunction(LLVMModuleRef M, const char *Name,
698                              LLVMTypeRef FunctionTy);
699 LLVMValueRef LLVMGetNamedFunction(LLVMModuleRef M, const char *Name);
700 LLVMValueRef LLVMGetFirstFunction(LLVMModuleRef M);
701 LLVMValueRef LLVMGetLastFunction(LLVMModuleRef M);
702 LLVMValueRef LLVMGetNextFunction(LLVMValueRef Fn);
703 LLVMValueRef LLVMGetPreviousFunction(LLVMValueRef Fn);
704 void LLVMDeleteFunction(LLVMValueRef Fn);
705 unsigned LLVMGetIntrinsicID(LLVMValueRef Fn);
706 unsigned LLVMGetFunctionCallConv(LLVMValueRef Fn);
707 void LLVMSetFunctionCallConv(LLVMValueRef Fn, unsigned CC);
708 const char *LLVMGetGC(LLVMValueRef Fn);
709 void LLVMSetGC(LLVMValueRef Fn, const char *Name);
710 void LLVMAddFunctionAttr(LLVMValueRef Fn, LLVMAttribute PA);
711 LLVMAttribute LLVMGetFunctionAttr(LLVMValueRef Fn);
712 void LLVMRemoveFunctionAttr(LLVMValueRef Fn, LLVMAttribute PA);
713
714 /* Operations on parameters */
715 unsigned LLVMCountParams(LLVMValueRef Fn);
716 void LLVMGetParams(LLVMValueRef Fn, LLVMValueRef *Params);
717 LLVMValueRef LLVMGetParam(LLVMValueRef Fn, unsigned Index);
718 LLVMValueRef LLVMGetParamParent(LLVMValueRef Inst);
719 LLVMValueRef LLVMGetFirstParam(LLVMValueRef Fn);
720 LLVMValueRef LLVMGetLastParam(LLVMValueRef Fn);
721 LLVMValueRef LLVMGetNextParam(LLVMValueRef Arg);
722 LLVMValueRef LLVMGetPreviousParam(LLVMValueRef Arg);
723 void LLVMAddAttribute(LLVMValueRef Arg, LLVMAttribute PA);
724 void LLVMRemoveAttribute(LLVMValueRef Arg, LLVMAttribute PA);
725 LLVMAttribute LLVMGetAttribute(LLVMValueRef Arg);
726 void LLVMSetParamAlignment(LLVMValueRef Arg, unsigned align);
727
728 /* Operations on basic blocks */
729 LLVMValueRef LLVMBasicBlockAsValue(LLVMBasicBlockRef BB);
730 LLVMBool LLVMValueIsBasicBlock(LLVMValueRef Val);
731 LLVMBasicBlockRef LLVMValueAsBasicBlock(LLVMValueRef Val);
732 LLVMValueRef LLVMGetBasicBlockParent(LLVMBasicBlockRef BB);
733 unsigned LLVMCountBasicBlocks(LLVMValueRef Fn);
734 void LLVMGetBasicBlocks(LLVMValueRef Fn, LLVMBasicBlockRef *BasicBlocks);
735 LLVMBasicBlockRef LLVMGetFirstBasicBlock(LLVMValueRef Fn);
736 LLVMBasicBlockRef LLVMGetLastBasicBlock(LLVMValueRef Fn);
737 LLVMBasicBlockRef LLVMGetNextBasicBlock(LLVMBasicBlockRef BB);
738 LLVMBasicBlockRef LLVMGetPreviousBasicBlock(LLVMBasicBlockRef BB);
739 LLVMBasicBlockRef LLVMGetEntryBasicBlock(LLVMValueRef Fn);
740
741 LLVMBasicBlockRef LLVMAppendBasicBlockInContext(LLVMContextRef C,
742                                                 LLVMValueRef Fn,
743                                                 const char *Name);
744 LLVMBasicBlockRef LLVMInsertBasicBlockInContext(LLVMContextRef C,
745                                                 LLVMBasicBlockRef BB,
746                                                 const char *Name);
747
748 LLVMBasicBlockRef LLVMAppendBasicBlock(LLVMValueRef Fn, const char *Name);
749 LLVMBasicBlockRef LLVMInsertBasicBlock(LLVMBasicBlockRef InsertBeforeBB,
750                                        const char *Name);
751 void LLVMDeleteBasicBlock(LLVMBasicBlockRef BB);
752
753 void LLVMMoveBasicBlockBefore(LLVMBasicBlockRef BB, LLVMBasicBlockRef MovePos);
754 void LLVMMoveBasicBlockAfter(LLVMBasicBlockRef BB, LLVMBasicBlockRef MovePos);
755
756 /* Operations on instructions */
757 LLVMBasicBlockRef LLVMGetInstructionParent(LLVMValueRef Inst);
758 LLVMValueRef LLVMGetFirstInstruction(LLVMBasicBlockRef BB);
759 LLVMValueRef LLVMGetLastInstruction(LLVMBasicBlockRef BB);
760 LLVMValueRef LLVMGetNextInstruction(LLVMValueRef Inst);
761 LLVMValueRef LLVMGetPreviousInstruction(LLVMValueRef Inst);
762
763 /* Operations on call sites */
764 void LLVMSetInstructionCallConv(LLVMValueRef Instr, unsigned CC);
765 unsigned LLVMGetInstructionCallConv(LLVMValueRef Instr);
766 void LLVMAddInstrAttribute(LLVMValueRef Instr, unsigned index, LLVMAttribute);
767 void LLVMRemoveInstrAttribute(LLVMValueRef Instr, unsigned index, 
768                               LLVMAttribute);
769 void LLVMSetInstrParamAlignment(LLVMValueRef Instr, unsigned index, 
770                                 unsigned align);
771
772 /* Operations on call instructions (only) */
773 LLVMBool LLVMIsTailCall(LLVMValueRef CallInst);
774 void LLVMSetTailCall(LLVMValueRef CallInst, LLVMBool IsTailCall);
775
776 /* Operations on phi nodes */
777 void LLVMAddIncoming(LLVMValueRef PhiNode, LLVMValueRef *IncomingValues,
778                      LLVMBasicBlockRef *IncomingBlocks, unsigned Count);
779 unsigned LLVMCountIncoming(LLVMValueRef PhiNode);
780 LLVMValueRef LLVMGetIncomingValue(LLVMValueRef PhiNode, unsigned Index);
781 LLVMBasicBlockRef LLVMGetIncomingBlock(LLVMValueRef PhiNode, unsigned Index);
782
783 /*===-- Instruction builders ----------------------------------------------===*/
784
785 /* An instruction builder represents a point within a basic block, and is the
786  * exclusive means of building instructions using the C interface.
787  */
788
789 LLVMBuilderRef LLVMCreateBuilderInContext(LLVMContextRef C);
790 LLVMBuilderRef LLVMCreateBuilder(void);
791 void LLVMPositionBuilder(LLVMBuilderRef Builder, LLVMBasicBlockRef Block,
792                          LLVMValueRef Instr);
793 void LLVMPositionBuilderBefore(LLVMBuilderRef Builder, LLVMValueRef Instr);
794 void LLVMPositionBuilderAtEnd(LLVMBuilderRef Builder, LLVMBasicBlockRef Block);
795 LLVMBasicBlockRef LLVMGetInsertBlock(LLVMBuilderRef Builder);
796 void LLVMClearInsertionPosition(LLVMBuilderRef Builder);
797 void LLVMInsertIntoBuilder(LLVMBuilderRef Builder, LLVMValueRef Instr);
798 void LLVMInsertIntoBuilderWithName(LLVMBuilderRef Builder, LLVMValueRef Instr,
799                                    const char *Name);
800 void LLVMDisposeBuilder(LLVMBuilderRef Builder);
801
802 /* Metadata */
803 void LLVMSetCurrentDebugLocation(LLVMBuilderRef Builder, LLVMValueRef L);
804 LLVMValueRef LLVMGetCurrentDebugLocation(LLVMBuilderRef Builder);
805 void LLVMSetInstDebugLocation(LLVMBuilderRef Builder, LLVMValueRef Inst);
806
807 /* Terminators */
808 LLVMValueRef LLVMBuildRetVoid(LLVMBuilderRef);
809 LLVMValueRef LLVMBuildRet(LLVMBuilderRef, LLVMValueRef V);
810 LLVMValueRef LLVMBuildAggregateRet(LLVMBuilderRef, LLVMValueRef *RetVals,
811                                    unsigned N);
812 LLVMValueRef LLVMBuildBr(LLVMBuilderRef, LLVMBasicBlockRef Dest);
813 LLVMValueRef LLVMBuildCondBr(LLVMBuilderRef, LLVMValueRef If,
814                              LLVMBasicBlockRef Then, LLVMBasicBlockRef Else);
815 LLVMValueRef LLVMBuildSwitch(LLVMBuilderRef, LLVMValueRef V,
816                              LLVMBasicBlockRef Else, unsigned NumCases);
817 LLVMValueRef LLVMBuildIndirectBr(LLVMBuilderRef B, LLVMValueRef Addr,
818                                  unsigned NumDests);
819 LLVMValueRef LLVMBuildInvoke(LLVMBuilderRef, LLVMValueRef Fn,
820                              LLVMValueRef *Args, unsigned NumArgs,
821                              LLVMBasicBlockRef Then, LLVMBasicBlockRef Catch,
822                              const char *Name);
823 LLVMValueRef LLVMBuildUnwind(LLVMBuilderRef);
824 LLVMValueRef LLVMBuildUnreachable(LLVMBuilderRef);
825
826 /* Add a case to the switch instruction */
827 void LLVMAddCase(LLVMValueRef Switch, LLVMValueRef OnVal,
828                  LLVMBasicBlockRef Dest);
829
830 /* Add a destination to the indirectbr instruction */
831 void LLVMAddDestination(LLVMValueRef IndirectBr, LLVMBasicBlockRef Dest);
832
833 /* Arithmetic */
834 LLVMValueRef LLVMBuildAdd(LLVMBuilderRef, LLVMValueRef LHS, LLVMValueRef RHS,
835                           const char *Name);
836 LLVMValueRef LLVMBuildNSWAdd(LLVMBuilderRef, LLVMValueRef LHS, LLVMValueRef RHS,
837                              const char *Name);
838 LLVMValueRef LLVMBuildNUWAdd(LLVMBuilderRef, LLVMValueRef LHS, LLVMValueRef RHS,
839                              const char *Name);
840 LLVMValueRef LLVMBuildFAdd(LLVMBuilderRef, LLVMValueRef LHS, LLVMValueRef RHS,
841                            const char *Name);
842 LLVMValueRef LLVMBuildSub(LLVMBuilderRef, LLVMValueRef LHS, LLVMValueRef RHS,
843                           const char *Name);
844 LLVMValueRef LLVMBuildNSWSub(LLVMBuilderRef, LLVMValueRef LHS, LLVMValueRef RHS,
845                              const char *Name);
846 LLVMValueRef LLVMBuildNUWSub(LLVMBuilderRef, LLVMValueRef LHS, LLVMValueRef RHS,
847                              const char *Name);
848 LLVMValueRef LLVMBuildFSub(LLVMBuilderRef, LLVMValueRef LHS, LLVMValueRef RHS,
849                            const char *Name);
850 LLVMValueRef LLVMBuildMul(LLVMBuilderRef, LLVMValueRef LHS, LLVMValueRef RHS,
851                           const char *Name);
852 LLVMValueRef LLVMBuildNSWMul(LLVMBuilderRef, LLVMValueRef LHS, LLVMValueRef RHS,
853                              const char *Name);
854 LLVMValueRef LLVMBuildNUWMul(LLVMBuilderRef, LLVMValueRef LHS, LLVMValueRef RHS,
855                              const char *Name);
856 LLVMValueRef LLVMBuildFMul(LLVMBuilderRef, LLVMValueRef LHS, LLVMValueRef RHS,
857                            const char *Name);
858 LLVMValueRef LLVMBuildUDiv(LLVMBuilderRef, LLVMValueRef LHS, LLVMValueRef RHS,
859                            const char *Name);
860 LLVMValueRef LLVMBuildSDiv(LLVMBuilderRef, LLVMValueRef LHS, LLVMValueRef RHS,
861                            const char *Name);
862 LLVMValueRef LLVMBuildExactSDiv(LLVMBuilderRef, LLVMValueRef LHS, LLVMValueRef RHS,
863                                 const char *Name);
864 LLVMValueRef LLVMBuildFDiv(LLVMBuilderRef, LLVMValueRef LHS, LLVMValueRef RHS,
865                            const char *Name);
866 LLVMValueRef LLVMBuildURem(LLVMBuilderRef, LLVMValueRef LHS, LLVMValueRef RHS,
867                            const char *Name);
868 LLVMValueRef LLVMBuildSRem(LLVMBuilderRef, LLVMValueRef LHS, LLVMValueRef RHS,
869                            const char *Name);
870 LLVMValueRef LLVMBuildFRem(LLVMBuilderRef, LLVMValueRef LHS, LLVMValueRef RHS,
871                            const char *Name);
872 LLVMValueRef LLVMBuildShl(LLVMBuilderRef, LLVMValueRef LHS, LLVMValueRef RHS,
873                            const char *Name);
874 LLVMValueRef LLVMBuildLShr(LLVMBuilderRef, LLVMValueRef LHS, LLVMValueRef RHS,
875                            const char *Name);
876 LLVMValueRef LLVMBuildAShr(LLVMBuilderRef, LLVMValueRef LHS, LLVMValueRef RHS,
877                            const char *Name);
878 LLVMValueRef LLVMBuildAnd(LLVMBuilderRef, LLVMValueRef LHS, LLVMValueRef RHS,
879                           const char *Name);
880 LLVMValueRef LLVMBuildOr(LLVMBuilderRef, LLVMValueRef LHS, LLVMValueRef RHS,
881                           const char *Name);
882 LLVMValueRef LLVMBuildXor(LLVMBuilderRef, LLVMValueRef LHS, LLVMValueRef RHS,
883                           const char *Name);
884 LLVMValueRef LLVMBuildBinOp(LLVMBuilderRef B, LLVMOpcode Op,
885                             LLVMValueRef LHS, LLVMValueRef RHS,
886                             const char *Name);
887 LLVMValueRef LLVMBuildNeg(LLVMBuilderRef, LLVMValueRef V, const char *Name);
888 LLVMValueRef LLVMBuildNSWNeg(LLVMBuilderRef B, LLVMValueRef V,
889                              const char *Name);
890 LLVMValueRef LLVMBuildNUWNeg(LLVMBuilderRef B, LLVMValueRef V,
891                              const char *Name);
892 LLVMValueRef LLVMBuildFNeg(LLVMBuilderRef, LLVMValueRef V, const char *Name);
893 LLVMValueRef LLVMBuildNot(LLVMBuilderRef, LLVMValueRef V, const char *Name);
894
895 /* Memory */
896 LLVMValueRef LLVMBuildMalloc(LLVMBuilderRef, LLVMTypeRef Ty, const char *Name);
897 LLVMValueRef LLVMBuildArrayMalloc(LLVMBuilderRef, LLVMTypeRef Ty,
898                                   LLVMValueRef Val, const char *Name);
899 LLVMValueRef LLVMBuildAlloca(LLVMBuilderRef, LLVMTypeRef Ty, const char *Name);
900 LLVMValueRef LLVMBuildArrayAlloca(LLVMBuilderRef, LLVMTypeRef Ty,
901                                   LLVMValueRef Val, const char *Name);
902 LLVMValueRef LLVMBuildFree(LLVMBuilderRef, LLVMValueRef PointerVal);
903 LLVMValueRef LLVMBuildLoad(LLVMBuilderRef, LLVMValueRef PointerVal,
904                            const char *Name);
905 LLVMValueRef LLVMBuildStore(LLVMBuilderRef, LLVMValueRef Val, LLVMValueRef Ptr);
906 LLVMValueRef LLVMBuildGEP(LLVMBuilderRef B, LLVMValueRef Pointer,
907                           LLVMValueRef *Indices, unsigned NumIndices,
908                           const char *Name);
909 LLVMValueRef LLVMBuildInBoundsGEP(LLVMBuilderRef B, LLVMValueRef Pointer,
910                                   LLVMValueRef *Indices, unsigned NumIndices,
911                                   const char *Name);
912 LLVMValueRef LLVMBuildStructGEP(LLVMBuilderRef B, LLVMValueRef Pointer,
913                                 unsigned Idx, const char *Name);
914 LLVMValueRef LLVMBuildGlobalString(LLVMBuilderRef B, const char *Str,
915                                    const char *Name);
916 LLVMValueRef LLVMBuildGlobalStringPtr(LLVMBuilderRef B, const char *Str,
917                                       const char *Name);
918
919 /* Casts */
920 LLVMValueRef LLVMBuildTrunc(LLVMBuilderRef, LLVMValueRef Val,
921                             LLVMTypeRef DestTy, const char *Name);
922 LLVMValueRef LLVMBuildZExt(LLVMBuilderRef, LLVMValueRef Val,
923                            LLVMTypeRef DestTy, const char *Name);
924 LLVMValueRef LLVMBuildSExt(LLVMBuilderRef, LLVMValueRef Val,
925                            LLVMTypeRef DestTy, const char *Name);
926 LLVMValueRef LLVMBuildFPToUI(LLVMBuilderRef, LLVMValueRef Val,
927                              LLVMTypeRef DestTy, const char *Name);
928 LLVMValueRef LLVMBuildFPToSI(LLVMBuilderRef, LLVMValueRef Val,
929                              LLVMTypeRef DestTy, const char *Name);
930 LLVMValueRef LLVMBuildUIToFP(LLVMBuilderRef, LLVMValueRef Val,
931                              LLVMTypeRef DestTy, const char *Name);
932 LLVMValueRef LLVMBuildSIToFP(LLVMBuilderRef, LLVMValueRef Val,
933                              LLVMTypeRef DestTy, const char *Name);
934 LLVMValueRef LLVMBuildFPTrunc(LLVMBuilderRef, LLVMValueRef Val,
935                               LLVMTypeRef DestTy, const char *Name);
936 LLVMValueRef LLVMBuildFPExt(LLVMBuilderRef, LLVMValueRef Val,
937                             LLVMTypeRef DestTy, const char *Name);
938 LLVMValueRef LLVMBuildPtrToInt(LLVMBuilderRef, LLVMValueRef Val,
939                                LLVMTypeRef DestTy, const char *Name);
940 LLVMValueRef LLVMBuildIntToPtr(LLVMBuilderRef, LLVMValueRef Val,
941                                LLVMTypeRef DestTy, const char *Name);
942 LLVMValueRef LLVMBuildBitCast(LLVMBuilderRef, LLVMValueRef Val,
943                               LLVMTypeRef DestTy, const char *Name);
944 LLVMValueRef LLVMBuildZExtOrBitCast(LLVMBuilderRef, LLVMValueRef Val,
945                                     LLVMTypeRef DestTy, const char *Name);
946 LLVMValueRef LLVMBuildSExtOrBitCast(LLVMBuilderRef, LLVMValueRef Val,
947                                     LLVMTypeRef DestTy, const char *Name);
948 LLVMValueRef LLVMBuildTruncOrBitCast(LLVMBuilderRef, LLVMValueRef Val,
949                                      LLVMTypeRef DestTy, const char *Name);
950 LLVMValueRef LLVMBuildCast(LLVMBuilderRef B, LLVMOpcode Op, LLVMValueRef Val,
951                            LLVMTypeRef DestTy, const char *Name);
952 LLVMValueRef LLVMBuildPointerCast(LLVMBuilderRef, LLVMValueRef Val,
953                                   LLVMTypeRef DestTy, const char *Name);
954 LLVMValueRef LLVMBuildIntCast(LLVMBuilderRef, LLVMValueRef Val, /*Signed cast!*/
955                               LLVMTypeRef DestTy, const char *Name);
956 LLVMValueRef LLVMBuildFPCast(LLVMBuilderRef, LLVMValueRef Val,
957                              LLVMTypeRef DestTy, const char *Name);
958
959 /* Comparisons */
960 LLVMValueRef LLVMBuildICmp(LLVMBuilderRef, LLVMIntPredicate Op,
961                            LLVMValueRef LHS, LLVMValueRef RHS,
962                            const char *Name);
963 LLVMValueRef LLVMBuildFCmp(LLVMBuilderRef, LLVMRealPredicate Op,
964                            LLVMValueRef LHS, LLVMValueRef RHS,
965                            const char *Name);
966
967 /* Miscellaneous instructions */
968 LLVMValueRef LLVMBuildPhi(LLVMBuilderRef, LLVMTypeRef Ty, const char *Name);
969 LLVMValueRef LLVMBuildCall(LLVMBuilderRef, LLVMValueRef Fn,
970                            LLVMValueRef *Args, unsigned NumArgs,
971                            const char *Name);
972 LLVMValueRef LLVMBuildSelect(LLVMBuilderRef, LLVMValueRef If,
973                              LLVMValueRef Then, LLVMValueRef Else,
974                              const char *Name);
975 LLVMValueRef LLVMBuildVAArg(LLVMBuilderRef, LLVMValueRef List, LLVMTypeRef Ty,
976                             const char *Name);
977 LLVMValueRef LLVMBuildExtractElement(LLVMBuilderRef, LLVMValueRef VecVal,
978                                      LLVMValueRef Index, const char *Name);
979 LLVMValueRef LLVMBuildInsertElement(LLVMBuilderRef, LLVMValueRef VecVal,
980                                     LLVMValueRef EltVal, LLVMValueRef Index,
981                                     const char *Name);
982 LLVMValueRef LLVMBuildShuffleVector(LLVMBuilderRef, LLVMValueRef V1,
983                                     LLVMValueRef V2, LLVMValueRef Mask,
984                                     const char *Name);
985 LLVMValueRef LLVMBuildExtractValue(LLVMBuilderRef, LLVMValueRef AggVal,
986                                    unsigned Index, const char *Name);
987 LLVMValueRef LLVMBuildInsertValue(LLVMBuilderRef, LLVMValueRef AggVal,
988                                   LLVMValueRef EltVal, unsigned Index,
989                                   const char *Name);
990
991 LLVMValueRef LLVMBuildIsNull(LLVMBuilderRef, LLVMValueRef Val,
992                              const char *Name);
993 LLVMValueRef LLVMBuildIsNotNull(LLVMBuilderRef, LLVMValueRef Val,
994                                 const char *Name);
995 LLVMValueRef LLVMBuildPtrDiff(LLVMBuilderRef, LLVMValueRef LHS,
996                               LLVMValueRef RHS, const char *Name);
997
998
999 /*===-- Module providers --------------------------------------------------===*/
1000
1001 /* Changes the type of M so it can be passed to FunctionPassManagers and the
1002  * JIT.  They take ModuleProviders for historical reasons.
1003  */
1004 LLVMModuleProviderRef
1005 LLVMCreateModuleProviderForExistingModule(LLVMModuleRef M);
1006
1007 /* Destroys the module M.
1008  */
1009 void LLVMDisposeModuleProvider(LLVMModuleProviderRef M);
1010
1011
1012 /*===-- Memory buffers ----------------------------------------------------===*/
1013
1014 LLVMBool LLVMCreateMemoryBufferWithContentsOfFile(const char *Path,
1015                                                   LLVMMemoryBufferRef *OutMemBuf,
1016                                                   char **OutMessage);
1017 LLVMBool LLVMCreateMemoryBufferWithSTDIN(LLVMMemoryBufferRef *OutMemBuf,
1018                                          char **OutMessage);
1019 void LLVMDisposeMemoryBuffer(LLVMMemoryBufferRef MemBuf);
1020
1021
1022 /*===-- Pass Managers -----------------------------------------------------===*/
1023
1024 /** Constructs a new whole-module pass pipeline. This type of pipeline is
1025     suitable for link-time optimization and whole-module transformations.
1026     See llvm::PassManager::PassManager. */
1027 LLVMPassManagerRef LLVMCreatePassManager(void);
1028
1029 /** Constructs a new function-by-function pass pipeline over the module
1030     provider. It does not take ownership of the module provider. This type of
1031     pipeline is suitable for code generation and JIT compilation tasks.
1032     See llvm::FunctionPassManager::FunctionPassManager. */
1033 LLVMPassManagerRef LLVMCreateFunctionPassManagerForModule(LLVMModuleRef M);
1034
1035 /** Deprecated: Use LLVMCreateFunctionPassManagerForModule instead. */
1036 LLVMPassManagerRef LLVMCreateFunctionPassManager(LLVMModuleProviderRef MP);
1037
1038 /** Initializes, executes on the provided module, and finalizes all of the
1039     passes scheduled in the pass manager. Returns 1 if any of the passes
1040     modified the module, 0 otherwise. See llvm::PassManager::run(Module&). */
1041 LLVMBool LLVMRunPassManager(LLVMPassManagerRef PM, LLVMModuleRef M);
1042
1043 /** Initializes all of the function passes scheduled in the function pass
1044     manager. Returns 1 if any of the passes modified the module, 0 otherwise.
1045     See llvm::FunctionPassManager::doInitialization. */
1046 LLVMBool LLVMInitializeFunctionPassManager(LLVMPassManagerRef FPM);
1047
1048 /** Executes all of the function passes scheduled in the function pass manager
1049     on the provided function. Returns 1 if any of the passes modified the
1050     function, false otherwise.
1051     See llvm::FunctionPassManager::run(Function&). */
1052 LLVMBool LLVMRunFunctionPassManager(LLVMPassManagerRef FPM, LLVMValueRef F);
1053
1054 /** Finalizes all of the function passes scheduled in in the function pass
1055     manager. Returns 1 if any of the passes modified the module, 0 otherwise.
1056     See llvm::FunctionPassManager::doFinalization. */
1057 LLVMBool LLVMFinalizeFunctionPassManager(LLVMPassManagerRef FPM);
1058
1059 /** Frees the memory of a pass pipeline. For function pipelines, does not free
1060     the module provider.
1061     See llvm::PassManagerBase::~PassManagerBase. */
1062 void LLVMDisposePassManager(LLVMPassManagerRef PM);
1063
1064
1065 #ifdef __cplusplus
1066 }
1067
1068 namespace llvm {
1069   class MemoryBuffer;
1070   class PassManagerBase;
1071   
1072   #define DEFINE_SIMPLE_CONVERSION_FUNCTIONS(ty, ref)   \
1073     inline ty *unwrap(ref P) {                          \
1074       return reinterpret_cast<ty*>(P);                  \
1075     }                                                   \
1076                                                         \
1077     inline ref wrap(const ty *P) {                      \
1078       return reinterpret_cast<ref>(const_cast<ty*>(P)); \
1079     }
1080   
1081   #define DEFINE_ISA_CONVERSION_FUNCTIONS(ty, ref)  \
1082     DEFINE_SIMPLE_CONVERSION_FUNCTIONS(ty, ref)         \
1083                                                         \
1084     template<typename T>                                \
1085     inline T *unwrap(ref P) {                           \
1086       return cast<T>(unwrap(P));                        \
1087     }
1088   
1089   #define DEFINE_STDCXX_CONVERSION_FUNCTIONS(ty, ref)   \
1090     DEFINE_SIMPLE_CONVERSION_FUNCTIONS(ty, ref)         \
1091                                                         \
1092     template<typename T>                                \
1093     inline T *unwrap(ref P) {                           \
1094       T *Q = (T*)unwrap(P);                             \
1095       assert(Q && "Invalid cast!");                     \
1096       return Q;                                         \
1097     }
1098   
1099   DEFINE_ISA_CONVERSION_FUNCTIONS   (Type,               LLVMTypeRef          )
1100   DEFINE_ISA_CONVERSION_FUNCTIONS   (Value,              LLVMValueRef         )
1101   DEFINE_SIMPLE_CONVERSION_FUNCTIONS(Module,             LLVMModuleRef        )
1102   DEFINE_SIMPLE_CONVERSION_FUNCTIONS(BasicBlock,         LLVMBasicBlockRef    )
1103   DEFINE_SIMPLE_CONVERSION_FUNCTIONS(IRBuilder<>,        LLVMBuilderRef       )
1104   DEFINE_SIMPLE_CONVERSION_FUNCTIONS(PATypeHolder,       LLVMTypeHandleRef    )
1105   DEFINE_SIMPLE_CONVERSION_FUNCTIONS(MemoryBuffer,       LLVMMemoryBufferRef  )
1106   DEFINE_SIMPLE_CONVERSION_FUNCTIONS(LLVMContext,        LLVMContextRef       )
1107   DEFINE_SIMPLE_CONVERSION_FUNCTIONS(Use,                LLVMUseRef           )
1108   DEFINE_STDCXX_CONVERSION_FUNCTIONS(PassManagerBase,    LLVMPassManagerRef   )
1109   /* LLVMModuleProviderRef exists for historical reasons, but now just holds a
1110    * Module.
1111    */
1112   inline Module *unwrap(LLVMModuleProviderRef MP) {
1113     return reinterpret_cast<Module*>(MP);
1114   }
1115   
1116   #undef DEFINE_STDCXX_CONVERSION_FUNCTIONS
1117   #undef DEFINE_ISA_CONVERSION_FUNCTIONS
1118   #undef DEFINE_SIMPLE_CONVERSION_FUNCTIONS
1119
1120   /* Specialized opaque context conversions.
1121    */
1122   inline LLVMContext **unwrap(LLVMContextRef* Tys) {
1123     return reinterpret_cast<LLVMContext**>(Tys);
1124   }
1125   
1126   inline LLVMContextRef *wrap(const LLVMContext **Tys) {
1127     return reinterpret_cast<LLVMContextRef*>(const_cast<LLVMContext**>(Tys));
1128   }
1129   
1130   /* Specialized opaque type conversions.
1131    */
1132   inline Type **unwrap(LLVMTypeRef* Tys) {
1133     return reinterpret_cast<Type**>(Tys);
1134   }
1135   
1136   inline LLVMTypeRef *wrap(const Type **Tys) {
1137     return reinterpret_cast<LLVMTypeRef*>(const_cast<Type**>(Tys));
1138   }
1139   
1140   /* Specialized opaque value conversions.
1141    */ 
1142   inline Value **unwrap(LLVMValueRef *Vals) {
1143     return reinterpret_cast<Value**>(Vals);
1144   }
1145   
1146   template<typename T>
1147   inline T **unwrap(LLVMValueRef *Vals, unsigned Length) {
1148     #if DEBUG
1149     for (LLVMValueRef *I = Vals, *E = Vals + Length; I != E; ++I)
1150       cast<T>(*I);
1151     #endif
1152     return reinterpret_cast<T**>(Vals);
1153   }
1154   
1155   inline LLVMValueRef *wrap(const Value **Vals) {
1156     return reinterpret_cast<LLVMValueRef*>(const_cast<Value**>(Vals));
1157   }
1158 }
1159
1160 #endif /* !defined(__cplusplus) */
1161
1162 #endif /* !defined(LLVM_C_CORE_H) */