2020-02-26 14:48:24 +01:00
|
|
|
/*
|
|
|
|
* Copyright (C) 2019 Koen Zandberg
|
|
|
|
* 2020 Inria
|
|
|
|
*
|
|
|
|
* This file is subject to the terms and conditions of the GNU Lesser
|
|
|
|
* General Public License v2.1. See the file LICENSE in the top level
|
|
|
|
* directory for more details.
|
|
|
|
*/
|
|
|
|
/**
|
2020-02-26 14:49:35 +01:00
|
|
|
* @ingroup sys_suit
|
2020-02-26 14:48:24 +01:00
|
|
|
* @{
|
|
|
|
*
|
|
|
|
* @file
|
2020-02-26 14:49:35 +01:00
|
|
|
* @brief SUIT handlers for the global SUIT manifest content.
|
2020-02-26 14:48:24 +01:00
|
|
|
*
|
2020-02-26 14:52:39 +01:00
|
|
|
* This file includes the implementation of the SUIT manifest content.
|
|
|
|
*
|
2020-02-26 14:48:24 +01:00
|
|
|
* @author Koen Zandberg <koen@bergzand.net>
|
|
|
|
*
|
|
|
|
* @}
|
|
|
|
*/
|
|
|
|
|
|
|
|
#include <inttypes.h>
|
|
|
|
#include <nanocbor/nanocbor.h>
|
|
|
|
|
|
|
|
#include "kernel_defines.h"
|
|
|
|
#include "log.h"
|
|
|
|
#include "suit/conditions.h"
|
|
|
|
#include "suit/handlers.h"
|
|
|
|
#include "suit/policy.h"
|
|
|
|
#include "suit.h"
|
2020-09-28 23:12:54 +02:00
|
|
|
#include "suit/storage.h"
|
2020-02-26 14:48:24 +01:00
|
|
|
|
|
|
|
extern int _common_sequence_handler(suit_manifest_t *manifest, int key,
|
|
|
|
nanocbor_value_t *it);
|
|
|
|
|
|
|
|
static int _version_handler(suit_manifest_t *manifest, int key,
|
|
|
|
nanocbor_value_t *it)
|
|
|
|
{
|
|
|
|
(void)manifest;
|
|
|
|
(void)key;
|
|
|
|
/* Validate manifest version */
|
|
|
|
int32_t version = -1;
|
|
|
|
if (nanocbor_get_int32(it, &version) >= 0) {
|
|
|
|
if (version == SUIT_VERSION) {
|
|
|
|
manifest->validated |= SUIT_VALIDATED_VERSION;
|
2023-03-10 02:27:43 +01:00
|
|
|
LOG_INFO("suit: validated manifest version\n");
|
2020-02-26 14:48:24 +01:00
|
|
|
return SUIT_OK;
|
|
|
|
}
|
|
|
|
}
|
|
|
|
return SUIT_ERR_SEQUENCE_NUMBER;
|
|
|
|
}
|
|
|
|
|
|
|
|
static int _seq_no_handler(suit_manifest_t *manifest, int key,
|
|
|
|
nanocbor_value_t *it)
|
|
|
|
{
|
|
|
|
(void)key;
|
|
|
|
|
2020-09-28 23:12:54 +02:00
|
|
|
uint32_t seq_nr;
|
2020-02-26 14:48:24 +01:00
|
|
|
|
2020-09-28 23:12:54 +02:00
|
|
|
if (nanocbor_get_uint32(it, &seq_nr) < 0) {
|
2020-02-26 14:48:24 +01:00
|
|
|
LOG_INFO("Unable to get sequence number\n");
|
|
|
|
return SUIT_ERR_INVALID_MANIFEST;
|
|
|
|
}
|
2020-09-28 23:12:54 +02:00
|
|
|
|
|
|
|
uint32_t stored_seq_no = 0;
|
|
|
|
if (suit_storage_get_highest_seq_no(&stored_seq_no) < 0) {
|
|
|
|
return SUIT_ERR_STORAGE;
|
2020-02-26 14:48:24 +01:00
|
|
|
}
|
2020-09-28 23:12:54 +02:00
|
|
|
LOG_INFO("Manifest seq_no: %"PRIu32", highest available: %"PRIu32"\n",
|
|
|
|
seq_nr, stored_seq_no);
|
2020-02-26 14:48:24 +01:00
|
|
|
|
2020-09-28 23:12:54 +02:00
|
|
|
if (seq_nr <= stored_seq_no) {
|
2023-03-10 02:27:43 +01:00
|
|
|
LOG_ERROR("seq_nr <= running image\n");
|
2020-09-28 23:12:54 +02:00
|
|
|
return SUIT_ERR_SEQUENCE_NUMBER;
|
2020-02-26 14:48:24 +01:00
|
|
|
}
|
2020-09-28 23:12:54 +02:00
|
|
|
|
2023-03-10 02:27:43 +01:00
|
|
|
LOG_INFO("suit: validated sequence number\n");
|
2022-04-04 11:27:41 +02:00
|
|
|
manifest->seq_number = seq_nr;
|
2020-02-26 14:48:24 +01:00
|
|
|
manifest->validated |= SUIT_VALIDATED_SEQ_NR;
|
|
|
|
return SUIT_OK;
|
|
|
|
|
|
|
|
}
|
|
|
|
|
|
|
|
static int _common_handler(suit_manifest_t *manifest, int key,
|
|
|
|
nanocbor_value_t *it)
|
|
|
|
{
|
|
|
|
(void)key;
|
|
|
|
LOG_DEBUG("Starting common section handler\n");
|
|
|
|
return suit_handle_manifest_structure_bstr(manifest, it,
|
|
|
|
suit_common_handlers,
|
|
|
|
suit_common_handlers_len);
|
|
|
|
}
|
|
|
|
|
|
|
|
/* begin{code-style-ignore} */
|
|
|
|
const suit_manifest_handler_t suit_global_handlers[] = {
|
|
|
|
[ 0] = NULL,
|
|
|
|
[SUIT_CONTAINER_VERSION] = _version_handler,
|
|
|
|
[SUIT_CONTAINER_SEQ_NO] = _seq_no_handler,
|
|
|
|
[SUIT_CONTAINER_COMMON] = _common_handler,
|
|
|
|
/* Install and validate both consist of a command sequence */
|
|
|
|
[SUIT_CONTAINER_INSTALL] = _common_sequence_handler,
|
|
|
|
[SUIT_CONTAINER_VALIDATE] = _common_sequence_handler,
|
|
|
|
};
|
|
|
|
/* end{code-style-ignore} */
|
|
|
|
|
|
|
|
const size_t suit_global_handlers_len = ARRAY_SIZE(suit_global_handlers);
|