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

Side by Side Diff: cc/raster/one_copy_tile_task_worker_pool.h

Issue 1139063002: cc: Partial tile update for one-copy raster. (Closed) Base URL: https://chromium.googlesource.com/chromium/src.git@master
Patch Set: monocle: tilemanagerconsistency Created 5 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_RASTER_ONE_COPY_TILE_TASK_WORKER_POOL_H_ 5 #ifndef CC_RASTER_ONE_COPY_TILE_TASK_WORKER_POOL_H_
6 #define CC_RASTER_ONE_COPY_TILE_TASK_WORKER_POOL_H_ 6 #define CC_RASTER_ONE_COPY_TILE_TASK_WORKER_POOL_H_
7 7
8 #include "base/memory/weak_ptr.h" 8 #include "base/memory/weak_ptr.h"
9 #include "base/synchronization/lock.h" 9 #include "base/synchronization/lock.h"
10 #include "base/values.h" 10 #include "base/values.h"
(...skipping 20 matching lines...) Expand all
31 public TileTaskRunner, 31 public TileTaskRunner,
32 public TileTaskClient { 32 public TileTaskClient {
33 public: 33 public:
34 ~OneCopyTileTaskWorkerPool() override; 34 ~OneCopyTileTaskWorkerPool() override;
35 35
36 static scoped_ptr<TileTaskWorkerPool> Create( 36 static scoped_ptr<TileTaskWorkerPool> Create(
37 base::SequencedTaskRunner* task_runner, 37 base::SequencedTaskRunner* task_runner,
38 TaskGraphRunner* task_graph_runner, 38 TaskGraphRunner* task_graph_runner,
39 ContextProvider* context_provider, 39 ContextProvider* context_provider,
40 ResourceProvider* resource_provider, 40 ResourceProvider* resource_provider,
41 ResourcePool* resource_pool); 41 ResourcePool* resource_pool,
42 bool have_persistent_gpu_memory_buffers);
42 43
43 // Overridden from TileTaskWorkerPool: 44 // Overridden from TileTaskWorkerPool:
44 TileTaskRunner* AsTileTaskRunner() override; 45 TileTaskRunner* AsTileTaskRunner() override;
45 46
46 // Overridden from TileTaskRunner: 47 // Overridden from TileTaskRunner:
47 void SetClient(TileTaskRunnerClient* client) override; 48 void SetClient(TileTaskRunnerClient* client) override;
48 void Shutdown() override; 49 void Shutdown() override;
49 void ScheduleTasks(TileTaskQueue* queue) override; 50 void ScheduleTasks(TileTaskQueue* queue) override;
50 void CheckForCompletedTasks() override; 51 void CheckForCompletedTasks() override;
51 ResourceFormat GetResourceFormat() override; 52 ResourceFormat GetResourceFormat() override;
52 53
53 // Overridden from TileTaskClient: 54 // Overridden from TileTaskClient:
54 scoped_ptr<RasterBuffer> AcquireBufferForRaster( 55 scoped_ptr<RasterBuffer> AcquireBufferForRaster(
55 const Resource* resource) override; 56 const TileTaskData& data) override;
56 void ReleaseBufferForRaster(scoped_ptr<RasterBuffer> buffer) override; 57 void ReleaseBufferForRaster(scoped_ptr<RasterBuffer> buffer) override;
57 58
58 // Playback raster source and schedule copy of |src| resource to |dst| 59 // Playback raster source and schedule copy of |raster_resource| resource to
59 // resource. Returns a non-zero sequence number for this copy operation. 60 // |data|'s resource. Returns a non-zero sequence number for this copy
61 // operation.
60 CopySequenceNumber PlaybackAndScheduleCopyOnWorkerThread( 62 CopySequenceNumber PlaybackAndScheduleCopyOnWorkerThread(
61 scoped_ptr<ResourceProvider::ScopedWriteLockGpuMemoryBuffer> write_lock, 63 bool reusing_raster_resource,
62 scoped_ptr<ScopedResource> src, 64 scoped_ptr<ResourceProvider::ScopedWriteLockGpuMemoryBuffer>
63 const Resource* dst, 65 raster_resource_write_lock,
66 scoped_ptr<ScopedResource> raster_resource,
67 const TileTaskData& data,
64 const RasterSource* raster_source, 68 const RasterSource* raster_source,
65 const gfx::Rect& rect, 69 const gfx::Rect& rect,
66 float scale); 70 float scale);
67 71
68 // Issues copy operations until |sequence| has been processed. This will 72 // Issues copy operations until |sequence| has been processed. This will
69 // return immediately if |sequence| has already been processed. 73 // return immediately if |sequence| has already been processed.
70 void AdvanceLastIssuedCopyTo(CopySequenceNumber sequence); 74 void AdvanceLastIssuedCopyTo(CopySequenceNumber sequence);
71 75
76 bool have_persistent_gpu_memory_buffers() const {
77 return have_persistent_gpu_memory_buffers_;
78 }
79
72 protected: 80 protected:
73 OneCopyTileTaskWorkerPool(base::SequencedTaskRunner* task_runner, 81 OneCopyTileTaskWorkerPool(base::SequencedTaskRunner* task_runner,
74 TaskGraphRunner* task_graph_runner, 82 TaskGraphRunner* task_graph_runner,
75 ContextProvider* context_provider, 83 ContextProvider* context_provider,
76 ResourceProvider* resource_provider, 84 ResourceProvider* resource_provider,
77 ResourcePool* resource_pool); 85 ResourcePool* resource_pool,
86 bool have_persistent_gpu_memory_buffers);
78 87
79 private: 88 private:
80 struct CopyOperation { 89 struct CopyOperation {
81 typedef ScopedPtrDeque<CopyOperation> Deque; 90 typedef ScopedPtrDeque<CopyOperation> Deque;
82 91
83 CopyOperation( 92 CopyOperation(scoped_ptr<ResourceProvider::ScopedWriteLockGpuMemoryBuffer>
84 scoped_ptr<ResourceProvider::ScopedWriteLockGpuMemoryBuffer> write_lock, 93 raster_resource_write_lock,
85 scoped_ptr<ScopedResource> src, 94 scoped_ptr<ScopedResource> raster_resource,
86 const Resource* dst); 95 const TileTaskData& data);
87 ~CopyOperation(); 96 ~CopyOperation();
88 97
89 scoped_ptr<ResourceProvider::ScopedWriteLockGpuMemoryBuffer> write_lock; 98 scoped_ptr<ResourceProvider::ScopedWriteLockGpuMemoryBuffer>
90 scoped_ptr<ScopedResource> src; 99 raster_resource_write_lock;
91 const Resource* dst; 100 scoped_ptr<ScopedResource> raster_resource;
101 TileTaskData tile_task_data;
92 }; 102 };
93 103
94 void OnTaskSetFinished(TaskSet task_set); 104 void OnTaskSetFinished(TaskSet task_set);
95 void AdvanceLastFlushedCopyTo(CopySequenceNumber sequence); 105 void AdvanceLastFlushedCopyTo(CopySequenceNumber sequence);
96 void IssueCopyOperations(int64 count); 106 void IssueCopyOperations(int64 count);
97 void ScheduleCheckForCompletedCopyOperationsWithLockAcquired( 107 void ScheduleCheckForCompletedCopyOperationsWithLockAcquired(
98 bool wait_if_needed); 108 bool wait_if_needed);
99 void CheckForCompletedCopyOperations(bool wait_if_needed); 109 void CheckForCompletedCopyOperations(bool wait_if_needed);
100 scoped_refptr<base::trace_event::ConvertableToTraceFormat> StateAsValue() 110 scoped_refptr<base::trace_event::ConvertableToTraceFormat> StateAsValue()
101 const; 111 const;
102 void StagingStateAsValueInto( 112 void StagingStateAsValueInto(
103 base::trace_event::TracedValue* staging_state) const; 113 base::trace_event::TracedValue* staging_state) const;
104 114
115 const bool have_persistent_gpu_memory_buffers_;
116
105 scoped_refptr<base::SequencedTaskRunner> task_runner_; 117 scoped_refptr<base::SequencedTaskRunner> task_runner_;
106 TaskGraphRunner* task_graph_runner_; 118 TaskGraphRunner* task_graph_runner_;
107 const NamespaceToken namespace_token_; 119 const NamespaceToken namespace_token_;
108 TileTaskRunnerClient* client_; 120 TileTaskRunnerClient* client_;
109 ContextProvider* context_provider_; 121 ContextProvider* context_provider_;
110 ResourceProvider* resource_provider_; 122 ResourceProvider* resource_provider_;
111 ResourcePool* resource_pool_; 123 ResourcePool* resource_pool_;
112 TaskSetCollection tasks_pending_; 124 TaskSetCollection tasks_pending_;
113 scoped_refptr<TileTask> task_set_finished_tasks_[kNumberOfTaskSets]; 125 scoped_refptr<TileTask> task_set_finished_tasks_[kNumberOfTaskSets];
114 CopySequenceNumber last_issued_copy_operation_; 126 CopySequenceNumber last_issued_copy_operation_;
(...skipping 20 matching lines...) Expand all
135 // canceled when ScheduleTasks() is called. 147 // canceled when ScheduleTasks() is called.
136 base::WeakPtrFactory<OneCopyTileTaskWorkerPool> 148 base::WeakPtrFactory<OneCopyTileTaskWorkerPool>
137 task_set_finished_weak_ptr_factory_; 149 task_set_finished_weak_ptr_factory_;
138 150
139 DISALLOW_COPY_AND_ASSIGN(OneCopyTileTaskWorkerPool); 151 DISALLOW_COPY_AND_ASSIGN(OneCopyTileTaskWorkerPool);
140 }; 152 };
141 153
142 } // namespace cc 154 } // namespace cc
143 155
144 #endif // CC_RASTER_ONE_COPY_TILE_TASK_WORKER_POOL_H_ 156 #endif // CC_RASTER_ONE_COPY_TILE_TASK_WORKER_POOL_H_
OLDNEW

Powered by Google App Engine
This is Rietveld 408576698