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
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
content / browser / renderer_host / embedded_frame_sink_impl.cc [blame]
// Copyright 2016 The Chromium Authors
// Use of this source code is governed by a BSD-style license that can be
// found in the LICENSE file.
#include "content/browser/renderer_host/embedded_frame_sink_impl.h"
#include <memory>
#include <utility>
#include "base/time/time.h"
#include "components/viz/host/host_frame_sink_manager.h"
namespace content {
EmbeddedFrameSinkImpl::EmbeddedFrameSinkImpl(
viz::HostFrameSinkManager* host_frame_sink_manager,
const viz::FrameSinkId& parent_frame_sink_id,
const viz::FrameSinkId& frame_sink_id,
mojo::PendingRemote<blink::mojom::EmbeddedFrameSinkClient> client,
DestroyCallback destroy_callback)
: host_frame_sink_manager_(host_frame_sink_manager),
parent_frame_sink_id_(parent_frame_sink_id),
frame_sink_id_(frame_sink_id) {
client_.Bind(std::move(client));
client_.set_disconnect_handler(std::move(destroy_callback));
host_frame_sink_manager_->RegisterFrameSinkId(
frame_sink_id_, this, viz::ReportFirstSurfaceActivation::kNo);
host_frame_sink_manager_->SetFrameSinkDebugLabel(frame_sink_id_,
"EmbeddedFrameSinkImpl");
}
EmbeddedFrameSinkImpl::~EmbeddedFrameSinkImpl() {
if (has_registered_compositor_frame_sink_) {
host_frame_sink_manager_->UnregisterFrameSinkHierarchy(
parent_frame_sink_id_, frame_sink_id_);
}
host_frame_sink_manager_->InvalidateFrameSinkId(frame_sink_id_, this);
}
void EmbeddedFrameSinkImpl::CreateCompositorFrameSink(
mojo::PendingRemote<viz::mojom::CompositorFrameSinkClient> client,
mojo::PendingReceiver<viz::mojom::CompositorFrameSink> receiver) {
CreateFrameSink(/*bundle_id=*/std::nullopt, std::move(client),
std::move(receiver));
}
void EmbeddedFrameSinkImpl::CreateBundledCompositorFrameSink(
const viz::FrameSinkBundleId& bundle_id,
mojo::PendingRemote<viz::mojom::CompositorFrameSinkClient> client,
mojo::PendingReceiver<viz::mojom::CompositorFrameSink> receiver) {
CreateFrameSink(bundle_id, std::move(client), std::move(receiver));
}
void EmbeddedFrameSinkImpl::CreateFrameSink(
const std::optional<viz::FrameSinkBundleId>& bundle_id,
mojo::PendingRemote<viz::mojom::CompositorFrameSinkClient> client,
mojo::PendingReceiver<viz::mojom::CompositorFrameSink> receiver) {
// We might recreate the CompositorFrameSink on context loss or GPU crash.
// Only register frame sink hierarchy the first time.
if (!has_registered_compositor_frame_sink_) {
// The request to create an embedded frame sink and the lifetime of the
// parent are controlled by different IPC channels. It's possible the parent
// FrameSinkId has been invalidated by the time this request has arrived. In
// that case, drop the request since there is no embedder.
if (!host_frame_sink_manager_->RegisterFrameSinkHierarchy(
parent_frame_sink_id_, frame_sink_id_)) {
return;
}
}
if (bundle_id.has_value()) {
host_frame_sink_manager_->CreateBundledCompositorFrameSink(
frame_sink_id_, *bundle_id, std::move(receiver), std::move(client));
} else {
host_frame_sink_manager_->CreateCompositorFrameSink(
frame_sink_id_, std::move(receiver), std::move(client));
}
has_registered_compositor_frame_sink_ = true;
}
void EmbeddedFrameSinkImpl::ConnectToEmbedder(
mojo::PendingReceiver<blink::mojom::SurfaceEmbedder>
surface_embedder_receiver) {
client_->BindSurfaceEmbedder(std::move(surface_embedder_receiver));
}
void EmbeddedFrameSinkImpl::OnFirstSurfaceActivation(
const viz::SurfaceInfo& surface_info) {}
void EmbeddedFrameSinkImpl::OnFrameTokenChanged(
uint32_t frame_token,
base::TimeTicks activation_time) {
// TODO(yiyix, fsamuel): To complete plumbing of frame tokens for offscreen
// canvas
}
void EmbeddedFrameSinkImpl::RegisterFrameSinkHierarchy() {
if (!has_registered_compositor_frame_sink_ &&
host_frame_sink_manager_->RegisterFrameSinkHierarchy(
parent_frame_sink_id_, frame_sink_id_)) {
has_registered_compositor_frame_sink_ = true;
return;
}
DLOG(ERROR) << "Unable to register " << parent_frame_sink_id_
<< " as parent of " << frame_sink_id_;
}
void EmbeddedFrameSinkImpl::UnregisterFrameSinkHierarchy() {
if (has_registered_compositor_frame_sink_) {
host_frame_sink_manager_->UnregisterFrameSinkHierarchy(
parent_frame_sink_id_, frame_sink_id_);
has_registered_compositor_frame_sink_ = false;
return;
}
DLOG(ERROR) << "Unable to unregister " << parent_frame_sink_id_
<< " as parent of " << frame_sink_id_;
}
} // namespace content