idf_build_get_property(target IDF_TARGET) if(${target} STREQUAL "linux") return() # This component is not supported by the POSIX/Linux simulator endif() idf_component_register(REQUIRES bootloader PRIV_REQUIRES partition_table) if(NOT BOOTLOADER_BUILD) idf_build_get_property(build_dir BUILD_DIR) if(CONFIG_APP_BUILD_GENERATE_BINARIES) partition_table_get_partition_info(app_partition_offset "--partition-boot-default" "offset") esptool_py_custom_target(app-flash app "app") esptool_py_flash_target_image(app-flash app "${app_partition_offset}" "${build_dir}/${PROJECT_BIN}") esptool_py_flash_target_image(flash app "${app_partition_offset}" "${build_dir}/${PROJECT_BIN}") endif() # If anti-rollback option is set then factory partition should not be in Partition Table. # In this case, should be used the partition table with two ota app without the factory. partition_table_get_partition_info(factory_offset "--partition-type app --partition-subtype factory" "offset") partition_table_get_partition_info(test_offset "--partition-type app --partition-subtype test" "offset") if(CONFIG_BOOTLOADER_APP_ANTI_ROLLBACK AND (factory_offset OR test_offset)) fail_at_build_time(check_table_contents "\ ERROR: Anti-rollback option is enabled. Partition table should \ consist of two ota app without factory or test partitions.") add_dependencies(app check_table_contents) endif() # Generate flasher_args.json for tools that need it. The variables below are used # in configuring the template flasher_args.json.in. # Some of the variables (flash mode, size, frequency, chip) are already set in project_include.cmake. set(ESPTOOLPY_BEFORE "${CONFIG_ESPTOOLPY_BEFORE}") set(ESPTOOLPY_AFTER "${CONFIG_ESPTOOLPY_AFTER}") if(CONFIG_ESPTOOLPY_NO_STUB) set(ESPTOOLPY_WITH_STUB false) else() set(ESPTOOLPY_WITH_STUB true) endif() if(CONFIG_SECURE_BOOT OR CONFIG_SECURE_FLASH_ENC_ENABLED) # If security enabled then override post flash option set(ESPTOOLPY_AFTER "no_reset") endif() if(CONFIG_APP_BUILD_GENERATE_BINARIES) # Generate flasher args files file(READ "flasher_args.json.in" flasher_args_content) string(CONFIGURE "${flasher_args_content}" flasher_args_content) file_generate("${CMAKE_CURRENT_BINARY_DIR}/flasher_args.json.in" CONTENT "${flasher_args_content}") file_generate("${CMAKE_BINARY_DIR}/flasher_args.json" INPUT "${CMAKE_CURRENT_BINARY_DIR}/flasher_args.json.in") if(CONFIG_APP_BUILD_TYPE_APP_2NDBOOT) # Generate app_check_size_command target to check the app size against the partition table parameters partition_table_add_check_size_target(app_check_size DEPENDS gen_project_binary BINARY_PATH "${build_dir}/${PROJECT_BIN}" PARTITION_TYPE app) add_dependencies(app app_check_size) endif() endif() endif() # NOT BOOTLOADER_BUILD if(BOOTLOADER_BUILD) # Generate bootloader post-build check of the bootloader size against the offset partition_table_add_check_bootloader_size_target(bootloader_check_size DEPENDS gen_project_binary BOOTLOADER_BINARY_PATH "${build_dir}/${PROJECT_BIN}" RESULT bootloader_check_size_command) add_dependencies(app bootloader_check_size) # note: in the subproject, so the target is 'app'... if(CONFIG_SECURE_BOOT_V2_ENABLED AND CONFIG_SECURE_BOOT_BUILD_SIGNED_BINARIES) # Check the size of the bootloader + signature block. partition_table_add_check_bootloader_size_target(bootloader_check_size_signed DEPENDS gen_signed_bootloader BOOTLOADER_BINARY_PATH "${build_dir}/${PROJECT_BIN}" RESULT bootloader_check_size_signed_command) add_dependencies(app bootloader_check_size_signed) # note: in the subproject, so the target is 'app'... endif() endif()