1
0
mirror of https://github.com/RIOT-OS/RIOT.git synced 2025-01-17 05:32:45 +01:00

stdio_nimble: port to new interface

This commit is contained in:
Benjamin Valentin 2023-06-14 18:17:04 +02:00
parent 35ef7ca389
commit c1b6c813ae

View File

@ -39,8 +39,7 @@
#include "periph/uart.h" #include "periph/uart.h"
#endif /* IS_USED(MODULE_STDIO_NIMBLE_DEBUG) */ #endif /* IS_USED(MODULE_STDIO_NIMBLE_DEBUG) */
#include "tsrb.h" #include "stdio_base.h"
#include "isrpipe.h"
#include "stdio_nimble.h" #include "stdio_nimble.h"
#define NIMBLE_MAX_PAYLOAD MYNEWT_VAL(BLE_LL_MAX_PKT_SIZE) #define NIMBLE_MAX_PAYLOAD MYNEWT_VAL(BLE_LL_MAX_PKT_SIZE)
@ -55,10 +54,6 @@ enum {
STDIO_NIMBLE_SENDING, STDIO_NIMBLE_SENDING,
}; };
/* isrpipe for stdin */
static uint8_t _isrpipe_stdin_mem[CONFIG_STDIO_NIMBLE_STDIN_BUFSIZE];
static isrpipe_t _isrpipe_stdin = ISRPIPE_INIT(_isrpipe_stdin_mem);
/* tsrb for stdout */ /* tsrb for stdout */
static uint8_t _tsrb_stdout_mem[CONFIG_STDIO_NIMBLE_STDOUT_BUFSIZE]; static uint8_t _tsrb_stdout_mem[CONFIG_STDIO_NIMBLE_STDOUT_BUFSIZE];
static tsrb_t _tsrb_stdout = TSRB_INIT(_tsrb_stdout_mem); static tsrb_t _tsrb_stdout = TSRB_INIT(_tsrb_stdout_mem);
@ -176,11 +171,11 @@ static const struct ble_gatt_svc_def _gatt_svr_svcs[] =
static void _purge_buffer(void) static void _purge_buffer(void)
{ {
tsrb_clear(&_isrpipe_stdin.tsrb); tsrb_clear(&stdin_isrpipe.tsrb);
#if IS_USED(MODULE_SHELL) #if IS_USED(MODULE_SHELL)
/* send Ctrl-C to the shell to reset the input */ /* send Ctrl-C to the shell to reset the input */
isrpipe_write_one(&_isrpipe_stdin, '\x03'); isrpipe_write_one(&stdin_isrpipe, '\x03');
#endif #endif
tsrb_clear(&_tsrb_stdout); tsrb_clear(&_tsrb_stdout);
@ -295,12 +290,12 @@ static int gatt_svr_chr_access_stdin(
/* read sent data */ /* read sent data */
int rc = ble_hs_mbuf_to_flat(ctxt->om, _stdin_read_buf, sizeof(_stdin_read_buf), &om_len); int rc = ble_hs_mbuf_to_flat(ctxt->om, _stdin_read_buf, sizeof(_stdin_read_buf), &om_len);
isrpipe_write(&_isrpipe_stdin, _stdin_read_buf, om_len); isrpipe_write(&stdin_isrpipe, _stdin_read_buf, om_len);
return rc; return rc;
} }
void stdio_init(void) static void _init(void)
{ {
#if IS_USED(MODULE_STDIO_NIMBLE_DEBUG) #if IS_USED(MODULE_STDIO_NIMBLE_DEBUG)
uart_init(STDIO_UART_DEV, STDIO_UART_BAUDRATE, NULL, NULL); uart_init(STDIO_UART_DEV, STDIO_UART_BAUDRATE, NULL, NULL);
@ -310,30 +305,7 @@ void stdio_init(void)
_send_stdout, NULL); _send_stdout, NULL);
} }
#if IS_USED(MODULE_STDIO_AVAILABLE) static ssize_t _write(const void *buffer, size_t len)
int stdio_available(void)
{
return tsrb_avail(&_isrpipe_stdin.tsrb);
}
#endif
ssize_t stdio_read(void *buffer, size_t count)
{
/* blocks until at least one character was read */
ssize_t res = isrpipe_read(&_isrpipe_stdin, buffer, count);
#if IS_USED(MODULE_STDIO_NIMBLE_DEBUG)
unsigned state = irq_disable();
uart_write(STDIO_UART_DEV, (const uint8_t *)PREFIX_STDIN, strlen(PREFIX_STDIN));
uart_write(STDIO_UART_DEV, (const uint8_t *)buffer, res);
uart_write(STDIO_UART_DEV, (const uint8_t *)"\n", 1);
irq_restore(state);
#endif
return res;
}
ssize_t stdio_write(const void *buffer, size_t len)
{ {
unsigned state = irq_disable(); unsigned state = irq_disable();
@ -378,3 +350,5 @@ void stdio_nimble_init(void)
/* fix compilation error when using DEVELHELP=0 */ /* fix compilation error when using DEVELHELP=0 */
(void)rc; (void)rc;
} }
STDIO_PROVIDER(STDIO_NIMBLE, _init, NULL, _write)