correct chec^Cfor flash erase boundaries
This commit is contained in:
parent
e97b0cfc61
commit
dc97b0d844
@ -109,6 +109,9 @@
|
|||||||
#define CIRCUITPY_DEFAULT_STACK_SIZE 4096
|
#define CIRCUITPY_DEFAULT_STACK_SIZE 4096
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
|
// Smallest unit of flash that can be erased.
|
||||||
|
#define FLASH_ERASE_SIZE NVMCTRL_ROW_SIZE
|
||||||
|
|
||||||
#endif // SAMD21
|
#endif // SAMD21
|
||||||
|
|
||||||
////////////////////////////////////////////////////////////////////////////////////////////////////
|
////////////////////////////////////////////////////////////////////////////////////////////////////
|
||||||
@ -123,6 +126,9 @@
|
|||||||
#define CIRCUITPY_DEFAULT_STACK_SIZE (24*1024)
|
#define CIRCUITPY_DEFAULT_STACK_SIZE (24*1024)
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
|
// Smallest unit of flash that can be erased.
|
||||||
|
#define FLASH_ERASE_SIZE NVMCTRL_BLOCK_SIZE
|
||||||
|
|
||||||
// If CIRCUITPY is internal, use half of flash for it.
|
// If CIRCUITPY is internal, use half of flash for it.
|
||||||
#if INTERNAL_FLASH_FILESYSTEM
|
#if INTERNAL_FLASH_FILESYSTEM
|
||||||
#ifndef CIRCUITPY_INTERNAL_FLASH_FILESYSTEM_SIZE
|
#ifndef CIRCUITPY_INTERNAL_FLASH_FILESYSTEM_SIZE
|
||||||
@ -187,25 +193,25 @@
|
|||||||
#error BOOTLOADER_START_ADDR must be on a flash page boundary.
|
#error BOOTLOADER_START_ADDR must be on a flash page boundary.
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
#if CIRCUITPY_INTERNAL_NVM_START_ADDR % FLASH_PAGE_SIZE != 0
|
#if CIRCUITPY_INTERNAL_NVM_START_ADDR % FLASH_ERASE_SIZE != 0
|
||||||
#error CIRCUITPY_INTERNAL_NVM_START_ADDR must be on a flash page boundary.
|
#error CIRCUITPY_INTERNAL_NVM_START_ADDR must be on a flash erase (row or block) boundary.
|
||||||
#endif
|
#endif
|
||||||
#if CIRCUITPY_INTERNAL_NVM_SIZE % FLASH_PAGE_SIZE != 0
|
#if CIRCUITPY_INTERNAL_NVM_SIZE % FLASH_ERASE_SIZE != 0
|
||||||
#error CIRCUITPY_INTERNAL_NVM_SIZE must be a multiple of FLASH_PAGE_SIZE.
|
#error CIRCUITPY_INTERNAL_NVM_SIZE must be a multiple of FLASH_ERASE_SIZE.
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
#if CIRCUITPY_INTERNAL_CONFIG_START_ADDR % FLASH_PAGE_SIZE != 0
|
#if CIRCUITPY_INTERNAL_CONFIG_START_ADDR % FLASH_ERASE_SIZE != 0
|
||||||
#error CIRCUITPY_INTERNAL_CONFIG_SIZE must be on a flash page boundary.
|
#error CIRCUITPY_INTERNAL_CONFIG_SIZE must be on a flash erase (row or block) boundary.
|
||||||
#endif
|
#endif
|
||||||
#if CIRCUITPY_INTERNAL_CONFIG_SIZE % FLASH_PAGE_SIZE != 0
|
#if CIRCUITPY_INTERNAL_CONFIG_SIZE % FLASH_ERASE_SIZE != 0
|
||||||
#error CIRCUITPY_INTERNAL_CONFIG_SIZE must be a multiple of FLASH_PAGE_SIZE.
|
#error CIRCUITPY_INTERNAL_CONFIG_SIZE must be a multiple of FLASH_ERASE_SIZE.
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
#if CIRCUITPY_INTERNAL_FLASH_FILESYSTEM_START_ADDR % FLASH_PAGE_SIZE != 0
|
#if CIRCUITPY_INTERNAL_FLASH_FILESYSTEM_START_ADDR % FLASH_ERASE_SIZE != 0
|
||||||
#error CIRCUITPY_INTERNAL_FLASH_FILESYSTEM_SIZE must be on a flash page boundary.
|
#error CIRCUITPY_INTERNAL_FLASH_FILESYSTEM_SIZE must be on a flash erase (row or block) boundary.
|
||||||
#endif
|
#endif
|
||||||
#if CIRCUITPY_INTERNAL_FLASH_FILESYSTEM_SIZE % FLASH_PAGE_SIZE != 0
|
#if CIRCUITPY_INTERNAL_FLASH_FILESYSTEM_SIZE % FLASH_ERASE_SIZE != 0
|
||||||
#error CIRCUITPY_INTERNAL_FLASH_FILESYSTEM_SIZE must be a multiple of FLASH_PAGE_SIZE.
|
#error CIRCUITPY_INTERNAL_FLASH_FILESYSTEM_SIZE must be a multiple of FLASH_ERASE_SIZE.
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
#if CIRCUITPY_FIRMWARE_SIZE < 0
|
#if CIRCUITPY_FIRMWARE_SIZE < 0
|
||||||
|
@ -104,6 +104,9 @@
|
|||||||
#define ISR_START_ADDR (SD_FLASH_START_ADDR + SD_FLASH_SIZE)
|
#define ISR_START_ADDR (SD_FLASH_START_ADDR + SD_FLASH_SIZE)
|
||||||
#define ISR_SIZE (0x1000) // 4kiB
|
#define ISR_SIZE (0x1000) // 4kiB
|
||||||
|
|
||||||
|
// Smallest unit of flash that can be erased.
|
||||||
|
#define FLASH_ERASE_SIZE FLASH_PAGE_SIZE
|
||||||
|
|
||||||
#define CIRCUITPY_FIRMWARE_START_ADDR (ISR_START_ADDR + ISR_SIZE)
|
#define CIRCUITPY_FIRMWARE_START_ADDR (ISR_START_ADDR + ISR_SIZE)
|
||||||
|
|
||||||
// Define these regions starting down from the bootloader:
|
// Define these regions starting down from the bootloader:
|
||||||
@ -129,29 +132,29 @@
|
|||||||
// The firmware space is the space left over between the fixed lower and upper regions.
|
// The firmware space is the space left over between the fixed lower and upper regions.
|
||||||
#define CIRCUITPY_FIRMWARE_SIZE (CIRCUITPY_INTERNAL_FLASH_FILESYSTEM_START_ADDR - CIRCUITPY_FIRMWARE_START_ADDR)
|
#define CIRCUITPY_FIRMWARE_SIZE (CIRCUITPY_INTERNAL_FLASH_FILESYSTEM_START_ADDR - CIRCUITPY_FIRMWARE_START_ADDR)
|
||||||
|
|
||||||
#if BOOTLOADER_START_ADDR % FLASH_PAGE_SIZE != 0
|
#if BOOTLOADER_START_ADDR % FLASH_ERASE_SIZE != 0
|
||||||
#error BOOTLOADER_START_ADDR must be on a flash page boundary.
|
#error BOOTLOADER_START_ADDR must be on a flash erase boundary.
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
#if CIRCUITPY_INTERNAL_NVM_START_ADDR % FLASH_PAGE_SIZE != 0
|
#if CIRCUITPY_INTERNAL_NVM_START_ADDR % FLASH_ERASE_SIZE != 0
|
||||||
#error CIRCUITPY_INTERNAL_NVM_START_ADDR must be on a flash page boundary.
|
#error CIRCUITPY_INTERNAL_NVM_START_ADDR must be on a flash erase boundary.
|
||||||
#endif
|
#endif
|
||||||
#if CIRCUITPY_INTERNAL_NVM_SIZE % FLASH_PAGE_SIZE != 0
|
#if CIRCUITPY_INTERNAL_NVM_SIZE % FLASH_ERASE_SIZE != 0
|
||||||
#error CIRCUITPY_INTERNAL_NVM_SIZE must be a multiple of FLASH_PAGE_SIZE.
|
#error CIRCUITPY_INTERNAL_NVM_SIZE must be a multiple of FLASH_ERASE_SIZE.
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
#if CIRCUITPY_BLE_CONFIG_START_ADDR % FLASH_PAGE_SIZE != 0
|
#if CIRCUITPY_BLE_CONFIG_START_ADDR % FLASH_ERASE_SIZE != 0
|
||||||
#error CIRCUITPY_BLE_CONFIG_SIZE must be on a flash page boundary.
|
#error CIRCUITPY_BLE_CONFIG_SIZE must be on a flash erase boundary.
|
||||||
#endif
|
#endif
|
||||||
#if CIRCUITPY_BLE_CONFIG_SIZE % FLASH_PAGE_SIZE != 0
|
#if CIRCUITPY_BLE_CONFIG_SIZE % FLASH_ERASE_SIZE != 0
|
||||||
#error CIRCUITPY_BLE_CONFIG_SIZE must be a multiple of FLASH_PAGE_SIZE.
|
#error CIRCUITPY_BLE_CONFIG_SIZE must be a multiple of FLASH_ERASE_SIZE.
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
#if CIRCUITPY_INTERNAL_FLASH_FILESYSTEM_START_ADDR % FLASH_PAGE_SIZE != 0
|
#if CIRCUITPY_INTERNAL_FLASH_FILESYSTEM_START_ADDR % FLASH_ERASE_SIZE != 0
|
||||||
#error CIRCUITPY_INTERNAL_FLASH_FILESYSTEM_SIZE must be on a flash page boundary.
|
#error CIRCUITPY_INTERNAL_FLASH_FILESYSTEM_SIZE must be on a flash erase boundary.
|
||||||
#endif
|
#endif
|
||||||
#if CIRCUITPY_INTERNAL_FLASH_FILESYSTEM_SIZE % FLASH_PAGE_SIZE != 0
|
#if CIRCUITPY_INTERNAL_FLASH_FILESYSTEM_SIZE % FLASH_ERASE_SIZE != 0
|
||||||
#error CIRCUITPY_INTERNAL_FLASH_FILESYSTEM_SIZE must be a multiple of FLASH_PAGE_SIZE.
|
#error CIRCUITPY_INTERNAL_FLASH_FILESYSTEM_SIZE must be a multiple of FLASH_ERASE_SIZE.
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
#if CIRCUITPY_FIRMWARE_SIZE < 0
|
#if CIRCUITPY_FIRMWARE_SIZE < 0
|
||||||
|
Loading…
Reference in New Issue
Block a user