BZ: https://bugzilla.tianocore.org/show_bug.cgi?id=1603
CLANG9 generated PE image exposes below two issues.
1. SectionSize is used to copy PE section data. It should be smaller than
section raw size.
2. The real data is required to be copied. So, copy the min size of
VirtualSize and SizeOfRawData.
Signed-off-by: Liming Gao <liming.gao@intel.com>
Cc: Bob Feng <bob.c.feng@intel.com>
Reviewed-by: Philippe Mathieu-Daude <philmd@redhat.com>
//\r
// Make the size of raw data in section header alignment.\r
//\r
- SectionHeader->SizeOfRawData = (SectionHeader->Misc.VirtualSize + PeHdr->Pe32.OptionalHeader.FileAlignment - 1) & (~(PeHdr->Pe32.OptionalHeader.FileAlignment - 1));\r
+ SectionSize = (SectionHeader->Misc.VirtualSize + PeHdr->Pe32.OptionalHeader.FileAlignment - 1) & (~(PeHdr->Pe32.OptionalHeader.FileAlignment - 1));\r
+ if (SectionSize < SectionHeader->SizeOfRawData) {\r
+ SectionHeader->SizeOfRawData = SectionSize;\r
+ }\r
+\r
SectionHeader->PointerToRawData = SectionHeader->VirtualAddress;\r
}\r
\r
CopyMem (\r
FileBuffer + SectionHeader->PointerToRawData,\r
(VOID*) (UINTN) (ImageContext.ImageAddress + SectionHeader->VirtualAddress),\r
- SectionHeader->SizeOfRawData\r
+ SectionHeader->SizeOfRawData < SectionHeader->Misc.VirtualSize ? SectionHeader->SizeOfRawData : SectionHeader->Misc.VirtualSize\r
);\r
}\r
\r