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

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

Issue 2514033002: Introducing SurfaceReferenceFactory (Closed)
Patch Set: fix 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(SurfaceRefPtr 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_->DelegateLock(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_->AllowSurfaceDestruction();
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 SurfaceRefPtr 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 return make_scoped_refptr(new SurfaceLayer());
47 const RequireCallback& require_callback) {
48 return make_scoped_refptr(
49 new SurfaceLayer(satisfy_callback, require_callback));
50 } 45 }
51 46
52 SurfaceLayer::SurfaceLayer(const SatisfyCallback& satisfy_callback, 47 scoped_refptr<SurfaceLayer> SurfaceLayer::Create(SurfaceRefPtr surface_ref) {
53 const RequireCallback& require_callback) 48 return make_scoped_refptr(new SurfaceLayer(std::move(surface_ref)));
54 : surface_scale_(1.f), 49 }
55 satisfy_callback_(satisfy_callback), 50
56 require_callback_(require_callback) {} 51 SurfaceLayer::SurfaceLayer() {}
52
53 SurfaceLayer::SurfaceLayer(SurfaceRefPtr surface_ref) {
54 SetSurfaceRef(std::move(surface_ref));
55 }
57 56
58 SurfaceLayer::~SurfaceLayer() { 57 SurfaceLayer::~SurfaceLayer() {
59 DCHECK(!layer_tree_host()); 58 DCHECK(!layer_tree_host());
60 DCHECK(!destroy_sequence_.is_valid());
61 } 59 }
62 60
63 void SurfaceLayer::SetSurfaceId(const SurfaceId& surface_id, 61 void SurfaceLayer::SetSurfaceRef(SurfaceRefPtr surface_ref) {
64 float scale, 62 if (surface_ref_)
65 const gfx::Size& size) { 63 RemoveReference();
66 SatisfyDestroySequence(); 64 surface_ref_ = std::move(surface_ref);
67 surface_id_ = surface_id; 65 if (layer_tree_host()) {
68 surface_size_ = size; 66 surface_ref_->SetHost(layer_tree_host());
69 surface_scale_ = scale; 67 surface_ref_->BlockSurfaceDestruction();
70 CreateNewDestroySequence(); 68 }
71
72 UpdateDrawsContent(HasDrawableContent()); 69 UpdateDrawsContent(HasDrawableContent());
73 SetNeedsPushProperties(); 70 SetNeedsPushProperties();
74 } 71 }
75 72
76 std::unique_ptr<LayerImpl> SurfaceLayer::CreateLayerImpl( 73 std::unique_ptr<LayerImpl> SurfaceLayer::CreateLayerImpl(
77 LayerTreeImpl* tree_impl) { 74 LayerTreeImpl* tree_impl) {
78 return SurfaceLayerImpl::Create(tree_impl, id()); 75 return SurfaceLayerImpl::Create(tree_impl, id());
79 } 76 }
80 77
81 bool SurfaceLayer::HasDrawableContent() const { 78 bool SurfaceLayer::HasDrawableContent() const {
82 return surface_id_.is_valid() && Layer::HasDrawableContent(); 79 return surface_ref_->id().is_valid() && Layer::HasDrawableContent();
83 } 80 }
84 81
85 void SurfaceLayer::SetLayerTreeHost(LayerTreeHost* host) { 82 void SurfaceLayer::SetLayerTreeHost(LayerTreeHost* host) {
86 if (layer_tree_host() == host) { 83 if (layer_tree_host() == host) {
87 Layer::SetLayerTreeHost(host); 84 Layer::SetLayerTreeHost(host);
88 return; 85 return;
89 } 86 }
90 87 if (surface_ref_)
91 SatisfyDestroySequence(); 88 RemoveReference();
92 Layer::SetLayerTreeHost(host); 89 Layer::SetLayerTreeHost(host);
93 CreateNewDestroySequence(); 90 if (surface_ref_ && layer_tree_host()) {
91 surface_ref_->SetHost(layer_tree_host());
92 surface_ref_->BlockSurfaceDestruction();
93 }
94 } 94 }
95 95
96 void SurfaceLayer::PushPropertiesTo(LayerImpl* layer) { 96 void SurfaceLayer::PushPropertiesTo(LayerImpl* layer) {
97 Layer::PushPropertiesTo(layer); 97 Layer::PushPropertiesTo(layer);
98 TRACE_EVENT0("cc", "SurfaceLayer::PushPropertiesTo"); 98 TRACE_EVENT0("cc", "SurfaceLayer::PushPropertiesTo");
99 SurfaceLayerImpl* layer_impl = static_cast<SurfaceLayerImpl*>(layer); 99 SurfaceLayerImpl* layer_impl = static_cast<SurfaceLayerImpl*>(layer);
100 100 layer_impl->SetSurfaceId(surface_ref_->id());
Saman Sami 2016/11/30 18:05:51 Send clone maybe
101 layer_impl->SetSurfaceId(surface_id_); 101 layer_impl->SetSurfaceSize(surface_ref_->size());
102 layer_impl->SetSurfaceSize(surface_size_); 102 layer_impl->SetSurfaceScale(surface_ref_->scale());
103 layer_impl->SetSurfaceScale(surface_scale_);
104 } 103 }
105 104
106 void SurfaceLayer::CreateNewDestroySequence() { 105 void SurfaceLayer::RemoveReference() {
107 DCHECK(!destroy_sequence_.is_valid());
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()) 106 if (!layer_tree_host())
118 return; 107 return;
119 DCHECK(destroy_sequence_.is_valid()); 108 DCHECK(surface_ref_);
109 SurfaceRefPtr clone = surface_ref_->Clone();
120 std::unique_ptr<SatisfySwapPromise> satisfy( 110 std::unique_ptr<SatisfySwapPromise> satisfy(
121 new SatisfySwapPromise(destroy_sequence_, satisfy_callback_)); 111 new SatisfySwapPromise(std::move(surface_ref_)));
122 layer_tree_host()->GetSwapPromiseManager()->QueueSwapPromise( 112 layer_tree_host()->GetSwapPromiseManager()->QueueSwapPromise(
123 std::move(satisfy)); 113 std::move(satisfy));
124 destroy_sequence_ = SurfaceSequence(); 114 surface_ref_ = std::move(clone);
125 } 115 }
126 116
127 } // namespace cc 117 } // namespace cc
OLDNEW

Powered by Google App Engine
This is Rietveld 408576698