1
0
mirror of https://github.com/RIOT-OS/RIOT.git synced 2025-01-18 12:52:44 +01:00

USBUS/cdc_acm: Adapt to xmit API

This commit is contained in:
Koen Zandberg 2021-10-26 19:46:41 +02:00
parent 7d9a177f25
commit 1a0bc3d8bc
No known key found for this signature in database
GPG Key ID: BA1718B37D79F51C
2 changed files with 16 additions and 5 deletions

View File

@ -142,6 +142,16 @@ struct usbus_cdcacm_device {
usbus_cdcacm_line_state_t state; /**< Current line state */ usbus_cdcacm_line_state_t state; /**< Current line state */
event_t flush; /**< device2host forced flush event */ event_t flush; /**< device2host forced flush event */
usb_req_cdcacm_coding_t coding; /**< Current coding configuration */ usb_req_cdcacm_coding_t coding; /**< Current coding configuration */
/**
* @brief Host to device data buffer
*/
usbdev_ep_buf_t out_buf[CONFIG_USBUS_CDC_ACM_BULK_EP_SIZE];
/**
* @brief Device to host data buffer
*/
usbdev_ep_buf_t in_buf[CONFIG_USBUS_CDC_ACM_STDIO_BUF_SIZE];
}; };
/** /**

View File

@ -303,7 +303,8 @@ static int _control_handler(usbus_t *usbus, usbus_handler_t *handler,
usbus_endpoint_t *data_out = usbus_interface_find_endpoint( usbus_endpoint_t *data_out = usbus_interface_find_endpoint(
&cdcacm->iface_data, USB_EP_TYPE_BULK, USB_EP_DIR_OUT); &cdcacm->iface_data, USB_EP_TYPE_BULK, USB_EP_DIR_OUT);
assert(data_out); assert(data_out);
usbdev_ep_ready(data_out->ep, 0); usbdev_ep_xmit(data_out->ep, cdcacm->out_buf,
CONFIG_USBUS_CDC_ACM_BULK_EP_SIZE);
usbus_cdc_acm_flush(cdcacm); usbus_cdc_acm_flush(cdcacm);
} }
else { else {
@ -329,13 +330,13 @@ static void _handle_in(usbus_cdcacm_device_t *cdcacm,
unsigned old = irq_disable(); unsigned old = irq_disable();
while (!tsrb_empty(&cdcacm->tsrb)) { while (!tsrb_empty(&cdcacm->tsrb)) {
int c = tsrb_get_one(&cdcacm->tsrb); int c = tsrb_get_one(&cdcacm->tsrb);
ep->buf[cdcacm->occupied++] = (uint8_t)c; cdcacm->in_buf[cdcacm->occupied++] = (uint8_t)c;
if (cdcacm->occupied >= CONFIG_USBUS_CDC_ACM_BULK_EP_SIZE) { if (cdcacm->occupied >= CONFIG_USBUS_CDC_ACM_BULK_EP_SIZE) {
break; break;
} }
} }
irq_restore(old); irq_restore(old);
usbdev_ep_ready(ep, cdcacm->occupied); usbdev_ep_xmit(ep, cdcacm->in_buf, cdcacm->occupied);
} }
static void _transfer_handler(usbus_t *usbus, usbus_handler_t *handler, static void _transfer_handler(usbus_t *usbus, usbus_handler_t *handler,
@ -349,9 +350,9 @@ static void _transfer_handler(usbus_t *usbus, usbus_handler_t *handler,
/* Retrieve incoming data */ /* Retrieve incoming data */
usbdev_ep_get(ep, USBOPT_EP_AVAILABLE, &len, sizeof(size_t)); usbdev_ep_get(ep, USBOPT_EP_AVAILABLE, &len, sizeof(size_t));
if (len > 0) { if (len > 0) {
cdcacm->cb(cdcacm, ep->buf, len); cdcacm->cb(cdcacm, cdcacm->out_buf, len);
} }
usbdev_ep_ready(ep, 0); usbdev_ep_xmit(ep, cdcacm->out_buf, CONFIG_USBUS_CDC_ACM_BULK_EP_SIZE);
} }
if ((ep->dir == USB_EP_DIR_IN) && (ep->type == USB_EP_TYPE_BULK)) { if ((ep->dir == USB_EP_DIR_IN) && (ep->type == USB_EP_TYPE_BULK)) {
cdcacm->occupied = 0; cdcacm->occupied = 0;