/usr/include/x86_64-linux-gnu/qcc/RWLock.h is in liballjoyn-common-dev-1504 15.04b-8.
This file is owned by root:root, with mode 0o644.
The actual contents of the file can be viewed below.
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 41 42 43 44 45 46 47 48 49 50 51 52 53 54 55 56 57 58 59 60 61 62 63 64 65 66 67 68 69 70 71 72 73 74 75 76 77 78 79 80 81 82 83 84 85 86 87 88 89 90 91 92 93 94 95 96 97 98 99 100 101 102 103 104 105 106 107 | /**
* @file
*
* Define a class that abstracts rwlock's.
*/
/******************************************************************************
* Copyright AllSeen Alliance. All rights reserved.
*
* Permission to use, copy, modify, and/or distribute this software for any
* purpose with or without fee is hereby granted, provided that the above
* copyright notice and this permission notice appear in all copies.
*
* THE SOFTWARE IS PROVIDED "AS IS" AND THE AUTHOR DISCLAIMS ALL WARRANTIES
* WITH REGARD TO THIS SOFTWARE INCLUDING ALL IMPLIED WARRANTIES OF
* MERCHANTABILITY AND FITNESS. IN NO EVENT SHALL THE AUTHOR BE LIABLE FOR
* ANY SPECIAL, DIRECT, INDIRECT, OR CONSEQUENTIAL DAMAGES OR ANY DAMAGES
* WHATSOEVER RESULTING FROM LOSS OF USE, DATA OR PROFITS, WHETHER IN AN
* ACTION OF CONTRACT, NEGLIGENCE OR OTHER TORTIOUS ACTION, ARISING OUT OF
* OR IN CONNECTION WITH THE USE OR PERFORMANCE OF THIS SOFTWARE.
******************************************************************************/
#ifndef _QCC_RWLOCK_H
#define _QCC_RWLOCK_H
#include <qcc/platform.h>
/*
* Note: The Android NDK does not include support for pThread's rwlock
* implementation, therefore we must fallback to using Mutexes instead.
*/
#if defined(QCC_OS_GROUP_POSIX) && !defined(QCC_OS_ANDROID)
#include <qcc/posix/RWLock.h>
#elif defined(QCC_OS_GROUP_WINDOWS)
#include <qcc/windows/RWLock.h>
#else
#include <qcc/Mutex.h>
namespace qcc {
/**
* The simple fallback implementation of RWLock using Mutex.
*/
class RWLock {
public:
/**
* The constructor initializes the underlying rwlock implementation.
*/
RWLock() { }
/**
* The destructor will destroy the underlying rwlock.
*/
~RWLock() { }
/**
* Acquires a lock on the rwlock. If another thread is holding the lock,
* then this function will block until the other thread has released its
* lock.
*
* @return ER_OK if the lock was acquired, ER_OS_ERROR if the underlying
* OS reports an error.
*/
QStatus RDLock() { return mutex.Lock(); }
QStatus WRLock() { return mutex.Lock(); }
/**
* Releases a lock on the rwlock. This will only release a lock for the
* current thread if that thread was the one that aquired the lock in the
* first place.
*
* @return ER_OK if the lock was released, ER_OS_ERROR if the underlying
* OS reports an error.
*/
QStatus Unlock() { return mutex.Unlock(); }
/**
* Attempt to acquire a lock on a rwlock. If another thread is holding the lock
* this function return false otherwise the lock is acquired and the function returns true.
*
* @return True if the lock was acquired.
*/
bool TryRDLock() { return mutex.TryLock(); }
bool TryWRLock() { return mutex.TryLock(); }
/**
* Rwlock copy constructor creates a new rwlock.
*/
RWLock(const RWLock& other) { }
/**
* Rwlock assignment operator.
*/
RWLock& operator=(const RWLock& other) { return *this; }
private:
qcc::Mutex mutex; ///< Use a mutex.
};
}
#endif // Default platform type.
#endif // _QCC_RWLOCK_H
|