[lld] r354080 - Revert "[lld] Fix elf::unlinkAsync detached thread"
Nick Desaulniers via llvm-commits
llvm-commits at lists.llvm.org
Thu Feb 14 15:39:33 PST 2019
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
}
More information about the llvm-commits
mailing list