11 releases (1 stable)
1.0.0 | Jan 9, 2024 |
---|---|
1.0.0-rc.3 | Dec 14, 2023 |
1.0.0-rc.2 | Nov 29, 2023 |
0.2.0-alpha.2 | Jul 4, 2023 |
0.1.0-alpha.1 | May 26, 2022 |
#1520 in Embedded development
76,165 downloads per month
Used in 330 crates
(180 directly)
78KB
804 lines
embedded-hal-async
An asynchronous Hardware Abstraction Layer (HAL) for embedded systems.
This crate contains asynchronous versions of the embedded-hal
traits and shares its scope and design goals.
This project is developed and maintained by the HAL team.
Serial/UART traits
There is no serial traits in embedded-hal-async
. Instead, use embedded-io-async
.
A serial port is essentially a byte-oriented stream, and that's what embedded-io-async
models. Sharing the traits
with all byte streams has some advantages. For example, it allows generic code providing a command-line interface
or a console to operate either on hardware serial ports or on virtual ones like Telnet or USB CDC-ACM.
Optional Cargo features
defmt-03
: Derivedefmt::Format
fromdefmt
0.3 for enums and structs.
Minimum Supported Rust Version (MSRV)
This crate is guaranteed to compile on stable Rust 1.75 and up. It might compile with older versions but that may change in any new patch release.
See here for details on how the MSRV may be upgraded.
License
Licensed under either of
- Apache License, Version 2.0 (LICENSE-APACHE or http://www.apache.org/licenses/LICENSE-2.0)
- MIT license (LICENSE-MIT or http://opensource.org/licenses/MIT)
at your option.
Contribution
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.
Dependencies
~160KB