ElfObject: Ignore section headers when offset is invalid

This happens in V-Rally 3:

(ELF) Section header offset 14853196 is larger than file size 5898828
This commit is contained in:
Connor McLaughlin 2022-04-22 21:32:33 +10:00 committed by refractionpcsx2
parent 4f44e3fc46
commit 0692517f13
1 changed files with 18 additions and 8 deletions

View File

@ -63,10 +63,20 @@ void ElfObject::initElfHeaders(bool isPSXElf)
DevCon.WriteLn( L"Initializing Elf: %d bytes", data.GetSizeInBytes()); DevCon.WriteLn( L"Initializing Elf: %d bytes", data.GetSizeInBytes());
if (header.e_phnum > 0) if (header.e_phnum > 0)
proghead = (ELF_PHR*)&data[header.e_phoff]; {
if ((header.e_phoff + sizeof(ELF_PHR)) <= data.GetSizeInBytes())
proghead = reinterpret_cast<ELF_PHR*>(&data[header.e_phoff]);
else
Console.Error("(ELF) Program header offset %u is larger than file size %u", header.e_phoff, data.GetSizeInBytes());
}
if (header.e_shnum > 0) if (header.e_shnum > 0)
secthead = (ELF_SHR*)&data[header.e_shoff]; {
if ((header.e_shoff + sizeof(ELF_SHR)) <= data.GetSizeInBytes())
secthead = reinterpret_cast<ELF_SHR*>(&data[header.e_shoff]);
else
Console.Error("(ELF) Section header offset %u is larger than file size %u", header.e_shoff, data.GetSizeInBytes());
}
if ((header.e_shnum > 0) && (header.e_shentsize != sizeof(ELF_SHR))) if ((header.e_shnum > 0) && (header.e_shentsize != sizeof(ELF_SHR)))
Console.Error("(ELF) Size of section headers is not standard"); Console.Error("(ELF) Size of section headers is not standard");