{stm32,stm32f7,stm32h7,stm32l4,efm32}/otg: rasie an assertion if IN request is not possible to transfer

Otherwise, a request will never be transferred and there is no
information to the user that something is wrong.
For example, when using default values for TXFIFO in HS mode,
USBMSC will never work because the maximum request len is 512B
which is lower than the default TXFIFO size for IN EP.
This commit is contained in:
raiden00pl 2023-04-06 11:57:26 +02:00 committed by Petro Karashchenko
parent 9affcb8673
commit d356ad633f
6 changed files with 79 additions and 0 deletions

View File

@ -1336,6 +1336,19 @@ static void efm32_epin_request(struct efm32_usbdev_s *priv,
empmsk |= USB_DIEPEMPMSK(privep->epphy); empmsk |= USB_DIEPEMPMSK(privep->epphy);
efm32_putreg(empmsk, EFM32_USB_DIEPEMPMSK); efm32_putreg(empmsk, EFM32_USB_DIEPEMPMSK);
#ifdef CONFIG_DEBUG_FEATURES
/* Check if the configured TXFIFO size is sufficient for a given
* request. If not, raise an assertion here.
*/
regval = emf32_putreg(regval, EMF32_USB_DIEPTXF(privep->epphy));
regval &= _USB_DIEPTXF1_INEPNTXFDEP_MASK;
regval >>= _USB_DIEPTXF1_INEPNTXFDEP_SHIFT;
uerr("EP%" PRId8 " TXLEN=%" PRId32 " nwords=%d\n",
privep->epphy, regval, nwords);
DEBUGASSERT(regval >= nwords);
#endif
/* Terminate the transfer. We will try again when the TxFIFO empty /* Terminate the transfer. We will try again when the TxFIFO empty
* interrupt is received. * interrupt is received.
*/ */

View File

@ -1378,6 +1378,19 @@ static void stm32_epin_request(struct stm32_usbdev_s *priv,
empmsk |= OTGFS_DIEPEMPMSK(privep->epphy); empmsk |= OTGFS_DIEPEMPMSK(privep->epphy);
stm32_putreg(empmsk, STM32_OTGFS_DIEPEMPMSK); stm32_putreg(empmsk, STM32_OTGFS_DIEPEMPMSK);
#ifdef CONFIG_DEBUG_FEATURES
/* Check if the configured TXFIFO size is sufficient for a given
* request. If not, raise an assertion here.
*/
regval = stm32_putreg(regval, STM32_OTGFS_DIEPTXF(privep->epphy));
regval &= OTGFS_DIEPTXF_INEPTXFD_MASK;
regval >>= OTGFS_DIEPTXF_INEPTXFD_SHIFT;
uerr("EP%" PRId8 " TXLEN=%" PRId32 " nwords=%d\n",
privep->epphy, regval, nwords);
DEBUGASSERT(regval >= nwords);
#endif
/* Terminate the transfer. We will try again when the TxFIFO empty /* Terminate the transfer. We will try again when the TxFIFO empty
* interrupt is received. * interrupt is received.
*/ */

View File

@ -1328,6 +1328,19 @@ static void stm32_epin_request(struct stm32_usbdev_s *priv,
empmsk |= OTGHS_DIEPEMPMSK(privep->epphy); empmsk |= OTGHS_DIEPEMPMSK(privep->epphy);
stm32_putreg(empmsk, STM32_OTGHS_DIEPEMPMSK); stm32_putreg(empmsk, STM32_OTGHS_DIEPEMPMSK);
#ifdef CONFIG_DEBUG_FEATURES
/* Check if the configured TXFIFO size is sufficient for a given
* request. If not, raise an assertion here.
*/
regval = stm32_putreg(regval, STM32_OTGHS_DIEPTXF(privep->epphy));
regval &= OTGHS_DIEPTXF_INEPTXFD_MASK;
regval >>= OTGHS_DIEPTXF_INEPTXFD_SHIFT;
uerr("EP%" PRId8 " TXLEN=%" PRId32 " nwords=%d\n",
privep->epphy, regval, nwords);
DEBUGASSERT(regval >= nwords);
#endif
/* Terminate the transfer. We will try again when the TxFIFO empty /* Terminate the transfer. We will try again when the TxFIFO empty
* interrupt is received. * interrupt is received.
*/ */

View File

@ -1438,6 +1438,19 @@ static void stm32_epin_request(struct stm32_usbdev_s *priv,
empmsk |= OTG_DIEPEMPMSK(privep->epphy); empmsk |= OTG_DIEPEMPMSK(privep->epphy);
stm32_putreg(empmsk, STM32_OTG_DIEPEMPMSK); stm32_putreg(empmsk, STM32_OTG_DIEPEMPMSK);
#ifdef CONFIG_DEBUG_FEATURES
/* Check if the configured TXFIFO size is sufficient for a given
* request. If not, raise an assertion here.
*/
regval = stm32_putreg(regval, STM32_OTG_DIEPTXF(privep->epphy));
regval &= OTG_DIEPTXF_INEPTXFD_MASK;
regval >>= OTG_DIEPTXF_INEPTXFD_SHIFT;
uerr("EP%" PRId8 " TXLEN=%" PRId32 " nwords=%d\n",
privep->epphy, regval, nwords);
DEBUGASSERT(regval >= nwords);
#endif
/* Terminate the transfer. We will try again when the TxFIFO empty /* Terminate the transfer. We will try again when the TxFIFO empty
* interrupt is received. * interrupt is received.
*/ */

View File

@ -1401,6 +1401,19 @@ static void stm32_epin_request(struct stm32_usbdev_s *priv,
empmsk |= OTG_DIEPEMPMSK(privep->epphy); empmsk |= OTG_DIEPEMPMSK(privep->epphy);
stm32_putreg(empmsk, STM32_OTG_DIEPEMPMSK); stm32_putreg(empmsk, STM32_OTG_DIEPEMPMSK);
#ifdef CONFIG_DEBUG_FEATURES
/* Check if the configured TXFIFO size is sufficient for a given
* request. If not, raise an assertion here.
*/
regval = stm32_putreg(regval, STM32_OTG_DIEPTXF(privep->epphy));
regval &= OTG_DIEPTXF_INEPTXFD_MASK;
regval >>= OTG_DIEPTXF_INEPTXFD_SHIFT;
uerr("EP%" PRId8 " TXLEN=%" PRId32 " nwords=%d\n",
privep->epphy, regval, nwords);
DEBUGASSERT(regval >= nwords);
#endif
/* Terminate the transfer. We will try again when the TxFIFO empty /* Terminate the transfer. We will try again when the TxFIFO empty
* interrupt is received. * interrupt is received.
*/ */

View File

@ -1438,6 +1438,20 @@ static void stm32l4_epin_request(struct stm32l4_usbdev_s *priv,
empmsk |= OTGFS_DIEPEMPMSK(privep->epphy); empmsk |= OTGFS_DIEPEMPMSK(privep->epphy);
stm32l4_putreg(empmsk, STM32L4_OTGFS_DIEPEMPMSK); stm32l4_putreg(empmsk, STM32L4_OTGFS_DIEPEMPMSK);
#ifdef CONFIG_DEBUG_FEATURES
/* Check if the configured TXFIFO size is sufficient for a given
* request. If not, raise an assertion here.
*/
regval = stm32l4_putreg(regval,
STM32L4_OTG_DIEPTXF(privep->epphy));
regval &= OTGFS_DIEPTXF_INEPTXFD_MASK;
regval >>= OTGFS_DIEPTXF_INEPTXFD_SHIFT;
uerr("EP%" PRId8 " TXLEN=%" PRId32 " nwords=%d\n",
privep->epphy, regval, nwords);
DEBUGASSERT(regval >= nwords);
#endif
/* Terminate the transfer. We will try again when the TxFIFO empty /* Terminate the transfer. We will try again when the TxFIFO empty
* interrupt is received. * interrupt is received.
*/ */