From 397446a784d1ac1eaee2f23eb48d84ccfefa291c Mon Sep 17 00:00:00 2001 From: =?UTF-8?q?Sosth=C3=A8ne=20Gu=C3=A9don?= Date: Wed, 13 Nov 2024 16:44:57 +0100 Subject: [PATCH] Add test for littlefs macros --- examples/flash.rs | 3 +++ src/drivers/flash.rs | 12 ++++++------ 2 files changed, 9 insertions(+), 6 deletions(-) diff --git a/examples/flash.rs b/examples/flash.rs index 89edfe4..bce973b 100644 --- a/examples/flash.rs +++ b/examples/flash.rs @@ -222,3 +222,6 @@ fn main() -> ! { continue; } } + +#[cfg(feature = "littlefs")] +lpc55_hal::littlefs2_filesystem!(InternalFilesystem: (0, 10)); diff --git a/src/drivers/flash.rs b/src/drivers/flash.rs index 350ca4d..ad362bd 100644 --- a/src/drivers/flash.rs +++ b/src/drivers/flash.rs @@ -439,13 +439,13 @@ macro_rules! littlefs2_filesystem { type LOOKAHEAD_SIZE = $crate::drivers::flash::littlefs_params::LOOKAHEAD_SIZE; - fn read(&mut self, off: usize, buf: &mut [u8]) -> LfsResult { + fn read(&mut self, off: usize, buf: &mut [u8]) -> littlefs2::io::Result { <$crate::drivers::flash::FlashGordon as $crate::traits::flash::Read<$crate::drivers::flash::U16>> ::read(&self.flash_gordon, Self::BASE_OFFSET + off, buf); Ok(buf.len()) } - fn write(&mut self, off: usize, data: &[u8]) -> LfsResult { + fn write(&mut self, off: usize, data: &[u8]) -> littlefs2::io::Result { let ret = <$crate::drivers::flash::FlashGordon as $crate::traits::flash::WriteErase<$crate::drivers::flash::U512, $crate::drivers::flash::U512>> ::write(&mut self.flash_gordon, Self::BASE_OFFSET + off, data); ret @@ -453,7 +453,7 @@ macro_rules! littlefs2_filesystem { .map_err(|_| littlefs2::io::Error::IO) } - fn erase(&mut self, off: usize, len: usize) -> LfsResult { + fn erase(&mut self, off: usize, len: usize) -> littlefs2::io::Result { let first_page = (Self::BASE_OFFSET + off) / 512; let pages = len / 512; for i in 0..pages { @@ -523,7 +523,7 @@ macro_rules! littlefs2_prince_filesystem { type LOOKAHEAD_SIZE = $crate::drivers::flash::littlefs_params::LOOKAHEAD_SIZE; - fn read(&mut self, off: usize, buf: &mut [u8]) -> LfsResult { + fn read(&mut self, off: usize, buf: &mut [u8]) -> littlefs2::io::Result { self.prince.enable_region_2_for(||{ let flash: *const u8 = (Self::BASE_OFFSET + off) as *const u8; for i in 0 .. buf.len() { @@ -533,7 +533,7 @@ macro_rules! littlefs2_prince_filesystem { Ok(buf.len()) } - fn write(&mut self, off: usize, data: &[u8]) -> LfsResult { + fn write(&mut self, off: usize, data: &[u8]) -> littlefs2::io::Result { let prince = &mut self.prince; let flash_gordon = &mut self.flash_gordon; let ret = prince.write_encrypted(|prince| { @@ -548,7 +548,7 @@ macro_rules! littlefs2_prince_filesystem { .map_err(|_| littlefs2::io::Error::IO) } - fn erase(&mut self, off: usize, len: usize) -> LfsResult { + fn erase(&mut self, off: usize, len: usize) -> littlefs2::io::Result { let first_page = (Self::BASE_OFFSET + off) / 512; let pages = len / 512; for i in 0..pages {