[lld] r354080 - Revert "[lld] Fix elf::unlinkAsync detached thread"
Rui Ueyama via llvm-commits
llvm-commits at lists.llvm.org
Thu Feb 14 18:04:55 PST 2019
Did it broke a bot? Please include a reason to revert when you revert a
commit. Thanks! Regards
On Thu, Feb 14, 2019 at 3:39 PM Nick Desaulniers via llvm-commits <
llvm-commits at lists.llvm.org> wrote:
> Author: nickdesaulniers
> Date: Thu Feb 14 15:39:32 2019
> New Revision: 354080
>
> URL: http://llvm.org/viewvc/llvm-project?rev=354080&view=rev
> Log:
> Revert "[lld] Fix elf::unlinkAsync detached thread"
>
> This reverts commit 2694810153cf992823eb45253d26b8567424438f.
>
> Modified:
> lld/trunk/ELF/Filesystem.cpp
>
> Modified: lld/trunk/ELF/Filesystem.cpp
> URL:
> http://llvm.org/viewvc/llvm-project/lld/trunk/ELF/Filesystem.cpp?rev=354080&r1=354079&r2=354080&view=diff
>
> ==============================================================================
> --- lld/trunk/ELF/Filesystem.cpp (original)
> +++ lld/trunk/ELF/Filesystem.cpp Thu Feb 14 15:39:32 2019
> @@ -58,26 +58,9 @@ void elf::unlinkAsync(StringRef Path) {
> std::error_code EC = sys::fs::openFileForRead(Path, FD);
> sys::fs::remove(Path);
>
> - if (EC)
> - return;
> -
> // close and therefore remove TempPath in background.
> - std::mutex M;
> - std::condition_variable CV;
> - bool Started = false;
> - std::thread([&, FD] {
> - {
> - std::lock_guard<std::mutex> L(M);
> - Started = true;
> - CV.notify_all();
> - }
> - ::close(FD);
> - }).detach();
> -
> - // GLIBC 2.26 and earlier have race condition that crashes an entire
> process
> - // if the main thread calls exit(2) while other thread is starting up.
> - std::unique_lock<std::mutex> L(M);
> - CV.wait(L, [&] { return Started; });
> + if (!EC)
> + std::thread([=] { ::close(FD); }).detach();
> #endif
> }
>
>
>
> _______________________________________________
> llvm-commits mailing list
> llvm-commits at lists.llvm.org
> https://lists.llvm.org/cgi-bin/mailman/listinfo/llvm-commits
>
-------------- next part --------------
An HTML attachment was scrubbed...
URL: <http://lists.llvm.org/pipermail/llvm-commits/attachments/20190214/e9a1b915/attachment-0001.html>
More information about the llvm-commits
mailing list