mirror of https://github.com/acidanthera/audk.git
MdeModulePkg/XhciDxe: Use BaseLib linked list iteration macros
REF:https://bugzilla.tianocore.org/show_bug.cgi?id=1959 Replaces usage of the linked list iteration macros defined in Xhci.h with the common definition in BaseLib.h. Cc: Dandan Bi <dandan.bi@intel.com> Cc: Hao A Wu <hao.a.wu@intel.com> Cc: Jian J Wang <jian.j.wang@intel.com> Cc: Liming Gao <liming.gao@intel.com> Cc: Ray Ni <ray.ni@intel.com> Cc: Sean Brogan <sean.brogan@microsoft.com> Signed-off-by: Michael Kubacki <michael.kubacki@microsoft.com> Reviewed-by: Guomin Jiang <guomin.jiang@intel.com> Reviewed-by: Hao A Wu <hao.a.wu@intel.com> Reviewed-by: Liming Gao <liming.gao@intel.com> Reviewed-by: Bret Barkelew <bret.barkelew@microsoft.com>
This commit is contained in:
parent
309809455a
commit
dc528558c9
|
@ -3,6 +3,7 @@
|
||||||
Provides some data structure definitions used by the XHCI host controller driver.
|
Provides some data structure definitions used by the XHCI host controller driver.
|
||||||
|
|
||||||
Copyright (c) 2011 - 2017, Intel Corporation. All rights reserved.<BR>
|
Copyright (c) 2011 - 2017, Intel Corporation. All rights reserved.<BR>
|
||||||
|
Copyright (c) Microsoft Corporation.<BR>
|
||||||
SPDX-License-Identifier: BSD-2-Clause-Patent
|
SPDX-License-Identifier: BSD-2-Clause-Patent
|
||||||
|
|
||||||
**/
|
**/
|
||||||
|
@ -82,14 +83,6 @@ typedef struct _USB_DEV_CONTEXT USB_DEV_CONTEXT;
|
||||||
#define INT_INTER 3
|
#define INT_INTER 3
|
||||||
#define INT_INTER_ASYNC 4
|
#define INT_INTER_ASYNC 4
|
||||||
|
|
||||||
//
|
|
||||||
// Iterate through the double linked list. This is delete-safe.
|
|
||||||
// Don't touch NextEntry
|
|
||||||
//
|
|
||||||
#define EFI_LIST_FOR_EACH_SAFE(Entry, NextEntry, ListHead) \
|
|
||||||
for (Entry = (ListHead)->ForwardLink, NextEntry = Entry->ForwardLink;\
|
|
||||||
Entry != (ListHead); Entry = NextEntry, NextEntry = Entry->ForwardLink)
|
|
||||||
|
|
||||||
#define EFI_LIST_CONTAINER(Entry, Type, Field) BASE_CR(Entry, Type, Field)
|
#define EFI_LIST_CONTAINER(Entry, Type, Field) BASE_CR(Entry, Type, Field)
|
||||||
|
|
||||||
#define XHC_LOW_32BIT(Addr64) ((UINT32)(((UINTN)(Addr64)) & 0xFFFFFFFF))
|
#define XHC_LOW_32BIT(Addr64) ((UINT32)(((UINTN)(Addr64)) & 0xFFFFFFFF))
|
||||||
|
|
|
@ -3,6 +3,7 @@
|
||||||
XHCI transfer scheduling routines.
|
XHCI transfer scheduling routines.
|
||||||
|
|
||||||
Copyright (c) 2011 - 2018, Intel Corporation. All rights reserved.<BR>
|
Copyright (c) 2011 - 2018, Intel Corporation. All rights reserved.<BR>
|
||||||
|
Copyright (c) Microsoft Corporation.<BR>
|
||||||
SPDX-License-Identifier: BSD-2-Clause-Patent
|
SPDX-License-Identifier: BSD-2-Clause-Patent
|
||||||
|
|
||||||
**/
|
**/
|
||||||
|
@ -1051,7 +1052,7 @@ IsAsyncIntTrb (
|
||||||
LIST_ENTRY *Next;
|
LIST_ENTRY *Next;
|
||||||
URB *CheckedUrb;
|
URB *CheckedUrb;
|
||||||
|
|
||||||
EFI_LIST_FOR_EACH_SAFE (Entry, Next, &Xhc->AsyncIntTransfers) {
|
BASE_LIST_FOR_EACH_SAFE (Entry, Next, &Xhc->AsyncIntTransfers) {
|
||||||
CheckedUrb = EFI_LIST_CONTAINER (Entry, URB, UrbList);
|
CheckedUrb = EFI_LIST_CONTAINER (Entry, URB, UrbList);
|
||||||
if (IsTransferRingTrb (Xhc, Trb, CheckedUrb)) {
|
if (IsTransferRingTrb (Xhc, Trb, CheckedUrb)) {
|
||||||
*Urb = CheckedUrb;
|
*Urb = CheckedUrb;
|
||||||
|
@ -1346,7 +1347,7 @@ XhciDelAsyncIntTransfer (
|
||||||
|
|
||||||
Urb = NULL;
|
Urb = NULL;
|
||||||
|
|
||||||
EFI_LIST_FOR_EACH_SAFE (Entry, Next, &Xhc->AsyncIntTransfers) {
|
BASE_LIST_FOR_EACH_SAFE (Entry, Next, &Xhc->AsyncIntTransfers) {
|
||||||
Urb = EFI_LIST_CONTAINER (Entry, URB, UrbList);
|
Urb = EFI_LIST_CONTAINER (Entry, URB, UrbList);
|
||||||
if ((Urb->Ep.BusAddr == BusAddr) &&
|
if ((Urb->Ep.BusAddr == BusAddr) &&
|
||||||
(Urb->Ep.EpAddr == EpNum) &&
|
(Urb->Ep.EpAddr == EpNum) &&
|
||||||
|
@ -1386,7 +1387,7 @@ XhciDelAllAsyncIntTransfers (
|
||||||
URB *Urb;
|
URB *Urb;
|
||||||
EFI_STATUS Status;
|
EFI_STATUS Status;
|
||||||
|
|
||||||
EFI_LIST_FOR_EACH_SAFE (Entry, Next, &Xhc->AsyncIntTransfers) {
|
BASE_LIST_FOR_EACH_SAFE (Entry, Next, &Xhc->AsyncIntTransfers) {
|
||||||
Urb = EFI_LIST_CONTAINER (Entry, URB, UrbList);
|
Urb = EFI_LIST_CONTAINER (Entry, URB, UrbList);
|
||||||
|
|
||||||
//
|
//
|
||||||
|
@ -1578,7 +1579,7 @@ XhcMonitorAsyncRequests (
|
||||||
|
|
||||||
Xhc = (USB_XHCI_INSTANCE*) Context;
|
Xhc = (USB_XHCI_INSTANCE*) Context;
|
||||||
|
|
||||||
EFI_LIST_FOR_EACH_SAFE (Entry, Next, &Xhc->AsyncIntTransfers) {
|
BASE_LIST_FOR_EACH_SAFE (Entry, Next, &Xhc->AsyncIntTransfers) {
|
||||||
Urb = EFI_LIST_CONTAINER (Entry, URB, UrbList);
|
Urb = EFI_LIST_CONTAINER (Entry, URB, UrbList);
|
||||||
|
|
||||||
//
|
//
|
||||||
|
|
Loading…
Reference in New Issue