From eb52105fd05ffc2ff98e59e76b48ae0968dfdced Mon Sep 17 00:00:00 2001 From: xengineering Date: Sun, 30 Mar 2025 17:03:15 +0200 Subject: fw: app: update: Write uploaded image to flash This write the received firmware image data to the secondary MCUboot slot. This prepares an update. With the MCUboot shell it can be applied with: mcuboot request_upgrade permanent kernel reboot If the signature is valid the device will permanently update to the new application firmware. Otherwise it will refuse the new image and boot the old one. --- fw/app/src/update.c | 44 ++++++++++++++++++++++++++++++++++++++++++-- 1 file changed, 42 insertions(+), 2 deletions(-) diff --git a/fw/app/src/update.c b/fw/app/src/update.c index 9e91380..ff4ce6a 100644 --- a/fw/app/src/update.c +++ b/fw/app/src/update.c @@ -4,18 +4,18 @@ * obtain one at https://mozilla.org/MPL/2.0/. */ - #include +#include #include #include #include #include #include +#include LOG_MODULE_REGISTER(update); - static int update_handler( struct http_client_ctx *client, enum http_data_status status, @@ -24,6 +24,8 @@ static int update_handler( void *user_data ) { static size_t processed; + static struct flash_img_context flash_img_context; + int ret; if (status == HTTP_SERVER_DATA_ABORTED) { LOG_WRN("Transaction aborted after %zd bytes.", processed); @@ -31,9 +33,47 @@ static int update_handler( return 0; } + bool is_first_call = processed == 0; + if (is_first_call == true) { + uint8_t upload_slot = flash_img_get_upload_slot(); + LOG_INF("Handling upload to flash slot %d", upload_slot); + + const struct flash_area *fa; + ret = flash_area_open(upload_slot, &fa); + if (ret < 0) { + LOG_ERR("Failed to open flash area (%d)", ret); + return ret; + } + + ret = flash_area_erase(fa, 0, FIXED_PARTITION_SIZE(slot1_partition)); + flash_area_close(fa); + if (ret < 0) { + LOG_ERR("Failed to erase flash area (%d)", ret); + return ret; + } + + ret = flash_img_init_id(&flash_img_context, upload_slot); + if (ret < 0) { + LOG_ERR("Failed to init flash image context (%d)", ret); + return ret; + } + } + + ret = flash_img_buffered_write(&flash_img_context, request_ctx->data, + request_ctx->data_len, true); + if (ret < 0) { + LOG_ERR("Failed to write data to flash (%d)", ret); + return ret; + } + processed += request_ctx->data_len; if (status == HTTP_SERVER_DATA_FINAL) { + size_t written = flash_img_bytes_written(&flash_img_context); + if (written != processed) { + LOG_ERR("Processed %zd octets but wrote %zd", processed, written); + return ret; + } LOG_INF("Handled update request receiving %zd octets.", processed); processed = 0; } -- cgit v1.2.3-70-g09d2