blob: c288b9ac2d9cd210b3f3164f21e1132cad6f08e8 [file] [log] [blame]
John Bauman66b8ab22014-05-06 15:57:45 -04001(*===-- llvm_target.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(** Target Information.
11
12 This interface provides an ocaml API for LLVM target information,
13 the classes in the Target library. *)
14
15module Endian : sig
16 type t =
17 | Big
18 | Little
19end
20
21module TargetData : sig
22 type t
23
24 (** [TargetData.create rep] parses the target data string representation [rep].
25 See the constructor llvm::TargetData::TargetData. *)
26 external create : string -> t = "llvm_targetdata_create"
27
28 (** [add_target_data td pm] adds the target data [td] to the pass manager [pm].
29 Does not take ownership of the target data.
30 See the method llvm::PassManagerBase::add. *)
31 external add : t -> [<Llvm.PassManager.any] Llvm.PassManager.t -> unit
32 = "llvm_targetdata_add"
33
34 (** [as_string td] is the string representation of the target data [td].
35 See the constructor llvm::TargetData::TargetData. *)
36 external as_string : t -> string = "llvm_targetdata_as_string"
37
38 (** Deallocates a TargetData.
39 See the destructor llvm::TargetData::~TargetData. *)
40 external dispose : t -> unit = "llvm_targetdata_dispose"
41end
42
43(** Returns the byte order of a target, either LLVMBigEndian or
44 LLVMLittleEndian.
45 See the method llvm::TargetData::isLittleEndian. *)
46external byte_order : TargetData.t -> Endian.t = "llvm_byte_order"
47
48(** Returns the pointer size in bytes for a target.
49 See the method llvm::TargetData::getPointerSize. *)
50external pointer_size : TargetData.t -> int = "llvm_pointer_size"
51
52(** Returns the integer type that is the same size as a pointer on a target.
53 See the method llvm::TargetData::getIntPtrType. *)
54external intptr_type : TargetData.t -> Llvm.lltype = "LLVMIntPtrType"
55
56(** Computes the size of a type in bytes for a target.
57 See the method llvm::TargetData::getTypeSizeInBits. *)
58external size_in_bits : TargetData.t -> Llvm.lltype -> Int64.t
59 = "llvm_size_in_bits"
60
61(** Computes the storage size of a type in bytes for a target.
62 See the method llvm::TargetData::getTypeStoreSize. *)
63external store_size : TargetData.t -> Llvm.lltype -> Int64.t = "llvm_store_size"
64
65(** Computes the ABI size of a type in bytes for a target.
66 See the method llvm::TargetData::getTypeAllocSize. *)
67external abi_size : TargetData.t -> Llvm.lltype -> Int64.t = "llvm_abi_size"
68
69(** Computes the ABI alignment of a type in bytes for a target.
70 See the method llvm::TargetData::getTypeABISize. *)
71external abi_align : TargetData.t -> Llvm.lltype -> int = "llvm_abi_align"
72
73(** Computes the call frame alignment of a type in bytes for a target.
74 See the method llvm::TargetData::getTypeABISize. *)
75external stack_align : TargetData.t -> Llvm.lltype -> int = "llvm_stack_align"
76
77(** Computes the preferred alignment of a type in bytes for a target.
78 See the method llvm::TargetData::getTypeABISize. *)
79external preferred_align : TargetData.t -> Llvm.lltype -> int
80 = "llvm_preferred_align"
81
82(** Computes the preferred alignment of a global variable in bytes for a target.
83 See the method llvm::TargetData::getPreferredAlignment. *)
84external preferred_align_of_global : TargetData.t -> Llvm.llvalue -> int
85 = "llvm_preferred_align_of_global"
86
87(** Computes the structure element that contains the byte offset for a target.
88 See the method llvm::StructLayout::getElementContainingOffset. *)
89external element_at_offset : TargetData.t -> Llvm.lltype -> Int64.t -> int
90 = "llvm_element_at_offset"
91
92(** Computes the byte offset of the indexed struct element for a target.
93 See the method llvm::StructLayout::getElementContainingOffset. *)
94external offset_of_element : TargetData.t -> Llvm.lltype -> int -> Int64.t
95 = "llvm_offset_of_element"