| OLD | NEW |
| 1 // Copyright 2013 The Chromium Authors. All rights reserved. | 1 // Copyright 2013 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 #include "cc/raster/zero_copy_tile_task_worker_pool.h" | 5 #include "cc/raster/zero_copy_tile_task_worker_pool.h" |
| 6 | 6 |
| 7 #include <algorithm> | 7 #include <algorithm> |
| 8 | 8 |
| 9 #include "base/strings/stringprintf.h" | 9 #include "base/strings/stringprintf.h" |
| 10 #include "base/trace_event/trace_event.h" | 10 #include "base/trace_event/trace_event.h" |
| (...skipping 14 matching lines...) Expand all Loading... |
| 25 const Resource* resource) | 25 const Resource* resource) |
| 26 : lock_(resource_provider, resource->id()), resource_(resource) {} | 26 : lock_(resource_provider, resource->id()), resource_(resource) {} |
| 27 | 27 |
| 28 // Overridden from RasterBuffer: | 28 // Overridden from RasterBuffer: |
| 29 void Playback(const DisplayListRasterSource* raster_source, | 29 void Playback(const DisplayListRasterSource* raster_source, |
| 30 const gfx::Rect& raster_full_rect, | 30 const gfx::Rect& raster_full_rect, |
| 31 const gfx::Rect& raster_dirty_rect, | 31 const gfx::Rect& raster_dirty_rect, |
| 32 uint64_t new_content_id, | 32 uint64_t new_content_id, |
| 33 float scale, | 33 float scale, |
| 34 bool include_images) override { | 34 bool include_images) override { |
| 35 gfx::GpuMemoryBuffer* gpu_memory_buffer = lock_.GetGpuMemoryBuffer(); | 35 gfx::GpuMemoryBuffer* buffer = lock_.GetGpuMemoryBuffer(); |
| 36 if (!gpu_memory_buffer) | 36 if (!buffer) |
| 37 return; | 37 return; |
| 38 DCHECK_EQ( | 38 |
| 39 1u, gfx::NumberOfPlanesForBufferFormat(gpu_memory_buffer->GetFormat())); | 39 DCHECK_EQ(1u, gfx::NumberOfPlanesForBufferFormat(buffer->GetFormat())); |
| 40 void* data = NULL; | 40 bool rv = buffer->Map(); |
| 41 bool rv = gpu_memory_buffer->Map(&data); | |
| 42 DCHECK(rv); | 41 DCHECK(rv); |
| 43 int stride; | 42 DCHECK(buffer->memory(0)); |
| 44 gpu_memory_buffer->GetStride(&stride); | |
| 45 // TileTaskWorkerPool::PlaybackToMemory only supports unsigned strides. | 43 // TileTaskWorkerPool::PlaybackToMemory only supports unsigned strides. |
| 46 DCHECK_GE(stride, 0); | 44 DCHECK_GE(buffer->stride(0), 0); |
| 45 |
| 47 // TODO(danakj): Implement partial raster with raster_dirty_rect. | 46 // TODO(danakj): Implement partial raster with raster_dirty_rect. |
| 48 TileTaskWorkerPool::PlaybackToMemory( | 47 TileTaskWorkerPool::PlaybackToMemory( |
| 49 data, resource_->format(), resource_->size(), | 48 buffer->memory(0), resource_->format(), resource_->size(), |
| 50 static_cast<size_t>(stride), raster_source, raster_full_rect, | 49 buffer->stride(0), raster_source, raster_full_rect, raster_full_rect, |
| 51 raster_full_rect, scale, include_images); | 50 scale, include_images); |
| 52 gpu_memory_buffer->Unmap(); | 51 buffer->Unmap(); |
| 53 } | 52 } |
| 54 | 53 |
| 55 private: | 54 private: |
| 56 ResourceProvider::ScopedWriteLockGpuMemoryBuffer lock_; | 55 ResourceProvider::ScopedWriteLockGpuMemoryBuffer lock_; |
| 57 const Resource* resource_; | 56 const Resource* resource_; |
| 58 | 57 |
| 59 DISALLOW_COPY_AND_ASSIGN(RasterBufferImpl); | 58 DISALLOW_COPY_AND_ASSIGN(RasterBufferImpl); |
| 60 }; | 59 }; |
| 61 | 60 |
| 62 } // namespace | 61 } // namespace |
| (...skipping 166 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
| 229 new base::trace_event::TracedValue(); | 228 new base::trace_event::TracedValue(); |
| 230 | 229 |
| 231 state->BeginArray("tasks_pending"); | 230 state->BeginArray("tasks_pending"); |
| 232 for (TaskSet task_set = 0; task_set < kNumberOfTaskSets; ++task_set) | 231 for (TaskSet task_set = 0; task_set < kNumberOfTaskSets; ++task_set) |
| 233 state->AppendBoolean(tasks_pending_[task_set]); | 232 state->AppendBoolean(tasks_pending_[task_set]); |
| 234 state->EndArray(); | 233 state->EndArray(); |
| 235 return state; | 234 return state; |
| 236 } | 235 } |
| 237 | 236 |
| 238 } // namespace cc | 237 } // namespace cc |
| OLD | NEW |