stm32f7:USB otgdev Ensure proper EP state

Repeated automated sercon, serdis on VBUS proved to fail
   for CDCACM DATA IN (device Serial TX). The root cause was
   that the EP was left active after disconnect. This resulted
   in the first serial write falling to kick-off the EP IN request.
   That should restart the EP ISR.
This commit is contained in:
David Sidrane 2021-09-09 07:13:23 -07:00 committed by Anthony Merlino
parent 60b2a0e2a0
commit 21f049b43a

View File

@ -2121,6 +2121,8 @@ static void stm32_usbreset(struct stm32_usbdev_s *priv)
/* Reset IN endpoint status */
privep->stalled = false;
privep->active = false;
privep->zlp = false;
/* Return read requests to the class implementation */
@ -2130,6 +2132,8 @@ static void stm32_usbreset(struct stm32_usbdev_s *priv)
/* Reset endpoint status */
privep->stalled = false;
privep->active = false;
privep->zlp = false;
}
stm32_putreg(0xffffffff, STM32_OTG_DAINT);
@ -4017,8 +4021,10 @@ static int stm32_epout_configure(FAR struct stm32_ep_s *privep,
/* Save the endpoint configuration */
privep->ep.maxpacket = maxpacket;
privep->eptype = eptype;
privep->stalled = false;
privep->eptype = eptype;
privep->stalled = false;
privep->active = false;
privep->zlp = false;
}
/* Enable the interrupt for this endpoint */
@ -4114,8 +4120,10 @@ static int stm32_epin_configure(FAR struct stm32_ep_s *privep,
/* Save the endpoint configuration */
privep->ep.maxpacket = maxpacket;
privep->eptype = eptype;
privep->stalled = false;
privep->eptype = eptype;
privep->stalled = false;
privep->active = false;
privep->zlp = false;
}
/* Enable the interrupt for this endpoint */