Change copy modes for new read/write functions in tusb_fifo.c

This commit is contained in:
Reinhard Panhuber 2021-03-02 21:52:42 +01:00
parent 3cdb82c21c
commit a1b07ae14c
7 changed files with 7 additions and 28 deletions

View File

@ -382,16 +382,6 @@ bool dcd_edpt_xfer_fifo (uint8_t rhport, uint8_t ep_addr, tu_fifo_t * ff, uint16
num_packets++; num_packets++;
} }
// Set copy mode to constant address - required since data copied to or from the hardware USB FIFO needs to be written at a constant address
if (dir == TUSB_DIR_IN)
{
tu_fifo_set_copy_mode_write(ff, TU_FIFO_COPY_CST);
}
else
{
tu_fifo_set_copy_mode_read(ff, TU_FIFO_COPY_CST);
}
ESP_LOGV(TAG, "Transfer <-> EP%i, %s, pkgs: %i, bytes: %i", ESP_LOGV(TAG, "Transfer <-> EP%i, %s, pkgs: %i, bytes: %i",
epnum, ((dir == TUSB_DIR_IN) ? "USB0.HOST (in)" : "HOST->DEV (out)"), epnum, ((dir == TUSB_DIR_IN) ? "USB0.HOST (in)" : "HOST->DEV (out)"),
num_packets, total_bytes); num_packets, total_bytes);
@ -527,7 +517,7 @@ static void receive_packet(xfer_ctl_t *xfer, /* usb_out_endpoint_t * out_ep, */
if (xfer->ff) if (xfer->ff)
{ {
// Ring buffer // Ring buffer
tu_fifo_write_n(xfer->ff, (const void *) rx_fifo, to_recv_size); tu_fifo_write_n_const_addr(xfer->ff, (const void *) rx_fifo, to_recv_size);
} }
else else
{ {
@ -583,7 +573,7 @@ static void transmit_packet(xfer_ctl_t *xfer, volatile usb_in_endpoint_t *in_ep,
if (xfer->ff) if (xfer->ff)
{ {
tu_fifo_read_n(xfer->ff, (void *) tx_fifo, to_xfer_size); tu_fifo_read_n_const_addr(xfer->ff, (void *) tx_fifo, to_xfer_size);
} }
else else
{ {

View File

@ -312,14 +312,11 @@ bool dcd_edpt_xfer_fifo (uint8_t rhport, uint8_t ep_addr, tu_fifo_t * ff, uint16
if (dir == TUSB_DIR_OUT) if (dir == TUSB_DIR_OUT)
{ {
tu_fifo_set_copy_mode_read(ff, TU_FIFO_COPY_CST);
// Enable interrupt when starting OUT transfer // Enable interrupt when starting OUT transfer
if (epnum != 0) UDP->UDP_IER |= (1 << epnum); if (epnum != 0) UDP->UDP_IER |= (1 << epnum);
} }
else else
{ {
tu_fifo_set_copy_mode_write(ff, TU_FIFO_COPY_CST);
tu_fifo_read_n(ff, (void *) &UDP->UDP_FDR[epnum], xfer_packet_len(xfer)); tu_fifo_read_n(ff, (void *) &UDP->UDP_FDR[epnum], xfer_packet_len(xfer));
// TX ready for transfer // TX ready for transfer
@ -440,7 +437,7 @@ void dcd_int_handler(uint8_t rhport)
// write to EP fifo // write to EP fifo
if (xfer->ff) if (xfer->ff)
{ {
tu_fifo_read_n(xfer->ff, (void *) &UDP->UDP_FDR[epnum], xact_len); tu_fifo_read_n_const_addr(xfer->ff, (void *) &UDP->UDP_FDR[epnum], xact_len);
} }
else else
{ {
@ -473,7 +470,7 @@ void dcd_int_handler(uint8_t rhport)
// Read from EP fifo // Read from EP fifo
if (xfer->ff) if (xfer->ff)
{ {
tu_fifo_write_n(xfer->ff, (const void *) &UDP->UDP_FDR[epnum], xact_len); tu_fifo_write_n_const_addr(xfer->ff, (const void *) &UDP->UDP_FDR[epnum], xact_len);
} }
else else
{ {

View File

@ -314,12 +314,10 @@ bool dcd_edpt_xfer_fifo (uint8_t rhport, uint8_t ep_addr, tu_fifo_t * ff, uint16
if (TUSB_DIR_IN == dir) if (TUSB_DIR_IN == dir)
{ {
tu_fifo_set_copy_mode_write(ff, TU_FIFO_COPY_INC); // For the PHY in nuc120 the source and destination pointer have to be incremented!
dcd_in_xfer(xfer, ep); dcd_in_xfer(xfer, ep);
} }
else else
{ {
tu_fifo_set_copy_mode_read(ff, TU_FIFO_COPY_INC); // For the PHY in nuc120 the source and destination pointer have to be incremented!
xfer->out_bytes_so_far = 0; xfer->out_bytes_so_far = 0;
ep->MXPLD = xfer->max_packet_size; ep->MXPLD = xfer->max_packet_size;
} }

View File

@ -320,12 +320,10 @@ bool dcd_edpt_xfer_fifo (uint8_t rhport, uint8_t ep_addr, tu_fifo_t * ff, uint16
if (TUSB_DIR_IN == dir) if (TUSB_DIR_IN == dir)
{ {
tu_fifo_set_copy_mode_write(ff, TU_FIFO_COPY_INC); // For the PHY in nuc120 the source and destination pointer have to be incremented!
dcd_in_xfer(xfer, ep); dcd_in_xfer(xfer, ep);
} }
else else
{ {
tu_fifo_set_copy_mode_read(ff, TU_FIFO_COPY_INC); // For the PHY in nuc120 the source and destination pointer have to be incremented!
xfer->out_bytes_so_far = 0; xfer->out_bytes_so_far = 0;
ep->MXPLD = xfer->max_packet_size; ep->MXPLD = xfer->max_packet_size;
} }

View File

@ -183,7 +183,7 @@ static void dcd_userEP_in_xfer(struct xfer_ctl_t *xfer, USBD_EP_T *ep)
/* provided buffers are thankfully 32-bit aligned, allowing most data to be transfered as 32-bit */ /* provided buffers are thankfully 32-bit aligned, allowing most data to be transfered as 32-bit */
if (xfer->ff) if (xfer->ff)
{ {
tu_fifo_read_n(xfer->ff, (void *) (&ep->EPDAT_BYTE), bytes_now); tu_fifo_read_n_const_addr(xfer->ff, (void *) (&ep->EPDAT_BYTE), bytes_now);
} }
else else
{ {
@ -431,12 +431,10 @@ bool dcd_edpt_xfer_fifo (uint8_t rhport, uint8_t ep_addr, tu_fifo_t * ff, uint16
if (TUSB_DIR_IN == dir) if (TUSB_DIR_IN == dir)
{ {
tu_fifo_set_copy_mode_write(ff, TU_FIFO_COPY_CST); // For the PHY in nuc505 the source and destination pointer have to be constant!
ep->EPINTEN = USBD_EPINTEN_BUFEMPTYIEN_Msk; ep->EPINTEN = USBD_EPINTEN_BUFEMPTYIEN_Msk;
} }
else else
{ {
tu_fifo_set_copy_mode_read(ff, TU_FIFO_COPY_CST); // For the PHY in nuc505 the source and destination pointer have to be constant!
xfer->out_bytes_so_far = 0; xfer->out_bytes_so_far = 0;
ep->EPINTEN = USBD_EPINTEN_RXPKIEN_Msk; ep->EPINTEN = USBD_EPINTEN_RXPKIEN_Msk;
} }
@ -659,7 +657,7 @@ void dcd_int_handler(uint8_t rhport)
/* copy the data from the PC to the previously provided buffer */ /* copy the data from the PC to the previously provided buffer */
if (xfer->ff) if (xfer->ff)
{ {
tu_fifo_write_n(xfer->ff, (const void *) &ep->EPDAT_BYTE, tu_min16(available_bytes, xfer->total_bytes - xfer->out_bytes_so_far)); tu_fifo_write_n_const_addr(xfer->ff, (const void *) &ep->EPDAT_BYTE, tu_min16(available_bytes, xfer->total_bytes - xfer->out_bytes_so_far));
} }
else else
{ {

View File

@ -105,7 +105,7 @@ bool dcd_edpt_xfer (uint8_t rhport, uint8_t ep_addr, uint8_t * buffer, uint16_t
return false; return false;
} }
// Submit a transfer where is managed by FIFO, When complete dcd_event_xfer_complete() is invoked to notify the stack // Submit a transfer where is managed by FIFO, When complete dcd_event_xfer_complete() is invoked to notify the stack - optional, however, must be listed in usbd.c
bool dcd_edpt_xfer_fifo (uint8_t rhport, uint8_t ep_addr, tu_fifo_t * ff, uint16_t total_bytes) bool dcd_edpt_xfer_fifo (uint8_t rhport, uint8_t ep_addr, tu_fifo_t * ff, uint16_t total_bytes)
{ {
(void) rhport; (void) rhport;

View File

@ -365,12 +365,10 @@ bool dcd_edpt_xfer_fifo (uint8_t rhport, uint8_t ep_addr, tu_fifo_t * ff, uint16
if(dir == TUSB_DIR_OUT) if(dir == TUSB_DIR_OUT)
{ {
tu_fifo_set_copy_mode_read(ff, TU_FIFO_COPY_INC); // For the PHY in msp430 the source and destination pointer have to be incremented!
ep_regs[BCTX] &= ~NAK; ep_regs[BCTX] &= ~NAK;
} }
else else
{ {
tu_fifo_set_copy_mode_write(ff, TU_FIFO_COPY_INC); // For the PHY in msp430 the source and destination pointer have to be incremented!
USBIEPIFG |= (1 << epnum); USBIEPIFG |= (1 << epnum);
} }