#linux #hal

dev linux-embedded-hal

Implementation of the embedded-hal traits for Linux devices

11 releases

0.4.0-alpha.3 Aug 5, 2022
0.4.0-alpha.2 Feb 14, 2022
0.4.0-alpha.1 Oct 7, 2021
0.4.0-alpha.0 Nov 29, 2020
0.1.1 Feb 13, 2018

#170 in Embedded development

Download history 1135/week @ 2022-10-08 857/week @ 2022-10-15 1429/week @ 2022-10-22 1441/week @ 2022-10-29 1464/week @ 2022-11-05 907/week @ 2022-11-12 801/week @ 2022-11-19 880/week @ 2022-11-26 920/week @ 2022-12-03 1577/week @ 2022-12-10 1345/week @ 2022-12-17 711/week @ 2022-12-24 858/week @ 2022-12-31 915/week @ 2023-01-07 1049/week @ 2023-01-14 1102/week @ 2023-01-21

4,036 downloads per month
Used in 134 crates (131 directly)


661 lines


Implementation of the embedded-hal traits for Linux devices

This project is developed and maintained by the Embedded Linux team.


Note that current v0.4.0-alpha.X releases track the unstable ['embedded-hal'] v1.0.0-alpha.Y. For bugfixes or backports please open PRs against the v0.3.x branch.

GPIO character device

Since Linux kernel v4.4 the use of sysfs GPIO was deprecated and replaced by the character device GPIO. See gpio-cdev documentation for details.

This crate includes feature flag gpio_cdev that exposes CdevPin as wrapper around LineHandle from gpio-cdev. To enable it update your Cargo.toml. Please note that in order to prevent LineHandle fd from closing you should assign to a variable, see cdev issue for more details.

linux-embedded-hal = { version = "0.3", features = ["gpio_cdev"] }

SysfsPin can be still used with feature flag gpio_sysfs.

With default-features = false you can enable the features gpio_cdev, gpio_sysfs, i2c, and spi as needed.

Minimum Supported Rust Version (MSRV)

This crate is guaranteed to compile on stable Rust 1.54.0 and up. It might compile with older versions but that may change in any new patch release.


Licensed under either of

at your option.


Unless you explicitly state otherwise, any contribution intentionally submitted for inclusion in the work by you, as defined in the Apache-2.0 license, shall be dual licensed as above, without any additional terms or conditions.

Code of Conduct

Contribution to this crate is organized under the terms of the Rust Code of Conduct, the maintainer of this crate, the HAL team, promises to intervene to uphold that code of conduct.


~39K SLoC