From b12f17fcd89319638dd772e544c4838575f748a2 Mon Sep 17 00:00:00 2001 From: Julien Portalier Date: Fri, 24 May 2024 15:02:52 +0200 Subject: [PATCH] Add some missing `LLVM::Context` bindings (#14612) --- src/llvm/context.cr | 26 +++++++++++++++++++++----- src/llvm/lib_llvm/core.cr | 4 ++++ src/llvm/type.cr | 6 +++--- 3 files changed, 28 insertions(+), 8 deletions(-) diff --git a/src/llvm/context.cr b/src/llvm/context.cr index b04dd8c85b15..987e8f13ba6b 100644 --- a/src/llvm/context.cr +++ b/src/llvm/context.cr @@ -51,6 +51,10 @@ class LLVM::Context Type.new LibLLVM.int_type_in_context(self, bits) end + def half : Type + Type.new LibLLVM.half_type_in_context(self) + end + def float : Type Type.new LibLLVM.float_type_in_context(self) end @@ -59,19 +63,31 @@ class LLVM::Context Type.new LibLLVM.double_type_in_context(self) end - def pointer : Type + def x86_fp80 : Type + Type.new LibLLVM.x86_fp80_type_in_context(self) + end + + def fp128 : Type + Type.new LibLLVM.fp128_type_in_context(self) + end + + def ppc_fp128 : Type + Type.new LibLLVM.ppc_fp128_type_in_context(self) + end + + def pointer(address_space = 0) : Type {% if LibLLVM::IS_LT_150 %} {% raise "Opaque pointers are only supported on LLVM 15.0 or above" %} {% else %} - Type.new LibLLVM.pointer_type_in_context(self, 0) + Type.new LibLLVM.pointer_type_in_context(self, address_space) {% end %} end - def void_pointer : Type + def void_pointer(address_space = 0) : Type {% if LibLLVM::IS_LT_150 %} - int8.pointer + int8.pointer(address_space) {% else %} - pointer + pointer(address_space) {% end %} end diff --git a/src/llvm/lib_llvm/core.cr b/src/llvm/lib_llvm/core.cr index c865baaa55a5..de6f04010cfa 100644 --- a/src/llvm/lib_llvm/core.cr +++ b/src/llvm/lib_llvm/core.cr @@ -58,8 +58,12 @@ lib LibLLVM fun int_type_in_context = LLVMIntTypeInContext(c : ContextRef, num_bits : UInt) : TypeRef fun get_int_type_width = LLVMGetIntTypeWidth(integer_ty : TypeRef) : UInt + fun half_type_in_context = LLVMHalfTypeInContext(c : ContextRef) : TypeRef fun float_type_in_context = LLVMFloatTypeInContext(c : ContextRef) : TypeRef fun double_type_in_context = LLVMDoubleTypeInContext(c : ContextRef) : TypeRef + fun x86_fp80_type_in_context = LLVMX86FP80TypeInContext(c : ContextRef) : TypeRef + fun fp128_type_in_context = LLVMFP128TypeInContext(c : ContextRef) : TypeRef + fun ppc_fp128_type_in_context = LLVMPPCFP128TypeInContext(c : ContextRef) : TypeRef fun function_type = LLVMFunctionType(return_type : TypeRef, param_types : TypeRef*, param_count : UInt, is_var_arg : Bool) : TypeRef fun is_function_var_arg = LLVMIsFunctionVarArg(function_ty : TypeRef) : Bool diff --git a/src/llvm/type.cr b/src/llvm/type.cr index 42d1a314c118..7d0582a9f736 100644 --- a/src/llvm/type.cr +++ b/src/llvm/type.cr @@ -50,11 +50,11 @@ struct LLVM::Type Value.new LibLLVM.get_undef(self) end - def pointer : LLVM::Type + def pointer(address_space = 0) : LLVM::Type {% if LibLLVM::IS_LT_150 %} - Type.new LibLLVM.pointer_type(self, 0) + Type.new LibLLVM.pointer_type(self, address_space) {% else %} - Type.new LibLLVM.pointer_type_in_context(LibLLVM.get_type_context(self), 0) + Type.new LibLLVM.pointer_type_in_context(LibLLVM.get_type_context(self), address_space) {% end %} end