Flash Abstraction Layer partition configuration. More...
Flash Abstraction Layer partition configuration.
FlashDB can only use a single MTD device, but allows for multiple named partitions on the MTD device.
This file pre-defines up to 4 partitions, if you need more edit this file or provide your own FAL_PART_TABLE.
Definition in file fal_cfg.h.
 Include dependency graph for fal_cfg.h:
 Include dependency graph for fal_cfg.h:Go to the source code of this file.
| #define | CONFIG_FLASHDB_MIN_SECTOR_SIZE_DEFAULT_KiB 4 | 
| Minimal virtual sector size in KiB for FlashDB.  More... | |
| #define | FAL_PART_HAS_TABLE_CFG | 
| Partition table is defined at compile time (not read from flash) | |
| #define | FAL_FLASH_DEV_TABLE | 
| flash device table  More... | |
| #define | FAL_MTD mtd_dev_get(0) | 
| Default MTD to use for flashdb. | |
| #define | FAL_PART0_LABEL "part0" | 
| Have at least the label of partition 0 defined. | |
| #define | FAL_PART0_LENGTH (2 * (CONFIG_FLASHDB_MIN_SECTOR_SIZE_DEFAULT_KiB * KiB(1))) | 
| Have at least the length of partition 0 defined, which must be at least two sectors and a multiple of the virtual sector size.  More... | |
| #define | FAL_PART0_OFFSET 0 | 
| Partition 0.  More... | |
| #define | FAL_ROW_PART0 | 
| Partition 0 compound definition.  More... | |
| #define | FAL_PART1_OFFSET (FAL_PART0_OFFSET + FAL_PART0_LENGTH) | 
| Partition 1.  More... | |
| #define | FAL_ROW_PART1 | 
| Partition 1 compound definition.  More... | |
| #define | FAL_PART2_OFFSET (FAL_PART1_OFFSET + FAL_PART1_LENGTH) | 
| Partition 2.  More... | |
| #define | FAL_ROW_PART2 | 
| Partition 2 compound definition.  More... | |
| #define | FAL_PART3_OFFSET (FAL_PART2_OFFSET + FAL_PART2_LENGTH) | 
| Partition 3.  More... | |
| #define | FAL_ROW_PART3 | 
| Partition 3 compound definition.  More... | |
| #define | FAL_PART_TABLE | 
| Partition Table.  More... | |
| struct fal_flash_dev | mtd_flash0 | 
| FAL <-> MTD adapter. | |
| #define CONFIG_FLASHDB_MIN_SECTOR_SIZE_DEFAULT_KiB 4 | 
Minimal virtual sector size in KiB for FlashDB.
This is just a reasonable default for an automatic partition configuration, hence "DEFAULT". The "MIN" stands for a required minimum to guarantee an expected size of key value pairs. The actually acceptable sector size must be a multiple of the physical sector size though. Thus, it can be larger than the minimum required size.
The default is 4 (4096). FlashDB sector size is different from MTD sector size as it is a virtual measure of granularity and not a device property. The virtual sector size must be a multiple of the physical sector size.
From the documentation of FLashDB: The internal storage structure of FlashDB is composed of N sectors, and each formatting takes sector as the smallest unit. A sector is usually N times the size of the Flash block. For example, the block size of Nor Flash is generally 4096.
By default, KVDB will use 1 times the block size as the sector size, that is, 4096. At this time, the KVDB cannot store a KV longer than 4096. If you want to save, for example, a KV with a length of 10K, you can use the control function to set the sector size to 12K or larger.
| #define FAL_FLASH_DEV_TABLE | 
flash device table
| #define FAL_PART0_LENGTH (2 * (CONFIG_FLASHDB_MIN_SECTOR_SIZE_DEFAULT_KiB * KiB(1))) | 
Have at least the length of partition 0 defined, which must be at least two sectors and a multiple of the virtual sector size.
The virtual sector size is however bound to the physical sector size of FAL_MTD. So make sure that CONFIG_FLASHDB_MIN_SECTOR_SIZE_DEFAULT_KiB times 1024 is a multiple of the MTD sector size. For example if the MTD sector size is 4KiB, then CONFIG_FLASHDB_MIN_SECTOR_SIZE_DEFAULT_KiB must be a multiple of 4. If the MTD sector size is 1KiB, then you have all options for CONFIG_FLASHDB_MIN_SECTOR_SIZE_DEFAULT_KiB.
| #define FAL_PART0_OFFSET 0 | 
| #define FAL_PART1_OFFSET (FAL_PART0_OFFSET + FAL_PART0_LENGTH) | 
| #define FAL_PART2_OFFSET (FAL_PART1_OFFSET + FAL_PART1_LENGTH) | 
| #define FAL_PART3_OFFSET (FAL_PART2_OFFSET + FAL_PART2_LENGTH) | 
| #define FAL_PART_TABLE | 
| #define FAL_ROW_PART0 | 
Partition 0 compound definition.
| #define FAL_ROW_PART1 | 
| #define FAL_ROW_PART2 |