mirror of https://github.com/acidanthera/audk.git
MdeModulePkg/Core: Merge memory map after filtering paging capability
Once the paging capabilities were filtered out, there might be some adjacent entries sharing the same capabilities. It's recommended to merge those entries for the OS compatibility purpose. This patch makes use of existing method MergeMemoryMap() to do it. This is done by simply turning this method from static to extern, and call it after filter code. This patch is related to an issue described at https://bugzilla.tianocore.org/show_bug.cgi?id=753 This patch is also passed test of booting follow OSs: Windows 10 Windows Server 2016 Fedora 26 Fedora 25 Cc: Jiewen Yao <jiewen.yao@intel.com> Cc: Star Zeng <star.zeng@intel.com> Cc: Laszlo Ersek <lersek@redhat.com> Contributed-under: TianoCore Contribution Agreement 1.1 Signed-off-by: Jian J Wang <jian.j.wang@intel.com> Reviewed-by: Star Zeng <star.zeng@intel.com> Acked-by: Laszlo Ersek <lersek@redhat.com>
This commit is contained in:
parent
2c936d7c39
commit
646127c192
|
@ -2948,4 +2948,22 @@ ApplyMemoryProtectionPolicy (
|
|||
IN UINT64 Length
|
||||
);
|
||||
|
||||
/**
|
||||
Merge continous memory map entries whose have same attributes.
|
||||
|
||||
@param MemoryMap A pointer to the buffer in which firmware places
|
||||
the current memory map.
|
||||
@param MemoryMapSize A pointer to the size, in bytes, of the
|
||||
MemoryMap buffer. On input, this is the size of
|
||||
the current memory map. On output,
|
||||
it is the size of new memory map after merge.
|
||||
@param DescriptorSize Size, in bytes, of an individual EFI_MEMORY_DESCRIPTOR.
|
||||
**/
|
||||
VOID
|
||||
MergeMemoryMap (
|
||||
IN OUT EFI_MEMORY_DESCRIPTOR *MemoryMap,
|
||||
IN OUT UINTN *MemoryMapSize,
|
||||
IN UINTN DescriptorSize
|
||||
);
|
||||
|
||||
#endif
|
||||
|
|
|
@ -1915,6 +1915,8 @@ CoreGetMemoryMap (
|
|||
EFI_MEMORY_XP);
|
||||
MemoryMap = NEXT_MEMORY_DESCRIPTOR (MemoryMap, Size);
|
||||
}
|
||||
MergeMemoryMap (MemoryMapStart, &BufferSize, Size);
|
||||
MemoryMapEnd = (EFI_MEMORY_DESCRIPTOR *)((UINT8 *)MemoryMapStart + BufferSize);
|
||||
|
||||
Status = EFI_SUCCESS;
|
||||
|
||||
|
|
|
@ -182,7 +182,6 @@ SortMemoryMap (
|
|||
it is the size of new memory map after merge.
|
||||
@param DescriptorSize Size, in bytes, of an individual EFI_MEMORY_DESCRIPTOR.
|
||||
**/
|
||||
STATIC
|
||||
VOID
|
||||
MergeMemoryMap (
|
||||
IN OUT EFI_MEMORY_DESCRIPTOR *MemoryMap,
|
||||
|
|
Loading…
Reference in New Issue