blob: 47dd08a7a45d9745ecce745fd0c988717a491445 (
plain)
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
91
92
93
94
|
/* -*- 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/. */
#include "WebRenderCanvasRenderer.h"
#include "GLContext.h"
#include "GLScreenBuffer.h"
#include "mozilla/layers/CompositorBridgeChild.h"
#include "mozilla/StaticPrefs_webgl.h"
#include "SharedSurfaceGL.h"
#include "WebRenderBridgeChild.h"
namespace mozilla {
namespace layers {
CompositableForwarder* WebRenderCanvasRenderer::GetForwarder() {
return mManager->WrBridge();
}
WebRenderCanvasRendererAsync::~WebRenderCanvasRendererAsync() {
if (mPipelineId.isSome()) {
mManager->RemovePipelineIdForCompositable(mPipelineId.ref());
mPipelineId.reset();
}
}
void WebRenderCanvasRendererAsync::Initialize(const CanvasRendererData& aData) {
WebRenderCanvasRenderer::Initialize(aData);
ClearCachedResources();
}
bool WebRenderCanvasRendererAsync::CreateCompositable() {
if (!mCanvasClient) {
auto compositableFlags = TextureFlags::NO_FLAGS;
if (!mData.mIsAlphaPremult) {
// WR needs this flag marked on the compositable, not just the texture.
compositableFlags |= TextureFlags::NON_PREMULTIPLIED;
}
mCanvasClient = new CanvasClient(GetForwarder(), compositableFlags);
mCanvasClient->Connect();
}
return true;
}
void WebRenderCanvasRendererAsync::EnsurePipeline() {
MOZ_ASSERT(mCanvasClient);
if (!mCanvasClient) {
return;
}
if (mPipelineId) {
return;
}
// Alloc async image pipeline id.
mPipelineId = Some(
mManager->WrBridge()->GetCompositorBridgeChild()->GetNextPipelineId());
mManager->AddPipelineIdForCompositable(
mPipelineId.ref(), mCanvasClient->GetIPCHandle(),
CompositableHandleOwner::WebRenderBridge);
}
bool WebRenderCanvasRendererAsync::HasPipeline() {
return mPipelineId.isSome();
}
void WebRenderCanvasRendererAsync::ClearCachedResources() {
if (mPipelineId.isSome()) {
mManager->RemovePipelineIdForCompositable(mPipelineId.ref());
mPipelineId.reset();
}
}
void WebRenderCanvasRendererAsync::
UpdateCompositableClientForEmptyTransaction() {
bool wasDirty = IsDirty();
UpdateCompositableClient();
if (wasDirty && mPipelineId.isSome()) {
// Notify an update of async image pipeline during empty transaction.
// During non empty transaction, WebRenderBridgeParent receives
// OpUpdateAsyncImagePipeline message, but during empty transaction, the
// message is not sent to WebRenderBridgeParent. Then
// OpUpdatedAsyncImagePipeline is used to notify the update.
mManager->AddWebRenderParentCommand(
OpUpdatedAsyncImagePipeline(mPipelineId.ref()));
}
}
} // namespace layers
} // namespace mozilla
|