1(*===-- llvm_executionengine.mli - LLVM OCaml Interface -------*- OCaml -*-===* 2 * 3 * The LLVM Compiler Infrastructure 4 * 5 * This file is distributed under the University of Illinois Open Source 6 * License. See LICENSE.TXT for details. 7 * 8 *===----------------------------------------------------------------------===*) 9 10(** JIT Interpreter. 11 12 This interface provides an OCaml API for LLVM execution engine (JIT/ 13 interpreter), the classes in the [ExecutionEngine] library. *) 14 15exception Error of string 16 17(** [initialize ()] initializes the backend corresponding to the host. 18 Returns [true] if initialization is successful; [false] indicates 19 that there is no such backend or it is unable to emit object code 20 via MCJIT. *) 21val initialize : unit -> bool 22 23(** An execution engine is either a JIT compiler or an interpreter, capable of 24 directly loading an LLVM module and executing its functions without first 25 invoking a static compiler and generating a native executable. *) 26type llexecutionengine 27 28(** MCJIT compiler options. See [llvm::TargetOptions]. *) 29type llcompileroptions = { 30 opt_level: int; 31 code_model: Llvm_target.CodeModel.t; 32 no_framepointer_elim: bool; 33 enable_fast_isel: bool; 34} 35 36(** Default MCJIT compiler options: 37 [{ opt_level = 0; code_model = CodeModel.JIT_default; 38 no_framepointer_elim = false; enable_fast_isel = false }] *) 39val default_compiler_options : llcompileroptions 40 41(** [create m optlevel] creates a new MCJIT just-in-time compiler, taking 42 ownership of the module [m] if successful with the desired optimization 43 level [optlevel]. Raises [Error msg] if an error occurrs. The execution 44 engine is not garbage collected and must be destroyed with [dispose ee]. 45 46 Run {!initialize} before using this function. 47 48 See the function [llvm::EngineBuilder::create]. *) 49val create : ?options:llcompileroptions -> Llvm.llmodule -> llexecutionengine 50 51(** [dispose ee] releases the memory used by the execution engine and must be 52 invoked to avoid memory leaks. *) 53val dispose : llexecutionengine -> unit 54 55(** [add_module m ee] adds the module [m] to the execution engine [ee]. *) 56val add_module : Llvm.llmodule -> llexecutionengine -> unit 57 58(** [remove_module m ee] removes the module [m] from the execution engine 59 [ee]. Raises [Error msg] if an error occurs. *) 60val remove_module : Llvm.llmodule -> llexecutionengine -> unit 61 62(** [run_static_ctors ee] executes the static constructors of each module in 63 the execution engine [ee]. *) 64val run_static_ctors : llexecutionengine -> unit 65 66(** [run_static_dtors ee] executes the static destructors of each module in 67 the execution engine [ee]. *) 68val run_static_dtors : llexecutionengine -> unit 69 70(** [data_layout ee] is the data layout of the execution engine [ee]. *) 71val data_layout : llexecutionengine -> Llvm_target.DataLayout.t 72 73(** [add_global_mapping gv ptr ee] tells the execution engine [ee] that 74 the global [gv] is at the specified location [ptr], which must outlive 75 [gv] and [ee]. 76 All uses of [gv] in the compiled code will refer to [ptr]. *) 77val add_global_mapping : Llvm.llvalue -> 'a Ctypes.ptr -> llexecutionengine -> unit 78 79(** [get_global_value_address id typ ee] returns a pointer to the 80 identifier [id] as type [typ], which will be a pointer type for a 81 value, and which will be live as long as [id] and [ee] 82 are. Caution: this function finalizes, i.e. forces code 83 generation, all loaded modules. Further modifications to the 84 modules will not have any effect. *) 85val get_global_value_address : string -> 'a Ctypes.typ -> llexecutionengine -> 'a 86 87(** [get_function_address fn typ ee] returns a pointer to the function 88 [fn] as type [typ], which will be a pointer type for a function 89 (e.g. [(int -> int) typ]), and which will be live as long as [fn] 90 and [ee] are. Caution: this function finalizes, i.e. forces code 91 generation, all loaded modules. Further modifications to the 92 modules will not have any effect. *) 93val get_function_address : string -> 'a Ctypes.typ -> llexecutionengine -> 'a 94