2018-10-09 15:35:18 +02:00
|
|
|
/*
|
|
|
|
* Copyright (C) 2018 Kaspar Schleiser <kaspar@schleiser.de>
|
2019-05-02 11:22:56 +02:00
|
|
|
* 2018 Inria
|
|
|
|
* 2018 Freie Universität Berlin
|
2018-10-09 15:35:18 +02:00
|
|
|
*
|
|
|
|
* 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.
|
|
|
|
*/
|
|
|
|
|
|
|
|
/**
|
2019-03-23 11:27:30 +01:00
|
|
|
* @defgroup sys_riotboot_slot Helpers to manipulate partitions (slots) on internal flash
|
2018-10-09 15:35:18 +02:00
|
|
|
* @ingroup sys
|
|
|
|
* @{
|
|
|
|
*
|
|
|
|
* @file
|
|
|
|
* @brief Slot management tools
|
|
|
|
*
|
|
|
|
* @author Kaspar Schleiser <kaspar@schleiser.de>
|
|
|
|
* @author Francisco Acosta <francisco.acosta@inria.fr>
|
|
|
|
*
|
|
|
|
* @}
|
|
|
|
*/
|
|
|
|
|
|
|
|
#ifndef RIOTBOOT_SLOT_H
|
|
|
|
#define RIOTBOOT_SLOT_H
|
|
|
|
|
|
|
|
#ifdef __cplusplus
|
|
|
|
extern "C" {
|
|
|
|
#endif
|
|
|
|
|
|
|
|
#include "riotboot/hdr.h"
|
|
|
|
|
|
|
|
/**
|
|
|
|
* @brief Get currently running image slot
|
|
|
|
*
|
|
|
|
* @returns nr of currently active slot
|
|
|
|
*/
|
|
|
|
int riotboot_slot_current(void);
|
|
|
|
|
2019-03-13 17:21:44 +01:00
|
|
|
/**
|
|
|
|
* @brief Get currently not running image slot
|
|
|
|
*
|
|
|
|
* @returns nr of currently inactive slot
|
|
|
|
*/
|
|
|
|
int riotboot_slot_other(void);
|
|
|
|
|
2018-10-09 15:35:18 +02:00
|
|
|
/**
|
|
|
|
* @brief Get jump-to address of image slot
|
|
|
|
*
|
|
|
|
* @param[in] slot slot nr to work on
|
|
|
|
*
|
|
|
|
* @returns address of first byte of @p slot
|
|
|
|
*/
|
|
|
|
uint32_t riotboot_slot_get_image_startaddr(unsigned slot);
|
|
|
|
|
|
|
|
/**
|
|
|
|
* @brief Boot into image in slot @p slot
|
|
|
|
*
|
|
|
|
* @param[in] slot slot nr to jump to
|
|
|
|
*/
|
|
|
|
void riotboot_slot_jump(unsigned slot);
|
|
|
|
|
|
|
|
/**
|
|
|
|
* @brief Get header from a given flash slot
|
|
|
|
*
|
|
|
|
* @param[in] slot slot nr to work on
|
|
|
|
*
|
|
|
|
* @returns header of image slot nr @p slot
|
|
|
|
*/
|
|
|
|
const riotboot_hdr_t *riotboot_slot_get_hdr(unsigned slot);
|
|
|
|
|
|
|
|
/**
|
|
|
|
* @brief Validate slot
|
|
|
|
*
|
|
|
|
* @param[in] slot slot nr to work on
|
|
|
|
*
|
|
|
|
* @returns 0 if ok.
|
|
|
|
*/
|
|
|
|
static inline int riotboot_slot_validate(unsigned slot)
|
|
|
|
{
|
|
|
|
return riotboot_hdr_validate(riotboot_slot_get_hdr(slot));
|
|
|
|
}
|
|
|
|
|
|
|
|
/**
|
|
|
|
* @brief Print formatted slot header to STDIO
|
|
|
|
*
|
|
|
|
* @param[in] slot slot nr to work on
|
|
|
|
*
|
|
|
|
*/
|
|
|
|
static inline void riotboot_slot_print_hdr(unsigned slot)
|
|
|
|
{
|
|
|
|
riotboot_hdr_print(riotboot_slot_get_hdr(slot));
|
|
|
|
}
|
|
|
|
|
2019-09-26 13:57:17 +02:00
|
|
|
/**
|
|
|
|
* @brief Get the offset (in flash, in bytes) for a given slot.
|
|
|
|
*/
|
|
|
|
size_t riotboot_slot_offset(unsigned slot);
|
|
|
|
|
2018-10-09 15:35:18 +02:00
|
|
|
/**
|
|
|
|
* @brief Dump the addresses of all configured slots
|
|
|
|
*
|
|
|
|
*/
|
|
|
|
void riotboot_slot_dump_addrs(void);
|
|
|
|
|
2020-09-26 22:01:19 +02:00
|
|
|
/**
|
|
|
|
* @brief Get the size of a slot
|
|
|
|
*
|
|
|
|
* @param[in] slot slot nr to get the size from
|
|
|
|
*
|
|
|
|
* @returns The slot size in bytes
|
|
|
|
*/
|
|
|
|
static inline size_t riotboot_slot_size(unsigned slot)
|
|
|
|
{
|
|
|
|
switch(slot) {
|
|
|
|
case 0:
|
|
|
|
return SLOT0_LEN;
|
|
|
|
#if NUM_SLOTS==2
|
|
|
|
case 1:
|
|
|
|
return SLOT1_LEN;
|
|
|
|
#endif
|
|
|
|
default:
|
|
|
|
return 0;
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
2018-10-09 15:35:18 +02:00
|
|
|
/**
|
|
|
|
* @brief Number of configured firmware slots (incl. bootloader slot)
|
|
|
|
*/
|
|
|
|
extern const unsigned riotboot_slot_numof;
|
|
|
|
|
|
|
|
/**
|
|
|
|
* @brief Storage for header pointers of the configured slots
|
|
|
|
*/
|
|
|
|
extern const riotboot_hdr_t * const riotboot_slots[];
|
|
|
|
|
|
|
|
#ifdef __cplusplus
|
|
|
|
}
|
|
|
|
#endif
|
|
|
|
|
|
|
|
#endif /* RIOTBOOT_SLOT_H */
|