diff options
author | David Majnemer <david.majnemer@gmail.com> | 2014-10-07 05:48:40 +0000 |
---|---|---|
committer | David Majnemer <david.majnemer@gmail.com> | 2014-10-07 05:48:40 +0000 |
commit | 51c2afc4b65b2782307a38ce54788ac4a61ef717 (patch) | |
tree | 560f4d3980b02f8da93a1291430d9261bd1350da /llvm/lib/Support/Windows | |
parent | dfc7ed7ad0971593e44eda3bde26606f1a8e543f (diff) | |
download | bcm5719-llvm-51c2afc4b65b2782307a38ce54788ac4a61ef717.tar.gz bcm5719-llvm-51c2afc4b65b2782307a38ce54788ac4a61ef717.zip |
Support: Don't call close again if we get EINTR
Most Unix-like operating systems guarantee that the file descriptor is
closed after a call to close(2), even if close comes back with EINTR.
For these systems, calling close _again_ will either do nothing or close
some other file descriptor open(2)'d by another thread. (Linux)
However, some operating systems do not have this behavior. They require
at least another call to close(2) before guaranteeing that the
descriptor is closed. (HP-UX)
And some operating systems have an unpredictable blend of the two
behaviors! (xnu)
Avoid this disaster by blocking all signals before we call close(2).
This ensures that a signal will not be delivered to the thread and
close(2) will not give us back EINTR. We restore the signal mask once
the operation is done.
N.B. This isn't a problem on Windows, it doesn't have a notion of EINTR
because signals always get delivered to dedicated signal handling
threads.
llvm-svn: 219189
Diffstat (limited to 'llvm/lib/Support/Windows')
-rw-r--r-- | llvm/lib/Support/Windows/Process.inc | 6 |
1 files changed, 6 insertions, 0 deletions
diff --git a/llvm/lib/Support/Windows/Process.inc b/llvm/lib/Support/Windows/Process.inc index db87d8ed60e..3819e638c72 100644 --- a/llvm/lib/Support/Windows/Process.inc +++ b/llvm/lib/Support/Windows/Process.inc @@ -277,6 +277,12 @@ std::error_code Process::FixupStandardFileDescriptors() { return std::error_code(); } +std::error_code Process::SafelyCloseFileDescriptor(int FD) { + if (::close(FD) < 0) + return std::error_code(errno, std::generic_category()); + return std::error_code(); +} + bool Process::StandardInIsUserInput() { return FileDescriptorIsDisplayed(0); } |