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

Side by Side Diff: cc/surfaces/direct_compositor_frame_sink.h

Issue 2888043004: [cc] Add and plumb CFS::DidNotProduceFrame. (Closed)
Patch Set: remove ExternalBFS::OnDidFinishFrame and related ack tracking. Created 3 years, 7 months 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 #ifndef CC_SURFACES_DIRECT_COMPOSITOR_FRAME_SINK_H_ 5 #ifndef CC_SURFACES_DIRECT_COMPOSITOR_FRAME_SINK_H_
6 #define CC_SURFACES_DIRECT_COMPOSITOR_FRAME_SINK_H_ 6 #define CC_SURFACES_DIRECT_COMPOSITOR_FRAME_SINK_H_
7 7
8 #include "base/macros.h" 8 #include "base/macros.h"
9 #include "base/threading/thread_checker.h" 9 #include "base/threading/thread_checker.h"
10 #include "cc/output/compositor_frame_sink.h" 10 #include "cc/output/compositor_frame_sink.h"
(...skipping 31 matching lines...) Expand 10 before | Expand all | Expand 10 after
42 const FrameSinkId& frame_sink_id, 42 const FrameSinkId& frame_sink_id,
43 SurfaceManager* surface_manager, 43 SurfaceManager* surface_manager,
44 Display* display, 44 Display* display,
45 scoped_refptr<VulkanContextProvider> vulkan_context_provider); 45 scoped_refptr<VulkanContextProvider> vulkan_context_provider);
46 ~DirectCompositorFrameSink() override; 46 ~DirectCompositorFrameSink() override;
47 47
48 // CompositorFrameSink implementation. 48 // CompositorFrameSink implementation.
49 bool BindToClient(CompositorFrameSinkClient* client) override; 49 bool BindToClient(CompositorFrameSinkClient* client) override;
50 void DetachFromClient() override; 50 void DetachFromClient() override;
51 void SubmitCompositorFrame(CompositorFrame frame) override; 51 void SubmitCompositorFrame(CompositorFrame frame) override;
52 void BeginFrameDidNotProduceFrame(const BeginFrameAck& ack) override;
52 53
53 // DisplayClient implementation. 54 // DisplayClient implementation.
54 void DisplayOutputSurfaceLost() override; 55 void DisplayOutputSurfaceLost() override;
55 void DisplayWillDrawAndSwap(bool will_draw_and_swap, 56 void DisplayWillDrawAndSwap(bool will_draw_and_swap,
56 const RenderPassList& render_passes) override; 57 const RenderPassList& render_passes) override;
57 void DisplayDidDrawAndSwap() override; 58 void DisplayDidDrawAndSwap() override;
58 59
59 protected: 60 protected:
60 std::unique_ptr<CompositorFrameSinkSupport> support_; // protected for test. 61 std::unique_ptr<CompositorFrameSinkSupport> support_; // protected for test.
61 62
62 private: 63 private:
63 // CompositorFrameSinkSupportClient implementation: 64 // CompositorFrameSinkSupportClient implementation:
64 void DidReceiveCompositorFrameAck( 65 void DidReceiveCompositorFrameAck(
65 const ReturnedResourceArray& resources) override; 66 const ReturnedResourceArray& resources) override;
66 void OnBeginFrame(const BeginFrameArgs& args) override; 67 void OnBeginFrame(const BeginFrameArgs& args) override;
67 void ReclaimResources(const ReturnedResourceArray& resources) override; 68 void ReclaimResources(const ReturnedResourceArray& resources) override;
68 void WillDrawSurface(const LocalSurfaceId& local_surface_id, 69 void WillDrawSurface(const LocalSurfaceId& local_surface_id,
69 const gfx::Rect& damage_rect) override; 70 const gfx::Rect& damage_rect) override;
70 71
71 // ExternalBeginFrameSourceClient implementation: 72 // ExternalBeginFrameSourceClient implementation:
72 void OnNeedsBeginFrames(bool needs_begin_frame) override; 73 void OnNeedsBeginFrames(bool needs_begin_frame) override;
73 void OnDidFinishFrame(const BeginFrameAck& ack) override;
74 74
75 // This class is only meant to be used on a single thread. 75 // This class is only meant to be used on a single thread.
76 base::ThreadChecker thread_checker_; 76 base::ThreadChecker thread_checker_;
77 77
78 const FrameSinkId frame_sink_id_; 78 const FrameSinkId frame_sink_id_;
79 LocalSurfaceId delegated_local_surface_id_; 79 LocalSurfaceId delegated_local_surface_id_;
80 SurfaceManager* surface_manager_; 80 SurfaceManager* surface_manager_;
81 LocalSurfaceIdAllocator local_surface_id_allocator_; 81 LocalSurfaceIdAllocator local_surface_id_allocator_;
82 Display* display_; 82 Display* display_;
83 gfx::Size last_swap_frame_size_; 83 gfx::Size last_swap_frame_size_;
84 bool is_lost_ = false; 84 bool is_lost_ = false;
85 std::unique_ptr<ExternalBeginFrameSource> begin_frame_source_; 85 std::unique_ptr<ExternalBeginFrameSource> begin_frame_source_;
86 86
87 DISALLOW_COPY_AND_ASSIGN(DirectCompositorFrameSink); 87 DISALLOW_COPY_AND_ASSIGN(DirectCompositorFrameSink);
88 }; 88 };
89 89
90 } // namespace cc 90 } // namespace cc
91 91
92 #endif // CC_SURFACES_DIRECT_COMPOSITOR_FRAME_SINK_H_ 92 #endif // CC_SURFACES_DIRECT_COMPOSITOR_FRAME_SINK_H_
OLDNEW

Powered by Google App Engine
This is Rietveld 408576698