diff options
author | qwang12 <qwang12@6f19259b-4bc3-4df7-8a09-765794883524> | 2008-05-29 06:22:28 +0000 |
---|---|---|
committer | qwang12 <qwang12@6f19259b-4bc3-4df7-8a09-765794883524> | 2008-05-29 06:22:28 +0000 |
commit | 6ea838c36053dd06c072a88c44a8e87dbc21b86c (patch) | |
tree | be6f9485195dd20ffa8b280ca42a92d69c8eb7a9 /EdkCompatibilityPkg/Compatibility | |
parent | fd4ae733751471fd934fe95e28a9ef4c1a48d560 (diff) | |
download | edk2-platforms-6ea838c36053dd06c072a88c44a8e87dbc21b86c.tar.xz |
Layer AllocateBuffer and FreeBuffer on the PciRootBridgeIo too.
git-svn-id: https://edk2.svn.sourceforge.net/svnroot/edk2/trunk/edk2@5307 6f19259b-4bc3-4df7-8a09-765794883524
Diffstat (limited to 'EdkCompatibilityPkg/Compatibility')
-rw-r--r-- | EdkCompatibilityPkg/Compatibility/DeviceIoToPciRootBridgeIoThunk/DeviceIoToPciRootBridgeIoThunk.c | 46 |
1 files changed, 34 insertions, 12 deletions
diff --git a/EdkCompatibilityPkg/Compatibility/DeviceIoToPciRootBridgeIoThunk/DeviceIoToPciRootBridgeIoThunk.c b/EdkCompatibilityPkg/Compatibility/DeviceIoToPciRootBridgeIoThunk/DeviceIoToPciRootBridgeIoThunk.c index 889c047c05..3c8c2a58f6 100644 --- a/EdkCompatibilityPkg/Compatibility/DeviceIoToPciRootBridgeIoThunk/DeviceIoToPciRootBridgeIoThunk.c +++ b/EdkCompatibilityPkg/Compatibility/DeviceIoToPciRootBridgeIoThunk/DeviceIoToPciRootBridgeIoThunk.c @@ -1,5 +1,8 @@ /** @file
-Module Layer Device I/O on top of PCI Root Bridge I/O (Segment 0)
+Module produces Device I/O on top of PCI Root Bridge I/O for Segment 0 only.
+This is a valid assumption because many of the EFI 1.02/EFI 1.10 systems that may have provided
+Device I/O were single segment platforms. The goal of the ECP is to provide compatibility with the
+drivers/apps that may have used Device I/O.
Device I/O is on list of deprecated protocols for UEFI 2.0 and later.
This module module layers Device I/O on top of PCI Root Bridge I/O (Segment 0)
@@ -451,7 +454,8 @@ PciRootBridgeIoNotificationEvent ( ASSERT_EFI_ERROR (Status);
//
- // We only install Device IO for PCI bus in Segment 0
+ // We only install Device IO for PCI bus in Segment 0.
+ // See the file description at @file for details.
//
if (PciRootBridgeIo->SegmentNumber != 0) {
continue;
@@ -1107,8 +1111,12 @@ DeviceIoAllocateBuffer ( IN OUT EFI_PHYSICAL_ADDRESS *PhysicalAddress
)
{
- EFI_STATUS Status;
- EFI_PHYSICAL_ADDRESS HostAddress;
+ EFI_STATUS Status;
+ EFI_PHYSICAL_ADDRESS HostAddress;
+ DEVICE_IO_PRIVATE_DATA *Private;
+ VOID *HostAddress2;
+
+ Private = DEVICE_IO_PRIVATE_DATA_FROM_THIS (This);
HostAddress = *PhysicalAddress;
@@ -1129,18 +1137,23 @@ DeviceIoAllocateBuffer ( HostAddress = MAX_COMMON_BUFFER;
}
- Status = gBS->AllocatePages (
- Type,
- MemoryType,
- Pages,
- &HostAddress
- );
+ HostAddress2 = (VOID *) (UINTN) (HostAddress);
+ Status = Private->PciRootBridgeIo->AllocateBuffer (
+ Private->PciRootBridgeIo,
+ Type,
+ MemoryType,
+ Pages,
+ &HostAddress2,
+ EFI_PCI_ATTRIBUTE_MEMORY_WRITE_COMBINE |
+ EFI_PCI_ATTRIBUTE_MEMORY_CACHED
+ );
+
if (EFI_ERROR (Status)) {
return Status;
}
- *PhysicalAddress = HostAddress;
+ *PhysicalAddress = (EFI_PHYSICAL_ADDRESS) (UINTN) HostAddress2;
return EFI_SUCCESS;
}
@@ -1195,10 +1208,19 @@ DeviceIoFreeBuffer ( IN EFI_PHYSICAL_ADDRESS HostAddress
)
{
+ DEVICE_IO_PRIVATE_DATA *Private;
+
+ Private = DEVICE_IO_PRIVATE_DATA_FROM_THIS (This);
+
if (((HostAddress & EFI_PAGE_MASK) != 0) || (Pages <= 0)) {
return EFI_INVALID_PARAMETER;
}
- return gBS->FreePages (HostAddress, Pages);
+ return Private->PciRootBridgeIo->FreeBuffer (
+ Private->PciRootBridgeIo,
+ Pages,
+ (VOID *) (UINTN) HostAddress
+ );
+
}
|