2024-01-11 15:38:44 +00:00
|
|
|
# embassy-time-driver
|
|
|
|
|
|
|
|
This crate contains the driver trait necessary for adding [`embassy-time`](https://crates.io/crates/embassy-time) support
|
|
|
|
for a new hardware platform.
|
|
|
|
|
|
|
|
If you want to *use* `embassy-time` with already made drivers, you should depend on the main `embassy-time` crate, not on this crate.
|
|
|
|
|
|
|
|
If you are writing a driver, you should depend only on this crate, not on the main `embassy-time` crate.
|
|
|
|
This will allow your driver to continue working for newer `embassy-time` major versions, without needing an update,
|
|
|
|
if the driver trait has not had breaking changes.
|
|
|
|
|
|
|
|
## How it works
|
|
|
|
|
2024-01-11 16:17:36 +00:00
|
|
|
`embassy-time` is backed by a global "time driver" specified at build time.
|
2024-01-11 15:38:44 +00:00
|
|
|
Only one driver can be active in a program.
|
|
|
|
|
|
|
|
All methods and structs transparently call into the active driver. This makes it
|
|
|
|
possible for libraries to use `embassy-time` in a driver-agnostic way without
|
|
|
|
requiring generic parameters.
|