| OLD | NEW |
| 1 // Copyright 2016 The Chromium Authors. All rights reserved. | 1 // Copyright 2016 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/staging_buffer_pool.h" | 5 #include "cc/raster/staging_buffer_pool.h" |
| 6 | 6 |
| 7 #include <memory> | 7 #include <memory> |
| 8 | 8 |
| 9 #include "base/memory/memory_coordinator_client_registry.h" | 9 #include "base/memory/memory_coordinator_client_registry.h" |
| 10 #include "base/memory/ptr_util.h" | 10 #include "base/memory/ptr_util.h" |
| 11 #include "base/memory/shared_memory_tracker.h" |
| 11 #include "base/strings/stringprintf.h" | 12 #include "base/strings/stringprintf.h" |
| 12 #include "base/threading/thread_task_runner_handle.h" | 13 #include "base/threading/thread_task_runner_handle.h" |
| 13 #include "base/trace_event/memory_dump_manager.h" | 14 #include "base/trace_event/memory_dump_manager.h" |
| 14 #include "cc/base/container_util.h" | 15 #include "cc/base/container_util.h" |
| 15 #include "cc/debug/traced_value.h" | 16 #include "cc/debug/traced_value.h" |
| 16 #include "cc/resources/scoped_resource.h" | 17 #include "cc/resources/scoped_resource.h" |
| 17 #include "gpu/command_buffer/client/gles2_interface.h" | 18 #include "gpu/command_buffer/client/gles2_interface.h" |
| 18 #include "ui/gfx/gpu_memory_buffer_tracing.h" | 19 #include "ui/gfx/gpu_memory_buffer_tracing.h" |
| 19 | 20 |
| 20 using base::trace_event::MemoryAllocatorDump; | 21 using base::trace_event::MemoryAllocatorDump; |
| (...skipping 83 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
| 104 | 105 |
| 105 uint64_t buffer_size_in_bytes = | 106 uint64_t buffer_size_in_bytes = |
| 106 ResourceUtil::UncheckedSizeInBytes<uint64_t>(size, format); | 107 ResourceUtil::UncheckedSizeInBytes<uint64_t>(size, format); |
| 107 buffer_dump->AddScalar(MemoryAllocatorDump::kNameSize, | 108 buffer_dump->AddScalar(MemoryAllocatorDump::kNameSize, |
| 108 MemoryAllocatorDump::kUnitsBytes, | 109 MemoryAllocatorDump::kUnitsBytes, |
| 109 buffer_size_in_bytes); | 110 buffer_size_in_bytes); |
| 110 buffer_dump->AddScalar("free_size", MemoryAllocatorDump::kUnitsBytes, | 111 buffer_dump->AddScalar("free_size", MemoryAllocatorDump::kUnitsBytes, |
| 111 in_free_list ? buffer_size_in_bytes : 0); | 112 in_free_list ? buffer_size_in_bytes : 0); |
| 112 | 113 |
| 113 // Emit an ownership edge towards a global allocator dump node. | 114 // Emit an ownership edge towards a global allocator dump node. |
| 114 const uint64_t tracing_process_id = | |
| 115 base::trace_event::MemoryDumpManager::GetInstance() | |
| 116 ->GetTracingProcessId(); | |
| 117 MemoryAllocatorDumpGuid shared_buffer_guid = | |
| 118 gfx::GetGpuMemoryBufferGUIDForTracing(tracing_process_id, buffer_id); | |
| 119 pmd->CreateSharedGlobalAllocatorDump(shared_buffer_guid); | |
| 120 | 115 |
| 121 // By creating an edge with a higher |importance| (w.r.t. browser-side dumps) | 116 // By creating an edge with a higher |importance| (w.r.t. browser-side dumps) |
| 122 // the tracing UI will account the effective size of the buffer to the child. | 117 // the tracing UI will account the effective size of the buffer to the child. |
| 123 const int kImportance = 2; | 118 // const int kImportance = 2; |
| 124 pmd->AddOwnershipEdge(buffer_dump->guid(), shared_buffer_guid, kImportance); | 119 // TODO(hajimehoshi): Importance |
| 120 base::SharedMemoryTracker::AddOwnershipEdges( |
| 121 pmd, buffer_dump->guid(), gpu_memory_buffer->GetHandle().handle, |
| 122 buffer_size_in_bytes); |
| 125 } | 123 } |
| 126 | 124 |
| 127 StagingBufferPool::StagingBufferPool(base::SequencedTaskRunner* task_runner, | 125 StagingBufferPool::StagingBufferPool(base::SequencedTaskRunner* task_runner, |
| 128 ContextProvider* worker_context_provider, | 126 ContextProvider* worker_context_provider, |
| 129 ResourceProvider* resource_provider, | 127 ResourceProvider* resource_provider, |
| 130 bool use_partial_raster, | 128 bool use_partial_raster, |
| 131 int max_staging_buffer_usage_in_bytes) | 129 int max_staging_buffer_usage_in_bytes) |
| 132 : task_runner_(task_runner), | 130 : task_runner_(task_runner), |
| 133 worker_context_provider_(worker_context_provider), | 131 worker_context_provider_(worker_context_provider), |
| 134 resource_provider_(resource_provider), | 132 resource_provider_(resource_provider), |
| (...skipping 297 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
| 432 } | 430 } |
| 433 } | 431 } |
| 434 | 432 |
| 435 void StagingBufferPool::OnPurgeMemory() { | 433 void StagingBufferPool::OnPurgeMemory() { |
| 436 base::AutoLock lock(lock_); | 434 base::AutoLock lock(lock_); |
| 437 // Release all buffers, regardless of how recently they were used. | 435 // Release all buffers, regardless of how recently they were used. |
| 438 ReleaseBuffersNotUsedSince(base::TimeTicks() + base::TimeDelta::Max()); | 436 ReleaseBuffersNotUsedSince(base::TimeTicks() + base::TimeDelta::Max()); |
| 439 } | 437 } |
| 440 | 438 |
| 441 } // namespace cc | 439 } // namespace cc |
| OLD | NEW |