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

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: init Created 5 years, 6 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 21 matching lines...) Expand all
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 size_t max_bytes_per_copy_operation); 42 size_t max_bytes_per_copy_operation,
43 bool have_persistent_gpu_memory_buffers);
43 44
44 // Overridden from TileTaskWorkerPool: 45 // Overridden from TileTaskWorkerPool:
45 TileTaskRunner* AsTileTaskRunner() override; 46 TileTaskRunner* AsTileTaskRunner() override;
46 47
47 // Overridden from TileTaskRunner: 48 // Overridden from TileTaskRunner:
48 void SetClient(TileTaskRunnerClient* client) override; 49 void SetClient(TileTaskRunnerClient* client) override;
49 void Shutdown() override; 50 void Shutdown() override;
50 void ScheduleTasks(TileTaskQueue* queue) override; 51 void ScheduleTasks(TileTaskQueue* queue) override;
51 void CheckForCompletedTasks() override; 52 void CheckForCompletedTasks() override;
52 ResourceFormat GetResourceFormat() override; 53 ResourceFormat GetResourceFormat() override;
53 54
54 // Overridden from TileTaskClient: 55 // Overridden from TileTaskClient:
55 scoped_ptr<RasterBuffer> AcquireBufferForRaster( 56 scoped_ptr<RasterBuffer> AcquireBufferForRaster(
56 const Resource* resource) override; 57 const Resource* resource,
58 uint64_t new_content_id,
59 uint64_t previous_content_id) override;
57 void ReleaseBufferForRaster(scoped_ptr<RasterBuffer> buffer) override; 60 void ReleaseBufferForRaster(scoped_ptr<RasterBuffer> buffer) override;
58 61
59 // Playback raster source and schedule copy of |src| resource to |dst| 62 // Playback raster source and schedule copy of |raster_resource| resource to
60 // resource. Returns a non-zero sequence number for this copy operation. 63 // |data|'s resource. Returns a non-zero sequence number for this copy
reveman 2015/05/29 14:50:27 nit: update comment, |data| -> X
danakj 2015/05/29 17:16:07 Done.
64 // operation.
61 CopySequenceNumber PlaybackAndScheduleCopyOnWorkerThread( 65 CopySequenceNumber PlaybackAndScheduleCopyOnWorkerThread(
62 scoped_ptr<ResourceProvider::ScopedWriteLockGpuMemoryBuffer> write_lock, 66 bool reusing_raster_resource,
63 const Resource* src, 67 scoped_ptr<ResourceProvider::ScopedWriteLockGpuMemoryBuffer>
64 const Resource* dst, 68 raster_resource_write_lock,
69 const Resource* raster_resource,
70 const Resource* upload_resource,
reveman 2015/05/29 14:50:27 nit: kill 'upload_' prefix. 'resource' alone is go
danakj 2015/05/29 17:16:07 ok output_resource everywhere.
65 const RasterSource* raster_source, 71 const RasterSource* raster_source,
66 const gfx::Rect& rect, 72 const gfx::Rect& raster_full_rect,
73 const gfx::Rect& raster_dirty_rect,
67 float scale); 74 float scale);
68 75
69 // Issues copy operations until |sequence| has been processed. This will 76 // Issues copy operations until |sequence| has been processed. This will
70 // return immediately if |sequence| has already been processed. 77 // return immediately if |sequence| has already been processed.
71 void AdvanceLastIssuedCopyTo(CopySequenceNumber sequence); 78 void AdvanceLastIssuedCopyTo(CopySequenceNumber sequence);
72 79
80 bool have_persistent_gpu_memory_buffers() const {
81 return have_persistent_gpu_memory_buffers_;
82 }
83
73 protected: 84 protected:
74 OneCopyTileTaskWorkerPool(base::SequencedTaskRunner* task_runner, 85 OneCopyTileTaskWorkerPool(base::SequencedTaskRunner* task_runner,
75 TaskGraphRunner* task_graph_runner, 86 TaskGraphRunner* task_graph_runner,
76 ContextProvider* context_provider, 87 ContextProvider* context_provider,
77 ResourceProvider* resource_provider, 88 ResourceProvider* resource_provider,
78 ResourcePool* resource_pool, 89 ResourcePool* resource_pool,
79 size_t max_bytes_per_copy_operation); 90 size_t max_bytes_per_copy_operation,
91 bool have_persistent_gpu_memory_buffers);
80 92
81 private: 93 private:
82 struct CopyOperation { 94 struct CopyOperation {
83 typedef ScopedPtrDeque<CopyOperation> Deque; 95 typedef ScopedPtrDeque<CopyOperation> Deque;
84 96
85 CopyOperation( 97 CopyOperation(scoped_ptr<ResourceProvider::ScopedWriteLockGpuMemoryBuffer>
86 scoped_ptr<ResourceProvider::ScopedWriteLockGpuMemoryBuffer> write_lock, 98 raster_resource_write_lock,
87 const Resource* src, 99 const Resource* src,
88 const Resource* dst, 100 const Resource* dst,
89 const gfx::Rect& rect); 101 const gfx::Rect& rect);
90 ~CopyOperation(); 102 ~CopyOperation();
91 103
92 scoped_ptr<ResourceProvider::ScopedWriteLockGpuMemoryBuffer> write_lock; 104 scoped_ptr<ResourceProvider::ScopedWriteLockGpuMemoryBuffer> src_write_lock;
reveman 2015/05/29 14:50:27 nit: raster_resource_write_lock like the ctor?
danakj 2015/05/29 17:16:06 meant to leave CopyOperation as src/dst, fixed the
93 const Resource* src; 105 const Resource* src;
94 const Resource* dst; 106 const Resource* dst;
95 const gfx::Rect rect; 107 const gfx::Rect rect;
96 }; 108 };
97 109
98 void OnTaskSetFinished(TaskSet task_set); 110 void OnTaskSetFinished(TaskSet task_set);
99 void AdvanceLastFlushedCopyTo(CopySequenceNumber sequence); 111 void AdvanceLastFlushedCopyTo(CopySequenceNumber sequence);
100 void IssueCopyOperations(int64 count); 112 void IssueCopyOperations(int64 count);
101 void ScheduleCheckForCompletedCopyOperationsWithLockAcquired( 113 void ScheduleCheckForCompletedCopyOperationsWithLockAcquired(
102 bool wait_if_needed); 114 bool wait_if_needed);
103 void CheckForCompletedCopyOperations(bool wait_if_needed); 115 void CheckForCompletedCopyOperations(bool wait_if_needed);
104 scoped_refptr<base::trace_event::ConvertableToTraceFormat> StateAsValue() 116 scoped_refptr<base::trace_event::ConvertableToTraceFormat> StateAsValue()
105 const; 117 const;
106 void StagingStateAsValueInto( 118 void StagingStateAsValueInto(
107 base::trace_event::TracedValue* staging_state) const; 119 base::trace_event::TracedValue* staging_state) const;
108 120
109 scoped_refptr<base::SequencedTaskRunner> task_runner_; 121 scoped_refptr<base::SequencedTaskRunner> task_runner_;
110 TaskGraphRunner* task_graph_runner_; 122 TaskGraphRunner* task_graph_runner_;
111 const NamespaceToken namespace_token_; 123 const NamespaceToken namespace_token_;
112 TileTaskRunnerClient* client_; 124 TileTaskRunnerClient* client_;
113 ContextProvider* context_provider_; 125 ContextProvider* context_provider_;
114 ResourceProvider* resource_provider_; 126 ResourceProvider* resource_provider_;
115 ResourcePool* resource_pool_; 127 ResourcePool* resource_pool_;
116 const size_t max_bytes_per_copy_operation_; 128 const size_t max_bytes_per_copy_operation_;
129 const bool have_persistent_gpu_memory_buffers_;
117 TaskSetCollection tasks_pending_; 130 TaskSetCollection tasks_pending_;
118 scoped_refptr<TileTask> task_set_finished_tasks_[kNumberOfTaskSets]; 131 scoped_refptr<TileTask> task_set_finished_tasks_[kNumberOfTaskSets];
119 CopySequenceNumber last_issued_copy_operation_; 132 CopySequenceNumber last_issued_copy_operation_;
120 CopySequenceNumber last_flushed_copy_operation_; 133 CopySequenceNumber last_flushed_copy_operation_;
121 134
122 // Task graph used when scheduling tasks and vector used to gather 135 // Task graph used when scheduling tasks and vector used to gather
123 // completed tasks. 136 // completed tasks.
124 TaskGraph graph_; 137 TaskGraph graph_;
125 Task::Vector completed_tasks_; 138 Task::Vector completed_tasks_;
126 139
(...skipping 12 matching lines...) Expand all
139 // canceled when ScheduleTasks() is called. 152 // canceled when ScheduleTasks() is called.
140 base::WeakPtrFactory<OneCopyTileTaskWorkerPool> 153 base::WeakPtrFactory<OneCopyTileTaskWorkerPool>
141 task_set_finished_weak_ptr_factory_; 154 task_set_finished_weak_ptr_factory_;
142 155
143 DISALLOW_COPY_AND_ASSIGN(OneCopyTileTaskWorkerPool); 156 DISALLOW_COPY_AND_ASSIGN(OneCopyTileTaskWorkerPool);
144 }; 157 };
145 158
146 } // namespace cc 159 } // namespace cc
147 160
148 #endif // CC_RASTER_ONE_COPY_TILE_TASK_WORKER_POOL_H_ 161 #endif // CC_RASTER_ONE_COPY_TILE_TASK_WORKER_POOL_H_
OLDNEW

Powered by Google App Engine
This is Rietveld 408576698