106f32e7eSjoerg /*===-- bitwriter_ocaml.c - LLVM OCaml Glue ---------------------*- C++ -*-===*\
206f32e7eSjoerg |*                                                                            *|
306f32e7eSjoerg |* Part of the LLVM Project, under the Apache License v2.0 with LLVM          *|
406f32e7eSjoerg |* Exceptions.                                                                *|
506f32e7eSjoerg |* See https://llvm.org/LICENSE.txt for license information.                  *|
606f32e7eSjoerg |* SPDX-License-Identifier: Apache-2.0 WITH LLVM-exception                    *|
706f32e7eSjoerg |*                                                                            *|
806f32e7eSjoerg |*===----------------------------------------------------------------------===*|
906f32e7eSjoerg |*                                                                            *|
1006f32e7eSjoerg |* This file glues LLVM's OCaml interface to its C interface. These functions *|
1106f32e7eSjoerg |* are by and large transparent wrappers to the corresponding C functions.    *|
1206f32e7eSjoerg |*                                                                            *|
1306f32e7eSjoerg |* Note that these functions intentionally take liberties with the CAMLparamX *|
1406f32e7eSjoerg |* macros, since most of the parameters are not GC heap objects.              *|
1506f32e7eSjoerg |*                                                                            *|
1606f32e7eSjoerg \*===----------------------------------------------------------------------===*/
1706f32e7eSjoerg 
1806f32e7eSjoerg #include "llvm-c/BitWriter.h"
1906f32e7eSjoerg #include "llvm-c/Core.h"
2006f32e7eSjoerg #include "caml/alloc.h"
2106f32e7eSjoerg #include "caml/mlvalues.h"
2206f32e7eSjoerg #include "caml/memory.h"
2306f32e7eSjoerg 
2406f32e7eSjoerg /* Llvm.llmodule -> string -> bool */
llvm_write_bitcode_file(LLVMModuleRef M,value Path)25*da58b97aSjoerg value llvm_write_bitcode_file(LLVMModuleRef M, value Path) {
2606f32e7eSjoerg   int Result = LLVMWriteBitcodeToFile(M, String_val(Path));
2706f32e7eSjoerg   return Val_bool(Result == 0);
2806f32e7eSjoerg }
2906f32e7eSjoerg 
3006f32e7eSjoerg /* ?unbuffered:bool -> Llvm.llmodule -> Unix.file_descr -> bool */
llvm_write_bitcode_to_fd(value U,LLVMModuleRef M,value FD)31*da58b97aSjoerg value llvm_write_bitcode_to_fd(value U, LLVMModuleRef M, value FD) {
3206f32e7eSjoerg   int Unbuffered;
3306f32e7eSjoerg   int Result;
3406f32e7eSjoerg 
3506f32e7eSjoerg   if (U == Val_int(0)) {
3606f32e7eSjoerg     Unbuffered = 0;
3706f32e7eSjoerg   } else {
3806f32e7eSjoerg     Unbuffered = Bool_val(Field(U, 0));
3906f32e7eSjoerg   }
4006f32e7eSjoerg 
4106f32e7eSjoerg   Result = LLVMWriteBitcodeToFD(M, Int_val(FD), 0, Unbuffered);
4206f32e7eSjoerg   return Val_bool(Result == 0);
4306f32e7eSjoerg }
4406f32e7eSjoerg 
4506f32e7eSjoerg /* Llvm.llmodule -> Llvm.llmemorybuffer */
llvm_write_bitcode_to_memory_buffer(LLVMModuleRef M)46*da58b97aSjoerg LLVMMemoryBufferRef llvm_write_bitcode_to_memory_buffer(LLVMModuleRef M) {
4706f32e7eSjoerg   return LLVMWriteBitcodeToMemoryBuffer(M);
4806f32e7eSjoerg }
49