2019-07-05 11:59:06 +02:00
|
|
|
/*
|
|
|
|
* Copyright (C) 2019 Kaspar Schleiser <kaspar@schleiser.de>
|
|
|
|
*
|
|
|
|
* 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.
|
|
|
|
*/
|
|
|
|
|
|
|
|
/**
|
|
|
|
* @ingroup examples
|
|
|
|
* @{
|
|
|
|
*
|
|
|
|
* @file
|
|
|
|
* @brief SUIT updates over CoAP example server application (using nanocoap)
|
|
|
|
*
|
|
|
|
* @author Kaspar Schleiser <kaspar@schleiser.de>
|
|
|
|
* @}
|
|
|
|
*/
|
|
|
|
|
|
|
|
#include <stdio.h>
|
|
|
|
|
2019-10-11 23:00:43 +02:00
|
|
|
#include "thread.h"
|
2019-07-05 11:59:06 +02:00
|
|
|
#include "irq.h"
|
|
|
|
#include "net/nanocoap_sock.h"
|
|
|
|
#include "xtimer.h"
|
|
|
|
|
2019-10-11 23:00:43 +02:00
|
|
|
#include "shell.h"
|
|
|
|
|
2020-02-26 14:52:39 +01:00
|
|
|
#include "suit/transport/coap.h"
|
2019-07-05 11:59:06 +02:00
|
|
|
#include "riotboot/slot.h"
|
|
|
|
|
2019-07-29 17:39:12 +02:00
|
|
|
#ifdef MODULE_PERIPH_GPIO
|
|
|
|
#include "periph/gpio.h"
|
|
|
|
#endif
|
|
|
|
|
2019-07-05 11:59:06 +02:00
|
|
|
#define COAP_INBUF_SIZE (256U)
|
|
|
|
|
2019-10-11 23:00:43 +02:00
|
|
|
/* Extend stacksize of nanocoap server thread */
|
|
|
|
static char _nanocoap_server_stack[THREAD_STACKSIZE_DEFAULT + THREAD_EXTRA_STACKSIZE_PRINTF];
|
|
|
|
#define NANOCOAP_SERVER_QUEUE_SIZE (8)
|
|
|
|
static msg_t _nanocoap_server_msg_queue[NANOCOAP_SERVER_QUEUE_SIZE];
|
|
|
|
|
2019-07-05 11:59:06 +02:00
|
|
|
#define MAIN_QUEUE_SIZE (8)
|
|
|
|
static msg_t _main_msg_queue[MAIN_QUEUE_SIZE];
|
|
|
|
|
2019-10-11 23:00:43 +02:00
|
|
|
static void *_nanocoap_server_thread(void *arg)
|
|
|
|
{
|
|
|
|
(void)arg;
|
|
|
|
|
|
|
|
/* nanocoap_server uses gnrc sock which uses gnrc which needs a msg queue */
|
|
|
|
msg_init_queue(_nanocoap_server_msg_queue, NANOCOAP_SERVER_QUEUE_SIZE);
|
|
|
|
|
|
|
|
/* initialize nanocoap server instance */
|
|
|
|
uint8_t buf[COAP_INBUF_SIZE];
|
|
|
|
sock_udp_ep_t local = { .port=COAP_PORT, .family=AF_INET6 };
|
|
|
|
nanocoap_server(&local, buf, sizeof(buf));
|
|
|
|
|
|
|
|
return NULL;
|
|
|
|
}
|
2019-07-05 11:59:06 +02:00
|
|
|
|
2019-07-29 17:39:12 +02:00
|
|
|
/* assuming that first button is always BTN0 */
|
|
|
|
#if defined(MODULE_PERIPH_GPIO_IRQ) && defined(BTN0_PIN)
|
|
|
|
static void cb(void *arg)
|
|
|
|
{
|
|
|
|
(void) arg;
|
|
|
|
printf("Button pressed! Triggering suit update! \n");
|
|
|
|
suit_coap_trigger((uint8_t *) SUIT_MANIFEST_RESOURCE, sizeof(SUIT_MANIFEST_RESOURCE));
|
|
|
|
}
|
|
|
|
#endif
|
|
|
|
|
2020-11-06 14:03:02 +01:00
|
|
|
static int cmd_print_riotboot_hdr(int argc, char **argv)
|
2019-07-05 11:59:06 +02:00
|
|
|
{
|
2020-11-06 14:03:02 +01:00
|
|
|
(void)argc;
|
|
|
|
(void)argv;
|
2019-07-05 11:59:06 +02:00
|
|
|
|
|
|
|
int current_slot = riotboot_slot_current();
|
|
|
|
if (current_slot != -1) {
|
|
|
|
/* Sometimes, udhcp output messes up the following printfs. That
|
|
|
|
* confuses the test script. As a workaround, just disable interrupts
|
|
|
|
* for a while.
|
|
|
|
*/
|
2020-11-06 14:03:02 +01:00
|
|
|
unsigned state = irq_disable();
|
2019-07-05 11:59:06 +02:00
|
|
|
riotboot_slot_print_hdr(current_slot);
|
2020-11-06 14:03:02 +01:00
|
|
|
irq_restore(state);
|
2019-07-05 11:59:06 +02:00
|
|
|
}
|
|
|
|
else {
|
|
|
|
printf("[FAILED] You're not running riotboot\n");
|
|
|
|
}
|
2020-11-06 14:03:02 +01:00
|
|
|
return 0;
|
|
|
|
}
|
|
|
|
|
|
|
|
static int cmd_print_current_slot(int argc, char **argv)
|
|
|
|
{
|
|
|
|
(void)argc;
|
|
|
|
(void)argv;
|
|
|
|
/* Sometimes, udhcp output messes up the following printfs. That
|
|
|
|
* confuses the test script. As a workaround, just disable interrupts
|
|
|
|
* for a while.
|
|
|
|
*/
|
|
|
|
unsigned state = irq_disable();
|
|
|
|
printf("Running from slot %d\n", riotboot_slot_current());
|
|
|
|
irq_restore(state);
|
|
|
|
return 0;
|
|
|
|
}
|
|
|
|
|
|
|
|
static const shell_command_t shell_commands[] = {
|
|
|
|
{ "current-slot", "Print current slot number", cmd_print_current_slot },
|
|
|
|
{ "riotboot-hdr", "Print current slot header", cmd_print_riotboot_hdr },
|
|
|
|
{ NULL, NULL, NULL }
|
|
|
|
};
|
|
|
|
|
|
|
|
|
|
|
|
int main(void)
|
|
|
|
{
|
|
|
|
puts("RIOT SUIT update example application");
|
2019-07-05 11:59:06 +02:00
|
|
|
|
2019-07-29 17:39:12 +02:00
|
|
|
#if defined(MODULE_PERIPH_GPIO_IRQ) && defined(BTN0_PIN)
|
|
|
|
/* initialize a button to manually trigger an update */
|
|
|
|
gpio_init_int(BTN0_PIN, BTN0_MODE, GPIO_FALLING, cb, NULL);
|
|
|
|
#endif
|
|
|
|
|
2020-11-06 14:03:02 +01:00
|
|
|
cmd_print_current_slot(0, NULL);
|
|
|
|
cmd_print_riotboot_hdr(0, NULL);
|
2019-07-29 17:39:12 +02:00
|
|
|
|
2019-07-05 11:59:06 +02:00
|
|
|
/* start suit coap updater thread */
|
|
|
|
suit_coap_run();
|
|
|
|
|
2019-10-11 23:00:43 +02:00
|
|
|
/* start nanocoap server thread */
|
|
|
|
thread_create(_nanocoap_server_stack, sizeof(_nanocoap_server_stack),
|
|
|
|
THREAD_PRIORITY_MAIN - 1,
|
|
|
|
THREAD_CREATE_STACKTEST,
|
|
|
|
_nanocoap_server_thread, NULL, "nanocoap server");
|
|
|
|
|
|
|
|
/* the shell contains commands that receive packets via GNRC and thus
|
|
|
|
needs a msg queue */
|
|
|
|
msg_init_queue(_main_msg_queue, MAIN_QUEUE_SIZE);
|
|
|
|
|
|
|
|
puts("Starting the shell");
|
|
|
|
char line_buf[SHELL_DEFAULT_BUFSIZE];
|
2020-11-06 14:03:02 +01:00
|
|
|
shell_run(shell_commands, line_buf, SHELL_DEFAULT_BUFSIZE);
|
2019-07-05 11:59:06 +02:00
|
|
|
|
|
|
|
return 0;
|
|
|
|
}
|