Terminate the Capability List traversal if the Capability Pointer is less than 0x40, or the Capability Pointer is not aligned on a 32-bit boundary.
git-svn-id: https://edk2.svn.sourceforge.net/svnroot/edk2/trunk/edk2@8376 6f19259b-4bc3-4df7-8a09-765794883524
This commit is contained in:
@ -153,11 +153,7 @@ LocateCapabilityRegBlock (
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
while (CapabilityPtr > 0x3F) {
|
while ((CapabilityPtr >= 0x40) && ((CapabilityPtr & 0x03) == 0x00)) {
|
||||||
//
|
|
||||||
// Mask it to DWORD alignment per PCI spec
|
|
||||||
//
|
|
||||||
CapabilityPtr &= 0xFC;
|
|
||||||
PciIoRead (
|
PciIoRead (
|
||||||
&PciIoDevice->PciIo,
|
&PciIoDevice->PciIo,
|
||||||
EfiPciIoWidthUint16,
|
EfiPciIoWidthUint16,
|
||||||
|
Reference in New Issue
Block a user