From 83a7ecc7c396c7018cbbcd22e1d0a7e64d1a808d Mon Sep 17 00:00:00 2001 From: Ivan Grokhotkov Date: Mon, 5 Oct 2020 23:20:33 +0200 Subject: [PATCH 1/7] build system: quote LD script search paths in target_linker_script --- tools/cmake/utilities.cmake | 4 ++-- 1 file changed, 2 insertions(+), 2 deletions(-) diff --git a/tools/cmake/utilities.cmake b/tools/cmake/utilities.cmake index df8b514bed..c476e744d2 100644 --- a/tools/cmake/utilities.cmake +++ b/tools/cmake/utilities.cmake @@ -158,9 +158,9 @@ function(target_linker_script target deptype scriptfiles) get_target_property(link_libraries "${target}" LINK_LIBRARIES) endif() - list(FIND "${link_libraries}" "-L ${search_dir}" found_search_dir) + list(FIND "${link_libraries}" "-L \"${search_dir}\"" found_search_dir) if(found_search_dir EQUAL "-1") # not already added as a search path - target_link_libraries("${target}" "${deptype}" "-L ${search_dir}") + target_link_libraries("${target}" "${deptype}" "-L \"${search_dir}\"") endif() target_link_libraries("${target}" "${deptype}" "-T ${scriptname}") From e39d3b21608049eb6d83f7f03a3c72393b1fafd3 Mon Sep 17 00:00:00 2001 From: Ivan Grokhotkov Date: Mon, 5 Oct 2020 23:21:29 +0200 Subject: [PATCH 2/7] build system: project: quote linker map file argument --- tools/cmake/project.cmake | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/tools/cmake/project.cmake b/tools/cmake/project.cmake index 0057e6d4d8..eed3def77a 100644 --- a/tools/cmake/project.cmake +++ b/tools/cmake/project.cmake @@ -444,7 +444,7 @@ macro(project project_name) if(CMAKE_C_COMPILER_ID STREQUAL "GNU") set(mapfile "${CMAKE_BINARY_DIR}/${CMAKE_PROJECT_NAME}.map") - target_link_libraries(${project_elf} "-Wl,--cref -Wl,--Map=${mapfile}") + target_link_libraries(${project_elf} "-Wl,--cref" "-Wl,--Map=\"${mapfile}\"") endif() set_property(DIRECTORY "${CMAKE_CURRENT_SOURCE_DIR}" APPEND PROPERTY From 5a6e27b8a161964397b7e1f425b29752e9cb4854 Mon Sep 17 00:00:00 2001 From: Ivan Grokhotkov Date: Mon, 5 Oct 2020 23:23:22 +0200 Subject: [PATCH 3/7] build system: quote values in __component_write_properties --- tools/cmake/component.cmake | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/tools/cmake/component.cmake b/tools/cmake/component.cmake index d017699f39..8bdba18be2 100644 --- a/tools/cmake/component.cmake +++ b/tools/cmake/component.cmake @@ -126,7 +126,7 @@ function(__component_write_properties output_file) foreach(property ${component_properties}) __component_get_property(val ${component_target} ${property}) set(component_properties_text - "${component_properties_text}\nset(__component_${component_target}_${property} ${val})") + "${component_properties_text}\nset(__component_${component_target}_${property} \"${val}\")") endforeach() file(WRITE ${output_file} "${component_properties_text}") endforeach() From 0ad89536cec8a6300592a89257f3254572ef40fa Mon Sep 17 00:00:00 2001 From: Ivan Grokhotkov Date: Tue, 6 Oct 2020 00:14:48 +0200 Subject: [PATCH 4/7] build system: quote values in __build_write_properties --- tools/cmake/build.cmake | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/tools/cmake/build.cmake b/tools/cmake/build.cmake index fe1942e38b..3352238ef6 100644 --- a/tools/cmake/build.cmake +++ b/tools/cmake/build.cmake @@ -265,7 +265,7 @@ function(__build_write_properties output_file) idf_build_get_property(build_properties __BUILD_PROPERTIES) foreach(property ${build_properties}) idf_build_get_property(val ${property}) - set(build_properties_text "${build_properties_text}\nset(${property} ${val})") + set(build_properties_text "${build_properties_text}\nset(${property} \"${val}\")") endforeach() file(WRITE ${output_file} "${build_properties_text}") endfunction() From 4ae1b0608214ae3bfa190a32437ab3b0ea2684f8 Mon Sep 17 00:00:00 2001 From: Ivan Grokhotkov Date: Mon, 30 Aug 2021 18:01:43 +0200 Subject: [PATCH 5/7] cmake: kconfig: don't add empty entries to kconfigs list --- tools/cmake/kconfig.cmake | 8 ++++++-- 1 file changed, 6 insertions(+), 2 deletions(-) diff --git a/tools/cmake/kconfig.cmake b/tools/cmake/kconfig.cmake index 30cec00829..420c139e81 100644 --- a/tools/cmake/kconfig.cmake +++ b/tools/cmake/kconfig.cmake @@ -163,8 +163,12 @@ function(__kconfig_generate_config sdkconfig sdkconfig_defaults) # Take into account bootloader components configuration files idf_build_get_property(bootloader_kconfigs BOOTLOADER_KCONFIGS) idf_build_get_property(bootloader_kconfigs_proj BOOTLOADER_KCONFIGS_PROJ) - list(APPEND kconfigs "${bootloader_kconfigs}") - list(APPEND kconfig_projbuilds "${bootloader_kconfigs_proj}") + if(bootloader_kconfigs) + list(APPEND kconfigs "${bootloader_kconfigs}") + endif() + if(bootloader_kconfigs_proj) + list(APPEND kconfig_projbuilds "${bootloader_kconfigs_proj}") + endif() # Store the list version of kconfigs and kconfig_projbuilds idf_build_set_property(KCONFIGS "${kconfigs}") From 4f3cc319af59a1f15d1414fb44ae4ca371f295e5 Mon Sep 17 00:00:00 2001 From: Ivan Grokhotkov Date: Mon, 30 Aug 2021 18:02:58 +0200 Subject: [PATCH 6/7] cmake: kconfig: sort results of new glob expressions Similar to 2f811b79, see that commit for the explanation. --- tools/cmake/kconfig.cmake | 2 ++ 1 file changed, 2 insertions(+) diff --git a/tools/cmake/kconfig.cmake b/tools/cmake/kconfig.cmake index 420c139e81..5a6340012e 100644 --- a/tools/cmake/kconfig.cmake +++ b/tools/cmake/kconfig.cmake @@ -121,11 +121,13 @@ function(__kconfig_bootloader_component_add component_dir) idf_build_get_property(bootloader_kconfigs_proj BOOTLOADER_KCONFIGS_PROJ) file(GLOB kconfig "${component_dir}/Kconfig") + list(SORT kconfig) if(EXISTS "${kconfig}" AND NOT IS_DIRECTORY "${kconfig}") list(APPEND bootloader_kconfigs "${kconfig}") endif() file(GLOB kconfig "${component_dir}/Kconfig.projbuild") + list(SORT kconfig) if(EXISTS "${kconfig}" AND NOT IS_DIRECTORY "${kconfig}") list(APPEND bootloader_kconfigs_proj "${kconfig}") endif() From 5bfd10113afc6df5cbdfed2b2b82c93497b71339 Mon Sep 17 00:00:00 2001 From: Ivan Grokhotkov Date: Wed, 6 Oct 2021 09:43:51 +0200 Subject: [PATCH 7/7] bootloader: fix adding bootloader_components to EXTRA_COMPONENT_DIRS --- components/bootloader/subproject/CMakeLists.txt | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/components/bootloader/subproject/CMakeLists.txt b/components/bootloader/subproject/CMakeLists.txt index 09f261b492..f2df83fab9 100644 --- a/components/bootloader/subproject/CMakeLists.txt +++ b/components/bootloader/subproject/CMakeLists.txt @@ -37,7 +37,7 @@ set(COMPONENTS # Make EXTRA_COMPONENT_DIRS variable to point to the bootloader_components directory # of the project being compiled set(PROJECT_EXTRA_COMPONENTS "${PROJECT_SOURCE_DIR}/bootloader_components") -set(EXTRA_COMPONENT_DIRS "${PROJECT_EXTRA_COMPONENTS}" APPEND) +list(APPEND EXTRA_COMPONENT_DIRS "${PROJECT_EXTRA_COMPONENTS}") # Consider each directory in project's bootloader_components as a component to be compiled file(GLOB proj_components RELATIVE ${PROJECT_EXTRA_COMPONENTS} ${PROJECT_EXTRA_COMPONENTS}/*)