Index: lld/COFF/DLL.h =================================================================== --- lld/COFF/DLL.h +++ lld/COFF/DLL.h @@ -36,7 +36,6 @@ std::vector Imports; std::vector Dirs; - std::vector Lookups; std::vector Addresses; std::vector Hints; std::map DLLNames; Index: lld/COFF/DLL.cpp =================================================================== --- lld/COFF/DLL.cpp +++ lld/COFF/DLL.cpp @@ -388,7 +388,6 @@ // Add each type in the correct order. std::vector V; V.insert(V.end(), Dirs.begin(), Dirs.end()); - V.insert(V.end(), Lookups.begin(), Lookups.end()); V.insert(V.end(), Addresses.begin(), Addresses.end()); V.insert(V.end(), Hints.begin(), Hints.end()); for (auto &KV : DLLNames) @@ -407,21 +406,18 @@ // we need to create HintName chunks to store the names. // If they don't (if they are import-by-ordinals), we store only // ordinal values to the table. - size_t Base = Lookups.size(); + size_t Base = Addresses.size(); for (DefinedImportData *S : Syms) { uint16_t Ord = S->getOrdinal(); if (S->getExternalName().empty()) { - Lookups.push_back(make(Ord)); Addresses.push_back(make(Ord)); continue; } auto *C = make(S->getExternalName(), Ord); - Lookups.push_back(make(C)); Addresses.push_back(make(C)); Hints.push_back(C); } // Terminate with null values. - Lookups.push_back(make(ptrSize())); Addresses.push_back(make(ptrSize())); for (int I = 0, E = Syms.size(); I < E; ++I) @@ -431,7 +427,7 @@ if (!DLLNames.count(Name)) DLLNames[Name] = make(Name); auto *Dir = make(DLLNames[Name]); - Dir->LookupTab = Lookups[Base]; + Dir->LookupTab = Addresses[Base]; Dir->AddressTab = Addresses[Base]; Dirs.push_back(Dir); } Index: lld/test/COFF/armnt-imports.test =================================================================== --- lld/test/COFF/armnt-imports.test +++ lld/test/COFF/armnt-imports.test @@ -6,7 +6,7 @@ # CHECK: Import { # CHECK: Name: library.dll # CHECK: ImportLookupTableRVA: 0x2028 -# CHECK: ImportAddressTableRVA: 0x2030 +# CHECK: ImportAddressTableRVA: 0x2028 # CHECK: Symbol: function (0) # CHECK: } Index: lld/test/COFF/hello32.test =================================================================== --- lld/test/COFF/hello32.test +++ lld/test/COFF/hello32.test @@ -77,7 +77,7 @@ HEADER-NEXT: LoadConfigTableSize: 0x0 HEADER-NEXT: BoundImportRVA: 0x0 HEADER-NEXT: BoundImportSize: 0x0 -HEADER-NEXT: IATRVA: 0x3034 +HEADER-NEXT: IATRVA: 0x3028 HEADER-NEXT: IATSize: 0xC HEADER-NEXT: DelayImportDescriptorRVA: 0x0 HEADER-NEXT: DelayImportDescriptorSize: 0x0 @@ -113,7 +113,7 @@ IMPORTS: Import { IMPORTS: Name: std32.dll IMPORTS: ImportLookupTableRVA: 0x3028 -IMPORTS: ImportAddressTableRVA: 0x3034 +IMPORTS: ImportAddressTableRVA: 0x3028 IMPORTS: Symbol: ExitProcess (0) IMPORTS: Symbol: MessageBoxA (1) IMPORTS: } Index: lld/test/COFF/imports.test =================================================================== --- lld/test/COFF/imports.test +++ lld/test/COFF/imports.test @@ -21,14 +21,14 @@ TEXT-NEXT: movl $0, %ecx TEXT-NEXT: callq 18 TEXT-NEXT: callq 29 -TEXT: jmpq *4098(%rip) -TEXT: jmpq *4090(%rip) -TEXT: jmpq *4082(%rip) +TEXT: jmpq *4066(%rip) +TEXT: jmpq *4058(%rip) +TEXT: jmpq *4050(%rip) IMPORT: Import { IMPORT-NEXT: Name: std64.dll IMPORT-NEXT: ImportLookupTableRVA: 0x3028 -IMPORT-NEXT: ImportAddressTableRVA: 0x3048 +IMPORT-NEXT: ImportAddressTableRVA: 0x3028 IMPORT-NEXT: Symbol: ExitProcess (0) IMPORT-NEXT: Symbol: (50) IMPORT-NEXT: Symbol: MessageBoxA (1)