diff options
author | Jez Ng <jezng@fb.com> | 2023-04-20 17:23:36 -0400 |
---|---|---|
committer | Jez Ng <jezng@fb.com> | 2023-04-20 17:24:06 -0400 |
commit | 9df7daa5ef912957c708382c0860e01d1cd3b4c8 (patch) | |
tree | 06f9c1cd62bb9a1c5f46801e91c1f4b09be81923 /lld | |
parent | a7cfcc686b7522abe10ff03d4ada160732646a0d (diff) | |
download | llvm-9df7daa5ef912957c708382c0860e01d1cd3b4c8.tar.gz |
[lld-macho] Tweak the names we give to archive members
In particular, make it `foo.a(foo.o)$ARCHIVE_OFFSET`. The goal is to
make it more similar to both ld64 implementation, which uses the
`foo.a(foo.o)$MODULE_ID` format. We dump some of these names in LTO
code, so matching ld64's format is helpful. This format is also more
similar to LLD-ELF's, which is `foo.a(foo.o at $ARCHIVE_OFFSET)`.
Reviewed By: #lld-macho, oontvoo
Differential Revision: https://reviews.llvm.org/D148828
Diffstat (limited to 'lld')
-rw-r--r-- | lld/MachO/InputFiles.cpp | 5 | ||||
-rw-r--r-- | lld/test/MachO/lto-archivecollision.ll | 18 |
2 files changed, 11 insertions, 12 deletions
diff --git a/lld/MachO/InputFiles.cpp b/lld/MachO/InputFiles.cpp index 9f0c003d6aa2..31372046840e 100644 --- a/lld/MachO/InputFiles.cpp +++ b/lld/MachO/InputFiles.cpp @@ -2207,10 +2207,9 @@ BitcodeFile::BitcodeFile(MemoryBufferRef mb, StringRef archiveName, MemoryBufferRef mbref(mb.getBuffer(), saver().save(archiveName.empty() ? path - : archiveName + - sys::path::filename(path) + + : archiveName + "(" + + sys::path::filename(path) + ")" + utostr(offsetInArchive))); - obj = check(lto::InputFile::create(mbref)); if (lazy) parseLazy(); diff --git a/lld/test/MachO/lto-archivecollision.ll b/lld/test/MachO/lto-archivecollision.ll index 4acbe79bdc18..993671a89050 100644 --- a/lld/test/MachO/lto-archivecollision.ll +++ b/lld/test/MachO/lto-archivecollision.ll @@ -13,15 +13,15 @@ ; RUN: %lld -save-temps %t/main.o %t/liba.a %t/libb.a -o %t/test ; RUN: FileCheck %s --check-prefix=DIFFERENT-ARCHIVES < %t/test.resolution.txt -; SAME-ARCHIVE: libbar.abar.o[[#OFFSET:]] -; SAME-ARCHIVE-NEXT: -r={{.*}}/libbar.abar.o[[#OFFSET:]],_foo,p -; SAME-ARCHIVE-NEXT: libbar.abar.o[[#OTHEROFFSET:]] -; SAME-ARCHIVE-NEXT: -r={{.*}}/libbar.abar.o[[#OTHEROFFSET:]],_bar,p - -; DIFFERENT-ARCHIVES: liba.abar.o[[#OFFSET:]] -; DIFFERENT-ARCHIVES-NEXT: -r={{.*}}/liba.abar.o[[#OFFSET:]],_foo,p -; DIFFERENT-ARCHIVES-NEXT: libb.abar.o[[#OTHEROFFSET:]] -; DIFFERENT-ARCHIVES-NEXT: -r={{.*}}/libb.abar.o[[#OTHEROFFSET:]],_bar,p +; SAME-ARCHIVE: libbar.a(bar.o)[[#OFFSET:]] +; SAME-ARCHIVE-NEXT: -r={{.*}}/libbar.a(bar.o)[[#OFFSET:]],_foo,p +; SAME-ARCHIVE-NEXT: libbar.a(bar.o)[[#OTHEROFFSET:]] +; SAME-ARCHIVE-NEXT: -r={{.*}}/libbar.a(bar.o)[[#OTHEROFFSET:]],_bar,p + +; DIFFERENT-ARCHIVES: liba.a(bar.o)[[#OFFSET:]] +; DIFFERENT-ARCHIVES-NEXT: -r={{.*}}/liba.a(bar.o)[[#OFFSET:]],_foo,p +; DIFFERENT-ARCHIVES-NEXT: libb.a(bar.o)[[#OTHEROFFSET:]] +; DIFFERENT-ARCHIVES-NEXT: -r={{.*}}/libb.a(bar.o)[[#OTHEROFFSET:]],_bar,p ;--- main.ll |