mirror of
				https://github.com/embassy-rs/embassy.git
				synced 2025-11-04 06:45:35 +00:00 
			
		
		
		
	Add readme for embassy-time
This commit is contained in:
		
							parent
							
								
									7b3ae0446c
								
							
						
					
					
						commit
						189d4137cc
					
				
							
								
								
									
										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(feature = "nightly", feature(generic_associated_types, type_alias_impl_trait))]
 | 
			
		||||
#![doc = include_str!("../README.md")]
 | 
			
		||||
#![allow(clippy::new_without_default)]
 | 
			
		||||
#![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.
 | 
			
		||||
pub(crate) mod fmt;
 | 
			
		||||
 | 
			
		||||
 | 
			
		||||
		Loading…
	
	
			
			x
			
			
		
	
		Reference in New Issue
	
	Block a user