1
0
mirror of https://github.com/RIOT-OS/RIOT.git synced 2024-12-29 04:50:03 +01:00

flashpage: Make pagewise API optional

flashpage currently requires pagewise implementation with an optional
extension for per block writes (flashpage_raw). Most implementations
with flashpage_raw implement the pagewise access via the flashpage_raw
functions. This commit makes the flashpage raw the main access method
and adds an extension feature for the pagewise access.

The functions and defines are renamed to reflect this. The API is also
extended with a dedicated function for erasing a sector.
This commit is contained in:
Koen Zandberg 2020-11-09 16:39:11 +01:00
parent 91f1b1c071
commit 41bbaa7442
No known key found for this signature in database
GPG Key ID: 0895A893E6D2985B
4 changed files with 64 additions and 44 deletions

View File

@ -64,17 +64,17 @@ extern "C" {
#define CPU_FLASH_BASE (0) #define CPU_FLASH_BASE (0)
#endif #endif
/** /**
* @def FLASHPAGE_RAW_BLOCKSIZE * @def FLASHPAGE_WRITE_BLOCK_SIZE
* *
* @brief For raw writings to the flash, this constant must define the * @brief For raw writings to the flash, this constant must define the
* minimum write length allowed by the MCU. * minimum write length allowed by the MCU.
*/ */
#ifdef DOXYGEN #ifdef DOXYGEN
#define FLASHPAGE_RAW_BLOCKSIZE #define FLASHPAGE_WRITE_BLOCK_SIZE
#endif #endif
/** /**
* @def FLASHPAGE_RAW_ALIGNMENT * @def FLASHPAGE_WRITE_BLOCK_ALIGNMENT
* *
* @brief The buffers to be written to the flash MUST be aligned, as well as * @brief The buffers to be written to the flash MUST be aligned, as well as
* the address on which the buffer is written to the flash. This variable * the address on which the buffer is written to the flash. This variable
@ -82,7 +82,7 @@ extern "C" {
* requirements. * requirements.
*/ */
#ifdef DOXYGEN #ifdef DOXYGEN
#define FLASHPAGE_RAW_ALIGNMENT #define FLASHPAGE_WRITE_BLOCK_ALIGNMENT
#endif #endif
/** /**
* @def FLASHPAGE_SIZE * @def FLASHPAGE_SIZE
@ -114,7 +114,7 @@ enum {
* *
* @return starting memory address of the given page * @return starting memory address of the given page
*/ */
static inline void *flashpage_addr(int page) static inline void *flashpage_addr(unsigned page)
{ {
return (void *)(CPU_FLASH_BASE + (page * FLASHPAGE_SIZE)); return (void *)(CPU_FLASH_BASE + (page * FLASHPAGE_SIZE));
} }
@ -130,11 +130,18 @@ static inline void *flashpage_addr(int page)
* *
* @return page containing the given address * @return page containing the given address
*/ */
static inline int flashpage_page(void *addr) static inline unsigned flashpage_page(void *addr)
{ {
return (int)(((int)addr - CPU_FLASH_BASE) / FLASHPAGE_SIZE); return (((intptr_t)addr - CPU_FLASH_BASE) / FLASHPAGE_SIZE);
} }
/**
* @brief Erase the given page
*
* @param[in] page Page to erase
*/
void flashpage_erase(unsigned page);
/** /**
* @brief Write the given page with the given data * @brief Write the given page with the given data
* *
@ -142,7 +149,7 @@ static inline int flashpage_page(void *addr)
* @param[in] data data to write to the page, MUST be FLASHPAGE_SIZE * @param[in] data data to write to the page, MUST be FLASHPAGE_SIZE
* byte. Set to NULL for page erase only. * byte. Set to NULL for page erase only.
*/ */
void flashpage_write(int page, const void *data); void flashpage_write_page(unsigned page, const void *data);
/** /**
* @brief Write any number of data bytes to a given location in the * @brief Write any number of data bytes to a given location in the
@ -152,20 +159,20 @@ void flashpage_write(int page, const void *data);
* this function * this function
* *
* Both target address and data address must be aligned to * Both target address and data address must be aligned to
* FLASHPAGE_RAW_ALIGN. @p len must be a multiple of FLASHPAGE_RAW_BLOCKSIZE. * FLASHPAGE_BLOCK_ALIGN. @p len must be a multiple of FLASHPAGE_WRITE_BLOCK_SIZE.
* This function doesn't erase any area in flash, thus be sure the targeted * This function doesn't erase any area in flash, thus be sure the targeted
* memory area is erased before writing on it (using the flashpage_write function). * memory area is erased before writing on it (using the flashpage_write function).
* *
* @param[in] target_addr address in flash to write to. MUST be aligned * @param[in] target_addr address in flash to write to. MUST be aligned
* to FLASHPAGE_RAW_ALIGNMENT. * to FLASHPAGE_WRITE_BLOCK_ALIGNMENT.
* @param[in] data data to write to the address. MUST be aligned * @param[in] data data to write to the address. MUST be aligned
* to FLASHPAGE_RAW_ALIGNMENT. * to FLASHPAGE_WRITE_BLOCK_ALIGNMENT.
* @param[in] len length of the data to be written. It MUST be * @param[in] len length of the data to be written. It MUST be
* multiple of FLASHPAGE_RAW_BLOCKSIZE. Also, * multiple of FLASHPAGE_WRITE_BLOCK_SIZE. Also,
* ensure it doesn't exceed the actual flash * ensure it doesn't exceed the actual flash
* memory size. * memory size.
*/ */
void flashpage_write_raw(void *target_addr, const void *data, size_t len); void flashpage_write(void *target_addr, const void *data, size_t len);
/** /**
* @brief Read the given page into the given memory location * @brief Read the given page into the given memory location
@ -174,7 +181,7 @@ void flashpage_write_raw(void *target_addr, const void *data, size_t len);
* @param[out] data memory to write the page to, MUST be FLASHPAGE_SIZE * @param[out] data memory to write the page to, MUST be FLASHPAGE_SIZE
* byte * byte
*/ */
void flashpage_read(int page, void *data); void flashpage_read(unsigned page, void *data);
/** /**
* @brief Verify the given page against the given data * @brief Verify the given page against the given data
@ -186,7 +193,7 @@ void flashpage_read(int page, void *data);
* @return FLASHPAGE_OK if data in the page is identical to @p data * @return FLASHPAGE_OK if data in the page is identical to @p data
* @return FLASHPAGE_NOMATCH if data and page content diverge * @return FLASHPAGE_NOMATCH if data and page content diverge
*/ */
int flashpage_verify(int page, const void *data); int flashpage_verify(unsigned page, const void *data);
/** /**
* @brief Write the given page and verify the results * @brief Write the given page and verify the results
@ -200,7 +207,7 @@ int flashpage_verify(int page, const void *data);
* @return FLASHPAGE_OK on success * @return FLASHPAGE_OK on success
* @return FLASHPAGE_NOMATCH if data and page content diverge * @return FLASHPAGE_NOMATCH if data and page content diverge
*/ */
int flashpage_write_and_verify(int page, const void *data); int flashpage_write_and_verify(unsigned page, const void *data);
/** /**
* @brief Functions to support additional RWWEE flash section * @brief Functions to support additional RWWEE flash section
@ -227,7 +234,7 @@ int flashpage_write_and_verify(int page, const void *data);
* *
* @return starting memory address of the given RWWEE page * @return starting memory address of the given RWWEE page
*/ */
static inline void *flashpage_rwwee_addr(int page) static inline void *flashpage_rwwee_addr(unsigned page)
{ {
return (void *)(CPU_FLASH_RWWEE_BASE + (page * FLASHPAGE_SIZE)); return (void *)(CPU_FLASH_RWWEE_BASE + (page * FLASHPAGE_SIZE));
} }
@ -255,7 +262,7 @@ static inline int flashpage_rwwee_page(void *addr)
* @param[in] data data to write to the RWWEE page, MUST be FLASHPAGE_SIZE * @param[in] data data to write to the RWWEE page, MUST be FLASHPAGE_SIZE
* byte. Set to NULL for RWWEE page erase only. * byte. Set to NULL for RWWEE page erase only.
*/ */
void flashpage_rwwee_write(int page, const void *data); void flashpage_rwwee_write_page(unsigned page, const void *data);
/** /**
* @brief Write any number of data bytes to a given location in the * @brief Write any number of data bytes to a given location in the
@ -265,20 +272,20 @@ void flashpage_rwwee_write(int page, const void *data);
* this function * this function
* *
* Both target address and data address must be aligned to * Both target address and data address must be aligned to
* FLASHPAGE_RAW_ALIGN. @p len must be a multiple of FLASHPAGE_RAW_BLOCKSIZE. * FLASHPAGE_BLOCK_ALIGN. @p len must be a multiple of FLASHPAGE_WRITE_BLOCK_SIZE.
* This function doesn't erase any area in flash, thus be sure the targeted * This function doesn't erase any area in flash, thus be sure the targeted
* memory area is erased before writing on it (using the flashpage_write function). * memory area is erased before writing on it (using the flashpage_write function).
* *
* @param[in] target_addr RWWEE address in flash to write to. MUST be aligned * @param[in] target_addr RWWEE address in flash to write to. MUST be aligned
* to FLASHPAGE_RAW_ALIGNMENT. * to FLASHPAGE_WRITE_BLOCK_ALIGNMENT.
* @param[in] data data to write to the address. MUST be aligned * @param[in] data data to write to the address. MUST be aligned
* to FLASHPAGE_RAW_ALIGNMENT. * to FLASHPAGE_WRITE_BLOCK_ALIGNMENT.
* @param[in] len length of the data to be written. It MUST be * @param[in] len length of the data to be written. It MUST be
* multiple of FLASHPAGE_RAW_BLOCKSIZE. Also, * multiple of FLASHPAGE_WRITE_BLOCK_SIZE. Also,
* ensure it doesn't exceed the actual RWWEE flash * ensure it doesn't exceed the actual RWWEE flash
* memory size. * memory size.
*/ */
void flashpage_rwwee_write_raw(void *target_addr, const void *data, size_t len); void flashpage_rwwee_write(void *target_addr, const void *data, size_t len);
/** /**
* @brief Read the given RWWEE page into the given memory location * @brief Read the given RWWEE page into the given memory location
@ -287,7 +294,7 @@ void flashpage_rwwee_write_raw(void *target_addr, const void *data, size_t len);
* @param[out] data memory to write the RWWEE page to, MUST be FLASHPAGE_SIZE * @param[out] data memory to write the RWWEE page to, MUST be FLASHPAGE_SIZE
* byte * byte
*/ */
void flashpage_rwwee_read(int page, void *data); void flashpage_rwwee_read(unsigned page, void *data);
/** /**
* @brief Verify the given RWWEE page against the given data * @brief Verify the given RWWEE page against the given data
@ -299,7 +306,7 @@ void flashpage_rwwee_read(int page, void *data);
* @return FLASHPAGE_OK if data in the RWWEE page is identical to @p data * @return FLASHPAGE_OK if data in the RWWEE page is identical to @p data
* @return FLASHPAGE_NOMATCH if data and RWWEE page content diverge * @return FLASHPAGE_NOMATCH if data and RWWEE page content diverge
*/ */
int flashpage_rwwee_verify(int page, const void *data); int flashpage_rwwee_verify(unsigned page, const void *data);
/** /**
* @brief Write the given RWWEE page and verify the results * @brief Write the given RWWEE page and verify the results
@ -314,7 +321,7 @@ int flashpage_rwwee_verify(int page, const void *data);
* @return FLASHPAGE_OK on success * @return FLASHPAGE_OK on success
* @return FLASHPAGE_NOMATCH if data and RWWEE page content diverge * @return FLASHPAGE_NOMATCH if data and RWWEE page content diverge
*/ */
int flashpage_rwwee_write_and_verify(int page, const void *data); int flashpage_rwwee_write_and_verify(unsigned page, const void *data);
#endif /* FLASHPAGE_RWWEE_NUMOF */ #endif /* FLASHPAGE_RWWEE_NUMOF */

View File

@ -19,15 +19,15 @@ config MODULE_PERIPH_INIT_FLASHPAGE
default y if MODULE_PERIPH_INIT default y if MODULE_PERIPH_INIT
depends on MODULE_PERIPH_FLASHPAGE depends on MODULE_PERIPH_FLASHPAGE
config MODULE_PERIPH_FLASHPAGE_RAW config MODULE_PERIPH_FLASHPAGE_PAGEWISE
bool "Raw writing support" bool "Pagewise writing support"
depends on HAS_PERIPH_FLASHPAGE_RAW depends on HAS_PERIPH_FLASHPAGE_PAGEWISE
depends on MODULE_PERIPH_FLASHPAGE depends on MODULE_PERIPH_FLASHPAGE
config MODULE_PERIPH_INIT_FLASHPAGE_RAW config MODULE_PERIPH_INIT_FLASHPAGE_PAGEWISE
bool "Auto initialize Flashpage raw" bool "Auto initialize Flashpage pagewise"
default y if MODULE_PERIPH_INIT default y if MODULE_PERIPH_INIT
depends on MODULE_PERIPH_FLASHPAGE_RAW depends on MODULE_PERIPH_FLASHPAGE_PAGEWISE
config MODULE_PERIPH_FLASHPAGE_RWEE config MODULE_PERIPH_FLASHPAGE_RWEE
bool "Read while Write support" bool "Read while Write support"

View File

@ -28,18 +28,19 @@
#include "periph/flashpage.h" #include "periph/flashpage.h"
void flashpage_read(int page, void *data) #ifdef MODULE_PERIPH_FLASHPAGE_PAGEWISE
void flashpage_read(unsigned page, void *data)
{ {
assert(page < (int)FLASHPAGE_NUMOF); assert(page < FLASHPAGE_NUMOF);
#if defined(CPU_FAM_STM32WB) #if defined(CPU_FAM_STM32WB)
assert(page < (int)(FLASH->SFR & FLASH_SFR_SFSA)); assert(page < (FLASH->SFR & FLASH_SFR_SFSA));
#endif #endif
memcpy(data, flashpage_addr(page), FLASHPAGE_SIZE); memcpy(data, flashpage_addr(page), FLASHPAGE_SIZE);
} }
int flashpage_verify(int page, const void *data) int flashpage_verify(unsigned page, const void *data)
{ {
assert(page < (int)FLASHPAGE_NUMOF); assert(page < (int)FLASHPAGE_NUMOF);
@ -55,23 +56,35 @@ int flashpage_verify(int page, const void *data)
} }
} }
int flashpage_write_and_verify(int page, const void *data) int flashpage_write_and_verify(unsigned page, const void *data)
{ {
flashpage_write(page, data); flashpage_write_page(page, data);
return flashpage_verify(page, data); return flashpage_verify(page, data);
} }
void flashpage_write_page(unsigned page, const void *data)
{
assert((unsigned) page < FLASHPAGE_NUMOF);
flashpage_erase(page);
/* write page */
if (data != NULL) {
flashpage_write(flashpage_addr(page), data, FLASHPAGE_SIZE);
}
}
#endif /* MODULE_PERIPH_FLASHPAGE_PAGEWISE */
#if defined(FLASHPAGE_RWWEE_NUMOF) #if defined(FLASHPAGE_RWWEE_NUMOF)
void flashpage_rwwee_read(int page, void *data) void flashpage_rwwee_read(unsigned page, void *data)
{ {
assert(page < (int)FLASHPAGE_RWWEE_NUMOF); assert(page < (int)FLASHPAGE_RWWEE_NUMOF);
memcpy(data, flashpage_rwwee_addr(page), FLASHPAGE_SIZE); memcpy(data, flashpage_rwwee_addr(page), FLASHPAGE_SIZE);
} }
int flashpage_rwwee_verify(int page, const void *data) int flashpage_rwwee_verify(unsigned page, const void *data)
{ {
assert(page < (int)FLASHPAGE_RWWEE_NUMOF); assert(page < (int)FLASHPAGE_RWWEE_NUMOF);
@ -83,9 +96,9 @@ int flashpage_rwwee_verify(int page, const void *data)
} }
} }
int flashpage_rwwee_write_and_verify(int page, const void *data) int flashpage_rwwee_write_and_verify(unsigned page, const void *data)
{ {
flashpage_rwwee_write(page, data); flashpage_rwwee_write_page(page, data);
return flashpage_rwwee_verify(page, data); return flashpage_rwwee_verify(page, data);
} }

View File

@ -124,10 +124,10 @@ config HAS_PERIPH_FLASHPAGE
help help
Indicates that a Flashpage peripheral is present. Indicates that a Flashpage peripheral is present.
config HAS_PERIPH_FLASHPAGE_RAW config HAS_PERIPH_FLASHPAGE_PAGEWISE
bool bool
help help
Indicates that the Flashpage peripheral supports raw writing. Indicates that the Flashpage peripheral supports pagewise writing.
config HAS_PERIPH_FLASHPAGE_RWEE config HAS_PERIPH_FLASHPAGE_RWEE
bool bool