OSDN Git Service

Change () to (void) in the C API.
[android-x86/external-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 \*===----------------------------------------------------------------------===*/
14
15 #ifndef LLVM_C_CORE_H
16 #define LLVM_C_CORE_H
17
18 #include "llvm-c/ErrorHandling.h"
19 #include "llvm-c/Types.h"
20
21 #ifdef __cplusplus
22 extern "C" {
23 #endif
24
25 /**
26  * @defgroup LLVMC LLVM-C: C interface to LLVM
27  *
28  * This module exposes parts of the LLVM library as a C API.
29  *
30  * @{
31  */
32
33 /**
34  * @defgroup LLVMCTransforms Transforms
35  */
36
37 /**
38  * @defgroup LLVMCCore Core
39  *
40  * This modules provide an interface to libLLVMCore, which implements
41  * the LLVM intermediate representation as well as other related types
42  * and utilities.
43  *
44  * Many exotic languages can interoperate with C code but have a harder time
45  * with C++ due to name mangling. So in addition to C, this interface enables
46  * tools written in such languages.
47  *
48  * @{
49  */
50
51 /**
52  * @defgroup LLVMCCoreTypes Types and Enumerations
53  *
54  * @{
55  */
56
57 typedef enum {
58     LLVMZExtAttribute       = 1<<0,
59     LLVMSExtAttribute       = 1<<1,
60     LLVMNoReturnAttribute   = 1<<2,
61     LLVMInRegAttribute      = 1<<3,
62     LLVMStructRetAttribute  = 1<<4,
63     LLVMNoUnwindAttribute   = 1<<5,
64     LLVMNoAliasAttribute    = 1<<6,
65     LLVMByValAttribute      = 1<<7,
66     LLVMNestAttribute       = 1<<8,
67     LLVMReadNoneAttribute   = 1<<9,
68     LLVMReadOnlyAttribute   = 1<<10,
69     LLVMNoInlineAttribute   = 1<<11,
70     LLVMAlwaysInlineAttribute    = 1<<12,
71     LLVMOptimizeForSizeAttribute = 1<<13,
72     LLVMStackProtectAttribute    = 1<<14,
73     LLVMStackProtectReqAttribute = 1<<15,
74     LLVMAlignment = 31<<16,
75     LLVMNoCaptureAttribute  = 1<<21,
76     LLVMNoRedZoneAttribute  = 1<<22,
77     LLVMNoImplicitFloatAttribute = 1<<23,
78     LLVMNakedAttribute      = 1<<24,
79     LLVMInlineHintAttribute = 1<<25,
80     LLVMStackAlignment = 7<<26,
81     LLVMReturnsTwice = 1 << 29,
82     LLVMUWTable = 1 << 30,
83     LLVMNonLazyBind = 1 << 31
84
85     /* FIXME: These attributes are currently not included in the C API as
86        a temporary measure until the API/ABI impact to the C API is understood
87        and the path forward agreed upon.
88     LLVMSanitizeAddressAttribute = 1ULL << 32,
89     LLVMStackProtectStrongAttribute = 1ULL<<35,
90     LLVMColdAttribute = 1ULL << 40,
91     LLVMOptimizeNoneAttribute = 1ULL << 42,
92     LLVMInAllocaAttribute = 1ULL << 43,
93     LLVMNonNullAttribute = 1ULL << 44,
94     LLVMJumpTableAttribute = 1ULL << 45,
95     LLVMConvergentAttribute = 1ULL << 46,
96     LLVMSafeStackAttribute = 1ULL << 47,
97     LLVMSwiftSelfAttribute = 1ULL << 48,
98     LLVMSwiftErrorAttribute = 1ULL << 49,
99     */
100 } LLVMAttribute;
101
102 typedef enum {
103   /* Terminator Instructions */
104   LLVMRet            = 1,
105   LLVMBr             = 2,
106   LLVMSwitch         = 3,
107   LLVMIndirectBr     = 4,
108   LLVMInvoke         = 5,
109   /* removed 6 due to API changes */
110   LLVMUnreachable    = 7,
111
112   /* Standard Binary Operators */
113   LLVMAdd            = 8,
114   LLVMFAdd           = 9,
115   LLVMSub            = 10,
116   LLVMFSub           = 11,
117   LLVMMul            = 12,
118   LLVMFMul           = 13,
119   LLVMUDiv           = 14,
120   LLVMSDiv           = 15,
121   LLVMFDiv           = 16,
122   LLVMURem           = 17,
123   LLVMSRem           = 18,
124   LLVMFRem           = 19,
125
126   /* Logical Operators */
127   LLVMShl            = 20,
128   LLVMLShr           = 21,
129   LLVMAShr           = 22,
130   LLVMAnd            = 23,
131   LLVMOr             = 24,
132   LLVMXor            = 25,
133
134   /* Memory Operators */
135   LLVMAlloca         = 26,
136   LLVMLoad           = 27,
137   LLVMStore          = 28,
138   LLVMGetElementPtr  = 29,
139
140   /* Cast Operators */
141   LLVMTrunc          = 30,
142   LLVMZExt           = 31,
143   LLVMSExt           = 32,
144   LLVMFPToUI         = 33,
145   LLVMFPToSI         = 34,
146   LLVMUIToFP         = 35,
147   LLVMSIToFP         = 36,
148   LLVMFPTrunc        = 37,
149   LLVMFPExt          = 38,
150   LLVMPtrToInt       = 39,
151   LLVMIntToPtr       = 40,
152   LLVMBitCast        = 41,
153   LLVMAddrSpaceCast  = 60,
154
155   /* Other Operators */
156   LLVMICmp           = 42,
157   LLVMFCmp           = 43,
158   LLVMPHI            = 44,
159   LLVMCall           = 45,
160   LLVMSelect         = 46,
161   LLVMUserOp1        = 47,
162   LLVMUserOp2        = 48,
163   LLVMVAArg          = 49,
164   LLVMExtractElement = 50,
165   LLVMInsertElement  = 51,
166   LLVMShuffleVector  = 52,
167   LLVMExtractValue   = 53,
168   LLVMInsertValue    = 54,
169
170   /* Atomic operators */
171   LLVMFence          = 55,
172   LLVMAtomicCmpXchg  = 56,
173   LLVMAtomicRMW      = 57,
174
175   /* Exception Handling Operators */
176   LLVMResume         = 58,
177   LLVMLandingPad     = 59,
178   LLVMCleanupRet     = 61,
179   LLVMCatchRet       = 62,
180   LLVMCatchPad       = 63,
181   LLVMCleanupPad     = 64,
182   LLVMCatchSwitch    = 65
183 } LLVMOpcode;
184
185 typedef enum {
186   LLVMVoidTypeKind,        /**< type with no size */
187   LLVMHalfTypeKind,        /**< 16 bit floating point type */
188   LLVMFloatTypeKind,       /**< 32 bit floating point type */
189   LLVMDoubleTypeKind,      /**< 64 bit floating point type */
190   LLVMX86_FP80TypeKind,    /**< 80 bit floating point type (X87) */
191   LLVMFP128TypeKind,       /**< 128 bit floating point type (112-bit mantissa)*/
192   LLVMPPC_FP128TypeKind,   /**< 128 bit floating point type (two 64-bits) */
193   LLVMLabelTypeKind,       /**< Labels */
194   LLVMIntegerTypeKind,     /**< Arbitrary bit width integers */
195   LLVMFunctionTypeKind,    /**< Functions */
196   LLVMStructTypeKind,      /**< Structures */
197   LLVMArrayTypeKind,       /**< Arrays */
198   LLVMPointerTypeKind,     /**< Pointers */
199   LLVMVectorTypeKind,      /**< SIMD 'packed' format, or other vector type */
200   LLVMMetadataTypeKind,    /**< Metadata */
201   LLVMX86_MMXTypeKind,     /**< X86 MMX */
202   LLVMTokenTypeKind        /**< Tokens */
203 } LLVMTypeKind;
204
205 typedef enum {
206   LLVMExternalLinkage,    /**< Externally visible function */
207   LLVMAvailableExternallyLinkage,
208   LLVMLinkOnceAnyLinkage, /**< Keep one copy of function when linking (inline)*/
209   LLVMLinkOnceODRLinkage, /**< Same, but only replaced by something
210                             equivalent. */
211   LLVMLinkOnceODRAutoHideLinkage, /**< Obsolete */
212   LLVMWeakAnyLinkage,     /**< Keep one copy of function when linking (weak) */
213   LLVMWeakODRLinkage,     /**< Same, but only replaced by something
214                             equivalent. */
215   LLVMAppendingLinkage,   /**< Special purpose, only applies to global arrays */
216   LLVMInternalLinkage,    /**< Rename collisions when linking (static
217                                functions) */
218   LLVMPrivateLinkage,     /**< Like Internal, but omit from symbol table */
219   LLVMDLLImportLinkage,   /**< Obsolete */
220   LLVMDLLExportLinkage,   /**< Obsolete */
221   LLVMExternalWeakLinkage,/**< ExternalWeak linkage description */
222   LLVMGhostLinkage,       /**< Obsolete */
223   LLVMCommonLinkage,      /**< Tentative definitions */
224   LLVMLinkerPrivateLinkage, /**< Like Private, but linker removes. */
225   LLVMLinkerPrivateWeakLinkage /**< Like LinkerPrivate, but is weak. */
226 } LLVMLinkage;
227
228 typedef enum {
229   LLVMDefaultVisibility,  /**< The GV is visible */
230   LLVMHiddenVisibility,   /**< The GV is hidden */
231   LLVMProtectedVisibility /**< The GV is protected */
232 } LLVMVisibility;
233
234 typedef enum {
235   LLVMDefaultStorageClass   = 0,
236   LLVMDLLImportStorageClass = 1, /**< Function to be imported from DLL. */
237   LLVMDLLExportStorageClass = 2  /**< Function to be accessible from DLL. */
238 } LLVMDLLStorageClass;
239
240 typedef enum {
241   LLVMCCallConv           = 0,
242   LLVMFastCallConv        = 8,
243   LLVMColdCallConv        = 9,
244   LLVMWebKitJSCallConv    = 12,
245   LLVMAnyRegCallConv      = 13,
246   LLVMX86StdcallCallConv  = 64,
247   LLVMX86FastcallCallConv = 65
248 } LLVMCallConv;
249
250 typedef enum {
251   LLVMArgumentValueKind,
252   LLVMBasicBlockValueKind,
253   LLVMMemoryUseValueKind,
254   LLVMMemoryDefValueKind,
255   LLVMMemoryPhiValueKind,
256
257   LLVMFunctionValueKind,
258   LLVMGlobalAliasValueKind,
259   LLVMGlobalIFuncValueKind,
260   LLVMGlobalVariableValueKind,
261   LLVMBlockAddressValueKind,
262   LLVMConstantExprValueKind,
263   LLVMConstantArrayValueKind,
264   LLVMConstantStructValueKind,
265   LLVMConstantVectorValueKind,
266
267   LLVMUndefValueValueKind,
268   LLVMConstantAggregateZeroValueKind,
269   LLVMConstantDataArrayValueKind,
270   LLVMConstantDataVectorValueKind,
271   LLVMConstantIntValueKind,
272   LLVMConstantFPValueKind,
273   LLVMConstantPointerNullValueKind,
274   LLVMConstantTokenNoneValueKind,
275
276   LLVMMetadataAsValueValueKind,
277   LLVMInlineAsmValueKind,
278
279   LLVMInstructionValueKind,
280 } LLVMValueKind;
281
282 typedef enum {
283   LLVMIntEQ = 32, /**< equal */
284   LLVMIntNE,      /**< not equal */
285   LLVMIntUGT,     /**< unsigned greater than */
286   LLVMIntUGE,     /**< unsigned greater or equal */
287   LLVMIntULT,     /**< unsigned less than */
288   LLVMIntULE,     /**< unsigned less or equal */
289   LLVMIntSGT,     /**< signed greater than */
290   LLVMIntSGE,     /**< signed greater or equal */
291   LLVMIntSLT,     /**< signed less than */
292   LLVMIntSLE      /**< signed less or equal */
293 } LLVMIntPredicate;
294
295 typedef enum {
296   LLVMRealPredicateFalse, /**< Always false (always folded) */
297   LLVMRealOEQ,            /**< True if ordered and equal */
298   LLVMRealOGT,            /**< True if ordered and greater than */
299   LLVMRealOGE,            /**< True if ordered and greater than or equal */
300   LLVMRealOLT,            /**< True if ordered and less than */
301   LLVMRealOLE,            /**< True if ordered and less than or equal */
302   LLVMRealONE,            /**< True if ordered and operands are unequal */
303   LLVMRealORD,            /**< True if ordered (no nans) */
304   LLVMRealUNO,            /**< True if unordered: isnan(X) | isnan(Y) */
305   LLVMRealUEQ,            /**< True if unordered or equal */
306   LLVMRealUGT,            /**< True if unordered or greater than */
307   LLVMRealUGE,            /**< True if unordered, greater than, or equal */
308   LLVMRealULT,            /**< True if unordered or less than */
309   LLVMRealULE,            /**< True if unordered, less than, or equal */
310   LLVMRealUNE,            /**< True if unordered or not equal */
311   LLVMRealPredicateTrue   /**< Always true (always folded) */
312 } LLVMRealPredicate;
313
314 typedef enum {
315   LLVMLandingPadCatch,    /**< A catch clause   */
316   LLVMLandingPadFilter    /**< A filter clause  */
317 } LLVMLandingPadClauseTy;
318
319 typedef enum {
320   LLVMNotThreadLocal = 0,
321   LLVMGeneralDynamicTLSModel,
322   LLVMLocalDynamicTLSModel,
323   LLVMInitialExecTLSModel,
324   LLVMLocalExecTLSModel
325 } LLVMThreadLocalMode;
326
327 typedef enum {
328   LLVMAtomicOrderingNotAtomic = 0, /**< A load or store which is not atomic */
329   LLVMAtomicOrderingUnordered = 1, /**< Lowest level of atomicity, guarantees
330                                      somewhat sane results, lock free. */
331   LLVMAtomicOrderingMonotonic = 2, /**< guarantees that if you take all the
332                                      operations affecting a specific address,
333                                      a consistent ordering exists */
334   LLVMAtomicOrderingAcquire = 4, /**< Acquire provides a barrier of the sort
335                                    necessary to acquire a lock to access other
336                                    memory with normal loads and stores. */
337   LLVMAtomicOrderingRelease = 5, /**< Release is similar to Acquire, but with
338                                    a barrier of the sort necessary to release
339                                    a lock. */
340   LLVMAtomicOrderingAcquireRelease = 6, /**< provides both an Acquire and a
341                                           Release barrier (for fences and
342                                           operations which both read and write
343                                            memory). */
344   LLVMAtomicOrderingSequentiallyConsistent = 7 /**< provides Acquire semantics
345                                                  for loads and Release
346                                                  semantics for stores.
347                                                  Additionally, it guarantees
348                                                  that a total ordering exists
349                                                  between all
350                                                  SequentiallyConsistent
351                                                  operations. */
352 } LLVMAtomicOrdering;
353
354 typedef enum {
355     LLVMAtomicRMWBinOpXchg, /**< Set the new value and return the one old */
356     LLVMAtomicRMWBinOpAdd, /**< Add a value and return the old one */
357     LLVMAtomicRMWBinOpSub, /**< Subtract a value and return the old one */
358     LLVMAtomicRMWBinOpAnd, /**< And a value and return the old one */
359     LLVMAtomicRMWBinOpNand, /**< Not-And a value and return the old one */
360     LLVMAtomicRMWBinOpOr, /**< OR a value and return the old one */
361     LLVMAtomicRMWBinOpXor, /**< Xor a value and return the old one */
362     LLVMAtomicRMWBinOpMax, /**< Sets the value if it's greater than the
363                              original using a signed comparison and return
364                              the old one */
365     LLVMAtomicRMWBinOpMin, /**< Sets the value if it's Smaller than the
366                              original using a signed comparison and return
367                              the old one */
368     LLVMAtomicRMWBinOpUMax, /**< Sets the value if it's greater than the
369                              original using an unsigned comparison and return
370                              the old one */
371     LLVMAtomicRMWBinOpUMin /**< Sets the value if it's greater than the
372                              original using an unsigned comparison  and return
373                              the old one */
374 } LLVMAtomicRMWBinOp;
375
376 typedef enum {
377     LLVMDSError,
378     LLVMDSWarning,
379     LLVMDSRemark,
380     LLVMDSNote
381 } LLVMDiagnosticSeverity;
382
383 /**
384  * Attribute index are either LLVMAttributeReturnIndex,
385  * LLVMAttributeFunctionIndex or a parameter number from 1 to N.
386  */
387 enum {
388   LLVMAttributeReturnIndex = 0U,
389   // ISO C restricts enumerator values to range of 'int'
390   // (4294967295 is too large)
391   // LLVMAttributeFunctionIndex = ~0U,
392   LLVMAttributeFunctionIndex = -1,
393 };
394
395 typedef unsigned LLVMAttributeIndex;
396
397 /**
398  * @}
399  */
400
401 void LLVMInitializeCore(LLVMPassRegistryRef R);
402
403 /** Deallocate and destroy all ManagedStatic variables.
404     @see llvm::llvm_shutdown
405     @see ManagedStatic */
406 void LLVMShutdown(void);
407
408 /*===-- Error handling ----------------------------------------------------===*/
409
410 char *LLVMCreateMessage(const char *Message);
411 void LLVMDisposeMessage(char *Message);
412
413 /**
414  * @defgroup LLVMCCoreContext Contexts
415  *
416  * Contexts are execution states for the core LLVM IR system.
417  *
418  * Most types are tied to a context instance. Multiple contexts can
419  * exist simultaneously. A single context is not thread safe. However,
420  * different contexts can execute on different threads simultaneously.
421  *
422  * @{
423  */
424
425 typedef void (*LLVMDiagnosticHandler)(LLVMDiagnosticInfoRef, void *);
426 typedef void (*LLVMYieldCallback)(LLVMContextRef, void *);
427
428 /**
429  * Create a new context.
430  *
431  * Every call to this function should be paired with a call to
432  * LLVMContextDispose() or the context will leak memory.
433  */
434 LLVMContextRef LLVMContextCreate(void);
435
436 /**
437  * Obtain the global context instance.
438  */
439 LLVMContextRef LLVMGetGlobalContext(void);
440
441 /**
442  * Set the diagnostic handler for this context.
443  */
444 void LLVMContextSetDiagnosticHandler(LLVMContextRef C,
445                                      LLVMDiagnosticHandler Handler,
446                                      void *DiagnosticContext);
447
448 /**
449  * Get the diagnostic handler of this context.
450  */
451 LLVMDiagnosticHandler LLVMContextGetDiagnosticHandler(LLVMContextRef C);
452
453 /**
454  * Get the diagnostic context of this context.
455  */
456 void *LLVMContextGetDiagnosticContext(LLVMContextRef C);
457
458 /**
459  * Set the yield callback function for this context.
460  *
461  * @see LLVMContext::setYieldCallback()
462  */
463 void LLVMContextSetYieldCallback(LLVMContextRef C, LLVMYieldCallback Callback,
464                                  void *OpaqueHandle);
465
466 /**
467  * Destroy a context instance.
468  *
469  * This should be called for every call to LLVMContextCreate() or memory
470  * will be leaked.
471  */
472 void LLVMContextDispose(LLVMContextRef C);
473
474 /**
475  * Return a string representation of the DiagnosticInfo. Use
476  * LLVMDisposeMessage to free the string.
477  *
478  * @see DiagnosticInfo::print()
479  */
480 char *LLVMGetDiagInfoDescription(LLVMDiagnosticInfoRef DI);
481
482 /**
483  * Return an enum LLVMDiagnosticSeverity.
484  *
485  * @see DiagnosticInfo::getSeverity()
486  */
487 LLVMDiagnosticSeverity LLVMGetDiagInfoSeverity(LLVMDiagnosticInfoRef DI);
488
489 unsigned LLVMGetMDKindIDInContext(LLVMContextRef C, const char *Name,
490                                   unsigned SLen);
491 unsigned LLVMGetMDKindID(const char *Name, unsigned SLen);
492
493 /**
494  * Return an unique id given the name of a enum attribute,
495  * or 0 if no attribute by that name exists.
496  *
497  * See http://llvm.org/docs/LangRef.html#parameter-attributes
498  * and http://llvm.org/docs/LangRef.html#function-attributes
499  * for the list of available attributes.
500  *
501  * NB: Attribute names and/or id are subject to change without
502  * going through the C API deprecation cycle.
503  */
504 unsigned LLVMGetEnumAttributeKindForName(const char *Name, size_t SLen);
505 unsigned LLVMGetLastEnumAttributeKind(void);
506
507 /**
508  * Create an enum attribute.
509  */
510 LLVMAttributeRef LLVMCreateEnumAttribute(LLVMContextRef C, unsigned KindID,
511                                          uint64_t Val);
512
513 /**
514  * Get the unique id corresponding to the enum attribute
515  * passed as argument.
516  */
517 unsigned LLVMGetEnumAttributeKind(LLVMAttributeRef A);
518
519 /**
520  * Get the enum attribute's value. 0 is returned if none exists.
521  */
522 uint64_t LLVMGetEnumAttributeValue(LLVMAttributeRef A);
523
524 /**
525  * Create a string attribute.
526  */
527 LLVMAttributeRef LLVMCreateStringAttribute(LLVMContextRef C,
528                                            const char *K, unsigned KLength,
529                                            const char *V, unsigned VLength);
530
531 /**
532  * Get the string attribute's kind.
533  */
534 const char *LLVMGetStringAttributeKind(LLVMAttributeRef A, unsigned *Length);
535
536 /**
537  * Get the string attribute's value.
538  */
539 const char *LLVMGetStringAttributeValue(LLVMAttributeRef A, unsigned *Length);
540
541 /**
542  * Check for the different types of attributes.
543  */
544 LLVMBool LLVMIsEnumAttribute(LLVMAttributeRef A);
545 LLVMBool LLVMIsStringAttribute(LLVMAttributeRef A);
546
547 /**
548  * @}
549  */
550
551 /**
552  * @defgroup LLVMCCoreModule Modules
553  *
554  * Modules represent the top-level structure in an LLVM program. An LLVM
555  * module is effectively a translation unit or a collection of
556  * translation units merged together.
557  *
558  * @{
559  */
560
561 /**
562  * Create a new, empty module in the global context.
563  *
564  * This is equivalent to calling LLVMModuleCreateWithNameInContext with
565  * LLVMGetGlobalContext() as the context parameter.
566  *
567  * Every invocation should be paired with LLVMDisposeModule() or memory
568  * will be leaked.
569  */
570 LLVMModuleRef LLVMModuleCreateWithName(const char *ModuleID);
571
572 /**
573  * Create a new, empty module in a specific context.
574  *
575  * Every invocation should be paired with LLVMDisposeModule() or memory
576  * will be leaked.
577  */
578 LLVMModuleRef LLVMModuleCreateWithNameInContext(const char *ModuleID,
579                                                 LLVMContextRef C);
580 /**
581  * Return an exact copy of the specified module.
582  */
583 LLVMModuleRef LLVMCloneModule(LLVMModuleRef M);
584
585 /**
586  * Destroy a module instance.
587  *
588  * This must be called for every created module or memory will be
589  * leaked.
590  */
591 void LLVMDisposeModule(LLVMModuleRef M);
592
593 /**
594  * Obtain the identifier of a module.
595  *
596  * @param M Module to obtain identifier of
597  * @param Len Out parameter which holds the length of the returned string.
598  * @return The identifier of M.
599  * @see Module::getModuleIdentifier()
600  */
601 const char *LLVMGetModuleIdentifier(LLVMModuleRef M, size_t *Len);
602
603 /**
604  * Set the identifier of a module to a string Ident with length Len.
605  *
606  * @param M The module to set identifier
607  * @param Ident The string to set M's identifier to
608  * @param Len Length of Ident
609  * @see Module::setModuleIdentifier()
610  */
611 void LLVMSetModuleIdentifier(LLVMModuleRef M, const char *Ident, size_t Len);
612
613 /**
614  * Obtain the data layout for a module.
615  *
616  * @see Module::getDataLayoutStr()
617  *
618  * LLVMGetDataLayout is DEPRECATED, as the name is not only incorrect,
619  * but match the name of another method on the module. Prefer the use
620  * of LLVMGetDataLayoutStr, which is not ambiguous.
621  */
622 const char *LLVMGetDataLayoutStr(LLVMModuleRef M);
623 const char *LLVMGetDataLayout(LLVMModuleRef M);
624
625 /**
626  * Set the data layout for a module.
627  *
628  * @see Module::setDataLayout()
629  */
630 void LLVMSetDataLayout(LLVMModuleRef M, const char *DataLayoutStr);
631
632 /**
633  * Obtain the target triple for a module.
634  *
635  * @see Module::getTargetTriple()
636  */
637 const char *LLVMGetTarget(LLVMModuleRef M);
638
639 /**
640  * Set the target triple for a module.
641  *
642  * @see Module::setTargetTriple()
643  */
644 void LLVMSetTarget(LLVMModuleRef M, const char *Triple);
645
646 /**
647  * Dump a representation of a module to stderr.
648  *
649  * @see Module::dump()
650  */
651 void LLVMDumpModule(LLVMModuleRef M);
652
653 /**
654  * Print a representation of a module to a file. The ErrorMessage needs to be
655  * disposed with LLVMDisposeMessage. Returns 0 on success, 1 otherwise.
656  *
657  * @see Module::print()
658  */
659 LLVMBool LLVMPrintModuleToFile(LLVMModuleRef M, const char *Filename,
660                                char **ErrorMessage);
661
662 /**
663  * Return a string representation of the module. Use
664  * LLVMDisposeMessage to free the string.
665  *
666  * @see Module::print()
667  */
668 char *LLVMPrintModuleToString(LLVMModuleRef M);
669
670 /**
671  * Set inline assembly for a module.
672  *
673  * @see Module::setModuleInlineAsm()
674  */
675 void LLVMSetModuleInlineAsm(LLVMModuleRef M, const char *Asm);
676
677 /**
678  * Obtain the context to which this module is associated.
679  *
680  * @see Module::getContext()
681  */
682 LLVMContextRef LLVMGetModuleContext(LLVMModuleRef M);
683
684 /**
685  * Obtain a Type from a module by its registered name.
686  */
687 LLVMTypeRef LLVMGetTypeByName(LLVMModuleRef M, const char *Name);
688
689 /**
690  * Obtain the number of operands for named metadata in a module.
691  *
692  * @see llvm::Module::getNamedMetadata()
693  */
694 unsigned LLVMGetNamedMetadataNumOperands(LLVMModuleRef M, const char *Name);
695
696 /**
697  * Obtain the named metadata operands for a module.
698  *
699  * The passed LLVMValueRef pointer should refer to an array of
700  * LLVMValueRef at least LLVMGetNamedMetadataNumOperands long. This
701  * array will be populated with the LLVMValueRef instances. Each
702  * instance corresponds to a llvm::MDNode.
703  *
704  * @see llvm::Module::getNamedMetadata()
705  * @see llvm::MDNode::getOperand()
706  */
707 void LLVMGetNamedMetadataOperands(LLVMModuleRef M, const char *Name,
708                                   LLVMValueRef *Dest);
709
710 /**
711  * Add an operand to named metadata.
712  *
713  * @see llvm::Module::getNamedMetadata()
714  * @see llvm::MDNode::addOperand()
715  */
716 void LLVMAddNamedMetadataOperand(LLVMModuleRef M, const char *Name,
717                                  LLVMValueRef Val);
718
719 /**
720  * Add a function to a module under a specified name.
721  *
722  * @see llvm::Function::Create()
723  */
724 LLVMValueRef LLVMAddFunction(LLVMModuleRef M, const char *Name,
725                              LLVMTypeRef FunctionTy);
726
727 /**
728  * Obtain a Function value from a Module by its name.
729  *
730  * The returned value corresponds to a llvm::Function value.
731  *
732  * @see llvm::Module::getFunction()
733  */
734 LLVMValueRef LLVMGetNamedFunction(LLVMModuleRef M, const char *Name);
735
736 /**
737  * Obtain an iterator to the first Function in a Module.
738  *
739  * @see llvm::Module::begin()
740  */
741 LLVMValueRef LLVMGetFirstFunction(LLVMModuleRef M);
742
743 /**
744  * Obtain an iterator to the last Function in a Module.
745  *
746  * @see llvm::Module::end()
747  */
748 LLVMValueRef LLVMGetLastFunction(LLVMModuleRef M);
749
750 /**
751  * Advance a Function iterator to the next Function.
752  *
753  * Returns NULL if the iterator was already at the end and there are no more
754  * functions.
755  */
756 LLVMValueRef LLVMGetNextFunction(LLVMValueRef Fn);
757
758 /**
759  * Decrement a Function iterator to the previous Function.
760  *
761  * Returns NULL if the iterator was already at the beginning and there are
762  * no previous functions.
763  */
764 LLVMValueRef LLVMGetPreviousFunction(LLVMValueRef Fn);
765
766 /**
767  * @}
768  */
769
770 /**
771  * @defgroup LLVMCCoreType Types
772  *
773  * Types represent the type of a value.
774  *
775  * Types are associated with a context instance. The context internally
776  * deduplicates types so there is only 1 instance of a specific type
777  * alive at a time. In other words, a unique type is shared among all
778  * consumers within a context.
779  *
780  * A Type in the C API corresponds to llvm::Type.
781  *
782  * Types have the following hierarchy:
783  *
784  *   types:
785  *     integer type
786  *     real type
787  *     function type
788  *     sequence types:
789  *       array type
790  *       pointer type
791  *       vector type
792  *     void type
793  *     label type
794  *     opaque type
795  *
796  * @{
797  */
798
799 /**
800  * Obtain the enumerated type of a Type instance.
801  *
802  * @see llvm::Type:getTypeID()
803  */
804 LLVMTypeKind LLVMGetTypeKind(LLVMTypeRef Ty);
805
806 /**
807  * Whether the type has a known size.
808  *
809  * Things that don't have a size are abstract types, labels, and void.a
810  *
811  * @see llvm::Type::isSized()
812  */
813 LLVMBool LLVMTypeIsSized(LLVMTypeRef Ty);
814
815 /**
816  * Obtain the context to which this type instance is associated.
817  *
818  * @see llvm::Type::getContext()
819  */
820 LLVMContextRef LLVMGetTypeContext(LLVMTypeRef Ty);
821
822 /**
823  * Dump a representation of a type to stderr.
824  *
825  * @see llvm::Type::dump()
826  */
827 void LLVMDumpType(LLVMTypeRef Val);
828
829 /**
830  * Return a string representation of the type. Use
831  * LLVMDisposeMessage to free the string.
832  *
833  * @see llvm::Type::print()
834  */
835 char *LLVMPrintTypeToString(LLVMTypeRef Val);
836
837 /**
838  * @defgroup LLVMCCoreTypeInt Integer Types
839  *
840  * Functions in this section operate on integer types.
841  *
842  * @{
843  */
844
845 /**
846  * Obtain an integer type from a context with specified bit width.
847  */
848 LLVMTypeRef LLVMInt1TypeInContext(LLVMContextRef C);
849 LLVMTypeRef LLVMInt8TypeInContext(LLVMContextRef C);
850 LLVMTypeRef LLVMInt16TypeInContext(LLVMContextRef C);
851 LLVMTypeRef LLVMInt32TypeInContext(LLVMContextRef C);
852 LLVMTypeRef LLVMInt64TypeInContext(LLVMContextRef C);
853 LLVMTypeRef LLVMInt128TypeInContext(LLVMContextRef C);
854 LLVMTypeRef LLVMIntTypeInContext(LLVMContextRef C, unsigned NumBits);
855
856 /**
857  * Obtain an integer type from the global context with a specified bit
858  * width.
859  */
860 LLVMTypeRef LLVMInt1Type(void);
861 LLVMTypeRef LLVMInt8Type(void);
862 LLVMTypeRef LLVMInt16Type(void);
863 LLVMTypeRef LLVMInt32Type(void);
864 LLVMTypeRef LLVMInt64Type(void);
865 LLVMTypeRef LLVMInt128Type(void);
866 LLVMTypeRef LLVMIntType(unsigned NumBits);
867 unsigned LLVMGetIntTypeWidth(LLVMTypeRef IntegerTy);
868
869 /**
870  * @}
871  */
872
873 /**
874  * @defgroup LLVMCCoreTypeFloat Floating Point Types
875  *
876  * @{
877  */
878
879 /**
880  * Obtain a 16-bit floating point type from a context.
881  */
882 LLVMTypeRef LLVMHalfTypeInContext(LLVMContextRef C);
883
884 /**
885  * Obtain a 32-bit floating point type from a context.
886  */
887 LLVMTypeRef LLVMFloatTypeInContext(LLVMContextRef C);
888
889 /**
890  * Obtain a 64-bit floating point type from a context.
891  */
892 LLVMTypeRef LLVMDoubleTypeInContext(LLVMContextRef C);
893
894 /**
895  * Obtain a 80-bit floating point type (X87) from a context.
896  */
897 LLVMTypeRef LLVMX86FP80TypeInContext(LLVMContextRef C);
898
899 /**
900  * Obtain a 128-bit floating point type (112-bit mantissa) from a
901  * context.
902  */
903 LLVMTypeRef LLVMFP128TypeInContext(LLVMContextRef C);
904
905 /**
906  * Obtain a 128-bit floating point type (two 64-bits) from a context.
907  */
908 LLVMTypeRef LLVMPPCFP128TypeInContext(LLVMContextRef C);
909
910 /**
911  * Obtain a floating point type from the global context.
912  *
913  * These map to the functions in this group of the same name.
914  */
915 LLVMTypeRef LLVMHalfType(void);
916 LLVMTypeRef LLVMFloatType(void);
917 LLVMTypeRef LLVMDoubleType(void);
918 LLVMTypeRef LLVMX86FP80Type(void);
919 LLVMTypeRef LLVMFP128Type(void);
920 LLVMTypeRef LLVMPPCFP128Type(void);
921
922 /**
923  * @}
924  */
925
926 /**
927  * @defgroup LLVMCCoreTypeFunction Function Types
928  *
929  * @{
930  */
931
932 /**
933  * Obtain a function type consisting of a specified signature.
934  *
935  * The function is defined as a tuple of a return Type, a list of
936  * parameter types, and whether the function is variadic.
937  */
938 LLVMTypeRef LLVMFunctionType(LLVMTypeRef ReturnType,
939                              LLVMTypeRef *ParamTypes, unsigned ParamCount,
940                              LLVMBool IsVarArg);
941
942 /**
943  * Returns whether a function type is variadic.
944  */
945 LLVMBool LLVMIsFunctionVarArg(LLVMTypeRef FunctionTy);
946
947 /**
948  * Obtain the Type this function Type returns.
949  */
950 LLVMTypeRef LLVMGetReturnType(LLVMTypeRef FunctionTy);
951
952 /**
953  * Obtain the number of parameters this function accepts.
954  */
955 unsigned LLVMCountParamTypes(LLVMTypeRef FunctionTy);
956
957 /**
958  * Obtain the types of a function's parameters.
959  *
960  * The Dest parameter should point to a pre-allocated array of
961  * LLVMTypeRef at least LLVMCountParamTypes() large. On return, the
962  * first LLVMCountParamTypes() entries in the array will be populated
963  * with LLVMTypeRef instances.
964  *
965  * @param FunctionTy The function type to operate on.
966  * @param Dest Memory address of an array to be filled with result.
967  */
968 void LLVMGetParamTypes(LLVMTypeRef FunctionTy, LLVMTypeRef *Dest);
969
970 /**
971  * @}
972  */
973
974 /**
975  * @defgroup LLVMCCoreTypeStruct Structure Types
976  *
977  * These functions relate to LLVMTypeRef instances.
978  *
979  * @see llvm::StructType
980  *
981  * @{
982  */
983
984 /**
985  * Create a new structure type in a context.
986  *
987  * A structure is specified by a list of inner elements/types and
988  * whether these can be packed together.
989  *
990  * @see llvm::StructType::create()
991  */
992 LLVMTypeRef LLVMStructTypeInContext(LLVMContextRef C, LLVMTypeRef *ElementTypes,
993                                     unsigned ElementCount, LLVMBool Packed);
994
995 /**
996  * Create a new structure type in the global context.
997  *
998  * @see llvm::StructType::create()
999  */
1000 LLVMTypeRef LLVMStructType(LLVMTypeRef *ElementTypes, unsigned ElementCount,
1001                            LLVMBool Packed);
1002
1003 /**
1004  * Create an empty structure in a context having a specified name.
1005  *
1006  * @see llvm::StructType::create()
1007  */
1008 LLVMTypeRef LLVMStructCreateNamed(LLVMContextRef C, const char *Name);
1009
1010 /**
1011  * Obtain the name of a structure.
1012  *
1013  * @see llvm::StructType::getName()
1014  */
1015 const char *LLVMGetStructName(LLVMTypeRef Ty);
1016
1017 /**
1018  * Set the contents of a structure type.
1019  *
1020  * @see llvm::StructType::setBody()
1021  */
1022 void LLVMStructSetBody(LLVMTypeRef StructTy, LLVMTypeRef *ElementTypes,
1023                        unsigned ElementCount, LLVMBool Packed);
1024
1025 /**
1026  * Get the number of elements defined inside the structure.
1027  *
1028  * @see llvm::StructType::getNumElements()
1029  */
1030 unsigned LLVMCountStructElementTypes(LLVMTypeRef StructTy);
1031
1032 /**
1033  * Get the elements within a structure.
1034  *
1035  * The function is passed the address of a pre-allocated array of
1036  * LLVMTypeRef at least LLVMCountStructElementTypes() long. After
1037  * invocation, this array will be populated with the structure's
1038  * elements. The objects in the destination array will have a lifetime
1039  * of the structure type itself, which is the lifetime of the context it
1040  * is contained in.
1041  */
1042 void LLVMGetStructElementTypes(LLVMTypeRef StructTy, LLVMTypeRef *Dest);
1043
1044 /**
1045  * Get the type of the element at a given index in the structure.
1046  *
1047  * @see llvm::StructType::getTypeAtIndex()
1048  */
1049 LLVMTypeRef LLVMStructGetTypeAtIndex(LLVMTypeRef StructTy, unsigned i);
1050
1051 /**
1052  * Determine whether a structure is packed.
1053  *
1054  * @see llvm::StructType::isPacked()
1055  */
1056 LLVMBool LLVMIsPackedStruct(LLVMTypeRef StructTy);
1057
1058 /**
1059  * Determine whether a structure is opaque.
1060  *
1061  * @see llvm::StructType::isOpaque()
1062  */
1063 LLVMBool LLVMIsOpaqueStruct(LLVMTypeRef StructTy);
1064
1065 /**
1066  * @}
1067  */
1068
1069 /**
1070  * @defgroup LLVMCCoreTypeSequential Sequential Types
1071  *
1072  * Sequential types represents "arrays" of types. This is a super class
1073  * for array, vector, and pointer types.
1074  *
1075  * @{
1076  */
1077
1078 /**
1079  * Obtain the type of elements within a sequential type.
1080  *
1081  * This works on array, vector, and pointer types.
1082  *
1083  * @see llvm::SequentialType::getElementType()
1084  */
1085 LLVMTypeRef LLVMGetElementType(LLVMTypeRef Ty);
1086
1087 /**
1088  * Create a fixed size array type that refers to a specific type.
1089  *
1090  * The created type will exist in the context that its element type
1091  * exists in.
1092  *
1093  * @see llvm::ArrayType::get()
1094  */
1095 LLVMTypeRef LLVMArrayType(LLVMTypeRef ElementType, unsigned ElementCount);
1096
1097 /**
1098  * Obtain the length of an array type.
1099  *
1100  * This only works on types that represent arrays.
1101  *
1102  * @see llvm::ArrayType::getNumElements()
1103  */
1104 unsigned LLVMGetArrayLength(LLVMTypeRef ArrayTy);
1105
1106 /**
1107  * Create a pointer type that points to a defined type.
1108  *
1109  * The created type will exist in the context that its pointee type
1110  * exists in.
1111  *
1112  * @see llvm::PointerType::get()
1113  */
1114 LLVMTypeRef LLVMPointerType(LLVMTypeRef ElementType, unsigned AddressSpace);
1115
1116 /**
1117  * Obtain the address space of a pointer type.
1118  *
1119  * This only works on types that represent pointers.
1120  *
1121  * @see llvm::PointerType::getAddressSpace()
1122  */
1123 unsigned LLVMGetPointerAddressSpace(LLVMTypeRef PointerTy);
1124
1125 /**
1126  * Create a vector type that contains a defined type and has a specific
1127  * number of elements.
1128  *
1129  * The created type will exist in the context thats its element type
1130  * exists in.
1131  *
1132  * @see llvm::VectorType::get()
1133  */
1134 LLVMTypeRef LLVMVectorType(LLVMTypeRef ElementType, unsigned ElementCount);
1135
1136 /**
1137  * Obtain the number of elements in a vector type.
1138  *
1139  * This only works on types that represent vectors.
1140  *
1141  * @see llvm::VectorType::getNumElements()
1142  */
1143 unsigned LLVMGetVectorSize(LLVMTypeRef VectorTy);
1144
1145 /**
1146  * @}
1147  */
1148
1149 /**
1150  * @defgroup LLVMCCoreTypeOther Other Types
1151  *
1152  * @{
1153  */
1154
1155 /**
1156  * Create a void type in a context.
1157  */
1158 LLVMTypeRef LLVMVoidTypeInContext(LLVMContextRef C);
1159
1160 /**
1161  * Create a label type in a context.
1162  */
1163 LLVMTypeRef LLVMLabelTypeInContext(LLVMContextRef C);
1164
1165 /**
1166  * Create a X86 MMX type in a context.
1167  */
1168 LLVMTypeRef LLVMX86MMXTypeInContext(LLVMContextRef C);
1169
1170 /**
1171  * These are similar to the above functions except they operate on the
1172  * global context.
1173  */
1174 LLVMTypeRef LLVMVoidType(void);
1175 LLVMTypeRef LLVMLabelType(void);
1176 LLVMTypeRef LLVMX86MMXType(void);
1177
1178 /**
1179  * @}
1180  */
1181
1182 /**
1183  * @}
1184  */
1185
1186 /**
1187  * @defgroup LLVMCCoreValues Values
1188  *
1189  * The bulk of LLVM's object model consists of values, which comprise a very
1190  * rich type hierarchy.
1191  *
1192  * LLVMValueRef essentially represents llvm::Value. There is a rich
1193  * hierarchy of classes within this type. Depending on the instance
1194  * obtained, not all APIs are available.
1195  *
1196  * Callers can determine the type of an LLVMValueRef by calling the
1197  * LLVMIsA* family of functions (e.g. LLVMIsAArgument()). These
1198  * functions are defined by a macro, so it isn't obvious which are
1199  * available by looking at the Doxygen source code. Instead, look at the
1200  * source definition of LLVM_FOR_EACH_VALUE_SUBCLASS and note the list
1201  * of value names given. These value names also correspond to classes in
1202  * the llvm::Value hierarchy.
1203  *
1204  * @{
1205  */
1206
1207 #define LLVM_FOR_EACH_VALUE_SUBCLASS(macro) \
1208   macro(Argument)                           \
1209   macro(BasicBlock)                         \
1210   macro(InlineAsm)                          \
1211   macro(User)                               \
1212     macro(Constant)                         \
1213       macro(BlockAddress)                   \
1214       macro(ConstantAggregateZero)          \
1215       macro(ConstantArray)                  \
1216       macro(ConstantDataSequential)         \
1217         macro(ConstantDataArray)            \
1218         macro(ConstantDataVector)           \
1219       macro(ConstantExpr)                   \
1220       macro(ConstantFP)                     \
1221       macro(ConstantInt)                    \
1222       macro(ConstantPointerNull)            \
1223       macro(ConstantStruct)                 \
1224       macro(ConstantTokenNone)              \
1225       macro(ConstantVector)                 \
1226       macro(GlobalValue)                    \
1227         macro(GlobalAlias)                  \
1228         macro(GlobalObject)                 \
1229           macro(Function)                   \
1230           macro(GlobalVariable)             \
1231       macro(UndefValue)                     \
1232     macro(Instruction)                      \
1233       macro(BinaryOperator)                 \
1234       macro(CallInst)                       \
1235         macro(IntrinsicInst)                \
1236           macro(DbgInfoIntrinsic)           \
1237             macro(DbgDeclareInst)           \
1238           macro(MemIntrinsic)               \
1239             macro(MemCpyInst)               \
1240             macro(MemMoveInst)              \
1241             macro(MemSetInst)               \
1242       macro(CmpInst)                        \
1243         macro(FCmpInst)                     \
1244         macro(ICmpInst)                     \
1245       macro(ExtractElementInst)             \
1246       macro(GetElementPtrInst)              \
1247       macro(InsertElementInst)              \
1248       macro(InsertValueInst)                \
1249       macro(LandingPadInst)                 \
1250       macro(PHINode)                        \
1251       macro(SelectInst)                     \
1252       macro(ShuffleVectorInst)              \
1253       macro(StoreInst)                      \
1254       macro(TerminatorInst)                 \
1255         macro(BranchInst)                   \
1256         macro(IndirectBrInst)               \
1257         macro(InvokeInst)                   \
1258         macro(ReturnInst)                   \
1259         macro(SwitchInst)                   \
1260         macro(UnreachableInst)              \
1261         macro(ResumeInst)                   \
1262         macro(CleanupReturnInst)            \
1263         macro(CatchReturnInst)              \
1264       macro(FuncletPadInst)                 \
1265         macro(CatchPadInst)                 \
1266         macro(CleanupPadInst)               \
1267       macro(UnaryInstruction)               \
1268         macro(AllocaInst)                   \
1269         macro(CastInst)                     \
1270           macro(AddrSpaceCastInst)          \
1271           macro(BitCastInst)                \
1272           macro(FPExtInst)                  \
1273           macro(FPToSIInst)                 \
1274           macro(FPToUIInst)                 \
1275           macro(FPTruncInst)                \
1276           macro(IntToPtrInst)               \
1277           macro(PtrToIntInst)               \
1278           macro(SExtInst)                   \
1279           macro(SIToFPInst)                 \
1280           macro(TruncInst)                  \
1281           macro(UIToFPInst)                 \
1282           macro(ZExtInst)                   \
1283         macro(ExtractValueInst)             \
1284         macro(LoadInst)                     \
1285         macro(VAArgInst)
1286
1287 /**
1288  * @defgroup LLVMCCoreValueGeneral General APIs
1289  *
1290  * Functions in this section work on all LLVMValueRef instances,
1291  * regardless of their sub-type. They correspond to functions available
1292  * on llvm::Value.
1293  *
1294  * @{
1295  */
1296
1297 /**
1298  * Obtain the type of a value.
1299  *
1300  * @see llvm::Value::getType()
1301  */
1302 LLVMTypeRef LLVMTypeOf(LLVMValueRef Val);
1303
1304 /**
1305  * Obtain the enumerated type of a Value instance.
1306  *
1307  * @see llvm::Value::getValueID()
1308  */
1309 LLVMValueKind LLVMGetValueKind(LLVMValueRef Val);
1310
1311 /**
1312  * Obtain the string name of a value.
1313  *
1314  * @see llvm::Value::getName()
1315  */
1316 const char *LLVMGetValueName(LLVMValueRef Val);
1317
1318 /**
1319  * Set the string name of a value.
1320  *
1321  * @see llvm::Value::setName()
1322  */
1323 void LLVMSetValueName(LLVMValueRef Val, const char *Name);
1324
1325 /**
1326  * Dump a representation of a value to stderr.
1327  *
1328  * @see llvm::Value::dump()
1329  */
1330 void LLVMDumpValue(LLVMValueRef Val);
1331
1332 /**
1333  * Return a string representation of the value. Use
1334  * LLVMDisposeMessage to free the string.
1335  *
1336  * @see llvm::Value::print()
1337  */
1338 char *LLVMPrintValueToString(LLVMValueRef Val);
1339
1340 /**
1341  * Replace all uses of a value with another one.
1342  *
1343  * @see llvm::Value::replaceAllUsesWith()
1344  */
1345 void LLVMReplaceAllUsesWith(LLVMValueRef OldVal, LLVMValueRef NewVal);
1346
1347 /**
1348  * Determine whether the specified value instance is constant.
1349  */
1350 LLVMBool LLVMIsConstant(LLVMValueRef Val);
1351
1352 /**
1353  * Determine whether a value instance is undefined.
1354  */
1355 LLVMBool LLVMIsUndef(LLVMValueRef Val);
1356
1357 /**
1358  * Convert value instances between types.
1359  *
1360  * Internally, an LLVMValueRef is "pinned" to a specific type. This
1361  * series of functions allows you to cast an instance to a specific
1362  * type.
1363  *
1364  * If the cast is not valid for the specified type, NULL is returned.
1365  *
1366  * @see llvm::dyn_cast_or_null<>
1367  */
1368 #define LLVM_DECLARE_VALUE_CAST(name) \
1369   LLVMValueRef LLVMIsA##name(LLVMValueRef Val);
1370 LLVM_FOR_EACH_VALUE_SUBCLASS(LLVM_DECLARE_VALUE_CAST)
1371
1372 LLVMValueRef LLVMIsAMDNode(LLVMValueRef Val);
1373 LLVMValueRef LLVMIsAMDString(LLVMValueRef Val);
1374
1375 /**
1376  * @}
1377  */
1378
1379 /**
1380  * @defgroup LLVMCCoreValueUses Usage
1381  *
1382  * This module defines functions that allow you to inspect the uses of a
1383  * LLVMValueRef.
1384  *
1385  * It is possible to obtain an LLVMUseRef for any LLVMValueRef instance.
1386  * Each LLVMUseRef (which corresponds to a llvm::Use instance) holds a
1387  * llvm::User and llvm::Value.
1388  *
1389  * @{
1390  */
1391
1392 /**
1393  * Obtain the first use of a value.
1394  *
1395  * Uses are obtained in an iterator fashion. First, call this function
1396  * to obtain a reference to the first use. Then, call LLVMGetNextUse()
1397  * on that instance and all subsequently obtained instances until
1398  * LLVMGetNextUse() returns NULL.
1399  *
1400  * @see llvm::Value::use_begin()
1401  */
1402 LLVMUseRef LLVMGetFirstUse(LLVMValueRef Val);
1403
1404 /**
1405  * Obtain the next use of a value.
1406  *
1407  * This effectively advances the iterator. It returns NULL if you are on
1408  * the final use and no more are available.
1409  */
1410 LLVMUseRef LLVMGetNextUse(LLVMUseRef U);
1411
1412 /**
1413  * Obtain the user value for a user.
1414  *
1415  * The returned value corresponds to a llvm::User type.
1416  *
1417  * @see llvm::Use::getUser()
1418  */
1419 LLVMValueRef LLVMGetUser(LLVMUseRef U);
1420
1421 /**
1422  * Obtain the value this use corresponds to.
1423  *
1424  * @see llvm::Use::get().
1425  */
1426 LLVMValueRef LLVMGetUsedValue(LLVMUseRef U);
1427
1428 /**
1429  * @}
1430  */
1431
1432 /**
1433  * @defgroup LLVMCCoreValueUser User value
1434  *
1435  * Function in this group pertain to LLVMValueRef instances that descent
1436  * from llvm::User. This includes constants, instructions, and
1437  * operators.
1438  *
1439  * @{
1440  */
1441
1442 /**
1443  * Obtain an operand at a specific index in a llvm::User value.
1444  *
1445  * @see llvm::User::getOperand()
1446  */
1447 LLVMValueRef LLVMGetOperand(LLVMValueRef Val, unsigned Index);
1448
1449 /**
1450  * Obtain the use of an operand at a specific index in a llvm::User value.
1451  *
1452  * @see llvm::User::getOperandUse()
1453  */
1454 LLVMUseRef LLVMGetOperandUse(LLVMValueRef Val, unsigned Index);
1455
1456 /**
1457  * Set an operand at a specific index in a llvm::User value.
1458  *
1459  * @see llvm::User::setOperand()
1460  */
1461 void LLVMSetOperand(LLVMValueRef User, unsigned Index, LLVMValueRef Val);
1462
1463 /**
1464  * Obtain the number of operands in a llvm::User value.
1465  *
1466  * @see llvm::User::getNumOperands()
1467  */
1468 int LLVMGetNumOperands(LLVMValueRef Val);
1469
1470 /**
1471  * @}
1472  */
1473
1474 /**
1475  * @defgroup LLVMCCoreValueConstant Constants
1476  *
1477  * This section contains APIs for interacting with LLVMValueRef that
1478  * correspond to llvm::Constant instances.
1479  *
1480  * These functions will work for any LLVMValueRef in the llvm::Constant
1481  * class hierarchy.
1482  *
1483  * @{
1484  */
1485
1486 /**
1487  * Obtain a constant value referring to the null instance of a type.
1488  *
1489  * @see llvm::Constant::getNullValue()
1490  */
1491 LLVMValueRef LLVMConstNull(LLVMTypeRef Ty); /* all zeroes */
1492
1493 /**
1494  * Obtain a constant value referring to the instance of a type
1495  * consisting of all ones.
1496  *
1497  * This is only valid for integer types.
1498  *
1499  * @see llvm::Constant::getAllOnesValue()
1500  */
1501 LLVMValueRef LLVMConstAllOnes(LLVMTypeRef Ty);
1502
1503 /**
1504  * Obtain a constant value referring to an undefined value of a type.
1505  *
1506  * @see llvm::UndefValue::get()
1507  */
1508 LLVMValueRef LLVMGetUndef(LLVMTypeRef Ty);
1509
1510 /**
1511  * Determine whether a value instance is null.
1512  *
1513  * @see llvm::Constant::isNullValue()
1514  */
1515 LLVMBool LLVMIsNull(LLVMValueRef Val);
1516
1517 /**
1518  * Obtain a constant that is a constant pointer pointing to NULL for a
1519  * specified type.
1520  */
1521 LLVMValueRef LLVMConstPointerNull(LLVMTypeRef Ty);
1522
1523 /**
1524  * @defgroup LLVMCCoreValueConstantScalar Scalar constants
1525  *
1526  * Functions in this group model LLVMValueRef instances that correspond
1527  * to constants referring to scalar types.
1528  *
1529  * For integer types, the LLVMTypeRef parameter should correspond to a
1530  * llvm::IntegerType instance and the returned LLVMValueRef will
1531  * correspond to a llvm::ConstantInt.
1532  *
1533  * For floating point types, the LLVMTypeRef returned corresponds to a
1534  * llvm::ConstantFP.
1535  *
1536  * @{
1537  */
1538
1539 /**
1540  * Obtain a constant value for an integer type.
1541  *
1542  * The returned value corresponds to a llvm::ConstantInt.
1543  *
1544  * @see llvm::ConstantInt::get()
1545  *
1546  * @param IntTy Integer type to obtain value of.
1547  * @param N The value the returned instance should refer to.
1548  * @param SignExtend Whether to sign extend the produced value.
1549  */
1550 LLVMValueRef LLVMConstInt(LLVMTypeRef IntTy, unsigned long long N,
1551                           LLVMBool SignExtend);
1552
1553 /**
1554  * Obtain a constant value for an integer of arbitrary precision.
1555  *
1556  * @see llvm::ConstantInt::get()
1557  */
1558 LLVMValueRef LLVMConstIntOfArbitraryPrecision(LLVMTypeRef IntTy,
1559                                               unsigned NumWords,
1560                                               const uint64_t Words[]);
1561
1562 /**
1563  * Obtain a constant value for an integer parsed from a string.
1564  *
1565  * A similar API, LLVMConstIntOfStringAndSize is also available. If the
1566  * string's length is available, it is preferred to call that function
1567  * instead.
1568  *
1569  * @see llvm::ConstantInt::get()
1570  */
1571 LLVMValueRef LLVMConstIntOfString(LLVMTypeRef IntTy, const char *Text,
1572                                   uint8_t Radix);
1573
1574 /**
1575  * Obtain a constant value for an integer parsed from a string with
1576  * specified length.
1577  *
1578  * @see llvm::ConstantInt::get()
1579  */
1580 LLVMValueRef LLVMConstIntOfStringAndSize(LLVMTypeRef IntTy, const char *Text,
1581                                          unsigned SLen, uint8_t Radix);
1582
1583 /**
1584  * Obtain a constant value referring to a double floating point value.
1585  */
1586 LLVMValueRef LLVMConstReal(LLVMTypeRef RealTy, double N);
1587
1588 /**
1589  * Obtain a constant for a floating point value parsed from a string.
1590  *
1591  * A similar API, LLVMConstRealOfStringAndSize is also available. It
1592  * should be used if the input string's length is known.
1593  */
1594 LLVMValueRef LLVMConstRealOfString(LLVMTypeRef RealTy, const char *Text);
1595
1596 /**
1597  * Obtain a constant for a floating point value parsed from a string.
1598  */
1599 LLVMValueRef LLVMConstRealOfStringAndSize(LLVMTypeRef RealTy, const char *Text,
1600                                           unsigned SLen);
1601
1602 /**
1603  * Obtain the zero extended value for an integer constant value.
1604  *
1605  * @see llvm::ConstantInt::getZExtValue()
1606  */
1607 unsigned long long LLVMConstIntGetZExtValue(LLVMValueRef ConstantVal);
1608
1609 /**
1610  * Obtain the sign extended value for an integer constant value.
1611  *
1612  * @see llvm::ConstantInt::getSExtValue()
1613  */
1614 long long LLVMConstIntGetSExtValue(LLVMValueRef ConstantVal);
1615
1616 /**
1617  * Obtain the double value for an floating point constant value.
1618  * losesInfo indicates if some precision was lost in the conversion.
1619  *
1620  * @see llvm::ConstantFP::getDoubleValue
1621  */
1622 double LLVMConstRealGetDouble(LLVMValueRef ConstantVal, LLVMBool *losesInfo);
1623
1624 /**
1625  * @}
1626  */
1627
1628 /**
1629  * @defgroup LLVMCCoreValueConstantComposite Composite Constants
1630  *
1631  * Functions in this group operate on composite constants.
1632  *
1633  * @{
1634  */
1635
1636 /**
1637  * Create a ConstantDataSequential and initialize it with a string.
1638  *
1639  * @see llvm::ConstantDataArray::getString()
1640  */
1641 LLVMValueRef LLVMConstStringInContext(LLVMContextRef C, const char *Str,
1642                                       unsigned Length, LLVMBool DontNullTerminate);
1643
1644 /**
1645  * Create a ConstantDataSequential with string content in the global context.
1646  *
1647  * This is the same as LLVMConstStringInContext except it operates on the
1648  * global context.
1649  *
1650  * @see LLVMConstStringInContext()
1651  * @see llvm::ConstantDataArray::getString()
1652  */
1653 LLVMValueRef LLVMConstString(const char *Str, unsigned Length,
1654                              LLVMBool DontNullTerminate);
1655
1656 /**
1657  * Returns true if the specified constant is an array of i8.
1658  *
1659  * @see ConstantDataSequential::getAsString()
1660  */
1661 LLVMBool LLVMIsConstantString(LLVMValueRef c);
1662
1663 /**
1664  * Get the given constant data sequential as a string.
1665  *
1666  * @see ConstantDataSequential::getAsString()
1667  */
1668 const char *LLVMGetAsString(LLVMValueRef c, size_t *Length);
1669
1670 /**
1671  * Create an anonymous ConstantStruct with the specified values.
1672  *
1673  * @see llvm::ConstantStruct::getAnon()
1674  */
1675 LLVMValueRef LLVMConstStructInContext(LLVMContextRef C,
1676                                       LLVMValueRef *ConstantVals,
1677                                       unsigned Count, LLVMBool Packed);
1678
1679 /**
1680  * Create a ConstantStruct in the global Context.
1681  *
1682  * This is the same as LLVMConstStructInContext except it operates on the
1683  * global Context.
1684  *
1685  * @see LLVMConstStructInContext()
1686  */
1687 LLVMValueRef LLVMConstStruct(LLVMValueRef *ConstantVals, unsigned Count,
1688                              LLVMBool Packed);
1689
1690 /**
1691  * Create a ConstantArray from values.
1692  *
1693  * @see llvm::ConstantArray::get()
1694  */
1695 LLVMValueRef LLVMConstArray(LLVMTypeRef ElementTy,
1696                             LLVMValueRef *ConstantVals, unsigned Length);
1697
1698 /**
1699  * Create a non-anonymous ConstantStruct from values.
1700  *
1701  * @see llvm::ConstantStruct::get()
1702  */
1703 LLVMValueRef LLVMConstNamedStruct(LLVMTypeRef StructTy,
1704                                   LLVMValueRef *ConstantVals,
1705                                   unsigned Count);
1706
1707 /**
1708  * Get an element at specified index as a constant.
1709  *
1710  * @see ConstantDataSequential::getElementAsConstant()
1711  */
1712 LLVMValueRef LLVMGetElementAsConstant(LLVMValueRef C, unsigned idx);
1713
1714 /**
1715  * Create a ConstantVector from values.
1716  *
1717  * @see llvm::ConstantVector::get()
1718  */
1719 LLVMValueRef LLVMConstVector(LLVMValueRef *ScalarConstantVals, unsigned Size);
1720
1721 /**
1722  * @}
1723  */
1724
1725 /**
1726  * @defgroup LLVMCCoreValueConstantExpressions Constant Expressions
1727  *
1728  * Functions in this group correspond to APIs on llvm::ConstantExpr.
1729  *
1730  * @see llvm::ConstantExpr.
1731  *
1732  * @{
1733  */
1734 LLVMOpcode LLVMGetConstOpcode(LLVMValueRef ConstantVal);
1735 LLVMValueRef LLVMAlignOf(LLVMTypeRef Ty);
1736 LLVMValueRef LLVMSizeOf(LLVMTypeRef Ty);
1737 LLVMValueRef LLVMConstNeg(LLVMValueRef ConstantVal);
1738 LLVMValueRef LLVMConstNSWNeg(LLVMValueRef ConstantVal);
1739 LLVMValueRef LLVMConstNUWNeg(LLVMValueRef ConstantVal);
1740 LLVMValueRef LLVMConstFNeg(LLVMValueRef ConstantVal);
1741 LLVMValueRef LLVMConstNot(LLVMValueRef ConstantVal);
1742 LLVMValueRef LLVMConstAdd(LLVMValueRef LHSConstant, LLVMValueRef RHSConstant);
1743 LLVMValueRef LLVMConstNSWAdd(LLVMValueRef LHSConstant, LLVMValueRef RHSConstant);
1744 LLVMValueRef LLVMConstNUWAdd(LLVMValueRef LHSConstant, LLVMValueRef RHSConstant);
1745 LLVMValueRef LLVMConstFAdd(LLVMValueRef LHSConstant, LLVMValueRef RHSConstant);
1746 LLVMValueRef LLVMConstSub(LLVMValueRef LHSConstant, LLVMValueRef RHSConstant);
1747 LLVMValueRef LLVMConstNSWSub(LLVMValueRef LHSConstant, LLVMValueRef RHSConstant);
1748 LLVMValueRef LLVMConstNUWSub(LLVMValueRef LHSConstant, LLVMValueRef RHSConstant);
1749 LLVMValueRef LLVMConstFSub(LLVMValueRef LHSConstant, LLVMValueRef RHSConstant);
1750 LLVMValueRef LLVMConstMul(LLVMValueRef LHSConstant, LLVMValueRef RHSConstant);
1751 LLVMValueRef LLVMConstNSWMul(LLVMValueRef LHSConstant, LLVMValueRef RHSConstant);
1752 LLVMValueRef LLVMConstNUWMul(LLVMValueRef LHSConstant, LLVMValueRef RHSConstant);
1753 LLVMValueRef LLVMConstFMul(LLVMValueRef LHSConstant, LLVMValueRef RHSConstant);
1754 LLVMValueRef LLVMConstUDiv(LLVMValueRef LHSConstant, LLVMValueRef RHSConstant);
1755 LLVMValueRef LLVMConstSDiv(LLVMValueRef LHSConstant, LLVMValueRef RHSConstant);
1756 LLVMValueRef LLVMConstExactSDiv(LLVMValueRef LHSConstant, LLVMValueRef RHSConstant);
1757 LLVMValueRef LLVMConstFDiv(LLVMValueRef LHSConstant, LLVMValueRef RHSConstant);
1758 LLVMValueRef LLVMConstURem(LLVMValueRef LHSConstant, LLVMValueRef RHSConstant);
1759 LLVMValueRef LLVMConstSRem(LLVMValueRef LHSConstant, LLVMValueRef RHSConstant);
1760 LLVMValueRef LLVMConstFRem(LLVMValueRef LHSConstant, LLVMValueRef RHSConstant);
1761 LLVMValueRef LLVMConstAnd(LLVMValueRef LHSConstant, LLVMValueRef RHSConstant);
1762 LLVMValueRef LLVMConstOr(LLVMValueRef LHSConstant, LLVMValueRef RHSConstant);
1763 LLVMValueRef LLVMConstXor(LLVMValueRef LHSConstant, LLVMValueRef RHSConstant);
1764 LLVMValueRef LLVMConstICmp(LLVMIntPredicate Predicate,
1765                            LLVMValueRef LHSConstant, LLVMValueRef RHSConstant);
1766 LLVMValueRef LLVMConstFCmp(LLVMRealPredicate Predicate,
1767                            LLVMValueRef LHSConstant, LLVMValueRef RHSConstant);
1768 LLVMValueRef LLVMConstShl(LLVMValueRef LHSConstant, LLVMValueRef RHSConstant);
1769 LLVMValueRef LLVMConstLShr(LLVMValueRef LHSConstant, LLVMValueRef RHSConstant);
1770 LLVMValueRef LLVMConstAShr(LLVMValueRef LHSConstant, LLVMValueRef RHSConstant);
1771 LLVMValueRef LLVMConstGEP(LLVMValueRef ConstantVal,
1772                           LLVMValueRef *ConstantIndices, unsigned NumIndices);
1773 LLVMValueRef LLVMConstInBoundsGEP(LLVMValueRef ConstantVal,
1774                                   LLVMValueRef *ConstantIndices,
1775                                   unsigned NumIndices);
1776 LLVMValueRef LLVMConstTrunc(LLVMValueRef ConstantVal, LLVMTypeRef ToType);
1777 LLVMValueRef LLVMConstSExt(LLVMValueRef ConstantVal, LLVMTypeRef ToType);
1778 LLVMValueRef LLVMConstZExt(LLVMValueRef ConstantVal, LLVMTypeRef ToType);
1779 LLVMValueRef LLVMConstFPTrunc(LLVMValueRef ConstantVal, LLVMTypeRef ToType);
1780 LLVMValueRef LLVMConstFPExt(LLVMValueRef ConstantVal, LLVMTypeRef ToType);
1781 LLVMValueRef LLVMConstUIToFP(LLVMValueRef ConstantVal, LLVMTypeRef ToType);
1782 LLVMValueRef LLVMConstSIToFP(LLVMValueRef ConstantVal, LLVMTypeRef ToType);
1783 LLVMValueRef LLVMConstFPToUI(LLVMValueRef ConstantVal, LLVMTypeRef ToType);
1784 LLVMValueRef LLVMConstFPToSI(LLVMValueRef ConstantVal, LLVMTypeRef ToType);
1785 LLVMValueRef LLVMConstPtrToInt(LLVMValueRef ConstantVal, LLVMTypeRef ToType);
1786 LLVMValueRef LLVMConstIntToPtr(LLVMValueRef ConstantVal, LLVMTypeRef ToType);
1787 LLVMValueRef LLVMConstBitCast(LLVMValueRef ConstantVal, LLVMTypeRef ToType);
1788 LLVMValueRef LLVMConstAddrSpaceCast(LLVMValueRef ConstantVal, LLVMTypeRef ToType);
1789 LLVMValueRef LLVMConstZExtOrBitCast(LLVMValueRef ConstantVal,
1790                                     LLVMTypeRef ToType);
1791 LLVMValueRef LLVMConstSExtOrBitCast(LLVMValueRef ConstantVal,
1792                                     LLVMTypeRef ToType);
1793 LLVMValueRef LLVMConstTruncOrBitCast(LLVMValueRef ConstantVal,
1794                                      LLVMTypeRef ToType);
1795 LLVMValueRef LLVMConstPointerCast(LLVMValueRef ConstantVal,
1796                                   LLVMTypeRef ToType);
1797 LLVMValueRef LLVMConstIntCast(LLVMValueRef ConstantVal, LLVMTypeRef ToType,
1798                               LLVMBool isSigned);
1799 LLVMValueRef LLVMConstFPCast(LLVMValueRef ConstantVal, LLVMTypeRef ToType);
1800 LLVMValueRef LLVMConstSelect(LLVMValueRef ConstantCondition,
1801                              LLVMValueRef ConstantIfTrue,
1802                              LLVMValueRef ConstantIfFalse);
1803 LLVMValueRef LLVMConstExtractElement(LLVMValueRef VectorConstant,
1804                                      LLVMValueRef IndexConstant);
1805 LLVMValueRef LLVMConstInsertElement(LLVMValueRef VectorConstant,
1806                                     LLVMValueRef ElementValueConstant,
1807                                     LLVMValueRef IndexConstant);
1808 LLVMValueRef LLVMConstShuffleVector(LLVMValueRef VectorAConstant,
1809                                     LLVMValueRef VectorBConstant,
1810                                     LLVMValueRef MaskConstant);
1811 LLVMValueRef LLVMConstExtractValue(LLVMValueRef AggConstant, unsigned *IdxList,
1812                                    unsigned NumIdx);
1813 LLVMValueRef LLVMConstInsertValue(LLVMValueRef AggConstant,
1814                                   LLVMValueRef ElementValueConstant,
1815                                   unsigned *IdxList, unsigned NumIdx);
1816 LLVMValueRef LLVMConstInlineAsm(LLVMTypeRef Ty,
1817                                 const char *AsmString, const char *Constraints,
1818                                 LLVMBool HasSideEffects, LLVMBool IsAlignStack);
1819 LLVMValueRef LLVMBlockAddress(LLVMValueRef F, LLVMBasicBlockRef BB);
1820
1821 /**
1822  * @}
1823  */
1824
1825 /**
1826  * @defgroup LLVMCCoreValueConstantGlobals Global Values
1827  *
1828  * This group contains functions that operate on global values. Functions in
1829  * this group relate to functions in the llvm::GlobalValue class tree.
1830  *
1831  * @see llvm::GlobalValue
1832  *
1833  * @{
1834  */
1835
1836 LLVMModuleRef LLVMGetGlobalParent(LLVMValueRef Global);
1837 LLVMBool LLVMIsDeclaration(LLVMValueRef Global);
1838 LLVMLinkage LLVMGetLinkage(LLVMValueRef Global);
1839 void LLVMSetLinkage(LLVMValueRef Global, LLVMLinkage Linkage);
1840 const char *LLVMGetSection(LLVMValueRef Global);
1841 void LLVMSetSection(LLVMValueRef Global, const char *Section);
1842 LLVMVisibility LLVMGetVisibility(LLVMValueRef Global);
1843 void LLVMSetVisibility(LLVMValueRef Global, LLVMVisibility Viz);
1844 LLVMDLLStorageClass LLVMGetDLLStorageClass(LLVMValueRef Global);
1845 void LLVMSetDLLStorageClass(LLVMValueRef Global, LLVMDLLStorageClass Class);
1846 LLVMBool LLVMHasUnnamedAddr(LLVMValueRef Global);
1847 void LLVMSetUnnamedAddr(LLVMValueRef Global, LLVMBool HasUnnamedAddr);
1848
1849 /**
1850  * @defgroup LLVMCCoreValueWithAlignment Values with alignment
1851  *
1852  * Functions in this group only apply to values with alignment, i.e.
1853  * global variables, load and store instructions.
1854  */
1855
1856 /**
1857  * Obtain the preferred alignment of the value.
1858  * @see llvm::AllocaInst::getAlignment()
1859  * @see llvm::LoadInst::getAlignment()
1860  * @see llvm::StoreInst::getAlignment()
1861  * @see llvm::GlobalValue::getAlignment()
1862  */
1863 unsigned LLVMGetAlignment(LLVMValueRef V);
1864
1865 /**
1866  * Set the preferred alignment of the value.
1867  * @see llvm::AllocaInst::setAlignment()
1868  * @see llvm::LoadInst::setAlignment()
1869  * @see llvm::StoreInst::setAlignment()
1870  * @see llvm::GlobalValue::setAlignment()
1871  */
1872 void LLVMSetAlignment(LLVMValueRef V, unsigned Bytes);
1873
1874 /**
1875  * @}
1876  */
1877
1878 /**
1879  * @defgroup LLVMCoreValueConstantGlobalVariable Global Variables
1880  *
1881  * This group contains functions that operate on global variable values.
1882  *
1883  * @see llvm::GlobalVariable
1884  *
1885  * @{
1886  */
1887 LLVMValueRef LLVMAddGlobal(LLVMModuleRef M, LLVMTypeRef Ty, const char *Name);
1888 LLVMValueRef LLVMAddGlobalInAddressSpace(LLVMModuleRef M, LLVMTypeRef Ty,
1889                                          const char *Name,
1890                                          unsigned AddressSpace);
1891 LLVMValueRef LLVMGetNamedGlobal(LLVMModuleRef M, const char *Name);
1892 LLVMValueRef LLVMGetFirstGlobal(LLVMModuleRef M);
1893 LLVMValueRef LLVMGetLastGlobal(LLVMModuleRef M);
1894 LLVMValueRef LLVMGetNextGlobal(LLVMValueRef GlobalVar);
1895 LLVMValueRef LLVMGetPreviousGlobal(LLVMValueRef GlobalVar);
1896 void LLVMDeleteGlobal(LLVMValueRef GlobalVar);
1897 LLVMValueRef LLVMGetInitializer(LLVMValueRef GlobalVar);
1898 void LLVMSetInitializer(LLVMValueRef GlobalVar, LLVMValueRef ConstantVal);
1899 LLVMBool LLVMIsThreadLocal(LLVMValueRef GlobalVar);
1900 void LLVMSetThreadLocal(LLVMValueRef GlobalVar, LLVMBool IsThreadLocal);
1901 LLVMBool LLVMIsGlobalConstant(LLVMValueRef GlobalVar);
1902 void LLVMSetGlobalConstant(LLVMValueRef GlobalVar, LLVMBool IsConstant);
1903 LLVMThreadLocalMode LLVMGetThreadLocalMode(LLVMValueRef GlobalVar);
1904 void LLVMSetThreadLocalMode(LLVMValueRef GlobalVar, LLVMThreadLocalMode Mode);
1905 LLVMBool LLVMIsExternallyInitialized(LLVMValueRef GlobalVar);
1906 void LLVMSetExternallyInitialized(LLVMValueRef GlobalVar, LLVMBool IsExtInit);
1907
1908 /**
1909  * @}
1910  */
1911
1912 /**
1913  * @defgroup LLVMCoreValueConstantGlobalAlias Global Aliases
1914  *
1915  * This group contains function that operate on global alias values.
1916  *
1917  * @see llvm::GlobalAlias
1918  *
1919  * @{
1920  */
1921 LLVMValueRef LLVMAddAlias(LLVMModuleRef M, LLVMTypeRef Ty, LLVMValueRef Aliasee,
1922                           const char *Name);
1923
1924 /**
1925  * @}
1926  */
1927
1928 /**
1929  * @defgroup LLVMCCoreValueFunction Function values
1930  *
1931  * Functions in this group operate on LLVMValueRef instances that
1932  * correspond to llvm::Function instances.
1933  *
1934  * @see llvm::Function
1935  *
1936  * @{
1937  */
1938
1939 /**
1940  * Remove a function from its containing module and deletes it.
1941  *
1942  * @see llvm::Function::eraseFromParent()
1943  */
1944 void LLVMDeleteFunction(LLVMValueRef Fn);
1945
1946 /**
1947  * Check whether the given function has a personality function.
1948  *
1949  * @see llvm::Function::hasPersonalityFn()
1950  */
1951 LLVMBool LLVMHasPersonalityFn(LLVMValueRef Fn);
1952
1953 /**
1954  * Obtain the personality function attached to the function.
1955  *
1956  * @see llvm::Function::getPersonalityFn()
1957  */
1958 LLVMValueRef LLVMGetPersonalityFn(LLVMValueRef Fn);
1959
1960 /**
1961  * Set the personality function attached to the function.
1962  *
1963  * @see llvm::Function::setPersonalityFn()
1964  */
1965 void LLVMSetPersonalityFn(LLVMValueRef Fn, LLVMValueRef PersonalityFn);
1966
1967 /**
1968  * Obtain the ID number from a function instance.
1969  *
1970  * @see llvm::Function::getIntrinsicID()
1971  */
1972 unsigned LLVMGetIntrinsicID(LLVMValueRef Fn);
1973
1974 /**
1975  * Obtain the calling function of a function.
1976  *
1977  * The returned value corresponds to the LLVMCallConv enumeration.
1978  *
1979  * @see llvm::Function::getCallingConv()
1980  */
1981 unsigned LLVMGetFunctionCallConv(LLVMValueRef Fn);
1982
1983 /**
1984  * Set the calling convention of a function.
1985  *
1986  * @see llvm::Function::setCallingConv()
1987  *
1988  * @param Fn Function to operate on
1989  * @param CC LLVMCallConv to set calling convention to
1990  */
1991 void LLVMSetFunctionCallConv(LLVMValueRef Fn, unsigned CC);
1992
1993 /**
1994  * Obtain the name of the garbage collector to use during code
1995  * generation.
1996  *
1997  * @see llvm::Function::getGC()
1998  */
1999 const char *LLVMGetGC(LLVMValueRef Fn);
2000
2001 /**
2002  * Define the garbage collector to use during code generation.
2003  *
2004  * @see llvm::Function::setGC()
2005  */
2006 void LLVMSetGC(LLVMValueRef Fn, const char *Name);
2007
2008 /**
2009  * Add an attribute to a function.
2010  *
2011  * @see llvm::Function::addAttribute()
2012  */
2013 void LLVMAddFunctionAttr(LLVMValueRef Fn, LLVMAttribute PA);
2014
2015 void LLVMAddAttributeAtIndex(LLVMValueRef F, LLVMAttributeIndex Idx,
2016                              LLVMAttributeRef A);
2017 LLVMAttributeRef LLVMGetEnumAttributeAtIndex(LLVMValueRef F,
2018                                              LLVMAttributeIndex Idx,
2019                                              unsigned KindID);
2020 void LLVMRemoveEnumAttributeAtIndex(LLVMValueRef F, LLVMAttributeIndex Idx,
2021                                     unsigned KindID);
2022
2023 /**
2024  * Add a target-dependent attribute to a function
2025  * @see llvm::AttrBuilder::addAttribute()
2026  */
2027 void LLVMAddTargetDependentFunctionAttr(LLVMValueRef Fn, const char *A,
2028                                         const char *V);
2029
2030 /**
2031  * Obtain an attribute from a function.
2032  *
2033  * @see llvm::Function::getAttributes()
2034  */
2035 LLVMAttribute LLVMGetFunctionAttr(LLVMValueRef Fn);
2036
2037 /**
2038  * Remove an attribute from a function.
2039  */
2040 void LLVMRemoveFunctionAttr(LLVMValueRef Fn, LLVMAttribute PA);
2041
2042 /**
2043  * @defgroup LLVMCCoreValueFunctionParameters Function Parameters
2044  *
2045  * Functions in this group relate to arguments/parameters on functions.
2046  *
2047  * Functions in this group expect LLVMValueRef instances that correspond
2048  * to llvm::Function instances.
2049  *
2050  * @{
2051  */
2052
2053 /**
2054  * Obtain the number of parameters in a function.
2055  *
2056  * @see llvm::Function::arg_size()
2057  */
2058 unsigned LLVMCountParams(LLVMValueRef Fn);
2059
2060 /**
2061  * Obtain the parameters in a function.
2062  *
2063  * The takes a pointer to a pre-allocated array of LLVMValueRef that is
2064  * at least LLVMCountParams() long. This array will be filled with
2065  * LLVMValueRef instances which correspond to the parameters the
2066  * function receives. Each LLVMValueRef corresponds to a llvm::Argument
2067  * instance.
2068  *
2069  * @see llvm::Function::arg_begin()
2070  */
2071 void LLVMGetParams(LLVMValueRef Fn, LLVMValueRef *Params);
2072
2073 /**
2074  * Obtain the parameter at the specified index.
2075  *
2076  * Parameters are indexed from 0.
2077  *
2078  * @see llvm::Function::arg_begin()
2079  */
2080 LLVMValueRef LLVMGetParam(LLVMValueRef Fn, unsigned Index);
2081
2082 /**
2083  * Obtain the function to which this argument belongs.
2084  *
2085  * Unlike other functions in this group, this one takes an LLVMValueRef
2086  * that corresponds to a llvm::Attribute.
2087  *
2088  * The returned LLVMValueRef is the llvm::Function to which this
2089  * argument belongs.
2090  */
2091 LLVMValueRef LLVMGetParamParent(LLVMValueRef Inst);
2092
2093 /**
2094  * Obtain the first parameter to a function.
2095  *
2096  * @see llvm::Function::arg_begin()
2097  */
2098 LLVMValueRef LLVMGetFirstParam(LLVMValueRef Fn);
2099
2100 /**
2101  * Obtain the last parameter to a function.
2102  *
2103  * @see llvm::Function::arg_end()
2104  */
2105 LLVMValueRef LLVMGetLastParam(LLVMValueRef Fn);
2106
2107 /**
2108  * Obtain the next parameter to a function.
2109  *
2110  * This takes an LLVMValueRef obtained from LLVMGetFirstParam() (which is
2111  * actually a wrapped iterator) and obtains the next parameter from the
2112  * underlying iterator.
2113  */
2114 LLVMValueRef LLVMGetNextParam(LLVMValueRef Arg);
2115
2116 /**
2117  * Obtain the previous parameter to a function.
2118  *
2119  * This is the opposite of LLVMGetNextParam().
2120  */
2121 LLVMValueRef LLVMGetPreviousParam(LLVMValueRef Arg);
2122
2123 /**
2124  * Add an attribute to a function argument.
2125  *
2126  * @see llvm::Argument::addAttr()
2127  */
2128 void LLVMAddAttribute(LLVMValueRef Arg, LLVMAttribute PA);
2129
2130 /**
2131  * Remove an attribute from a function argument.
2132  *
2133  * @see llvm::Argument::removeAttr()
2134  */
2135 void LLVMRemoveAttribute(LLVMValueRef Arg, LLVMAttribute PA);
2136
2137 /**
2138  * Get an attribute from a function argument.
2139  */
2140 LLVMAttribute LLVMGetAttribute(LLVMValueRef Arg);
2141
2142 /**
2143  * Set the alignment for a function parameter.
2144  *
2145  * @see llvm::Argument::addAttr()
2146  * @see llvm::AttrBuilder::addAlignmentAttr()
2147  */
2148 void LLVMSetParamAlignment(LLVMValueRef Arg, unsigned Align);
2149
2150 /**
2151  * @}
2152  */
2153
2154 /**
2155  * @}
2156  */
2157
2158 /**
2159  * @}
2160  */
2161
2162 /**
2163  * @}
2164  */
2165
2166 /**
2167  * @defgroup LLVMCCoreValueMetadata Metadata
2168  *
2169  * @{
2170  */
2171
2172 /**
2173  * Obtain a MDString value from a context.
2174  *
2175  * The returned instance corresponds to the llvm::MDString class.
2176  *
2177  * The instance is specified by string data of a specified length. The
2178  * string content is copied, so the backing memory can be freed after
2179  * this function returns.
2180  */
2181 LLVMValueRef LLVMMDStringInContext(LLVMContextRef C, const char *Str,
2182                                    unsigned SLen);
2183
2184 /**
2185  * Obtain a MDString value from the global context.
2186  */
2187 LLVMValueRef LLVMMDString(const char *Str, unsigned SLen);
2188
2189 /**
2190  * Obtain a MDNode value from a context.
2191  *
2192  * The returned value corresponds to the llvm::MDNode class.
2193  */
2194 LLVMValueRef LLVMMDNodeInContext(LLVMContextRef C, LLVMValueRef *Vals,
2195                                  unsigned Count);
2196
2197 /**
2198  * Obtain a MDNode value from the global context.
2199  */
2200 LLVMValueRef LLVMMDNode(LLVMValueRef *Vals, unsigned Count);
2201
2202 /**
2203  * Obtain the underlying string from a MDString value.
2204  *
2205  * @param V Instance to obtain string from.
2206  * @param Length Memory address which will hold length of returned string.
2207  * @return String data in MDString.
2208  */
2209 const char *LLVMGetMDString(LLVMValueRef V, unsigned *Length);
2210
2211 /**
2212  * Obtain the number of operands from an MDNode value.
2213  *
2214  * @param V MDNode to get number of operands from.
2215  * @return Number of operands of the MDNode.
2216  */
2217 unsigned LLVMGetMDNodeNumOperands(LLVMValueRef V);
2218
2219 /**
2220  * Obtain the given MDNode's operands.
2221  *
2222  * The passed LLVMValueRef pointer should point to enough memory to hold all of
2223  * the operands of the given MDNode (see LLVMGetMDNodeNumOperands) as
2224  * LLVMValueRefs. This memory will be populated with the LLVMValueRefs of the
2225  * MDNode's operands.
2226  *
2227  * @param V MDNode to get the operands from.
2228  * @param Dest Destination array for operands.
2229  */
2230 void LLVMGetMDNodeOperands(LLVMValueRef V, LLVMValueRef *Dest);
2231
2232 /**
2233  * @}
2234  */
2235
2236 /**
2237  * @defgroup LLVMCCoreValueBasicBlock Basic Block
2238  *
2239  * A basic block represents a single entry single exit section of code.
2240  * Basic blocks contain a list of instructions which form the body of
2241  * the block.
2242  *
2243  * Basic blocks belong to functions. They have the type of label.
2244  *
2245  * Basic blocks are themselves values. However, the C API models them as
2246  * LLVMBasicBlockRef.
2247  *
2248  * @see llvm::BasicBlock
2249  *
2250  * @{
2251  */
2252
2253 /**
2254  * Convert a basic block instance to a value type.
2255  */
2256 LLVMValueRef LLVMBasicBlockAsValue(LLVMBasicBlockRef BB);
2257
2258 /**
2259  * Determine whether an LLVMValueRef is itself a basic block.
2260  */
2261 LLVMBool LLVMValueIsBasicBlock(LLVMValueRef Val);
2262
2263 /**
2264  * Convert an LLVMValueRef to an LLVMBasicBlockRef instance.
2265  */
2266 LLVMBasicBlockRef LLVMValueAsBasicBlock(LLVMValueRef Val);
2267
2268 /**
2269  * Obtain the string name of a basic block.
2270  */
2271 const char *LLVMGetBasicBlockName(LLVMBasicBlockRef BB);
2272
2273 /**
2274  * Obtain the function to which a basic block belongs.
2275  *
2276  * @see llvm::BasicBlock::getParent()
2277  */
2278 LLVMValueRef LLVMGetBasicBlockParent(LLVMBasicBlockRef BB);
2279
2280 /**
2281  * Obtain the terminator instruction for a basic block.
2282  *
2283  * If the basic block does not have a terminator (it is not well-formed
2284  * if it doesn't), then NULL is returned.
2285  *
2286  * The returned LLVMValueRef corresponds to a llvm::TerminatorInst.
2287  *
2288  * @see llvm::BasicBlock::getTerminator()
2289  */
2290 LLVMValueRef LLVMGetBasicBlockTerminator(LLVMBasicBlockRef BB);
2291
2292 /**
2293  * Obtain the number of basic blocks in a function.
2294  *
2295  * @param Fn Function value to operate on.
2296  */
2297 unsigned LLVMCountBasicBlocks(LLVMValueRef Fn);
2298
2299 /**
2300  * Obtain all of the basic blocks in a function.
2301  *
2302  * This operates on a function value. The BasicBlocks parameter is a
2303  * pointer to a pre-allocated array of LLVMBasicBlockRef of at least
2304  * LLVMCountBasicBlocks() in length. This array is populated with
2305  * LLVMBasicBlockRef instances.
2306  */
2307 void LLVMGetBasicBlocks(LLVMValueRef Fn, LLVMBasicBlockRef *BasicBlocks);
2308
2309 /**
2310  * Obtain the first basic block in a function.
2311  *
2312  * The returned basic block can be used as an iterator. You will likely
2313  * eventually call into LLVMGetNextBasicBlock() with it.
2314  *
2315  * @see llvm::Function::begin()
2316  */
2317 LLVMBasicBlockRef LLVMGetFirstBasicBlock(LLVMValueRef Fn);
2318
2319 /**
2320  * Obtain the last basic block in a function.
2321  *
2322  * @see llvm::Function::end()
2323  */
2324 LLVMBasicBlockRef LLVMGetLastBasicBlock(LLVMValueRef Fn);
2325
2326 /**
2327  * Advance a basic block iterator.
2328  */
2329 LLVMBasicBlockRef LLVMGetNextBasicBlock(LLVMBasicBlockRef BB);
2330
2331 /**
2332  * Go backwards in a basic block iterator.
2333  */
2334 LLVMBasicBlockRef LLVMGetPreviousBasicBlock(LLVMBasicBlockRef BB);
2335
2336 /**
2337  * Obtain the basic block that corresponds to the entry point of a
2338  * function.
2339  *
2340  * @see llvm::Function::getEntryBlock()
2341  */
2342 LLVMBasicBlockRef LLVMGetEntryBasicBlock(LLVMValueRef Fn);
2343
2344 /**
2345  * Append a basic block to the end of a function.
2346  *
2347  * @see llvm::BasicBlock::Create()
2348  */
2349 LLVMBasicBlockRef LLVMAppendBasicBlockInContext(LLVMContextRef C,
2350                                                 LLVMValueRef Fn,
2351                                                 const char *Name);
2352
2353 /**
2354  * Append a basic block to the end of a function using the global
2355  * context.
2356  *
2357  * @see llvm::BasicBlock::Create()
2358  */
2359 LLVMBasicBlockRef LLVMAppendBasicBlock(LLVMValueRef Fn, const char *Name);
2360
2361 /**
2362  * Insert a basic block in a function before another basic block.
2363  *
2364  * The function to add to is determined by the function of the
2365  * passed basic block.
2366  *
2367  * @see llvm::BasicBlock::Create()
2368  */
2369 LLVMBasicBlockRef LLVMInsertBasicBlockInContext(LLVMContextRef C,
2370                                                 LLVMBasicBlockRef BB,
2371                                                 const char *Name);
2372
2373 /**
2374  * Insert a basic block in a function using the global context.
2375  *
2376  * @see llvm::BasicBlock::Create()
2377  */
2378 LLVMBasicBlockRef LLVMInsertBasicBlock(LLVMBasicBlockRef InsertBeforeBB,
2379                                        const char *Name);
2380
2381 /**
2382  * Remove a basic block from a function and delete it.
2383  *
2384  * This deletes the basic block from its containing function and deletes
2385  * the basic block itself.
2386  *
2387  * @see llvm::BasicBlock::eraseFromParent()
2388  */
2389 void LLVMDeleteBasicBlock(LLVMBasicBlockRef BB);
2390
2391 /**
2392  * Remove a basic block from a function.
2393  *
2394  * This deletes the basic block from its containing function but keep
2395  * the basic block alive.
2396  *
2397  * @see llvm::BasicBlock::removeFromParent()
2398  */
2399 void LLVMRemoveBasicBlockFromParent(LLVMBasicBlockRef BB);
2400
2401 /**
2402  * Move a basic block to before another one.
2403  *
2404  * @see llvm::BasicBlock::moveBefore()
2405  */
2406 void LLVMMoveBasicBlockBefore(LLVMBasicBlockRef BB, LLVMBasicBlockRef MovePos);
2407
2408 /**
2409  * Move a basic block to after another one.
2410  *
2411  * @see llvm::BasicBlock::moveAfter()
2412  */
2413 void LLVMMoveBasicBlockAfter(LLVMBasicBlockRef BB, LLVMBasicBlockRef MovePos);
2414
2415 /**
2416  * Obtain the first instruction in a basic block.
2417  *
2418  * The returned LLVMValueRef corresponds to a llvm::Instruction
2419  * instance.
2420  */
2421 LLVMValueRef LLVMGetFirstInstruction(LLVMBasicBlockRef BB);
2422
2423 /**
2424  * Obtain the last instruction in a basic block.
2425  *
2426  * The returned LLVMValueRef corresponds to an LLVM:Instruction.
2427  */
2428 LLVMValueRef LLVMGetLastInstruction(LLVMBasicBlockRef BB);
2429
2430 /**
2431  * @}
2432  */
2433
2434 /**
2435  * @defgroup LLVMCCoreValueInstruction Instructions
2436  *
2437  * Functions in this group relate to the inspection and manipulation of
2438  * individual instructions.
2439  *
2440  * In the C++ API, an instruction is modeled by llvm::Instruction. This
2441  * class has a large number of descendents. llvm::Instruction is a
2442  * llvm::Value and in the C API, instructions are modeled by
2443  * LLVMValueRef.
2444  *
2445  * This group also contains sub-groups which operate on specific
2446  * llvm::Instruction types, e.g. llvm::CallInst.
2447  *
2448  * @{
2449  */
2450
2451 /**
2452  * Determine whether an instruction has any metadata attached.
2453  */
2454 int LLVMHasMetadata(LLVMValueRef Val);
2455
2456 /**
2457  * Return metadata associated with an instruction value.
2458  */
2459 LLVMValueRef LLVMGetMetadata(LLVMValueRef Val, unsigned KindID);
2460
2461 /**
2462  * Set metadata associated with an instruction value.
2463  */
2464 void LLVMSetMetadata(LLVMValueRef Val, unsigned KindID, LLVMValueRef Node);
2465
2466 /**
2467  * Obtain the basic block to which an instruction belongs.
2468  *
2469  * @see llvm::Instruction::getParent()
2470  */
2471 LLVMBasicBlockRef LLVMGetInstructionParent(LLVMValueRef Inst);
2472
2473 /**
2474  * Obtain the instruction that occurs after the one specified.
2475  *
2476  * The next instruction will be from the same basic block.
2477  *
2478  * If this is the last instruction in a basic block, NULL will be
2479  * returned.
2480  */
2481 LLVMValueRef LLVMGetNextInstruction(LLVMValueRef Inst);
2482
2483 /**
2484  * Obtain the instruction that occurred before this one.
2485  *
2486  * If the instruction is the first instruction in a basic block, NULL
2487  * will be returned.
2488  */
2489 LLVMValueRef LLVMGetPreviousInstruction(LLVMValueRef Inst);
2490
2491 /**
2492  * Remove and delete an instruction.
2493  *
2494  * The instruction specified is removed from its containing building
2495  * block but is kept alive.
2496  *
2497  * @see llvm::Instruction::removeFromParent()
2498  */
2499 void LLVMInstructionRemoveFromParent(LLVMValueRef Inst);
2500
2501 /**
2502  * Remove and delete an instruction.
2503  *
2504  * The instruction specified is removed from its containing building
2505  * block and then deleted.
2506  *
2507  * @see llvm::Instruction::eraseFromParent()
2508  */
2509 void LLVMInstructionEraseFromParent(LLVMValueRef Inst);
2510
2511 /**
2512  * Obtain the code opcode for an individual instruction.
2513  *
2514  * @see llvm::Instruction::getOpCode()
2515  */
2516 LLVMOpcode LLVMGetInstructionOpcode(LLVMValueRef Inst);
2517
2518 /**
2519  * Obtain the predicate of an instruction.
2520  *
2521  * This is only valid for instructions that correspond to llvm::ICmpInst
2522  * or llvm::ConstantExpr whose opcode is llvm::Instruction::ICmp.
2523  *
2524  * @see llvm::ICmpInst::getPredicate()
2525  */
2526 LLVMIntPredicate LLVMGetICmpPredicate(LLVMValueRef Inst);
2527
2528 /**
2529  * Obtain the float predicate of an instruction.
2530  *
2531  * This is only valid for instructions that correspond to llvm::FCmpInst
2532  * or llvm::ConstantExpr whose opcode is llvm::Instruction::FCmp.
2533  *
2534  * @see llvm::FCmpInst::getPredicate()
2535  */
2536 LLVMRealPredicate LLVMGetFCmpPredicate(LLVMValueRef Inst);
2537
2538 /**
2539  * Create a copy of 'this' instruction that is identical in all ways
2540  * except the following:
2541  *   * The instruction has no parent
2542  *   * The instruction has no name
2543  *
2544  * @see llvm::Instruction::clone()
2545  */
2546 LLVMValueRef LLVMInstructionClone(LLVMValueRef Inst);
2547
2548 /**
2549  * @defgroup LLVMCCoreValueInstructionCall Call Sites and Invocations
2550  *
2551  * Functions in this group apply to instructions that refer to call
2552  * sites and invocations. These correspond to C++ types in the
2553  * llvm::CallInst class tree.
2554  *
2555  * @{
2556  */
2557
2558 /**
2559  * Obtain the argument count for a call instruction.
2560  *
2561  * This expects an LLVMValueRef that corresponds to a llvm::CallInst or
2562  * llvm::InvokeInst.
2563  *
2564  * @see llvm::CallInst::getNumArgOperands()
2565  * @see llvm::InvokeInst::getNumArgOperands()
2566  */
2567 unsigned LLVMGetNumArgOperands(LLVMValueRef Instr);
2568
2569 /**
2570  * Set the calling convention for a call instruction.
2571  *
2572  * This expects an LLVMValueRef that corresponds to a llvm::CallInst or
2573  * llvm::InvokeInst.
2574  *
2575  * @see llvm::CallInst::setCallingConv()
2576  * @see llvm::InvokeInst::setCallingConv()
2577  */
2578 void LLVMSetInstructionCallConv(LLVMValueRef Instr, unsigned CC);
2579
2580 /**
2581  * Obtain the calling convention for a call instruction.
2582  *
2583  * This is the opposite of LLVMSetInstructionCallConv(). Reads its
2584  * usage.
2585  *
2586  * @see LLVMSetInstructionCallConv()
2587  */
2588 unsigned LLVMGetInstructionCallConv(LLVMValueRef Instr);
2589
2590
2591 void LLVMAddInstrAttribute(LLVMValueRef Instr, unsigned index, LLVMAttribute);
2592 void LLVMRemoveInstrAttribute(LLVMValueRef Instr, unsigned index,
2593                               LLVMAttribute);
2594 void LLVMSetInstrParamAlignment(LLVMValueRef Instr, unsigned index,
2595                                 unsigned Align);
2596
2597 /**
2598  * Obtain the pointer to the function invoked by this instruction.
2599  *
2600  * This expects an LLVMValueRef that corresponds to a llvm::CallInst or
2601  * llvm::InvokeInst.
2602  *
2603  * @see llvm::CallInst::getCalledValue()
2604  * @see llvm::InvokeInst::getCalledValue()
2605  */
2606 LLVMValueRef LLVMGetCalledValue(LLVMValueRef Instr);
2607
2608 /**
2609  * Obtain whether a call instruction is a tail call.
2610  *
2611  * This only works on llvm::CallInst instructions.
2612  *
2613  * @see llvm::CallInst::isTailCall()
2614  */
2615 LLVMBool LLVMIsTailCall(LLVMValueRef CallInst);
2616
2617 /**
2618  * Set whether a call instruction is a tail call.
2619  *
2620  * This only works on llvm::CallInst instructions.
2621  *
2622  * @see llvm::CallInst::setTailCall()
2623  */
2624 void LLVMSetTailCall(LLVMValueRef CallInst, LLVMBool IsTailCall);
2625
2626 /**
2627  * Return the normal destination basic block.
2628  *
2629  * This only works on llvm::InvokeInst instructions.
2630  *
2631  * @see llvm::InvokeInst::getNormalDest()
2632  */
2633 LLVMBasicBlockRef LLVMGetNormalDest(LLVMValueRef InvokeInst);
2634
2635 /**
2636  * Return the unwind destination basic block.
2637  *
2638  * This only works on llvm::InvokeInst instructions.
2639  *
2640  * @see llvm::InvokeInst::getUnwindDest()
2641  */
2642 LLVMBasicBlockRef LLVMGetUnwindDest(LLVMValueRef InvokeInst);
2643
2644 /**
2645  * Set the normal destination basic block.
2646  *
2647  * This only works on llvm::InvokeInst instructions.
2648  *
2649  * @see llvm::InvokeInst::setNormalDest()
2650  */
2651 void LLVMSetNormalDest(LLVMValueRef InvokeInst, LLVMBasicBlockRef B);
2652
2653 /**
2654  * Set the unwind destination basic block.
2655  *
2656  * This only works on llvm::InvokeInst instructions.
2657  *
2658  * @see llvm::InvokeInst::setUnwindDest()
2659  */
2660 void LLVMSetUnwindDest(LLVMValueRef InvokeInst, LLVMBasicBlockRef B);
2661
2662 /**
2663  * @}
2664  */
2665
2666 /**
2667  * @defgroup LLVMCCoreValueInstructionTerminator Terminators
2668  *
2669  * Functions in this group only apply to instructions that map to
2670  * llvm::TerminatorInst instances.
2671  *
2672  * @{
2673  */
2674
2675 /**
2676  * Return the number of successors that this terminator has.
2677  *
2678  * @see llvm::TerminatorInst::getNumSuccessors
2679  */
2680 unsigned LLVMGetNumSuccessors(LLVMValueRef Term);
2681
2682 /**
2683  * Return the specified successor.
2684  *
2685  * @see llvm::TerminatorInst::getSuccessor
2686  */
2687 LLVMBasicBlockRef LLVMGetSuccessor(LLVMValueRef Term, unsigned i);
2688
2689 /**
2690  * Update the specified successor to point at the provided block.
2691  *
2692  * @see llvm::TerminatorInst::setSuccessor
2693  */
2694 void LLVMSetSuccessor(LLVMValueRef Term, unsigned i, LLVMBasicBlockRef block);
2695
2696 /**
2697  * Return if a branch is conditional.
2698  *
2699  * This only works on llvm::BranchInst instructions.
2700  *
2701  * @see llvm::BranchInst::isConditional
2702  */
2703 LLVMBool LLVMIsConditional(LLVMValueRef Branch);
2704
2705 /**
2706  * Return the condition of a branch instruction.
2707  *
2708  * This only works on llvm::BranchInst instructions.
2709  *
2710  * @see llvm::BranchInst::getCondition
2711  */
2712 LLVMValueRef LLVMGetCondition(LLVMValueRef Branch);
2713
2714 /**
2715  * Set the condition of a branch instruction.
2716  *
2717  * This only works on llvm::BranchInst instructions.
2718  *
2719  * @see llvm::BranchInst::setCondition
2720  */
2721 void LLVMSetCondition(LLVMValueRef Branch, LLVMValueRef Cond);
2722
2723 /**
2724  * Obtain the default destination basic block of a switch instruction.
2725  *
2726  * This only works on llvm::SwitchInst instructions.
2727  *
2728  * @see llvm::SwitchInst::getDefaultDest()
2729  */
2730 LLVMBasicBlockRef LLVMGetSwitchDefaultDest(LLVMValueRef SwitchInstr);
2731
2732 /**
2733  * @}
2734  */
2735
2736 /**
2737  * @defgroup LLVMCCoreValueInstructionAlloca Allocas
2738  *
2739  * Functions in this group only apply to instructions that map to
2740  * llvm::AllocaInst instances.
2741  *
2742  * @{
2743  */
2744
2745 /**
2746  * Obtain the type that is being allocated by the alloca instruction.
2747  */
2748 LLVMTypeRef LLVMGetAllocatedType(LLVMValueRef Alloca);
2749
2750 /**
2751  * @}
2752  */
2753
2754 /**
2755  * @defgroup LLVMCCoreValueInstructionGetElementPointer GEPs
2756  *
2757  * Functions in this group only apply to instructions that map to
2758  * llvm::GetElementPtrInst instances.
2759  *
2760  * @{
2761  */
2762
2763 /**
2764  * Check whether the given GEP instruction is inbounds.
2765  */
2766 LLVMBool LLVMIsInBounds(LLVMValueRef GEP);
2767
2768 /**
2769  * Set the given GEP instruction to be inbounds or not.
2770  */
2771 void LLVMSetIsInBounds(LLVMValueRef GEP, LLVMBool InBounds);
2772
2773 /**
2774  * @}
2775  */
2776
2777 /**
2778  * @defgroup LLVMCCoreValueInstructionPHINode PHI Nodes
2779  *
2780  * Functions in this group only apply to instructions that map to
2781  * llvm::PHINode instances.
2782  *
2783  * @{
2784  */
2785
2786 /**
2787  * Add an incoming value to the end of a PHI list.
2788  */
2789 void LLVMAddIncoming(LLVMValueRef PhiNode, LLVMValueRef *IncomingValues,
2790                      LLVMBasicBlockRef *IncomingBlocks, unsigned Count);
2791
2792 /**
2793  * Obtain the number of incoming basic blocks to a PHI node.
2794  */
2795 unsigned LLVMCountIncoming(LLVMValueRef PhiNode);
2796
2797 /**
2798  * Obtain an incoming value to a PHI node as an LLVMValueRef.
2799  */
2800 LLVMValueRef LLVMGetIncomingValue(LLVMValueRef PhiNode, unsigned Index);
2801
2802 /**
2803  * Obtain an incoming value to a PHI node as an LLVMBasicBlockRef.
2804  */
2805 LLVMBasicBlockRef LLVMGetIncomingBlock(LLVMValueRef PhiNode, unsigned Index);
2806
2807 /**
2808  * @}
2809  */
2810
2811 /**
2812  * @defgroup LLVMCCoreValueInstructionExtractValue ExtractValue
2813  * @defgroup LLVMCCoreValueInstructionInsertValue InsertValue
2814  *
2815  * Functions in this group only apply to instructions that map to
2816  * llvm::ExtractValue and llvm::InsertValue instances.
2817  *
2818  * @{
2819  */
2820
2821 /**
2822  * Obtain the number of indices.
2823  * NB: This also works on GEP.
2824  */
2825 unsigned LLVMGetNumIndices(LLVMValueRef Inst);
2826
2827 /**
2828  * Obtain the indices as an array.
2829  */
2830 const unsigned *LLVMGetIndices(LLVMValueRef Inst);
2831
2832 /**
2833  * @}
2834  */
2835
2836 /**
2837  * @}
2838  */
2839
2840 /**
2841  * @}
2842  */
2843
2844 /**
2845  * @defgroup LLVMCCoreInstructionBuilder Instruction Builders
2846  *
2847  * An instruction builder represents a point within a basic block and is
2848  * the exclusive means of building instructions using the C interface.
2849  *
2850  * @{
2851  */
2852
2853 LLVMBuilderRef LLVMCreateBuilderInContext(LLVMContextRef C);
2854 LLVMBuilderRef LLVMCreateBuilder(void);
2855 void LLVMPositionBuilder(LLVMBuilderRef Builder, LLVMBasicBlockRef Block,
2856                          LLVMValueRef Instr);
2857 void LLVMPositionBuilderBefore(LLVMBuilderRef Builder, LLVMValueRef Instr);
2858 void LLVMPositionBuilderAtEnd(LLVMBuilderRef Builder, LLVMBasicBlockRef Block);
2859 LLVMBasicBlockRef LLVMGetInsertBlock(LLVMBuilderRef Builder);
2860 void LLVMClearInsertionPosition(LLVMBuilderRef Builder);
2861 void LLVMInsertIntoBuilder(LLVMBuilderRef Builder, LLVMValueRef Instr);
2862 void LLVMInsertIntoBuilderWithName(LLVMBuilderRef Builder, LLVMValueRef Instr,
2863                                    const char *Name);
2864 void LLVMDisposeBuilder(LLVMBuilderRef Builder);
2865
2866 /* Metadata */
2867 void LLVMSetCurrentDebugLocation(LLVMBuilderRef Builder, LLVMValueRef L);
2868 LLVMValueRef LLVMGetCurrentDebugLocation(LLVMBuilderRef Builder);
2869 void LLVMSetInstDebugLocation(LLVMBuilderRef Builder, LLVMValueRef Inst);
2870
2871 /* Terminators */
2872 LLVMValueRef LLVMBuildRetVoid(LLVMBuilderRef);
2873 LLVMValueRef LLVMBuildRet(LLVMBuilderRef, LLVMValueRef V);
2874 LLVMValueRef LLVMBuildAggregateRet(LLVMBuilderRef, LLVMValueRef *RetVals,
2875                                    unsigned N);
2876 LLVMValueRef LLVMBuildBr(LLVMBuilderRef, LLVMBasicBlockRef Dest);
2877 LLVMValueRef LLVMBuildCondBr(LLVMBuilderRef, LLVMValueRef If,
2878                              LLVMBasicBlockRef Then, LLVMBasicBlockRef Else);
2879 LLVMValueRef LLVMBuildSwitch(LLVMBuilderRef, LLVMValueRef V,
2880                              LLVMBasicBlockRef Else, unsigned NumCases);
2881 LLVMValueRef LLVMBuildIndirectBr(LLVMBuilderRef B, LLVMValueRef Addr,
2882                                  unsigned NumDests);
2883 LLVMValueRef LLVMBuildInvoke(LLVMBuilderRef, LLVMValueRef Fn,
2884                              LLVMValueRef *Args, unsigned NumArgs,
2885                              LLVMBasicBlockRef Then, LLVMBasicBlockRef Catch,
2886                              const char *Name);
2887 LLVMValueRef LLVMBuildLandingPad(LLVMBuilderRef B, LLVMTypeRef Ty,
2888                                  LLVMValueRef PersFn, unsigned NumClauses,
2889                                  const char *Name);
2890 LLVMValueRef LLVMBuildResume(LLVMBuilderRef B, LLVMValueRef Exn);
2891 LLVMValueRef LLVMBuildUnreachable(LLVMBuilderRef);
2892
2893 /* Add a case to the switch instruction */
2894 void LLVMAddCase(LLVMValueRef Switch, LLVMValueRef OnVal,
2895                  LLVMBasicBlockRef Dest);
2896
2897 /* Add a destination to the indirectbr instruction */
2898 void LLVMAddDestination(LLVMValueRef IndirectBr, LLVMBasicBlockRef Dest);
2899
2900 /* Get the number of clauses on the landingpad instruction */
2901 unsigned LLVMGetNumClauses(LLVMValueRef LandingPad);
2902
2903 /* Get the value of the clause at idnex Idx on the landingpad instruction */
2904 LLVMValueRef LLVMGetClause(LLVMValueRef LandingPad, unsigned Idx);
2905
2906 /* Add a catch or filter clause to the landingpad instruction */
2907 void LLVMAddClause(LLVMValueRef LandingPad, LLVMValueRef ClauseVal);
2908
2909 /* Get the 'cleanup' flag in the landingpad instruction */
2910 LLVMBool LLVMIsCleanup(LLVMValueRef LandingPad);
2911
2912 /* Set the 'cleanup' flag in the landingpad instruction */
2913 void LLVMSetCleanup(LLVMValueRef LandingPad, LLVMBool Val);
2914
2915 /* Arithmetic */
2916 LLVMValueRef LLVMBuildAdd(LLVMBuilderRef, LLVMValueRef LHS, LLVMValueRef RHS,
2917                           const char *Name);
2918 LLVMValueRef LLVMBuildNSWAdd(LLVMBuilderRef, LLVMValueRef LHS, LLVMValueRef RHS,
2919                              const char *Name);
2920 LLVMValueRef LLVMBuildNUWAdd(LLVMBuilderRef, LLVMValueRef LHS, LLVMValueRef RHS,
2921                              const char *Name);
2922 LLVMValueRef LLVMBuildFAdd(LLVMBuilderRef, LLVMValueRef LHS, LLVMValueRef RHS,
2923                            const char *Name);
2924 LLVMValueRef LLVMBuildSub(LLVMBuilderRef, LLVMValueRef LHS, LLVMValueRef RHS,
2925                           const char *Name);
2926 LLVMValueRef LLVMBuildNSWSub(LLVMBuilderRef, LLVMValueRef LHS, LLVMValueRef RHS,
2927                              const char *Name);
2928 LLVMValueRef LLVMBuildNUWSub(LLVMBuilderRef, LLVMValueRef LHS, LLVMValueRef RHS,
2929                              const char *Name);
2930 LLVMValueRef LLVMBuildFSub(LLVMBuilderRef, LLVMValueRef LHS, LLVMValueRef RHS,
2931                            const char *Name);
2932 LLVMValueRef LLVMBuildMul(LLVMBuilderRef, LLVMValueRef LHS, LLVMValueRef RHS,
2933                           const char *Name);
2934 LLVMValueRef LLVMBuildNSWMul(LLVMBuilderRef, LLVMValueRef LHS, LLVMValueRef RHS,
2935                              const char *Name);
2936 LLVMValueRef LLVMBuildNUWMul(LLVMBuilderRef, LLVMValueRef LHS, LLVMValueRef RHS,
2937                              const char *Name);
2938 LLVMValueRef LLVMBuildFMul(LLVMBuilderRef, LLVMValueRef LHS, LLVMValueRef RHS,
2939                            const char *Name);
2940 LLVMValueRef LLVMBuildUDiv(LLVMBuilderRef, LLVMValueRef LHS, LLVMValueRef RHS,
2941                            const char *Name);
2942 LLVMValueRef LLVMBuildSDiv(LLVMBuilderRef, LLVMValueRef LHS, LLVMValueRef RHS,
2943                            const char *Name);
2944 LLVMValueRef LLVMBuildExactSDiv(LLVMBuilderRef, LLVMValueRef LHS, LLVMValueRef RHS,
2945                                 const char *Name);
2946 LLVMValueRef LLVMBuildFDiv(LLVMBuilderRef, LLVMValueRef LHS, LLVMValueRef RHS,
2947                            const char *Name);
2948 LLVMValueRef LLVMBuildURem(LLVMBuilderRef, LLVMValueRef LHS, LLVMValueRef RHS,
2949                            const char *Name);
2950 LLVMValueRef LLVMBuildSRem(LLVMBuilderRef, LLVMValueRef LHS, LLVMValueRef RHS,
2951                            const char *Name);
2952 LLVMValueRef LLVMBuildFRem(LLVMBuilderRef, LLVMValueRef LHS, LLVMValueRef RHS,
2953                            const char *Name);
2954 LLVMValueRef LLVMBuildShl(LLVMBuilderRef, LLVMValueRef LHS, LLVMValueRef RHS,
2955                            const char *Name);
2956 LLVMValueRef LLVMBuildLShr(LLVMBuilderRef, LLVMValueRef LHS, LLVMValueRef RHS,
2957                            const char *Name);
2958 LLVMValueRef LLVMBuildAShr(LLVMBuilderRef, LLVMValueRef LHS, LLVMValueRef RHS,
2959                            const char *Name);
2960 LLVMValueRef LLVMBuildAnd(LLVMBuilderRef, LLVMValueRef LHS, LLVMValueRef RHS,
2961                           const char *Name);
2962 LLVMValueRef LLVMBuildOr(LLVMBuilderRef, LLVMValueRef LHS, LLVMValueRef RHS,
2963                           const char *Name);
2964 LLVMValueRef LLVMBuildXor(LLVMBuilderRef, LLVMValueRef LHS, LLVMValueRef RHS,
2965                           const char *Name);
2966 LLVMValueRef LLVMBuildBinOp(LLVMBuilderRef B, LLVMOpcode Op,
2967                             LLVMValueRef LHS, LLVMValueRef RHS,
2968                             const char *Name);
2969 LLVMValueRef LLVMBuildNeg(LLVMBuilderRef, LLVMValueRef V, const char *Name);
2970 LLVMValueRef LLVMBuildNSWNeg(LLVMBuilderRef B, LLVMValueRef V,
2971                              const char *Name);
2972 LLVMValueRef LLVMBuildNUWNeg(LLVMBuilderRef B, LLVMValueRef V,
2973                              const char *Name);
2974 LLVMValueRef LLVMBuildFNeg(LLVMBuilderRef, LLVMValueRef V, const char *Name);
2975 LLVMValueRef LLVMBuildNot(LLVMBuilderRef, LLVMValueRef V, const char *Name);
2976
2977 /* Memory */
2978 LLVMValueRef LLVMBuildMalloc(LLVMBuilderRef, LLVMTypeRef Ty, const char *Name);
2979 LLVMValueRef LLVMBuildArrayMalloc(LLVMBuilderRef, LLVMTypeRef Ty,
2980                                   LLVMValueRef Val, const char *Name);
2981 LLVMValueRef LLVMBuildAlloca(LLVMBuilderRef, LLVMTypeRef Ty, const char *Name);
2982 LLVMValueRef LLVMBuildArrayAlloca(LLVMBuilderRef, LLVMTypeRef Ty,
2983                                   LLVMValueRef Val, const char *Name);
2984 LLVMValueRef LLVMBuildFree(LLVMBuilderRef, LLVMValueRef PointerVal);
2985 LLVMValueRef LLVMBuildLoad(LLVMBuilderRef, LLVMValueRef PointerVal,
2986                            const char *Name);
2987 LLVMValueRef LLVMBuildStore(LLVMBuilderRef, LLVMValueRef Val, LLVMValueRef Ptr);
2988 LLVMValueRef LLVMBuildGEP(LLVMBuilderRef B, LLVMValueRef Pointer,
2989                           LLVMValueRef *Indices, unsigned NumIndices,
2990                           const char *Name);
2991 LLVMValueRef LLVMBuildInBoundsGEP(LLVMBuilderRef B, LLVMValueRef Pointer,
2992                                   LLVMValueRef *Indices, unsigned NumIndices,
2993                                   const char *Name);
2994 LLVMValueRef LLVMBuildStructGEP(LLVMBuilderRef B, LLVMValueRef Pointer,
2995                                 unsigned Idx, const char *Name);
2996 LLVMValueRef LLVMBuildGlobalString(LLVMBuilderRef B, const char *Str,
2997                                    const char *Name);
2998 LLVMValueRef LLVMBuildGlobalStringPtr(LLVMBuilderRef B, const char *Str,
2999                                       const char *Name);
3000 LLVMBool LLVMGetVolatile(LLVMValueRef MemoryAccessInst);
3001 void LLVMSetVolatile(LLVMValueRef MemoryAccessInst, LLVMBool IsVolatile);
3002 LLVMAtomicOrdering LLVMGetOrdering(LLVMValueRef MemoryAccessInst);
3003 void LLVMSetOrdering(LLVMValueRef MemoryAccessInst, LLVMAtomicOrdering Ordering);
3004
3005 /* Casts */
3006 LLVMValueRef LLVMBuildTrunc(LLVMBuilderRef, LLVMValueRef Val,
3007                             LLVMTypeRef DestTy, const char *Name);
3008 LLVMValueRef LLVMBuildZExt(LLVMBuilderRef, LLVMValueRef Val,
3009                            LLVMTypeRef DestTy, const char *Name);
3010 LLVMValueRef LLVMBuildSExt(LLVMBuilderRef, LLVMValueRef Val,
3011                            LLVMTypeRef DestTy, const char *Name);
3012 LLVMValueRef LLVMBuildFPToUI(LLVMBuilderRef, LLVMValueRef Val,
3013                              LLVMTypeRef DestTy, const char *Name);
3014 LLVMValueRef LLVMBuildFPToSI(LLVMBuilderRef, LLVMValueRef Val,
3015                              LLVMTypeRef DestTy, const char *Name);
3016 LLVMValueRef LLVMBuildUIToFP(LLVMBuilderRef, LLVMValueRef Val,
3017                              LLVMTypeRef DestTy, const char *Name);
3018 LLVMValueRef LLVMBuildSIToFP(LLVMBuilderRef, LLVMValueRef Val,
3019                              LLVMTypeRef DestTy, const char *Name);
3020 LLVMValueRef LLVMBuildFPTrunc(LLVMBuilderRef, LLVMValueRef Val,
3021                               LLVMTypeRef DestTy, const char *Name);
3022 LLVMValueRef LLVMBuildFPExt(LLVMBuilderRef, LLVMValueRef Val,
3023                             LLVMTypeRef DestTy, const char *Name);
3024 LLVMValueRef LLVMBuildPtrToInt(LLVMBuilderRef, LLVMValueRef Val,
3025                                LLVMTypeRef DestTy, const char *Name);
3026 LLVMValueRef LLVMBuildIntToPtr(LLVMBuilderRef, LLVMValueRef Val,
3027                                LLVMTypeRef DestTy, const char *Name);
3028 LLVMValueRef LLVMBuildBitCast(LLVMBuilderRef, LLVMValueRef Val,
3029                               LLVMTypeRef DestTy, const char *Name);
3030 LLVMValueRef LLVMBuildAddrSpaceCast(LLVMBuilderRef, LLVMValueRef Val,
3031                                     LLVMTypeRef DestTy, const char *Name);
3032 LLVMValueRef LLVMBuildZExtOrBitCast(LLVMBuilderRef, LLVMValueRef Val,
3033                                     LLVMTypeRef DestTy, const char *Name);
3034 LLVMValueRef LLVMBuildSExtOrBitCast(LLVMBuilderRef, LLVMValueRef Val,
3035                                     LLVMTypeRef DestTy, const char *Name);
3036 LLVMValueRef LLVMBuildTruncOrBitCast(LLVMBuilderRef, LLVMValueRef Val,
3037                                      LLVMTypeRef DestTy, const char *Name);
3038 LLVMValueRef LLVMBuildCast(LLVMBuilderRef B, LLVMOpcode Op, LLVMValueRef Val,
3039                            LLVMTypeRef DestTy, const char *Name);
3040 LLVMValueRef LLVMBuildPointerCast(LLVMBuilderRef, LLVMValueRef Val,
3041                                   LLVMTypeRef DestTy, const char *Name);
3042 LLVMValueRef LLVMBuildIntCast(LLVMBuilderRef, LLVMValueRef Val, /*Signed cast!*/
3043                               LLVMTypeRef DestTy, const char *Name);
3044 LLVMValueRef LLVMBuildFPCast(LLVMBuilderRef, LLVMValueRef Val,
3045                              LLVMTypeRef DestTy, const char *Name);
3046
3047 /* Comparisons */
3048 LLVMValueRef LLVMBuildICmp(LLVMBuilderRef, LLVMIntPredicate Op,
3049                            LLVMValueRef LHS, LLVMValueRef RHS,
3050                            const char *Name);
3051 LLVMValueRef LLVMBuildFCmp(LLVMBuilderRef, LLVMRealPredicate Op,
3052                            LLVMValueRef LHS, LLVMValueRef RHS,
3053                            const char *Name);
3054
3055 /* Miscellaneous instructions */
3056 LLVMValueRef LLVMBuildPhi(LLVMBuilderRef, LLVMTypeRef Ty, const char *Name);
3057 LLVMValueRef LLVMBuildCall(LLVMBuilderRef, LLVMValueRef Fn,
3058                            LLVMValueRef *Args, unsigned NumArgs,
3059                            const char *Name);
3060 LLVMValueRef LLVMBuildSelect(LLVMBuilderRef, LLVMValueRef If,
3061                              LLVMValueRef Then, LLVMValueRef Else,
3062                              const char *Name);
3063 LLVMValueRef LLVMBuildVAArg(LLVMBuilderRef, LLVMValueRef List, LLVMTypeRef Ty,
3064                             const char *Name);
3065 LLVMValueRef LLVMBuildExtractElement(LLVMBuilderRef, LLVMValueRef VecVal,
3066                                      LLVMValueRef Index, const char *Name);
3067 LLVMValueRef LLVMBuildInsertElement(LLVMBuilderRef, LLVMValueRef VecVal,
3068                                     LLVMValueRef EltVal, LLVMValueRef Index,
3069                                     const char *Name);
3070 LLVMValueRef LLVMBuildShuffleVector(LLVMBuilderRef, LLVMValueRef V1,
3071                                     LLVMValueRef V2, LLVMValueRef Mask,
3072                                     const char *Name);
3073 LLVMValueRef LLVMBuildExtractValue(LLVMBuilderRef, LLVMValueRef AggVal,
3074                                    unsigned Index, const char *Name);
3075 LLVMValueRef LLVMBuildInsertValue(LLVMBuilderRef, LLVMValueRef AggVal,
3076                                   LLVMValueRef EltVal, unsigned Index,
3077                                   const char *Name);
3078
3079 LLVMValueRef LLVMBuildIsNull(LLVMBuilderRef, LLVMValueRef Val,
3080                              const char *Name);
3081 LLVMValueRef LLVMBuildIsNotNull(LLVMBuilderRef, LLVMValueRef Val,
3082                                 const char *Name);
3083 LLVMValueRef LLVMBuildPtrDiff(LLVMBuilderRef, LLVMValueRef LHS,
3084                               LLVMValueRef RHS, const char *Name);
3085 LLVMValueRef LLVMBuildFence(LLVMBuilderRef B, LLVMAtomicOrdering ordering,
3086                             LLVMBool singleThread, const char *Name);
3087 LLVMValueRef LLVMBuildAtomicRMW(LLVMBuilderRef B, LLVMAtomicRMWBinOp op,
3088                                 LLVMValueRef PTR, LLVMValueRef Val,
3089                                 LLVMAtomicOrdering ordering,
3090                                 LLVMBool singleThread);
3091 LLVMValueRef LLVMBuildAtomicCmpXchg(LLVMBuilderRef B, LLVMValueRef Ptr,
3092                                     LLVMValueRef Cmp, LLVMValueRef New,
3093                                     LLVMAtomicOrdering SuccessOrdering,
3094                                     LLVMAtomicOrdering FailureOrdering,
3095                                     LLVMBool SingleThread);
3096
3097 LLVMBool LLVMIsAtomicSingleThread(LLVMValueRef AtomicInst);
3098 void LLVMSetAtomicSingleThread(LLVMValueRef AtomicInst, LLVMBool SingleThread);
3099
3100 LLVMAtomicOrdering LLVMGetCmpXchgSuccessOrdering(LLVMValueRef CmpXchgInst);
3101 void LLVMSetCmpXchgSuccessOrdering(LLVMValueRef CmpXchgInst,
3102                                    LLVMAtomicOrdering Ordering);
3103 LLVMAtomicOrdering LLVMGetCmpXchgFailureOrdering(LLVMValueRef CmpXchgInst);
3104 void LLVMSetCmpXchgFailureOrdering(LLVMValueRef CmpXchgInst,
3105                                    LLVMAtomicOrdering Ordering);
3106
3107 /**
3108  * @}
3109  */
3110
3111 /**
3112  * @defgroup LLVMCCoreModuleProvider Module Providers
3113  *
3114  * @{
3115  */
3116
3117 /**
3118  * Changes the type of M so it can be passed to FunctionPassManagers and the
3119  * JIT.  They take ModuleProviders for historical reasons.
3120  */
3121 LLVMModuleProviderRef
3122 LLVMCreateModuleProviderForExistingModule(LLVMModuleRef M);
3123
3124 /**
3125  * Destroys the module M.
3126  */
3127 void LLVMDisposeModuleProvider(LLVMModuleProviderRef M);
3128
3129 /**
3130  * @}
3131  */
3132
3133 /**
3134  * @defgroup LLVMCCoreMemoryBuffers Memory Buffers
3135  *
3136  * @{
3137  */
3138
3139 LLVMBool LLVMCreateMemoryBufferWithContentsOfFile(const char *Path,
3140                                                   LLVMMemoryBufferRef *OutMemBuf,
3141                                                   char **OutMessage);
3142 LLVMBool LLVMCreateMemoryBufferWithSTDIN(LLVMMemoryBufferRef *OutMemBuf,
3143                                          char **OutMessage);
3144 LLVMMemoryBufferRef LLVMCreateMemoryBufferWithMemoryRange(const char *InputData,
3145                                                           size_t InputDataLength,
3146                                                           const char *BufferName,
3147                                                           LLVMBool RequiresNullTerminator);
3148 LLVMMemoryBufferRef LLVMCreateMemoryBufferWithMemoryRangeCopy(const char *InputData,
3149                                                               size_t InputDataLength,
3150                                                               const char *BufferName);
3151 const char *LLVMGetBufferStart(LLVMMemoryBufferRef MemBuf);
3152 size_t LLVMGetBufferSize(LLVMMemoryBufferRef MemBuf);
3153 void LLVMDisposeMemoryBuffer(LLVMMemoryBufferRef MemBuf);
3154
3155 /**
3156  * @}
3157  */
3158
3159 /**
3160  * @defgroup LLVMCCorePassRegistry Pass Registry
3161  *
3162  * @{
3163  */
3164
3165 /** Return the global pass registry, for use with initialization functions.
3166     @see llvm::PassRegistry::getPassRegistry */
3167 LLVMPassRegistryRef LLVMGetGlobalPassRegistry(void);
3168
3169 /**
3170  * @}
3171  */
3172
3173 /**
3174  * @defgroup LLVMCCorePassManagers Pass Managers
3175  *
3176  * @{
3177  */
3178
3179 /** Constructs a new whole-module pass pipeline. This type of pipeline is
3180     suitable for link-time optimization and whole-module transformations.
3181     @see llvm::PassManager::PassManager */
3182 LLVMPassManagerRef LLVMCreatePassManager(void);
3183
3184 /** Constructs a new function-by-function pass pipeline over the module
3185     provider. It does not take ownership of the module provider. This type of
3186     pipeline is suitable for code generation and JIT compilation tasks.
3187     @see llvm::FunctionPassManager::FunctionPassManager */
3188 LLVMPassManagerRef LLVMCreateFunctionPassManagerForModule(LLVMModuleRef M);
3189
3190 /** Deprecated: Use LLVMCreateFunctionPassManagerForModule instead. */
3191 LLVMPassManagerRef LLVMCreateFunctionPassManager(LLVMModuleProviderRef MP);
3192
3193 /** Initializes, executes on the provided module, and finalizes all of the
3194     passes scheduled in the pass manager. Returns 1 if any of the passes
3195     modified the module, 0 otherwise.
3196     @see llvm::PassManager::run(Module&) */
3197 LLVMBool LLVMRunPassManager(LLVMPassManagerRef PM, LLVMModuleRef M);
3198
3199 /** Initializes all of the function passes scheduled in the function pass
3200     manager. Returns 1 if any of the passes modified the module, 0 otherwise.
3201     @see llvm::FunctionPassManager::doInitialization */
3202 LLVMBool LLVMInitializeFunctionPassManager(LLVMPassManagerRef FPM);
3203
3204 /** Executes all of the function passes scheduled in the function pass manager
3205     on the provided function. Returns 1 if any of the passes modified the
3206     function, false otherwise.
3207     @see llvm::FunctionPassManager::run(Function&) */
3208 LLVMBool LLVMRunFunctionPassManager(LLVMPassManagerRef FPM, LLVMValueRef F);
3209
3210 /** Finalizes all of the function passes scheduled in in the function pass
3211     manager. Returns 1 if any of the passes modified the module, 0 otherwise.
3212     @see llvm::FunctionPassManager::doFinalization */
3213 LLVMBool LLVMFinalizeFunctionPassManager(LLVMPassManagerRef FPM);
3214
3215 /** Frees the memory of a pass pipeline. For function pipelines, does not free
3216     the module provider.
3217     @see llvm::PassManagerBase::~PassManagerBase. */
3218 void LLVMDisposePassManager(LLVMPassManagerRef PM);
3219
3220 /**
3221  * @}
3222  */
3223
3224 /**
3225  * @defgroup LLVMCCoreThreading Threading
3226  *
3227  * Handle the structures needed to make LLVM safe for multithreading.
3228  *
3229  * @{
3230  */
3231
3232 /** Deprecated: Multi-threading can only be enabled/disabled with the compile
3233     time define LLVM_ENABLE_THREADS.  This function always returns
3234     LLVMIsMultithreaded(). */
3235 LLVMBool LLVMStartMultithreaded(void);
3236
3237 /** Deprecated: Multi-threading can only be enabled/disabled with the compile
3238     time define LLVM_ENABLE_THREADS. */
3239 void LLVMStopMultithreaded(void);
3240
3241 /** Check whether LLVM is executing in thread-safe mode or not.
3242     @see llvm::llvm_is_multithreaded */
3243 LLVMBool LLVMIsMultithreaded(void);
3244
3245 /**
3246  * @}
3247  */
3248
3249 /**
3250  * @}
3251  */
3252
3253 /**
3254  * @}
3255  */
3256
3257 #ifdef __cplusplus
3258 }
3259 #endif
3260
3261 #endif /* LLVM_C_CORE_H */