2021-05-24 19:39:39 +08:00
|
|
|
idf_build_get_property(idf_target IDF_TARGET)
|
|
|
|
|
2023-08-28 14:02:08 +08:00
|
|
|
if(${idf_target} STREQUAL "linux")
|
|
|
|
return() # This component is not supported by the POSIX/Linux simulator
|
|
|
|
endif()
|
|
|
|
|
2023-12-11 20:10:38 +08:00
|
|
|
if(IDF_TARGET STREQUAL "esp32p4" OR IDF_TARGET STREQUAL "esp32c5")
|
|
|
|
# TODO: IDF-7460, IDF-8851
|
2023-06-09 20:31:22 +08:00
|
|
|
return()
|
|
|
|
endif()
|
|
|
|
|
2023-06-07 20:05:29 +08:00
|
|
|
set(srcs "src/phy_override.c" "src/lib_printf.c" "src/phy_common.c")
|
2022-03-01 16:12:45 +08:00
|
|
|
|
2022-01-07 12:22:56 +08:00
|
|
|
if(CONFIG_APP_NO_BLOBS)
|
2021-05-24 19:39:39 +08:00
|
|
|
set(link_binary_libs 0)
|
|
|
|
set(ldfragments)
|
|
|
|
else()
|
|
|
|
set(link_binary_libs 1)
|
|
|
|
set(ldfragments "linker.lf")
|
|
|
|
endif()
|
|
|
|
|
2022-12-28 15:40:50 +08:00
|
|
|
if(CONFIG_SOC_IEEE802154_BLE_ONLY)
|
2022-03-01 16:12:45 +08:00
|
|
|
list(APPEND srcs "src/phy_init_esp32hxx.c")
|
2021-06-10 20:45:18 +08:00
|
|
|
else()
|
2022-03-01 16:12:45 +08:00
|
|
|
list(APPEND srcs "src/phy_init.c")
|
2021-06-10 20:45:18 +08:00
|
|
|
endif()
|
|
|
|
|
2023-02-23 17:15:36 +08:00
|
|
|
if(CONFIG_SOC_BT_SUPPORTED OR CONFIG_SOC_IEEE802154_SUPPORTED OR CONFIG_SOC_IEEE802154_BLE_ONLY)
|
2022-12-19 20:29:52 +08:00
|
|
|
list(APPEND srcs "src/btbb_init.c")
|
|
|
|
endif()
|
|
|
|
|
2023-01-18 15:01:59 +08:00
|
|
|
if(CONFIG_ESP_PHY_ENABLE_CERT_TEST)
|
|
|
|
list(APPEND srcs "src/phy_callback.c")
|
|
|
|
endif()
|
|
|
|
|
2021-05-24 19:39:39 +08:00
|
|
|
idf_build_get_property(build_dir BUILD_DIR)
|
|
|
|
|
2023-02-23 17:15:36 +08:00
|
|
|
if(CONFIG_SOC_WIFI_SUPPORTED)
|
2021-06-16 11:39:08 +08:00
|
|
|
if(CONFIG_ESP_PHY_MULTIPLE_INIT_DATA_BIN)
|
2021-06-10 13:33:54 +08:00
|
|
|
if(NOT EXISTS "${build_dir}/phy_multiple_init_data.bin")
|
|
|
|
file(COPY ${CMAKE_CURRENT_SOURCE_DIR}/${idf_target}/phy_multiple_init_data.bin DESTINATION "${build_dir}")
|
|
|
|
endif()
|
|
|
|
endif()
|
|
|
|
|
2021-06-16 11:39:08 +08:00
|
|
|
if(CONFIG_ESP_PHY_MULTIPLE_INIT_DATA_BIN_EMBED)
|
2022-03-01 16:12:45 +08:00
|
|
|
set(embed_files "${build_dir}/phy_multiple_init_data.bin")
|
2021-06-10 13:33:54 +08:00
|
|
|
endif()
|
2023-02-23 17:15:36 +08:00
|
|
|
endif()
|
2021-06-10 13:33:54 +08:00
|
|
|
|
2022-03-01 16:12:45 +08:00
|
|
|
# [refactor-todo]: requires "driver" component for periph_ctrl header file
|
|
|
|
idf_component_register(SRCS "${srcs}"
|
|
|
|
INCLUDE_DIRS "include" "${idf_target}/include"
|
2022-07-21 11:47:09 +08:00
|
|
|
PRIV_REQUIRES nvs_flash driver efuse esp_timer esp_wifi
|
2022-03-01 16:12:45 +08:00
|
|
|
LDFRAGMENTS "${ldfragments}"
|
|
|
|
EMBED_FILES ${embed_files}
|
|
|
|
)
|
|
|
|
|
2021-05-24 19:39:39 +08:00
|
|
|
set(target_name "${idf_target}")
|
2023-04-13 14:32:25 +08:00
|
|
|
target_link_directories(${COMPONENT_LIB} PUBLIC "${CMAKE_CURRENT_SOURCE_DIR}/lib/${target_name}")
|
2021-05-24 19:39:39 +08:00
|
|
|
|
2022-03-01 16:12:45 +08:00
|
|
|
# Override functions in PHY lib with the functions in 'phy_override.c'
|
|
|
|
target_link_libraries(${COMPONENT_LIB} INTERFACE "-u include_esp_phy_override")
|
|
|
|
|
2021-05-24 19:39:39 +08:00
|
|
|
if(link_binary_libs)
|
|
|
|
target_link_libraries(${COMPONENT_LIB} PUBLIC phy)
|
|
|
|
|
|
|
|
idf_component_get_property(esp_phy_lib esp_phy COMPONENT_LIB)
|
|
|
|
|
|
|
|
if(CONFIG_IDF_TARGET_ESP32)
|
|
|
|
target_link_libraries(${COMPONENT_LIB} PUBLIC rtc)
|
2021-09-02 21:25:34 +08:00
|
|
|
target_link_libraries(${COMPONENT_LIB} INTERFACE $<TARGET_FILE:${esp_phy_lib}> libphy.a librtc.a
|
|
|
|
$<TARGET_FILE:${esp_phy_lib}>)
|
2022-12-13 14:04:50 +08:00
|
|
|
elseif(CONFIG_IDF_TARGET_ESP32S2)
|
2021-09-02 21:25:34 +08:00
|
|
|
target_link_libraries(${COMPONENT_LIB} INTERFACE $<TARGET_FILE:${esp_phy_lib}> libphy.a
|
|
|
|
$<TARGET_FILE:${esp_phy_lib}>)
|
2022-12-13 14:04:50 +08:00
|
|
|
elseif(CONFIG_SOC_BT_SUPPORTED OR CONFIG_SOC_IEEE802154_SUPPORTED)
|
2021-05-24 19:39:39 +08:00
|
|
|
target_link_libraries(${COMPONENT_LIB} PUBLIC btbb)
|
2021-09-02 21:25:34 +08:00
|
|
|
target_link_libraries(${COMPONENT_LIB} INTERFACE $<TARGET_FILE:${esp_phy_lib}> libphy.a libbtbb.a
|
|
|
|
$<TARGET_FILE:${esp_phy_lib}>)
|
2021-05-24 19:39:39 +08:00
|
|
|
endif()
|
2023-01-16 17:48:32 +08:00
|
|
|
|
|
|
|
if(CONFIG_ESP_PHY_ENABLE_CERT_TEST)
|
|
|
|
target_link_libraries(${COMPONENT_LIB} INTERFACE $<TARGET_FILE:${esp_phy_lib}> libbttestmode.a
|
|
|
|
librfate.a librftest.a $<TARGET_FILE:${esp_phy_lib}>)
|
|
|
|
endif()
|
2021-05-24 19:39:39 +08:00
|
|
|
endif()
|
|
|
|
|
2021-06-16 11:39:08 +08:00
|
|
|
if(CONFIG_ESP_PHY_INIT_DATA_IN_PARTITION)
|
2021-05-24 19:39:39 +08:00
|
|
|
idf_component_get_property(esp_common_dir esp_common COMPONENT_DIR)
|
|
|
|
partition_table_get_partition_info(phy_partition_offset "--partition-type data --partition-subtype phy" "offset")
|
|
|
|
|
2021-06-16 11:39:08 +08:00
|
|
|
if(CONFIG_ESP_PHY_MULTIPLE_INIT_DATA_BIN)
|
2021-06-10 13:33:54 +08:00
|
|
|
set(phy_init_data_bin "${build_dir}/phy_multiple_init_data.bin")
|
2021-06-16 11:39:08 +08:00
|
|
|
if(CONFIG_ESP_PHY_MULTIPLE_INIT_DATA_BIN_EMBED)
|
2021-06-10 13:33:54 +08:00
|
|
|
set(COMPONENT_EMBED_FILES "${build_dir}/phy_multiple_init_data.bin")
|
2021-06-04 16:45:45 +08:00
|
|
|
endif()
|
2021-05-24 19:39:39 +08:00
|
|
|
else()
|
|
|
|
set(phy_init_data_bin "${build_dir}/phy_init_data.bin")
|
|
|
|
|
|
|
|
# To get the phy_init_data.bin file, compile phy_init_data.h as a C file and then objcopy
|
|
|
|
# the object file to a raw binary
|
|
|
|
idf_build_get_property(config_dir CONFIG_DIR)
|
|
|
|
add_custom_command(
|
|
|
|
OUTPUT ${phy_init_data_bin}
|
|
|
|
DEPENDS ${CMAKE_CURRENT_LIST_DIR}/${idf_target}/include/phy_init_data.h
|
|
|
|
COMMAND ${CMAKE_C_COMPILER} -x c -c
|
|
|
|
-I ${esp_common_dir}/include -I ${CMAKE_CURRENT_LIST_DIR}/include -I ${config_dir}
|
|
|
|
-o phy_init_data.obj
|
|
|
|
${CMAKE_CURRENT_LIST_DIR}/${idf_target}/include/phy_init_data.h
|
|
|
|
COMMAND ${CMAKE_OBJCOPY} -O binary phy_init_data.obj ${phy_init_data_bin}
|
|
|
|
)
|
|
|
|
add_custom_target(phy_init_data ALL DEPENDS ${phy_init_data_bin})
|
|
|
|
add_dependencies(flash phy_init_data)
|
|
|
|
|
|
|
|
idf_component_get_property(main_args esptool_py FLASH_ARGS)
|
|
|
|
idf_component_get_property(sub_args esptool_py FLASH_SUB_ARGS)
|
|
|
|
endif()
|
|
|
|
|
|
|
|
set(phy_name "phy")
|
|
|
|
|
|
|
|
esptool_py_flash_target(${phy_name}-flash "${main_args}" "${sub_args}")
|
|
|
|
esptool_py_flash_target_image(${phy_name}-flash ${phy_name} "${phy_partition_offset}" "${phy_init_data_bin}")
|
|
|
|
esptool_py_flash_target_image(flash ${phy_name} "${phy_partition_offset}" "${phy_init_data_bin}")
|
|
|
|
endif()
|