Chromium Code Reviews
chromiumcodereview-hr@appspot.gserviceaccount.com (chromiumcodereview-hr) | Please choose your nickname with Settings | Help | Chromium Project | Gerrit Changes | Sign out
(400)

Side by Side Diff: cc/layers/surface_layer.cc

Issue 2514033002: Introducing SurfaceReferenceFactory (Closed)
Patch Set: c Created 4 years ago
Use n/p to move between diff chunks; N/P to move between comments. Draft comments are only viewable by you.
Jump to:
View unified diff | Download patch
OLDNEW
1 // Copyright 2014 The Chromium Authors. All rights reserved. 1 // Copyright 2014 The Chromium Authors. All rights reserved.
2 // Use of this source code is governed by a BSD-style license that can be 2 // Use of this source code is governed by a BSD-style license that can be
3 // found in the LICENSE file. 3 // found in the LICENSE file.
4 4
5 #include "cc/layers/surface_layer.h" 5 #include "cc/layers/surface_layer.h"
6 6
7 #include <stdint.h> 7 #include <stdint.h>
8 8
9 #include "base/macros.h" 9 #include "base/macros.h"
10 #include "base/trace_event/trace_event.h" 10 #include "base/trace_event/trace_event.h"
11 #include "cc/layers/surface_layer_impl.h" 11 #include "cc/layers/surface_layer_impl.h"
12 #include "cc/output/swap_promise.h" 12 #include "cc/output/swap_promise.h"
13 #include "cc/surfaces/surface_sequence_generator.h" 13 #include "cc/surfaces/surface_sequence_generator.h"
14 #include "cc/trees/layer_tree_host.h" 14 #include "cc/trees/layer_tree_host.h"
15 #include "cc/trees/swap_promise_manager.h" 15 #include "cc/trees/swap_promise_manager.h"
16 16
17 namespace cc { 17 namespace cc {
18 18
19 class SatisfySwapPromise : public SwapPromise { 19 class SatisfySwapPromise : public SwapPromise {
20 public: 20 public:
21 SatisfySwapPromise(SurfaceSequence sequence, 21 explicit SatisfySwapPromise(std::unique_ptr<SurfaceReferenceBase> surface_ref)
22 const SurfaceLayer::SatisfyCallback& satisfy_callback) 22 : surface_ref_(std::move(surface_ref)) {}
23 : sequence_(sequence), satisfy_callback_(satisfy_callback) {}
24 23
25 ~SatisfySwapPromise() override {} 24 ~SatisfySwapPromise() override {}
26 25
27 private: 26 private:
28 void DidActivate() override {} 27 void DidActivate() override {}
29 void DidSwap(CompositorFrameMetadata* metadata) override { 28 void DidSwap(CompositorFrameMetadata* metadata) override {
30 metadata->satisfies_sequences.push_back(sequence_.sequence); 29 surface_ref_->Destroy(metadata);
31 } 30 }
32 31
33 DidNotSwapAction DidNotSwap(DidNotSwapReason reason) override { 32 DidNotSwapAction DidNotSwap(DidNotSwapReason reason) override {
34 satisfy_callback_.Run(sequence_); 33 surface_ref_->Destroy();
35 return DidNotSwapAction::BREAK_PROMISE; 34 return DidNotSwapAction::BREAK_PROMISE;
36 } 35 }
37 int64_t TraceId() const override { return 0; } 36 int64_t TraceId() const override { return 0; }
38 37
39 SurfaceSequence sequence_; 38 std::unique_ptr<SurfaceReferenceBase> surface_ref_;
40 SurfaceLayer::SatisfyCallback satisfy_callback_;
41 39
42 DISALLOW_COPY_AND_ASSIGN(SatisfySwapPromise); 40 DISALLOW_COPY_AND_ASSIGN(SatisfySwapPromise);
43 }; 41 };
44 42
45 scoped_refptr<SurfaceLayer> SurfaceLayer::Create( 43 scoped_refptr<SurfaceLayer> SurfaceLayer::Create(
46 const SatisfyCallback& satisfy_callback, 44 scoped_refptr<SurfaceReferenceFactory> ref_factory) {
47 const RequireCallback& require_callback) { 45 return make_scoped_refptr(new SurfaceLayer(std::move(ref_factory)));
48 return make_scoped_refptr(
49 new SurfaceLayer(satisfy_callback, require_callback));
50 } 46 }
51 47
52 SurfaceLayer::SurfaceLayer(const SatisfyCallback& satisfy_callback, 48 SurfaceLayer::SurfaceLayer(scoped_refptr<SurfaceReferenceFactory> ref_factory) {
53 const RequireCallback& require_callback) 49 ref_factory_ = std::move(ref_factory);
kylechar 2016/12/14 20:51:53 ref_factory_(std::move(ref_factory))
Saman Sami 2016/12/14 21:54:22 Done.
54 : surface_scale_(1.f), 50 }
55 satisfy_callback_(satisfy_callback),
56 require_callback_(require_callback) {}
57 51
58 SurfaceLayer::~SurfaceLayer() { 52 SurfaceLayer::~SurfaceLayer() {
59 DCHECK(!layer_tree_host()); 53 DCHECK(!layer_tree_host());
60 DCHECK(!destroy_sequence_.is_valid());
61 } 54 }
62 55
63 void SurfaceLayer::SetSurfaceId(const SurfaceId& surface_id, 56 void SurfaceLayer::SetSurfaceInfo(const SurfaceInfo& surface_info) {
64 float scale, 57 RemoveCurrentReference();
65 const gfx::Size& size) { 58 surface_info_ = surface_info;
66 SatisfyDestroySequence(); 59 if (layer_tree_host()) {
67 surface_id_ = surface_id; 60 current_ref_ =
68 surface_size_ = size; 61 ref_factory_->CreateReference(layer_tree_host(), surface_info_.id());
69 surface_scale_ = scale; 62 }
70 CreateNewDestroySequence();
71
72 UpdateDrawsContent(HasDrawableContent()); 63 UpdateDrawsContent(HasDrawableContent());
73 SetNeedsPushProperties(); 64 SetNeedsPushProperties();
74 } 65 }
75 66
76 std::unique_ptr<LayerImpl> SurfaceLayer::CreateLayerImpl( 67 std::unique_ptr<LayerImpl> SurfaceLayer::CreateLayerImpl(
77 LayerTreeImpl* tree_impl) { 68 LayerTreeImpl* tree_impl) {
78 return SurfaceLayerImpl::Create(tree_impl, id()); 69 return SurfaceLayerImpl::Create(tree_impl, id());
79 } 70 }
80 71
81 bool SurfaceLayer::HasDrawableContent() const { 72 bool SurfaceLayer::HasDrawableContent() const {
82 return surface_id_.is_valid() && Layer::HasDrawableContent(); 73 return surface_info_.id().is_valid() && Layer::HasDrawableContent();
83 } 74 }
84 75
85 void SurfaceLayer::SetLayerTreeHost(LayerTreeHost* host) { 76 void SurfaceLayer::SetLayerTreeHost(LayerTreeHost* host) {
86 if (layer_tree_host() == host) { 77 if (layer_tree_host() == host) {
87 Layer::SetLayerTreeHost(host); 78 Layer::SetLayerTreeHost(host);
88 return; 79 return;
89 } 80 }
90 81 RemoveCurrentReference();
91 SatisfyDestroySequence();
92 Layer::SetLayerTreeHost(host); 82 Layer::SetLayerTreeHost(host);
93 CreateNewDestroySequence(); 83 if (layer_tree_host()) {
84 current_ref_ =
85 ref_factory_->CreateReference(layer_tree_host(), surface_info_.id());
86 }
94 } 87 }
95 88
96 void SurfaceLayer::PushPropertiesTo(LayerImpl* layer) { 89 void SurfaceLayer::PushPropertiesTo(LayerImpl* layer) {
97 Layer::PushPropertiesTo(layer); 90 Layer::PushPropertiesTo(layer);
98 TRACE_EVENT0("cc", "SurfaceLayer::PushPropertiesTo"); 91 TRACE_EVENT0("cc", "SurfaceLayer::PushPropertiesTo");
99 SurfaceLayerImpl* layer_impl = static_cast<SurfaceLayerImpl*>(layer); 92 SurfaceLayerImpl* layer_impl = static_cast<SurfaceLayerImpl*>(layer);
100 93 layer_impl->SetSurfaceInfo(surface_info_);
101 layer_impl->SetSurfaceId(surface_id_);
102 layer_impl->SetSurfaceSize(surface_size_);
103 layer_impl->SetSurfaceScale(surface_scale_);
104 } 94 }
105 95
106 void SurfaceLayer::CreateNewDestroySequence() { 96 void SurfaceLayer::RemoveCurrentReference() {
107 DCHECK(!destroy_sequence_.is_valid()); 97 if (!current_ref_)
108 if (layer_tree_host()) {
109 destroy_sequence_ = layer_tree_host()
110 ->GetSurfaceSequenceGenerator()
111 ->CreateSurfaceSequence();
112 require_callback_.Run(surface_id_, destroy_sequence_);
113 }
114 }
115
116 void SurfaceLayer::SatisfyDestroySequence() {
117 if (!layer_tree_host())
118 return; 98 return;
119 DCHECK(destroy_sequence_.is_valid());
120 std::unique_ptr<SatisfySwapPromise> satisfy(
121 new SatisfySwapPromise(destroy_sequence_, satisfy_callback_));
122 layer_tree_host()->GetSwapPromiseManager()->QueueSwapPromise( 99 layer_tree_host()->GetSwapPromiseManager()->QueueSwapPromise(
123 std::move(satisfy)); 100 base::MakeUnique<SatisfySwapPromise>(std::move(current_ref_)));
124 destroy_sequence_ = SurfaceSequence();
125 } 101 }
126 102
127 } // namespace cc 103 } // namespace cc
OLDNEW

Powered by Google App Engine
This is Rietveld 408576698