Commit 2251198b authored by Mathias Nyman's avatar Mathias Nyman Committed by Greg Kroah-Hartman

xhci: clean up event ring checks from inc_enq()

Remove the event ring related checks in inc_enq()

Host hardware is the producer of events on the event ring,
driver will not queue anything, or call inc_enq() for the
event ring.
Signed-off-by: default avatarMathias Nyman <mathias.nyman@linux.intel.com>
Signed-off-by: default avatarGreg Kroah-Hartman <gregkh@linuxfoundation.org>
parent f9c589e1
...@@ -199,50 +199,42 @@ static void inc_enq(struct xhci_hcd *xhci, struct xhci_ring *ring, ...@@ -199,50 +199,42 @@ static void inc_enq(struct xhci_hcd *xhci, struct xhci_ring *ring,
chain = le32_to_cpu(ring->enqueue->generic.field[3]) & TRB_CHAIN; chain = le32_to_cpu(ring->enqueue->generic.field[3]) & TRB_CHAIN;
/* If this is not event ring, there is one less usable TRB */ /* If this is not event ring, there is one less usable TRB */
if (ring->type != TYPE_EVENT && if (!last_trb(xhci, ring, ring->enq_seg, ring->enqueue))
!last_trb(xhci, ring, ring->enq_seg, ring->enqueue))
ring->num_trbs_free--; ring->num_trbs_free--;
next = ++(ring->enqueue); next = ++(ring->enqueue);
ring->enq_updates++; ring->enq_updates++;
/* Update the dequeue pointer further if that was a link TRB or we're at /* Update the dequeue pointer further if that was a link TRB */
* the end of an event ring segment (which doesn't have link TRBS)
*/
while (last_trb(xhci, ring, ring->enq_seg, next)) { while (last_trb(xhci, ring, ring->enq_seg, next)) {
if (ring->type != TYPE_EVENT) {
/*
* If the caller doesn't plan on enqueueing more
* TDs before ringing the doorbell, then we
* don't want to give the link TRB to the
* hardware just yet. We'll give the link TRB
* back in prepare_ring() just before we enqueue
* the TD at the top of the ring.
*/
if (!chain && !more_trbs_coming)
break;
/* If we're not dealing with 0.95 hardware or /*
* isoc rings on AMD 0.96 host, * If the caller doesn't plan on enqueueing more TDs before
* carry over the chain bit of the previous TRB * ringing the doorbell, then we don't want to give the link TRB
* (which may mean the chain bit is cleared). * to the hardware just yet. We'll give the link TRB back in
*/ * prepare_ring() just before we enqueue the TD at the top of
if (!(ring->type == TYPE_ISOC && * the ring.
(xhci->quirks & XHCI_AMD_0x96_HOST)) */
&& !xhci_link_trb_quirk(xhci)) { if (!chain && !more_trbs_coming)
next->link.control &= break;
cpu_to_le32(~TRB_CHAIN);
next->link.control |=
cpu_to_le32(chain);
}
/* Give this link TRB to the hardware */
wmb();
next->link.control ^= cpu_to_le32(TRB_CYCLE);
/* Toggle the cycle bit after the last ring segment. */ /* If we're not dealing with 0.95 hardware or isoc rings on
if (last_trb_on_last_seg(xhci, ring, ring->enq_seg, next)) { * AMD 0.96 host, carry over the chain bit of the previous TRB
ring->cycle_state ^= 1; * (which may mean the chain bit is cleared).
} */
if (!(ring->type == TYPE_ISOC &&
(xhci->quirks & XHCI_AMD_0x96_HOST)) &&
!xhci_link_trb_quirk(xhci)) {
next->link.control &= cpu_to_le32(~TRB_CHAIN);
next->link.control |= cpu_to_le32(chain);
} }
/* Give this link TRB to the hardware */
wmb();
next->link.control ^= cpu_to_le32(TRB_CYCLE);
/* Toggle the cycle bit after the last ring segment. */
if (last_trb_on_last_seg(xhci, ring, ring->enq_seg, next))
ring->cycle_state ^= 1;
ring->enq_seg = ring->enq_seg->next; ring->enq_seg = ring->enq_seg->next;
ring->enqueue = ring->enq_seg->trbs; ring->enqueue = ring->enq_seg->trbs;
next = ring->enqueue; next = ring->enqueue;
......
Markdown is supported
0%
or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment