Module Linux_ext
Interface to Linux-specific system calls.
module Sysinfo : sig ... end
Filesystem functions
val sendfile : (?pos:int -> ?len:int -> fd:Core.Unix.File_descr.t -> Core.Unix.File_descr.t -> int) Core.Or_error.t
sendfile ?pos ?len ~fd sock
sends mmap-able data from file descriptorfd
to socketsock
using offsetpos
and lengthlen
. Returns the number of characters actually written.NOTE: If the returned value is unequal to what was requested (= the initial size of the data by default), the system call may have been interrupted by a signal, the source file may have been truncated during operation, or a timeout may have occurred on the socket during sending. It is currently impossible to find out which of these events actually happened. Calling
sendfile
several times on the same descriptor that only partially accepted data due to a timeout will eventually lead to the Unix errorEAGAIN
.Raises
Unix_error
on Unix-errors.
module Bound_to_interface : sig ... end
Type for status of SO_BINDTODEVICE socket option. The socket may either restrict the traffic to a given (by name, e.g. "eth0") interface, or do no restriction at all.
Non-portable TCP functionality
type tcp_bool_option
=
val sexp_of_tcp_bool_option : tcp_bool_option -> Ppx_sexp_conv_lib.Sexp.t
val tcp_bool_option_of_sexp : Ppx_sexp_conv_lib.Sexp.t -> tcp_bool_option
val bin_shape_tcp_bool_option : Bin_prot.Shape.t
val bin_size_tcp_bool_option : tcp_bool_option Bin_prot.Size.sizer
val bin_write_tcp_bool_option : tcp_bool_option Bin_prot.Write.writer
val bin_writer_tcp_bool_option : tcp_bool_option Bin_prot.Type_class.writer
val bin_read_tcp_bool_option : tcp_bool_option Bin_prot.Read.reader
val __bin_read_tcp_bool_option__ : (int -> tcp_bool_option) Bin_prot.Read.reader
val bin_reader_tcp_bool_option : tcp_bool_option Bin_prot.Type_class.reader
val bin_tcp_bool_option : tcp_bool_option Bin_prot.Type_class.t
val gettcpopt_bool : (Core.Unix.File_descr.t -> tcp_bool_option -> bool) Core.Or_error.t
gettcpopt_bool sock opt
Returns the current value of the boolean TCP socket optionopt
for socketsock
.
val settcpopt_bool : (Core.Unix.File_descr.t -> tcp_bool_option -> bool -> unit) Core.Or_error.t
settcpopt_bool sock opt v
sets the current value of the boolean TCP socket optionopt
for socketsock
to valuev
.
val send_nonblocking_no_sigpipe : (Core.Unix.File_descr.t -> ?pos:int -> ?len:int -> Core.Bytes.t -> int option) Core.Or_error.t
send_nonblocking_no_sigpipe sock ?pos ?len buf
tries to do a nonblocking send on socketsock
given bufferbuf
, offsetpos
and lengthlen
. PreventsSIGPIPE
, i.e., raises a Unix-error in that case immediately. ReturnsSome bytes_written
orNone
if the operation would have blocked.Raises
Invalid_argument
if the designated buffer range is invalid. RaisesUnix_error
on Unix-errors.
val send_no_sigpipe : (Core.Unix.File_descr.t -> ?pos:int -> ?len:int -> Core.Bytes.t -> int) Core.Or_error.t
send_no_sigpipe sock ?pos ?len buf
tries to do a blocking send on socketsock
given bufferbuf
, offsetpos
and lengthlen
. PreventsSIGPIPE
, i.e., raises a Unix-error in that case immediately. Returns the number of bytes written.Raises
Invalid_argument
if the designated buffer range is invalid. RaisesUnix_error
on Unix-errors.
val sendmsg_nonblocking_no_sigpipe : (Core.Unix.File_descr.t -> ?count:int -> string Core.Unix.IOVec.t array -> int option) Core.Or_error.t
sendmsg_nonblocking_no_sigpipe sock ?count iovecs
tries to do a nonblocking send on socketsock
usingcount
I/O-vectorsiovecs
. PreventsSIGPIPE
, i.e., raises a Unix-error in that case immediately. ReturnsSome bytes_written
orNone
if the operation would have blocked.Raises
Invalid_argument
if the designated ranges are invalid. RaisesUnix_error
on Unix-errors.
Non-portable socket functionality
module Peer_credentials : sig ... end
val peer_credentials : (Core.Unix.File_descr.t -> Peer_credentials.t) Core.Or_error.t
peer_credential fd
takes a file descriptor of a unix socket. It returns the pid and real ids of the process on the other side, as described inman 7 socket
entry for SO_PEERCRED. This is useful in particular in the presence of pid namespace, as the returned pid will be a pid in the current namespace, not the namespace of the other process.Raises
Unix_error
if something goes wrong (file descriptor doesn't satisfy the conditions above, no process on the other side of the socket, etc.).
Clock functions
module Clock : sig ... end
Eventfd functions
module Eventfd : sig ... end
Timerfd functions
module Timerfd : sig ... end
Parent death notifications
val pr_set_pdeathsig : (Core.Signal.t -> unit) Core.Or_error.t
pr_set_pdeathsig s
sets the signals
to be sent to the executing process when its parent dies. NOTE: the parent may have died before or while executing this system call. To make sure that you do not miss this event, you should callgetppid
to get the parent process id after this system call. If the parent has died, the returned parent PID will be 1, i.e., the init process will have adopted the child. You should then either send the signal to yourself usingUnix.kill
, or execute an appropriate handler.
val pr_get_pdeathsig : (unit -> Core.Signal.t) Core.Or_error.t
pr_get_pdeathsig ()
gets the signal that will be sent to the currently executing process when its parent dies.
Task name
val pr_set_name_first16 : (string -> unit) Core.Or_error.t
pr_set_name_first16 name
sets the name of the executing thread toname
. Only the first 16 bytes inname
will be used; the rest is ignored.
val pr_get_name : (unit -> string) Core.Or_error.t
pr_get_name ()
gets the name of the executing thread. The name is at most 16 bytes long.
Pathname resolution
val file_descr_realpath : (Core.Unix.File_descr.t -> string) Core.Or_error.t
file_descr_realpath fd
returns the canonicalized absolute pathname of the file associated with file descriptorfd
.Raises
Unix_error
on errors.
val out_channel_realpath : (Core.Out_channel.t -> string) Core.Or_error.t
out_channel_realpath oc
returns the canonicalized absolute pathname of the file associated with output channeloc
.Raises
Unix_error
on errors.
val in_channel_realpath : (Core.In_channel.t -> string) Core.Or_error.t
in_channel_realpath ic
returns the canonicalized absolute pathname of the file associated with input channelic
.Raises
Unix_error
on errors.
Affinity
val sched_setaffinity : (?pid:Core.Pid.t -> cpuset:int list -> unit -> unit) Core.Or_error.t
Setting the CPU affinity causes a process to only run on the cores chosen. You can find out how many cores a system has in /proc/cpuinfo. This can be useful in two ways: first, it limits a process to a core so that it won't interfere with processes on other cores. Second, you save time by not moving the process back and forth between CPUs, which sometimes invalidates their cache. See
man sched_setaffinity
for details.
val sched_getaffinity : (?pid:Core.Pid.t -> unit -> int list) Core.Or_error.t
val sched_setaffinity_this_thread : (cpuset:int list -> unit) Core.Or_error.t
val cores : (unit -> int) Core.Or_error.t
cores ()
returns the number of cores on the machine. This may be different than the number of cores available to the calling process.
val get_terminal_size : ([ `Controlling | `Fd of Core.Unix.File_descr.t ] -> int * int) Core.Or_error.t
get_terminal_size term
returns(rows, cols)
, the number of rows and columns of the controlling terminal (raises if no controlling terminal), or of the specified file descriptor (useful when writing to stdout, because stdout doesn't have to be the controlling terminal).
module Priority : sig ... end
Priority.t
is what is usually referred to as the "nice" value of a process. It is also known as the "dynamic" priority. It is used with normal (as opposed to real-time) processes that have static priority zero. SeeUnix.Scheduler.set
for setting the static priority.
val setpriority : (Priority.t -> unit) Core.Or_error.t
Set the calling thread's priority in the Linux scheduler
val getpriority : (unit -> Priority.t) Core.Or_error.t
Get the calling thread's priority in the Linux scheduler
val get_ipv4_address_for_interface : (string -> string) Core.Or_error.t
get_ipv4_address_for_interface "eth0"
returns the IP address assigned to eth0, or throws an exception if no IP address is configured.
val bind_to_interface : (Core.Unix.File_descr.t -> Bound_to_interface.t -> unit) Core.Or_error.t
bind_to_interface fd (Only "eth0")
restricts packets from being received/sent on the given file descriptorfd
on any interface other than "eth0". Usebind_to_interface fd Any
to allow traffic on any interface. The bindings are not cumulative; you may only select one interface, orAny
.Not to be confused with a traditional BSD sockets API
bind()
call, this Linux-specific socket option (SO_BINDTODEVICE
) is used for applications on multi-homed machines with specific security concerns. For similar functionality when using multicast, seeCore_unix
.mcast_set_ifname.
val get_bind_to_interface : (Core.Unix.File_descr.t -> Bound_to_interface.t) Core.Or_error.t
module Epoll : sig ... end
epoll(): a Linux I/O multiplexer of the same family as select() or poll(). Its main differences are support for Edge- or Level-triggered notifications (we're using Level-triggered to emulate "select") and much better scaling with the number of file descriptors.
module Extended_file_attributes : sig ... end