Index: ELF/LinkerScript.cpp =================================================================== --- ELF/LinkerScript.cpp +++ ELF/LinkerScript.cpp @@ -28,8 +28,8 @@ namespace { class LinkerScript { public: - LinkerScript(BumpPtrAllocator *A, StringRef S) - : Saver(*A), Tokens(tokenize(S)) {} + LinkerScript(BumpPtrAllocator *A, StringRef S, bool B) + : Saver(*A), Tokens(tokenize(S)), IsUnderSysroot(B) {} void run(); private: @@ -58,6 +58,7 @@ StringSaver Saver; std::vector Tokens; size_t Pos = 0; + bool IsUnderSysroot; }; } @@ -161,6 +162,12 @@ void LinkerScript::addFile(StringRef S) { if (sys::path::is_absolute(S)) { + if (IsUnderSysroot) { + SmallString<128> Path; + (Config->Sysroot + S).toStringRef(Path); + if (sys::fs::exists(Path)) + S = Saver.save(Path.str()); + } Driver->addFile(S); } else if (S.startswith("=")) { if (Config->Sysroot.empty()) @@ -292,5 +299,12 @@ // Entry point. The other functions or classes are private to this file. void lld::elf2::readLinkerScript(BumpPtrAllocator *A, MemoryBufferRef MB) { - LinkerScript(A, MB.getBuffer()).run(); + StringRef Path = MB.getBufferIdentifier(); + if (!Config->Sysroot.empty()) + for (; !Path.empty(); Path = sys::path::parent_path(Path)) + if (sys::fs::equivalent(Config->Sysroot, Path)) { + LinkerScript(A, MB.getBuffer(), true).run(); + return; + } + LinkerScript(A, MB.getBuffer(), false).run(); } Index: test/ELF/linkerscript.s =================================================================== --- test/ELF/linkerscript.s +++ test/ELF/linkerscript.s @@ -38,6 +38,13 @@ # RUN: ld.lld -o %t2 %t.script -L%t.dir # RUN: llvm-readobj %t2 > /dev/null +# RUN: echo "GROUP(" %t /libxyz.a ")" > %t.script +# RUN: echo "GROUP(" %t /libxyz.a ")" > %t.dir/xyz.script +# RUN: not ld.lld -o %t2 %t.script +# RUN: not ld.lld -o %t2 %t.script --sysroot=%t.dir +# RUN: ld.lld -o %t2 %t.dir/xyz.script --sysroot=%t.dir +# RUN: llvm-readobj %t2 > /dev/null + # RUN: echo "GROUP(" %t.script2 ")" > %t.script1 # RUN: echo "GROUP(" %t ")" > %t.script2 # RUN: ld.lld -o %t2 %t.script1