1. NAME▲
usb_ep_set_halt - sets the endpoint halt feature.
2. SYNOPSIS ▲
int usb_ep_set_halt(struct usb_ep * ep );
3. ARGUMENTS ▲
ep
the non-isochronous endpoint being stalled
4. DESCRIPTION ▲
Use this to stall an endpoint, perhaps as an error report. Except for control endpoints, the endpoint stays halted (will not stream any data) until the host clears this feature; drivers may need to empty the endpointAqs request queue first, to make sure no inappropriate transfers happen.
Note that while an endpoint CLEAR_FEATURE will be invisible to the gadget driver, a SET_INTERFACE will not be. To reset endpoints for the current altsetting, see usb_ep_clear_halt. When switching altsettings, itAqs simplest to use usb_ep_enable or usb_ep_disable for the endpoints.
Returns zero, or a negative error code. On success, this call sets underlying hardware state that blocks data transfers. Attempts to halt IN endpoints will fail (returning -EAGAIN) if any transfer requests are still queued, or if the controller hardware (usually a FIFO) still holds bytes that the host hasnAqt collected.
5. AUTHOR ▲
David Brownell <>
Author.
6. COPYRIGHT ▲