2021-05-24 07:39:39 -04:00
|
|
|
idf_build_get_property(idf_target IDF_TARGET)
|
|
|
|
|
2022-03-01 03:12:45 -05:00
|
|
|
set(srcs "src/phy_override.c" "src/lib_printf.c")
|
|
|
|
|
2022-01-06 23:22:56 -05:00
|
|
|
if(CONFIG_APP_NO_BLOBS)
|
2021-05-24 07:39:39 -04:00
|
|
|
set(link_binary_libs 0)
|
|
|
|
set(ldfragments)
|
|
|
|
else()
|
|
|
|
set(link_binary_libs 1)
|
|
|
|
set(ldfragments "linker.lf")
|
|
|
|
endif()
|
|
|
|
|
2022-12-28 02:40:50 -05:00
|
|
|
if(CONFIG_SOC_IEEE802154_BLE_ONLY)
|
2022-03-01 03:12:45 -05:00
|
|
|
list(APPEND srcs "src/phy_init_esp32hxx.c")
|
2021-06-10 08:45:18 -04:00
|
|
|
else()
|
2022-03-01 03:12:45 -05:00
|
|
|
list(APPEND srcs "src/phy_init.c")
|
2021-06-10 08:45:18 -04:00
|
|
|
endif()
|
|
|
|
|
2023-02-23 04:15:36 -05:00
|
|
|
if(CONFIG_SOC_BT_SUPPORTED OR CONFIG_SOC_IEEE802154_SUPPORTED OR CONFIG_SOC_IEEE802154_BLE_ONLY)
|
2022-12-19 07:29:52 -05:00
|
|
|
list(APPEND srcs "src/btbb_init.c")
|
|
|
|
endif()
|
|
|
|
|
2023-01-18 02:01:59 -05:00
|
|
|
if(CONFIG_ESP_PHY_ENABLE_CERT_TEST)
|
|
|
|
list(APPEND srcs "src/phy_callback.c")
|
|
|
|
endif()
|
|
|
|
|
2021-05-24 07:39:39 -04:00
|
|
|
idf_build_get_property(build_dir BUILD_DIR)
|
|
|
|
|
2023-02-23 04:15:36 -05:00
|
|
|
if(CONFIG_SOC_WIFI_SUPPORTED)
|
2021-06-15 23:39:08 -04:00
|
|
|
if(CONFIG_ESP_PHY_MULTIPLE_INIT_DATA_BIN)
|
2021-06-10 01:33:54 -04: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-15 23:39:08 -04:00
|
|
|
if(CONFIG_ESP_PHY_MULTIPLE_INIT_DATA_BIN_EMBED)
|
2022-03-01 03:12:45 -05:00
|
|
|
set(embed_files "${build_dir}/phy_multiple_init_data.bin")
|
2021-06-10 01:33:54 -04:00
|
|
|
endif()
|
2023-02-23 04:15:36 -05:00
|
|
|
endif()
|
2021-06-10 01:33:54 -04:00
|
|
|
|
2022-03-01 03:12:45 -05:00
|
|
|
# [refactor-todo]: requires "driver" component for periph_ctrl header file
|
|
|
|
idf_component_register(SRCS "${srcs}"
|
|
|
|
INCLUDE_DIRS "include" "${idf_target}/include"
|
2022-07-20 23:47:09 -04:00
|
|
|
PRIV_REQUIRES nvs_flash driver efuse esp_timer esp_wifi
|
2022-03-01 03:12:45 -05:00
|
|
|
LDFRAGMENTS "${ldfragments}"
|
|
|
|
EMBED_FILES ${embed_files}
|
|
|
|
)
|
|
|
|
|
2021-05-24 07:39:39 -04:00
|
|
|
set(target_name "${idf_target}")
|
2022-10-19 03:57:24 -04:00
|
|
|
if(IDF_TARGET STREQUAL "esp32h4")
|
|
|
|
if(CONFIG_IDF_TARGET_ESP32H4_BETA_VERSION_2)
|
2023-03-06 03:56:52 -05:00
|
|
|
target_link_directories(${COMPONENT_LIB} PUBLIC "${CMAKE_CURRENT_SOURCE_DIR}/lib/esp32h4/rev2")
|
2022-04-19 05:02:13 -04:00
|
|
|
endif()
|
2022-10-19 03:57:24 -04:00
|
|
|
if(CONFIG_IDF_TARGET_ESP32H4_BETA_VERSION_1)
|
2023-03-06 03:56:52 -05:00
|
|
|
target_link_directories(${COMPONENT_LIB} PUBLIC "${CMAKE_CURRENT_SOURCE_DIR}/lib/esp32h4/rev1")
|
2022-04-19 05:02:13 -04:00
|
|
|
endif()
|
|
|
|
else()
|
2022-08-28 11:07:49 -04:00
|
|
|
target_link_directories(${COMPONENT_LIB} PUBLIC "${CMAKE_CURRENT_SOURCE_DIR}/lib/${target_name}")
|
2022-04-19 05:02:13 -04:00
|
|
|
endif()
|
2021-05-24 07:39:39 -04:00
|
|
|
|
2022-03-01 03:12:45 -05: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 07:39:39 -04: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 09:25:34 -04:00
|
|
|
target_link_libraries(${COMPONENT_LIB} INTERFACE $<TARGET_FILE:${esp_phy_lib}> libphy.a librtc.a
|
|
|
|
$<TARGET_FILE:${esp_phy_lib}>)
|
2022-12-13 01:04:50 -05:00
|
|
|
elseif(CONFIG_IDF_TARGET_ESP32S2)
|
2021-09-02 09:25:34 -04:00
|
|
|
target_link_libraries(${COMPONENT_LIB} INTERFACE $<TARGET_FILE:${esp_phy_lib}> libphy.a
|
|
|
|
$<TARGET_FILE:${esp_phy_lib}>)
|
2022-12-13 01:04:50 -05:00
|
|
|
elseif(CONFIG_SOC_BT_SUPPORTED OR CONFIG_SOC_IEEE802154_SUPPORTED)
|
2021-05-24 07:39:39 -04:00
|
|
|
target_link_libraries(${COMPONENT_LIB} PUBLIC btbb)
|
2021-09-02 09:25:34 -04:00
|
|
|
target_link_libraries(${COMPONENT_LIB} INTERFACE $<TARGET_FILE:${esp_phy_lib}> libphy.a libbtbb.a
|
|
|
|
$<TARGET_FILE:${esp_phy_lib}>)
|
2021-05-24 07:39:39 -04:00
|
|
|
endif()
|
2023-01-16 04:48:32 -05: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 07:39:39 -04:00
|
|
|
endif()
|
|
|
|
|
2021-06-15 23:39:08 -04:00
|
|
|
if(CONFIG_ESP_PHY_INIT_DATA_IN_PARTITION)
|
2021-05-24 07:39:39 -04: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-15 23:39:08 -04:00
|
|
|
if(CONFIG_ESP_PHY_MULTIPLE_INIT_DATA_BIN)
|
2021-06-10 01:33:54 -04:00
|
|
|
set(phy_init_data_bin "${build_dir}/phy_multiple_init_data.bin")
|
2021-06-15 23:39:08 -04:00
|
|
|
if(CONFIG_ESP_PHY_MULTIPLE_INIT_DATA_BIN_EMBED)
|
2021-06-10 01:33:54 -04:00
|
|
|
set(COMPONENT_EMBED_FILES "${build_dir}/phy_multiple_init_data.bin")
|
2021-06-04 04:45:45 -04:00
|
|
|
endif()
|
2021-05-24 07:39:39 -04: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()
|