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

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

Issue 1159833002: content: Partial copy workaround for devices with known upload performance problems. (Closed) Base URL: https://chromium.googlesource.com/chromium/src.git@master
Patch Set: sort 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
« no previous file with comments | « no previous file | cc/raster/one_copy_tile_task_worker_pool.cc » ('j') | no next file with comments »
Toggle Intra-line Diffs ('i') | Expand Comments ('e') | Collapse Comments ('c') | Show Comments Hide Comments ('s')
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 int max_bytes_per_copy_operation, 42 int max_copy_texture_chromium_size,
43 bool have_persistent_gpu_memory_buffers); 43 bool have_persistent_gpu_memory_buffers);
44 44
45 // Overridden from TileTaskWorkerPool: 45 // Overridden from TileTaskWorkerPool:
46 TileTaskRunner* AsTileTaskRunner() override; 46 TileTaskRunner* AsTileTaskRunner() override;
47 47
48 // Overridden from TileTaskRunner: 48 // Overridden from TileTaskRunner:
49 void SetClient(TileTaskRunnerClient* client) override; 49 void SetClient(TileTaskRunnerClient* client) override;
50 void Shutdown() override; 50 void Shutdown() override;
51 void ScheduleTasks(TileTaskQueue* queue) override; 51 void ScheduleTasks(TileTaskQueue* queue) override;
52 void CheckForCompletedTasks() override; 52 void CheckForCompletedTasks() override;
(...skipping 27 matching lines...) Expand all
80 bool have_persistent_gpu_memory_buffers() const { 80 bool have_persistent_gpu_memory_buffers() const {
81 return have_persistent_gpu_memory_buffers_; 81 return have_persistent_gpu_memory_buffers_;
82 } 82 }
83 83
84 protected: 84 protected:
85 OneCopyTileTaskWorkerPool(base::SequencedTaskRunner* task_runner, 85 OneCopyTileTaskWorkerPool(base::SequencedTaskRunner* task_runner,
86 TaskGraphRunner* task_graph_runner, 86 TaskGraphRunner* task_graph_runner,
87 ContextProvider* context_provider, 87 ContextProvider* context_provider,
88 ResourceProvider* resource_provider, 88 ResourceProvider* resource_provider,
89 ResourcePool* resource_pool, 89 ResourcePool* resource_pool,
90 int max_bytes_per_copy_operation, 90 int max_copy_texture_chromium_size,
91 bool have_persistent_gpu_memory_buffers); 91 bool have_persistent_gpu_memory_buffers);
92 92
93 private: 93 private:
94 struct CopyOperation { 94 struct CopyOperation {
95 typedef ScopedPtrDeque<CopyOperation> Deque; 95 typedef ScopedPtrDeque<CopyOperation> Deque;
96 96
97 CopyOperation(scoped_ptr<ResourceProvider::ScopedWriteLockGpuMemoryBuffer> 97 CopyOperation(scoped_ptr<ResourceProvider::ScopedWriteLockGpuMemoryBuffer>
98 src_write_lock, 98 src_write_lock,
99 const Resource* src, 99 const Resource* src,
100 const Resource* dst, 100 const Resource* dst,
(...skipping 52 matching lines...) Expand 10 before | Expand all | Expand 10 after
153 // canceled when ScheduleTasks() is called. 153 // canceled when ScheduleTasks() is called.
154 base::WeakPtrFactory<OneCopyTileTaskWorkerPool> 154 base::WeakPtrFactory<OneCopyTileTaskWorkerPool>
155 task_set_finished_weak_ptr_factory_; 155 task_set_finished_weak_ptr_factory_;
156 156
157 DISALLOW_COPY_AND_ASSIGN(OneCopyTileTaskWorkerPool); 157 DISALLOW_COPY_AND_ASSIGN(OneCopyTileTaskWorkerPool);
158 }; 158 };
159 159
160 } // namespace cc 160 } // namespace cc
161 161
162 #endif // CC_RASTER_ONE_COPY_TILE_TASK_WORKER_POOL_H_ 162 #endif // CC_RASTER_ONE_COPY_TILE_TASK_WORKER_POOL_H_
OLDNEW
« no previous file with comments | « no previous file | cc/raster/one_copy_tile_task_worker_pool.cc » ('j') | no next file with comments »

Powered by Google App Engine
This is Rietveld 408576698