1
0
mirror of https://github.com/RIOT-OS/RIOT.git synced 2025-01-17 04:52:59 +01:00

usbdev_mock: Adapt to xmit API

Includes the adaptations needed in the test application
This commit is contained in:
Koen Zandberg 2021-10-26 19:41:38 +02:00
parent 597f1d19aa
commit f8e7e2f557
No known key found for this signature in database
GPG Key ID: BA1718B37D79F51C
3 changed files with 22 additions and 20 deletions

View File

@ -43,7 +43,8 @@ typedef struct {
usbdev_ep_t ep; /**< Generic endpoint struct */ usbdev_ep_t ep; /**< Generic endpoint struct */
usbdev_mock_ep_state_t state; /**< Endpoint state */ usbdev_mock_ep_state_t state; /**< Endpoint state */
size_t available; /**< Bytes available in the buffer */ size_t available; /**< Bytes available in the buffer */
uint8_t *buf_start; /**< Start location of the buffer */ uint8_t *target_buf; /**< Buffer as passed by @ref usbdev_ep_xmit */
uint8_t *buf; /**< Internal mock buffer pointer */
} usbdev_mock_ep_t; } usbdev_mock_ep_t;
/** /**

View File

@ -75,16 +75,15 @@ usbdev_ep_t *_new_ep(usbdev_t *dev, usb_ep_type_t type, usb_ep_dir_t dir,
res = &testdev->out[0]; res = &testdev->out[0];
res->ep.num = 0; res->ep.num = 0;
res->ep.buf = _out_buf; res->buf = _out_buf;
} }
else { else {
res = &testdev->in[0]; res = &testdev->in[0];
res->ep.num = 0; res->ep.num = 0;
res->ep.buf = _in_buf; res->buf = _in_buf;
} }
} }
if (res) { if (res) {
res->buf_start = res->ep.buf;
res->state = EP_STATE_READY; res->state = EP_STATE_READY;
res->available = 0; res->available = 0;
res->ep.len = buf_len; res->ep.len = buf_len;
@ -190,26 +189,30 @@ void _ep_esr(usbdev_ep_t *ep)
ep->num, ep->dir == USB_EP_DIR_OUT ? "out" : "in"); ep->num, ep->dir == USB_EP_DIR_OUT ? "out" : "in");
usbdev_mock_ep_t *mock_ep = (usbdev_mock_ep_t *)ep; usbdev_mock_ep_t *mock_ep = (usbdev_mock_ep_t *)ep;
if (mock_ep->ep.dir == USB_EP_DIR_OUT) {
memcpy(mock_ep->target_buf, mock_ep->buf, mock_ep->available);
}
if (mock_ep->state == EP_STATE_DATA_AVAILABLE) { if (mock_ep->state == EP_STATE_DATA_AVAILABLE) {
dev->ep_esr_cb(dev, mock_ep); dev->ep_esr_cb(dev, mock_ep);
mock_ep->state = EP_STATE_READY; mock_ep->state = EP_STATE_READY;
} }
} }
int _ready(usbdev_ep_t *ep, size_t len) int _xmit(usbdev_ep_t *ep, uint8_t *buf, size_t len)
{ {
DEBUG("[mock]: Readying EP %u, dir %s, len %u\n", DEBUG("[mock]: Readying EP %u, dir %s, len %u\n",
ep->num, ep->dir == USB_EP_DIR_OUT ? "out" : "in", (unsigned)len); ep->num, ep->dir == USB_EP_DIR_OUT ? "out" : "in", (unsigned)len);
if (ep->num == 0) { if (ep->num == 0) {
usbdev_mock_t *usbdev_mock = _ep2dev(ep); usbdev_mock_t *usbdev_mock = _ep2dev(ep);
usbdev_mock_ep_t *mock_ep = (usbdev_mock_ep_t *)ep; usbdev_mock_ep_t *mock_ep = (usbdev_mock_ep_t *)ep;
mock_ep->target_buf = buf;
if (ep->dir == USB_EP_DIR_IN) {
memcpy(mock_ep->buf + mock_ep->available, mock_ep->target_buf, len);
mock_ep->available = len; mock_ep->available = len;
mock_ep->ep.buf += len; }
mock_ep->state = EP_STATE_DATA_AVAILABLE; mock_ep->state = EP_STATE_DATA_AVAILABLE;
usbdev_mock->ready_cb(usbdev_mock, (usbdev_mock_ep_t *)ep, len); usbdev_mock->ready_cb(usbdev_mock, (usbdev_mock_ep_t *)ep, len);
} }
return 0; return 0;
} }
@ -224,5 +227,5 @@ static const usbdev_driver_t testdriver = {
.ep_get = _ep_get, .ep_get = _ep_get,
.ep_set = _ep_set, .ep_set = _ep_set,
.ep_esr = _ep_esr, .ep_esr = _ep_esr,
.ready = _ready, .xmit = _xmit,
}; };

View File

@ -146,7 +146,7 @@ static void _test_sequence(usbdev_mock_t *dev)
case TESTPHASE_RESET: case TESTPHASE_RESET:
next_phase = TESTPHASE_REQ_DEV_INIT; next_phase = TESTPHASE_REQ_DEV_INIT;
DEBUG("[test]: Requesting device descriptor\n"); DEBUG("[test]: Requesting device descriptor\n");
_build_conf_req(dev->out[0].ep.buf, 8); /* initial config request */ _build_conf_req(dev->out[0].buf, 8); /* initial config request */
dev->req_len = 8; dev->req_len = 8;
dev->out[0].state = EP_STATE_DATA_AVAILABLE; dev->out[0].state = EP_STATE_DATA_AVAILABLE;
dev->out[0].available = 8; dev->out[0].available = 8;
@ -157,7 +157,7 @@ static void _test_sequence(usbdev_mock_t *dev)
DEBUG("[test]: validating device descriptor\n"); DEBUG("[test]: validating device descriptor\n");
TEST_ASSERT_EQUAL_INT(dev->in[0].available, 8); TEST_ASSERT_EQUAL_INT(dev->in[0].available, 8);
_validate_device_desc_init( _validate_device_desc_init(
(usb_descriptor_device_t *)dev->in[0].buf_start); (usb_descriptor_device_t *)dev->in[0].buf);
/* Reset device */ /* Reset device */
DEBUG("[test]: Signalling second USB reset condition\n"); DEBUG("[test]: Signalling second USB reset condition\n");
dev->usbdev.cb(&dev->usbdev, USBDEV_EVENT_RESET); dev->usbdev.cb(&dev->usbdev, USBDEV_EVENT_RESET);
@ -166,7 +166,7 @@ static void _test_sequence(usbdev_mock_t *dev)
case TESTPHASE_RESET2: case TESTPHASE_RESET2:
next_phase = TESTPHASE_SET_ADDRESS; next_phase = TESTPHASE_SET_ADDRESS;
DEBUG("[test]: Set USB address\n"); DEBUG("[test]: Set USB address\n");
_build_set_addr(dev->out[0].ep.buf); _build_set_addr(dev->out[0].buf);
dev->req_len = 0; dev->req_len = 0;
dev->out[0].state = EP_STATE_DATA_AVAILABLE; dev->out[0].state = EP_STATE_DATA_AVAILABLE;
dev->out[0].available = 8; dev->out[0].available = 8;
@ -175,7 +175,7 @@ static void _test_sequence(usbdev_mock_t *dev)
case TESTPHASE_SET_ADDRESS: case TESTPHASE_SET_ADDRESS:
next_phase = TESTPHASE_REQ_DEV_FULL; next_phase = TESTPHASE_REQ_DEV_FULL;
DEBUG("[test]: Requesting full device descriptor\n"); DEBUG("[test]: Requesting full device descriptor\n");
_build_conf_req(dev->out[0].ep.buf, _build_conf_req(dev->out[0].buf,
sizeof(usb_descriptor_device_t)); sizeof(usb_descriptor_device_t));
dev->req_len = sizeof(usb_descriptor_device_t); dev->req_len = sizeof(usb_descriptor_device_t);
dev->out[0].state = EP_STATE_DATA_AVAILABLE; dev->out[0].state = EP_STATE_DATA_AVAILABLE;
@ -187,7 +187,7 @@ static void _test_sequence(usbdev_mock_t *dev)
sizeof(usb_descriptor_device_t)); sizeof(usb_descriptor_device_t));
DEBUG("[test]: Validating full descriptor\n"); DEBUG("[test]: Validating full descriptor\n");
_validate_device_desc_init( _validate_device_desc_init(
(usb_descriptor_device_t *)dev->in[0].buf_start); (usb_descriptor_device_t *)dev->in[0].buf);
next_phase = TESTPHASE_FINAL; next_phase = TESTPHASE_FINAL;
dev->usbdev.cb(&dev->usbdev, USBDEV_EVENT_ESR); dev->usbdev.cb(&dev->usbdev, USBDEV_EVENT_ESR);
@ -261,8 +261,6 @@ static void _handle_data(usbdev_mock_t *dev, usbdev_mock_ep_t *ep, size_t len)
if (ep->available == dev->req_len) { if (ep->available == dev->req_len) {
DEBUG("[data]: Full data received from stack\n"); DEBUG("[data]: Full data received from stack\n");
req_phase = TEST_REQ_PHASE_OUTACK; req_phase = TEST_REQ_PHASE_OUTACK;
/* Reset buffer ptr to the start */
ep->ep.buf = ep->buf_start;
} }
else { else {
DEBUG("[data]: Expecting more data from stack: %u/%u\n", DEBUG("[data]: Expecting more data from stack: %u/%u\n",