Crates.io | eeprom |
lib.rs | eeprom |
version | 0.3.1 |
source | src |
created_at | 2017-09-30 03:46:41.860893 |
updated_at | 2022-11-19 04:10:17.753873 |
description | EEPROM emulation on top of FLASH for STM32 |
homepage | |
repository | https://github.com/idubrov/eeprom |
max_upload_size | |
id | 33971 |
size | 93,406 |
Flash-based EEPROM emulation for the STM32 series microcontrollers. Uses 2 or more Flash pages for storing 16-bit data.
use eeprom::EEPROM;
struct MockFlash;
// let param = Params { .. };
// let mut flash: stm32f1::stm32f103::FLASH = /* get flash somehow */;
let mut eeprom = flash.eeprom(params);
eeprom.init().expect("failed to init EEPROM");
eeprom.write(1, 0xdead).expect("failed to write data to EEPROM");
eeprom.write(2, 0xbeef).expect("failed to write data to EEPROM");
assert_eq!(0xdead, eeprom.read(1).unwrap());
assert_eq!(0xbeef, eeprom.read(2).unwrap());
assert_eq!(true, eeprom.read(3).is_none());
EEPROM controller will panic in the following cases:
read
/write
operation (init
makes sure that there
is exactly one active page.Licensed under either of
at your option.
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.