123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127 |
- set(BOOTLOADER_OFFSET 0x1000)
- if(BOOTLOADER_BUILD)
- return()
- endif()
- idf_build_get_property(build_dir BUILD_DIR)
- set(BOOTLOADER_BUILD_DIR "${build_dir}/bootloader")
- set(bootloader_binary_files
- "${BOOTLOADER_BUILD_DIR}/bootloader.elf"
- "${BOOTLOADER_BUILD_DIR}/bootloader.bin"
- "${BOOTLOADER_BUILD_DIR}/bootloader.map"
- )
- idf_build_get_property(project_dir PROJECT_DIR)
- if(CONFIG_SECURE_SIGNED_APPS)
- add_custom_target(gen_secure_boot_keys)
- if(CONFIG_SECURE_BOOT_ENABLED)
-
- if((CONFIG_SECURE_BOOTLOADER_REFLASHABLE AND CONFIG_SECURE_BOOTLOADER_ONE_TIME_FLASH) OR
- (NOT CONFIG_SECURE_BOOTLOADER_REFLASHABLE AND NOT CONFIG_SECURE_BOOTLOADER_ONE_TIME_FLASH))
- fail_at_build_time(bootloader "Invalid bootloader target: bad sdkconfig?")
- endif()
- if(CONFIG_SECURE_BOOTLOADER_REFLASHABLE)
- set(bootloader_binary_files
- ${bootloader_binary_files}
- "${BOOTLOADER_BUILD_DIR}/bootloader-reflash-digest.bin"
- "${BOOTLOADER_BUILD_DIR}/secure-bootloader-key-192.bin"
- "${BOOTLOADER_BUILD_DIR}/secure-bootloader-key-256.bin"
- )
- endif()
- endif()
-
-
-
- if(CONFIG_SECURE_BOOT_BUILD_SIGNED_BINARIES)
- get_filename_component(secure_boot_signing_key
- "${CONFIG_SECURE_BOOT_SIGNING_KEY}"
- ABSOLUTE BASE_DIR "${project_dir}")
- if(NOT EXISTS ${secure_boot_signing_key})
-
-
-
- fail_at_build_time(gen_secure_boot_signing_key
- "Secure Boot Signing Key ${CONFIG_SECURE_BOOT_SIGNING_KEY} does not exist. Generate using:"
- "\tespsecure.py generate_signing_key ${CONFIG_SECURE_BOOT_SIGNING_KEY}")
- else()
- add_custom_target(gen_secure_boot_signing_key)
- endif()
- set(SECURE_BOOT_SIGNING_KEY ${secure_boot_signing_key})
- set(sign_key_arg "-DSECURE_BOOT_SIGNING_KEY=${secure_boot_signing_key}")
- add_dependencies(gen_secure_boot_keys gen_secure_boot_signing_key)
- else()
- get_filename_component(secure_boot_verification_key
- ${CONFIG_SECURE_BOOT_VERIFICATION_KEY}
- ABSOLUTE BASE_DIR "${project_dir}")
- if(NOT EXISTS ${secure_boot_verification_key})
-
-
-
- fail_at_build_time(gen_secure_boot_verification_key
- "Secure Boot Verification Public Key ${CONFIG_SECURE_BOOT_VERIFICATION_KEY} does not exist."
- "\tThis can be extracted from the private signing key."
- "\tSee docs/security/secure-boot.rst for details.")
- else()
- add_custom_target(gen_secure_boot_verification_key)
- endif()
- set(ver_key_arg "-DSECURE_BOOT_VERIFICATION_KEY=${secure_boot_verification_key}")
- add_dependencies(gen_secure_boot_keys gen_secure_boot_verification_key)
- endif()
- endif()
- idf_build_get_property(idf_path IDF_PATH)
- idf_build_get_property(idf_target IDF_TARGET)
- idf_build_get_property(sdkconfig SDKCONFIG)
- externalproject_add(bootloader
- SOURCE_DIR "${CMAKE_CURRENT_LIST_DIR}/subproject"
- BINARY_DIR "${BOOTLOADER_BUILD_DIR}"
- CMAKE_ARGS -DSDKCONFIG=${sdkconfig} -DIDF_PATH=${idf_path} -DIDF_TARGET=${idf_target}
- -DPYTHON_DEPS_CHECKED=1
- -DEXTRA_COMPONENT_DIRS=${CMAKE_CURRENT_LIST_DIR}
- ${sign_key_arg} ${ver_key_arg}
-
-
-
- -DLEGACY_INCLUDE_COMMON_HEADERS=${CONFIG_LEGACY_INCLUDE_COMMON_HEADERS}
- INSTALL_COMMAND ""
- BUILD_ALWAYS 1
- BUILD_BYPRODUCTS ${bootloader_binary_files}
- )
- if(CONFIG_SECURE_SIGNED_APPS)
- add_dependencies(bootloader gen_secure_boot_keys)
- endif()
- set_property(DIRECTORY "${CMAKE_CURRENT_SOURCE_DIR}" APPEND PROPERTY
- ADDITIONAL_MAKE_CLEAN_FILES
- ${bootloader_binary_files})
|