2020-09-01 17:06:22 +08:00
|
|
|
idf_build_get_property(target IDF_TARGET)
|
2021-07-02 12:27:09 +08:00
|
|
|
if(BOOTLOADER_BUILD)
|
|
|
|
set(srcs "${target}/spi_flash_rom_patch.c")
|
|
|
|
set(cache_srcs "")
|
|
|
|
set(priv_requires bootloader_support soc)
|
2018-01-12 13:49:13 +11:00
|
|
|
else()
|
2021-07-02 12:27:09 +08:00
|
|
|
set(cache_srcs
|
|
|
|
"cache_utils.c"
|
|
|
|
"flash_mmap.c"
|
|
|
|
"flash_ops.c"
|
|
|
|
"${target}/flash_ops_${target}.c"
|
|
|
|
)
|
|
|
|
set(srcs
|
|
|
|
"partition.c"
|
|
|
|
"${target}/spi_flash_rom_patch.c"
|
|
|
|
)
|
2021-04-15 17:13:48 +08:00
|
|
|
|
2021-07-02 12:27:09 +08:00
|
|
|
if(CONFIG_ESPTOOLPY_OCT_FLASH)
|
|
|
|
list(APPEND srcs "${target}/spi_flash_oct_flash_init.c")
|
|
|
|
endif()
|
2021-04-15 17:13:48 +08:00
|
|
|
|
2021-07-02 12:27:09 +08:00
|
|
|
if(CONFIG_IDF_TARGET_ESP32S3)
|
2020-09-18 14:32:37 +08:00
|
|
|
list(APPEND srcs
|
2021-07-02 12:27:09 +08:00
|
|
|
"esp32s3/spi_timing_config.c"
|
2022-02-25 17:03:45 +08:00
|
|
|
"spi_flash_timing_tuning.c"
|
2023-06-24 20:38:53 +08:00
|
|
|
)
|
|
|
|
endif()
|
|
|
|
|
|
|
|
if(CONFIG_SPI_FLASH_HPM_ON)
|
|
|
|
list(APPEND srcs
|
2022-02-25 17:03:45 +08:00
|
|
|
"spi_flash_hpm_enable.c")
|
2019-10-22 13:51:49 +11:00
|
|
|
endif()
|
|
|
|
|
2021-07-02 12:27:09 +08:00
|
|
|
# New implementation after IDF v4.0
|
|
|
|
list(APPEND srcs
|
|
|
|
"spi_flash_chip_drivers.c"
|
|
|
|
"spi_flash_chip_generic.c"
|
|
|
|
"spi_flash_chip_issi.c"
|
|
|
|
"spi_flash_chip_mxic.c"
|
|
|
|
"spi_flash_chip_gd.c"
|
|
|
|
"spi_flash_chip_winbond.c"
|
|
|
|
"spi_flash_chip_boya.c"
|
2021-09-01 15:58:15 +08:00
|
|
|
"spi_flash_chip_mxic_opi.c"
|
2021-12-01 15:13:02 +08:00
|
|
|
"spi_flash_chip_th.c"
|
2021-07-02 12:27:09 +08:00
|
|
|
"memspi_host_driver.c")
|
|
|
|
|
|
|
|
list(APPEND cache_srcs
|
|
|
|
"esp_flash_api.c"
|
|
|
|
"esp_flash_spi_init.c"
|
|
|
|
"spi_flash_os_func_app.c"
|
|
|
|
"spi_flash_os_func_noos.c")
|
|
|
|
|
|
|
|
list(APPEND srcs ${cache_srcs})
|
|
|
|
set(priv_requires bootloader_support app_update soc esp_ipc driver)
|
|
|
|
endif()
|
2018-01-12 13:49:13 +11:00
|
|
|
|
2021-07-02 12:27:09 +08:00
|
|
|
idf_component_register(SRCS "${srcs}"
|
|
|
|
REQUIRES hal
|
|
|
|
PRIV_REQUIRES "${priv_requires}"
|
|
|
|
INCLUDE_DIRS include
|
|
|
|
PRIV_INCLUDE_DIRS include/spi_flash
|
|
|
|
LDFRAGMENTS linker.lf)
|
2018-04-18 10:57:45 +08:00
|
|
|
|
2021-07-02 12:27:09 +08:00
|
|
|
# Avoid cache miss by unexpected inlineing when built by -Os
|
2021-09-10 19:23:21 +02:00
|
|
|
set_source_files_properties(${cache_srcs} PROPERTIES COMPILE_FLAGS "-fno-inline-functions")
|
|
|
|
if(CMAKE_C_COMPILER_ID MATCHES "GNU")
|
|
|
|
# These flags are GCC specific
|
|
|
|
set_property(SOURCE ${cache_srcs} APPEND_STRING PROPERTY COMPILE_FLAGS
|
|
|
|
" -fno-inline-small-functions -fno-inline-functions-called-once")
|
|
|
|
endif()
|