mirror of https://github.com/acidanthera/audk.git
Updated the Runtime Driver to use the MDE libs for cache flush and removed local copy of Cache flush code. Updated FPD files that include Runtime driver as a new lib was added to Runtime Driver for the cache flush. Removed Cache Flush routine from EDK DXE SAL Lib.
Cleaned up BaseLib IPF cache routines to only Flush ranges when needed and not to flush the entire cache. git-svn-id: https://edk2.svn.sourceforge.net/svnroot/edk2/trunk/edk2@1811 6f19259b-4bc3-4df7-8a09-765794883524
This commit is contained in:
parent
b077fb7492
commit
92ea7f231b
|
@ -1038,6 +1038,7 @@
|
||||||
</ModuleSA>
|
</ModuleSA>
|
||||||
<ModuleSA SupArchList="IA32" PackageGuid="68169ab0-d41b-4009-9060-292c253ac43d" ModuleGuid="B601F8C4-43B7-4784-95B1-F4226CB40CEE">
|
<ModuleSA SupArchList="IA32" PackageGuid="68169ab0-d41b-4009-9060-292c253ac43d" ModuleGuid="B601F8C4-43B7-4784-95B1-F4226CB40CEE">
|
||||||
<Libraries>
|
<Libraries>
|
||||||
|
<Instance ModuleGuid="123dd843-57c9-4158-8418-ce68b3944ce7" PackageGuid="5e0e9358-46b6-4ae2-8218-4ab8b9bbdcec"/>
|
||||||
<Instance ModuleGuid="19cbbb97-ff61-45ff-8c3f-dfa66dd118c8" PackageGuid="5e0e9358-46b6-4ae2-8218-4ab8b9bbdcec"/>
|
<Instance ModuleGuid="19cbbb97-ff61-45ff-8c3f-dfa66dd118c8" PackageGuid="5e0e9358-46b6-4ae2-8218-4ab8b9bbdcec"/>
|
||||||
<Instance ModuleGuid="ff5c7a2c-ab7a-4366-8616-11c6e53247b6" PackageGuid="5e0e9358-46b6-4ae2-8218-4ab8b9bbdcec"/>
|
<Instance ModuleGuid="ff5c7a2c-ab7a-4366-8616-11c6e53247b6" PackageGuid="5e0e9358-46b6-4ae2-8218-4ab8b9bbdcec"/>
|
||||||
<Instance ModuleGuid="27d67720-ea68-48ae-93da-a3a074c90e30" PackageGuid="5e0e9358-46b6-4ae2-8218-4ab8b9bbdcec"/>
|
<Instance ModuleGuid="27d67720-ea68-48ae-93da-a3a074c90e30" PackageGuid="5e0e9358-46b6-4ae2-8218-4ab8b9bbdcec"/>
|
||||||
|
@ -6201,6 +6202,7 @@
|
||||||
</ModuleSA>
|
</ModuleSA>
|
||||||
<ModuleSA SupArchList="X64" PackageGuid="68169ab0-d41b-4009-9060-292c253ac43d" ModuleGuid="B601F8C4-43B7-4784-95B1-F4226CB40CEE">
|
<ModuleSA SupArchList="X64" PackageGuid="68169ab0-d41b-4009-9060-292c253ac43d" ModuleGuid="B601F8C4-43B7-4784-95B1-F4226CB40CEE">
|
||||||
<Libraries>
|
<Libraries>
|
||||||
|
<Instance ModuleGuid="123dd843-57c9-4158-8418-ce68b3944ce7" PackageGuid="5e0e9358-46b6-4ae2-8218-4ab8b9bbdcec"/>
|
||||||
<Instance ModuleGuid="19cbbb97-ff61-45ff-8c3f-dfa66dd118c8" PackageGuid="5e0e9358-46b6-4ae2-8218-4ab8b9bbdcec"/>
|
<Instance ModuleGuid="19cbbb97-ff61-45ff-8c3f-dfa66dd118c8" PackageGuid="5e0e9358-46b6-4ae2-8218-4ab8b9bbdcec"/>
|
||||||
<Instance ModuleGuid="ff5c7a2c-ab7a-4366-8616-11c6e53247b6" PackageGuid="5e0e9358-46b6-4ae2-8218-4ab8b9bbdcec"/>
|
<Instance ModuleGuid="ff5c7a2c-ab7a-4366-8616-11c6e53247b6" PackageGuid="5e0e9358-46b6-4ae2-8218-4ab8b9bbdcec"/>
|
||||||
<Instance ModuleGuid="27d67720-ea68-48ae-93da-a3a074c90e30" PackageGuid="5e0e9358-46b6-4ae2-8218-4ab8b9bbdcec"/>
|
<Instance ModuleGuid="27d67720-ea68-48ae-93da-a3a074c90e30" PackageGuid="5e0e9358-46b6-4ae2-8218-4ab8b9bbdcec"/>
|
||||||
|
@ -10223,6 +10225,7 @@
|
||||||
</ModuleSA>
|
</ModuleSA>
|
||||||
<ModuleSA SupArchList="IPF" PackageGuid="68169ab0-d41b-4009-9060-292c253ac43d" ModuleGuid="B601F8C4-43B7-4784-95B1-F4226CB40CEE">
|
<ModuleSA SupArchList="IPF" PackageGuid="68169ab0-d41b-4009-9060-292c253ac43d" ModuleGuid="B601F8C4-43B7-4784-95B1-F4226CB40CEE">
|
||||||
<Libraries>
|
<Libraries>
|
||||||
|
<Instance ModuleGuid="123dd843-57c9-4158-8418-ce68b3944ce7" PackageGuid="5e0e9358-46b6-4ae2-8218-4ab8b9bbdcec"/>
|
||||||
<Instance ModuleGuid="19cbbb97-ff61-45ff-8c3f-dfa66dd118c8" PackageGuid="5e0e9358-46b6-4ae2-8218-4ab8b9bbdcec"/>
|
<Instance ModuleGuid="19cbbb97-ff61-45ff-8c3f-dfa66dd118c8" PackageGuid="5e0e9358-46b6-4ae2-8218-4ab8b9bbdcec"/>
|
||||||
<Instance ModuleGuid="ff5c7a2c-ab7a-4366-8616-11c6e53247b6" PackageGuid="5e0e9358-46b6-4ae2-8218-4ab8b9bbdcec"/>
|
<Instance ModuleGuid="ff5c7a2c-ab7a-4366-8616-11c6e53247b6" PackageGuid="5e0e9358-46b6-4ae2-8218-4ab8b9bbdcec"/>
|
||||||
<Instance ModuleGuid="27d67720-ea68-48ae-93da-a3a074c90e30" PackageGuid="5e0e9358-46b6-4ae2-8218-4ab8b9bbdcec"/>
|
<Instance ModuleGuid="27d67720-ea68-48ae-93da-a3a074c90e30" PackageGuid="5e0e9358-46b6-4ae2-8218-4ab8b9bbdcec"/>
|
||||||
|
|
|
@ -137,12 +137,5 @@ GetEsalEntryPoint (
|
||||||
)
|
)
|
||||||
;
|
;
|
||||||
|
|
||||||
VOID
|
|
||||||
EFIAPI
|
|
||||||
SalFlushCache (
|
|
||||||
IN EFI_PHYSICAL_ADDRESS Start,
|
|
||||||
IN UINT64 Length
|
|
||||||
)
|
|
||||||
;
|
|
||||||
|
|
||||||
#endif
|
#endif
|
||||||
|
|
|
@ -35,7 +35,6 @@
|
||||||
<SourceFiles>
|
<SourceFiles>
|
||||||
<Filename SupArchList="IPF">Ipf/EsalServiceLib.c</Filename>
|
<Filename SupArchList="IPF">Ipf/EsalServiceLib.c</Filename>
|
||||||
<Filename SupArchList="IPF">Ipf/AsmEsalServiceLib.s</Filename>
|
<Filename SupArchList="IPF">Ipf/AsmEsalServiceLib.s</Filename>
|
||||||
<Filename SupArchList="IPF">Ipf/AsmIpfCpuCache.s</Filename>
|
|
||||||
</SourceFiles>
|
</SourceFiles>
|
||||||
<PackageDependencies>
|
<PackageDependencies>
|
||||||
<Package PackageGuid="5e0e9358-46b6-4ae2-8218-4ab8b9bbdcec"/>
|
<Package PackageGuid="5e0e9358-46b6-4ae2-8218-4ab8b9bbdcec"/>
|
||||||
|
|
|
@ -468,7 +468,7 @@ RuntimeDriverSetVirtualAddressMap (
|
||||||
RuntimeImage->RelocationData
|
RuntimeImage->RelocationData
|
||||||
);
|
);
|
||||||
|
|
||||||
FlushCpuCache (RuntimeImage->ImageBase, (UINT64)RuntimeImage->ImageSize);
|
InvalidateInstructionCacheRange ((VOID *)(UINTN)RuntimeImage->ImageBase, (UINTN)RuntimeImage->ImageSize);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
//
|
//
|
||||||
|
|
|
@ -50,8 +50,7 @@ typedef struct {
|
||||||
VOID
|
VOID
|
||||||
RelocatePeImageForRuntime (
|
RelocatePeImageForRuntime (
|
||||||
RUNTIME_IMAGE_RELOCATION_DATA *Image
|
RUNTIME_IMAGE_RELOCATION_DATA *Image
|
||||||
)
|
);
|
||||||
;
|
|
||||||
|
|
||||||
EFI_STATUS
|
EFI_STATUS
|
||||||
EFIAPI
|
EFIAPI
|
||||||
|
@ -59,8 +58,7 @@ RuntimeDriverCalculateCrc32 (
|
||||||
IN VOID *Data,
|
IN VOID *Data,
|
||||||
IN UINTN DataSize,
|
IN UINTN DataSize,
|
||||||
OUT UINT32 *CrcOut
|
OUT UINT32 *CrcOut
|
||||||
)
|
);
|
||||||
;
|
|
||||||
|
|
||||||
EFI_STATUS
|
EFI_STATUS
|
||||||
EFIAPI
|
EFIAPI
|
||||||
|
@ -69,8 +67,7 @@ RuntimeDriverRegisterImage (
|
||||||
IN EFI_PHYSICAL_ADDRESS ImageBase,
|
IN EFI_PHYSICAL_ADDRESS ImageBase,
|
||||||
IN UINTN ImageSize,
|
IN UINTN ImageSize,
|
||||||
IN VOID *RelocationData
|
IN VOID *RelocationData
|
||||||
)
|
);
|
||||||
;
|
|
||||||
|
|
||||||
EFI_STATUS
|
EFI_STATUS
|
||||||
EFIAPI
|
EFIAPI
|
||||||
|
@ -81,40 +78,27 @@ RuntimeDriverRegisterEvent (
|
||||||
IN EFI_EVENT_NOTIFY NotifyFunction,
|
IN EFI_EVENT_NOTIFY NotifyFunction,
|
||||||
IN VOID *NotifyContext,
|
IN VOID *NotifyContext,
|
||||||
IN EFI_EVENT *Event
|
IN EFI_EVENT *Event
|
||||||
)
|
);
|
||||||
;
|
|
||||||
|
|
||||||
EFI_STATUS
|
EFI_STATUS
|
||||||
EFIAPI
|
EFIAPI
|
||||||
RuntimeDriverConvertPointer (
|
RuntimeDriverConvertPointer (
|
||||||
IN UINTN DebugDisposition,
|
IN UINTN DebugDisposition,
|
||||||
IN OUT VOID **ConvertAddress
|
IN OUT VOID **ConvertAddress
|
||||||
)
|
);
|
||||||
;
|
|
||||||
|
|
||||||
VOID
|
VOID
|
||||||
RuntimeDriverInitializeCrc32Table (
|
RuntimeDriverInitializeCrc32Table (
|
||||||
VOID
|
VOID
|
||||||
)
|
);
|
||||||
;
|
|
||||||
|
|
||||||
EFI_STATUS
|
EFI_STATUS
|
||||||
EFIAPI
|
EFIAPI
|
||||||
RuntimeDriverInitialize (
|
RuntimeDriverInitialize (
|
||||||
IN EFI_HANDLE ImageHandle,
|
IN EFI_HANDLE ImageHandle,
|
||||||
IN EFI_SYSTEM_TABLE *SystemTable
|
IN EFI_SYSTEM_TABLE *SystemTable
|
||||||
)
|
);
|
||||||
;
|
|
||||||
|
|
||||||
|
|
||||||
//
|
|
||||||
// Cache Flush Routine.
|
|
||||||
//
|
|
||||||
EFI_STATUS
|
|
||||||
FlushCpuCache (
|
|
||||||
IN EFI_PHYSICAL_ADDRESS Start,
|
|
||||||
IN UINT64 Length
|
|
||||||
)
|
|
||||||
;
|
|
||||||
|
|
||||||
#endif
|
#endif
|
||||||
|
|
|
@ -49,17 +49,15 @@
|
||||||
<LibraryClass Usage="ALWAYS_CONSUMED">
|
<LibraryClass Usage="ALWAYS_CONSUMED">
|
||||||
<Keyword>UefiBootServicesTableLib</Keyword>
|
<Keyword>UefiBootServicesTableLib</Keyword>
|
||||||
</LibraryClass>
|
</LibraryClass>
|
||||||
|
<LibraryClass Usage="ALWAYS_CONSUMED">
|
||||||
|
<Keyword>CacheMaintenanceLib</Keyword>
|
||||||
|
</LibraryClass>
|
||||||
</LibraryClassDefinitions>
|
</LibraryClassDefinitions>
|
||||||
<SourceFiles>
|
<SourceFiles>
|
||||||
<Filename>Runtime.dxs</Filename>
|
<Filename>Runtime.dxs</Filename>
|
||||||
<Filename>Runtime.c</Filename>
|
<Filename>Runtime.c</Filename>
|
||||||
<Filename>Runtime.h</Filename>
|
<Filename>Runtime.h</Filename>
|
||||||
<Filename>Crc32.c</Filename>
|
<Filename>Crc32.c</Filename>
|
||||||
<Filename SupArchList="IA32">Ia32/PeHotRelocateEx.c</Filename>
|
|
||||||
<Filename SupArchList="X64">x64/PeHotRelocateEx.c</Filename>
|
|
||||||
<Filename SupArchList="X64">x64/PeHotRelocateEx.h</Filename>
|
|
||||||
<Filename SupArchList="IPF">Ipf/PeHotRelocateEx.c</Filename>
|
|
||||||
<Filename SupArchList="IPF">Ipf/PeHotRelocateEx.h</Filename>
|
|
||||||
</SourceFiles>
|
</SourceFiles>
|
||||||
<PackageDependencies>
|
<PackageDependencies>
|
||||||
<Package PackageGuid="5e0e9358-46b6-4ae2-8218-4ab8b9bbdcec"/>
|
<Package PackageGuid="5e0e9358-46b6-4ae2-8218-4ab8b9bbdcec"/>
|
||||||
|
|
|
@ -2199,6 +2199,7 @@
|
||||||
</ModuleSA>
|
</ModuleSA>
|
||||||
<ModuleSA SupArchList="IA32" PackageGuid="68169ab0-d41b-4009-9060-292c253ac43d" ModuleGuid="B601F8C4-43B7-4784-95B1-F4226CB40CEE">
|
<ModuleSA SupArchList="IA32" PackageGuid="68169ab0-d41b-4009-9060-292c253ac43d" ModuleGuid="B601F8C4-43B7-4784-95B1-F4226CB40CEE">
|
||||||
<Libraries>
|
<Libraries>
|
||||||
|
<Instance ModuleGuid="123dd843-57c9-4158-8418-ce68b3944ce7" PackageGuid="5e0e9358-46b6-4ae2-8218-4ab8b9bbdcec"/>
|
||||||
<Instance ModuleGuid="19cbbb97-ff61-45ff-8c3f-dfa66dd118c8" PackageGuid="5e0e9358-46b6-4ae2-8218-4ab8b9bbdcec"/>
|
<Instance ModuleGuid="19cbbb97-ff61-45ff-8c3f-dfa66dd118c8" PackageGuid="5e0e9358-46b6-4ae2-8218-4ab8b9bbdcec"/>
|
||||||
<Instance ModuleGuid="ff5c7a2c-ab7a-4366-8616-11c6e53247b6" PackageGuid="5e0e9358-46b6-4ae2-8218-4ab8b9bbdcec"/>
|
<Instance ModuleGuid="ff5c7a2c-ab7a-4366-8616-11c6e53247b6" PackageGuid="5e0e9358-46b6-4ae2-8218-4ab8b9bbdcec"/>
|
||||||
<Instance ModuleGuid="27d67720-ea68-48ae-93da-a3a074c90e30" PackageGuid="5e0e9358-46b6-4ae2-8218-4ab8b9bbdcec"/>
|
<Instance ModuleGuid="27d67720-ea68-48ae-93da-a3a074c90e30" PackageGuid="5e0e9358-46b6-4ae2-8218-4ab8b9bbdcec"/>
|
||||||
|
|
|
@ -5072,24 +5072,24 @@ IpfReadItc (
|
||||||
|
|
||||||
|
|
||||||
/**
|
/**
|
||||||
Invalidates a range of instruction cache lines in the cache coherency domain
|
Flush a range of cache lines in the cache coherency domain of the calling
|
||||||
of the calling CPU.
|
CPU.
|
||||||
|
|
||||||
Invalidates the instruction cache lines specified by Address and Length. If
|
Invalidates the cache lines specified by Address and Length. If Address is
|
||||||
Address is not aligned on a cache line boundary, then entire instruction
|
not aligned on a cache line boundary, then entire cache line containing
|
||||||
cache line containing Address is invalidated. If Address + Length is not
|
Address is invalidated. If Address + Length is not aligned on a cache line
|
||||||
aligned on a cache line boundary, then the entire instruction cache line
|
boundary, then the entire instruction cache line containing Address + Length
|
||||||
containing Address + Length -1 is invalidated. This function may choose to
|
-1 is invalidated. This function may choose to invalidate the entire
|
||||||
invalidate the entire instruction cache if that is more efficient than
|
instruction cache if that is more efficient than invalidating the specified
|
||||||
invalidating the specified range. If Length is 0, the no instruction cache
|
range. If Length is 0, the no instruction cache lines are invalidated.
|
||||||
lines are invalidated. Address is returned.
|
Address is returned.
|
||||||
|
|
||||||
If Length is greater than (MAX_ADDRESS - Address + 1), then ASSERT().
|
If Length is greater than (MAX_ADDRESS - Address + 1), then ASSERT().
|
||||||
|
|
||||||
@param Address The base address of the instruction cache lines to
|
@param Address The base address of the instruction lines to invalidate. If
|
||||||
invalidate. If the CPU is in a physical addressing mode, then
|
the CPU is in a physical addressing mode, then Address is a
|
||||||
Address is a physical address. If the CPU is in a virtual
|
physical address. If the CPU is in a virtual addressing mode,
|
||||||
addressing mode, then Address is a virtual address.
|
then Address is a virtual address.
|
||||||
|
|
||||||
@param Length The number of bytes to invalidate from the instruction cache.
|
@param Length The number of bytes to invalidate from the instruction cache.
|
||||||
|
|
||||||
|
@ -5098,7 +5098,7 @@ IpfReadItc (
|
||||||
**/
|
**/
|
||||||
VOID *
|
VOID *
|
||||||
EFIAPI
|
EFIAPI
|
||||||
IpfInvalidateInstructionCacheRange (
|
IpfFlushCacheRange (
|
||||||
IN VOID *Address,
|
IN VOID *Address,
|
||||||
IN UINTN Length
|
IN UINTN Length
|
||||||
);
|
);
|
||||||
|
|
|
@ -62,7 +62,7 @@ InvalidateInstructionCacheRange (
|
||||||
IN UINTN Length
|
IN UINTN Length
|
||||||
)
|
)
|
||||||
{
|
{
|
||||||
return IpfInvalidateInstructionCacheRange (Address, Length);
|
return IpfFlushCacheRange (Address, Length);
|
||||||
}
|
}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
|
@ -119,10 +119,7 @@ WriteBackInvalidateDataCacheRange (
|
||||||
{
|
{
|
||||||
ASSERT (Length <= MAX_ADDRESS - (UINTN)Address + 1);
|
ASSERT (Length <= MAX_ADDRESS - (UINTN)Address + 1);
|
||||||
|
|
||||||
if (Length > 0) {
|
return IpfFlushCacheRange (Address, Length);
|
||||||
WriteBackInvalidateDataCache ();
|
|
||||||
}
|
|
||||||
return Address;
|
|
||||||
}
|
}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
|
@ -178,10 +175,7 @@ WriteBackDataCacheRange (
|
||||||
{
|
{
|
||||||
ASSERT (Length <= MAX_ADDRESS - (UINTN)Address + 1);
|
ASSERT (Length <= MAX_ADDRESS - (UINTN)Address + 1);
|
||||||
|
|
||||||
if (Length > 0) {
|
return IpfFlushCacheRange (Address, Length);
|
||||||
WriteBackDataCache ();
|
|
||||||
}
|
|
||||||
return Address;
|
|
||||||
}
|
}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
|
@ -238,5 +232,5 @@ InvalidateDataCacheRange (
|
||||||
IN UINTN Length
|
IN UINTN Length
|
||||||
)
|
)
|
||||||
{
|
{
|
||||||
return WriteBackInvalidateDataCacheRange (Address, Length);
|
return IpfFlushCacheRange (Address, Length);
|
||||||
}
|
}
|
||||||
|
|
|
@ -425,7 +425,7 @@ WITHOUT WARRANTIES OR REPRESENTATIONS OF ANY KIND, EITHER EXPRESS OR IMPLIED.
|
||||||
<Filename SupArchList="IPF">Ipf/CpuFlushTlb.s</Filename>
|
<Filename SupArchList="IPF">Ipf/CpuFlushTlb.s</Filename>
|
||||||
<Filename SupArchList="IPF">Ipf/GetInterruptState.s</Filename>
|
<Filename SupArchList="IPF">Ipf/GetInterruptState.s</Filename>
|
||||||
<Filename SupArchList="IPF">Ipf/Non-existing.c</Filename>
|
<Filename SupArchList="IPF">Ipf/Non-existing.c</Filename>
|
||||||
<Filename SupArchList="IPF">Ipf/InvalidateInstructionCacheRange.s</Filename>
|
<Filename SupArchList="IPF">Ipf/FlushCacheRange.s</Filename>
|
||||||
<Filename SupArchList="IPF">Ipf/ReadItc.s</Filename>
|
<Filename SupArchList="IPF">Ipf/ReadItc.s</Filename>
|
||||||
|
|
||||||
<Filename SupArchList="EBC">Math64.c</Filename>
|
<Filename SupArchList="EBC">Math64.c</Filename>
|
||||||
|
|
Loading…
Reference in New Issue