forked from OSchip/llvm-project
Support: improve identify_magic to recognize COFF bigobj
identify_magic recognized a COFF bigobj as an import library file. This patch fixes that. llvm-svn: 217627
This commit is contained in:
parent
5d8f698ec1
commit
2acb05843b
|
@ -901,10 +901,16 @@ file_magic identify_magic(StringRef Magic) {
|
||||||
return file_magic::unknown;
|
return file_magic::unknown;
|
||||||
switch ((unsigned char)Magic[0]) {
|
switch ((unsigned char)Magic[0]) {
|
||||||
case 0x00: {
|
case 0x00: {
|
||||||
// COFF short import library file
|
// COFF bigobj or short import library file
|
||||||
if (Magic[1] == (char)0x00 && Magic[2] == (char)0xff &&
|
if (Magic[1] == (char)0x00 && Magic[2] == (char)0xff &&
|
||||||
Magic[3] == (char)0xff)
|
Magic[3] == (char)0xff) {
|
||||||
return file_magic::coff_import_library;
|
const char BigobjMagic[] =
|
||||||
|
"\xc7\xa1\xba\xd1\xee\xba\xa9\x4b\xaf\x20\xfa\xf6\x6a\xa4\xdc\xb8";
|
||||||
|
if (Magic.size() >= 28 &&
|
||||||
|
memcmp(Magic.data() + 12, BigobjMagic, sizeof(BigobjMagic)) == 0)
|
||||||
|
return file_magic::coff_object;
|
||||||
|
return file_magic::coff_import_library;
|
||||||
|
}
|
||||||
// Windows resource file
|
// Windows resource file
|
||||||
const char Expected[] = { 0, 0, 0, 0, '\x20', 0, 0, 0, '\xff' };
|
const char Expected[] = { 0, 0, 0, 0, '\x20', 0, 0, 0, '\xff' };
|
||||||
if (Magic.size() >= sizeof(Expected) &&
|
if (Magic.size() >= sizeof(Expected) &&
|
||||||
|
|
|
@ -483,6 +483,8 @@ TEST_F(FileSystemTest, DirectoryIteration) {
|
||||||
const char archive[] = "!<arch>\x0A";
|
const char archive[] = "!<arch>\x0A";
|
||||||
const char bitcode[] = "\xde\xc0\x17\x0b";
|
const char bitcode[] = "\xde\xc0\x17\x0b";
|
||||||
const char coff_object[] = "\x00\x00......";
|
const char coff_object[] = "\x00\x00......";
|
||||||
|
const char coff_bigobj[] = "\x00\x00\xff\xff........"
|
||||||
|
"\xc7\xa1\xba\xd1\xee\xba\xa9\x4b\xaf\x20\xfa\xf6\x6a\xa4\xdc\xb8";
|
||||||
const char coff_import_library[] = "\x00\x00\xff\xff....";
|
const char coff_import_library[] = "\x00\x00\xff\xff....";
|
||||||
const char elf_relocatable[] = { 0x7f, 'E', 'L', 'F', 1, 2, 1, 0, 0,
|
const char elf_relocatable[] = { 0x7f, 'E', 'L', 'F', 1, 2, 1, 0, 0,
|
||||||
0, 0, 0, 0, 0, 0, 0, 0, 1 };
|
0, 0, 0, 0, 0, 0, 0, 0, 1 };
|
||||||
|
@ -512,6 +514,7 @@ TEST_F(FileSystemTest, Magic) {
|
||||||
DEFINE(archive),
|
DEFINE(archive),
|
||||||
DEFINE(bitcode),
|
DEFINE(bitcode),
|
||||||
DEFINE(coff_object),
|
DEFINE(coff_object),
|
||||||
|
{ "coff_bigobj", coff_bigobj, sizeof(coff_bigobj), fs::file_magic::coff_object },
|
||||||
DEFINE(coff_import_library),
|
DEFINE(coff_import_library),
|
||||||
DEFINE(elf_relocatable),
|
DEFINE(elf_relocatable),
|
||||||
DEFINE(macho_universal_binary),
|
DEFINE(macho_universal_binary),
|
||||||
|
|
Loading…
Reference in New Issue