]> granicus.if.org Git - esp-idf/commitdiff
cmake: Bootloader subproject & "clean" cleanup
authorAngus Gratton <angus@espressif.com>
Tue, 16 Jan 2018 05:50:15 +0000 (16:50 +1100)
committerAngus Gratton <gus@projectgus.com>
Sun, 29 Apr 2018 23:59:20 +0000 (09:59 +1000)
idf.cmake
tools/cmake/bootloader_subproject.cmake
tools/cmake/idf_functions.cmake

index c6cb99d7ae15a74e50add168cde68beb78fc721a..efb4631d2cd3c68282a4d18e0e07069a67393dce 100644 (file)
--- a/idf.cmake
+++ b/idf.cmake
@@ -12,11 +12,12 @@ if(NOT ( ${CMAKE_SYSTEM_NAME} STREQUAL "Generic" AND ${CMAKE_C_COMPILER} MATCHES
     "re-running cmake.")
 endif()
 
-set(IDF_PATH $ENV{IDF_PATH})
+set(IDF_PATH "$ENV{IDF_PATH}")
 if(NOT IDF_PATH)
   # Documentation says you should set IDF_PATH in your environment, but we
   # can infer it here if it's not set.
   set(IDF_PATH ${CMAKE_CURRENT_LIST_DIR})
+  set($ENV{IDF_PATH} "${IDF_PATH}")
 endif()
 
 # PROJECT_PATH has the path to the IDF project (top-level cmake directory)
index 924a7ea77abfdbe841a7f7633b4293ed44feb7f7..c141fadd345a8e323487bd5eaeda46f7dccc3c82 100644 (file)
@@ -2,12 +2,26 @@
 # cmake project under this one
 #
 #
+set(bootloader_subproject_build_dir "${CMAKE_BINARY_DIR}/bootloader_subproject")
+set(bootloader_binary_files
+  "${bootloader_subproject_build_dir}/bootloader.elf"
+  "${bootloader_subproject_build_dir}/bootloader.bin"
+  "${bootloader_subproject_build_dir}/bootloader.map"
+  )
+
 ExternalProject_Add(bootloader_subproject
   # TODO: support overriding the bootloader in COMPONENT_PATHS
-  SOURCE_DIR ${IDF_PATH}/components/bootloader/subproject
-  BINARY_DIR ${CMAKE_BINARY_DIR}/bootloader_subproject
-  CMAKE_ARGS -DSDKCONFIG=${SDKCONFIG} -DIDF_PATH=${IDF_PATH}
+  SOURCE_DIR "${IDF_PATH}/components/bootloader/subproject"
+  BINARY_DIR "${bootloader_subproject_build_dir}"
+  CMAKE_ARGS -DSDKCONFIG=${SDKCONFIG} -DIDF_PATH="${IDF_PATH}"
   INSTALL_COMMAND ""
+  BUILD_ALWAYS 1  # no easy way around this...
+  BUILD_BYPRODUCTS ${bootloader_binary_files}
   )
 
-
+# this is a hack due to an (annoying) shortcoming in cmake, it can't
+# extend the 'clean' target to the external project
+# see thread: https://cmake.org/pipermail/cmake/2016-December/064660.html
+#
+# So for now we just have the top-level build remove the final build products...
+set_property(DIRECTORY "${CMAKE_CURRENT_SOURCE_DIR}" APPEND PROPERTY ADDITIONAL_MAKE_CLEAN_FILES ${bootloader_binary_files})
index 72216dfbfd259c7ab1fc01b5add05e03041697b9..6da9780381fdc4b2270cc945c2bfd634dc9e02a9 100644 (file)
@@ -64,4 +64,6 @@ function(add_executable target)
   _add_executable(${ARGV})
 
   target_link_libraries(${target} "-Wl,--gc-sections -Wl,--cref -Wl,--Map=${mapfile} -Wl,--start-group")
+
+  set_property(DIRECTORY "${CMAKE_CURRENT_SOURCE_DIR}" APPEND PROPERTY ADDITIONAL_MAKE_CLEAN_FILES "${CMAKE_CURRENT_BINARY_DIR}/${mapfile}")
 endfunction()