/*===-- llvm-c/Support.h - C Interface Types declarations ---------*- C -*-===*\ |* *| |* Part of the LLVM Project, under the Apache License v2.0 with LLVM *| |* Exceptions. *| |* See https://llvm.org/LICENSE.txt for license information. *| |* SPDX-License-Identifier: Apache-2.0 WITH LLVM-exception *| |* *| |*===----------------------------------------------------------------------===*| |* *| |* This file defines types used by the C interface to LLVM. *| |* *| \*===----------------------------------------------------------------------===*/ #ifndef LLVM_C_TYPES_H #define LLVM_C_TYPES_H #include "llvm-c/DataTypes.h" #ifdef __cplusplus extern "C" { #endif /** * @defgroup LLVMCSupportTypes Types and Enumerations * * @{ */ typedef int LLVMBool; /* Opaque types. */ /** * LLVM uses a polymorphic type hierarchy which C cannot represent, therefore * parameters must be passed as base types. Despite the declared types, most * of the functions provided operate only on branches of the type hierarchy. * The declared parameter names are descriptive and specify which type is * required. Additionally, each type hierarchy is documented along with the * functions that operate upon it. For more detail, refer to LLVM's C++ code. * If in doubt, refer to Core.cpp, which performs parameter downcasts in the * form unwrap(Param). */ /** * Used to pass regions of memory through LLVM interfaces. * * @see llvm::MemoryBuffer */ typedef struct LLVMOpaqueMemoryBuffer *LLVMMemoryBufferRef; /** * The top-level container for all LLVM global data. See the LLVMContext class. */ typedef struct LLVMOpaqueContext *LLVMContextRef; /** * The top-level container for all other LLVM Intermediate Representation (IR) * objects. * * @see llvm::Module */ typedef struct LLVMOpaqueModule *LLVMModuleRef; /** * Each value in the LLVM IR has a type, an LLVMTypeRef. * * @see llvm::Type */ typedef struct LLVMOpaqueType *LLVMTypeRef; /** * Represents an individual value in LLVM IR. * * This models llvm::Value. */ typedef struct LLVMOpaqueValue *LLVMValueRef; /** * Represents a basic block of instructions in LLVM IR. * * This models llvm::BasicBlock. */ typedef struct LLVMOpaqueBasicBlock *LLVMBasicBlockRef; /** * Represents an LLVM Metadata. * * This models llvm::Metadata. */ typedef struct LLVMOpaqueMetadata *LLVMMetadataRef; /** * Represents an LLVM Named Metadata Node. * * This models llvm::NamedMDNode. */ typedef struct LLVMOpaqueNamedMDNode *LLVMNamedMDNodeRef; /** * Represents an entry in a Global Object's metadata attachments. * * This models std::pair */ typedef struct LLVMOpaqueValueMetadataEntry LLVMValueMetadataEntry; /** * Represents an LLVM basic block builder. * * This models llvm::IRBuilder. */ typedef struct LLVMOpaqueBuilder *LLVMBuilderRef; /** * Represents an LLVM debug info builder. * * This models llvm::DIBuilder. */ typedef struct LLVMOpaqueDIBuilder *LLVMDIBuilderRef; /** * Interface used to provide a module to JIT or interpreter. * This is now just a synonym for llvm::Module, but we have to keep using the * different type to keep binary compatibility. */ typedef struct LLVMOpaqueModuleProvider *LLVMModuleProviderRef; /** @see llvm::PassManagerBase */ typedef struct LLVMOpaquePassManager *LLVMPassManagerRef; /** @see llvm::PassRegistry */ typedef struct LLVMOpaquePassRegistry *LLVMPassRegistryRef; /** * Used to get the users and usees of a Value. * * @see llvm::Use */ typedef struct LLVMOpaqueUse *LLVMUseRef; /** * Used to represent an attributes. * * @see llvm::Attribute */ typedef struct LLVMOpaqueAttributeRef *LLVMAttributeRef; /** * @see llvm::DiagnosticInfo */ typedef struct LLVMOpaqueDiagnosticInfo *LLVMDiagnosticInfoRef; /** * @see llvm::Comdat */ typedef struct LLVMComdat *LLVMComdatRef; /** * @see llvm::Module::ModuleFlagEntry */ typedef struct LLVMOpaqueModuleFlagEntry LLVMModuleFlagEntry; /** * @see llvm::JITEventListener */ typedef struct LLVMOpaqueJITEventListener *LLVMJITEventListenerRef; /** * @see llvm::object::Binary */ typedef struct LLVMOpaqueBinary *LLVMBinaryRef; /** * @} */ #ifdef __cplusplus } #endif #endif