stm32f4: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:
parent
e488f0047d
commit
41e1696b27
@ -2090,6 +2090,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 */
|
||||
|
||||
@ -2099,6 +2101,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_OTGFS_DAINT);
|
||||
@ -4003,6 +4007,8 @@ static int stm32_epout_configure(FAR struct stm32_ep_s *privep,
|
||||
privep->ep.maxpacket = maxpacket;
|
||||
privep->eptype = eptype;
|
||||
privep->stalled = false;
|
||||
privep->active = false;
|
||||
privep->zlp = false;
|
||||
}
|
||||
|
||||
/* Enable the interrupt for this endpoint */
|
||||
@ -4101,6 +4107,8 @@ static int stm32_epin_configure(FAR struct stm32_ep_s *privep,
|
||||
privep->ep.maxpacket = maxpacket;
|
||||
privep->eptype = eptype;
|
||||
privep->stalled = false;
|
||||
privep->active = false;
|
||||
privep->zlp = false;
|
||||
}
|
||||
|
||||
/* Enable the interrupt for this endpoint */
|
||||
|
Loading…
Reference in New Issue
Block a user