/usr/include/sipxtapi/os/linux/OsMutexLinux.h is in libsipxtapi-dev 3.3.0~test17-2.1.
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 | //
// Copyright (C) 2004-2006 SIPfoundry Inc.
// Licensed by SIPfoundry under the LGPL license.
//
// Copyright (C) 2004-2006 Pingtel Corp. All rights reserved.
// Licensed to SIPfoundry under a Contributor Agreement.
//
// $$
///////////////////////////////////////////////////////////////////////////////
#ifndef _OsMutexLinux_h_
#define _OsMutexLinux_h_
// SYSTEM INCLUDES
// APPLICATION INCLUDES
#include "os/OsMutex.h"
#include "os/linux/OsLinuxDefs.h"
#include "os/linux/pt_mutex.h"
// DEFINES
// MACROS
// EXTERNAL FUNCTIONS
// EXTERNAL VARIABLES
// CONSTANTS
// STRUCTS
// TYPEDEFS
// FORWARD DECLARATIONS
//:Mutual exclusion semaphore (mutex) for Linux
// The mutual-exclusion semaphore is a specialized version of the binary
// semaphore, designed to address issues inherent in mutual exclusion, such
// as recursive access to resources, priority inversion, and deletion safety
// The fundamental behavior of the mutual-exclusion semaphore is identical to
// except for the following restrictions: it can only be used for mutual
// exclusion and it can only be released by the task that acquired it.
class OsMutexLinux : public OsMutexBase
{
/* //////////////////////////// PUBLIC //////////////////////////////////// */
public:
/* ============================ CREATORS ================================== */
OsMutexLinux(const unsigned options);
//:Constructor
virtual
~OsMutexLinux();
//:Destructor
/* ============================ MANIPULATORS ============================== */
virtual OsStatus acquire(const OsTime& rTimeout = OsTime::OS_INFINITY);
//:Block the task until the semaphore is acquired or the timeout expires
virtual OsStatus tryAcquire(void);
//:Conditionally acquire the mutex (i.e., don't block)
// Return OS_BUSY if the mutex is held by some other task
virtual OsStatus release(void);
//:Release the semaphore
/* ============================ ACCESSORS ================================= */
virtual void OsMutexShow(void);
//:Print mutex information to the console.
/* ============================ INQUIRY =================================== */
/* //////////////////////////// PROTECTED ///////////////////////////////// */
protected:
/* //////////////////////////// PRIVATE /////////////////////////////////// */
private:
pt_mutex_t mMutexImp; // Pingtel-Linux mutex
OsMutexLinux();
//:Default constructor (not implemented for this class)
OsMutexLinux(const OsMutexLinux& rOsMutexLinux);
//:Copy constructor (not implemented for this class)
OsMutexLinux& operator=(const OsMutexLinux& rhs);
//:Assignment operator (not implemented for this class)
};
/* ============================ INLINE METHODS ============================ */
#endif // _OsMutexLinux_h_
|