Merge pull request #923 from lulf/doc-warnings2
Fix warnings after crate split
This commit is contained in:
commit
6530c179b2
9
embassy-futures/README.md
Normal file
9
embassy-futures/README.md
Normal file
@ -0,0 +1,9 @@
|
|||||||
|
# embassy-futures
|
||||||
|
|
||||||
|
Utilities for working with futures:
|
||||||
|
|
||||||
|
- [`select`](select::select) - waiting for one out of two futures to complete.
|
||||||
|
- [`select3`](select::select3) - waiting for one out of three futures to complete.
|
||||||
|
- [`select4`](select::select4) - waiting for one out of four futures to complete.
|
||||||
|
- [`select_all`](select::select_all) - waiting for one future in a list of futures to complete.
|
||||||
|
- [`yield_now`](yield_now::yield_now) - yielding the current task.
|
@ -1,5 +1,5 @@
|
|||||||
#![no_std]
|
#![no_std]
|
||||||
#![doc = include_str!("../../README.md")]
|
#![doc = include_str!("../README.md")]
|
||||||
#![warn(missing_docs)]
|
#![warn(missing_docs)]
|
||||||
|
|
||||||
// This mod MUST go first, so that the others see its macros.
|
// This mod MUST go first, so that the others see its macros.
|
||||||
|
12
embassy-sync/README.md
Normal file
12
embassy-sync/README.md
Normal file
@ -0,0 +1,12 @@
|
|||||||
|
# embassy-sync
|
||||||
|
|
||||||
|
Synchronization primitives and data structures with an async API:
|
||||||
|
|
||||||
|
- [`Channel`](channel::Channel) - A Multiple Producer Multiple Consumer (MPMC) channel. Each message is only received by a single consumer.
|
||||||
|
- [`PubSubChannel`](pubsub::PubSubChannel) - A broadcast channel (publish-subscribe) channel. Each message is received by all consumers.
|
||||||
|
- [`Signal`](signal::Signal) - Signalling latest value to a single consumer.
|
||||||
|
- [`Mutex`](mutex::Mutex) - A Mutex for synchronizing state between asynchronous tasks.
|
||||||
|
- [`Pipe`](pipe::Pipe) - Byte stream implementing `embedded_io` traits.
|
||||||
|
- [`WakerRegistration`](waitqueue::WakerRegistration) - Utility to register and wake a `Waker`.
|
||||||
|
- [`AtomicWaker`](waitqueue::AtomicWaker) - A variant of `WakerRegistration` accessible using a non-mut API.
|
||||||
|
- [`MultiWakerRegistration`](waitqueue::MultiWakerRegistration) - Utility registering and waking multiple `Waker`'s.
|
@ -1,7 +1,7 @@
|
|||||||
#![cfg_attr(not(any(feature = "std", feature = "wasm")), no_std)]
|
#![cfg_attr(not(any(feature = "std", feature = "wasm")), no_std)]
|
||||||
#![cfg_attr(feature = "nightly", feature(generic_associated_types, type_alias_impl_trait))]
|
#![cfg_attr(feature = "nightly", feature(generic_associated_types, type_alias_impl_trait))]
|
||||||
#![allow(clippy::new_without_default)]
|
#![allow(clippy::new_without_default)]
|
||||||
#![doc = include_str!("../../README.md")]
|
#![doc = include_str!("../README.md")]
|
||||||
#![warn(missing_docs)]
|
#![warn(missing_docs)]
|
||||||
|
|
||||||
// This mod MUST go first, so that the others see its macros.
|
// This mod MUST go first, so that the others see its macros.
|
||||||
|
@ -6,7 +6,7 @@ use core::task::{Context, Poll, Waker};
|
|||||||
|
|
||||||
/// Single-slot signaling primitive.
|
/// Single-slot signaling primitive.
|
||||||
///
|
///
|
||||||
/// This is similar to a [`Channel`](crate::channel::mpmc::Channel) with a buffer size of 1, except
|
/// This is similar to a [`Channel`](crate::channel::Channel) with a buffer size of 1, except
|
||||||
/// "sending" to it (calling [`Signal::signal`]) when full will overwrite the previous value instead
|
/// "sending" to it (calling [`Signal::signal`]) when full will overwrite the previous value instead
|
||||||
/// of waiting for the receiver to pop the previous value.
|
/// of waiting for the receiver to pop the previous value.
|
||||||
///
|
///
|
||||||
@ -14,7 +14,7 @@ use core::task::{Context, Poll, Waker};
|
|||||||
/// the latest data, and therefore it's fine to "lose" messages. This is often the case for "state"
|
/// the latest data, and therefore it's fine to "lose" messages. This is often the case for "state"
|
||||||
/// updates.
|
/// updates.
|
||||||
///
|
///
|
||||||
/// For more advanced use cases, you might want to use [`Channel`](crate::channel::mpmc::Channel) instead.
|
/// For more advanced use cases, you might want to use [`Channel`](crate::channel::Channel) instead.
|
||||||
///
|
///
|
||||||
/// Signals are generally declared as `static`s and then borrowed as required.
|
/// Signals are generally declared as `static`s and then borrowed as required.
|
||||||
///
|
///
|
||||||
|
43
embassy-time/README.md
Normal file
43
embassy-time/README.md
Normal file
@ -0,0 +1,43 @@
|
|||||||
|
# embassy-time
|
||||||
|
|
||||||
|
Timekeeping, delays and timeouts.
|
||||||
|
|
||||||
|
Timekeeping is done with elapsed time since system boot. Time is represented in
|
||||||
|
ticks, where the tick rate is defined by the current driver, usually to match
|
||||||
|
the tick rate of the hardware.
|
||||||
|
|
||||||
|
Tick counts are 64 bits. At the highest supported tick rate of 1Mhz this supports
|
||||||
|
representing time spans of up to ~584558 years, which is big enough for all practical
|
||||||
|
purposes and allows not having to worry about overflows.
|
||||||
|
|
||||||
|
[`Instant`] represents a given instant of time (relative to system boot), and [`Duration`]
|
||||||
|
represents the duration of a span of time. They implement the math operations you'd expect,
|
||||||
|
like addition and substraction.
|
||||||
|
|
||||||
|
# Delays and timeouts
|
||||||
|
|
||||||
|
[`Timer`] allows performing async delays. [`Ticker`] allows periodic delays without drifting over time.
|
||||||
|
|
||||||
|
An implementation of the `embedded-hal` delay traits is provided by [`Delay`], for compatibility
|
||||||
|
with libraries from the ecosystem.
|
||||||
|
|
||||||
|
# Wall-clock time
|
||||||
|
|
||||||
|
The `time` module deals exclusively with a monotonically increasing tick count.
|
||||||
|
Therefore it has no direct support for wall-clock time ("real life" datetimes
|
||||||
|
like `2021-08-24 13:33:21`).
|
||||||
|
|
||||||
|
If persistence across reboots is not needed, support can be built on top of
|
||||||
|
`embassy_time` by storing the offset between "seconds elapsed since boot"
|
||||||
|
and "seconds since unix epoch".
|
||||||
|
|
||||||
|
# Time driver
|
||||||
|
|
||||||
|
The `time` module is backed by a global "time driver" specified at build time.
|
||||||
|
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.
|
||||||
|
|
||||||
|
For more details, check the [`driver`] module.
|
@ -1,50 +1,9 @@
|
|||||||
#![cfg_attr(not(any(feature = "std", feature = "wasm")), no_std)]
|
#![cfg_attr(not(any(feature = "std", feature = "wasm")), no_std)]
|
||||||
#![cfg_attr(feature = "nightly", feature(generic_associated_types, type_alias_impl_trait))]
|
#![cfg_attr(feature = "nightly", feature(generic_associated_types, type_alias_impl_trait))]
|
||||||
|
#![doc = include_str!("../README.md")]
|
||||||
#![allow(clippy::new_without_default)]
|
#![allow(clippy::new_without_default)]
|
||||||
#![warn(missing_docs)]
|
#![warn(missing_docs)]
|
||||||
|
|
||||||
//! Timekeeping, delays and timeouts.
|
|
||||||
//!
|
|
||||||
//! Timekeeping is done with elapsed time since system boot. Time is represented in
|
|
||||||
//! ticks, where the tick rate is defined by the current driver, usually to match
|
|
||||||
//! the tick rate of the hardware.
|
|
||||||
//!
|
|
||||||
//! Tick counts are 64 bits. At the highest supported tick rate of 1Mhz this supports
|
|
||||||
//! representing time spans of up to ~584558 years, which is big enough for all practical
|
|
||||||
//! purposes and allows not having to worry about overflows.
|
|
||||||
//!
|
|
||||||
//! [`Instant`] represents a given instant of time (relative to system boot), and [`Duration`]
|
|
||||||
//! represents the duration of a span of time. They implement the math operations you'd expect,
|
|
||||||
//! like addition and substraction.
|
|
||||||
//!
|
|
||||||
//! # Delays and timeouts
|
|
||||||
//!
|
|
||||||
//! [`Timer`] allows performing async delays. [`Ticker`] allows periodic delays without drifting over time.
|
|
||||||
//!
|
|
||||||
//! An implementation of the `embedded-hal` delay traits is provided by [`Delay`], for compatibility
|
|
||||||
//! with libraries from the ecosystem.
|
|
||||||
//!
|
|
||||||
//! # Wall-clock time
|
|
||||||
//!
|
|
||||||
//! The `time` module deals exclusively with a monotonically increasing tick count.
|
|
||||||
//! Therefore it has no direct support for wall-clock time ("real life" datetimes
|
|
||||||
//! like `2021-08-24 13:33:21`).
|
|
||||||
//!
|
|
||||||
//! If persistence across reboots is not needed, support can be built on top of
|
|
||||||
//! `embassy_time` by storing the offset between "seconds elapsed since boot"
|
|
||||||
//! and "seconds since unix epoch".
|
|
||||||
//!
|
|
||||||
//! # Time driver
|
|
||||||
//!
|
|
||||||
//! The `time` module is backed by a global "time driver" specified at build time.
|
|
||||||
//! 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.
|
|
||||||
//!
|
|
||||||
//! For more details, check the [`driver`] module.
|
|
||||||
|
|
||||||
// This mod MUST go first, so that the others see its macros.
|
// This mod MUST go first, so that the others see its macros.
|
||||||
pub(crate) mod fmt;
|
pub(crate) mod fmt;
|
||||||
|
|
||||||
|
Loading…
x
Reference in New Issue
Block a user