[PATCH] D134916: [llvm-ocaml] Add binding for constructing opaque pointers
Alan via Phabricator via llvm-commits
llvm-commits at lists.llvm.org
Sat Oct 1 08:57:22 PDT 2022
alan updated this revision to Diff 464505.
alan added a comment.
[llvm-ocaml] Add binding for constructing opaque pointers
Repository:
rG LLVM Github Monorepo
CHANGES SINCE LAST ACTION
https://reviews.llvm.org/D134916/new/
https://reviews.llvm.org/D134916
Files:
llvm/bindings/ocaml/llvm/llvm.ml
llvm/bindings/ocaml/llvm/llvm.mli
llvm/bindings/ocaml/llvm/llvm_ocaml.c
llvm/test/Bindings/OCaml/core.ml
Index: llvm/test/Bindings/OCaml/core.ml
===================================================================
--- llvm/test/Bindings/OCaml/core.ml
+++ llvm/test/Bindings/OCaml/core.ml
@@ -41,6 +41,10 @@
insist (i32_type = (Array.get (subtypes ar)) 0);
insist (i8_type = (Array.get (subtypes ar)) 1)
+(*===-- Pointer types ----------------------------------------------------===*)
+let test_pointer_types () =
+ insist (address_space (pointer_type_in_context context 0) = 0);
+ insist (address_space (pointer_type_in_context context 1) = 1)
(*===-- Conversion --------------------------------------------------------===*)
@@ -1502,6 +1506,7 @@
let _ =
suite "contained types" test_contained_types;
+ suite "pointer types" test_pointer_types;
suite "conversion" test_conversion;
suite "target" test_target;
suite "constants" test_constants;
Index: llvm/bindings/ocaml/llvm/llvm_ocaml.c
===================================================================
--- llvm/bindings/ocaml/llvm/llvm_ocaml.c
+++ llvm/bindings/ocaml/llvm/llvm_ocaml.c
@@ -581,6 +581,11 @@
return LLVMPointerType(ElementTy, Int_val(AddressSpace));
}
+/* llcontext -> int -> lltype */
+LLVMTypeRef llvm_pointer_type_in_context(LLVMContextRef C, value AddressSpace) {
+ return LLVMPointerTypeInContext(C, Int_val(AddressSpace));
+}
+
/* lltype -> int -> lltype */
LLVMTypeRef llvm_vector_type(LLVMTypeRef ElementTy, value Count) {
return LLVMVectorType(ElementTy, Int_val(Count));
Index: llvm/bindings/ocaml/llvm/llvm.mli
===================================================================
--- llvm/bindings/ocaml/llvm/llvm.mli
+++ llvm/bindings/ocaml/llvm/llvm.mli
@@ -726,6 +726,11 @@
See the method [llvm::PointerType::get]. *)
val qualified_pointer_type : lltype -> int -> lltype
+(** [pointer_type_in_context context as] returns the opaque pointer type
+ referencing objects in address space [as].
+ See the method [llvm::PointerType::get]. *)
+val pointer_type_in_context : llcontext -> int -> lltype
+
(** [vector_type ty n] returns the array type containing [n] elements of the
primitive type [ty]. See the method [llvm::ArrayType::get]. *)
val vector_type : lltype -> int -> lltype
Index: llvm/bindings/ocaml/llvm/llvm.ml
===================================================================
--- llvm/bindings/ocaml/llvm/llvm.ml
+++ llvm/bindings/ocaml/llvm/llvm.ml
@@ -508,6 +508,8 @@
external pointer_type : lltype -> lltype = "llvm_pointer_type"
external qualified_pointer_type : lltype -> int -> lltype
= "llvm_qualified_pointer_type"
+external pointer_type_in_context : llcontext -> int -> lltype
+ = "llvm_pointer_type_in_context"
external vector_type : lltype -> int -> lltype = "llvm_vector_type"
external element_type : lltype -> lltype = "LLVMGetElementType"
-------------- next part --------------
A non-text attachment was scrubbed...
Name: D134916.464505.patch
Type: text/x-patch
Size: 2902 bytes
Desc: not available
URL: <http://lists.llvm.org/pipermail/llvm-commits/attachments/20221001/b776a213/attachment.bin>
More information about the llvm-commits
mailing list