mirror of
https://github.com/espressif/esp-idf.git
synced 2024-10-05 20:47:46 -04:00
236498b040
This commit allows the configuration of an absolute path for the custom partitions.csv file via the Kconfig option CONFIG_PARTITION_TABLE_CUSTOM_FILENAME. Closes https://github.com/espressif/esp-idf/issues/12264
126 lines
5.8 KiB
CMake
126 lines
5.8 KiB
CMake
set(PARTITION_TABLE_OFFSET ${CONFIG_PARTITION_TABLE_OFFSET})
|
|
|
|
set(PARTITION_TABLE_CHECK_SIZES_TOOL_PATH "${CMAKE_CURRENT_LIST_DIR}/check_sizes.py")
|
|
|
|
idf_build_get_property(build_dir BUILD_DIR)
|
|
idf_build_set_property(PARTITION_TABLE_BIN_PATH "${build_dir}/partition_table/partition-table.bin")
|
|
|
|
if(NOT BOOTLOADER_BUILD)
|
|
# Set PARTITION_CSV_PATH to the configured partition CSV file
|
|
# absolute path
|
|
if(CONFIG_PARTITION_TABLE_CUSTOM)
|
|
# If the partition CSV file config already has the absolute path then set PARTITION_CSV_PATH directly
|
|
if(IS_ABSOLUTE ${CONFIG_PARTITION_TABLE_FILENAME})
|
|
set(PARTITION_CSV_PATH "${CONFIG_PARTITION_TABLE_FILENAME}")
|
|
else()
|
|
idf_build_get_property(project_dir PROJECT_DIR)
|
|
# Custom filename expands any path relative to the project
|
|
get_filename_component(PARTITION_CSV_PATH "${CONFIG_PARTITION_TABLE_FILENAME}"
|
|
ABSOLUTE BASE_DIR "${project_dir}")
|
|
endif()
|
|
|
|
if(NOT EXISTS "${PARTITION_CSV_PATH}")
|
|
message(WARNING "Partition table CSV file ${PARTITION_CSV_PATH} not found. "
|
|
"Change custom partition CSV path in menuconfig.")
|
|
# Note: partition_table CMakeLists.txt contains some logic to create a dummy
|
|
# partition_table target in this case, see comments in that file.
|
|
endif()
|
|
else()
|
|
# Other .csv files are always in the component directory
|
|
get_filename_component(PARTITION_CSV_PATH "${COMPONENT_DIR}/${CONFIG_PARTITION_TABLE_FILENAME}" ABSOLUTE)
|
|
|
|
if(NOT EXISTS "${PARTITION_CSV_PATH}")
|
|
message(FATAL_ERROR "Internal error, built-in ${PARTITION_CSV_PATH} not found.")
|
|
endif()
|
|
endif()
|
|
|
|
# need to re-run CMake if the partition CSV changes, as the offsets/sizes of partitions may change
|
|
set_property(DIRECTORY APPEND PROPERTY CMAKE_CONFIGURE_DEPENDS ${PARTITION_CSV_PATH})
|
|
endif()
|
|
|
|
# partition_table_get_partition_info
|
|
#
|
|
# Get information about a partition from the partition table
|
|
function(partition_table_get_partition_info result get_part_info_args part_info)
|
|
idf_build_get_property(python PYTHON)
|
|
idf_build_get_property(idf_path IDF_PATH)
|
|
|
|
idf_build_get_property(extra_subtypes EXTRA_PARTITION_SUBTYPES)
|
|
if(extra_subtypes)
|
|
# Remove all white spaces from the string
|
|
string(REPLACE " " "" extra_subtypes "${extra_subtypes}")
|
|
set(extra_partition_subtypes --extra-partition-subtypes ${extra_subtypes})
|
|
else()
|
|
set(extra_partition_subtypes "")
|
|
endif()
|
|
separate_arguments(get_part_info_args)
|
|
execute_process(COMMAND ${python}
|
|
${idf_path}/components/partition_table/parttool.py -q
|
|
--partition-table-offset ${PARTITION_TABLE_OFFSET}
|
|
--partition-table-file ${PARTITION_CSV_PATH}
|
|
get_partition_info ${get_part_info_args} --info ${part_info}
|
|
${extra_partition_subtypes}
|
|
OUTPUT_VARIABLE info
|
|
RESULT_VARIABLE exit_code
|
|
OUTPUT_STRIP_TRAILING_WHITESPACE)
|
|
if(NOT ${exit_code} EQUAL 0 AND NOT ${exit_code} EQUAL 1)
|
|
# can't fail here as it would prevent the user from running 'menuconfig' again
|
|
message(WARNING "parttool.py execution failed (${result}), problem with partition CSV file (see above)")
|
|
endif()
|
|
set(${result} ${info} PARENT_SCOPE)
|
|
endfunction()
|
|
|
|
# Add a custom target (see add_custom_target) that checks a given binary built by the build system
|
|
# doesn't overflow any partitions with the given partition type and (optional) sub-type.
|
|
#
|
|
# Adding the target doesn't mean it gets called during the build, use add_dependencies to make another
|
|
# target depend on this one.
|
|
#
|
|
# Arguments:
|
|
# - target name - (first argument) name of the target to create
|
|
# - DEPENDS - dependencies the target should have (i.e. whatever target generates the binary).
|
|
# - BINARY_PATH - path to the target binary file to check
|
|
# - PARTITION_TYPE - partition type to check against
|
|
# - PARTITION_SUBTYPE - (optional) partition subtype to check against
|
|
|
|
function(partition_table_add_check_size_target target_name)
|
|
# result binary_path partition_type partition_subtype
|
|
set(args BINARY_PATH PARTITION_TYPE PARTITION_SUBTYPE)
|
|
set(multi_args DEPENDS)
|
|
cmake_parse_arguments(CMD "" "${args}" "${multi_args}" ${ARGN})
|
|
|
|
idf_build_get_property(python PYTHON)
|
|
idf_build_get_property(table_bin PARTITION_TABLE_BIN_PATH)
|
|
if(CMD_PARTITION_SUBTYPE)
|
|
set(subtype_arg --subtype ${CMD_PARTITION_SUBTYPE})
|
|
else()
|
|
set(subtype_arg)
|
|
endif()
|
|
set(command ${python} ${PARTITION_TABLE_CHECK_SIZES_TOOL_PATH}
|
|
--offset ${PARTITION_TABLE_OFFSET}
|
|
partition --type ${CMD_PARTITION_TYPE} ${subtype_arg}
|
|
${table_bin} ${CMD_BINARY_PATH})
|
|
|
|
add_custom_target(${target_name} COMMAND ${command} DEPENDS ${CMD_DEPENDS} partition_table_bin)
|
|
endfunction()
|
|
|
|
# Add a custom target (see add_custom_target) that checks a bootloader binary
|
|
# built by the build system will not overlap the partition table.
|
|
#
|
|
# Adding the target doesn't mean it gets called during the build, use add_dependencies to make another
|
|
# target depend on this one.
|
|
#
|
|
# Arguments:
|
|
# - target name - (first argument) name of the target to create
|
|
# - DEPENDS - dependencies the new target should have (i.e. whatever target generates the bootloader binary)
|
|
# - BOOTLOADER_BINARY_PATH - path to bootloader binary file
|
|
function(partition_table_add_check_bootloader_size_target target_name)
|
|
cmake_parse_arguments(CMD "" "BOOTLOADER_BINARY_PATH" "DEPENDS" ${ARGN})
|
|
idf_build_get_property(python PYTHON)
|
|
|
|
set(command ${python} ${PARTITION_TABLE_CHECK_SIZES_TOOL_PATH}
|
|
--offset ${PARTITION_TABLE_OFFSET}
|
|
bootloader ${BOOTLOADER_OFFSET} ${CMD_BOOTLOADER_BINARY_PATH})
|
|
add_custom_target(${target_name} COMMAND ${command} DEPENDS ${CMD_DEPENDS})
|
|
endfunction()
|