| // Copyright (c) 2016 The Chromium Authors. All rights reserved. | 
 | // Use of this source code is governed by a BSD-style license that can be | 
 | // found in the LICENSE file. | 
 |  | 
 | #ifndef QUICHE_QUIC_PLATFORM_API_QUIC_MUTEX_H_ | 
 | #define QUICHE_QUIC_PLATFORM_API_QUIC_MUTEX_H_ | 
 |  | 
 | // TODO(b/178613777): move into the common QUICHE platform. | 
 | #include "quiche_platform_impl/quic_mutex_impl.h" | 
 |  | 
 | #define QUIC_EXCLUSIVE_LOCKS_REQUIRED QUIC_EXCLUSIVE_LOCKS_REQUIRED_IMPL | 
 | #define QUIC_GUARDED_BY QUIC_GUARDED_BY_IMPL | 
 | #define QUIC_LOCKABLE QUIC_LOCKABLE_IMPL | 
 | #define QUIC_LOCKS_EXCLUDED QUIC_LOCKS_EXCLUDED_IMPL | 
 | #define QUIC_SHARED_LOCKS_REQUIRED QUIC_SHARED_LOCKS_REQUIRED_IMPL | 
 | #define QUIC_EXCLUSIVE_LOCK_FUNCTION QUIC_EXCLUSIVE_LOCK_FUNCTION_IMPL | 
 | #define QUIC_UNLOCK_FUNCTION QUIC_UNLOCK_FUNCTION_IMPL | 
 | #define QUIC_SHARED_LOCK_FUNCTION QUIC_SHARED_LOCK_FUNCTION_IMPL | 
 | #define QUIC_SCOPED_LOCKABLE QUIC_SCOPED_LOCKABLE_IMPL | 
 | #define QUIC_ASSERT_SHARED_LOCK QUIC_ASSERT_SHARED_LOCK_IMPL | 
 |  | 
 | namespace quic { | 
 |  | 
 | // A class representing a non-reentrant mutex in QUIC. | 
 | class QUIC_LOCKABLE QUIC_EXPORT_PRIVATE QuicMutex { | 
 |  public: | 
 |   QuicMutex() = default; | 
 |   QuicMutex(const QuicMutex&) = delete; | 
 |   QuicMutex& operator=(const QuicMutex&) = delete; | 
 |  | 
 |   // Block until this Mutex is free, then acquire it exclusively. | 
 |   void WriterLock() QUIC_EXCLUSIVE_LOCK_FUNCTION(); | 
 |  | 
 |   // Release this Mutex. Caller must hold it exclusively. | 
 |   void WriterUnlock() QUIC_UNLOCK_FUNCTION(); | 
 |  | 
 |   // Block until this Mutex is free or shared, then acquire a share of it. | 
 |   void ReaderLock() QUIC_SHARED_LOCK_FUNCTION(); | 
 |  | 
 |   // Release this Mutex. Caller could hold it in shared mode. | 
 |   void ReaderUnlock() QUIC_UNLOCK_FUNCTION(); | 
 |  | 
 |   // Returns immediately if current thread holds the Mutex in at least shared | 
 |   // mode.  Otherwise, may report an error (typically by crashing with a | 
 |   // diagnostic), or may return immediately. | 
 |   void AssertReaderHeld() const QUIC_ASSERT_SHARED_LOCK(); | 
 |  | 
 |  private: | 
 |   QuicLockImpl impl_; | 
 | }; | 
 |  | 
 | // A helper class that acquires the given QuicMutex shared lock while the | 
 | // QuicReaderMutexLock is in scope. | 
 | class QUIC_SCOPED_LOCKABLE QUIC_EXPORT_PRIVATE QuicReaderMutexLock { | 
 |  public: | 
 |   explicit QuicReaderMutexLock(QuicMutex* lock) QUIC_SHARED_LOCK_FUNCTION(lock); | 
 |   QuicReaderMutexLock(const QuicReaderMutexLock&) = delete; | 
 |   QuicReaderMutexLock& operator=(const QuicReaderMutexLock&) = delete; | 
 |  | 
 |   ~QuicReaderMutexLock() QUIC_UNLOCK_FUNCTION(); | 
 |  | 
 |  private: | 
 |   QuicMutex* const lock_; | 
 | }; | 
 |  | 
 | // A helper class that acquires the given QuicMutex exclusive lock while the | 
 | // QuicWriterMutexLock is in scope. | 
 | class QUIC_SCOPED_LOCKABLE QUIC_EXPORT_PRIVATE QuicWriterMutexLock { | 
 |  public: | 
 |   explicit QuicWriterMutexLock(QuicMutex* lock) | 
 |       QUIC_EXCLUSIVE_LOCK_FUNCTION(lock); | 
 |   QuicWriterMutexLock(const QuicWriterMutexLock&) = delete; | 
 |   QuicWriterMutexLock& operator=(const QuicWriterMutexLock&) = delete; | 
 |  | 
 |   ~QuicWriterMutexLock() QUIC_UNLOCK_FUNCTION(); | 
 |  | 
 |  private: | 
 |   QuicMutex* const lock_; | 
 | }; | 
 |  | 
 | // A Notification allows threads to receive notification of a single occurrence | 
 | // of a single event. | 
 | class QUIC_EXPORT_PRIVATE QuicNotification { | 
 |  public: | 
 |   QuicNotification() = default; | 
 |   QuicNotification(const QuicNotification&) = delete; | 
 |   QuicNotification& operator=(const QuicNotification&) = delete; | 
 |  | 
 |   bool HasBeenNotified() { return impl_.HasBeenNotified(); } | 
 |  | 
 |   void Notify() { impl_.Notify(); } | 
 |  | 
 |   void WaitForNotification() { impl_.WaitForNotification(); } | 
 |  | 
 |  private: | 
 |   QuicNotificationImpl impl_; | 
 | }; | 
 |  | 
 | }  // namespace quic | 
 |  | 
 | #endif  // QUICHE_QUIC_PLATFORM_API_QUIC_MUTEX_H_ |