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/tiles/gpu_image_decode_cache.h" | 5 #include "cc/tiles/gpu_image_decode_cache.h" |
6 | 6 |
7 #include <inttypes.h> | 7 #include <inttypes.h> |
8 | 8 |
9 #include "base/auto_reset.h" | 9 #include "base/auto_reset.h" |
10 #include "base/debug/alias.h" | 10 #include "base/debug/alias.h" |
(...skipping 566 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
577 | 577 |
578 // We are holding the context lock, so finish cleaning up deleted images | 578 // We are holding the context lock, so finish cleaning up deleted images |
579 // now. | 579 // now. |
580 DeletePendingImages(); | 580 DeletePendingImages(); |
581 } else { | 581 } else { |
582 base::AutoLock lock(lock_); | 582 base::AutoLock lock(lock_); |
583 cached_bytes_limit_ = normal_max_cache_bytes_; | 583 cached_bytes_limit_ = normal_max_cache_bytes_; |
584 } | 584 } |
585 } | 585 } |
586 | 586 |
| 587 void GpuImageDecodeCache::ClearCache() { |
| 588 base::AutoLock lock(lock_); |
| 589 for (auto it = persistent_cache_.begin(); it != persistent_cache_.end();) { |
| 590 if (it->second->decode.ref_count != 0 || |
| 591 it->second->upload.ref_count != 0) { |
| 592 ++it; |
| 593 continue; |
| 594 } |
| 595 |
| 596 if (it->second->upload.image()) { |
| 597 bytes_used_ -= it->second->size; |
| 598 images_pending_deletion_.push_back(it->second->upload.image()); |
| 599 it->second->upload.SetImage(nullptr); |
| 600 it->second->upload.budgeted = false; |
| 601 } |
| 602 |
| 603 it = persistent_cache_.Erase(it); |
| 604 } |
| 605 } |
| 606 |
587 bool GpuImageDecodeCache::OnMemoryDump( | 607 bool GpuImageDecodeCache::OnMemoryDump( |
588 const base::trace_event::MemoryDumpArgs& args, | 608 const base::trace_event::MemoryDumpArgs& args, |
589 base::trace_event::ProcessMemoryDump* pmd) { | 609 base::trace_event::ProcessMemoryDump* pmd) { |
590 using base::trace_event::MemoryAllocatorDump; | 610 using base::trace_event::MemoryAllocatorDump; |
591 using base::trace_event::MemoryAllocatorDumpGuid; | 611 using base::trace_event::MemoryAllocatorDumpGuid; |
592 using base::trace_event::MemoryDumpLevelOfDetail; | 612 using base::trace_event::MemoryDumpLevelOfDetail; |
593 | 613 |
594 TRACE_EVENT0(TRACE_DISABLED_BY_DEFAULT("cc.debug"), | 614 TRACE_EVENT0(TRACE_DISABLED_BY_DEFAULT("cc.debug"), |
595 "GpuImageDecodeCache::OnMemoryDump"); | 615 "GpuImageDecodeCache::OnMemoryDump"); |
596 | 616 |
(...skipping 692 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
1289 | 1309 |
1290 void GpuImageDecodeCache::OnPurgeMemory() { | 1310 void GpuImageDecodeCache::OnPurgeMemory() { |
1291 base::AutoLock lock(lock_); | 1311 base::AutoLock lock(lock_); |
1292 // Temporary changes |memory_state_| to free up cache as much as possible. | 1312 // Temporary changes |memory_state_| to free up cache as much as possible. |
1293 base::AutoReset<base::MemoryState> reset(&memory_state_, | 1313 base::AutoReset<base::MemoryState> reset(&memory_state_, |
1294 base::MemoryState::SUSPENDED); | 1314 base::MemoryState::SUSPENDED); |
1295 EnsureCapacity(0); | 1315 EnsureCapacity(0); |
1296 } | 1316 } |
1297 | 1317 |
1298 } // namespace cc | 1318 } // namespace cc |
OLD | NEW |