project_include.cmake 11 KB

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