2020-08-08 20:15:27 +08:00
|
|
|
idf_build_get_property(target IDF_TARGET)
|
|
|
|
|
2022-04-16 15:06:40 +08:00
|
|
|
set(srcs "mpu_hal.c"
|
2021-12-22 22:18:43 +08:00
|
|
|
"efuse_hal.c"
|
2022-02-11 15:30:54 +08:00
|
|
|
"${target}/efuse_hal.c"
|
|
|
|
"mmu_hal.c")
|
2021-02-07 15:03:51 +08:00
|
|
|
|
2021-05-19 10:53:21 +08:00
|
|
|
set(includes "${target}/include" "include" "platform_port/include")
|
2020-08-08 20:15:27 +08:00
|
|
|
|
2022-05-06 18:57:14 +08:00
|
|
|
if(NOT CONFIG_HAL_WDT_USE_ROM_IMPL)
|
2022-04-16 15:06:40 +08:00
|
|
|
list(APPEND srcs "wdt_hal_iram.c")
|
|
|
|
endif()
|
|
|
|
|
2023-06-13 11:56:14 +08:00
|
|
|
# We wrap Cache ROM APIs as Cache HAL APIs for: 1. internal ram ; 2. unified APIs
|
|
|
|
# ESP32 cache structure / ROM APIs are different and we have a patch `cache_hal_esp32.c` for it.
|
|
|
|
if(${target} STREQUAL "esp32")
|
|
|
|
list(APPEND srcs "esp32/cache_hal_esp32.c")
|
|
|
|
else()
|
2022-02-11 15:30:54 +08:00
|
|
|
list(APPEND srcs "cache_hal.c")
|
|
|
|
endif()
|
|
|
|
|
2022-05-06 18:57:14 +08:00
|
|
|
if(${target} STREQUAL "esp32h2")
|
2021-12-30 20:31:38 +08:00
|
|
|
if(CONFIG_IDF_TARGET_ESP32H2_BETA_VERSION_1)
|
|
|
|
list(APPEND includes "${target}/include/rev1")
|
|
|
|
elseif(CONFIG_IDF_TARGET_ESP32H2_BETA_VERSION_2)
|
|
|
|
list(APPEND includes "${target}/include/rev2")
|
|
|
|
endif()
|
|
|
|
endif()
|
|
|
|
|
2020-08-08 20:15:27 +08:00
|
|
|
if(NOT BOOTLOADER_BUILD)
|
|
|
|
list(APPEND srcs
|
2021-08-24 21:23:45 +05:30
|
|
|
"rtc_io_hal.c"
|
|
|
|
"spi_hal.c"
|
|
|
|
"spi_hal_iram.c"
|
|
|
|
"spi_slave_hal.c"
|
|
|
|
"spi_slave_hal_iram.c"
|
|
|
|
"timer_hal.c"
|
2022-01-02 16:14:17 +08:00
|
|
|
"timer_hal_iram.c"
|
2021-08-24 21:23:45 +05:30
|
|
|
"ledc_hal.c"
|
|
|
|
"ledc_hal_iram.c"
|
|
|
|
"i2c_hal.c"
|
|
|
|
"i2c_hal_iram.c"
|
|
|
|
"gpio_hal.c"
|
|
|
|
"uart_hal.c"
|
|
|
|
"uart_hal_iram.c"
|
|
|
|
"spi_flash_hal.c"
|
|
|
|
"spi_flash_hal_iram.c"
|
|
|
|
"spi_flash_encrypt_hal_iram.c"
|
|
|
|
"sha_hal.c"
|
2022-03-24 17:45:58 +08:00
|
|
|
"adc_hal_common.c"
|
2022-07-15 12:52:44 +08:00
|
|
|
"adc_oneshot_hal.c")
|
2020-08-08 20:15:27 +08:00
|
|
|
|
2022-05-06 18:57:14 +08:00
|
|
|
if(CONFIG_SOC_SYSTIMER_SUPPORTED AND NOT CONFIG_HAL_SYSTIMER_USE_ROM_IMPL)
|
|
|
|
list(APPEND srcs "systimer_hal.c")
|
|
|
|
endif()
|
|
|
|
|
|
|
|
if(CONFIG_SOC_RMT_SUPPORTED)
|
|
|
|
list(APPEND srcs "rmt_hal.c")
|
|
|
|
endif()
|
|
|
|
|
|
|
|
if(CONFIG_SOC_PCNT_SUPPORTED)
|
|
|
|
list(APPEND srcs "pcnt_hal.c")
|
|
|
|
endif()
|
|
|
|
|
|
|
|
if(CONFIG_SOC_MCPWM_SUPPORTED)
|
|
|
|
list(APPEND srcs "mcpwm_hal.c")
|
|
|
|
endif()
|
|
|
|
|
|
|
|
if(CONFIG_SOC_TWAI_SUPPORTED)
|
|
|
|
list(APPEND srcs "twai_hal.c" "twai_hal_iram.c")
|
|
|
|
endif()
|
|
|
|
|
|
|
|
if(CONFIG_SOC_GDMA_SUPPORTED)
|
|
|
|
list(APPEND srcs "gdma_hal.c")
|
|
|
|
endif()
|
|
|
|
|
|
|
|
if(CONFIG_SOC_I2S_SUPPORTED)
|
|
|
|
list(APPEND srcs "i2s_hal.c")
|
|
|
|
endif()
|
|
|
|
|
2022-05-17 13:47:14 +08:00
|
|
|
if(CONFIG_SOC_SDM_SUPPORTED)
|
|
|
|
list(APPEND srcs "sdm_hal.c")
|
2022-05-06 18:57:14 +08:00
|
|
|
endif()
|
|
|
|
|
|
|
|
if(CONFIG_ETH_USE_ESP32_EMAC)
|
|
|
|
list(APPEND srcs "emac_hal.c")
|
2022-04-24 16:40:32 +08:00
|
|
|
endif()
|
|
|
|
|
2022-07-15 12:52:44 +08:00
|
|
|
if(CONFIG_SOC_ADC_DMA_SUPPORTED)
|
|
|
|
list(APPEND srcs "adc_hal.c")
|
|
|
|
endif()
|
|
|
|
|
2022-06-01 11:00:00 +08:00
|
|
|
if(CONFIG_SOC_LCDCAM_SUPPORTED)
|
|
|
|
list(APPEND srcs "lcd_hal.c")
|
|
|
|
endif()
|
|
|
|
|
2022-06-21 12:28:34 +05:30
|
|
|
if(CONFIG_SOC_ECC_SUPPORTED)
|
|
|
|
list(APPEND srcs "ecc_hal.c")
|
|
|
|
endif()
|
|
|
|
|
2020-08-08 20:15:27 +08:00
|
|
|
if(${target} STREQUAL "esp32")
|
|
|
|
list(APPEND srcs
|
2021-08-24 21:23:45 +05:30
|
|
|
"dac_hal.c"
|
|
|
|
"sdio_slave_hal.c"
|
|
|
|
"touch_sensor_hal.c"
|
2021-11-06 17:24:45 +08:00
|
|
|
"aes_hal.c"
|
2021-08-24 21:23:45 +05:30
|
|
|
"esp32/brownout_hal.c"
|
|
|
|
"esp32/touch_sensor_hal.c"
|
|
|
|
"esp32/gpio_hal_workaround.c")
|
2020-08-08 20:15:27 +08:00
|
|
|
endif()
|
|
|
|
|
|
|
|
if(${target} STREQUAL "esp32s2")
|
|
|
|
list(APPEND srcs
|
2020-11-26 16:06:21 +11:00
|
|
|
"dac_hal.c"
|
2020-08-08 20:15:27 +08:00
|
|
|
"spi_flash_hal_gpspi.c"
|
|
|
|
"spi_slave_hd_hal.c"
|
2020-11-26 16:06:21 +11:00
|
|
|
"touch_sensor_hal.c"
|
2021-05-06 16:20:54 +08:00
|
|
|
"usb_hal.c"
|
2021-08-19 20:28:28 +08:00
|
|
|
"usb_phy_hal.c"
|
2021-08-30 11:30:12 +08:00
|
|
|
"xt_wdt_hal.c"
|
2021-11-06 17:24:45 +08:00
|
|
|
"aes_hal.c"
|
2020-08-08 20:15:27 +08:00
|
|
|
"esp32s2/brownout_hal.c"
|
|
|
|
"esp32s2/cp_dma_hal.c"
|
|
|
|
"esp32s2/touch_sensor_hal.c"
|
2020-09-17 19:59:37 +08:00
|
|
|
"esp32s2/dac_hal.c"
|
2022-09-15 20:43:18 +08:00
|
|
|
"usb_dwc_hal.c")
|
2020-08-08 20:15:27 +08:00
|
|
|
endif()
|
|
|
|
|
|
|
|
if(${target} STREQUAL "esp32s3")
|
|
|
|
list(APPEND srcs
|
2021-08-24 21:23:45 +05:30
|
|
|
"ds_hal.c"
|
2020-08-18 17:11:46 +08:00
|
|
|
"spi_flash_hal_gpspi.c"
|
2020-09-08 17:05:49 +08:00
|
|
|
"spi_slave_hd_hal.c"
|
2020-11-26 16:06:21 +11:00
|
|
|
"touch_sensor_hal.c"
|
2021-05-06 16:20:54 +08:00
|
|
|
"usb_hal.c"
|
2021-08-19 20:28:28 +08:00
|
|
|
"usb_phy_hal.c"
|
2021-08-30 11:30:12 +08:00
|
|
|
"xt_wdt_hal.c"
|
2021-11-06 17:24:45 +08:00
|
|
|
"aes_hal.c"
|
2020-08-08 20:15:27 +08:00
|
|
|
"esp32s3/brownout_hal.c"
|
2021-08-02 14:31:43 +08:00
|
|
|
"esp32s3/hmac_hal.c"
|
2021-06-02 17:57:50 +08:00
|
|
|
"esp32s3/touch_sensor_hal.c"
|
2021-06-18 17:25:04 +08:00
|
|
|
"esp32s3/rtc_cntl_hal.c"
|
2022-09-15 20:43:18 +08:00
|
|
|
"usb_dwc_hal.c")
|
2020-08-08 20:15:27 +08:00
|
|
|
endif()
|
2020-11-26 16:06:21 +11:00
|
|
|
|
|
|
|
if(${target} STREQUAL "esp32c3")
|
|
|
|
list(APPEND srcs
|
2020-09-30 17:27:33 +08:00
|
|
|
"ds_hal.c"
|
2021-04-02 12:41:21 +08:00
|
|
|
"spi_flash_hal_gpspi.c"
|
|
|
|
"spi_slave_hd_hal.c"
|
2021-08-30 11:30:12 +08:00
|
|
|
"xt_wdt_hal.c"
|
2021-11-06 17:24:45 +08:00
|
|
|
"aes_hal.c"
|
2020-11-26 16:06:21 +11:00
|
|
|
"esp32c3/brownout_hal.c"
|
|
|
|
"esp32c3/hmac_hal.c"
|
2020-12-24 21:02:32 +08:00
|
|
|
"esp32c3/rtc_cntl_hal.c")
|
2020-11-26 16:06:21 +11:00
|
|
|
endif()
|
2021-06-10 10:28:23 +08:00
|
|
|
|
|
|
|
if(${target} STREQUAL "esp32h2")
|
|
|
|
list(APPEND srcs
|
2021-08-24 21:23:45 +05:30
|
|
|
"ds_hal.c"
|
|
|
|
"spi_flash_hal_gpspi.c"
|
|
|
|
"spi_slave_hd_hal.c"
|
2021-11-06 17:24:45 +08:00
|
|
|
"aes_hal.c"
|
2021-08-24 21:23:45 +05:30
|
|
|
"esp32h2/brownout_hal.c"
|
|
|
|
"esp32h2/hmac_hal.c"
|
|
|
|
"esp32h2/rtc_cntl_hal.c")
|
2021-06-10 10:28:23 +08:00
|
|
|
endif()
|
2021-11-06 17:24:45 +08:00
|
|
|
|
2022-01-18 10:32:56 +08:00
|
|
|
if(${target} STREQUAL "esp32c2")
|
2021-11-06 17:24:45 +08:00
|
|
|
list(APPEND srcs
|
|
|
|
"spi_flash_hal_gpspi.c"
|
|
|
|
"spi_slave_hd_hal.c"
|
2022-01-18 10:32:56 +08:00
|
|
|
"esp32c2/brownout_hal.c"
|
|
|
|
"esp32c2/rtc_cntl_hal.c")
|
2021-11-06 17:24:45 +08:00
|
|
|
endif()
|
2020-08-08 20:15:27 +08:00
|
|
|
endif()
|
|
|
|
|
|
|
|
idf_component_register(SRCS ${srcs}
|
|
|
|
INCLUDE_DIRS ${includes}
|
|
|
|
PRIV_INCLUDE_DIRS ${priv_include}
|
2021-12-22 22:18:43 +08:00
|
|
|
REQUIRES soc esp_rom
|
2020-08-08 20:15:27 +08:00
|
|
|
LDFRAGMENTS linker.lf)
|
2022-01-31 19:45:31 +01:00
|
|
|
target_compile_options(${COMPONENT_LIB} PRIVATE "-Wno-format")
|
2021-05-19 10:53:21 +08:00
|
|
|
|
|
|
|
if(CONFIG_HAL_DEFAULT_ASSERTION_LEVEL EQUAL 1)
|
|
|
|
target_link_libraries(${COMPONENT_LIB} INTERFACE "-u abort")
|
|
|
|
elseif(CONFIG_HAL_DEFAULT_ASSERTION_LEVEL EQUAL 2)
|
|
|
|
target_link_libraries(${COMPONENT_LIB} INTERFACE "-u __assert_func")
|
|
|
|
endif()
|