summaryrefslogtreecommitdiff
diff options
context:
space:
mode:
authorAndrew Leech <andrew@alelec.net>2024-05-11 08:53:44 +1000
committerDamien George <damien@micropython.org>2024-05-31 19:47:55 +1000
commitc11efc74ee72021987a75f1b17d1375d592db1a5 (patch)
treed6f9d6e43dedce6ba224223c2d20248321cf18ad
parent2d33071b171e2de4a3e04f48d1f19b5bbe87c663 (diff)
samd/mphalport: Refactor to use shared TinyUSB CDC functions.
Signed-off-by: Andrew Leech <andrew@alelec.net>
-rw-r--r--ports/samd/mphalport.c80
-rw-r--r--ports/samd/mphalport.h1
2 files changed, 7 insertions, 74 deletions
diff --git a/ports/samd/mphalport.c b/ports/samd/mphalport.c
index 3fc687590..80904804c 100644
--- a/ports/samd/mphalport.c
+++ b/ports/samd/mphalport.c
@@ -30,6 +30,7 @@
#include "py/stream.h"
#include "shared/runtime/interrupt_char.h"
#include "shared/tinyusb/mp_usbd.h"
+#include "shared/tinyusb/mp_usbd_cdc.h"
#include "extmod/misc.h"
#include "samd_soc.h"
#include "tusb.h"
@@ -51,48 +52,6 @@ ringbuf_t stdin_ringbuf = { stdin_ringbuf_array, sizeof(stdin_ringbuf_array), 0,
mp_usbd_task(); \
} while (0)
-uint8_t cdc_itf_pending; // keep track of cdc interfaces which need attention to poll
-
-void poll_cdc_interfaces(void) {
- // any CDC interfaces left to poll?
- if (cdc_itf_pending && ringbuf_free(&stdin_ringbuf)) {
- for (uint8_t itf = 0; itf < 8; ++itf) {
- if (cdc_itf_pending & (1 << itf)) {
- tud_cdc_rx_cb(itf);
- if (!cdc_itf_pending) {
- break;
- }
- }
- }
- }
-}
-
-void tud_cdc_rx_cb(uint8_t itf) {
- // consume pending USB data immediately to free usb buffer and keep the endpoint from stalling.
- // in case the ringbuffer is full, mark the CDC interface that need attention later on for polling
- cdc_itf_pending &= ~(1 << itf);
- for (uint32_t bytes_avail = tud_cdc_n_available(itf); bytes_avail > 0; --bytes_avail) {
- if (ringbuf_free(&stdin_ringbuf)) {
- int data_char = tud_cdc_read_char();
- #if MICROPY_KBD_EXCEPTION
- if (data_char == mp_interrupt_char) {
- // Clear the ring buffer
- stdin_ringbuf.iget = stdin_ringbuf.iput = 0;
- // and stop
- mp_sched_keyboard_interrupt();
- } else {
- ringbuf_put(&stdin_ringbuf, data_char);
- }
- #else
- ringbuf_put(&stdin_ringbuf, data_char);
- #endif
- } else {
- cdc_itf_pending |= (1 << itf);
- return;
- }
- }
-}
-
void mp_hal_set_pin_mux(mp_hal_pin_obj_t pin, uint8_t mux) {
int pin_grp = pin / 32;
int port_grp = (pin % 32) / 2;
@@ -165,16 +124,7 @@ uint64_t mp_hal_ticks_us_64(void) {
uintptr_t mp_hal_stdio_poll(uintptr_t poll_flags) {
uintptr_t ret = 0;
-
- poll_cdc_interfaces();
- if ((poll_flags & MP_STREAM_POLL_RD) && ringbuf_peek(&stdin_ringbuf) != -1) {
- ret |= MP_STREAM_POLL_RD;
- }
-
- if ((poll_flags & MP_STREAM_POLL_WR) && tud_cdc_connected() && tud_cdc_write_available() > 0) {
- ret |= MP_STREAM_POLL_WR;
- }
-
+ ret |= mp_usbd_cdc_poll_interfaces(poll_flags);
#if MICROPY_PY_OS_DUPTERM
ret |= mp_os_dupterm_poll(poll_flags);
#endif
@@ -184,7 +134,7 @@ uintptr_t mp_hal_stdio_poll(uintptr_t poll_flags) {
int mp_hal_stdin_rx_chr(void) {
for (;;) {
- poll_cdc_interfaces();
+ mp_usbd_cdc_poll_interfaces(0);
int c = ringbuf_get(&stdin_ringbuf);
if (c != -1) {
return c;
@@ -203,28 +153,10 @@ int mp_hal_stdin_rx_chr(void) {
mp_uint_t mp_hal_stdout_tx_strn(const char *str, mp_uint_t len) {
mp_uint_t ret = len;
bool did_write = false;
- if (tud_cdc_connected()) {
- size_t i = 0;
- while (i < len) {
- uint32_t n = len - i;
- if (n > CFG_TUD_CDC_EP_BUFSIZE) {
- n = CFG_TUD_CDC_EP_BUFSIZE;
- }
- int timeout = 0;
- // Wait with a max of USC_CDC_TIMEOUT ms
- while (n > tud_cdc_write_available() && timeout++ < MICROPY_HW_USB_CDC_TX_TIMEOUT) {
- MICROPY_EVENT_POLL_HOOK_WITH_USB;
- }
- if (timeout >= MICROPY_HW_USB_CDC_TX_TIMEOUT) {
- ret = i;
- break;
- }
- uint32_t n2 = tud_cdc_write(str + i, n);
- tud_cdc_write_flush();
- i += n2;
- }
- ret = MIN(i, ret);
+ mp_uint_t cdc_res = mp_usbd_cdc_tx_strn(str, len);
+ if (cdc_res > 0) {
did_write = true;
+ ret = MIN(cdc_res, ret);
}
#if MICROPY_PY_OS_DUPTERM
int dupterm_res = mp_os_dupterm_tx_strn(str, len);
diff --git a/ports/samd/mphalport.h b/ports/samd/mphalport.h
index 48f047066..ee1ebf7ae 100644
--- a/ports/samd/mphalport.h
+++ b/ports/samd/mphalport.h
@@ -44,6 +44,7 @@
#define MICROPY_HW_USB_CDC_TX_TIMEOUT (500)
extern int mp_interrupt_char;
+extern ringbuf_t stdin_ringbuf;
extern volatile uint32_t systick_ms;
uint64_t mp_hal_ticks_us_64(void);