Index: llvm/bindings/ocaml/llvm/llvm.ml =================================================================== --- llvm/bindings/ocaml/llvm/llvm.ml +++ llvm/bindings/ocaml/llvm/llvm.ml @@ -1348,6 +1348,8 @@ = "llvm_build_extractvalue" external build_insertvalue : llvalue -> llvalue -> int -> string -> llbuilder -> llvalue = "llvm_build_insertvalue" +external build_fence : AtomicOrdering.t -> bool -> string -> llbuilder -> + llvalue = "llvm_build_fence" external build_is_null : llvalue -> string -> llbuilder -> llvalue = "llvm_build_is_null" Index: llvm/bindings/ocaml/llvm/llvm.mli =================================================================== --- llvm/bindings/ocaml/llvm/llvm.mli +++ llvm/bindings/ocaml/llvm/llvm.mli @@ -2597,6 +2597,12 @@ See the method [llvm::LLVMBuilder::CreateFreeze]. *) val build_freeze : llvalue -> string -> llbuilder -> llvalue +(** [build_fence o st name b] creates a + [%name = fence %o] + instruction with ordering [o] and singlethread flag set to [st] at the + position specified by the instruction builder [b]. + See the method [llvm::LLVMBuilder::CreateFence]. *) +val build_fence : AtomicOrdering.t -> bool -> string -> llbuilder -> llvalue (** {6 Memory buffers} *) Index: llvm/bindings/ocaml/llvm/llvm_ocaml.c =================================================================== --- llvm/bindings/ocaml/llvm/llvm_ocaml.c +++ llvm/bindings/ocaml/llvm/llvm_ocaml.c @@ -2457,6 +2457,13 @@ return LLVMBuildFreeze(Builder_val(B), X, String_val(Name)); } +/* AtomicOrdering.t -> bool -> string -> llbuilder -> llvalue */ +CAMLprim LLVMValueRef llvm_build_fence(value Ord, value ST, value Name, + value B) { + return LLVMBuildFence(Builder_val(B), Int_val(Ord), Bool_val(ST), + String_val(Name)); +} + /*===-- Memory buffers ----------------------------------------------------===*/ /* string -> llmemorybuffer