summaryrefslogtreecommitdiffstats
path: root/dom/canvas/WebGLSync.cpp
diff options
context:
space:
mode:
authorDaniel Baumann <daniel.baumann@progress-linux.org>2024-05-15 03:34:42 +0000
committerDaniel Baumann <daniel.baumann@progress-linux.org>2024-05-15 03:34:42 +0000
commitda4c7e7ed675c3bf405668739c3012d140856109 (patch)
treecdd868dba063fecba609a1d819de271f0d51b23e /dom/canvas/WebGLSync.cpp
parentAdding upstream version 125.0.3. (diff)
downloadfirefox-da4c7e7ed675c3bf405668739c3012d140856109.tar.xz
firefox-da4c7e7ed675c3bf405668739c3012d140856109.zip
Adding upstream version 126.0.upstream/126.0
Signed-off-by: Daniel Baumann <daniel.baumann@progress-linux.org>
Diffstat (limited to 'dom/canvas/WebGLSync.cpp')
-rw-r--r--dom/canvas/WebGLSync.cpp35
1 files changed, 32 insertions, 3 deletions
diff --git a/dom/canvas/WebGLSync.cpp b/dom/canvas/WebGLSync.cpp
index e4b196ab04..6a8e9403f7 100644
--- a/dom/canvas/WebGLSync.cpp
+++ b/dom/canvas/WebGLSync.cpp
@@ -23,10 +23,39 @@ WebGLSync::~WebGLSync() {
mContext->gl->fDeleteSync(mGLName);
}
-void WebGLSync::MarkSignaled() const {
- if (mContext->mCompletedFenceId < mFenceId) {
- mContext->mCompletedFenceId = mFenceId;
+ClientWaitSyncResult WebGLSync::ClientWaitSync(const GLbitfield flags,
+ const GLuint64 timeout) {
+ if (!mContext) return ClientWaitSyncResult::WAIT_FAILED;
+ if (IsKnownComplete()) return ClientWaitSyncResult::ALREADY_SIGNALED;
+
+ auto ret = ClientWaitSyncResult::WAIT_FAILED;
+ bool newlyComplete = false;
+ const auto status = static_cast<ClientWaitSyncResult>(
+ mContext->gl->fClientWaitSync(mGLName, 0, 0));
+ switch (status) {
+ case ClientWaitSyncResult::TIMEOUT_EXPIRED: // Poll() -> false
+ case ClientWaitSyncResult::WAIT_FAILED: // Error
+ ret = status;
+ break;
+ case ClientWaitSyncResult::CONDITION_SATISFIED: // Should never happen, but
+ // tolerate it.
+ case ClientWaitSyncResult::ALREADY_SIGNALED: // Poll() -> true
+ newlyComplete = true;
+ ret = status;
+ break;
+ }
+
+ if (newlyComplete) {
+ if (mContext->mCompletedFenceId < mFenceId) {
+ mContext->mCompletedFenceId = mFenceId;
+ }
+ MOZ_RELEASE_ASSERT(mOnCompleteTasks);
+ for (const auto& task : *mOnCompleteTasks) {
+ (*task)();
+ }
+ mOnCompleteTasks = {};
}
+ return ret;
}
} // namespace mozilla