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 LLVMAttributeRef LLVMGetStringAttributeAtIndex(LLVMValueRef F,
2021                                                LLVMAttributeIndex Idx,
2022                                                const char *K, unsigned KLen);
2023 void LLVMRemoveEnumAttributeAtIndex(LLVMValueRef F, LLVMAttributeIndex Idx,
2024                                     unsigned KindID);
2025 void LLVMRemoveStringAttributeAtIndex(LLVMValueRef F, LLVMAttributeIndex Idx,
2026                                       const char *K, unsigned KLen);
2027 
2028 /**
2029  * Add a target-dependent attribute to a function
2030  * @see llvm::AttrBuilder::addAttribute()
2031  */
2032 void LLVMAddTargetDependentFunctionAttr(LLVMValueRef Fn, const char *A,
2033                                         const char *V);
2034 
2035 /**
2036  * Obtain an attribute from a function.
2037  *
2038  * @see llvm::Function::getAttributes()
2039  */
2040 LLVMAttribute LLVMGetFunctionAttr(LLVMValueRef Fn);
2041 
2042 /**
2043  * Remove an attribute from a function.
2044  */
2045 void LLVMRemoveFunctionAttr(LLVMValueRef Fn, LLVMAttribute PA);
2046 
2047 /**
2048  * @defgroup LLVMCCoreValueFunctionParameters Function Parameters
2049  *
2050  * Functions in this group relate to arguments/parameters on functions.
2051  *
2052  * Functions in this group expect LLVMValueRef instances that correspond
2053  * to llvm::Function instances.
2054  *
2055  * @{
2056  */
2057 
2058 /**
2059  * Obtain the number of parameters in a function.
2060  *
2061  * @see llvm::Function::arg_size()
2062  */
2063 unsigned LLVMCountParams(LLVMValueRef Fn);
2064 
2065 /**
2066  * Obtain the parameters in a function.
2067  *
2068  * The takes a pointer to a pre-allocated array of LLVMValueRef that is
2069  * at least LLVMCountParams() long. This array will be filled with
2070  * LLVMValueRef instances which correspond to the parameters the
2071  * function receives. Each LLVMValueRef corresponds to a llvm::Argument
2072  * instance.
2073  *
2074  * @see llvm::Function::arg_begin()
2075  */
2076 void LLVMGetParams(LLVMValueRef Fn, LLVMValueRef *Params);
2077 
2078 /**
2079  * Obtain the parameter at the specified index.
2080  *
2081  * Parameters are indexed from 0.
2082  *
2083  * @see llvm::Function::arg_begin()
2084  */
2085 LLVMValueRef LLVMGetParam(LLVMValueRef Fn, unsigned Index);
2086 
2087 /**
2088  * Obtain the function to which this argument belongs.
2089  *
2090  * Unlike other functions in this group, this one takes an LLVMValueRef
2091  * that corresponds to a llvm::Attribute.
2092  *
2093  * The returned LLVMValueRef is the llvm::Function to which this
2094  * argument belongs.
2095  */
2096 LLVMValueRef LLVMGetParamParent(LLVMValueRef Inst);
2097 
2098 /**
2099  * Obtain the first parameter to a function.
2100  *
2101  * @see llvm::Function::arg_begin()
2102  */
2103 LLVMValueRef LLVMGetFirstParam(LLVMValueRef Fn);
2104 
2105 /**
2106  * Obtain the last parameter to a function.
2107  *
2108  * @see llvm::Function::arg_end()
2109  */
2110 LLVMValueRef LLVMGetLastParam(LLVMValueRef Fn);
2111 
2112 /**
2113  * Obtain the next parameter to a function.
2114  *
2115  * This takes an LLVMValueRef obtained from LLVMGetFirstParam() (which is
2116  * actually a wrapped iterator) and obtains the next parameter from the
2117  * underlying iterator.
2118  */
2119 LLVMValueRef LLVMGetNextParam(LLVMValueRef Arg);
2120 
2121 /**
2122  * Obtain the previous parameter to a function.
2123  *
2124  * This is the opposite of LLVMGetNextParam().
2125  */
2126 LLVMValueRef LLVMGetPreviousParam(LLVMValueRef Arg);
2127 
2128 /**
2129  * Add an attribute to a function argument.
2130  *
2131  * @see llvm::Argument::addAttr()
2132  */
2133 void LLVMAddAttribute(LLVMValueRef Arg, LLVMAttribute PA);
2134 
2135 /**
2136  * Remove an attribute from a function argument.
2137  *
2138  * @see llvm::Argument::removeAttr()
2139  */
2140 void LLVMRemoveAttribute(LLVMValueRef Arg, LLVMAttribute PA);
2141 
2142 /**
2143  * Get an attribute from a function argument.
2144  */
2145 LLVMAttribute LLVMGetAttribute(LLVMValueRef Arg);
2146 
2147 /**
2148  * Set the alignment for a function parameter.
2149  *
2150  * @see llvm::Argument::addAttr()
2151  * @see llvm::AttrBuilder::addAlignmentAttr()
2152  */
2153 void LLVMSetParamAlignment(LLVMValueRef Arg, unsigned Align);
2154 
2155 /**
2156  * @}
2157  */
2158 
2159 /**
2160  * @}
2161  */
2162 
2163 /**
2164  * @}
2165  */
2166 
2167 /**
2168  * @}
2169  */
2170 
2171 /**
2172  * @defgroup LLVMCCoreValueMetadata Metadata
2173  *
2174  * @{
2175  */
2176 
2177 /**
2178  * Obtain a MDString value from a context.
2179  *
2180  * The returned instance corresponds to the llvm::MDString class.
2181  *
2182  * The instance is specified by string data of a specified length. The
2183  * string content is copied, so the backing memory can be freed after
2184  * this function returns.
2185  */
2186 LLVMValueRef LLVMMDStringInContext(LLVMContextRef C, const char *Str,
2187                                    unsigned SLen);
2188 
2189 /**
2190  * Obtain a MDString value from the global context.
2191  */
2192 LLVMValueRef LLVMMDString(const char *Str, unsigned SLen);
2193 
2194 /**
2195  * Obtain a MDNode value from a context.
2196  *
2197  * The returned value corresponds to the llvm::MDNode class.
2198  */
2199 LLVMValueRef LLVMMDNodeInContext(LLVMContextRef C, LLVMValueRef *Vals,
2200                                  unsigned Count);
2201 
2202 /**
2203  * Obtain a MDNode value from the global context.
2204  */
2205 LLVMValueRef LLVMMDNode(LLVMValueRef *Vals, unsigned Count);
2206 
2207 /**
2208  * Obtain the underlying string from a MDString value.
2209  *
2210  * @param V Instance to obtain string from.
2211  * @param Length Memory address which will hold length of returned string.
2212  * @return String data in MDString.
2213  */
2214 const char *LLVMGetMDString(LLVMValueRef V, unsigned *Length);
2215 
2216 /**
2217  * Obtain the number of operands from an MDNode value.
2218  *
2219  * @param V MDNode to get number of operands from.
2220  * @return Number of operands of the MDNode.
2221  */
2222 unsigned LLVMGetMDNodeNumOperands(LLVMValueRef V);
2223 
2224 /**
2225  * Obtain the given MDNode's operands.
2226  *
2227  * The passed LLVMValueRef pointer should point to enough memory to hold all of
2228  * the operands of the given MDNode (see LLVMGetMDNodeNumOperands) as
2229  * LLVMValueRefs. This memory will be populated with the LLVMValueRefs of the
2230  * MDNode's operands.
2231  *
2232  * @param V MDNode to get the operands from.
2233  * @param Dest Destination array for operands.
2234  */
2235 void LLVMGetMDNodeOperands(LLVMValueRef V, LLVMValueRef *Dest);
2236 
2237 /**
2238  * @}
2239  */
2240 
2241 /**
2242  * @defgroup LLVMCCoreValueBasicBlock Basic Block
2243  *
2244  * A basic block represents a single entry single exit section of code.
2245  * Basic blocks contain a list of instructions which form the body of
2246  * the block.
2247  *
2248  * Basic blocks belong to functions. They have the type of label.
2249  *
2250  * Basic blocks are themselves values. However, the C API models them as
2251  * LLVMBasicBlockRef.
2252  *
2253  * @see llvm::BasicBlock
2254  *
2255  * @{
2256  */
2257 
2258 /**
2259  * Convert a basic block instance to a value type.
2260  */
2261 LLVMValueRef LLVMBasicBlockAsValue(LLVMBasicBlockRef BB);
2262 
2263 /**
2264  * Determine whether an LLVMValueRef is itself a basic block.
2265  */
2266 LLVMBool LLVMValueIsBasicBlock(LLVMValueRef Val);
2267 
2268 /**
2269  * Convert an LLVMValueRef to an LLVMBasicBlockRef instance.
2270  */
2271 LLVMBasicBlockRef LLVMValueAsBasicBlock(LLVMValueRef Val);
2272 
2273 /**
2274  * Obtain the string name of a basic block.
2275  */
2276 const char *LLVMGetBasicBlockName(LLVMBasicBlockRef BB);
2277 
2278 /**
2279  * Obtain the function to which a basic block belongs.
2280  *
2281  * @see llvm::BasicBlock::getParent()
2282  */
2283 LLVMValueRef LLVMGetBasicBlockParent(LLVMBasicBlockRef BB);
2284 
2285 /**
2286  * Obtain the terminator instruction for a basic block.
2287  *
2288  * If the basic block does not have a terminator (it is not well-formed
2289  * if it doesn't), then NULL is returned.
2290  *
2291  * The returned LLVMValueRef corresponds to a llvm::TerminatorInst.
2292  *
2293  * @see llvm::BasicBlock::getTerminator()
2294  */
2295 LLVMValueRef LLVMGetBasicBlockTerminator(LLVMBasicBlockRef BB);
2296 
2297 /**
2298  * Obtain the number of basic blocks in a function.
2299  *
2300  * @param Fn Function value to operate on.
2301  */
2302 unsigned LLVMCountBasicBlocks(LLVMValueRef Fn);
2303 
2304 /**
2305  * Obtain all of the basic blocks in a function.
2306  *
2307  * This operates on a function value. The BasicBlocks parameter is a
2308  * pointer to a pre-allocated array of LLVMBasicBlockRef of at least
2309  * LLVMCountBasicBlocks() in length. This array is populated with
2310  * LLVMBasicBlockRef instances.
2311  */
2312 void LLVMGetBasicBlocks(LLVMValueRef Fn, LLVMBasicBlockRef *BasicBlocks);
2313 
2314 /**
2315  * Obtain the first basic block in a function.
2316  *
2317  * The returned basic block can be used as an iterator. You will likely
2318  * eventually call into LLVMGetNextBasicBlock() with it.
2319  *
2320  * @see llvm::Function::begin()
2321  */
2322 LLVMBasicBlockRef LLVMGetFirstBasicBlock(LLVMValueRef Fn);
2323 
2324 /**
2325  * Obtain the last basic block in a function.
2326  *
2327  * @see llvm::Function::end()
2328  */
2329 LLVMBasicBlockRef LLVMGetLastBasicBlock(LLVMValueRef Fn);
2330 
2331 /**
2332  * Advance a basic block iterator.
2333  */
2334 LLVMBasicBlockRef LLVMGetNextBasicBlock(LLVMBasicBlockRef BB);
2335 
2336 /**
2337  * Go backwards in a basic block iterator.
2338  */
2339 LLVMBasicBlockRef LLVMGetPreviousBasicBlock(LLVMBasicBlockRef BB);
2340 
2341 /**
2342  * Obtain the basic block that corresponds to the entry point of a
2343  * function.
2344  *
2345  * @see llvm::Function::getEntryBlock()
2346  */
2347 LLVMBasicBlockRef LLVMGetEntryBasicBlock(LLVMValueRef Fn);
2348 
2349 /**
2350  * Append a basic block to the end of a function.
2351  *
2352  * @see llvm::BasicBlock::Create()
2353  */
2354 LLVMBasicBlockRef LLVMAppendBasicBlockInContext(LLVMContextRef C,
2355                                                 LLVMValueRef Fn,
2356                                                 const char *Name);
2357 
2358 /**
2359  * Append a basic block to the end of a function using the global
2360  * context.
2361  *
2362  * @see llvm::BasicBlock::Create()
2363  */
2364 LLVMBasicBlockRef LLVMAppendBasicBlock(LLVMValueRef Fn, const char *Name);
2365 
2366 /**
2367  * Insert a basic block in a function before another basic block.
2368  *
2369  * The function to add to is determined by the function of the
2370  * passed basic block.
2371  *
2372  * @see llvm::BasicBlock::Create()
2373  */
2374 LLVMBasicBlockRef LLVMInsertBasicBlockInContext(LLVMContextRef C,
2375                                                 LLVMBasicBlockRef BB,
2376                                                 const char *Name);
2377 
2378 /**
2379  * Insert a basic block in a function using the global context.
2380  *
2381  * @see llvm::BasicBlock::Create()
2382  */
2383 LLVMBasicBlockRef LLVMInsertBasicBlock(LLVMBasicBlockRef InsertBeforeBB,
2384                                        const char *Name);
2385 
2386 /**
2387  * Remove a basic block from a function and delete it.
2388  *
2389  * This deletes the basic block from its containing function and deletes
2390  * the basic block itself.
2391  *
2392  * @see llvm::BasicBlock::eraseFromParent()
2393  */
2394 void LLVMDeleteBasicBlock(LLVMBasicBlockRef BB);
2395 
2396 /**
2397  * Remove a basic block from a function.
2398  *
2399  * This deletes the basic block from its containing function but keep
2400  * the basic block alive.
2401  *
2402  * @see llvm::BasicBlock::removeFromParent()
2403  */
2404 void LLVMRemoveBasicBlockFromParent(LLVMBasicBlockRef BB);
2405 
2406 /**
2407  * Move a basic block to before another one.
2408  *
2409  * @see llvm::BasicBlock::moveBefore()
2410  */
2411 void LLVMMoveBasicBlockBefore(LLVMBasicBlockRef BB, LLVMBasicBlockRef MovePos);
2412 
2413 /**
2414  * Move a basic block to after another one.
2415  *
2416  * @see llvm::BasicBlock::moveAfter()
2417  */
2418 void LLVMMoveBasicBlockAfter(LLVMBasicBlockRef BB, LLVMBasicBlockRef MovePos);
2419 
2420 /**
2421  * Obtain the first instruction in a basic block.
2422  *
2423  * The returned LLVMValueRef corresponds to a llvm::Instruction
2424  * instance.
2425  */
2426 LLVMValueRef LLVMGetFirstInstruction(LLVMBasicBlockRef BB);
2427 
2428 /**
2429  * Obtain the last instruction in a basic block.
2430  *
2431  * The returned LLVMValueRef corresponds to an LLVM:Instruction.
2432  */
2433 LLVMValueRef LLVMGetLastInstruction(LLVMBasicBlockRef BB);
2434 
2435 /**
2436  * @}
2437  */
2438 
2439 /**
2440  * @defgroup LLVMCCoreValueInstruction Instructions
2441  *
2442  * Functions in this group relate to the inspection and manipulation of
2443  * individual instructions.
2444  *
2445  * In the C++ API, an instruction is modeled by llvm::Instruction. This
2446  * class has a large number of descendents. llvm::Instruction is a
2447  * llvm::Value and in the C API, instructions are modeled by
2448  * LLVMValueRef.
2449  *
2450  * This group also contains sub-groups which operate on specific
2451  * llvm::Instruction types, e.g. llvm::CallInst.
2452  *
2453  * @{
2454  */
2455 
2456 /**
2457  * Determine whether an instruction has any metadata attached.
2458  */
2459 int LLVMHasMetadata(LLVMValueRef Val);
2460 
2461 /**
2462  * Return metadata associated with an instruction value.
2463  */
2464 LLVMValueRef LLVMGetMetadata(LLVMValueRef Val, unsigned KindID);
2465 
2466 /**
2467  * Set metadata associated with an instruction value.
2468  */
2469 void LLVMSetMetadata(LLVMValueRef Val, unsigned KindID, LLVMValueRef Node);
2470 
2471 /**
2472  * Obtain the basic block to which an instruction belongs.
2473  *
2474  * @see llvm::Instruction::getParent()
2475  */
2476 LLVMBasicBlockRef LLVMGetInstructionParent(LLVMValueRef Inst);
2477 
2478 /**
2479  * Obtain the instruction that occurs after the one specified.
2480  *
2481  * The next instruction will be from the same basic block.
2482  *
2483  * If this is the last instruction in a basic block, NULL will be
2484  * returned.
2485  */
2486 LLVMValueRef LLVMGetNextInstruction(LLVMValueRef Inst);
2487 
2488 /**
2489  * Obtain the instruction that occurred before this one.
2490  *
2491  * If the instruction is the first instruction in a basic block, NULL
2492  * will be returned.
2493  */
2494 LLVMValueRef LLVMGetPreviousInstruction(LLVMValueRef Inst);
2495 
2496 /**
2497  * Remove and delete an instruction.
2498  *
2499  * The instruction specified is removed from its containing building
2500  * block but is kept alive.
2501  *
2502  * @see llvm::Instruction::removeFromParent()
2503  */
2504 void LLVMInstructionRemoveFromParent(LLVMValueRef Inst);
2505 
2506 /**
2507  * Remove and delete an instruction.
2508  *
2509  * The instruction specified is removed from its containing building
2510  * block and then deleted.
2511  *
2512  * @see llvm::Instruction::eraseFromParent()
2513  */
2514 void LLVMInstructionEraseFromParent(LLVMValueRef Inst);
2515 
2516 /**
2517  * Obtain the code opcode for an individual instruction.
2518  *
2519  * @see llvm::Instruction::getOpCode()
2520  */
2521 LLVMOpcode LLVMGetInstructionOpcode(LLVMValueRef Inst);
2522 
2523 /**
2524  * Obtain the predicate of an instruction.
2525  *
2526  * This is only valid for instructions that correspond to llvm::ICmpInst
2527  * or llvm::ConstantExpr whose opcode is llvm::Instruction::ICmp.
2528  *
2529  * @see llvm::ICmpInst::getPredicate()
2530  */
2531 LLVMIntPredicate LLVMGetICmpPredicate(LLVMValueRef Inst);
2532 
2533 /**
2534  * Obtain the float predicate of an instruction.
2535  *
2536  * This is only valid for instructions that correspond to llvm::FCmpInst
2537  * or llvm::ConstantExpr whose opcode is llvm::Instruction::FCmp.
2538  *
2539  * @see llvm::FCmpInst::getPredicate()
2540  */
2541 LLVMRealPredicate LLVMGetFCmpPredicate(LLVMValueRef Inst);
2542 
2543 /**
2544  * Create a copy of 'this' instruction that is identical in all ways
2545  * except the following:
2546  *   * The instruction has no parent
2547  *   * The instruction has no name
2548  *
2549  * @see llvm::Instruction::clone()
2550  */
2551 LLVMValueRef LLVMInstructionClone(LLVMValueRef Inst);
2552 
2553 /**
2554  * @defgroup LLVMCCoreValueInstructionCall Call Sites and Invocations
2555  *
2556  * Functions in this group apply to instructions that refer to call
2557  * sites and invocations. These correspond to C++ types in the
2558  * llvm::CallInst class tree.
2559  *
2560  * @{
2561  */
2562 
2563 /**
2564  * Obtain the argument count for a call instruction.
2565  *
2566  * This expects an LLVMValueRef that corresponds to a llvm::CallInst or
2567  * llvm::InvokeInst.
2568  *
2569  * @see llvm::CallInst::getNumArgOperands()
2570  * @see llvm::InvokeInst::getNumArgOperands()
2571  */
2572 unsigned LLVMGetNumArgOperands(LLVMValueRef Instr);
2573 
2574 /**
2575  * Set the calling convention for a call instruction.
2576  *
2577  * This expects an LLVMValueRef that corresponds to a llvm::CallInst or
2578  * llvm::InvokeInst.
2579  *
2580  * @see llvm::CallInst::setCallingConv()
2581  * @see llvm::InvokeInst::setCallingConv()
2582  */
2583 void LLVMSetInstructionCallConv(LLVMValueRef Instr, unsigned CC);
2584 
2585 /**
2586  * Obtain the calling convention for a call instruction.
2587  *
2588  * This is the opposite of LLVMSetInstructionCallConv(). Reads its
2589  * usage.
2590  *
2591  * @see LLVMSetInstructionCallConv()
2592  */
2593 unsigned LLVMGetInstructionCallConv(LLVMValueRef Instr);
2594 
2595 void LLVMAddInstrAttribute(LLVMValueRef Instr, unsigned index, LLVMAttribute);
2596 void LLVMRemoveInstrAttribute(LLVMValueRef Instr, unsigned index,
2597                               LLVMAttribute);
2598 void LLVMSetInstrParamAlignment(LLVMValueRef Instr, unsigned index,
2599                                 unsigned Align);
2600 
2601 void LLVMAddCallSiteAttribute(LLVMValueRef C, LLVMAttributeIndex Idx,
2602                               LLVMAttributeRef A);
2603 LLVMAttributeRef LLVMGetCallSiteEnumAttribute(LLVMValueRef C,
2604                                               LLVMAttributeIndex Idx,
2605                                               unsigned KindID);
2606 LLVMAttributeRef LLVMGetCallSiteStringAttribute(LLVMValueRef C,
2607                                                 LLVMAttributeIndex Idx,
2608                                                 const char *K, unsigned KLen);
2609 void LLVMRemoveCallSiteEnumAttribute(LLVMValueRef C, LLVMAttributeIndex Idx,
2610                                      unsigned KindID);
2611 void LLVMRemoveCallSiteStringAttribute(LLVMValueRef C, LLVMAttributeIndex Idx,
2612                                        const char *K, unsigned KLen);
2613 
2614 /**
2615  * Obtain the pointer to the function invoked by this instruction.
2616  *
2617  * This expects an LLVMValueRef that corresponds to a llvm::CallInst or
2618  * llvm::InvokeInst.
2619  *
2620  * @see llvm::CallInst::getCalledValue()
2621  * @see llvm::InvokeInst::getCalledValue()
2622  */
2623 LLVMValueRef LLVMGetCalledValue(LLVMValueRef Instr);
2624 
2625 /**
2626  * Obtain whether a call instruction is a tail call.
2627  *
2628  * This only works on llvm::CallInst instructions.
2629  *
2630  * @see llvm::CallInst::isTailCall()
2631  */
2632 LLVMBool LLVMIsTailCall(LLVMValueRef CallInst);
2633 
2634 /**
2635  * Set whether a call instruction is a tail call.
2636  *
2637  * This only works on llvm::CallInst instructions.
2638  *
2639  * @see llvm::CallInst::setTailCall()
2640  */
2641 void LLVMSetTailCall(LLVMValueRef CallInst, LLVMBool IsTailCall);
2642 
2643 /**
2644  * Return the normal destination basic block.
2645  *
2646  * This only works on llvm::InvokeInst instructions.
2647  *
2648  * @see llvm::InvokeInst::getNormalDest()
2649  */
2650 LLVMBasicBlockRef LLVMGetNormalDest(LLVMValueRef InvokeInst);
2651 
2652 /**
2653  * Return the unwind destination basic block.
2654  *
2655  * This only works on llvm::InvokeInst instructions.
2656  *
2657  * @see llvm::InvokeInst::getUnwindDest()
2658  */
2659 LLVMBasicBlockRef LLVMGetUnwindDest(LLVMValueRef InvokeInst);
2660 
2661 /**
2662  * Set the normal destination basic block.
2663  *
2664  * This only works on llvm::InvokeInst instructions.
2665  *
2666  * @see llvm::InvokeInst::setNormalDest()
2667  */
2668 void LLVMSetNormalDest(LLVMValueRef InvokeInst, LLVMBasicBlockRef B);
2669 
2670 /**
2671  * Set the unwind destination basic block.
2672  *
2673  * This only works on llvm::InvokeInst instructions.
2674  *
2675  * @see llvm::InvokeInst::setUnwindDest()
2676  */
2677 void LLVMSetUnwindDest(LLVMValueRef InvokeInst, LLVMBasicBlockRef B);
2678 
2679 /**
2680  * @}
2681  */
2682 
2683 /**
2684  * @defgroup LLVMCCoreValueInstructionTerminator Terminators
2685  *
2686  * Functions in this group only apply to instructions that map to
2687  * llvm::TerminatorInst instances.
2688  *
2689  * @{
2690  */
2691 
2692 /**
2693  * Return the number of successors that this terminator has.
2694  *
2695  * @see llvm::TerminatorInst::getNumSuccessors
2696  */
2697 unsigned LLVMGetNumSuccessors(LLVMValueRef Term);
2698 
2699 /**
2700  * Return the specified successor.
2701  *
2702  * @see llvm::TerminatorInst::getSuccessor
2703  */
2704 LLVMBasicBlockRef LLVMGetSuccessor(LLVMValueRef Term, unsigned i);
2705 
2706 /**
2707  * Update the specified successor to point at the provided block.
2708  *
2709  * @see llvm::TerminatorInst::setSuccessor
2710  */
2711 void LLVMSetSuccessor(LLVMValueRef Term, unsigned i, LLVMBasicBlockRef block);
2712 
2713 /**
2714  * Return if a branch is conditional.
2715  *
2716  * This only works on llvm::BranchInst instructions.
2717  *
2718  * @see llvm::BranchInst::isConditional
2719  */
2720 LLVMBool LLVMIsConditional(LLVMValueRef Branch);
2721 
2722 /**
2723  * Return the condition of a branch instruction.
2724  *
2725  * This only works on llvm::BranchInst instructions.
2726  *
2727  * @see llvm::BranchInst::getCondition
2728  */
2729 LLVMValueRef LLVMGetCondition(LLVMValueRef Branch);
2730 
2731 /**
2732  * Set the condition of a branch instruction.
2733  *
2734  * This only works on llvm::BranchInst instructions.
2735  *
2736  * @see llvm::BranchInst::setCondition
2737  */
2738 void LLVMSetCondition(LLVMValueRef Branch, LLVMValueRef Cond);
2739 
2740 /**
2741  * Obtain the default destination basic block of a switch instruction.
2742  *
2743  * This only works on llvm::SwitchInst instructions.
2744  *
2745  * @see llvm::SwitchInst::getDefaultDest()
2746  */
2747 LLVMBasicBlockRef LLVMGetSwitchDefaultDest(LLVMValueRef SwitchInstr);
2748 
2749 /**
2750  * @}
2751  */
2752 
2753 /**
2754  * @defgroup LLVMCCoreValueInstructionAlloca Allocas
2755  *
2756  * Functions in this group only apply to instructions that map to
2757  * llvm::AllocaInst instances.
2758  *
2759  * @{
2760  */
2761 
2762 /**
2763  * Obtain the type that is being allocated by the alloca instruction.
2764  */
2765 LLVMTypeRef LLVMGetAllocatedType(LLVMValueRef Alloca);
2766 
2767 /**
2768  * @}
2769  */
2770 
2771 /**
2772  * @defgroup LLVMCCoreValueInstructionGetElementPointer GEPs
2773  *
2774  * Functions in this group only apply to instructions that map to
2775  * llvm::GetElementPtrInst instances.
2776  *
2777  * @{
2778  */
2779 
2780 /**
2781  * Check whether the given GEP instruction is inbounds.
2782  */
2783 LLVMBool LLVMIsInBounds(LLVMValueRef GEP);
2784 
2785 /**
2786  * Set the given GEP instruction to be inbounds or not.
2787  */
2788 void LLVMSetIsInBounds(LLVMValueRef GEP, LLVMBool InBounds);
2789 
2790 /**
2791  * @}
2792  */
2793 
2794 /**
2795  * @defgroup LLVMCCoreValueInstructionPHINode PHI Nodes
2796  *
2797  * Functions in this group only apply to instructions that map to
2798  * llvm::PHINode instances.
2799  *
2800  * @{
2801  */
2802 
2803 /**
2804  * Add an incoming value to the end of a PHI list.
2805  */
2806 void LLVMAddIncoming(LLVMValueRef PhiNode, LLVMValueRef *IncomingValues,
2807                      LLVMBasicBlockRef *IncomingBlocks, unsigned Count);
2808 
2809 /**
2810  * Obtain the number of incoming basic blocks to a PHI node.
2811  */
2812 unsigned LLVMCountIncoming(LLVMValueRef PhiNode);
2813 
2814 /**
2815  * Obtain an incoming value to a PHI node as an LLVMValueRef.
2816  */
2817 LLVMValueRef LLVMGetIncomingValue(LLVMValueRef PhiNode, unsigned Index);
2818 
2819 /**
2820  * Obtain an incoming value to a PHI node as an LLVMBasicBlockRef.
2821  */
2822 LLVMBasicBlockRef LLVMGetIncomingBlock(LLVMValueRef PhiNode, unsigned Index);
2823 
2824 /**
2825  * @}
2826  */
2827 
2828 /**
2829  * @defgroup LLVMCCoreValueInstructionExtractValue ExtractValue
2830  * @defgroup LLVMCCoreValueInstructionInsertValue InsertValue
2831  *
2832  * Functions in this group only apply to instructions that map to
2833  * llvm::ExtractValue and llvm::InsertValue instances.
2834  *
2835  * @{
2836  */
2837 
2838 /**
2839  * Obtain the number of indices.
2840  * NB: This also works on GEP.
2841  */
2842 unsigned LLVMGetNumIndices(LLVMValueRef Inst);
2843 
2844 /**
2845  * Obtain the indices as an array.
2846  */
2847 const unsigned *LLVMGetIndices(LLVMValueRef Inst);
2848 
2849 /**
2850  * @}
2851  */
2852 
2853 /**
2854  * @}
2855  */
2856 
2857 /**
2858  * @}
2859  */
2860 
2861 /**
2862  * @defgroup LLVMCCoreInstructionBuilder Instruction Builders
2863  *
2864  * An instruction builder represents a point within a basic block and is
2865  * the exclusive means of building instructions using the C interface.
2866  *
2867  * @{
2868  */
2869 
2870 LLVMBuilderRef LLVMCreateBuilderInContext(LLVMContextRef C);
2871 LLVMBuilderRef LLVMCreateBuilder(void);
2872 void LLVMPositionBuilder(LLVMBuilderRef Builder, LLVMBasicBlockRef Block,
2873                          LLVMValueRef Instr);
2874 void LLVMPositionBuilderBefore(LLVMBuilderRef Builder, LLVMValueRef Instr);
2875 void LLVMPositionBuilderAtEnd(LLVMBuilderRef Builder, LLVMBasicBlockRef Block);
2876 LLVMBasicBlockRef LLVMGetInsertBlock(LLVMBuilderRef Builder);
2877 void LLVMClearInsertionPosition(LLVMBuilderRef Builder);
2878 void LLVMInsertIntoBuilder(LLVMBuilderRef Builder, LLVMValueRef Instr);
2879 void LLVMInsertIntoBuilderWithName(LLVMBuilderRef Builder, LLVMValueRef Instr,
2880                                    const char *Name);
2881 void LLVMDisposeBuilder(LLVMBuilderRef Builder);
2882 
2883 /* Metadata */
2884 void LLVMSetCurrentDebugLocation(LLVMBuilderRef Builder, LLVMValueRef L);
2885 LLVMValueRef LLVMGetCurrentDebugLocation(LLVMBuilderRef Builder);
2886 void LLVMSetInstDebugLocation(LLVMBuilderRef Builder, LLVMValueRef Inst);
2887 
2888 /* Terminators */
2889 LLVMValueRef LLVMBuildRetVoid(LLVMBuilderRef);
2890 LLVMValueRef LLVMBuildRet(LLVMBuilderRef, LLVMValueRef V);
2891 LLVMValueRef LLVMBuildAggregateRet(LLVMBuilderRef, LLVMValueRef *RetVals,
2892                                    unsigned N);
2893 LLVMValueRef LLVMBuildBr(LLVMBuilderRef, LLVMBasicBlockRef Dest);
2894 LLVMValueRef LLVMBuildCondBr(LLVMBuilderRef, LLVMValueRef If,
2895                              LLVMBasicBlockRef Then, LLVMBasicBlockRef Else);
2896 LLVMValueRef LLVMBuildSwitch(LLVMBuilderRef, LLVMValueRef V,
2897                              LLVMBasicBlockRef Else, unsigned NumCases);
2898 LLVMValueRef LLVMBuildIndirectBr(LLVMBuilderRef B, LLVMValueRef Addr,
2899                                  unsigned NumDests);
2900 LLVMValueRef LLVMBuildInvoke(LLVMBuilderRef, LLVMValueRef Fn,
2901                              LLVMValueRef *Args, unsigned NumArgs,
2902                              LLVMBasicBlockRef Then, LLVMBasicBlockRef Catch,
2903                              const char *Name);
2904 LLVMValueRef LLVMBuildLandingPad(LLVMBuilderRef B, LLVMTypeRef Ty,
2905                                  LLVMValueRef PersFn, unsigned NumClauses,
2906                                  const char *Name);
2907 LLVMValueRef LLVMBuildResume(LLVMBuilderRef B, LLVMValueRef Exn);
2908 LLVMValueRef LLVMBuildUnreachable(LLVMBuilderRef);
2909 
2910 /* Add a case to the switch instruction */
2911 void LLVMAddCase(LLVMValueRef Switch, LLVMValueRef OnVal,
2912                  LLVMBasicBlockRef Dest);
2913 
2914 /* Add a destination to the indirectbr instruction */
2915 void LLVMAddDestination(LLVMValueRef IndirectBr, LLVMBasicBlockRef Dest);
2916 
2917 /* Get the number of clauses on the landingpad instruction */
2918 unsigned LLVMGetNumClauses(LLVMValueRef LandingPad);
2919 
2920 /* Get the value of the clause at idnex Idx on the landingpad instruction */
2921 LLVMValueRef LLVMGetClause(LLVMValueRef LandingPad, unsigned Idx);
2922 
2923 /* Add a catch or filter clause to the landingpad instruction */
2924 void LLVMAddClause(LLVMValueRef LandingPad, LLVMValueRef ClauseVal);
2925 
2926 /* Get the 'cleanup' flag in the landingpad instruction */
2927 LLVMBool LLVMIsCleanup(LLVMValueRef LandingPad);
2928 
2929 /* Set the 'cleanup' flag in the landingpad instruction */
2930 void LLVMSetCleanup(LLVMValueRef LandingPad, LLVMBool Val);
2931 
2932 /* Arithmetic */
2933 LLVMValueRef LLVMBuildAdd(LLVMBuilderRef, LLVMValueRef LHS, LLVMValueRef RHS,
2934                           const char *Name);
2935 LLVMValueRef LLVMBuildNSWAdd(LLVMBuilderRef, LLVMValueRef LHS, LLVMValueRef RHS,
2936                              const char *Name);
2937 LLVMValueRef LLVMBuildNUWAdd(LLVMBuilderRef, LLVMValueRef LHS, LLVMValueRef RHS,
2938                              const char *Name);
2939 LLVMValueRef LLVMBuildFAdd(LLVMBuilderRef, LLVMValueRef LHS, LLVMValueRef RHS,
2940                            const char *Name);
2941 LLVMValueRef LLVMBuildSub(LLVMBuilderRef, LLVMValueRef LHS, LLVMValueRef RHS,
2942                           const char *Name);
2943 LLVMValueRef LLVMBuildNSWSub(LLVMBuilderRef, LLVMValueRef LHS, LLVMValueRef RHS,
2944                              const char *Name);
2945 LLVMValueRef LLVMBuildNUWSub(LLVMBuilderRef, LLVMValueRef LHS, LLVMValueRef RHS,
2946                              const char *Name);
2947 LLVMValueRef LLVMBuildFSub(LLVMBuilderRef, LLVMValueRef LHS, LLVMValueRef RHS,
2948                            const char *Name);
2949 LLVMValueRef LLVMBuildMul(LLVMBuilderRef, LLVMValueRef LHS, LLVMValueRef RHS,
2950                           const char *Name);
2951 LLVMValueRef LLVMBuildNSWMul(LLVMBuilderRef, LLVMValueRef LHS, LLVMValueRef RHS,
2952                              const char *Name);
2953 LLVMValueRef LLVMBuildNUWMul(LLVMBuilderRef, LLVMValueRef LHS, LLVMValueRef RHS,
2954                              const char *Name);
2955 LLVMValueRef LLVMBuildFMul(LLVMBuilderRef, LLVMValueRef LHS, LLVMValueRef RHS,
2956                            const char *Name);
2957 LLVMValueRef LLVMBuildUDiv(LLVMBuilderRef, LLVMValueRef LHS, LLVMValueRef RHS,
2958                            const char *Name);
2959 LLVMValueRef LLVMBuildSDiv(LLVMBuilderRef, LLVMValueRef LHS, LLVMValueRef RHS,
2960                            const char *Name);
2961 LLVMValueRef LLVMBuildExactSDiv(LLVMBuilderRef, LLVMValueRef LHS, LLVMValueRef RHS,
2962                                 const char *Name);
2963 LLVMValueRef LLVMBuildFDiv(LLVMBuilderRef, LLVMValueRef LHS, LLVMValueRef RHS,
2964                            const char *Name);
2965 LLVMValueRef LLVMBuildURem(LLVMBuilderRef, LLVMValueRef LHS, LLVMValueRef RHS,
2966                            const char *Name);
2967 LLVMValueRef LLVMBuildSRem(LLVMBuilderRef, LLVMValueRef LHS, LLVMValueRef RHS,
2968                            const char *Name);
2969 LLVMValueRef LLVMBuildFRem(LLVMBuilderRef, LLVMValueRef LHS, LLVMValueRef RHS,
2970                            const char *Name);
2971 LLVMValueRef LLVMBuildShl(LLVMBuilderRef, LLVMValueRef LHS, LLVMValueRef RHS,
2972                            const char *Name);
2973 LLVMValueRef LLVMBuildLShr(LLVMBuilderRef, LLVMValueRef LHS, LLVMValueRef RHS,
2974                            const char *Name);
2975 LLVMValueRef LLVMBuildAShr(LLVMBuilderRef, LLVMValueRef LHS, LLVMValueRef RHS,
2976                            const char *Name);
2977 LLVMValueRef LLVMBuildAnd(LLVMBuilderRef, LLVMValueRef LHS, LLVMValueRef RHS,
2978                           const char *Name);
2979 LLVMValueRef LLVMBuildOr(LLVMBuilderRef, LLVMValueRef LHS, LLVMValueRef RHS,
2980                           const char *Name);
2981 LLVMValueRef LLVMBuildXor(LLVMBuilderRef, LLVMValueRef LHS, LLVMValueRef RHS,
2982                           const char *Name);
2983 LLVMValueRef LLVMBuildBinOp(LLVMBuilderRef B, LLVMOpcode Op,
2984                             LLVMValueRef LHS, LLVMValueRef RHS,
2985                             const char *Name);
2986 LLVMValueRef LLVMBuildNeg(LLVMBuilderRef, LLVMValueRef V, const char *Name);
2987 LLVMValueRef LLVMBuildNSWNeg(LLVMBuilderRef B, LLVMValueRef V,
2988                              const char *Name);
2989 LLVMValueRef LLVMBuildNUWNeg(LLVMBuilderRef B, LLVMValueRef V,
2990                              const char *Name);
2991 LLVMValueRef LLVMBuildFNeg(LLVMBuilderRef, LLVMValueRef V, const char *Name);
2992 LLVMValueRef LLVMBuildNot(LLVMBuilderRef, LLVMValueRef V, const char *Name);
2993 
2994 /* Memory */
2995 LLVMValueRef LLVMBuildMalloc(LLVMBuilderRef, LLVMTypeRef Ty, const char *Name);
2996 LLVMValueRef LLVMBuildArrayMalloc(LLVMBuilderRef, LLVMTypeRef Ty,
2997                                   LLVMValueRef Val, const char *Name);
2998 LLVMValueRef LLVMBuildAlloca(LLVMBuilderRef, LLVMTypeRef Ty, const char *Name);
2999 LLVMValueRef LLVMBuildArrayAlloca(LLVMBuilderRef, LLVMTypeRef Ty,
3000                                   LLVMValueRef Val, const char *Name);
3001 LLVMValueRef LLVMBuildFree(LLVMBuilderRef, LLVMValueRef PointerVal);
3002 LLVMValueRef LLVMBuildLoad(LLVMBuilderRef, LLVMValueRef PointerVal,
3003                            const char *Name);
3004 LLVMValueRef LLVMBuildStore(LLVMBuilderRef, LLVMValueRef Val, LLVMValueRef Ptr);
3005 LLVMValueRef LLVMBuildGEP(LLVMBuilderRef B, LLVMValueRef Pointer,
3006                           LLVMValueRef *Indices, unsigned NumIndices,
3007                           const char *Name);
3008 LLVMValueRef LLVMBuildInBoundsGEP(LLVMBuilderRef B, LLVMValueRef Pointer,
3009                                   LLVMValueRef *Indices, unsigned NumIndices,
3010                                   const char *Name);
3011 LLVMValueRef LLVMBuildStructGEP(LLVMBuilderRef B, LLVMValueRef Pointer,
3012                                 unsigned Idx, const char *Name);
3013 LLVMValueRef LLVMBuildGlobalString(LLVMBuilderRef B, const char *Str,
3014                                    const char *Name);
3015 LLVMValueRef LLVMBuildGlobalStringPtr(LLVMBuilderRef B, const char *Str,
3016                                       const char *Name);
3017 LLVMBool LLVMGetVolatile(LLVMValueRef MemoryAccessInst);
3018 void LLVMSetVolatile(LLVMValueRef MemoryAccessInst, LLVMBool IsVolatile);
3019 LLVMAtomicOrdering LLVMGetOrdering(LLVMValueRef MemoryAccessInst);
3020 void LLVMSetOrdering(LLVMValueRef MemoryAccessInst, LLVMAtomicOrdering Ordering);
3021 
3022 /* Casts */
3023 LLVMValueRef LLVMBuildTrunc(LLVMBuilderRef, LLVMValueRef Val,
3024                             LLVMTypeRef DestTy, const char *Name);
3025 LLVMValueRef LLVMBuildZExt(LLVMBuilderRef, LLVMValueRef Val,
3026                            LLVMTypeRef DestTy, const char *Name);
3027 LLVMValueRef LLVMBuildSExt(LLVMBuilderRef, LLVMValueRef Val,
3028                            LLVMTypeRef DestTy, const char *Name);
3029 LLVMValueRef LLVMBuildFPToUI(LLVMBuilderRef, LLVMValueRef Val,
3030                              LLVMTypeRef DestTy, const char *Name);
3031 LLVMValueRef LLVMBuildFPToSI(LLVMBuilderRef, LLVMValueRef Val,
3032                              LLVMTypeRef DestTy, const char *Name);
3033 LLVMValueRef LLVMBuildUIToFP(LLVMBuilderRef, LLVMValueRef Val,
3034                              LLVMTypeRef DestTy, const char *Name);
3035 LLVMValueRef LLVMBuildSIToFP(LLVMBuilderRef, LLVMValueRef Val,
3036                              LLVMTypeRef DestTy, const char *Name);
3037 LLVMValueRef LLVMBuildFPTrunc(LLVMBuilderRef, LLVMValueRef Val,
3038                               LLVMTypeRef DestTy, const char *Name);
3039 LLVMValueRef LLVMBuildFPExt(LLVMBuilderRef, LLVMValueRef Val,
3040                             LLVMTypeRef DestTy, const char *Name);
3041 LLVMValueRef LLVMBuildPtrToInt(LLVMBuilderRef, LLVMValueRef Val,
3042                                LLVMTypeRef DestTy, const char *Name);
3043 LLVMValueRef LLVMBuildIntToPtr(LLVMBuilderRef, LLVMValueRef Val,
3044                                LLVMTypeRef DestTy, const char *Name);
3045 LLVMValueRef LLVMBuildBitCast(LLVMBuilderRef, LLVMValueRef Val,
3046                               LLVMTypeRef DestTy, const char *Name);
3047 LLVMValueRef LLVMBuildAddrSpaceCast(LLVMBuilderRef, LLVMValueRef Val,
3048                                     LLVMTypeRef DestTy, const char *Name);
3049 LLVMValueRef LLVMBuildZExtOrBitCast(LLVMBuilderRef, LLVMValueRef Val,
3050                                     LLVMTypeRef DestTy, const char *Name);
3051 LLVMValueRef LLVMBuildSExtOrBitCast(LLVMBuilderRef, LLVMValueRef Val,
3052                                     LLVMTypeRef DestTy, const char *Name);
3053 LLVMValueRef LLVMBuildTruncOrBitCast(LLVMBuilderRef, LLVMValueRef Val,
3054                                      LLVMTypeRef DestTy, const char *Name);
3055 LLVMValueRef LLVMBuildCast(LLVMBuilderRef B, LLVMOpcode Op, LLVMValueRef Val,
3056                            LLVMTypeRef DestTy, const char *Name);
3057 LLVMValueRef LLVMBuildPointerCast(LLVMBuilderRef, LLVMValueRef Val,
3058                                   LLVMTypeRef DestTy, const char *Name);
3059 LLVMValueRef LLVMBuildIntCast(LLVMBuilderRef, LLVMValueRef Val, /*Signed cast!*/
3060                               LLVMTypeRef DestTy, const char *Name);
3061 LLVMValueRef LLVMBuildFPCast(LLVMBuilderRef, LLVMValueRef Val,
3062                              LLVMTypeRef DestTy, const char *Name);
3063 
3064 /* Comparisons */
3065 LLVMValueRef LLVMBuildICmp(LLVMBuilderRef, LLVMIntPredicate Op,
3066                            LLVMValueRef LHS, LLVMValueRef RHS,
3067                            const char *Name);
3068 LLVMValueRef LLVMBuildFCmp(LLVMBuilderRef, LLVMRealPredicate Op,
3069                            LLVMValueRef LHS, LLVMValueRef RHS,
3070                            const char *Name);
3071 
3072 /* Miscellaneous instructions */
3073 LLVMValueRef LLVMBuildPhi(LLVMBuilderRef, LLVMTypeRef Ty, const char *Name);
3074 LLVMValueRef LLVMBuildCall(LLVMBuilderRef, LLVMValueRef Fn,
3075                            LLVMValueRef *Args, unsigned NumArgs,
3076                            const char *Name);
3077 LLVMValueRef LLVMBuildSelect(LLVMBuilderRef, LLVMValueRef If,
3078                              LLVMValueRef Then, LLVMValueRef Else,
3079                              const char *Name);
3080 LLVMValueRef LLVMBuildVAArg(LLVMBuilderRef, LLVMValueRef List, LLVMTypeRef Ty,
3081                             const char *Name);
3082 LLVMValueRef LLVMBuildExtractElement(LLVMBuilderRef, LLVMValueRef VecVal,
3083                                      LLVMValueRef Index, const char *Name);
3084 LLVMValueRef LLVMBuildInsertElement(LLVMBuilderRef, LLVMValueRef VecVal,
3085                                     LLVMValueRef EltVal, LLVMValueRef Index,
3086                                     const char *Name);
3087 LLVMValueRef LLVMBuildShuffleVector(LLVMBuilderRef, LLVMValueRef V1,
3088                                     LLVMValueRef V2, LLVMValueRef Mask,
3089                                     const char *Name);
3090 LLVMValueRef LLVMBuildExtractValue(LLVMBuilderRef, LLVMValueRef AggVal,
3091                                    unsigned Index, const char *Name);
3092 LLVMValueRef LLVMBuildInsertValue(LLVMBuilderRef, LLVMValueRef AggVal,
3093                                   LLVMValueRef EltVal, unsigned Index,
3094                                   const char *Name);
3095 
3096 LLVMValueRef LLVMBuildIsNull(LLVMBuilderRef, LLVMValueRef Val,
3097                              const char *Name);
3098 LLVMValueRef LLVMBuildIsNotNull(LLVMBuilderRef, LLVMValueRef Val,
3099                                 const char *Name);
3100 LLVMValueRef LLVMBuildPtrDiff(LLVMBuilderRef, LLVMValueRef LHS,
3101                               LLVMValueRef RHS, const char *Name);
3102 LLVMValueRef LLVMBuildFence(LLVMBuilderRef B, LLVMAtomicOrdering ordering,
3103                             LLVMBool singleThread, const char *Name);
3104 LLVMValueRef LLVMBuildAtomicRMW(LLVMBuilderRef B, LLVMAtomicRMWBinOp op,
3105                                 LLVMValueRef PTR, LLVMValueRef Val,
3106                                 LLVMAtomicOrdering ordering,
3107                                 LLVMBool singleThread);
3108 LLVMValueRef LLVMBuildAtomicCmpXchg(LLVMBuilderRef B, LLVMValueRef Ptr,
3109                                     LLVMValueRef Cmp, LLVMValueRef New,
3110                                     LLVMAtomicOrdering SuccessOrdering,
3111                                     LLVMAtomicOrdering FailureOrdering,
3112                                     LLVMBool SingleThread);
3113 
3114 LLVMBool LLVMIsAtomicSingleThread(LLVMValueRef AtomicInst);
3115 void LLVMSetAtomicSingleThread(LLVMValueRef AtomicInst, LLVMBool SingleThread);
3116 
3117 LLVMAtomicOrdering LLVMGetCmpXchgSuccessOrdering(LLVMValueRef CmpXchgInst);
3118 void LLVMSetCmpXchgSuccessOrdering(LLVMValueRef CmpXchgInst,
3119                                    LLVMAtomicOrdering Ordering);
3120 LLVMAtomicOrdering LLVMGetCmpXchgFailureOrdering(LLVMValueRef CmpXchgInst);
3121 void LLVMSetCmpXchgFailureOrdering(LLVMValueRef CmpXchgInst,
3122                                    LLVMAtomicOrdering Ordering);
3123 
3124 /**
3125  * @}
3126  */
3127 
3128 /**
3129  * @defgroup LLVMCCoreModuleProvider Module Providers
3130  *
3131  * @{
3132  */
3133 
3134 /**
3135  * Changes the type of M so it can be passed to FunctionPassManagers and the
3136  * JIT.  They take ModuleProviders for historical reasons.
3137  */
3138 LLVMModuleProviderRef
3139 LLVMCreateModuleProviderForExistingModule(LLVMModuleRef M);
3140 
3141 /**
3142  * Destroys the module M.
3143  */
3144 void LLVMDisposeModuleProvider(LLVMModuleProviderRef M);
3145 
3146 /**
3147  * @}
3148  */
3149 
3150 /**
3151  * @defgroup LLVMCCoreMemoryBuffers Memory Buffers
3152  *
3153  * @{
3154  */
3155 
3156 LLVMBool LLVMCreateMemoryBufferWithContentsOfFile(const char *Path,
3157                                                   LLVMMemoryBufferRef *OutMemBuf,
3158                                                   char **OutMessage);
3159 LLVMBool LLVMCreateMemoryBufferWithSTDIN(LLVMMemoryBufferRef *OutMemBuf,
3160                                          char **OutMessage);
3161 LLVMMemoryBufferRef LLVMCreateMemoryBufferWithMemoryRange(const char *InputData,
3162                                                           size_t InputDataLength,
3163                                                           const char *BufferName,
3164                                                           LLVMBool RequiresNullTerminator);
3165 LLVMMemoryBufferRef LLVMCreateMemoryBufferWithMemoryRangeCopy(const char *InputData,
3166                                                               size_t InputDataLength,
3167                                                               const char *BufferName);
3168 const char *LLVMGetBufferStart(LLVMMemoryBufferRef MemBuf);
3169 size_t LLVMGetBufferSize(LLVMMemoryBufferRef MemBuf);
3170 void LLVMDisposeMemoryBuffer(LLVMMemoryBufferRef MemBuf);
3171 
3172 /**
3173  * @}
3174  */
3175 
3176 /**
3177  * @defgroup LLVMCCorePassRegistry Pass Registry
3178  *
3179  * @{
3180  */
3181 
3182 /** Return the global pass registry, for use with initialization functions.
3183     @see llvm::PassRegistry::getPassRegistry */
3184 LLVMPassRegistryRef LLVMGetGlobalPassRegistry(void);
3185 
3186 /**
3187  * @}
3188  */
3189 
3190 /**
3191  * @defgroup LLVMCCorePassManagers Pass Managers
3192  *
3193  * @{
3194  */
3195 
3196 /** Constructs a new whole-module pass pipeline. This type of pipeline is
3197     suitable for link-time optimization and whole-module transformations.
3198     @see llvm::PassManager::PassManager */
3199 LLVMPassManagerRef LLVMCreatePassManager(void);
3200 
3201 /** Constructs a new function-by-function pass pipeline over the module
3202     provider. It does not take ownership of the module provider. This type of
3203     pipeline is suitable for code generation and JIT compilation tasks.
3204     @see llvm::FunctionPassManager::FunctionPassManager */
3205 LLVMPassManagerRef LLVMCreateFunctionPassManagerForModule(LLVMModuleRef M);
3206 
3207 /** Deprecated: Use LLVMCreateFunctionPassManagerForModule instead. */
3208 LLVMPassManagerRef LLVMCreateFunctionPassManager(LLVMModuleProviderRef MP);
3209 
3210 /** Initializes, executes on the provided module, and finalizes all of the
3211     passes scheduled in the pass manager. Returns 1 if any of the passes
3212     modified the module, 0 otherwise.
3213     @see llvm::PassManager::run(Module&) */
3214 LLVMBool LLVMRunPassManager(LLVMPassManagerRef PM, LLVMModuleRef M);
3215 
3216 /** Initializes all of the function passes scheduled in the function pass
3217     manager. Returns 1 if any of the passes modified the module, 0 otherwise.
3218     @see llvm::FunctionPassManager::doInitialization */
3219 LLVMBool LLVMInitializeFunctionPassManager(LLVMPassManagerRef FPM);
3220 
3221 /** Executes all of the function passes scheduled in the function pass manager
3222     on the provided function. Returns 1 if any of the passes modified the
3223     function, false otherwise.
3224     @see llvm::FunctionPassManager::run(Function&) */
3225 LLVMBool LLVMRunFunctionPassManager(LLVMPassManagerRef FPM, LLVMValueRef F);
3226 
3227 /** Finalizes all of the function passes scheduled in in the function pass
3228     manager. Returns 1 if any of the passes modified the module, 0 otherwise.
3229     @see llvm::FunctionPassManager::doFinalization */
3230 LLVMBool LLVMFinalizeFunctionPassManager(LLVMPassManagerRef FPM);
3231 
3232 /** Frees the memory of a pass pipeline. For function pipelines, does not free
3233     the module provider.
3234     @see llvm::PassManagerBase::~PassManagerBase. */
3235 void LLVMDisposePassManager(LLVMPassManagerRef PM);
3236 
3237 /**
3238  * @}
3239  */
3240 
3241 /**
3242  * @defgroup LLVMCCoreThreading Threading
3243  *
3244  * Handle the structures needed to make LLVM safe for multithreading.
3245  *
3246  * @{
3247  */
3248 
3249 /** Deprecated: Multi-threading can only be enabled/disabled with the compile
3250     time define LLVM_ENABLE_THREADS.  This function always returns
3251     LLVMIsMultithreaded(). */
3252 LLVMBool LLVMStartMultithreaded(void);
3253 
3254 /** Deprecated: Multi-threading can only be enabled/disabled with the compile
3255     time define LLVM_ENABLE_THREADS. */
3256 void LLVMStopMultithreaded(void);
3257 
3258 /** Check whether LLVM is executing in thread-safe mode or not.
3259     @see llvm::llvm_is_multithreaded */
3260 LLVMBool LLVMIsMultithreaded(void);
3261 
3262 /**
3263  * @}
3264  */
3265 
3266 /**
3267  * @}
3268  */
3269 
3270 /**
3271  * @}
3272  */
3273 
3274 #ifdef __cplusplus
3275 }
3276 #endif
3277 
3278 #endif /* LLVM_C_CORE_H */
3279