Module Udev.Device

module Device: sig .. end
Accessing device information.

type t 
A Device.t corresponds to a system device.
type descr = 
A type describing different ways of creating a Device.t using Device.create.
| Syspath of string
A device path in /sys, including the mount point.

Example: Device.create (Device.Syspath "/sys/devices/platform").

| Subsystem_sysname of string * string
A given subsystem, and a given sys name.

Example: Device.create (Device.Subsystem_sysname ("block", "sda")).

| Device_id of string
A device id, which is a special string in one of the following four forms:

  • block device major:minor; example: "b8:2"
  • char device major:minor; example: "c128:1"
  • network device ifindex; example: "n3"
  • kernel driver core subsystem:device name; example: "+sound:card29"

| Environment
The process environment.

This only works reliably if the current process is called from an udev rule, and is usually used for tools executed from IMPORT= rules. Use this method to create device objects in OCaml programs called from udev rules.

val create : Udev.Context.t -> descr -> t
Create a Device.t from a Device.descr.

General attributes


val context : t -> Udev.Context.t
The Context.t to which the device is bound.
val syspath : t -> string
Absolute path of this device in sysfs including the sysfs mount point, as a unicode string.
val sysname : t -> string
Device file name inside sysfs as unicode string.
val sysnum : t -> string option
The trailing number of the sysname as unicode string, if any.

Note: the number is returned as a unicode string to preserve the exact format of the number, especially any leading zeros.

val devpath : t -> string
Kernel device path as a unicode string. This path uniquely identifies a single device.

Unlike Device.syspath, this path does not contain the sysfs mount point. However, the path is absolute and starts with a slash "/".

val tags : t -> string list
The tags attached to the device. Tags are arbitrary classifiers that can be attached to devices by udev scripts and daemons. For instance, systemd uses tags for multi-seat support.
val has_tag : t -> string -> bool
Check is the device has some tag.

Device driver and subsystem


val subsystem : t -> string
Name of the subsystem the device is part of, as a unicode string.
val driver : t -> string option
The driver name as a unicode string, if any.
val devtype : t -> string option
The device type as a unicode string, if it is known.

Device nodes


val devnode : t -> string option
Absolute path to the device node of this device, as a unicode string, if the device has a device node.

This path always points to the actual device node associated with this device, and never to any symbolic links to this device node. See Device.devlinks to get a list of symbolic links to this device node.

val devlinks : t -> string list
The absolute paths of all symbolic links pointing to the Device.devnode of this device. The paths are unicode strings.

UDev can create symlinks to the original device node (see Device.devnode) inside the device directory. This is often used to assign a constant, fixed device node to devices like removeable media, which technically do not have a constant device node, or to map a single device into multiple device hierarchies. This function provides access to all such symbolic links, which were created by UDev for this device.


Device initialization time


val is_initialized : t -> bool
Checks if the device is initialized

A device is initialized if udev has already handled this device and has set up device node permissions and context, or renamed a network device.

Such a distinction is meaningful only for devices with a device node, or for network devices. For all other devices, the function returns true.

Using uninitialized devices is not recommended.

val usec_since_initialized : t -> Stdint.Uint64.t
The time elapsed since initialization, as a number of microseconds.

This is only implemented on devices which need to store properties in the udev database. For all other devices, Uint64.zero is returned.


Device hierarchy


val parent : t -> t option
The parent of the device, if any.
val find_parent : t -> ?devtype:string -> subsystem:string -> t option
Find the parent device within the given subsystem and optionally with the given devtype, if any.

subsystem contains the name of the subsystem, in which to search for the parent. devtype optionally holds the expected device type of the parent.


Device events


type action = 
A device event action, for devices received from a Monitor.t.
| Add
| Remove
| Change
| Online
| Offline
| Other of string
val string_of_action : action -> string
val action : t -> action option
The device event action. Returns None if the device was not received from a Monitor.t
val seqnum : t -> Stdint.Uint64.t
The device event sequence number, or Uint64.zero if this device has no sequence number, i.e. was not received from a Monitor.t

Device properties


val properties : t -> (string * string) list
Return the properties defined for a device, as a (key, value) list.
val property : t -> string -> string option
Return the value of a property, if present.
val int_property : t -> string -> int option
val bool_property : t -> string -> bool option

Sysfs attributes


val sysattrs : t -> (string * string) list
Return the system attributes of the device, as a (key, value) list.

System attributes are basically normal files inside the device directory. These files contain all sorts of information about the device, which may not be reflected by properties. These attributes are commonly used for matching in udev rules, and can be printed using udevadm info --attribute-walk.

val sysattr : t -> string -> string option
Return the value of an attribute, if present.
val int_sysattr : t -> string -> int option
val bool_sysattr : t -> string -> bool option
val set_sysattr : t -> string -> string -> unit
Update the value of a device attribute.