gecko-dev/mozglue/misc/PlatformMutex.h
Ehsan Akhgari e5e885ae31 Bug 1521000 - Part 2: Adjust our clang-format rules to include spaces after the hash for nested preprocessor directives r=sylvestre
# ignore-this-changeset

--HG--
extra : amend_source : 7221c8d15a765df71171099468e7c7faa648f37c
extra : histedit_source : a0cce6015636202bff09e35a13f72e03257a7695
2019-01-18 10:16:18 +01:00

77 lines
2.1 KiB
C++

/* -*- Mode: C++; tab-width: 8; indent-tabs-mode: nil; c-basic-offset: 2 -*- */
/* vim: set ts=8 sts=2 et sw=2 tw=80: */
/* This Source Code Form is subject to the terms of the Mozilla Public
* License, v. 2.0. If a copy of the MPL was not distributed with this
* file, You can obtain one at http://mozilla.org/MPL/2.0/. */
#ifndef mozilla_PlatformMutex_h
#define mozilla_PlatformMutex_h
#include "mozilla/Atomics.h"
#include "mozilla/Attributes.h"
#include "mozilla/Move.h"
#include "mozilla/RecordReplay.h"
#if !defined(XP_WIN)
# include <pthread.h>
#endif
namespace mozilla {
namespace detail {
class ConditionVariableImpl;
class MutexImpl {
public:
struct PlatformData;
explicit MFBT_API MutexImpl(
recordreplay::Behavior aRecorded = recordreplay::Behavior::Preserve);
MFBT_API ~MutexImpl();
protected:
MFBT_API void lock();
MFBT_API void unlock();
// We have a separate, forwarding API so internal uses don't have to go
// through the PLT.
MFBT_API bool tryLock();
private:
MutexImpl(const MutexImpl&) = delete;
void operator=(const MutexImpl&) = delete;
MutexImpl(MutexImpl&&) = delete;
void operator=(MutexImpl&&) = delete;
bool operator==(const MutexImpl& rhs) = delete;
void mutexLock();
bool mutexTryLock();
PlatformData* platformData();
#if !defined(XP_WIN)
void* platformData_[sizeof(pthread_mutex_t) / sizeof(void*)];
static_assert(sizeof(pthread_mutex_t) / sizeof(void*) != 0 &&
sizeof(pthread_mutex_t) % sizeof(void*) == 0,
"pthread_mutex_t must have pointer alignment");
# ifdef XP_DARWIN
// Moving average of the number of spins it takes to acquire the mutex if we
// have to wait. May be accessed by multiple threads concurrently. Getting the
// latest value is not essential hence relaxed memory ordering is sufficient.
mozilla::Atomic<int32_t, mozilla::MemoryOrdering::Relaxed,
recordreplay::Behavior::DontPreserve>
averageSpins;
# endif
#else
void* platformData_[6];
#endif
friend class mozilla::detail::ConditionVariableImpl;
};
} // namespace detail
} // namespace mozilla
#endif // mozilla_PlatformMutex_h