summaryrefslogtreecommitdiffstats
path: root/llvm/lib/Support/LockFileManager.cpp
diff options
context:
space:
mode:
authorBen Langmuir <blangmuir@apple.com>2015-06-29 21:56:03 +0000
committerBen Langmuir <blangmuir@apple.com>2015-06-29 21:56:03 +0000
commit5123eecd63e94b786c6999105a05a86696dc9d26 (patch)
tree64c0b4d58ec404910499d12715c6a177ab0cfde5 /llvm/lib/Support/LockFileManager.cpp
parent121c1c54bf7f0fbcc78485770a04af177bb1d144 (diff)
downloadbcm5719-llvm-5123eecd63e94b786c6999105a05a86696dc9d26.tar.gz
bcm5719-llvm-5123eecd63e94b786c6999105a05a86696dc9d26.zip
Revert "Use gethostuuid() on Mac to identify hosts for LockFileManager"
Broke non-Mac builds. This reverts commit r241005. llvm-svn: 241007
Diffstat (limited to 'llvm/lib/Support/LockFileManager.cpp')
-rw-r--r--llvm/lib/Support/LockFileManager.cpp68
1 files changed, 14 insertions, 54 deletions
diff --git a/llvm/lib/Support/LockFileManager.cpp b/llvm/lib/Support/LockFileManager.cpp
index 83c67b8de76..95e0ece9245 100644
--- a/llvm/lib/Support/LockFileManager.cpp
+++ b/llvm/lib/Support/LockFileManager.cpp
@@ -21,16 +21,6 @@
#if LLVM_ON_UNIX
#include <unistd.h>
#endif
-
-#if defined(__APPLE__) && defined(__MAC_OS_X_VERSION_MIN_REQUIRED) && (__MAC_OS_X_VERSION_MIN_REQUIRED > 1050)
-#define USE_OSX_GETHOSTUUID 1
-#else
-#define USE_OSX_GETHOSTUUID 0
-#endif
-
-#if USE_OSX_GETHOSTUUID
-#include <uuid/uuid.h>
-#endif
using namespace llvm;
/// \brief Attempt to read the lock file with the given name, if it exists.
@@ -66,43 +56,14 @@ LockFileManager::readLockFile(StringRef LockFileName) {
return None;
}
-static std::error_code getHostID(SmallVectorImpl<char> &HostID) {
- HostID.clear();
-
-#if USE_OSX_GETHOSTUUID
- // On OS X, use the more stable hardware UUID instead of hostname.
- struct timespec wait = {1, 0}; // 1 second.
- uuid_t uuid;
- if (gethostuuid(uuid, &wait) != 0)
- return std::error_code(errno, std::system_category());
-
- uuid_string_t UUIDStr;
- uuid_unparse(uuid, UUIDStr);
- assert(strlen(UUIDStr) == 36);
- HostID.append(&UUIDStr[0], &UUIDStr[36]);
-
-#elif LLVM_ON_UNIX
- char hostname[256];
- hostname[255] = 0;
- hostname[0] = 0;
- gethostname(hostname, 255);
- HostID = hostname;
-
-#else
- HostID = "localhost";
-#endif
-
- return std::error_code();
-}
-
-bool LockFileManager::processStillExecuting(StringRef HostID, int PID) {
+bool LockFileManager::processStillExecuting(StringRef Hostname, int PID) {
#if LLVM_ON_UNIX && !defined(__ANDROID__)
- SmallString<256> StoredHostID;
- if (getHostID(StoredHostID))
- return true; // Conservatively assume it's executing on error.
-
+ char MyHostname[256];
+ MyHostname[255] = 0;
+ MyHostname[0] = 0;
+ gethostname(MyHostname, 255);
// Check whether the process is dead. If so, we're done.
- if (StoredHostID == HostID && getsid(PID) == -1 && errno == ESRCH)
+ if (MyHostname == Hostname && getsid(PID) == -1 && errno == ESRCH)
return false;
#endif
@@ -165,18 +126,17 @@ LockFileManager::LockFileManager(StringRef FileName)
// Write our process ID to our unique lock file.
{
- SmallString<256> HostID;
- if (auto EC = getHostID(HostID)) {
- Error = EC;
- return;
- }
-
raw_fd_ostream Out(UniqueLockFileID, /*shouldClose=*/true);
- Out << HostID << ' ';
+
#if LLVM_ON_UNIX
- Out << getpid();
+ // FIXME: move getpid() call into LLVM
+ char hostname[256];
+ hostname[255] = 0;
+ hostname[0] = 0;
+ gethostname(hostname, 255);
+ Out << hostname << ' ' << getpid();
#else
- Out << "1";
+ Out << "localhost 1";
#endif
Out.close();
OpenPOWER on IntegriCloud