Crate sensors_sys

Source
Expand description

crates.io docs.rs license

§sensors-sys: Unsafe Rust bindings for libsensors

lm-sensors provides user-space support for the hardware monitoring drivers in Linux.

This crate is Linux-specific. Building it for non-Linux platforms, or for the Linux kernel, results in an empty crate.

This crate links to libsensors, and requires it to be installed. See below for example installation instructions.

§Installing libsensors

This crate links to libsensors, and requires it to be installed.

The library, its C header files, and the clang compiler need to be installed on the build machine. On Debian, for example, one can install that as follows:

$ sudo apt install clang libsensors-dev

If the library is linked dynamically (most typical configuration), then it needs to be installed on the target computer in order to run the resulting program. On Debian, for example, one can install it as follows:

$ sudo apt install libsensors5

§Supported environment variables

This crate depends on some environment variables, and variants of those. For each environment variable (e.g., CC), the following are the accepted variants of it:

  • <var>_<target>, e.g., CC_aarch64-unknown-linux-gnu.
  • <var>_<target-with-underscores>, e.g., CC_aarch64_unknown_linux_gnu.
  • TARGET_<var>, e.g., TARGET_CC.
  • <var>, e.g., CC.

The following environment variables (and their variants) affect how this crate is built:

  • LMSENSORS_STATIC
  • LMSENSORS_PATH
  • LMSENSORS_INCLUDE_DIR
  • LMSENSORS_LIB_DIR
  • SYSROOT
  • CC
  • CFLAGS

§Dynamic or static linking

This crate links to libsensors dynamically if possible, except when targeting platforms based on the musl C library.

This behavior can be changed either by setting the environment variable LMSENSORS_STATIC to 1, or by enabling the crate feature static. If both are defined, then the value of LMSENSORS_STATIC takes precedence.

Setting LMSENSORS_STATIC to 0 mandates dynamic linking.

§Finding lm-sensors library and headers

By default, this crate finds lm-sensors headers and library based on the default target C compiler.

This behavior can be changed by:

  • Either defining the environment variable LMSENSORS_PATH to the path of a directory containing the sub-directories include and lib where the headers and library are installed.
  • Or by defining one or both of the environment variables LMSENSORS_INCLUDE_DIR and LMSENSORS_LIB_DIR to paths to the directories where headers and library are present. If LMSENSORS_PATH is also defined, then LMSENSORS_INCLUDE_DIR and LMSENSORS_LIB_DIR take precedence.

§Depending on this crate

This crate provides the following variables to other crates that depend on it:

  • DEP_LMSENSORS_INCLUDE: Path of the directory where library C header files reside.
  • DEP_LMSENSORS_LIB: Path of the directory where the library binary resides.

§Documentation-only build mode

The documentation-only build mode allows building documentation even if libsensors and its headers are unavailable. To build in this mode, set the environment variable DOCS_RS to 1:

$ env DOCS_RS=1 cargo doc --open

The generated documentation is based on libsensors version 3.6.0.

⚠️ The generated crate might be unusable in this mode.

§Versioning

This project adheres to Semantic Versioning. The CHANGELOG.md file details notable changes over time.

Modules§

sensors_feature_type
sensors_subfeature_type

Structs§

sensors_bus_id
sensors_chip_name
sensors_feature
sensors_subfeature

Constants§

SENSORS_API_VERSION
SENSORS_BUS_NR_ANY
SENSORS_BUS_NR_IGNORE
SENSORS_BUS_TYPE_ACPI
SENSORS_BUS_TYPE_ANY
SENSORS_BUS_TYPE_HID
SENSORS_BUS_TYPE_I2C
SENSORS_BUS_TYPE_ISA
SENSORS_BUS_TYPE_MDIO
SENSORS_BUS_TYPE_PCI
SENSORS_BUS_TYPE_SCSI
SENSORS_BUS_TYPE_SPI
SENSORS_BUS_TYPE_VIRTUAL
SENSORS_CHIP_NAME_ADDR_ANY
SENSORS_COMPUTE_MAPPING
SENSORS_ERR_ACCESS_R
SENSORS_ERR_ACCESS_W
SENSORS_ERR_BUS_NAME
SENSORS_ERR_CHIP_NAME
SENSORS_ERR_DIV_ZERO
SENSORS_ERR_IO
SENSORS_ERR_KERNEL
SENSORS_ERR_NO_ENTRY
SENSORS_ERR_PARSE
SENSORS_ERR_RECURSION
SENSORS_ERR_WILDCARDS
SENSORS_MODE_R
SENSORS_MODE_W

Statics§

libsensors_version
sensors_fatal_error
sensors_parse_error
sensors_parse_error_wfn

Functions§

sensors_cleanup
sensors_do_chip_sets
sensors_free_chip_name
sensors_get_adapter_name
sensors_get_all_subfeatures
sensors_get_detected_chips
sensors_get_features
sensors_get_label
sensors_get_subfeature
sensors_get_value
sensors_init
sensors_parse_chip_name
sensors_set_value
sensors_snprintf_chip_name
sensors_strerror

Type Aliases§

FILE