mirror of
https://github.com/RIOT-OS/RIOT.git
synced 2024-12-29 04:50:03 +01:00
sys/stdio_udp: add stdio over UDP
This commit is contained in:
parent
1dcccdc99a
commit
6d3562bd0d
@ -80,4 +80,17 @@ else
|
|||||||
"don't run this on public networks!$(COLOR_RESET)" 1>&2)
|
"don't run this on public networks!$(COLOR_RESET)" 1>&2)
|
||||||
endif
|
endif
|
||||||
endif
|
endif
|
||||||
|
|
||||||
|
# Warn about STDIO UDP
|
||||||
|
ifneq (,$(filter stdio_udp,$(USEMODULE)))
|
||||||
|
ifneq (1,$(I_UNDERSTAND_THAT_STDIO_UDP_IS_INSECURE))
|
||||||
|
$(shell $(COLOR_ECHO) "$(COLOR_RED)stdio via UDP will be started automatically,"\
|
||||||
|
"make sure you understand why this almost certainly"\
|
||||||
|
"is a REALLY BAD idea before proceeding!$(COLOR_RESET)" 1>&2)
|
||||||
|
$(error I_UNDERSTAND_THAT_STDIO_UDP_IS_INSECURE must be set to 1 to proceed)
|
||||||
|
else
|
||||||
|
$(shell $(COLOR_ECHO) "$(COLOR_YELLOW)stdio via UDP will be started automatically,"\
|
||||||
|
"don't run this on public networks!$(COLOR_RESET)" 1>&2)
|
||||||
|
endif
|
||||||
|
endif
|
||||||
endif
|
endif
|
||||||
|
@ -8,6 +8,7 @@ STDIO_MODULES = \
|
|||||||
stdio_rtt \
|
stdio_rtt \
|
||||||
stdio_semihosting \
|
stdio_semihosting \
|
||||||
stdio_uart \
|
stdio_uart \
|
||||||
|
stdio_udp \
|
||||||
stdio_telnet \
|
stdio_telnet \
|
||||||
stdio_tinyusb_cdc_acm \
|
stdio_tinyusb_cdc_acm \
|
||||||
stdio_usb_serial_jtag \
|
stdio_usb_serial_jtag \
|
||||||
@ -75,6 +76,10 @@ ifneq (,$(filter stdio_telnet,$(USEMODULE)))
|
|||||||
USEMODULE += telnet
|
USEMODULE += telnet
|
||||||
endif
|
endif
|
||||||
|
|
||||||
|
ifneq (,$(filter stdio_udp,$(USEMODULE)))
|
||||||
|
USEMODULE += sock_udp
|
||||||
|
endif
|
||||||
|
|
||||||
# enable stdout buffering for modules that benefit from sending out buffers in larger chunks
|
# enable stdout buffering for modules that benefit from sending out buffers in larger chunks
|
||||||
ifneq (,$(filter picolibc,$(USEMODULE)))
|
ifneq (,$(filter picolibc,$(USEMODULE)))
|
||||||
ifneq (,$(filter stdio_cdc_acm stdio_ethos slipdev_stdio stdio_semihosting,$(USEMODULE)))
|
ifneq (,$(filter stdio_cdc_acm stdio_ethos slipdev_stdio stdio_semihosting,$(USEMODULE)))
|
||||||
|
1
sys/stdio_udp/Makefile
Normal file
1
sys/stdio_udp/Makefile
Normal file
@ -0,0 +1 @@
|
|||||||
|
include $(RIOTBASE)/Makefile.base
|
29
sys/stdio_udp/doc.txt
Normal file
29
sys/stdio_udp/doc.txt
Normal file
@ -0,0 +1,29 @@
|
|||||||
|
/*
|
||||||
|
* Copyright (C) 2023 ML!PA Consulting GmbH
|
||||||
|
*
|
||||||
|
* 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.
|
||||||
|
*/
|
||||||
|
|
||||||
|
/**
|
||||||
|
* @defgroup sys_stdio_udp STDIO over UDP
|
||||||
|
* @ingroup sys_stdio
|
||||||
|
* @brief STDIO over UDP implementation
|
||||||
|
*
|
||||||
|
* This file implements STDIO via a UDP that can be used with e.g. netcat:
|
||||||
|
*
|
||||||
|
* nc -u fe80::7837:fcff:fe7d:1aaf%tapbr0 2323
|
||||||
|
*
|
||||||
|
* It can be enabled with
|
||||||
|
*
|
||||||
|
* USEMODULE += stdio_udp
|
||||||
|
*
|
||||||
|
* and will listen on `CONFIG_STDIO_UDP_PORT` for incoming connections.
|
||||||
|
*
|
||||||
|
* You will also have to set `I_UNDERSTAND_THAT_STDIO_UDP_IS_INSECURE = 1` to
|
||||||
|
* acknowledge that you will only use this for debugging in an isolated network.
|
||||||
|
*
|
||||||
|
* @warning This is entirely unsecured, only use this for debugging in
|
||||||
|
* an isolated network!
|
||||||
|
*/
|
85
sys/stdio_udp/stdio_udp.c
Normal file
85
sys/stdio_udp/stdio_udp.c
Normal file
@ -0,0 +1,85 @@
|
|||||||
|
/*
|
||||||
|
* Copyright (C) 2023 ML!PA Consulting GmbH
|
||||||
|
*
|
||||||
|
* 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 sys_stdio_udp
|
||||||
|
* @{
|
||||||
|
*
|
||||||
|
* @file
|
||||||
|
* @brief STDIO over UDP implementation
|
||||||
|
*
|
||||||
|
* @author Benjamin Valentin <benjamin.valentin@ml-pa.com>
|
||||||
|
*
|
||||||
|
* @}
|
||||||
|
*/
|
||||||
|
|
||||||
|
#include <errno.h>
|
||||||
|
|
||||||
|
#include "macros/utils.h"
|
||||||
|
#include "net/sock/udp.h"
|
||||||
|
|
||||||
|
#ifndef CONFIG_STDIO_UDP_PORT
|
||||||
|
#define CONFIG_STDIO_UDP_PORT 2323
|
||||||
|
#endif
|
||||||
|
|
||||||
|
#ifndef CONFIG_STDIO_UDP_RX_BUF_LEN
|
||||||
|
#define CONFIG_STDIO_UDP_RX_BUF_LEN 64
|
||||||
|
#endif
|
||||||
|
|
||||||
|
static sock_udp_t sock;
|
||||||
|
static sock_udp_ep_t remote;
|
||||||
|
|
||||||
|
void stdio_init(void)
|
||||||
|
{
|
||||||
|
const sock_udp_ep_t local = {
|
||||||
|
.family = AF_INET6,
|
||||||
|
.netif = SOCK_ADDR_ANY_NETIF,
|
||||||
|
.port = CONFIG_STDIO_UDP_PORT,
|
||||||
|
};
|
||||||
|
|
||||||
|
sock_udp_create(&sock, &local, NULL, 0);
|
||||||
|
}
|
||||||
|
|
||||||
|
ssize_t stdio_read(void* buffer, size_t count)
|
||||||
|
{
|
||||||
|
static uint8_t rx_buf[CONFIG_STDIO_UDP_RX_BUF_LEN];
|
||||||
|
static uint8_t *pos;
|
||||||
|
static size_t left;
|
||||||
|
|
||||||
|
/* shell will only read one byte at a time, so we buffer the input */
|
||||||
|
if (left == 0) {
|
||||||
|
int res = sock_udp_recv(&sock, rx_buf, sizeof(rx_buf),
|
||||||
|
SOCK_NO_TIMEOUT, &remote);
|
||||||
|
if (res > 0) {
|
||||||
|
left = res;
|
||||||
|
pos = rx_buf;
|
||||||
|
} else {
|
||||||
|
return res;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
count = MIN(left, count);
|
||||||
|
memcpy(buffer, pos, count);
|
||||||
|
|
||||||
|
left -= count;
|
||||||
|
pos += count;
|
||||||
|
|
||||||
|
return count;
|
||||||
|
}
|
||||||
|
|
||||||
|
ssize_t stdio_write(const void* buffer, size_t len)
|
||||||
|
{
|
||||||
|
if (remote.port == 0) {
|
||||||
|
return -ENOTCONN;
|
||||||
|
}
|
||||||
|
if (len == 0) {
|
||||||
|
return 0;
|
||||||
|
}
|
||||||
|
|
||||||
|
return sock_udp_send(&sock, buffer, len, &remote);
|
||||||
|
}
|
Loading…
Reference in New Issue
Block a user