Support: improve identify_magic to recognize COFF bigobj

identify_magic recognized a COFF bigobj as an import library file.
This patch fixes that.



git-svn-id: https://llvm.org/svn/llvm-project/llvm/trunk@217627 91177308-0d34-0410-b5e6-96231b3b80d8
This commit is contained in:
Rui Ueyama 2014-09-11 21:09:57 +00:00
parent 8d230cd536
commit 330c819d83
2 changed files with 12 additions and 3 deletions

View File

@ -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) &&

View File

@ -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),