project_include.cmake 9.8 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246
  1. # Set some global esptool.py variables
  2. #
  3. # Many of these are read when generating flash_app_args & flash_project_args
  4. idf_build_get_property(target IDF_TARGET)
  5. idf_build_get_property(python PYTHON)
  6. set(ESPTOOLPY ${python} "${CMAKE_CURRENT_LIST_DIR}/esptool/esptool.py" --chip ${target})
  7. set(ESPSECUREPY ${python} "${CMAKE_CURRENT_LIST_DIR}/esptool/espsecure.py")
  8. set(ESPEFUSEPY ${python} "${CMAKE_CURRENT_LIST_DIR}/esptool/espefuse.py")
  9. if(NOT BOOTLOADER_BUILD)
  10. set(esptool_elf2image_args --elf-sha256-offset 0xb0)
  11. endif()
  12. if(CONFIG_SECURE_BOOT_ENABLED AND
  13. NOT CONFIG_SECURE_BOOT_ALLOW_SHORT_APP_PARTITION
  14. AND NOT BOOTLOADER_BUILD)
  15. list(APPEND esptool_elf2image_args --secure-pad)
  16. endif()
  17. if(CONFIG_ESP32_REV_MIN)
  18. list(APPEND esptool_elf2image_args --min-rev ${CONFIG_ESP32_REV_MIN})
  19. endif()
  20. if(CONFIG_ESPTOOLPY_FLASHSIZE_DETECT)
  21. # Set ESPFLASHSIZE to 'detect' *after* elf2image options are generated,
  22. # as elf2image can't have 'detect' as an option...
  23. set(ESPFLASHSIZE detect)
  24. endif()
  25. idf_build_get_property(build_dir BUILD_DIR)
  26. idf_build_get_property(elf_name EXECUTABLE_NAME GENERATOR_EXPRESSION)
  27. idf_build_get_property(elf EXECUTABLE GENERATOR_EXPRESSION)
  28. if(CONFIG_SECURE_BOOT_BUILD_SIGNED_BINARIES AND NOT BOOTLOADER_BUILD)
  29. set(unsigned_project_binary "${elf_name}-unsigned.bin")
  30. else()
  31. set(unsigned_project_binary "${elf_name}.bin")
  32. endif()
  33. set(PROJECT_BIN "${elf_name}.bin")
  34. #
  35. # Add 'app.bin' target - generates with elf2image
  36. #
  37. if(CONFIG_APP_BUILD_GENERATE_BINARIES)
  38. add_custom_command(OUTPUT "${build_dir}/.bin_timestamp"
  39. COMMAND ${ESPTOOLPY} elf2image ${ESPTOOLPY_FLASH_OPTIONS} ${esptool_elf2image_args}
  40. -o "${build_dir}/${unsigned_project_binary}" "${elf}"
  41. COMMAND ${CMAKE_COMMAND} -E echo "Generated ${build_dir}/${unsigned_project_binary}"
  42. COMMAND ${CMAKE_COMMAND} -E md5sum "${build_dir}/${unsigned_project_binary}" > "${build_dir}/.bin_timestamp"
  43. DEPENDS ${elf}
  44. VERBATIM
  45. WORKING_DIRECTORY ${build_dir}
  46. COMMENT "Generating binary image from built executable"
  47. )
  48. add_custom_target(gen_project_binary DEPENDS "${build_dir}/.bin_timestamp")
  49. endif()
  50. set_property(DIRECTORY "${CMAKE_CURRENT_SOURCE_DIR}"
  51. APPEND PROPERTY ADDITIONAL_MAKE_CLEAN_FILES
  52. "${build_dir}/${unsigned_project_binary}"
  53. )
  54. if(CONFIG_APP_BUILD_GENERATE_BINARIES)
  55. add_custom_target(app ALL DEPENDS gen_project_binary)
  56. endif()
  57. if(NOT BOOTLOADER_BUILD AND CONFIG_SECURE_SIGNED_APPS)
  58. if(CONFIG_SECURE_BOOT_BUILD_SIGNED_BINARIES)
  59. # for locally signed secure boot image, add a signing step to get from unsigned app to signed app
  60. add_custom_command(OUTPUT "${build_dir}/.signed_bin_timestamp"
  61. COMMAND ${ESPSECUREPY} sign_data --keyfile ${secure_boot_signing_key}
  62. -o "${build_dir}/${PROJECT_BIN}" "${build_dir}/${unsigned_project_binary}"
  63. COMMAND ${CMAKE_COMMAND} -E echo "Generated signed binary image ${build_dir}/${PROJECT_BIN}"
  64. "from ${build_dir}/${unsigned_project_binary}"
  65. COMMAND ${CMAKE_COMMAND} -E md5sum "${build_dir}/${PROJECT_BIN}" > "${build_dir}/.signed_bin_timestamp"
  66. DEPENDS "${build_dir}/.bin_timestamp"
  67. VERBATIM
  68. COMMENT "Generating signed binary image"
  69. )
  70. add_custom_target(gen_signed_project_binary DEPENDS "${build_dir}/.signed_bin_timestamp")
  71. add_dependencies(gen_project_binary gen_signed_project_binary)
  72. set_property(DIRECTORY "${CMAKE_CURRENT_SOURCE_DIR}"
  73. APPEND PROPERTY ADDITIONAL_MAKE_CLEAN_FILES
  74. "${build_dir}/${PROJECT_BIN}"
  75. )
  76. else()
  77. string(REPLACE ";" " " espsecurepy "${ESPSECUREPY}")
  78. add_custom_command(TARGET app POST_BUILD
  79. COMMAND ${CMAKE_COMMAND} -E echo
  80. "App built but not signed. Sign app before flashing"
  81. COMMAND ${CMAKE_COMMAND} -E echo
  82. "\t${espsecurepy} sign_data --keyfile KEYFILE ${build_dir}/${PROJECT_BIN}"
  83. VERBATIM)
  84. endif()
  85. endif()
  86. add_custom_target(erase_flash
  87. COMMAND ${CMAKE_COMMAND}
  88. -D IDF_PATH="${idf_path}"
  89. -D ESPTOOLPY="${ESPTOOLPY}"
  90. -D ESPTOOL_ARGS="erase_flash"
  91. -P run_esptool.cmake
  92. WORKING_DIRECTORY ${CMAKE_CURRENT_LIST_DIR}
  93. USES_TERMINAL
  94. )
  95. add_custom_target(monitor
  96. COMMAND ${CMAKE_COMMAND}
  97. -D IDF_PATH="${idf_path}"
  98. -D IDF_MONITOR="${idf_path}/tools/idf_monitor.py"
  99. -D ELF_FILE="${elf}"
  100. -D WORKING_DIRECTORY="${build_dir}"
  101. -P run_idf_monitor.cmake
  102. WORKING_DIRECTORY ${CMAKE_CURRENT_LIST_DIR}
  103. USES_TERMINAL
  104. )
  105. set(esptool_flash_main_args "--before=${CONFIG_ESPTOOLPY_BEFORE}")
  106. if(CONFIG_SECURE_BOOT_ENABLED OR CONFIG_SECURE_FLASH_ENC_ENABLED)
  107. # If security enabled then override post flash option
  108. list(APPEND esptool_flash_main_args "--after=no_reset")
  109. else()
  110. list(APPEND esptool_flash_main_args "--after=${CONFIG_ESPTOOLPY_AFTER}")
  111. endif()
  112. set(esptool_flash_sub_args "--flash_mode=${CONFIG_ESPTOOLPY_FLASHMODE}"
  113. "--flash_freq=${CONFIG_ESPTOOLPY_FLASHFREQ}"
  114. "--flash_size=${CONFIG_ESPTOOLPY_FLASHSIZE}")
  115. idf_component_set_property(esptool_py FLASH_ARGS "${esptool_flash_main_args}")
  116. idf_component_set_property(esptool_py FLASH_SUB_ARGS "${esptool_flash_sub_args}")
  117. function(esptool_py_flash_target_image target_name image_name offset image)
  118. idf_build_get_property(build_dir BUILD_DIR)
  119. file(RELATIVE_PATH image ${build_dir} ${image})
  120. set_property(TARGET ${target_name} APPEND PROPERTY FLASH_FILE
  121. "\"${offset}\" : \"${image}\"")
  122. set_property(TARGET ${target_name} APPEND PROPERTY FLASH_ENTRY
  123. "\"${image_name}\" : { \"offset\" : \"${offset}\", \"file\" : \"${image}\" }")
  124. set_property(TARGET ${target_name} APPEND PROPERTY IMAGES "${offset} ${image}")
  125. if(CONFIG_SECURE_FLASH_ENCRYPTION_MODE_DEVELOPMENT)
  126. set_property(TARGET encrypted-${target_name} APPEND PROPERTY FLASH_FILE
  127. "\"${offset}\" : \"${image}\"")
  128. set_property(TARGET encrypted-${target_name} APPEND PROPERTY FLASH_ENTRY
  129. "\"${image_name}\" : { \"offset\" : \"${offset}\", \"file\" : \"${image}\" }")
  130. set_property(TARGET encrypted-${target_name} APPEND PROPERTY IMAGES "${offset} ${image}")
  131. endif()
  132. endfunction()
  133. function(esptool_py_flash_target target_name main_args sub_args)
  134. set(single_value OFFSET IMAGE) # template file to use to be able to
  135. # flash the image individually using esptool
  136. cmake_parse_arguments(_ "" "${single_value}" "" "${ARGN}")
  137. idf_build_get_property(idf_path IDF_PATH)
  138. idf_build_get_property(build_dir BUILD_DIR)
  139. idf_component_get_property(esptool_py_dir esptool_py COMPONENT_DIR)
  140. add_custom_target(${target_name}
  141. COMMAND ${CMAKE_COMMAND}
  142. -D IDF_PATH="${idf_path}"
  143. -D ESPTOOLPY="${ESPTOOLPY}"
  144. -D ESPTOOL_ARGS="${main_args};write_flash;@${target_name}_args"
  145. -D WORKING_DIRECTORY="${build_dir}"
  146. -P ${esptool_py_dir}/run_esptool.cmake
  147. WORKING_DIRECTORY ${CMAKE_CURRENT_LIST_DIR}
  148. USES_TERMINAL
  149. )
  150. set_target_properties(${target_name} PROPERTIES SUB_ARGS "${sub_args}")
  151. set(flash_args_content "$<JOIN:$<TARGET_PROPERTY:${target_name},SUB_ARGS>, >\n\
  152. $<JOIN:$<TARGET_PROPERTY:${target_name},IMAGES>,\n>")
  153. file(GENERATE OUTPUT "${CMAKE_CURRENT_BINARY_DIR}/${target_name}_args.in"
  154. CONTENT "${flash_args_content}")
  155. file(GENERATE OUTPUT "${build_dir}/${target_name}_args"
  156. INPUT "${CMAKE_CURRENT_BINARY_DIR}/${target_name}_args.in")
  157. if(CONFIG_SECURE_FLASH_ENCRYPTION_MODE_DEVELOPMENT)
  158. add_custom_target(encrypted-${target_name}
  159. COMMAND ${CMAKE_COMMAND}
  160. -D IDF_PATH="${idf_path}"
  161. -D ESPTOOLPY="${ESPTOOLPY}"
  162. -D ESPTOOL_ARGS="${main_args};write_flash;@encrypted_${target_name}_args"
  163. -D WORKING_DIRECTORY="${build_dir}"
  164. -P ${esptool_py_dir}/run_esptool.cmake
  165. WORKING_DIRECTORY ${CMAKE_CURRENT_LIST_DIR}
  166. USES_TERMINAL
  167. )
  168. set_target_properties(encrypted-${target_name} PROPERTIES SUB_ARGS "${sub_args};--encrypt")
  169. set(flash_args_content "$<JOIN:$<TARGET_PROPERTY:encrypted-${target_name},SUB_ARGS>, >\n\
  170. $<JOIN:$<TARGET_PROPERTY:encrypted-${target_name},IMAGES>,\n>")
  171. file(GENERATE OUTPUT "${CMAKE_CURRENT_BINARY_DIR}/encrypted_${target_name}_args.in"
  172. CONTENT "${flash_args_content}")
  173. file(GENERATE OUTPUT "${build_dir}/encrypted_${target_name}_args"
  174. INPUT "${CMAKE_CURRENT_BINARY_DIR}/encrypted_${target_name}_args.in")
  175. endif()
  176. endfunction()
  177. function(esptool_py_custom_target target_name flasher_filename dependencies)
  178. idf_component_get_property(main_args esptool_py FLASH_ARGS)
  179. idf_component_get_property(sub_args esptool_py FLASH_SUB_ARGS)
  180. idf_build_get_property(build_dir BUILD_DIR)
  181. esptool_py_flash_target(${target_name} "${main_args}" "${sub_args}")
  182. # Copy the file to flash_xxx_args for compatibility for select target
  183. file_generate("${build_dir}/flash_${flasher_filename}_args"
  184. INPUT "${build_dir}/${target_name}_args")
  185. add_dependencies(${target_name} ${dependencies})
  186. if(CONFIG_SECURE_FLASH_ENCRYPTION_MODE_DEVELOPMENT)
  187. file_generate("${build_dir}/flash_encrypted_${flasher_filename}_args"
  188. INPUT "${build_dir}/encrypted_${target_name}_args")
  189. add_dependencies(encrypted-${target_name} ${dependencies})
  190. endif()
  191. endfunction()
  192. if(NOT BOOTLOADER_BUILD)
  193. set(flash_deps "partition_table")
  194. if(CONFIG_APP_BUILD_GENERATE_BINARIES)
  195. list(APPEND flash_deps "app")
  196. endif()
  197. if(CONFIG_APP_BUILD_BOOTLOADER)
  198. list(APPEND flash_deps "bootloader")
  199. endif()
  200. esptool_py_custom_target(flash project "${flash_deps}")
  201. endif()