kopia lustrzana https://github.com/espressif/esp-idf
spi_flash: Move FLASH_PAGE_SIZE constant into esp_spi_flash.h
rodzic
14aa1d1b3e
commit
d4462664b7
|
@ -39,12 +39,11 @@
|
||||||
|
|
||||||
#define REGIONS_COUNT 4
|
#define REGIONS_COUNT 4
|
||||||
#define PAGES_PER_REGION 64
|
#define PAGES_PER_REGION 64
|
||||||
#define FLASH_PAGE_SIZE 0x10000
|
|
||||||
#define INVALID_ENTRY_VAL 0x100
|
#define INVALID_ENTRY_VAL 0x100
|
||||||
#define VADDR0_START_ADDR 0x3F400000
|
#define VADDR0_START_ADDR 0x3F400000
|
||||||
#define VADDR1_START_ADDR 0x40000000
|
#define VADDR1_START_ADDR 0x40000000
|
||||||
#define VADDR1_FIRST_USABLE_ADDR 0x400D0000
|
#define VADDR1_FIRST_USABLE_ADDR 0x400D0000
|
||||||
#define PRO_IRAM0_FIRST_USABLE_PAGE ((VADDR1_FIRST_USABLE_ADDR - VADDR1_START_ADDR) / FLASH_PAGE_SIZE + 64)
|
#define PRO_IRAM0_FIRST_USABLE_PAGE ((VADDR1_FIRST_USABLE_ADDR - VADDR1_START_ADDR) / SPI_FLASH_MMU_PAGE_SIZE + 64)
|
||||||
|
|
||||||
/* Ensure pages in a region haven't been marked as written via
|
/* Ensure pages in a region haven't been marked as written via
|
||||||
spi_flash_mark_modified_region(). If the page has
|
spi_flash_mark_modified_region(). If the page has
|
||||||
|
@ -124,8 +123,8 @@ esp_err_t IRAM_ATTR spi_flash_mmap(size_t src_addr, size_t size, spi_flash_mmap_
|
||||||
region_addr = VADDR1_FIRST_USABLE_ADDR;
|
region_addr = VADDR1_FIRST_USABLE_ADDR;
|
||||||
}
|
}
|
||||||
// region which should be mapped
|
// region which should be mapped
|
||||||
int phys_page = src_addr / FLASH_PAGE_SIZE;
|
int phys_page = src_addr / SPI_FLASH_MMU_PAGE_SIZE;
|
||||||
int page_count = (size + FLASH_PAGE_SIZE - 1) / FLASH_PAGE_SIZE;
|
int page_count = (size + SPI_FLASH_MMU_PAGE_SIZE - 1) / SPI_FLASH_MMU_PAGE_SIZE;
|
||||||
// The following part searches for a range of MMU entries which can be used.
|
// The following part searches for a range of MMU entries which can be used.
|
||||||
// Algorithm is essentially naïve strstr algorithm, except that unused MMU
|
// Algorithm is essentially naïve strstr algorithm, except that unused MMU
|
||||||
// entries are treated as wildcards.
|
// entries are treated as wildcards.
|
||||||
|
@ -171,7 +170,7 @@ esp_err_t IRAM_ATTR spi_flash_mmap(size_t src_addr, size_t size, spi_flash_mmap_
|
||||||
new_entry->count = page_count;
|
new_entry->count = page_count;
|
||||||
new_entry->handle = ++s_mmap_last_handle;
|
new_entry->handle = ++s_mmap_last_handle;
|
||||||
*out_handle = new_entry->handle;
|
*out_handle = new_entry->handle;
|
||||||
*out_ptr = (void*) (region_addr + start * FLASH_PAGE_SIZE);
|
*out_ptr = (void*) (region_addr + start * SPI_FLASH_MMU_PAGE_SIZE);
|
||||||
ret = ESP_OK;
|
ret = ESP_OK;
|
||||||
}
|
}
|
||||||
spi_flash_enable_interrupts_caches_and_other_cpu();
|
spi_flash_enable_interrupts_caches_and_other_cpu();
|
||||||
|
@ -256,8 +255,8 @@ static void IRAM_ATTR spi_flash_ensure_unmodified_region(size_t start_addr, size
|
||||||
/* generic implementation for the previous two functions */
|
/* generic implementation for the previous two functions */
|
||||||
static inline IRAM_ATTR void update_written_pages(size_t start_addr, size_t length, bool mark)
|
static inline IRAM_ATTR void update_written_pages(size_t start_addr, size_t length, bool mark)
|
||||||
{
|
{
|
||||||
for (uint32_t addr = start_addr; addr < start_addr + length; addr += FLASH_PAGE_SIZE) {
|
for (uint32_t addr = start_addr; addr < start_addr + length; addr += SPI_FLASH_MMU_PAGE_SIZE) {
|
||||||
int page = addr / FLASH_PAGE_SIZE;
|
int page = addr / SPI_FLASH_MMU_PAGE_SIZE;
|
||||||
if (page >= 256) {
|
if (page >= 256) {
|
||||||
return; /* invalid address */
|
return; /* invalid address */
|
||||||
}
|
}
|
||||||
|
|
|
@ -419,8 +419,6 @@ out:
|
||||||
return spi_flash_translate_rc(rc);
|
return spi_flash_translate_rc(rc);
|
||||||
}
|
}
|
||||||
|
|
||||||
#define FLASH_PAGE_SIZE 0x10000
|
|
||||||
|
|
||||||
esp_err_t IRAM_ATTR spi_flash_read_encrypted(size_t src, void *dstv, size_t size)
|
esp_err_t IRAM_ATTR spi_flash_read_encrypted(size_t src, void *dstv, size_t size)
|
||||||
{
|
{
|
||||||
if (src + size > g_rom_flashchip.chip_size) {
|
if (src + size > g_rom_flashchip.chip_size) {
|
||||||
|
@ -433,7 +431,7 @@ esp_err_t IRAM_ATTR spi_flash_read_encrypted(size_t src, void *dstv, size_t size
|
||||||
esp_err_t err;
|
esp_err_t err;
|
||||||
const uint8_t *map;
|
const uint8_t *map;
|
||||||
spi_flash_mmap_handle_t map_handle;
|
spi_flash_mmap_handle_t map_handle;
|
||||||
size_t map_src = src & ~(FLASH_PAGE_SIZE-1);
|
size_t map_src = src & ~(SPI_FLASH_MMU_PAGE_SIZE-1);
|
||||||
size_t map_size = size + (src - map_src);
|
size_t map_size = size + (src - map_src);
|
||||||
|
|
||||||
err = spi_flash_mmap(map_src, map_size, SPI_FLASH_MMAP_DATA, (const void **)&map, &map_handle);
|
err = spi_flash_mmap(map_src, map_size, SPI_FLASH_MMAP_DATA, (const void **)&map, &map_handle);
|
||||||
|
|
|
@ -31,6 +31,8 @@ extern "C" {
|
||||||
|
|
||||||
#define SPI_FLASH_SEC_SIZE 4096 /**< SPI Flash sector size */
|
#define SPI_FLASH_SEC_SIZE 4096 /**< SPI Flash sector size */
|
||||||
|
|
||||||
|
#define SPI_FLASH_MMU_PAGE_SIZE 0x10000 /**< Flash cache MMU mapping page size */
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* @brief Initialize SPI flash access driver
|
* @brief Initialize SPI flash access driver
|
||||||
*
|
*
|
||||||
|
@ -161,7 +163,8 @@ typedef uint32_t spi_flash_mmap_handle_t;
|
||||||
* page allocation, use spi_flash_mmap_dump function.
|
* page allocation, use spi_flash_mmap_dump function.
|
||||||
*
|
*
|
||||||
* @param src_addr Physical address in flash where requested region starts.
|
* @param src_addr Physical address in flash where requested region starts.
|
||||||
* This address *must* be aligned to 64kB boundary.
|
* This address *must* be aligned to 64kB boundary
|
||||||
|
* (SPI_FLASH_MMU_PAGE_SIZE).
|
||||||
* @param size Size of region which has to be mapped. This size will be rounded
|
* @param size Size of region which has to be mapped. This size will be rounded
|
||||||
* up to a 64k boundary.
|
* up to a 64k boundary.
|
||||||
* @param memory Memory space where the region should be mapped
|
* @param memory Memory space where the region should be mapped
|
||||||
|
|
|
@ -17,6 +17,7 @@ Macros
|
||||||
.. doxygendefine:: ESP_ERR_FLASH_OP_FAIL
|
.. doxygendefine:: ESP_ERR_FLASH_OP_FAIL
|
||||||
.. doxygendefine:: ESP_ERR_FLASH_OP_TIMEOUT
|
.. doxygendefine:: ESP_ERR_FLASH_OP_TIMEOUT
|
||||||
.. doxygendefine:: SPI_FLASH_SEC_SIZE
|
.. doxygendefine:: SPI_FLASH_SEC_SIZE
|
||||||
|
.. doxygendefine:: SPI_FLASH_MMU_PAGE_SIZE
|
||||||
.. doxygendefine:: ESP_PARTITION_SUBTYPE_OTA
|
.. doxygendefine:: ESP_PARTITION_SUBTYPE_OTA
|
||||||
|
|
||||||
Type Definitions
|
Type Definitions
|
||||||
|
|
Ładowanie…
Reference in New Issue