1# Copyright Runtime.io 2018. All rights reserved. 2# Copyright Nordic Semiconductor ASA 2020-2022. All rights reserved. 3# SPDX-License-Identifier: Apache-2.0 4 5# The Kconfig file is dedicated to Application Image management group of 6# of MCUmgr subsystem and provides Kconfig options to configure 7# group commands behaviour and other aspects. 8# 9# Options defined in this file should be prefixed: 10# MCUMGR_GRP_IMG_ -- general group options; 11# 12# When adding Kconfig options, that control the same feature, 13# try to group them together by the same stem after prefix. 14 15menuconfig MCUMGR_GRP_IMG 16 bool "Mcumgr handlers for image management" 17 depends on FLASH 18 depends on IMG_MANAGER 19 depends on !MCUBOOT_BOOTLOADER_MODE_SINGLE_APP 20 select MPU_ALLOW_FLASH_WRITE if ARM_MPU 21 select MCUMGR_SMP_CBOR_MIN_DECODING_LEVEL_2 22 select MCUMGR_SMP_CBOR_MIN_ENCODING_LEVEL_3 if ZCBOR_CANONICAL 23 help 24 Enables MCUmgr handlers for image management 25 26if MCUMGR_GRP_IMG 27 28if HEAP_MEM_POOL_SIZE > 0 29 30config MCUMGR_GRP_IMG_USE_HEAP_FOR_FLASH_IMG_CONTEXT 31 bool "Use heap mem pool for flash image DFU context" 32 help 33 Use heap to allocate flash image upload context, otherwise a static variable will 34 be used. The context object is used by MCUMGR_GRP_IMG_MANAGER to buffer image writes 35 and has significant size, mainly affected by image write buffer of 36 the CONFIG_IMG_BLOCK_BUF_SIZE size and additional fields that hold the state information 37 (struct flash_img_context). 38 When the option is not enabled it increases static RAM use. 39 Make sure with testing, when enabling the option, that the heap has enough size 40 to allocate this context or it will not be possible to perform DFU; it may also not be 41 possible to allocate such context when heap is under pressure, due to application 42 operation, an issue that should also be addressed within application. 43 44endif 45 46config MCUMGR_GRP_IMG_UPDATABLE_IMAGE_NUMBER 47 int "Number of supported images" 48 default UPDATEABLE_IMAGE_NUMBER 49 range 1 3 50 help 51 Sets how many application images are supported (pairs of secondary and primary slots). 52 Setting this to 2 requires MCUMGR_TRANSPORT_NETBUF_SIZE to be at least 512b. 53 NOTE: The UPDATEABLE_IMAGE_NUMBER of MCUBOOT configuration, even for Zephyr build, 54 needs to be set to the same value; this is due to the fact that the MCUmgr uses 55 boot_util and the UPDATEABLE_IMAGE_NUMBER controls number of images supported 56 by that library. 57 58config MCUMGR_GRP_IMG_VERBOSE_ERR 59 bool "Verbose error responses when uploading application image" 60 select MCUMGR_SMP_VERBOSE_ERR_RESPONSE 61 help 62 Add additional "rsn" key to SMP responses, where provided, explaining 63 non-0 "rc" codes. 64 65config MCUMGR_GRP_IMG_ALLOW_CONFIRM_NON_ACTIVE_IMAGE_SECONDARY 66 bool "Allow to confirm secondary slot of non-active image" 67 default y 68 help 69 Allows to confirm secondary (non-active) slot of non-active image. 70 Normally it should not be allowed to confirm any slots of non-active 71 image, via MCUmgr commands, to prevent confirming something that is 72 broken and may not boot in other slot; instead application should 73 have means to test and confirm the image. 74 75config MCUMGR_GRP_IMG_ALLOW_CONFIRM_NON_ACTIVE_IMAGE_ANY 76 bool "Allow to confirm slots of non-active image" 77 select MCUMGR_GRP_IMG_ALLOW_CONFIRM_NON_ACTIVE_IMAGE_SECONDARY 78 help 79 Allows to confirm any slot of non-active image. 80 Normally it should not be allowed to confirm any slots of non-active 81 image, via MCUmgr commands, to prevent confirming something that is 82 broken and may not boot in other slot; instead application should 83 have means to test and confirm the image. 84 85if !MCUBOOT_BOOTLOADER_MODE_DIRECT_XIP 86config MCUMGR_GRP_IMG_ALLOW_ERASE_PENDING 87 bool "Allow to erase pending slot" 88 help 89 Allows erasing secondary slot which is marked for test or confirmed; this allows 90 erasing slots that have been set for next boot but the device has not 91 reset yet, so has not yet been swapped. 92endif 93 94config MCUMGR_GRP_IMG_DIRECT_UPLOAD 95 bool "Allow direct image upload" 96 help 97 Enables directly uploading image to selected image partition. 98 This changes how "image" is understood by MCUmgr: normally MCUmgr allows uploading to 99 the first slot of the only image it knows, where image is understood as two slots 100 (two DTS images for Zephyr); this allows to treat every DTS defined image as direct 101 target for upload, and more than two may be used (4 at this time). 102 NOTE: When direct upload is used the image numbers are shifted by + 1, and the default 103 behaviour is, when image is not selected, to upload to image that represents secondary 104 slot in normal operation. 105 106config MCUMGR_GRP_IMG_REJECT_DIRECT_XIP_MISMATCHED_SLOT 107 bool "Reject Direct-XIP applications with mismatched address" 108 help 109 When enabled, the MCUmgr will compare base address of application, 110 encoded into .bin file header with use of imgtool, on upload and will 111 reject binaries that would not be able to start from available 112 Direct-XIP address. 113 The base address can be set, to an image binary header, with imgtool, 114 using the --rom-fixed command line option. 115 116config MCUMGR_GRP_IMG_FRUGAL_LIST 117 bool "Omit zero, empty or false values from status list" 118 help 119 The status list send back from the device will only be filled with data that is non-zero, 120 non-empty or true. This option slightly reduces number of bytes transferred back from 121 a device but requires support in client software, which has to default omitted values. 122 Works correctly with the go mcumgr-cli application. 123 124config MCUMGR_GRP_IMG_VERSION_CMP_USE_BUILD_NUMBER 125 bool "Use build number while comparing image version" 126 help 127 By default, the image version comparison relies only on version major, 128 minor and revision. Enable this option to take into account the build 129 number as well. 130 131config MCUMGR_GRP_IMG_UPLOAD_CHECK_HOOK 132 bool "Upload check hook" 133 depends on MCUMGR_MGMT_NOTIFICATION_HOOKS 134 help 135 This will enable the upload check hook which will send image upload requests to 136 registered callbacks to check with the user application if an upload should be accepted 137 or rejected. 138 139config MCUMGR_GRP_IMG_STATUS_HOOKS 140 bool "Status hooks" 141 depends on MCUMGR_MGMT_NOTIFICATION_HOOKS 142 help 143 This will enable DFU status hooks which can be checked by the application to monitor DFU 144 uploads. Note that these are status checking only, to allow inspecting of a file upload 145 or prevent it, CONFIG_MCUMGR_GRP_IMG_UPLOAD_CHECK_HOOK must be used. 146 147config MCUMGR_GRP_IMG_MUTEX 148 bool "Mutex locking" 149 help 150 This will enable use of a mutex to lock the image group object access, preventing issues 151 of concurrent thread (i.e. multiple transport) access. This option also makes the 152 ``img_mgmt_reset_upload()`` function visible in the image management group header, which 153 can be used by applications to reset the image management state (useful if there are 154 multiple ways that firmware updates can be loaded). 155 156choice MCUMGR_GRP_IMG_TOO_LARGE_CHECK 157 prompt "Image size check overhead" 158 default MCUMGR_GRP_IMG_TOO_LARGE_DISABLED 159 help 160 MCUboot images should be limited to the maximum size that the bootloader can swap, in 161 order to know this size, additional information is needed from the MCUboot 162 configuration, otherwise an image can be uploaded that is too large for the bootloader 163 to swap, this selects which method to use. 164 165 Note: setting this to a non-disabled option will prevent uploading of padded and 166 confirmed images, if support for that is required then this feature should be left as 167 disabled. 168 169config MCUMGR_GRP_IMG_TOO_LARGE_DISABLED 170 bool "Disabled" 171 help 172 Will not take MCUboot configuration into account when checking for maximum file size. 173 174config MCUMGR_GRP_IMG_TOO_LARGE_SYSBUILD 175 bool "Via Sysbuild from MCUboot configuration" 176 depends on ROM_END_OFFSET > 0 || MCUBOOT_UPDATE_FOOTER_SIZE > 0 177 help 178 Will use the image overhead size calculated during Sysbuild image configuration. 179 180config MCUMGR_GRP_IMG_TOO_LARGE_BOOTLOADER_INFO 181 bool "Via retention bootloader info" 182 depends on RETENTION_BOOTLOADER_INFO_OUTPUT_FUNCTION 183 help 184 Will fetch the maximum image size from the bootloader info retention subsystem module. 185 186endchoice 187 188config MCUMGR_GRP_IMG_IMAGE_SLOT_STATE_HOOK 189 bool "Image slot state hook" 190 depends on MCUMGR_MGMT_NOTIFICATION_HOOKS 191 help 192 Allows applications to add additional fields to responses for the image slot state 193 command. 194 195config MCUMGR_GRP_IMG_IMAGE_SLOT_STATE_STATES 196 int 197 prompt "Predicted maximum number of entries per group" if MCUMGR_GRP_IMG_IMAGE_SLOT_STATE_HOOK 198 default 15 199 help 200 This is used for defining CBOR map holding group data. 201 The value does not affect memory allocation, it is used by zcbor 202 to figure out how to encode map depending on its predicted size. 203 204config MCUMGR_GRP_IMG_SLOT_INFO 205 bool "Slot info" 206 default y if MCUMGR_GRP_IMG_UPDATABLE_IMAGE_NUMBER > 1 207 help 208 This will enable the slot information function which will return information about all 209 images and slots that the application can see. 210 211config MCUMGR_GRP_IMG_SLOT_INFO_HOOKS 212 bool "Slot info hooks" 213 depends on MCUMGR_GRP_IMG_SLOT_INFO && MCUMGR_MGMT_NOTIFICATION_HOOKS 214 help 215 This will enable the slot info function hooks which can be used to add additional 216 information to responses. 217 218module = MCUMGR_GRP_IMG 219module-str = mcumgr_grp_img 220source "subsys/logging/Kconfig.template.log_config" 221 222endif 223