mirror of
https://github.com/RIOT-OS/RIOT.git
synced 2025-01-18 12:52:44 +01:00
nanocoap_server: add nanocoap_server_auto_init
This commit is contained in:
parent
88789454dd
commit
9495dc4e2e
@ -739,6 +739,15 @@ ifneq (,$(filter nanocoap_dtls,$(USEMODULE)))
|
|||||||
USEPKG += tinydtls
|
USEPKG += tinydtls
|
||||||
endif
|
endif
|
||||||
|
|
||||||
|
ifneq (,$(filter nanocoap_server_auto_init,$(USEMODULE)))
|
||||||
|
USEMODULE += nanocoap_server
|
||||||
|
endif
|
||||||
|
|
||||||
|
ifneq (,$(filter nanocoap_server,$(USEMODULE)))
|
||||||
|
USEMODULE += nanocoap_resources
|
||||||
|
USEMODULE += nanocoap_sock
|
||||||
|
endif
|
||||||
|
|
||||||
ifneq (,$(filter nanocoap_sock,$(USEMODULE)))
|
ifneq (,$(filter nanocoap_sock,$(USEMODULE)))
|
||||||
USEMODULE += sock_udp
|
USEMODULE += sock_udp
|
||||||
USEMODULE += sock_util
|
USEMODULE += sock_util
|
||||||
|
@ -160,6 +160,10 @@ extern void gcoap_init(void);
|
|||||||
AUTO_INIT(gcoap_init,
|
AUTO_INIT(gcoap_init,
|
||||||
AUTO_INIT_PRIO_MOD_GCOAP);
|
AUTO_INIT_PRIO_MOD_GCOAP);
|
||||||
#endif
|
#endif
|
||||||
|
#if IS_USED(MODULE_NANOCOAP_SERVER_AUTO_INIT)
|
||||||
|
extern void auto_init_nanocoap_server(void);
|
||||||
|
AUTO_INIT(auto_init_nanocoap_server, AUTO_INIT_PRIO_MOD_NANOCOAP);
|
||||||
|
#endif
|
||||||
#if IS_USED(MODULE_DEVFS)
|
#if IS_USED(MODULE_DEVFS)
|
||||||
extern void auto_init_devfs(void);
|
extern void auto_init_devfs(void);
|
||||||
AUTO_INIT(auto_init_devfs,
|
AUTO_INIT(auto_init_devfs,
|
||||||
|
@ -174,6 +174,12 @@ extern "C" {
|
|||||||
#define AUTO_INIT_PRIO_MOD_UWB_CORE 1230
|
#define AUTO_INIT_PRIO_MOD_UWB_CORE 1230
|
||||||
#endif
|
#endif
|
||||||
#ifndef AUTO_INIT_PRIO_MOD_GCOAP
|
#ifndef AUTO_INIT_PRIO_MOD_GCOAP
|
||||||
|
/**
|
||||||
|
* @brief nanoCoAP server priority
|
||||||
|
*/
|
||||||
|
#define AUTO_INIT_PRIO_MOD_NANOCOAP 1235
|
||||||
|
#endif
|
||||||
|
#ifndef AUTO_INIT_PRIO_MOD_GCOAP
|
||||||
/**
|
/**
|
||||||
* @brief GCoAP priority
|
* @brief GCoAP priority
|
||||||
*/
|
*/
|
||||||
|
@ -159,6 +159,22 @@ extern "C" {
|
|||||||
#define CONFIG_NANOCOAP_SOCK_DTLS_TAG (0xc0ab)
|
#define CONFIG_NANOCOAP_SOCK_DTLS_TAG (0xc0ab)
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
|
/**
|
||||||
|
* @brief CoAP server work buf size
|
||||||
|
* Used both for RX and TX, needs to hold payload block + header
|
||||||
|
*/
|
||||||
|
#ifndef CONFIG_NANOCOAP_SERVER_BUF_SIZE
|
||||||
|
#define CONFIG_NANOCOAP_SERVER_BUF_SIZE ((1 << (CONFIG_NANOCOAP_BLOCKSIZE_DEFAULT + 3)) \
|
||||||
|
+ CONFIG_NANOCOAP_URI_MAX + 16)
|
||||||
|
#endif
|
||||||
|
|
||||||
|
/**
|
||||||
|
* @brief CoAP server thread stack size
|
||||||
|
*/
|
||||||
|
#ifndef CONFIG_NANOCOAP_SERVER_STACK_SIZE
|
||||||
|
#define CONFIG_NANOCOAP_SERVER_STACK_SIZE THREAD_STACKSIZE_DEFAULT
|
||||||
|
#endif
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* @brief NanoCoAP socket types
|
* @brief NanoCoAP socket types
|
||||||
*/
|
*/
|
||||||
@ -220,6 +236,18 @@ static inline uint16_t nanocoap_sock_next_msg_id(nanocoap_sock_t *sock)
|
|||||||
*/
|
*/
|
||||||
int nanocoap_server(sock_udp_ep_t *local, uint8_t *buf, size_t bufsize);
|
int nanocoap_server(sock_udp_ep_t *local, uint8_t *buf, size_t bufsize);
|
||||||
|
|
||||||
|
/**
|
||||||
|
* @brief Create and start the nanoCoAP server thread
|
||||||
|
*
|
||||||
|
* To automatically start the nanoCoAP server on startup, select the
|
||||||
|
* `nanocoap_server_auto_init` module.
|
||||||
|
*
|
||||||
|
* @param[in] local UDP endpoint to bind to
|
||||||
|
*
|
||||||
|
* @return pid of the server thread
|
||||||
|
*/
|
||||||
|
kernel_pid_t nanocoap_server_start(const sock_udp_ep_t *local);
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* @brief Create a CoAP client socket
|
* @brief Create a CoAP client socket
|
||||||
*
|
*
|
||||||
|
@ -817,3 +817,36 @@ int nanocoap_server(sock_udp_ep_t *local, uint8_t *buf, size_t bufsize)
|
|||||||
|
|
||||||
return 0;
|
return 0;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
static kernel_pid_t _coap_server_pid;
|
||||||
|
static void *_nanocoap_server_thread(void *local)
|
||||||
|
{
|
||||||
|
static uint8_t buf[CONFIG_NANOCOAP_SERVER_BUF_SIZE];
|
||||||
|
|
||||||
|
nanocoap_server(local, buf, sizeof(buf));
|
||||||
|
|
||||||
|
return NULL;
|
||||||
|
}
|
||||||
|
|
||||||
|
kernel_pid_t nanocoap_server_start(const sock_udp_ep_t *local)
|
||||||
|
{
|
||||||
|
static char stack[CONFIG_NANOCOAP_SERVER_STACK_SIZE];
|
||||||
|
|
||||||
|
if (_coap_server_pid) {
|
||||||
|
return _coap_server_pid;
|
||||||
|
}
|
||||||
|
_coap_server_pid = thread_create(stack, sizeof(stack), THREAD_PRIORITY_MAIN - 1,
|
||||||
|
THREAD_CREATE_STACKTEST, _nanocoap_server_thread,
|
||||||
|
(void *)local, "nanoCoAP server");
|
||||||
|
return _coap_server_pid;
|
||||||
|
}
|
||||||
|
|
||||||
|
void auto_init_nanocoap_server(void)
|
||||||
|
{
|
||||||
|
sock_udp_ep_t local = {
|
||||||
|
.port = COAP_PORT,
|
||||||
|
.family = AF_INET6,
|
||||||
|
};
|
||||||
|
|
||||||
|
nanocoap_server_start(&local);
|
||||||
|
}
|
||||||
|
Loading…
Reference in New Issue
Block a user