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

Side by Side Diff: components/exo/compositor_frame_sink_holder.cc

Issue 2584953002: exo::CompositorFrameSinkHolder's release callbacks hold ref (Closed)
Patch Set: Added ReleaseTextureAndCompositorFrameSinkHolder() and ReleaseContentsTextureAndCompositorFrameSink… 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 2016 The Chromium Authors. All rights reserved. 1 // Copyright 2016 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 "components/exo/compositor_frame_sink_holder.h" 5 #include "components/exo/compositor_frame_sink_holder.h"
6 6
7 #include "base/callback_helpers.h"
7 #include "cc/resources/returned_resource.h" 8 #include "cc/resources/returned_resource.h"
8 #include "components/exo/surface.h" 9 #include "components/exo/surface.h"
9 10
10 namespace exo { 11 namespace exo {
11 12
12 //////////////////////////////////////////////////////////////////////////////// 13 ////////////////////////////////////////////////////////////////////////////////
13 // CompositorFrameSinkHolder, public: 14 // CompositorFrameSinkHolder, public:
14 15
15 CompositorFrameSinkHolder::CompositorFrameSinkHolder( 16 CompositorFrameSinkHolder::CompositorFrameSinkHolder(
16 Surface* surface, 17 Surface* surface,
17 std::unique_ptr<CompositorFrameSink> frame_sink, 18 std::unique_ptr<CompositorFrameSink> frame_sink,
18 cc::mojom::MojoCompositorFrameSinkClientRequest request) 19 cc::mojom::MojoCompositorFrameSinkClientRequest request)
19 : surface_(surface), 20 : surface_(surface),
20 frame_sink_(std::move(frame_sink)), 21 frame_sink_(std::move(frame_sink)),
21 begin_frame_source_(base::MakeUnique<cc::ExternalBeginFrameSource>(this)), 22 begin_frame_source_(base::MakeUnique<cc::ExternalBeginFrameSource>(this)),
22 binding_(this, std::move(request)), 23 binding_(this, std::move(request)),
23 weak_factory_(this) { 24 weak_factory_(this) {
24 surface_->AddSurfaceObserver(this); 25 surface_->AddSurfaceObserver(this);
25 } 26 }
26 27
27 bool CompositorFrameSinkHolder::HasReleaseCallbackForResource( 28 bool CompositorFrameSinkHolder::HasReleaseCallbackForResource(
28 cc::ResourceId id) { 29 cc::ResourceId id) {
29 return release_callbacks_.find(id) != release_callbacks_.end(); 30 return release_callbacks_.find(id) != release_callbacks_.end();
30 } 31 }
31 32
32 void CompositorFrameSinkHolder::AddResourceReleaseCallback( 33 void CompositorFrameSinkHolder::AddResourceReleaseCallback(
33 cc::ResourceId id, 34 cc::ResourceId id,
34 std::unique_ptr<cc::SingleReleaseCallback> callback) { 35 std::unique_ptr<cc::SingleReleaseCallback> callback) {
35 release_callbacks_[id] = std::make_pair(this, std::move(callback)); 36 release_callbacks_[id] = std::move(callback);
36 } 37 }
37 38
38 void CompositorFrameSinkHolder::ActivateFrameCallbacks( 39 void CompositorFrameSinkHolder::ActivateFrameCallbacks(
39 std::list<FrameCallback>* frame_callbacks) { 40 std::list<FrameCallback>* frame_callbacks) {
40 active_frame_callbacks_.splice(active_frame_callbacks_.end(), 41 active_frame_callbacks_.splice(active_frame_callbacks_.end(),
41 *frame_callbacks); 42 *frame_callbacks);
42 UpdateNeedsBeginFrame(); 43 UpdateNeedsBeginFrame();
43 } 44 }
44 45
45 void CompositorFrameSinkHolder::CancelFrameCallbacks() { 46 void CompositorFrameSinkHolder::CancelFrameCallbacks() {
(...skipping 30 matching lines...) Expand all
76 active_frame_callbacks_.pop_front(); 77 active_frame_callbacks_.pop_front();
77 } 78 }
78 begin_frame_source_->OnBeginFrame(args); 79 begin_frame_source_->OnBeginFrame(args);
79 } 80 }
80 81
81 void CompositorFrameSinkHolder::ReclaimResources( 82 void CompositorFrameSinkHolder::ReclaimResources(
82 const cc::ReturnedResourceArray& resources) { 83 const cc::ReturnedResourceArray& resources) {
83 for (auto& resource : resources) { 84 for (auto& resource : resources) {
84 auto it = release_callbacks_.find(resource.id); 85 auto it = release_callbacks_.find(resource.id);
85 DCHECK(it != release_callbacks_.end()); 86 DCHECK(it != release_callbacks_.end());
86 std::unique_ptr<cc::SingleReleaseCallback> callback = 87 base::ScopedClosureRunner runner(base::Bind(
reveman 2016/12/22 17:00:53 You're still not using PostTask here so this sink
Alex Z. 2016/12/22 18:08:48 I thought you wanted the ScopedClosureRunner to pr
reveman 2016/12/22 20:29:49 Yes, the only way that can happen is if you post a
Alex Z. 2016/12/23 22:45:38 Done.
87 std::move(it->second.second); 88 &cc::SingleReleaseCallback::Run, base::Passed(std::move(it->second)),
89 resource.sync_token, resource.lost));
88 release_callbacks_.erase(it); 90 release_callbacks_.erase(it);
89 callback->Run(resource.sync_token, resource.lost);
90 } 91 }
91 } 92 }
92 93
93 void CompositorFrameSinkHolder::WillDrawSurface() { 94 void CompositorFrameSinkHolder::WillDrawSurface() {
94 if (surface_) 95 if (surface_)
95 surface_->WillDraw(); 96 surface_->WillDraw();
96 97
97 UpdateNeedsBeginFrame(); 98 UpdateNeedsBeginFrame();
98 } 99 }
99 100
(...skipping 33 matching lines...) Expand 10 before | Expand all | Expand 10 after
133 134
134 bool needs_begin_frame = !active_frame_callbacks_.empty(); 135 bool needs_begin_frame = !active_frame_callbacks_.empty();
135 if (needs_begin_frame == needs_begin_frame_) 136 if (needs_begin_frame == needs_begin_frame_)
136 return; 137 return;
137 138
138 needs_begin_frame_ = needs_begin_frame; 139 needs_begin_frame_ = needs_begin_frame;
139 OnNeedsBeginFrames(needs_begin_frame_); 140 OnNeedsBeginFrames(needs_begin_frame_);
140 } 141 }
141 142
142 } // namespace exo 143 } // namespace exo
OLDNEW

Powered by Google App Engine
This is Rietveld 408576698