mirror of
https://github.com/espressif/esp-idf.git
synced 2026-04-27 19:13:21 +00:00
fix(esp_rom): sync spi_flash_disable/enable_cache patches to rom implementation
This commit is contained in:
@@ -139,8 +139,8 @@ PROVIDE( spi_flash_check_and_flush_cache = 0x400001a4 );
|
||||
PROVIDE( spi_flash_mmap_get_free_pages = 0x400001a8 );
|
||||
PROVIDE( spi_flash_cache2phys = 0x400001ac );
|
||||
PROVIDE( spi_flash_phys2cache = 0x400001b0 );
|
||||
PROVIDE( spi_flash_disable_cache = 0x400001b4 );
|
||||
PROVIDE( spi_flash_restore_cache = 0x400001b8 );
|
||||
PROVIDE( rom_spi_flash_disable_cache = 0x400001b4 );
|
||||
PROVIDE( rom_spi_flash_restore_cache = 0x400001b8 );
|
||||
PROVIDE( spi_flash_cache_enabled = 0x400001bc );
|
||||
PROVIDE( spi_flash_enable_cache = 0x400001c0 );
|
||||
PROVIDE( spi_cache_mode_switch = 0x400001c4 );
|
||||
|
||||
@@ -144,8 +144,8 @@ PROVIDE( spi_flash_check_and_flush_cache = 0x400001b4 );
|
||||
PROVIDE( spi_flash_mmap_get_free_pages = 0x400001b8 );
|
||||
PROVIDE( spi_flash_cache2phys = 0x400001bc );
|
||||
PROVIDE( spi_flash_phys2cache = 0x400001c0 );
|
||||
PROVIDE( spi_flash_disable_cache = 0x400001c4 );
|
||||
PROVIDE( spi_flash_restore_cache = 0x400001c8 );
|
||||
PROVIDE( rom_spi_flash_disable_cache = 0x400001c4 );
|
||||
PROVIDE( rom_spi_flash_restore_cache = 0x400001c8 );
|
||||
PROVIDE( spi_flash_cache_enabled = 0x400001cc );
|
||||
PROVIDE( spi_flash_enable_cache = 0x400001d0 );
|
||||
PROVIDE( spi_cache_mode_switch = 0x400001d4 );
|
||||
|
||||
@@ -18,8 +18,8 @@
|
||||
***************************************/
|
||||
|
||||
/* Functions */
|
||||
spi_flash_disable_cache = 0x40000204;
|
||||
spi_flash_restore_cache = 0x40000208;
|
||||
rom_spi_flash_disable_cache = 0x40000204;
|
||||
rom_spi_flash_restore_cache = 0x40000208;
|
||||
spi_flash_cache_enabled = 0x4000020c;
|
||||
spi_flash_enable_cache = 0x40000210;
|
||||
esp_enable_cache_flash_wrap = 0x40000214;
|
||||
|
||||
@@ -18,8 +18,8 @@
|
||||
***************************************/
|
||||
|
||||
/* Functions */
|
||||
spi_flash_disable_cache = 0x400001f0;
|
||||
spi_flash_restore_cache = 0x400001f4;
|
||||
rom_spi_flash_disable_cache = 0x400001f0;
|
||||
rom_spi_flash_restore_cache = 0x400001f4;
|
||||
spi_flash_cache_enabled = 0x400001f8;
|
||||
esp_enable_cache_flash_wrap = 0x40000200;
|
||||
|
||||
|
||||
@@ -18,8 +18,8 @@
|
||||
***************************************/
|
||||
|
||||
/* Functions */
|
||||
spi_flash_disable_cache = 0x40000204;
|
||||
spi_flash_restore_cache = 0x40000208;
|
||||
rom_spi_flash_disable_cache = 0x40000204;
|
||||
rom_spi_flash_restore_cache = 0x40000208;
|
||||
spi_flash_cache_enabled = 0x4000020c;
|
||||
spi_flash_enable_cache = 0x40000210;
|
||||
esp_enable_cache_flash_wrap = 0x40000214;
|
||||
|
||||
@@ -18,8 +18,8 @@
|
||||
***************************************/
|
||||
|
||||
/* Functions */
|
||||
spi_flash_disable_cache = 0x400001e8;
|
||||
spi_flash_restore_cache = 0x400001ec;
|
||||
rom_spi_flash_disable_cache = 0x400001e8;
|
||||
rom_spi_flash_restore_cache = 0x400001ec;
|
||||
spi_flash_cache_enabled = 0x400001f0;
|
||||
esp_enable_cache_flash_wrap = 0x400001f8;
|
||||
|
||||
|
||||
@@ -18,8 +18,8 @@
|
||||
***************************************/
|
||||
|
||||
/* Functions */
|
||||
spi_flash_disable_cache = 0x400001e8;
|
||||
spi_flash_restore_cache = 0x400001ec;
|
||||
rom_spi_flash_disable_cache = 0x400001e8;
|
||||
rom_spi_flash_restore_cache = 0x400001ec;
|
||||
spi_flash_cache_enabled = 0x400001f0;
|
||||
spi_flash_enable_cache = 0x400001f4;
|
||||
esp_enable_cache_flash_wrap = 0x400001f8;
|
||||
|
||||
@@ -18,8 +18,8 @@
|
||||
***************************************/
|
||||
|
||||
/* Functions */
|
||||
spi_flash_disable_cache = 0x400001f8;
|
||||
spi_flash_restore_cache = 0x400001fc;
|
||||
rom_spi_flash_disable_cache = 0x400001f8;
|
||||
rom_spi_flash_restore_cache = 0x400001fc;
|
||||
spi_flash_cache_enabled = 0x40000200;
|
||||
spi_flash_enable_cache = 0x40000204;
|
||||
esp_enable_cache_flash_wrap = 0x40000208;
|
||||
|
||||
@@ -196,8 +196,8 @@ PROVIDE( spi_flash_check_and_flush_cache = 0x40000bdc );
|
||||
PROVIDE( spi_flash_mmap_get_free_pages = 0x40000be8 );
|
||||
PROVIDE( spi_flash_cache2phys = 0x40000bf4 ); /* patched when XIP */
|
||||
PROVIDE( spi_flash_phys2cache = 0x40000c00 ); /* patched when XIP */
|
||||
PROVIDE( spi_flash_disable_cache = 0x40000c0c );
|
||||
PROVIDE( spi_flash_restore_cache = 0x40000c18 );
|
||||
PROVIDE( rom_spi_flash_disable_cache = 0x40000c0c );
|
||||
PROVIDE( rom_spi_flash_restore_cache = 0x40000c18 );
|
||||
PROVIDE( spi_flash_cache_enabled = 0x40000c24 );
|
||||
PROVIDE( spi_flash_enable_cache = 0x40000c30 );
|
||||
PROVIDE( spi_cache_mode_switch = 0x40000c3c );
|
||||
|
||||
@@ -13,6 +13,9 @@
|
||||
#include "soc/spi_mem_reg.h"
|
||||
#endif
|
||||
|
||||
#if SOC_BRANCH_PREDICTOR_SUPPORTED
|
||||
#include "riscv/rv_utils.h"
|
||||
#endif
|
||||
#include "esp_rom_spiflash.h"
|
||||
#if CONFIG_IDF_TARGET_ESP32
|
||||
#include "esp32/rom/spi_flash.h"
|
||||
@@ -806,3 +809,24 @@ void esp_rom_opiflash_cache_mode_config(esp_rom_spiflash_read_mode_t mode, const
|
||||
}
|
||||
|
||||
#endif // IDF_TARGET
|
||||
|
||||
#if CONFIG_SPI_FLASH_ROM_IMPL
|
||||
extern void rom_spi_flash_disable_cache(uint32_t cpuid, uint32_t *saved_state);
|
||||
void spi_flash_disable_cache(uint32_t cpuid, uint32_t *saved_state)
|
||||
{
|
||||
#if SOC_BRANCH_PREDICTOR_SUPPORTED
|
||||
//branch predictor will start cache request as well
|
||||
rv_utils_dis_branch_predictor();
|
||||
#endif
|
||||
rom_spi_flash_disable_cache(cpuid, saved_state);
|
||||
}
|
||||
|
||||
extern void rom_spi_flash_restore_cache(uint32_t cpuid, uint32_t saved_state);
|
||||
void spi_flash_restore_cache(uint32_t cpuid, uint32_t saved_state)
|
||||
{
|
||||
rom_spi_flash_restore_cache(cpuid, saved_state);
|
||||
#if SOC_BRANCH_PREDICTOR_SUPPORTED
|
||||
rv_utils_en_branch_predictor();
|
||||
#endif
|
||||
}
|
||||
#endif
|
||||
|
||||
@@ -336,6 +336,7 @@ void IRAM_ATTR spi_flash_enable_cache(uint32_t cpuid)
|
||||
#endif
|
||||
}
|
||||
|
||||
#if !CONFIG_SPI_FLASH_ROM_IMPL
|
||||
void IRAM_ATTR spi_flash_disable_cache(uint32_t cpuid, uint32_t *saved_state)
|
||||
{
|
||||
#if SOC_BRANCH_PREDICTOR_SUPPORTED
|
||||
@@ -357,6 +358,7 @@ bool IRAM_ATTR spi_flash_cache_enabled(void)
|
||||
{
|
||||
return cache_hal_is_cache_enabled(CACHE_LL_LEVEL_EXT_MEM, CACHE_TYPE_ALL);
|
||||
}
|
||||
#endif
|
||||
|
||||
#if CONFIG_IDF_TARGET_ESP32S2
|
||||
IRAM_ATTR void esp_config_instruction_cache_mode(void)
|
||||
|
||||
Reference in New Issue
Block a user