123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130(** [Ext_pointer] uses values of the OCaml type "int" to represent pointers to 2-byte
aligned memory blocks allocated outside the OCaml heap.
The least significant bit of the address of a 2-byte aligned memory block is 0.
This bit is used by this library to represent the address as an OCaml int, which
prevents the OCaml GC from following pointers to external memory.
To encode an external pointer as int: set the least significant bit.
To decode int into an external pointer: clear the least significant bit.
Note that these encode and decode operations are not the same as tagging and untagging
operations on OCaml representation of int, which involves shifting.
[Ext_pointer] allows OCaml code to pass around and manipulate pointers to external
memory blocks without using "naked pointers".
*)typet=privateintexternalcreate:int->t="%identity"moduleImmediate(V:sigtypet[@@immediate]end)=struct(** [load_immediate t] assumes without checking that
the value pointed to by [t] is immediate. *)externalunsafe_load_immediate:t->V.t="caml_ext_pointer_load_immediate"[@@noalloc][@@builtin][@@no_effects](** [store_int t i] stores the immediate [i] to the memory address
represented by [t]. *)externalstore_immediate:t->V.t->unit="caml_ext_pointer_store_immediate"[@@noalloc][@@builtin][@@no_coeffects]endmoduleInt=Immediate(Stdlib.Int)moduleBool=Immediate(Stdlib.Bool)(** [load_int t] reads untagged int pointed to by [t] and returns
the corresponding tagged int.
This should only be used to read a value
written by [store_untagged_int]. Otherwise, if the value has most significant
bit set, it will be lost by tagging. To avoid it,
use [load_unboxed_nativeint] and check before converting to int
(should not allocate). The native C stub is the same for both.
*)externalload_untagged_int:t->(int[@untagged])="caml_ext_pointer_load_untagged_int""caml_ext_pointer_load_unboxed_nativeint"[@@noalloc][@@builtin][@@no_effects](** [store_int t d] untags [d] and stores the result to the memory pointed to by
[t]. *)externalstore_untagged_int:t->(int[@untagged])->unit="caml_ext_pointer_store_untagged_int""caml_ext_pointer_store_unboxed_nativeint"[@@noalloc][@@builtin][@@no_coeffects](** [load_unboxed_nativeint t] reads unboxed nativeint pointed to by [t] and returns
the corresponding (boxed) nativeint allocated on the OCaml heap. *)externalload_unboxed_nativeint:t->(nativeint[@unboxed])="caml_ext_pointer_load_unboxed_nativeint_bytecode""caml_ext_pointer_load_unboxed_nativeint"[@@noalloc][@@builtin][@@no_effects](** [store_unboxed_nativeint t d] stores the unboxed nativeint to the memory pointed to by
[t]. *)externalstore_unboxed_nativeint:t->(nativeint[@unboxed])->unit="caml_ext_pointer_store_unboxed_nativeint_bytecode""caml_ext_pointer_store_unboxed_nativeint"[@@noalloc][@@builtin][@@no_coeffects](** [load_unboxed_int64 t] reads unboxed int64 pointed to by [t] and returns
the corresponding (boxed) int64 allocated on the OCaml heap. *)externalload_unboxed_int64:t->(int64[@unboxed])="caml_ext_pointer_load_unboxed_int64_bytecode""caml_ext_pointer_load_unboxed_int64"[@@noalloc][@@builtin][@@no_effects](** [store_unboxed_int64 t d] stores the unboxed int64 to the memory pointed to by [t]. *)externalstore_unboxed_int64:t->(int64[@unboxed])->unit="caml_ext_pointer_store_unboxed_int64_bytecode""caml_ext_pointer_store_unboxed_int64"[@@noalloc][@@builtin][@@no_coeffects](** [load_unboxed_int32 t] reads unboxed int32 pointed to by [t] and returns
the corresponding (boxed) int32 allocated on the OCaml heap. *)externalload_unboxed_int32:t->(int32[@unboxed])="caml_ext_pointer_load_unboxed_int32_bytecode""caml_ext_pointer_load_unboxed_int32"[@@noalloc][@@builtin][@@no_effects](** [store_unboxed_int32 t d] stores the unboxed int32 to the memory pointed to by [t]. *)externalstore_unboxed_int32:t->(int32[@unboxed])->unit="caml_ext_pointer_store_unboxed_int32_bytecode""caml_ext_pointer_store_unboxed_int32"[@@noalloc][@@builtin][@@no_coeffects](** For float operations, the pointer must be aligned at least to the native integer
machine width (meaning on 32-bit platforms, a 32-bit-aligned pointer is acceptable
even though the width of the float is 64 bits). *)(** [load_unboxed_float t] reads the unboxed float pointed to by [t]. (If the result is
not directly passed to another operation expecting an unboxed float, then it will
be boxed.) *)externalload_unboxed_float:t->(float[@unboxed])="caml_ext_pointer_load_unboxed_float_bytecode""caml_ext_pointer_load_unboxed_float"[@@noalloc][@@builtin][@@no_effects](** [store_unboxed_float t d] stores the unboxed float to the memory pointed to by [t]. *)externalstore_unboxed_float:t->(float[@unboxed])->unit="caml_ext_pointer_store_unboxed_float_bytecode""caml_ext_pointer_store_unboxed_float"[@@noalloc][@@builtin][@@no_coeffects]