summaryrefslogtreecommitdiffstats
path: root/drivers/memory
diff options
context:
space:
mode:
authorVardan Mikayelyan <mvardan@synopsys.com>2016-05-25 18:07:14 -0700
committerFelipe Balbi <felipe.balbi@linux.intel.com>2016-06-21 10:49:54 +0300
commit5321922cb6fa0f513fdd8ce73b281f4b9957886b (patch)
tree3108da61d85848e698a9b22b4b33353309afd4f1 /drivers/memory
parent41cc4cd2716fa6d18a1a09d740ea075adecfa7dd (diff)
downloadlinux-5321922cb6fa0f513fdd8ce73b281f4b9957886b.tar.gz
linux-5321922cb6fa0f513fdd8ce73b281f4b9957886b.tar.bz2
linux-5321922cb6fa0f513fdd8ce73b281f4b9957886b.zip
usb: dwc2: gadget: Add OUTTKNEPDIS and NAKINTRPT handlers
NAKINTRPT interrupt is starting point for isoc-in transfer, synchronization done with first in token received from host, core asserts this interrupt when responds with 0 length data to in token, received from host. The first IN token is asynchronous for device - device does not know when first one token will arrive from host. On first token arrival HW generates 2 interrupts: 'in token received while FIFO empty' and 'NAK'. NAK interrupt for ISOC in means that token has arrived and ZLP was sent in response to that as there was no data in FIFO. SW is basing on this interrupt to obtain frame in which token has come and then based on the interval calculates next frame for transfer. OUTTKNEPDIS interrupt is starting point for isoc-out transfer, synchronization done with first out token received from host while corresponding ep is disabled. For OUTs the reason is same - device does not know initial frame in which out token will come. For this HW generates OUTTKNEPDIS - out token is received while EP is disabled. Upon getting this interrupt SW starts calculation for next transfer frame. Tested-by: John Keeping <john@metanate.com> Signed-off-by: Vardan Mikayelyan <mvardan@synopsys.com> Signed-off-by: John Youn <johnyoun@synopsys.com> Signed-off-by: Felipe Balbi <felipe.balbi@linux.intel.com>
Diffstat (limited to 'drivers/memory')
0 files changed, 0 insertions, 0 deletions