mirror of
https://github.com/edk2-porting/linux-next.git
synced 2025-01-14 08:34:02 +08:00
xhci: use and add separate function for checking for link trbs
Add a new is_link_trb() function that only checks for link trbs. We want to split generic last_trb() function which is used for both event rings without link trbs, and endpoint and command rings with links. This will allow us to easier check for link trbs added mid segments. Signed-off-by: Mathias Nyman <mathias.nyman@linux.intel.com> Signed-off-by: Greg Kroah-Hartman <gregkh@linuxfoundation.org>
This commit is contained in:
parent
2251198bef
commit
2d98ef406f
@ -115,6 +115,11 @@ static int last_trb(struct xhci_hcd *xhci, struct xhci_ring *ring,
|
|||||||
return TRB_TYPE_LINK_LE32(trb->link.control);
|
return TRB_TYPE_LINK_LE32(trb->link.control);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
static bool trb_is_link(union xhci_trb *trb)
|
||||||
|
{
|
||||||
|
return TRB_TYPE_LINK_LE32(trb->link.control);
|
||||||
|
}
|
||||||
|
|
||||||
static int enqueue_is_link_trb(struct xhci_ring *ring)
|
static int enqueue_is_link_trb(struct xhci_ring *ring)
|
||||||
{
|
{
|
||||||
struct xhci_link_trb *link = &ring->enqueue->link;
|
struct xhci_link_trb *link = &ring->enqueue->link;
|
||||||
@ -130,7 +135,7 @@ static void next_trb(struct xhci_hcd *xhci,
|
|||||||
struct xhci_segment **seg,
|
struct xhci_segment **seg,
|
||||||
union xhci_trb **trb)
|
union xhci_trb **trb)
|
||||||
{
|
{
|
||||||
if (last_trb(xhci, ring, *seg, *trb)) {
|
if (trb_is_link(*trb)) {
|
||||||
*seg = (*seg)->next;
|
*seg = (*seg)->next;
|
||||||
*trb = ((*seg)->trbs);
|
*trb = ((*seg)->trbs);
|
||||||
} else {
|
} else {
|
||||||
@ -150,8 +155,7 @@ static void inc_deq(struct xhci_hcd *xhci, struct xhci_ring *ring)
|
|||||||
* If this is not event ring, and the dequeue pointer
|
* If this is not event ring, and the dequeue pointer
|
||||||
* is not on a link TRB, there is one more usable TRB
|
* is not on a link TRB, there is one more usable TRB
|
||||||
*/
|
*/
|
||||||
if (ring->type != TYPE_EVENT &&
|
if (ring->type != TYPE_EVENT && !trb_is_link(ring->dequeue))
|
||||||
!last_trb(xhci, ring, ring->deq_seg, ring->dequeue))
|
|
||||||
ring->num_trbs_free++;
|
ring->num_trbs_free++;
|
||||||
|
|
||||||
do {
|
do {
|
||||||
@ -199,13 +203,13 @@ 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 (!last_trb(xhci, ring, ring->enq_seg, ring->enqueue))
|
if (!trb_is_link(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 */
|
/* Update the dequeue pointer further if that was a link TRB */
|
||||||
while (last_trb(xhci, ring, ring->enq_seg, next)) {
|
while (trb_is_link(next)) {
|
||||||
|
|
||||||
/*
|
/*
|
||||||
* If the caller doesn't plan on enqueueing more TDs before
|
* If the caller doesn't plan on enqueueing more TDs before
|
||||||
@ -940,7 +944,7 @@ static void update_ring_for_set_deq_completion(struct xhci_hcd *xhci,
|
|||||||
* the dequeue pointer one segment further, or we'll jump off
|
* the dequeue pointer one segment further, or we'll jump off
|
||||||
* the segment into la-la-land.
|
* the segment into la-la-land.
|
||||||
*/
|
*/
|
||||||
if (last_trb(xhci, ep_ring, ep_ring->deq_seg, ep_ring->dequeue)) {
|
if (trb_is_link(ep_ring->dequeue)) {
|
||||||
ep_ring->deq_seg = ep_ring->deq_seg->next;
|
ep_ring->deq_seg = ep_ring->deq_seg->next;
|
||||||
ep_ring->dequeue = ep_ring->deq_seg->trbs;
|
ep_ring->dequeue = ep_ring->deq_seg->trbs;
|
||||||
}
|
}
|
||||||
@ -949,8 +953,7 @@ static void update_ring_for_set_deq_completion(struct xhci_hcd *xhci,
|
|||||||
/* We have more usable TRBs */
|
/* We have more usable TRBs */
|
||||||
ep_ring->num_trbs_free++;
|
ep_ring->num_trbs_free++;
|
||||||
ep_ring->dequeue++;
|
ep_ring->dequeue++;
|
||||||
if (last_trb(xhci, ep_ring, ep_ring->deq_seg,
|
if (trb_is_link(ep_ring->dequeue)) {
|
||||||
ep_ring->dequeue)) {
|
|
||||||
if (ep_ring->dequeue ==
|
if (ep_ring->dequeue ==
|
||||||
dev->eps[ep_index].queued_deq_ptr)
|
dev->eps[ep_index].queued_deq_ptr)
|
||||||
break;
|
break;
|
||||||
@ -2898,7 +2901,7 @@ static int prepare_ring(struct xhci_hcd *xhci, struct xhci_ring *ep_ring,
|
|||||||
|
|
||||||
next = ring->enqueue;
|
next = ring->enqueue;
|
||||||
|
|
||||||
while (last_trb(xhci, ring, ring->enq_seg, next)) {
|
while (trb_is_link(next)) {
|
||||||
/* If we're not dealing with 0.95 hardware or isoc rings
|
/* If we're not dealing with 0.95 hardware or isoc rings
|
||||||
* on AMD 0.96 host, clear the chain bit.
|
* on AMD 0.96 host, clear the chain bit.
|
||||||
*/
|
*/
|
||||||
@ -3287,8 +3290,7 @@ int xhci_queue_bulk_tx(struct xhci_hcd *xhci, gfp_t mem_flags,
|
|||||||
*/
|
*/
|
||||||
if (enqd_len + trb_buff_len < full_len) {
|
if (enqd_len + trb_buff_len < full_len) {
|
||||||
field |= TRB_CHAIN;
|
field |= TRB_CHAIN;
|
||||||
if (last_trb(xhci, ring, ring->enq_seg,
|
if (trb_is_link(ring->enqueue + 1)) {
|
||||||
ring->enqueue + 1)) {
|
|
||||||
if (xhci_align_td(xhci, urb, enqd_len,
|
if (xhci_align_td(xhci, urb, enqd_len,
|
||||||
&trb_buff_len,
|
&trb_buff_len,
|
||||||
ring->enq_seg)) {
|
ring->enq_seg)) {
|
||||||
|
Loading…
Reference in New Issue
Block a user