From 36d22d82aa202bb199967e9512281e9a53db42c9 Mon Sep 17 00:00:00 2001 From: Daniel Baumann Date: Sun, 7 Apr 2024 21:33:14 +0200 Subject: Adding upstream version 115.7.0esr. Signed-off-by: Daniel Baumann --- js/src/vm/Monitor.h | 72 +++++++++++++++++++++++++++++++++++++++++++++++++++++ 1 file changed, 72 insertions(+) create mode 100644 js/src/vm/Monitor.h (limited to 'js/src/vm/Monitor.h') diff --git a/js/src/vm/Monitor.h b/js/src/vm/Monitor.h new file mode 100644 index 0000000000..6c0fbff0d9 --- /dev/null +++ b/js/src/vm/Monitor.h @@ -0,0 +1,72 @@ +/* -*- 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 vm_Monitor_h +#define vm_Monitor_h + +#include "threading/ConditionVariable.h" +#include "threading/Mutex.h" + +namespace js { + +// A base class used for types intended to be used in a parallel +// fashion. Combines a lock and a condition variable. You can +// acquire the lock or signal the condition variable using the +// |AutoLockMonitor| type. + +class Monitor { + protected: + friend class AutoLockMonitor; + friend class AutoUnlockMonitor; + + Mutex lock_ MOZ_UNANNOTATED; + ConditionVariable condVar_; + + public: + explicit Monitor(const MutexId& id) : lock_(id) {} +}; + +class AutoLockMonitor : public LockGuard { + private: + using Base = LockGuard; + Monitor& monitor; + + public: + explicit AutoLockMonitor(Monitor& monitor) + : Base(monitor.lock_), monitor(monitor) {} + + bool isFor(Monitor& other) const { return &monitor.lock_ == &other.lock_; } + + void wait(ConditionVariable& condVar) { condVar.wait(*this); } + + void wait() { wait(monitor.condVar_); } + + void notify(ConditionVariable& condVar) { condVar.notify_one(); } + + void notify() { notify(monitor.condVar_); } + + void notifyAll(ConditionVariable& condVar) { condVar.notify_all(); } + + void notifyAll() { notifyAll(monitor.condVar_); } +}; + +class AutoUnlockMonitor { + private: + Monitor& monitor; + + public: + explicit AutoUnlockMonitor(Monitor& monitor) : monitor(monitor) { + monitor.lock_.unlock(); + } + + ~AutoUnlockMonitor() { monitor.lock_.lock(); } + + bool isFor(Monitor& other) const { return &monitor.lock_ == &other.lock_; } +}; + +} // namespace js + +#endif /* vm_Monitor_h */ -- cgit v1.2.3