cmake: flash: scripts: Include externally built hex files
Allow user to add externally built hex files to the cmake property HEX_FILES_TO_MERGE. The hex files in this list will be merged with the hex file generated when building the zephyr application. This allows users to leverage the application configuration available in Kconfig and CMake to help decide what hex file should be merged with the zephyr application. Signed-off-by: Håkon Øye Amundsen <haakon.amundsen@nordicsemi.no>
This commit is contained in:
parent
9452a1f045
commit
81c6662d23
|
@ -1304,6 +1304,27 @@ add_custom_command(
|
||||||
# NB: COMMENT only works for some CMake-Generators
|
# NB: COMMENT only works for some CMake-Generators
|
||||||
)
|
)
|
||||||
|
|
||||||
|
# To populate with hex files to merge, do the following:
|
||||||
|
# set_property(GLOBAL APPEND PROPERTY HEX_FILES_TO_MERGE ${my_local_list})
|
||||||
|
# Note that the zephyr.hex file will not be included automatically.
|
||||||
|
get_property(HEX_FILES_TO_MERGE GLOBAL PROPERTY HEX_FILES_TO_MERGE)
|
||||||
|
if(HEX_FILES_TO_MERGE)
|
||||||
|
# Merge in out-of-tree hex files.
|
||||||
|
set(merged_hex_name merged.hex)
|
||||||
|
|
||||||
|
add_custom_command(
|
||||||
|
OUTPUT ${merged_hex_name}
|
||||||
|
COMMAND
|
||||||
|
${PYTHON_EXECUTABLE}
|
||||||
|
${ZEPHYR_BASE}/scripts/mergehex.py
|
||||||
|
-o ${merged_hex_name}
|
||||||
|
${HEX_FILES_TO_MERGE}
|
||||||
|
DEPENDS ${HEX_FILES_TO_MERGE} ${logical_target_for_zephyr_elf}
|
||||||
|
)
|
||||||
|
|
||||||
|
add_custom_target(mergehex ALL DEPENDS ${merged_hex_name})
|
||||||
|
endif()
|
||||||
|
|
||||||
if(CONFIG_OUTPUT_PRINT_MEMORY_USAGE)
|
if(CONFIG_OUTPUT_PRINT_MEMORY_USAGE)
|
||||||
# Use --print-memory-usage with the first link.
|
# Use --print-memory-usage with the first link.
|
||||||
#
|
#
|
||||||
|
|
|
@ -29,8 +29,14 @@ if(RUNNERS)
|
||||||
CACHE STRING "Board definition directory" FORCE)
|
CACHE STRING "Board definition directory" FORCE)
|
||||||
set(ZEPHYR_RUNNER_CONFIG_KERNEL_ELF "${PROJECT_BINARY_DIR}/${KERNEL_ELF_NAME}"
|
set(ZEPHYR_RUNNER_CONFIG_KERNEL_ELF "${PROJECT_BINARY_DIR}/${KERNEL_ELF_NAME}"
|
||||||
CACHE STRING "Path to kernel image in ELF format" FORCE)
|
CACHE STRING "Path to kernel image in ELF format" FORCE)
|
||||||
set(ZEPHYR_RUNNER_CONFIG_KERNEL_HEX "${PROJECT_BINARY_DIR}/${KERNEL_HEX_NAME}"
|
get_property(HEX_FILES_TO_MERGE GLOBAL PROPERTY HEX_FILES_TO_MERGE)
|
||||||
CACHE STRING "Path to kernel image in Intel Hex format" FORCE)
|
if(HEX_FILES_TO_MERGE)
|
||||||
|
set(ZEPHYR_RUNNER_CONFIG_KERNEL_HEX "${PROJECT_BINARY_DIR}/${MERGED_HEX_NAME}"
|
||||||
|
CACHE STRING "Path to merged image in Intel Hex format" FORCE)
|
||||||
|
else()
|
||||||
|
set(ZEPHYR_RUNNER_CONFIG_KERNEL_HEX "${PROJECT_BINARY_DIR}/${KERNEL_HEX_NAME}"
|
||||||
|
CACHE STRING "Path to kernel image in Intel Hex format" FORCE)
|
||||||
|
endif()
|
||||||
set(ZEPHYR_RUNNER_CONFIG_KERNEL_BIN "${PROJECT_BINARY_DIR}/${KERNEL_BIN_NAME}"
|
set(ZEPHYR_RUNNER_CONFIG_KERNEL_BIN "${PROJECT_BINARY_DIR}/${KERNEL_BIN_NAME}"
|
||||||
CACHE STRING "Path to kernel image as raw binary" FORCE)
|
CACHE STRING "Path to kernel image as raw binary" FORCE)
|
||||||
# Not always applicable, but so often needed that they're provided
|
# Not always applicable, but so often needed that they're provided
|
||||||
|
|
|
@ -930,6 +930,19 @@ Below is a simple example :file:`CMakeList.txt`:
|
||||||
|
|
||||||
target_sources(app PRIVATE src/main.c)
|
target_sources(app PRIVATE src/main.c)
|
||||||
|
|
||||||
|
The Cmake property ``HEX_FILES_TO_MERGE``
|
||||||
|
leverages the application configuration provided by
|
||||||
|
Kconfig and CMake to let you merge externally built hex files
|
||||||
|
with the hex file generated when building the Zephyr application.
|
||||||
|
For example:
|
||||||
|
|
||||||
|
.. code-block:: cmake
|
||||||
|
|
||||||
|
set_property(GLOBAL APPEND PROPERTY HEX_FILES_TO_MERGE
|
||||||
|
${app_bootloader_hex}
|
||||||
|
${PROJECT_BINARY_DIR}/${KERNEL_HEX_NAME}
|
||||||
|
${app_provision_hex})
|
||||||
|
|
||||||
CMakeCache.txt
|
CMakeCache.txt
|
||||||
==============
|
==============
|
||||||
|
|
||||||
|
@ -1292,3 +1305,4 @@ project that demonstrates some of these features.
|
||||||
.. _Eclipse IDE for C/C++ Developers: https://www.eclipse.org/downloads/packages/eclipse-ide-cc-developers/oxygen2
|
.. _Eclipse IDE for C/C++ Developers: https://www.eclipse.org/downloads/packages/eclipse-ide-cc-developers/oxygen2
|
||||||
.. _GNU MCU Eclipse plug-ins: https://gnu-mcu-eclipse.github.io/plugins/install/
|
.. _GNU MCU Eclipse plug-ins: https://gnu-mcu-eclipse.github.io/plugins/install/
|
||||||
.. _pyOCD v0.11.0: https://github.com/mbedmicro/pyOCD/releases/tag/v0.11.0
|
.. _pyOCD v0.11.0: https://github.com/mbedmicro/pyOCD/releases/tag/v0.11.0
|
||||||
|
|
||||||
|
|
47
scripts/mergehex.py
Normal file
47
scripts/mergehex.py
Normal file
|
@ -0,0 +1,47 @@
|
||||||
|
#!/usr/bin/env python3
|
||||||
|
#
|
||||||
|
# Copyright (c) 2018 Nordic Semiconductor ASA
|
||||||
|
#
|
||||||
|
# SPDX-License-Identifier: Apache-2.0
|
||||||
|
|
||||||
|
# This merges a set of input hex files into a single output hex file.
|
||||||
|
# Any conflicts will result in an error being reported.
|
||||||
|
|
||||||
|
from intelhex import IntelHex
|
||||||
|
|
||||||
|
import argparse
|
||||||
|
|
||||||
|
|
||||||
|
def merge_hex_files(output, input_hex_files):
|
||||||
|
ih = IntelHex()
|
||||||
|
|
||||||
|
for hex_file_path in input_hex_files:
|
||||||
|
to_merge = IntelHex(hex_file_path)
|
||||||
|
|
||||||
|
# Since 'arm-none-eabi-objcopy' incorrectly inserts record type '03 - Start Segment Address', we need to remove
|
||||||
|
# the start_addr to avoid conflicts when merging.
|
||||||
|
to_merge.start_addr = None
|
||||||
|
|
||||||
|
ih.merge(to_merge)
|
||||||
|
ih.write_hex_file(output)
|
||||||
|
|
||||||
|
|
||||||
|
def parse_args():
|
||||||
|
parser = argparse.ArgumentParser(
|
||||||
|
description="Merge hex files.",
|
||||||
|
formatter_class=argparse.RawDescriptionHelpFormatter)
|
||||||
|
parser.add_argument("-o", "--output", required=False, default="merged.hex",
|
||||||
|
type=argparse.FileType('w', encoding='UTF-8'),
|
||||||
|
help="Output file name.")
|
||||||
|
parser.add_argument("input_files", nargs='*')
|
||||||
|
return parser.parse_args()
|
||||||
|
|
||||||
|
|
||||||
|
def main():
|
||||||
|
args = parse_args()
|
||||||
|
|
||||||
|
merge_hex_files(args.output, args.input_files)
|
||||||
|
|
||||||
|
|
||||||
|
if __name__ == "__main__":
|
||||||
|
main()
|
|
@ -17,3 +17,4 @@ pykwalify
|
||||||
windows-curses; sys_platform == "win32"
|
windows-curses; sys_platform == "win32"
|
||||||
colorama
|
colorama
|
||||||
Pillow
|
Pillow
|
||||||
|
intelhex
|
||||||
|
|
Loading…
Reference in a new issue