EFM32: Finishes USB naming fixup. Still some missing initialization logic
This commit is contained in:
parent
7358c3c641
commit
db12ac1f14
@ -77,16 +77,16 @@
|
|||||||
*******************************************************************************************************************************/
|
*******************************************************************************************************************************/
|
||||||
/* General definitions */
|
/* General definitions */
|
||||||
|
|
||||||
#define USB_EPTYPE_CTRL (0) /* Control */
|
#define EFM32_USB_EPTYPE_CTRL (0) /* Control */
|
||||||
#define USB_EPTYPE_ISOC (1) /* Isochronous */
|
#define EFM32_USB_EPTYPE_ISOC (1) /* Isochronous */
|
||||||
#define USB_EPTYPE_BULK (2) /* Bulk */
|
#define EFM32_USB_EPTYPE_BULK (2) /* Bulk */
|
||||||
#define USB_EPTYPE_INTR (3) /* Interrupt */
|
#define EFM32_USB_EPTYPE_INTR (3) /* Interrupt */
|
||||||
|
|
||||||
#define USB_PID_DATA0 (0)
|
#define EFM32_USB_PID_DATA0 (0)
|
||||||
#define USB_PID_DATA2 (1)
|
#define EFM32_USB_PID_DATA2 (1)
|
||||||
#define USB_PID_DATA1 (2)
|
#define EFM32_USB_PID_DATA1 (2)
|
||||||
#define USB_PID_MDATA (3) /* Non-control */
|
#define EFM32_USB_PID_MDATA (3) /* Non-control */
|
||||||
#define USB_PID_SETUP (3) /* Control */
|
#define EFM32_USB_PID_SETUP (3) /* Control */
|
||||||
|
|
||||||
/* USB Register Offsets ********************************************************************************************************/
|
/* USB Register Offsets ********************************************************************************************************/
|
||||||
|
|
||||||
@ -936,6 +936,7 @@
|
|||||||
#define USB_GRSTCTL_TXFNUM_F4 (_USB_GRSTCTL_TXFNUM_F4 << 6) /* Shifted mode F4 for USB_GRSTCTL */
|
#define USB_GRSTCTL_TXFNUM_F4 (_USB_GRSTCTL_TXFNUM_F4 << 6) /* Shifted mode F4 for USB_GRSTCTL */
|
||||||
#define USB_GRSTCTL_TXFNUM_F5 (_USB_GRSTCTL_TXFNUM_F5 << 6) /* Shifted mode F5 for USB_GRSTCTL */
|
#define USB_GRSTCTL_TXFNUM_F5 (_USB_GRSTCTL_TXFNUM_F5 << 6) /* Shifted mode F5 for USB_GRSTCTL */
|
||||||
#define USB_GRSTCTL_TXFNUM_F6 (_USB_GRSTCTL_TXFNUM_F6 << 6) /* Shifted mode F6 for USB_GRSTCTL */
|
#define USB_GRSTCTL_TXFNUM_F6 (_USB_GRSTCTL_TXFNUM_F6 << 6) /* Shifted mode F6 for USB_GRSTCTL */
|
||||||
|
#define USB_GRSTCTL_TXFNUM_F(n) ((uint32_t)(n) << 6) /* TXFIFO n flush, n=0-15 */
|
||||||
#define USB_GRSTCTL_TXFNUM_FALL (_USB_GRSTCTL_TXFNUM_FALL << 6) /* Shifted mode FALL for USB_GRSTCTL */
|
#define USB_GRSTCTL_TXFNUM_FALL (_USB_GRSTCTL_TXFNUM_FALL << 6) /* Shifted mode FALL for USB_GRSTCTL */
|
||||||
#define USB_GRSTCTL_DMAREQ (0x1UL << 30) /* DMA Request Signal (host and device) */
|
#define USB_GRSTCTL_DMAREQ (0x1UL << 30) /* DMA Request Signal (host and device) */
|
||||||
#define _USB_GRSTCTL_DMAREQ_SHIFT 30 /* Shift value for USB_DMAREQ */
|
#define _USB_GRSTCTL_DMAREQ_SHIFT 30 /* Shift value for USB_DMAREQ */
|
||||||
@ -1577,6 +1578,7 @@
|
|||||||
#define _USB_HAINT_HAINT_MASK 0x3FFFUL /* Bit mask for USB_HAINT */
|
#define _USB_HAINT_HAINT_MASK 0x3FFFUL /* Bit mask for USB_HAINT */
|
||||||
#define _USB_HAINT_HAINT_DEFAULT 0x00000000UL /* Mode DEFAULT for USB_HAINT */
|
#define _USB_HAINT_HAINT_DEFAULT 0x00000000UL /* Mode DEFAULT for USB_HAINT */
|
||||||
#define USB_HAINT_HAINT_DEFAULT (_USB_HAINT_HAINT_DEFAULT << 0) /* Shifted mode DEFAULT for USB_HAINT */
|
#define USB_HAINT_HAINT_DEFAULT (_USB_HAINT_HAINT_DEFAULT << 0) /* Shifted mode DEFAULT for USB_HAINT */
|
||||||
|
#define USB_HAINT(n) (1UL << ((n) + _USB_HAINT_HAINT_SHIFT)) /* Channel n interrupt */
|
||||||
|
|
||||||
/* Bit fields for USB HAINTMSK */
|
/* Bit fields for USB HAINTMSK */
|
||||||
|
|
||||||
@ -2330,6 +2332,7 @@
|
|||||||
#define _USB_DIEPEMPMSK_DIEPEMPMSK_MASK 0xFFFFUL /* Bit mask for USB_DIEPEMPMSK */
|
#define _USB_DIEPEMPMSK_DIEPEMPMSK_MASK 0xFFFFUL /* Bit mask for USB_DIEPEMPMSK */
|
||||||
#define _USB_DIEPEMPMSK_DIEPEMPMSK_DEFAULT 0x00000000UL /* Mode DEFAULT for USB_DIEPEMPMSK */
|
#define _USB_DIEPEMPMSK_DIEPEMPMSK_DEFAULT 0x00000000UL /* Mode DEFAULT for USB_DIEPEMPMSK */
|
||||||
#define USB_DIEPEMPMSK_DIEPEMPMSK_DEFAULT (_USB_DIEPEMPMSK_DIEPEMPMSK_DEFAULT << 0) /* Shifted mode DEFAULT for USB_DIEPEMPMSK */
|
#define USB_DIEPEMPMSK_DIEPEMPMSK_DEFAULT (_USB_DIEPEMPMSK_DIEPEMPMSK_DEFAULT << 0) /* Shifted mode DEFAULT for USB_DIEPEMPMSK */
|
||||||
|
#define USB_DIEPEMPMSK(n) (1UL << ((n) + _USB_DIEPEMPMSK_DIEPEMPMSK_SHIFT))
|
||||||
|
|
||||||
/* Bit fields for USB DIEP0CTL */
|
/* Bit fields for USB DIEP0CTL */
|
||||||
|
|
||||||
|
@ -73,7 +73,7 @@ extern "C"
|
|||||||
#endif
|
#endif
|
||||||
|
|
||||||
/*******************************************************************************
|
/*******************************************************************************
|
||||||
* Name: efm32_otgfshost_initialize
|
* Name: efm32_usbhost_initialize
|
||||||
*
|
*
|
||||||
* Description:
|
* Description:
|
||||||
* Initialize USB host device controller hardware.
|
* Initialize USB host device controller hardware.
|
||||||
@ -99,7 +99,27 @@ extern "C"
|
|||||||
|
|
||||||
#ifdef CONFIG_USBHOST
|
#ifdef CONFIG_USBHOST
|
||||||
struct usbhost_connection_s;
|
struct usbhost_connection_s;
|
||||||
FAR struct usbhost_connection_s *efm32_otgfshost_initialize(int controller);
|
FAR struct usbhost_connection_s *efm32_usbhost_initialize(int controller);
|
||||||
|
#endif
|
||||||
|
|
||||||
|
/***********************************************************************************
|
||||||
|
* Name: efm32_usbhost_vbusdrive
|
||||||
|
*
|
||||||
|
* Description:
|
||||||
|
* Enable/disable driving of VBUS 5V output. This function must be provided be
|
||||||
|
* each platform that implements the EFM32 OTG FS host interface
|
||||||
|
*
|
||||||
|
* Input Parameters:
|
||||||
|
* iface - For future growth to handle multiple USB host interface. Should be zero.
|
||||||
|
* enable - true: enable VBUS power; false: disable VBUS power
|
||||||
|
*
|
||||||
|
* Returned Value:
|
||||||
|
* None
|
||||||
|
*
|
||||||
|
***********************************************************************************/
|
||||||
|
|
||||||
|
#ifdef CONFIG_USBHOST
|
||||||
|
void efm32_usbhost_vbusdrive(int iface, bool enable);
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
/************************************************************************************
|
/************************************************************************************
|
||||||
@ -113,7 +133,10 @@ FAR struct usbhost_connection_s *efm32_otgfshost_initialize(int controller);
|
|||||||
*
|
*
|
||||||
************************************************************************************/
|
************************************************************************************/
|
||||||
|
|
||||||
|
#ifdef CONFIG_USBDEV
|
||||||
|
struct usbdev_s;
|
||||||
void efm32_usbsuspend(FAR struct usbdev_s *dev, bool resume);
|
void efm32_usbsuspend(FAR struct usbdev_s *dev, bool resume);
|
||||||
|
#endif
|
||||||
|
|
||||||
#undef EXTERN
|
#undef EXTERN
|
||||||
#if defined(__cplusplus)
|
#if defined(__cplusplus)
|
||||||
|
@ -1035,7 +1035,7 @@ static void efm32_txfifo_write(FAR struct efm32_ep_s *privep,
|
|||||||
|
|
||||||
/* Get the TxFIFO for this endpoint (same as the endpoint number) */
|
/* Get the TxFIFO for this endpoint (same as the endpoint number) */
|
||||||
|
|
||||||
regaddr = EFM32_USB_DFIFO_DEP(privep->epphy);
|
regaddr = EFM32_USB_FIFO_BASE(privep->epphy);
|
||||||
|
|
||||||
/* Then transfer each word to the TxFIFO */
|
/* Then transfer each word to the TxFIFO */
|
||||||
|
|
||||||
@ -1309,7 +1309,7 @@ static void efm32_epin_request(FAR struct efm32_usbdev_s *priv,
|
|||||||
* n: n words available
|
* n: n words available
|
||||||
*/
|
*/
|
||||||
|
|
||||||
regaddr = EFM32_USB_DTXFSTS(privep->epphy);
|
regaddr = EFM32_USB_DIEPTXFSTS(privep->epphy);
|
||||||
|
|
||||||
/* Check for space in the TxFIFO. If space in the TxFIFO is not
|
/* Check for space in the TxFIFO. If space in the TxFIFO is not
|
||||||
* available, then set up an interrupt to resume the transfer when
|
* available, then set up an interrupt to resume the transfer when
|
||||||
@ -1394,7 +1394,7 @@ static void efm32_rxfifo_read(FAR struct efm32_ep_s *privep,
|
|||||||
* we might as well use the addess associated with EP0.
|
* we might as well use the addess associated with EP0.
|
||||||
*/
|
*/
|
||||||
|
|
||||||
regaddr = EFM32_USB_DFIFO_DEP(EP0);
|
regaddr = EFM32_USB_FIFO_BASE(EP0);
|
||||||
|
|
||||||
/* Read 32-bits and write 4 x 8-bits at time (to avoid unaligned accesses) */
|
/* Read 32-bits and write 4 x 8-bits at time (to avoid unaligned accesses) */
|
||||||
|
|
||||||
@ -1435,10 +1435,10 @@ static void efm32_rxfifo_discard(FAR struct efm32_ep_s *privep, int len)
|
|||||||
int i;
|
int i;
|
||||||
|
|
||||||
/* Get the address of the RxFIFO Note: there is only one RxFIFO so
|
/* Get the address of the RxFIFO Note: there is only one RxFIFO so
|
||||||
* we might as well use the addess associated with EP0.
|
* we might as well use the address associated with EP0.
|
||||||
*/
|
*/
|
||||||
|
|
||||||
regaddr = EFM32_USB_DFIFO_DEP(EP0);
|
regaddr = EFM32_USB_FIFO_BASE(EP0);
|
||||||
|
|
||||||
/* Read 32-bits at time */
|
/* Read 32-bits at time */
|
||||||
|
|
||||||
@ -1790,7 +1790,7 @@ static void efm32_ep_flush(struct efm32_ep_s *privep)
|
|||||||
{
|
{
|
||||||
if (privep->isin)
|
if (privep->isin)
|
||||||
{
|
{
|
||||||
efm32_txfifo_flush(USB_GRSTCTL_TXFNUM_D(privep->epphy));
|
efm32_txfifo_flush(USB_GRSTCTL_TXFNUM_F(privep->epphy));
|
||||||
}
|
}
|
||||||
else
|
else
|
||||||
{
|
{
|
||||||
@ -1954,7 +1954,7 @@ static void efm32_usbreset(struct efm32_usbdev_s *priv)
|
|||||||
|
|
||||||
/* Flush the EP0 Tx FIFO */
|
/* Flush the EP0 Tx FIFO */
|
||||||
|
|
||||||
efm32_txfifo_flush(USB_GRSTCTL_TXFNUM_D(EP0));
|
efm32_txfifo_flush(USB_GRSTCTL_TXFNUM_F(EP0));
|
||||||
|
|
||||||
/* Tell the class driver that we are disconnected. The class
|
/* Tell the class driver that we are disconnected. The class
|
||||||
* driver should then accept any new configurations.
|
* driver should then accept any new configurations.
|
||||||
@ -4156,7 +4156,7 @@ static void efm32_epin_disable(FAR struct efm32_ep_s *privep)
|
|||||||
|
|
||||||
/* Flush any data remaining in the TxFIFO */
|
/* Flush any data remaining in the TxFIFO */
|
||||||
|
|
||||||
efm32_txfifo_flush(USB_GRSTCTL_TXFNUM_D(privep->epphy));
|
efm32_txfifo_flush(USB_GRSTCTL_TXFNUM_F(privep->epphy));
|
||||||
|
|
||||||
/* Disable endpoint interrupts */
|
/* Disable endpoint interrupts */
|
||||||
|
|
||||||
|
@ -97,12 +97,6 @@
|
|||||||
* packets. Depends on CONFIG_DEBUG.
|
* packets. Depends on CONFIG_DEBUG.
|
||||||
*/
|
*/
|
||||||
|
|
||||||
/* Pre-requisites (partial) */
|
|
||||||
|
|
||||||
#ifndef CONFIG_EFM32_SYSCFG
|
|
||||||
# error "CONFIG_EFM32_SYSCFG is required"
|
|
||||||
#endif
|
|
||||||
|
|
||||||
/* Default RxFIFO size */
|
/* Default RxFIFO size */
|
||||||
|
|
||||||
#ifndef CONFIG_EFM32_OTGFS_RXFIFO_SIZE
|
#ifndef CONFIG_EFM32_OTGFS_RXFIFO_SIZE
|
||||||
@ -206,7 +200,7 @@ struct efm32_chan_s
|
|||||||
volatile uint8_t result; /* The result of the transfer */
|
volatile uint8_t result; /* The result of the transfer */
|
||||||
volatile uint8_t chreason; /* Channel halt reason. See enum efm32_chreason_e */
|
volatile uint8_t chreason; /* Channel halt reason. See enum efm32_chreason_e */
|
||||||
uint8_t epno; /* Device endpoint number (0-127) */
|
uint8_t epno; /* Device endpoint number (0-127) */
|
||||||
uint8_t eptype; /* See USB_EPTYPE_* definitions */
|
uint8_t eptype; /* See EFM32_USB_EPTYPE_* definitions */
|
||||||
uint8_t pid; /* Data PID */
|
uint8_t pid; /* Data PID */
|
||||||
uint8_t npackets; /* Number of packets (for data toggle) */
|
uint8_t npackets; /* Number of packets (for data toggle) */
|
||||||
bool inuse; /* True: This channel is "in use" */
|
bool inuse; /* True: This channel is "in use" */
|
||||||
@ -710,8 +704,8 @@ static void efm32_chan_configure(FAR struct efm32_usbhost_s *priv, int chidx)
|
|||||||
|
|
||||||
switch (priv->chan[chidx].eptype)
|
switch (priv->chan[chidx].eptype)
|
||||||
{
|
{
|
||||||
case USB_EPTYPE_CTRL:
|
case EFM32_USB_EPTYPE_CTRL:
|
||||||
case USB_EPTYPE_BULK:
|
case EFM32_USB_EPTYPE_BULK:
|
||||||
{
|
{
|
||||||
#ifdef HAVE_USBHOST_TRACE_VERBOSE
|
#ifdef HAVE_USBHOST_TRACE_VERBOSE
|
||||||
uint16_t intrace;
|
uint16_t intrace;
|
||||||
@ -719,7 +713,7 @@ static void efm32_chan_configure(FAR struct efm32_usbhost_s *priv, int chidx)
|
|||||||
|
|
||||||
/* Determine the definitive trace ID to use below */
|
/* Determine the definitive trace ID to use below */
|
||||||
|
|
||||||
if (priv->chan[chidx].eptype == USB_EPTYPE_CTRL)
|
if (priv->chan[chidx].eptype == EFM32_USB_EPTYPE_CTRL)
|
||||||
{
|
{
|
||||||
intrace = OTGFS_VTRACE2_CHANCONF_CTRL_IN;
|
intrace = OTGFS_VTRACE2_CHANCONF_CTRL_IN;
|
||||||
outtrace = OTGFS_VTRACE2_CHANCONF_CTRL_OUT;
|
outtrace = OTGFS_VTRACE2_CHANCONF_CTRL_OUT;
|
||||||
@ -751,7 +745,7 @@ static void efm32_chan_configure(FAR struct efm32_usbhost_s *priv, int chidx)
|
|||||||
}
|
}
|
||||||
break;
|
break;
|
||||||
|
|
||||||
case USB_EPTYPE_INTR:
|
case EFM32_USB_EPTYPE_INTR:
|
||||||
{
|
{
|
||||||
/* Interrupts required for INTR endpoints */
|
/* Interrupts required for INTR endpoints */
|
||||||
|
|
||||||
@ -777,7 +771,7 @@ static void efm32_chan_configure(FAR struct efm32_usbhost_s *priv, int chidx)
|
|||||||
}
|
}
|
||||||
break;
|
break;
|
||||||
|
|
||||||
case USB_EPTYPE_ISOC:
|
case EFM32_USB_EPTYPE_ISOC:
|
||||||
{
|
{
|
||||||
/* Interrupts required for ISOC endpoints */
|
/* Interrupts required for ISOC endpoints */
|
||||||
|
|
||||||
@ -836,14 +830,14 @@ static void efm32_chan_configure(FAR struct efm32_usbhost_s *priv, int chidx)
|
|||||||
|
|
||||||
/* Special case settings for INTR endpoints */
|
/* Special case settings for INTR endpoints */
|
||||||
|
|
||||||
if (priv->chan[chidx].eptype == USB_EPTYPE_INTR)
|
if (priv->chan[chidx].eptype == EFM32_USB_EPTYPE_INTR)
|
||||||
{
|
{
|
||||||
regval |= USB_HC_CHAR_ODDFRM;
|
regval |= USB_HC_CHAR_ODDFRM;
|
||||||
}
|
}
|
||||||
|
|
||||||
/* Write the channel configuration */
|
/* Write the channel configuration */
|
||||||
|
|
||||||
efm32_putreg(EFM32_USB_HCCHAR(chidx), regval);
|
efm32_putreg(EFM32_USB_HCn_CHAR(chidx), regval);
|
||||||
}
|
}
|
||||||
|
|
||||||
/*******************************************************************************
|
/*******************************************************************************
|
||||||
@ -880,7 +874,7 @@ static void efm32_chan_halt(FAR struct efm32_usbhost_s *priv, int chidx,
|
|||||||
* USB."
|
* USB."
|
||||||
*/
|
*/
|
||||||
|
|
||||||
hcchar = efm32_getreg(EFM32_USB_HCCHAR(chidx));
|
hcchar = efm32_getreg(EFM32_USB_HCn_CHAR(chidx));
|
||||||
hcchar |= (USB_HC_CHAR_CHDIS | USB_HC_CHAR_CHENA);
|
hcchar |= (USB_HC_CHAR_CHDIS | USB_HC_CHAR_CHENA);
|
||||||
|
|
||||||
/* Get the endpoint type from the HCCHAR register */
|
/* Get the endpoint type from the HCCHAR register */
|
||||||
@ -902,13 +896,13 @@ static void efm32_chan_halt(FAR struct efm32_usbhost_s *priv, int chidx,
|
|||||||
{
|
{
|
||||||
/* Get the number of words available in the non-periodic Tx FIFO. */
|
/* Get the number of words available in the non-periodic Tx FIFO. */
|
||||||
|
|
||||||
avail = efm32_getreg(EFM32_USB_HNPTXSTS) & _USB_HNPTXSTS_NPTXFSAV_MASK;
|
avail = efm32_getreg(EFM32_USB_GNPTXSTS) & _USB_GNPTXSTS_NPTXFSPCAVAIL_MASK;
|
||||||
}
|
}
|
||||||
else /* if (eptype == USB_HCCHAR_EPTYP_ISOC || eptype == USB_HC_CHAR_EPTYPE_INT) */
|
else /* if (eptype == USB_HCCHAR_EPTYP_ISOC || eptype == USB_HC_CHAR_EPTYPE_INT) */
|
||||||
{
|
{
|
||||||
/* Get the number of words available in the non-periodic Tx FIFO. */
|
/* Get the number of words available in the non-periodic Tx FIFO. */
|
||||||
|
|
||||||
avail = efm32_getreg(EFM32_USB_HPTXSTS) & _USB_HPTXSTS_PTXFSAVL_MASK;
|
avail = efm32_getreg(EFM32_USB_HPTXSTS) & _USB_HPTXSTS_PTXFSPCAVAIL_MASK;
|
||||||
}
|
}
|
||||||
|
|
||||||
/* Check if there is any space available in the Tx FIFO. */
|
/* Check if there is any space available in the Tx FIFO. */
|
||||||
@ -928,7 +922,7 @@ static void efm32_chan_halt(FAR struct efm32_usbhost_s *priv, int chidx,
|
|||||||
|
|
||||||
/* Halt the channel by setting CHDIS (and maybe CHENA) in the HCCHAR */
|
/* Halt the channel by setting CHDIS (and maybe CHENA) in the HCCHAR */
|
||||||
|
|
||||||
efm32_putreg(EFM32_USB_HCCHAR(chidx), hcchar);
|
efm32_putreg(EFM32_USB_HCn_CHAR(chidx), hcchar);
|
||||||
}
|
}
|
||||||
|
|
||||||
/*******************************************************************************
|
/*******************************************************************************
|
||||||
@ -1136,16 +1130,16 @@ static void efm32_transfer_start(FAR struct efm32_usbhost_s *priv, int chidx)
|
|||||||
|
|
||||||
chan->npackets = (uint8_t)npackets;
|
chan->npackets = (uint8_t)npackets;
|
||||||
|
|
||||||
/* Setup the HCTSIZn register */
|
/* Setup the HCn_TSIZ register */
|
||||||
|
|
||||||
regval = ((uint32_t)chan->buflen << _USB_HCTSIZ_XFRSIZ_SHIFT) |
|
regval = ((uint32_t)chan->buflen << _USB_HC_TSIZ_XFERSIZE_SHIFT) |
|
||||||
((uint32_t)npackets << _USB_HCTSIZ_PKTCNT_SHIFT) |
|
((uint32_t)npackets << _USB_HC_TSIZ_PKTCNT_SHIFT) |
|
||||||
((uint32_t)chan->pid << _USB_HCTSIZ_DPID_SHIFT);
|
((uint32_t)chan->pid << _USB_HC_TSIZ_PID_SHIFT);
|
||||||
efm32_putreg(EFM32_USB_HCTSIZ(chidx), regval);
|
efm32_putreg(EFM32_USB_HCn_TSIZ(chidx), regval);
|
||||||
|
|
||||||
/* Setup the HCCHAR register: Frame oddness and host channel enable */
|
/* Setup the HCCHAR register: Frame oddness and host channel enable */
|
||||||
|
|
||||||
regval = efm32_getreg(EFM32_USB_HCCHAR(chidx));
|
regval = efm32_getreg(EFM32_USB_HCn_CHAR(chidx));
|
||||||
|
|
||||||
/* Set/clear the Odd Frame bit. Check for an even frame; if so set Odd
|
/* Set/clear the Odd Frame bit. Check for an even frame; if so set Odd
|
||||||
* Frame. This field is applicable for only periodic (isochronous and
|
* Frame. This field is applicable for only periodic (isochronous and
|
||||||
@ -1163,7 +1157,7 @@ static void efm32_transfer_start(FAR struct efm32_usbhost_s *priv, int chidx)
|
|||||||
|
|
||||||
regval &= ~USB_HC_CHAR_CHDIS;
|
regval &= ~USB_HC_CHAR_CHDIS;
|
||||||
regval |= USB_HC_CHAR_CHENA;
|
regval |= USB_HC_CHAR_CHENA;
|
||||||
efm32_putreg(EFM32_USB_HCCHAR(chidx), regval);
|
efm32_putreg(EFM32_USB_HCn_CHAR(chidx), regval);
|
||||||
|
|
||||||
/* If this is an out transfer, then we need to do more.. we need to copy
|
/* If this is an out transfer, then we need to do more.. we need to copy
|
||||||
* the outgoing data into the correct TxFIFO.
|
* the outgoing data into the correct TxFIFO.
|
||||||
@ -1179,25 +1173,25 @@ static void efm32_transfer_start(FAR struct efm32_usbhost_s *priv, int chidx)
|
|||||||
|
|
||||||
switch (chan->eptype)
|
switch (chan->eptype)
|
||||||
{
|
{
|
||||||
case USB_EPTYPE_CTRL: /* Non periodic transfer */
|
case EFM32_USB_EPTYPE_CTRL: /* Non periodic transfer */
|
||||||
case USB_EPTYPE_BULK:
|
case EFM32_USB_EPTYPE_BULK:
|
||||||
{
|
{
|
||||||
/* Read the Non-periodic Tx FIFO status register */
|
/* Read the Non-periodic Tx FIFO status register */
|
||||||
|
|
||||||
regval = efm32_getreg(EFM32_USB_HNPTXSTS);
|
regval = efm32_getreg(EFM32_USB_GNPTXSTS);
|
||||||
avail = ((regval & _USB_HNPTXSTS_NPTXFSAV_MASK) >> _USB_HNPTXSTS_NPTXFSAV_SHIFT) << 2;
|
avail = ((regval & _USB_GNPTXSTS_NPTXFSPCAVAIL_MASK) >> _USB_GNPTXSTS_NPTXFSPCAVAIL_SHIFT) << 2;
|
||||||
}
|
}
|
||||||
break;
|
break;
|
||||||
|
|
||||||
/* Periodic transfer */
|
/* Periodic transfer */
|
||||||
|
|
||||||
case USB_EPTYPE_INTR:
|
case EFM32_USB_EPTYPE_INTR:
|
||||||
case USB_EPTYPE_ISOC:
|
case EFM32_USB_EPTYPE_ISOC:
|
||||||
{
|
{
|
||||||
/* Read the Non-periodic Tx FIFO status register */
|
/* Read the Non-periodic Tx FIFO status register */
|
||||||
|
|
||||||
regval = efm32_getreg(EFM32_USB_HPTXSTS);
|
regval = efm32_getreg(EFM32_USB_HPTXSTS);
|
||||||
avail = ((regval & _USB_HPTXSTS_PTXFSAVL_MASK) >> _USB_HPTXSTS_PTXFSAVL_SHIFT) << 2;
|
avail = ((regval & _USB_HPTXSTS_PTXFSPCAVAIL_MASK) >> _USB_HPTXSTS_PTXFSPCAVAIL_SHIFT) << 2;
|
||||||
}
|
}
|
||||||
break;
|
break;
|
||||||
|
|
||||||
@ -1284,7 +1278,7 @@ static int efm32_ctrl_sendsetup(FAR struct efm32_usbhost_s *priv,
|
|||||||
{
|
{
|
||||||
/* Send the SETUP packet */
|
/* Send the SETUP packet */
|
||||||
|
|
||||||
chan->pid = USB_PID_SETUP;
|
chan->pid = EFM32_USB_PID_SETUP;
|
||||||
chan->buffer = (FAR uint8_t *)req;
|
chan->buffer = (FAR uint8_t *)req;
|
||||||
chan->buflen = USB_SIZEOF_CTRLREQ;
|
chan->buflen = USB_SIZEOF_CTRLREQ;
|
||||||
|
|
||||||
@ -1364,7 +1358,7 @@ static int efm32_ctrl_senddata(FAR struct efm32_usbhost_s *priv,
|
|||||||
|
|
||||||
/* Set the Data PID as per the outdata1 boolean */
|
/* Set the Data PID as per the outdata1 boolean */
|
||||||
|
|
||||||
chan->pid = chan->outdata1 ? USB_PID_DATA1 : USB_PID_DATA0;
|
chan->pid = chan->outdata1 ? EFM32_USB_PID_DATA1 : EFM32_USB_PID_DATA0;
|
||||||
|
|
||||||
/* Set up for the wait BEFORE starting the transfer */
|
/* Set up for the wait BEFORE starting the transfer */
|
||||||
|
|
||||||
@ -1401,7 +1395,7 @@ static int efm32_ctrl_recvdata(FAR struct efm32_usbhost_s *priv,
|
|||||||
|
|
||||||
/* Save buffer information */
|
/* Save buffer information */
|
||||||
|
|
||||||
chan->pid = USB_PID_DATA1;
|
chan->pid = EFM32_USB_PID_DATA1;
|
||||||
chan->buffer = buffer;
|
chan->buffer = buffer;
|
||||||
chan->buflen = buflen;
|
chan->buflen = buflen;
|
||||||
|
|
||||||
@ -1464,7 +1458,7 @@ static int efm32_in_transfer(FAR struct efm32_usbhost_s *priv, int chidx,
|
|||||||
switch (chan->eptype)
|
switch (chan->eptype)
|
||||||
{
|
{
|
||||||
default:
|
default:
|
||||||
case USB_EPTYPE_CTRL: /* Control */
|
case EFM32_USB_EPTYPE_CTRL: /* Control */
|
||||||
{
|
{
|
||||||
/* This kind of transfer on control endpoints other than EP0 are not
|
/* This kind of transfer on control endpoints other than EP0 are not
|
||||||
* currently supported
|
* currently supported
|
||||||
@ -1473,30 +1467,30 @@ static int efm32_in_transfer(FAR struct efm32_usbhost_s *priv, int chidx,
|
|||||||
return -ENOSYS;
|
return -ENOSYS;
|
||||||
}
|
}
|
||||||
|
|
||||||
case USB_EPTYPE_ISOC: /* Isochronous */
|
case EFM32_USB_EPTYPE_ISOC: /* Isochronous */
|
||||||
{
|
{
|
||||||
/* Set up the IN data PID */
|
/* Set up the IN data PID */
|
||||||
|
|
||||||
usbhost_vtrace2(OTGFS_VTRACE2_ISOCIN, chidx, buflen);
|
usbhost_vtrace2(OTGFS_VTRACE2_ISOCIN, chidx, buflen);
|
||||||
chan->pid = USB_PID_DATA0;
|
chan->pid = EFM32_USB_PID_DATA0;
|
||||||
}
|
}
|
||||||
break;
|
break;
|
||||||
|
|
||||||
case USB_EPTYPE_BULK: /* Bulk */
|
case EFM32_USB_EPTYPE_BULK: /* Bulk */
|
||||||
{
|
{
|
||||||
/* Setup the IN data PID */
|
/* Setup the IN data PID */
|
||||||
|
|
||||||
usbhost_vtrace2(OTGFS_VTRACE2_BULKIN, chidx, buflen);
|
usbhost_vtrace2(OTGFS_VTRACE2_BULKIN, chidx, buflen);
|
||||||
chan->pid = chan->indata1 ? USB_PID_DATA1 : USB_PID_DATA0;
|
chan->pid = chan->indata1 ? EFM32_USB_PID_DATA1 : EFM32_USB_PID_DATA0;
|
||||||
}
|
}
|
||||||
break;
|
break;
|
||||||
|
|
||||||
case USB_EPTYPE_INTR: /* Interrupt */
|
case EFM32_USB_EPTYPE_INTR: /* Interrupt */
|
||||||
{
|
{
|
||||||
/* Setup the IN data PID */
|
/* Setup the IN data PID */
|
||||||
|
|
||||||
usbhost_vtrace2(OTGFS_VTRACE2_INTRIN, chidx, buflen);
|
usbhost_vtrace2(OTGFS_VTRACE2_INTRIN, chidx, buflen);
|
||||||
chan->pid = chan->indata1 ? USB_PID_DATA1 : USB_PID_DATA0;
|
chan->pid = chan->indata1 ? EFM32_USB_PID_DATA1 : EFM32_USB_PID_DATA0;
|
||||||
}
|
}
|
||||||
break;
|
break;
|
||||||
}
|
}
|
||||||
@ -1589,7 +1583,7 @@ static int efm32_out_transfer(FAR struct efm32_usbhost_s *priv, int chidx,
|
|||||||
switch (chan->eptype)
|
switch (chan->eptype)
|
||||||
{
|
{
|
||||||
default:
|
default:
|
||||||
case USB_EPTYPE_CTRL: /* Control */
|
case EFM32_USB_EPTYPE_CTRL: /* Control */
|
||||||
{
|
{
|
||||||
/* This kind of transfer on control endpoints other than EP0 are not
|
/* This kind of transfer on control endpoints other than EP0 are not
|
||||||
* currently supported
|
* currently supported
|
||||||
@ -1598,30 +1592,30 @@ static int efm32_out_transfer(FAR struct efm32_usbhost_s *priv, int chidx,
|
|||||||
return -ENOSYS;
|
return -ENOSYS;
|
||||||
}
|
}
|
||||||
|
|
||||||
case USB_EPTYPE_ISOC: /* Isochronous */
|
case EFM32_USB_EPTYPE_ISOC: /* Isochronous */
|
||||||
{
|
{
|
||||||
/* Set up the OUT data PID */
|
/* Set up the OUT data PID */
|
||||||
|
|
||||||
usbhost_vtrace2(OTGFS_VTRACE2_ISOCOUT, chidx, buflen);
|
usbhost_vtrace2(OTGFS_VTRACE2_ISOCOUT, chidx, buflen);
|
||||||
chan->pid = USB_PID_DATA0;
|
chan->pid = EFM32_USB_PID_DATA0;
|
||||||
}
|
}
|
||||||
break;
|
break;
|
||||||
|
|
||||||
case USB_EPTYPE_BULK: /* Bulk */
|
case EFM32_USB_EPTYPE_BULK: /* Bulk */
|
||||||
{
|
{
|
||||||
/* Setup the OUT data PID */
|
/* Setup the OUT data PID */
|
||||||
|
|
||||||
usbhost_vtrace2(OTGFS_VTRACE2_BULKOUT, chidx, buflen);
|
usbhost_vtrace2(OTGFS_VTRACE2_BULKOUT, chidx, buflen);
|
||||||
chan->pid = chan->outdata1 ? USB_PID_DATA1 : USB_PID_DATA0;
|
chan->pid = chan->outdata1 ? EFM32_USB_PID_DATA1 : EFM32_USB_PID_DATA0;
|
||||||
}
|
}
|
||||||
break;
|
break;
|
||||||
|
|
||||||
case USB_EPTYPE_INTR: /* Interrupt */
|
case EFM32_USB_EPTYPE_INTR: /* Interrupt */
|
||||||
{
|
{
|
||||||
/* Setup the OUT data PID */
|
/* Setup the OUT data PID */
|
||||||
|
|
||||||
usbhost_vtrace2(OTGFS_VTRACE2_INTROUT, chidx, buflen);
|
usbhost_vtrace2(OTGFS_VTRACE2_INTROUT, chidx, buflen);
|
||||||
chan->pid = chan->outdata1 ? USB_PID_DATA1 : USB_PID_DATA0;
|
chan->pid = chan->outdata1 ? EFM32_USB_PID_DATA1 : EFM32_USB_PID_DATA0;
|
||||||
|
|
||||||
/* Toggle the OUT data PID for the next transfer */
|
/* Toggle the OUT data PID for the next transfer */
|
||||||
|
|
||||||
@ -1709,7 +1703,7 @@ static void efm32_gint_wrpacket(FAR struct efm32_usbhost_s *priv,
|
|||||||
|
|
||||||
/* Get the address of the Tx FIFO associated with this channel */
|
/* Get the address of the Tx FIFO associated with this channel */
|
||||||
|
|
||||||
fifo = EFM32_USB_DFIFO_HCH(chidx);
|
fifo = EFM32_USB_FIFO_BASE(chidx);
|
||||||
|
|
||||||
/* Transfer all of the data into the Tx FIFO */
|
/* Transfer all of the data into the Tx FIFO */
|
||||||
|
|
||||||
@ -1831,7 +1825,7 @@ static inline void efm32_gint_hcinisr(FAR struct efm32_usbhost_s *priv,
|
|||||||
|
|
||||||
/* Then handle the transfer completion event based on the endpoint type */
|
/* Then handle the transfer completion event based on the endpoint type */
|
||||||
|
|
||||||
if (chan->eptype == USB_EPTYPE_CTRL || chan->eptype == USB_EPTYPE_BULK)
|
if (chan->eptype == EFM32_USB_EPTYPE_CTRL || chan->eptype == EFM32_USB_EPTYPE_BULK)
|
||||||
{
|
{
|
||||||
/* Halt the channel -- the CHH interrrupt is expected next */
|
/* Halt the channel -- the CHH interrrupt is expected next */
|
||||||
|
|
||||||
@ -1844,13 +1838,13 @@ static inline void efm32_gint_hcinisr(FAR struct efm32_usbhost_s *priv,
|
|||||||
|
|
||||||
efm32_putreg(EFM32_USB_HCn_INT(chidx), USB_HC_INT_NAK);
|
efm32_putreg(EFM32_USB_HCn_INT(chidx), USB_HC_INT_NAK);
|
||||||
}
|
}
|
||||||
else if (chan->eptype == USB_EPTYPE_INTR)
|
else if (chan->eptype == EFM32_USB_EPTYPE_INTR)
|
||||||
{
|
{
|
||||||
/* Force the next transfer on an ODD frame */
|
/* Force the next transfer on an ODD frame */
|
||||||
|
|
||||||
regval = efm32_getreg(EFM32_USB_HCCHAR(chidx));
|
regval = efm32_getreg(EFM32_USB_HCn_CHAR(chidx));
|
||||||
regval |= USB_HC_CHAR_ODDFRM;
|
regval |= USB_HC_CHAR_ODDFRM;
|
||||||
efm32_putreg(EFM32_USB_HCCHAR(chidx), regval);
|
efm32_putreg(EFM32_USB_HCn_CHAR(chidx), regval);
|
||||||
|
|
||||||
/* Set the request done state */
|
/* Set the request done state */
|
||||||
|
|
||||||
@ -1895,7 +1889,7 @@ static inline void efm32_gint_hcinisr(FAR struct efm32_usbhost_s *priv,
|
|||||||
* and check for an interrupt endpoint.
|
* and check for an interrupt endpoint.
|
||||||
*/
|
*/
|
||||||
|
|
||||||
regval = efm32_getreg(EFM32_USB_HCCHAR(chidx));
|
regval = efm32_getreg(EFM32_USB_HCn_CHAR(chidx));
|
||||||
if ((regval & _USB_HC_CHAR_EPTYPE_MASK) == USB_HC_CHAR_EPTYPE_INT)
|
if ((regval & _USB_HC_CHAR_EPTYPE_MASK) == USB_HC_CHAR_EPTYPE_INT)
|
||||||
{
|
{
|
||||||
/* Toggle the IN data toggle (Used by Bulk and INTR only) */
|
/* Toggle the IN data toggle (Used by Bulk and INTR only) */
|
||||||
@ -1947,7 +1941,7 @@ static inline void efm32_gint_hcinisr(FAR struct efm32_usbhost_s *priv,
|
|||||||
#if 1
|
#if 1
|
||||||
/* Halt the interrupt channel */
|
/* Halt the interrupt channel */
|
||||||
|
|
||||||
if (chan->eptype == USB_EPTYPE_INTR)
|
if (chan->eptype == EFM32_USB_EPTYPE_INTR)
|
||||||
{
|
{
|
||||||
/* Halt the channel -- the CHH interrupt is expected next */
|
/* Halt the channel -- the CHH interrupt is expected next */
|
||||||
|
|
||||||
@ -1956,17 +1950,17 @@ static inline void efm32_gint_hcinisr(FAR struct efm32_usbhost_s *priv,
|
|||||||
|
|
||||||
/* Re-activate CTRL and BULK channels */
|
/* Re-activate CTRL and BULK channels */
|
||||||
|
|
||||||
else if (chan->eptype == USB_EPTYPE_CTRL ||
|
else if (chan->eptype == EFM32_USB_EPTYPE_CTRL ||
|
||||||
chan->eptype == USB_EPTYPE_BULK)
|
chan->eptype == EFM32_USB_EPTYPE_BULK)
|
||||||
{
|
{
|
||||||
/* Re-activate the channel by clearing CHDIS and assuring that
|
/* Re-activate the channel by clearing CHDIS and assuring that
|
||||||
* CHENA is set
|
* CHENA is set
|
||||||
*/
|
*/
|
||||||
|
|
||||||
regval = efm32_getreg(EFM32_USB_HCCHAR(chidx));
|
regval = efm32_getreg(EFM32_USB_HCn_CHAR(chidx));
|
||||||
regval |= USB_HC_CHAR_CHENA;
|
regval |= USB_HC_CHAR_CHENA;
|
||||||
regval &= ~USB_HC_CHAR_CHDIS;
|
regval &= ~USB_HC_CHAR_CHDIS;
|
||||||
efm32_putreg(EFM32_USB_HCCHAR(chidx), regval);
|
efm32_putreg(EFM32_USB_HCn_CHAR(chidx), regval);
|
||||||
}
|
}
|
||||||
#else
|
#else
|
||||||
/* Halt all transfers on the NAK -- the CHH interrupt is expected next */
|
/* Halt all transfers on the NAK -- the CHH interrupt is expected next */
|
||||||
@ -2143,7 +2137,7 @@ static inline void efm32_gint_hcoutisr(FAR struct efm32_usbhost_s *priv,
|
|||||||
* the endpoint type.
|
* the endpoint type.
|
||||||
*/
|
*/
|
||||||
|
|
||||||
regval = efm32_getreg(EFM32_USB_HCCHAR(chidx));
|
regval = efm32_getreg(EFM32_USB_HCn_CHAR(chidx));
|
||||||
|
|
||||||
/* Is it a bulk endpoint? Were an odd number of packets
|
/* Is it a bulk endpoint? Were an odd number of packets
|
||||||
* transferred?
|
* transferred?
|
||||||
@ -2316,7 +2310,7 @@ static inline void efm32_gint_rxflvlisr(FAR struct efm32_usbhost_s *priv)
|
|||||||
/* Disable the RxFIFO non-empty interrupt */
|
/* Disable the RxFIFO non-empty interrupt */
|
||||||
|
|
||||||
intmsk = efm32_getreg(EFM32_USB_GINTMSK);
|
intmsk = efm32_getreg(EFM32_USB_GINTMSK);
|
||||||
intmsk &= ~USB_GINTMSK_PTXFEMPMSKRXFLVLMSK;
|
intmsk &= ~USB_GINTMSK_RXFLVLMSK;
|
||||||
efm32_putreg(EFM32_USB_GINTMSK, intmsk);
|
efm32_putreg(EFM32_USB_GINTMSK, intmsk);
|
||||||
|
|
||||||
/* Read and pop the next status from the Rx FIFO */
|
/* Read and pop the next status from the Rx FIFO */
|
||||||
@ -2330,7 +2324,7 @@ static inline void efm32_gint_rxflvlisr(FAR struct efm32_usbhost_s *priv)
|
|||||||
|
|
||||||
/* Get the host channel characteristics register (HCCHAR) for this channel */
|
/* Get the host channel characteristics register (HCCHAR) for this channel */
|
||||||
|
|
||||||
hcchar = efm32_getreg(EFM32_USB_HCCHAR(chidx));
|
hcchar = efm32_getreg(EFM32_USB_HCn_CHAR(chidx));
|
||||||
|
|
||||||
/* Then process the interrupt according to the packet status */
|
/* Then process the interrupt according to the packet status */
|
||||||
|
|
||||||
@ -2346,7 +2340,7 @@ static inline void efm32_gint_rxflvlisr(FAR struct efm32_usbhost_s *priv)
|
|||||||
/* Transfer the packet from the Rx FIFO into the user buffer */
|
/* Transfer the packet from the Rx FIFO into the user buffer */
|
||||||
|
|
||||||
dest = (FAR uint32_t *)priv->chan[chidx].buffer;
|
dest = (FAR uint32_t *)priv->chan[chidx].buffer;
|
||||||
fifo = EFM32_USB_DFIFO_HCH(0);
|
fifo = EFM32_USB_FIFO_BASE(0);
|
||||||
bcnt32 = (bcnt + 3) >> 2;
|
bcnt32 = (bcnt + 3) >> 2;
|
||||||
|
|
||||||
for (i = 0; i < bcnt32; i++)
|
for (i = 0; i < bcnt32; i++)
|
||||||
@ -2367,14 +2361,14 @@ static inline void efm32_gint_rxflvlisr(FAR struct efm32_usbhost_s *priv)
|
|||||||
|
|
||||||
/* Check if more packets are expected */
|
/* Check if more packets are expected */
|
||||||
|
|
||||||
hctsiz = efm32_getreg(EFM32_USB_HCTSIZ(chidx));
|
hctsiz = efm32_getreg(EFM32_USB_HCn_TSIZ(chidx));
|
||||||
if ((hctsiz & _USB_HCTSIZ_PKTCNT_MASK) != 0)
|
if ((hctsiz & _USB_HC_TSIZ_PKTCNT_MASK) != 0)
|
||||||
{
|
{
|
||||||
/* Re-activate the channel when more packets are expected */
|
/* Re-activate the channel when more packets are expected */
|
||||||
|
|
||||||
hcchar |= USB_HC_CHAR_CHENA;
|
hcchar |= USB_HC_CHAR_CHENA;
|
||||||
hcchar &= ~USB_HC_CHAR_CHDIS;
|
hcchar &= ~USB_HC_CHAR_CHDIS;
|
||||||
efm32_putreg(EFM32_USB_HCCHAR(chidx), hcchar);
|
efm32_putreg(EFM32_USB_HCn_CHAR(chidx), hcchar);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
@ -2389,7 +2383,7 @@ static inline void efm32_gint_rxflvlisr(FAR struct efm32_usbhost_s *priv)
|
|||||||
|
|
||||||
/* Re-enable the RxFIFO non-empty interrupt */
|
/* Re-enable the RxFIFO non-empty interrupt */
|
||||||
|
|
||||||
intmsk |= USB_GINTMSK_PTXFEMPMSKRXFLVLMSK;
|
intmsk |= USB_GINTMSK_RXFLVLMSK;
|
||||||
efm32_putreg(EFM32_USB_GINTMSK, intmsk);
|
efm32_putreg(EFM32_USB_GINTMSK, intmsk);
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -2433,17 +2427,17 @@ static inline void efm32_gint_nptxfeisr(FAR struct efm32_usbhost_s *priv)
|
|||||||
{
|
{
|
||||||
/* Disable further Tx FIFO empty interrupts and bail. */
|
/* Disable further Tx FIFO empty interrupts and bail. */
|
||||||
|
|
||||||
efm32_modifyreg(EFM32_USB_GINTMSK, USB_GINTMSK_PTXFEMPMSKNPTXFEMPMSK, 0);
|
efm32_modifyreg(EFM32_USB_GINTMSK, USB_GINTMSK_NPTXFEMPMSK, 0);
|
||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
|
|
||||||
/* Read the status from the top of the non-periodic TxFIFO */
|
/* Read the status from the top of the non-periodic TxFIFO */
|
||||||
|
|
||||||
regval = efm32_getreg(EFM32_USB_HNPTXSTS);
|
regval = efm32_getreg(EFM32_USB_GNPTXSTS);
|
||||||
|
|
||||||
/* Extract the number of bytes available in the non-periodic Tx FIFO. */
|
/* Extract the number of bytes available in the non-periodic Tx FIFO. */
|
||||||
|
|
||||||
avail = ((regval & _USB_HNPTXSTS_NPTXFSAV_MASK) >> _USB_HNPTXSTS_NPTXFSAV_SHIFT) << 2;
|
avail = ((regval & _USB_GNPTXSTS_NPTXFSPCAVAIL_MASK) >> _USB_GNPTXSTS_NPTXFSPCAVAIL_SHIFT) << 2;
|
||||||
|
|
||||||
/* Get minimal size packet that can be sent. Something is seriously
|
/* Get minimal size packet that can be sent. Something is seriously
|
||||||
* configured wrong if one packet will not fit into the empty Tx FIFO.
|
* configured wrong if one packet will not fit into the empty Tx FIFO.
|
||||||
@ -2471,7 +2465,7 @@ static inline void efm32_gint_nptxfeisr(FAR struct efm32_usbhost_s *priv)
|
|||||||
|
|
||||||
else
|
else
|
||||||
{
|
{
|
||||||
efm32_modifyreg(EFM32_USB_GINTMSK, USB_GINTMSK_PTXFEMPMSKNPTXFEMPMSK, 0);
|
efm32_modifyreg(EFM32_USB_GINTMSK, USB_GINTMSK_NPTXFEMPMSK, 0);
|
||||||
}
|
}
|
||||||
|
|
||||||
/* Write the next group of packets into the Tx FIFO */
|
/* Write the next group of packets into the Tx FIFO */
|
||||||
@ -2522,7 +2516,7 @@ static inline void efm32_gint_ptxfeisr(FAR struct efm32_usbhost_s *priv)
|
|||||||
{
|
{
|
||||||
/* Disable further Tx FIFO empty interrupts and bail. */
|
/* Disable further Tx FIFO empty interrupts and bail. */
|
||||||
|
|
||||||
efm32_modifyreg(EFM32_USB_GINTMSK, USB_GINTMSK_PTXFEMPMSKPTXFEMPMSK, 0);
|
efm32_modifyreg(EFM32_USB_GINTMSK, USB_GINTMSK_NPTXFEMPMSK, 0);
|
||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -2532,7 +2526,7 @@ static inline void efm32_gint_ptxfeisr(FAR struct efm32_usbhost_s *priv)
|
|||||||
|
|
||||||
/* Extract the number of bytes available in the periodic Tx FIFO. */
|
/* Extract the number of bytes available in the periodic Tx FIFO. */
|
||||||
|
|
||||||
avail = ((regval & _USB_HPTXSTS_PTXFSAVL_MASK) >> _USB_HPTXSTS_PTXFSAVL_SHIFT) << 2;
|
avail = ((regval & _USB_HPTXSTS_PTXFSPCAVAIL_MASK) >> _USB_HPTXSTS_PTXFSPCAVAIL_SHIFT) << 2;
|
||||||
|
|
||||||
/* Get minimal size packet that can be sent. Something is seriously
|
/* Get minimal size packet that can be sent. Something is seriously
|
||||||
* configured wrong if one packet will not fit into the empty Tx FIFO.
|
* configured wrong if one packet will not fit into the empty Tx FIFO.
|
||||||
@ -2560,7 +2554,7 @@ static inline void efm32_gint_ptxfeisr(FAR struct efm32_usbhost_s *priv)
|
|||||||
|
|
||||||
else
|
else
|
||||||
{
|
{
|
||||||
efm32_modifyreg(EFM32_USB_GINTMSK, USB_GINTMSK_PTXFEMPMSKPTXFEMPMSK, 0);
|
efm32_modifyreg(EFM32_USB_GINTMSK, USB_GINTMSK_NPTXFEMPMSK, 0);
|
||||||
}
|
}
|
||||||
|
|
||||||
/* Write the next group of packets into the Tx FIFO */
|
/* Write the next group of packets into the Tx FIFO */
|
||||||
@ -2599,7 +2593,7 @@ static inline void efm32_gint_hcisr(FAR struct efm32_usbhost_s *priv)
|
|||||||
{
|
{
|
||||||
/* Yes... read the HCCHAR register to get the direction bit */
|
/* Yes... read the HCCHAR register to get the direction bit */
|
||||||
|
|
||||||
hcchar = efm32_getreg(EFM32_USB_HCCHAR(i));
|
hcchar = efm32_getreg(EFM32_USB_HCn_CHAR(i));
|
||||||
|
|
||||||
/* Was this an interrupt on an IN or an OUT channel? */
|
/* Was this an interrupt on an IN or an OUT channel? */
|
||||||
|
|
||||||
@ -2707,14 +2701,14 @@ static inline void efm32_gint_hprtisr(FAR struct efm32_usbhost_s *priv)
|
|||||||
|
|
||||||
/* Are we switching from FS to LS? */
|
/* Are we switching from FS to LS? */
|
||||||
|
|
||||||
if ((hcfg & _USB_HCFG_FSLSPCS_MASK) != USB_HCFG_FSLSPCS_LS6MHz)
|
if ((hcfg & _USB_HCFG_FSLSPCLKSEL_MASK) != USB_HCFG_FSLSPCLKSEL_DIV8)
|
||||||
{
|
{
|
||||||
|
|
||||||
usbhost_vtrace1(OTGFS_VTRACE1_GINT_HPRT_FSLSSW, 0);
|
usbhost_vtrace1(OTGFS_VTRACE1_GINT_HPRT_FSLSSW, 0);
|
||||||
/* Yes... configure for LS */
|
/* Yes... configure for LS */
|
||||||
|
|
||||||
hcfg &= ~_USB_HCFG_FSLSPCS_MASK;
|
hcfg &= ~_USB_HCFG_FSLSPCLKSEL_MASK;
|
||||||
hcfg |= USB_HCFG_FSLSPCS_LS6MHz;
|
hcfg |= USB_HCFG_FSLSPCLKSEL_DIV8;
|
||||||
efm32_putreg(EFM32_USB_HCFG, hcfg);
|
efm32_putreg(EFM32_USB_HCFG, hcfg);
|
||||||
|
|
||||||
/* And reset the port */
|
/* And reset the port */
|
||||||
@ -2730,14 +2724,14 @@ static inline void efm32_gint_hprtisr(FAR struct efm32_usbhost_s *priv)
|
|||||||
|
|
||||||
/* Are we switching from LS to FS? */
|
/* Are we switching from LS to FS? */
|
||||||
|
|
||||||
if ((hcfg & _USB_HCFG_FSLSPCS_MASK) != USB_HCFG_FSLSPCS_FS48MHz)
|
if ((hcfg & _USB_HCFG_FSLSPCLKSEL_MASK) != USB_HCFG_FSLSPCLKSEL_DIV1)
|
||||||
{
|
{
|
||||||
|
|
||||||
usbhost_vtrace1(OTGFS_VTRACE1_GINT_HPRT_LSFSSW, 0);
|
usbhost_vtrace1(OTGFS_VTRACE1_GINT_HPRT_LSFSSW, 0);
|
||||||
/* Yes... configure for FS */
|
/* Yes... configure for FS */
|
||||||
|
|
||||||
hcfg &= ~_USB_HCFG_FSLSPCS_MASK;
|
hcfg &= ~_USB_HCFG_FSLSPCLKSEL_MASK;
|
||||||
hcfg |= USB_HCFG_FSLSPCS_FS48MHz;
|
hcfg |= USB_HCFG_FSLSPCLKSEL_DIV1;
|
||||||
efm32_putreg(EFM32_USB_HCFG, hcfg);
|
efm32_putreg(EFM32_USB_HCFG, hcfg);
|
||||||
|
|
||||||
/* And reset the port */
|
/* And reset the port */
|
||||||
@ -2788,9 +2782,9 @@ static inline void efm32_gint_ipxfrisr(FAR struct efm32_usbhost_s *priv)
|
|||||||
* CHDIS : Set to stop transmitting/receiving data on a channel
|
* CHDIS : Set to stop transmitting/receiving data on a channel
|
||||||
*/
|
*/
|
||||||
|
|
||||||
regval = efm32_getreg(EFM32_USB_HCCHAR(0));
|
regval = efm32_getreg(EFM32_USB_HCn_CHAR(0));
|
||||||
regval |= (USB_HC_CHAR_CHDIS | USB_HC_CHAR_CHENA);
|
regval |= (USB_HC_CHAR_CHDIS | USB_HC_CHAR_CHENA);
|
||||||
efm32_putreg(EFM32_USB_HCCHAR(0), regval);
|
efm32_putreg(EFM32_USB_HCn_CHAR(0), regval);
|
||||||
|
|
||||||
/* Clear the incomplete isochronous OUT interrupt */
|
/* Clear the incomplete isochronous OUT interrupt */
|
||||||
|
|
||||||
@ -3012,11 +3006,13 @@ static inline void efm32_hostinit_enable(void)
|
|||||||
*/
|
*/
|
||||||
|
|
||||||
#ifdef CONFIG_EFM32_OTGFS_SOFINTR
|
#ifdef CONFIG_EFM32_OTGFS_SOFINTR
|
||||||
regval |= (USB_GINTMSK_SOFMSK | USB_GINTMSK_RXFLVLMSK | USB_GINTMSK_INCOMPLPMSK |
|
regval |= (USB_GINTMSK_SOFMSK | USB_GINTMSK_RXFLVLMSK |
|
||||||
USB_GINTMSK_PRTINTMSK | USB_GINTMSK_HCHINTMSK | USB_GINTMSK_DISCONNINTMSK);
|
USB_GINTMSK_INCOMPLPMSK | USB_GINTMSK_PRTINTMSK |
|
||||||
#else
|
|
||||||
regval |= (USB_GINTMSK_RXFLVLMSK | USB_GINTMSK_IPXFR | USB_GINTMSK_PRTINTMSK |
|
|
||||||
USB_GINTMSK_HCHINTMSK | USB_GINTMSK_DISCONNINTMSK);
|
USB_GINTMSK_HCHINTMSK | USB_GINTMSK_DISCONNINTMSK);
|
||||||
|
#else
|
||||||
|
regval |= (USB_GINTMSK_RXFLVLMSK | USB_GINTMSK_INCOMPLPMSK |
|
||||||
|
USB_GINTMSK_PRTINTMSK | USB_GINTMSK_HCHINTMSK |
|
||||||
|
USB_GINTMSK_DISCONNINTMSK);
|
||||||
#endif
|
#endif
|
||||||
efm32_putreg(EFM32_USB_GINTMSK, regval);
|
efm32_putreg(EFM32_USB_GINTMSK, regval);
|
||||||
}
|
}
|
||||||
@ -3061,13 +3057,13 @@ static void efm32_txfe_enable(FAR struct efm32_usbhost_s *priv, int chidx)
|
|||||||
switch (chan->eptype)
|
switch (chan->eptype)
|
||||||
{
|
{
|
||||||
default:
|
default:
|
||||||
case USB_EPTYPE_CTRL: /* Non periodic transfer */
|
case EFM32_USB_EPTYPE_CTRL: /* Non periodic transfer */
|
||||||
case USB_EPTYPE_BULK:
|
case EFM32_USB_EPTYPE_BULK:
|
||||||
regval |= USB_GINTMSK_NPTXFEMPMSK;
|
regval |= USB_GINTMSK_NPTXFEMPMSK;
|
||||||
break;
|
break;
|
||||||
|
|
||||||
case USB_EPTYPE_INTR: /* Periodic transfer */
|
case EFM32_USB_EPTYPE_INTR: /* Periodic transfer */
|
||||||
case USB_EPTYPE_ISOC:
|
case EFM32_USB_EPTYPE_ISOC:
|
||||||
regval |= USB_GINTMSK_PTXFEMPMSK;
|
regval |= USB_GINTMSK_PTXFEMPMSK;
|
||||||
break;
|
break;
|
||||||
}
|
}
|
||||||
@ -3189,7 +3185,7 @@ static int efm32_enumerate(FAR struct usbhost_connection_s *conn, int rhpndx)
|
|||||||
priv->ep0out = chidx;
|
priv->ep0out = chidx;
|
||||||
priv->chan[chidx].epno = 0;
|
priv->chan[chidx].epno = 0;
|
||||||
priv->chan[chidx].in = false;
|
priv->chan[chidx].in = false;
|
||||||
priv->chan[chidx].eptype = USB_EPTYPE_CTRL;
|
priv->chan[chidx].eptype = EFM32_USB_EPTYPE_CTRL;
|
||||||
priv->chan[chidx].maxpacket = EFM32_EP0_DEF_PACKET_SIZE;
|
priv->chan[chidx].maxpacket = EFM32_EP0_DEF_PACKET_SIZE;
|
||||||
priv->chan[chidx].indata1 = false;
|
priv->chan[chidx].indata1 = false;
|
||||||
priv->chan[chidx].outdata1 = false;
|
priv->chan[chidx].outdata1 = false;
|
||||||
@ -3202,7 +3198,7 @@ static int efm32_enumerate(FAR struct usbhost_connection_s *conn, int rhpndx)
|
|||||||
priv->ep0in = chidx;
|
priv->ep0in = chidx;
|
||||||
priv->chan[chidx].epno = 0;
|
priv->chan[chidx].epno = 0;
|
||||||
priv->chan[chidx].in = true;
|
priv->chan[chidx].in = true;
|
||||||
priv->chan[chidx].eptype = USB_EPTYPE_CTRL;
|
priv->chan[chidx].eptype = EFM32_USB_EPTYPE_CTRL;
|
||||||
priv->chan[chidx].maxpacket = EFM32_EP0_DEF_PACKET_SIZE;
|
priv->chan[chidx].maxpacket = EFM32_EP0_DEF_PACKET_SIZE;
|
||||||
priv->chan[chidx].indata1 = false;
|
priv->chan[chidx].indata1 = false;
|
||||||
priv->chan[chidx].outdata1 = false;
|
priv->chan[chidx].outdata1 = false;
|
||||||
@ -4119,8 +4115,8 @@ static void efm32_host_initialize(FAR struct efm32_usbhost_s *priv)
|
|||||||
/* Initialize Host Configuration (HCFG) register */
|
/* Initialize Host Configuration (HCFG) register */
|
||||||
|
|
||||||
regval = efm32_getreg(EFM32_USB_HCFG);
|
regval = efm32_getreg(EFM32_USB_HCFG);
|
||||||
regval &= ~_USB_HCFG_FSLSPCS_MASK;
|
regval &= ~_USB_HCFG_FSLSPCLKSEL_MASK;
|
||||||
regval |= USB_HCFG_FSLSPCS_FS48MHz;
|
regval |= USB_HCFG_FSLSPCLKSEL_DIV1;
|
||||||
efm32_putreg(EFM32_USB_HCFG, regval);
|
efm32_putreg(EFM32_USB_HCFG, regval);
|
||||||
|
|
||||||
/* Reset the host port */
|
/* Reset the host port */
|
||||||
@ -4130,7 +4126,7 @@ static void efm32_host_initialize(FAR struct efm32_usbhost_s *priv)
|
|||||||
/* Clear the FS-/LS-only support bit in the HCFG register */
|
/* Clear the FS-/LS-only support bit in the HCFG register */
|
||||||
|
|
||||||
regval = efm32_getreg(EFM32_USB_HCFG);
|
regval = efm32_getreg(EFM32_USB_HCFG);
|
||||||
regval &= ~USB_HCFG_FSLSS;
|
regval &= ~USB_HCFG_FSLSSUPP;
|
||||||
efm32_putreg(EFM32_USB_HCFG, regval);
|
efm32_putreg(EFM32_USB_HCFG, regval);
|
||||||
|
|
||||||
/* Carve up FIFO memory for the Rx FIFO and the periodic and non-periodic Tx FIFOs */
|
/* Carve up FIFO memory for the Rx FIFO and the periodic and non-periodic Tx FIFOs */
|
||||||
@ -4139,15 +4135,15 @@ static void efm32_host_initialize(FAR struct efm32_usbhost_s *priv)
|
|||||||
efm32_putreg(EFM32_USB_GRXFSIZ, CONFIG_EFM32_OTGFS_RXFIFO_SIZE);
|
efm32_putreg(EFM32_USB_GRXFSIZ, CONFIG_EFM32_OTGFS_RXFIFO_SIZE);
|
||||||
offset = CONFIG_EFM32_OTGFS_RXFIFO_SIZE;
|
offset = CONFIG_EFM32_OTGFS_RXFIFO_SIZE;
|
||||||
|
|
||||||
/* Setup the host non-periodic Tx FIFO size (HNPTXFSIZ) */
|
/* Setup the host non-periodic Tx FIFO size (GNPTXFSIZ) */
|
||||||
|
|
||||||
regval = (offset | (CONFIG_EFM32_OTGFS_NPTXFIFO_SIZE << _USB_HNPTXFSIZ_NPTXFD_SHIFT));
|
regval = (offset | (CONFIG_EFM32_OTGFS_NPTXFIFO_SIZE << _USB_GNPTXFSIZ_NPTXFINEPTXF0DEP_SHIFT));
|
||||||
efm32_putreg(EFM32_USB_HNPTXFSIZ, regval);
|
efm32_putreg(EFM32_USB_GNPTXFSIZ, regval);
|
||||||
offset += CONFIG_EFM32_OTGFS_NPTXFIFO_SIZE;
|
offset += CONFIG_EFM32_OTGFS_NPTXFIFO_SIZE;
|
||||||
|
|
||||||
/* Set up the host periodic Tx FIFO size register (HPTXFSIZ) */
|
/* Set up the host periodic Tx FIFO size register (HPTXFSIZ) */
|
||||||
|
|
||||||
regval = (offset | (CONFIG_EFM32_OTGFS_PTXFIFO_SIZE << _USB_HPTXFSIZ_PTXFD_SHIFT));
|
regval = (offset | (CONFIG_EFM32_OTGFS_PTXFIFO_SIZE << _USB_HPTXFSIZ_PTXFSIZE_SHIFT));
|
||||||
efm32_putreg(EFM32_USB_HPTXFSIZ, regval);
|
efm32_putreg(EFM32_USB_HPTXFSIZ, regval);
|
||||||
|
|
||||||
/* If OTG were supported, we would need to clear HNP enable bit in the
|
/* If OTG were supported, we would need to clear HNP enable bit in the
|
||||||
@ -4317,7 +4313,7 @@ static inline int efm32_hw_initialize(FAR struct efm32_usbhost_s *priv)
|
|||||||
*******************************************************************************/
|
*******************************************************************************/
|
||||||
|
|
||||||
/*******************************************************************************
|
/*******************************************************************************
|
||||||
* Name: efm32_otgfshost_initialize
|
* Name: efm32_usbhost_initialize
|
||||||
*
|
*
|
||||||
* Description:
|
* Description:
|
||||||
* Initialize USB host device controller hardware.
|
* Initialize USB host device controller hardware.
|
||||||
@ -4341,7 +4337,7 @@ static inline int efm32_hw_initialize(FAR struct efm32_usbhost_s *priv)
|
|||||||
*
|
*
|
||||||
*******************************************************************************/
|
*******************************************************************************/
|
||||||
|
|
||||||
FAR struct usbhost_connection_s *efm32_otgfshost_initialize(int controller)
|
FAR struct usbhost_connection_s *efm32_usbhost_initialize(int controller)
|
||||||
{
|
{
|
||||||
/* At present, there is only support for a single OTG FS host. Hence it is
|
/* At present, there is only support for a single OTG FS host. Hence it is
|
||||||
* pre-allocated as g_usbhost. However, in most code, the private data
|
* pre-allocated as g_usbhost. However, in most code, the private data
|
||||||
|
Loading…
Reference in New Issue
Block a user