Zephyr API Documentation
2.7.0-rc2
A Scalable Open Source RTOS
|
Abstraction over flash partitions/areas and their drivers. More...
Data Structures | |
struct | flash_area |
Flash partition. More... | |
struct | flash_sector |
Structure for transfer flash sector boundaries. More... | |
Macros | |
#define | SOC_FLASH_0_ID 0 |
#define | SPI_FLASH_0_ID 1 |
#define | FLASH_AREA_LABEL_EXISTS(label) DT_HAS_FIXED_PARTITION_LABEL(label) |
#define | FLASH_AREA_LABEL_STR(lbl) DT_PROP(DT_NODE_BY_FIXED_PARTITION_LABEL(lbl), label) |
#define | FLASH_AREA_ID(label) DT_FIXED_PARTITION_ID(DT_NODE_BY_FIXED_PARTITION_LABEL(label)) |
#define | FLASH_AREA_OFFSET(label) DT_REG_ADDR(DT_NODE_BY_FIXED_PARTITION_LABEL(label)) |
#define | FLASH_AREA_SIZE(label) DT_REG_SIZE(DT_NODE_BY_FIXED_PARTITION_LABEL(label)) |
Typedefs | |
typedef void(* | flash_area_cb_t) (const struct flash_area *fa, void *user_data) |
Functions | |
int | flash_area_open (uint8_t id, const struct flash_area **fa) |
Retrieve partitions flash area from the flash_map. More... | |
void | flash_area_close (const struct flash_area *fa) |
Close flash_area. More... | |
int | flash_area_read (const struct flash_area *fa, off_t off, void *dst, size_t len) |
Read flash area data. More... | |
int | flash_area_write (const struct flash_area *fa, off_t off, const void *src, size_t len) |
Write data to flash area. More... | |
int | flash_area_erase (const struct flash_area *fa, off_t off, size_t len) |
Erase flash area. More... | |
uint8_t | flash_area_align (const struct flash_area *fa) |
Get write block size of the flash area. More... | |
int | flash_area_get_sectors (int fa_id, uint32_t *count, struct flash_sector *sectors) |
void | flash_area_foreach (flash_area_cb_t user_cb, void *user_data) |
int | flash_area_has_driver (const struct flash_area *fa) |
const struct device * | flash_area_get_device (const struct flash_area *fa) |
uint8_t | flash_area_erased_val (const struct flash_area *fa) |
Abstraction over flash partitions/areas and their drivers.
#define FLASH_AREA_ID | ( | label | ) | DT_FIXED_PARTITION_ID(DT_NODE_BY_FIXED_PARTITION_LABEL(label)) |
#include <include/storage/flash_map.h>
#define FLASH_AREA_LABEL_EXISTS | ( | label | ) | DT_HAS_FIXED_PARTITION_LABEL(label) |
#include <include/storage/flash_map.h>
#define FLASH_AREA_LABEL_STR | ( | lbl | ) | DT_PROP(DT_NODE_BY_FIXED_PARTITION_LABEL(lbl), label) |
#include <include/storage/flash_map.h>
#define FLASH_AREA_OFFSET | ( | label | ) | DT_REG_ADDR(DT_NODE_BY_FIXED_PARTITION_LABEL(label)) |
#include <include/storage/flash_map.h>
#define FLASH_AREA_SIZE | ( | label | ) | DT_REG_SIZE(DT_NODE_BY_FIXED_PARTITION_LABEL(label)) |
#include <include/storage/flash_map.h>
#define SOC_FLASH_0_ID 0 |
#include <include/storage/flash_map.h>
Provided for compatibility with MCUboot
#define SPI_FLASH_0_ID 1 |
#include <include/storage/flash_map.h>
Provided for compatibility with MCUboot
typedef void(* flash_area_cb_t) (const struct flash_area *fa, void *user_data) |
#include <include/storage/flash_map.h>
Flash map iteration callback
fa | flash area |
user_data | User supplied data |
uint8_t flash_area_align | ( | const struct flash_area * | fa | ) |
#include <include/storage/flash_map.h>
Get write block size of the flash area.
Currently write block size might be treated as read block size, although most of drivers supports unaligned readout.
[in] | fa | Flash area |
void flash_area_close | ( | const struct flash_area * | fa | ) |
#include <include/storage/flash_map.h>
Close flash_area.
Reserved for future usage and external projects compatibility reason. Currently is NOP.
[in] | fa | Flash area to be closed. |
int flash_area_erase | ( | const struct flash_area * | fa, |
off_t | off, | ||
size_t | len | ||
) |
#include <include/storage/flash_map.h>
Erase flash area.
Erase given flash area range. Area boundaries are asserted before erase request. API has the same limitation regard erase-block alignment and size as wrapped flash driver.
[in] | fa | Flash area |
[in] | off | Offset relative from beginning of flash area. |
[in] | len | Number of bytes to be erase |
uint8_t flash_area_erased_val | ( | const struct flash_area * | fa | ) |
#include <include/storage/flash_map.h>
Get the value expected to be read when accessing any erased flash byte. This API is compatible with the MCUBoot's porting layer.
fa | Flash area. |
void flash_area_foreach | ( | flash_area_cb_t | user_cb, |
void * | user_data | ||
) |
#include <include/storage/flash_map.h>
Iterate over flash map
user_cb | User callback |
user_data | User supplied data |
const struct device * flash_area_get_device | ( | const struct flash_area * | fa | ) |
#include <include/storage/flash_map.h>
Get driver for given flash area.
fa | Flash area. |
int flash_area_get_sectors | ( | int | fa_id, |
uint32_t * | count, | ||
struct flash_sector * | sectors | ||
) |
#include <include/storage/flash_map.h>
Retrieve info about sectors within the area.
[in] | fa_id | Given flash area ID |
[out] | sectors | buffer for sectors data |
[in,out] | count | On input Capacity of sectors , on output number of sectors Retrieved. |
int flash_area_has_driver | ( | const struct flash_area * | fa | ) |
#include <include/storage/flash_map.h>
Check whether given flash area has supporting flash driver in the system.
[in] | fa | Flash area. |
int flash_area_open | ( | uint8_t | id, |
const struct flash_area ** | fa | ||
) |
#include <include/storage/flash_map.h>
Retrieve partitions flash area from the flash_map.
Function Retrieves flash_area from flash_map for given partition.
[in] | id | ID of the flash partition. |
[out] | fa | Pointer which has to reference flash_area. If ID is unknown, it will be NULL on output. |
ID
is unknown. int flash_area_read | ( | const struct flash_area * | fa, |
off_t | off, | ||
void * | dst, | ||
size_t | len | ||
) |
#include <include/storage/flash_map.h>
Read flash area data.
Read data from flash area. Area readout boundaries are asserted before read request. API has the same limitation regard read-block alignment and size as wrapped flash driver.
[in] | fa | Flash area |
[in] | off | Offset relative from beginning of flash area to read |
[out] | dst | Buffer to store read data |
[in] | len | Number of bytes to read |
int flash_area_write | ( | const struct flash_area * | fa, |
off_t | off, | ||
const void * | src, | ||
size_t | len | ||
) |
#include <include/storage/flash_map.h>
Write data to flash area.
Write data to flash area. Area write boundaries are asserted before write request. API has the same limitation regard write-block alignment and size as wrapped flash driver.
[in] | fa | Flash area |
[in] | off | Offset relative from beginning of flash area to read |
[out] | src | Buffer with data to be written |
[in] | len | Number of bytes to write |