Summary: It defined a couple of types (condition_t) which we don't use anymore, as we have c++11 goodies now. I remove these definitions. Also it unnecessarily included a couple of headers which weren't necessary for it's operation. I remove these, and place the includes in the relevant files (usually .cpp, usually in Host code) which use them. This allows us to reduce namespace pollution in most of the lldb files which don't need the OS-specific definitions. Reviewers: zturner, jingham Subscribers: ki.stfu, lldb-commits Differential Revision: https://reviews.llvm.org/D35113 llvm-svn: 308304
62 lines
1.6 KiB
C++
62 lines
1.6 KiB
C++
//===-- LockFilePosix.cpp ---------------------------------------*- C++ -*-===//
|
|
//
|
|
// The LLVM Compiler Infrastructure
|
|
//
|
|
// This file is distributed under the University of Illinois Open Source
|
|
// License. See LICENSE.TXT for details.
|
|
//
|
|
//===----------------------------------------------------------------------===//
|
|
|
|
#include "lldb/Host/posix/LockFilePosix.h"
|
|
|
|
#include <fcntl.h>
|
|
#include <unistd.h>
|
|
|
|
using namespace lldb;
|
|
using namespace lldb_private;
|
|
|
|
namespace {
|
|
|
|
Status fileLock(int fd, int cmd, int lock_type, const uint64_t start,
|
|
const uint64_t len) {
|
|
struct flock fl;
|
|
|
|
fl.l_type = lock_type;
|
|
fl.l_whence = SEEK_SET;
|
|
fl.l_start = start;
|
|
fl.l_len = len;
|
|
fl.l_pid = ::getpid();
|
|
|
|
Status error;
|
|
if (::fcntl(fd, cmd, &fl) == -1)
|
|
error.SetErrorToErrno();
|
|
|
|
return error;
|
|
}
|
|
|
|
} // namespace
|
|
|
|
LockFilePosix::LockFilePosix(int fd) : LockFileBase(fd) {}
|
|
|
|
LockFilePosix::~LockFilePosix() { Unlock(); }
|
|
|
|
Status LockFilePosix::DoWriteLock(const uint64_t start, const uint64_t len) {
|
|
return fileLock(m_fd, F_SETLKW, F_WRLCK, start, len);
|
|
}
|
|
|
|
Status LockFilePosix::DoTryWriteLock(const uint64_t start, const uint64_t len) {
|
|
return fileLock(m_fd, F_SETLK, F_WRLCK, start, len);
|
|
}
|
|
|
|
Status LockFilePosix::DoReadLock(const uint64_t start, const uint64_t len) {
|
|
return fileLock(m_fd, F_SETLKW, F_RDLCK, start, len);
|
|
}
|
|
|
|
Status LockFilePosix::DoTryReadLock(const uint64_t start, const uint64_t len) {
|
|
return fileLock(m_fd, F_SETLK, F_RDLCK, start, len);
|
|
}
|
|
|
|
Status LockFilePosix::DoUnlock() {
|
|
return fileLock(m_fd, F_SETLK, F_UNLCK, m_start, m_len);
|
|
}
|