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

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: slightlylessstruct 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 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 TileTaskData& data) override;
57 void ReleaseBufferForRaster(scoped_ptr<RasterBuffer> buffer) override; 58 void ReleaseBufferForRaster(scoped_ptr<RasterBuffer> buffer) override;
58 59
59 // Playback raster source and schedule copy of |src| resource to |dst| 60 // Playback raster source and schedule copy of |raster_resource| resource to
60 // resource. Returns a non-zero sequence number for this copy operation. 61 // |data|'s resource. Returns a non-zero sequence number for this copy
62 // operation.
61 CopySequenceNumber PlaybackAndScheduleCopyOnWorkerThread( 63 CopySequenceNumber PlaybackAndScheduleCopyOnWorkerThread(
62 scoped_ptr<ResourceProvider::ScopedWriteLockGpuMemoryBuffer> write_lock, 64 bool reusing_raster_resource,
63 const Resource* src, 65 scoped_ptr<ResourceProvider::ScopedWriteLockGpuMemoryBuffer>
64 const Resource* dst, 66 raster_resource_write_lock,
67 const Resource* raster_resource,
68 const Resource* upload_resource,
reveman 2015/05/28 05:07:24 s/upload/copy/. what's wrong with |write_lock|, |s
danakj 2015/05/28 18:54:46 see previous comment?
65 const RasterSource* raster_source, 69 const RasterSource* raster_source,
66 const gfx::Rect& rect, 70 const gfx::Rect& raster_full_rect,
71 const gfx::Rect& raster_dirty_rect,
67 float scale); 72 float scale);
68 73
69 // Issues copy operations until |sequence| has been processed. This will 74 // Issues copy operations until |sequence| has been processed. This will
70 // return immediately if |sequence| has already been processed. 75 // return immediately if |sequence| has already been processed.
71 void AdvanceLastIssuedCopyTo(CopySequenceNumber sequence); 76 void AdvanceLastIssuedCopyTo(CopySequenceNumber sequence);
72 77
78 bool have_persistent_gpu_memory_buffers() const {
79 return have_persistent_gpu_memory_buffers_;
80 }
81
73 protected: 82 protected:
74 OneCopyTileTaskWorkerPool(base::SequencedTaskRunner* task_runner, 83 OneCopyTileTaskWorkerPool(base::SequencedTaskRunner* task_runner,
75 TaskGraphRunner* task_graph_runner, 84 TaskGraphRunner* task_graph_runner,
76 ContextProvider* context_provider, 85 ContextProvider* context_provider,
77 ResourceProvider* resource_provider, 86 ResourceProvider* resource_provider,
78 ResourcePool* resource_pool, 87 ResourcePool* resource_pool,
79 size_t max_bytes_per_copy_operation); 88 size_t max_bytes_per_copy_operation,
89 bool have_persistent_gpu_memory_buffers);
80 90
81 private: 91 private:
82 struct CopyOperation { 92 struct CopyOperation {
83 typedef ScopedPtrDeque<CopyOperation> Deque; 93 typedef ScopedPtrDeque<CopyOperation> Deque;
84 94
85 CopyOperation( 95 CopyOperation(scoped_ptr<ResourceProvider::ScopedWriteLockGpuMemoryBuffer>
86 scoped_ptr<ResourceProvider::ScopedWriteLockGpuMemoryBuffer> write_lock, 96 raster_resource_write_lock,
87 const Resource* src, 97 const Resource* src,
88 const Resource* dst, 98 const Resource* dst,
89 const gfx::Rect& rect); 99 const gfx::Rect& rect);
90 ~CopyOperation(); 100 ~CopyOperation();
91 101
92 scoped_ptr<ResourceProvider::ScopedWriteLockGpuMemoryBuffer> write_lock; 102 scoped_ptr<ResourceProvider::ScopedWriteLockGpuMemoryBuffer> src_write_lock;
reveman 2015/05/28 05:07:24 is this name change necessary?
93 const Resource* src; 103 const Resource* src;
94 const Resource* dst; 104 const Resource* dst;
95 const gfx::Rect rect; 105 const gfx::Rect rect;
96 }; 106 };
97 107
98 void OnTaskSetFinished(TaskSet task_set); 108 void OnTaskSetFinished(TaskSet task_set);
99 void AdvanceLastFlushedCopyTo(CopySequenceNumber sequence); 109 void AdvanceLastFlushedCopyTo(CopySequenceNumber sequence);
100 void IssueCopyOperations(int64 count); 110 void IssueCopyOperations(int64 count);
101 void ScheduleCheckForCompletedCopyOperationsWithLockAcquired( 111 void ScheduleCheckForCompletedCopyOperationsWithLockAcquired(
102 bool wait_if_needed); 112 bool wait_if_needed);
103 void CheckForCompletedCopyOperations(bool wait_if_needed); 113 void CheckForCompletedCopyOperations(bool wait_if_needed);
104 scoped_refptr<base::trace_event::ConvertableToTraceFormat> StateAsValue() 114 scoped_refptr<base::trace_event::ConvertableToTraceFormat> StateAsValue()
105 const; 115 const;
106 void StagingStateAsValueInto( 116 void StagingStateAsValueInto(
107 base::trace_event::TracedValue* staging_state) const; 117 base::trace_event::TracedValue* staging_state) const;
108 118
109 scoped_refptr<base::SequencedTaskRunner> task_runner_; 119 scoped_refptr<base::SequencedTaskRunner> task_runner_;
110 TaskGraphRunner* task_graph_runner_; 120 TaskGraphRunner* task_graph_runner_;
111 const NamespaceToken namespace_token_; 121 const NamespaceToken namespace_token_;
112 TileTaskRunnerClient* client_; 122 TileTaskRunnerClient* client_;
113 ContextProvider* context_provider_; 123 ContextProvider* context_provider_;
114 ResourceProvider* resource_provider_; 124 ResourceProvider* resource_provider_;
115 ResourcePool* resource_pool_; 125 ResourcePool* resource_pool_;
116 const size_t max_bytes_per_copy_operation_; 126 const size_t max_bytes_per_copy_operation_;
127 const bool have_persistent_gpu_memory_buffers_;
117 TaskSetCollection tasks_pending_; 128 TaskSetCollection tasks_pending_;
118 scoped_refptr<TileTask> task_set_finished_tasks_[kNumberOfTaskSets]; 129 scoped_refptr<TileTask> task_set_finished_tasks_[kNumberOfTaskSets];
119 CopySequenceNumber last_issued_copy_operation_; 130 CopySequenceNumber last_issued_copy_operation_;
120 CopySequenceNumber last_flushed_copy_operation_; 131 CopySequenceNumber last_flushed_copy_operation_;
121 132
122 // Task graph used when scheduling tasks and vector used to gather 133 // Task graph used when scheduling tasks and vector used to gather
123 // completed tasks. 134 // completed tasks.
124 TaskGraph graph_; 135 TaskGraph graph_;
125 Task::Vector completed_tasks_; 136 Task::Vector completed_tasks_;
126 137
(...skipping 12 matching lines...) Expand all
139 // canceled when ScheduleTasks() is called. 150 // canceled when ScheduleTasks() is called.
140 base::WeakPtrFactory<OneCopyTileTaskWorkerPool> 151 base::WeakPtrFactory<OneCopyTileTaskWorkerPool>
141 task_set_finished_weak_ptr_factory_; 152 task_set_finished_weak_ptr_factory_;
142 153
143 DISALLOW_COPY_AND_ASSIGN(OneCopyTileTaskWorkerPool); 154 DISALLOW_COPY_AND_ASSIGN(OneCopyTileTaskWorkerPool);
144 }; 155 };
145 156
146 } // namespace cc 157 } // namespace cc
147 158
148 #endif // CC_RASTER_ONE_COPY_TILE_TASK_WORKER_POOL_H_ 159 #endif // CC_RASTER_ONE_COPY_TILE_TASK_WORKER_POOL_H_
OLDNEW

Powered by Google App Engine
This is Rietveld 408576698