embedded_storage_async/
nor_flash.rs

1pub use embedded_storage::nor_flash::{ErrorType, NorFlashError, NorFlashErrorKind};
2
3/// Read only NOR flash trait.
4pub trait ReadNorFlash: ErrorType {
5	/// The minumum number of bytes the storage peripheral can read
6	const READ_SIZE: usize;
7
8	/// Read a slice of data from the storage peripheral, starting the read
9	/// operation at the given address offset, and reading `bytes.len()` bytes.
10	///
11	/// # Errors
12	///
13	/// Returns an error if the arguments are not aligned or out of bounds. The implementation
14	/// can use the [`check_read`] helper function.
15	async fn read(&mut self, offset: u32, bytes: &mut [u8]) -> Result<(), Self::Error>;
16
17	/// The capacity of the peripheral in bytes.
18	fn capacity(&self) -> usize;
19}
20
21/// NOR flash trait.
22pub trait NorFlash: ReadNorFlash {
23	/// The minumum number of bytes the storage peripheral can write
24	const WRITE_SIZE: usize;
25
26	/// The minumum number of bytes the storage peripheral can erase
27	const ERASE_SIZE: usize;
28
29	/// Erase the given storage range, clearing all data within `[from..to]`.
30	/// The given range will contain all 1s afterwards.
31	///
32	/// If power is lost during erase, contents of the page are undefined.
33	///
34	/// # Errors
35	///
36	/// Returns an error if the arguments are not aligned or out of bounds (the case where `to >
37	/// from` is considered out of bounds). The implementation can use the [`check_erase`]
38	/// helper function.
39	async fn erase(&mut self, from: u32, to: u32) -> Result<(), Self::Error>;
40
41	/// If power is lost during write, the contents of the written words are undefined,
42	/// but the rest of the page is guaranteed to be unchanged.
43	/// It is not allowed to write to the same word twice.
44	///
45	/// # Errors
46	///
47	/// Returns an error if the arguments are not aligned or out of bounds. The implementation
48	/// can use the [`check_write`] helper function.
49	async fn write(&mut self, offset: u32, bytes: &[u8]) -> Result<(), Self::Error>;
50}
51
52impl<T: ReadNorFlash> ReadNorFlash for &mut T {
53	const READ_SIZE: usize = T::READ_SIZE;
54
55	async fn read(&mut self, offset: u32, bytes: &mut [u8]) -> Result<(), Self::Error> {
56		T::read(self, offset, bytes).await
57	}
58
59	fn capacity(&self) -> usize {
60		T::capacity(self)
61	}
62}
63
64impl<T: NorFlash> NorFlash for &mut T {
65	const WRITE_SIZE: usize = T::WRITE_SIZE;
66	const ERASE_SIZE: usize = T::ERASE_SIZE;
67
68	async fn erase(&mut self, from: u32, to: u32) -> Result<(), Self::Error> {
69		T::erase(self, from, to).await
70	}
71
72	async fn write(&mut self, offset: u32, bytes: &[u8]) -> Result<(), Self::Error> {
73		T::write(self, offset, bytes).await
74	}
75}
76
77/// Marker trait for NorFlash relaxing the restrictions on `write`.
78///
79/// Writes to the same word twice are now allowed. The result is the logical AND of the
80/// previous data and the written data. That is, it is only possible to change 1 bits to 0 bits.
81///
82/// If power is lost during write:
83/// - Bits that were 1 on flash and are written to 1 are guaranteed to stay as 1
84/// - Bits that were 1 on flash and are written to 0 are undefined
85/// - Bits that were 0 on flash are guaranteed to stay as 0
86/// - Rest of the bits in the page are guaranteed to be unchanged
87pub trait MultiwriteNorFlash: NorFlash {}