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

Side by Side Diff: components/discardable_memory/service/discardable_shared_memory_manager.cc

Issue 2648323005: memory coordinator: Add MemoryCoordinatorClient::OnPurgeMemory() (Closed)
Patch Set: Created 3 years, 11 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 #include "components/discardable_memory/service/discardable_shared_memory_manage r.h" 5 #include "components/discardable_memory/service/discardable_shared_memory_manage r.h"
6 6
7 #include <algorithm> 7 #include <algorithm>
8 #include <utility> 8 #include <utility>
9 9
10 #include "base/atomic_sequence_num.h" 10 #include "base/atomic_sequence_num.h"
(...skipping 403 matching lines...) Expand 10 before | Expand all | Expand 10 after
414 break; 414 break;
415 case base::MemoryState::SUSPENDED: 415 case base::MemoryState::SUSPENDED:
416 // Note that SUSPENDED never occurs in the main browser process so far. 416 // Note that SUSPENDED never occurs in the main browser process so far.
417 // Fall through. 417 // Fall through.
418 case base::MemoryState::UNKNOWN: 418 case base::MemoryState::UNKNOWN:
419 NOTREACHED(); 419 NOTREACHED();
420 break; 420 break;
421 } 421 }
422 } 422 }
423 423
424 void DiscardableSharedMemoryManager::OnPurgeMemory() {
425 base::AutoLock lock(lock_);
426 ReduceMemoryUsageUntilWithinLimit(0);
427 }
428
424 void DiscardableSharedMemoryManager::AllocateLockedDiscardableSharedMemory( 429 void DiscardableSharedMemoryManager::AllocateLockedDiscardableSharedMemory(
425 int client_id, 430 int client_id,
426 size_t size, 431 size_t size,
427 int32_t id, 432 int32_t id,
428 base::SharedMemoryHandle* shared_memory_handle) { 433 base::SharedMemoryHandle* shared_memory_handle) {
429 base::AutoLock lock(lock_); 434 base::AutoLock lock(lock_);
430 435
431 // Make sure |id| is not already in use. 436 // Make sure |id| is not already in use.
432 MemorySegmentMap& client_segments = clients_[client_id]; 437 MemorySegmentMap& client_segments = clients_[client_id];
433 if (client_segments.find(id) != client_segments.end()) { 438 if (client_segments.find(id) != client_segments.end()) {
(...skipping 183 matching lines...) Expand 10 before | Expand all | Expand 10 after
617 return; 622 return;
618 623
619 enforce_memory_policy_pending_ = true; 624 enforce_memory_policy_pending_ = true;
620 DCHECK(enforce_memory_policy_task_runner_); 625 DCHECK(enforce_memory_policy_task_runner_);
621 enforce_memory_policy_task_runner_->PostDelayedTask( 626 enforce_memory_policy_task_runner_->PostDelayedTask(
622 FROM_HERE, enforce_memory_policy_callback_, 627 FROM_HERE, enforce_memory_policy_callback_,
623 base::TimeDelta::FromMilliseconds(kEnforceMemoryPolicyDelayMs)); 628 base::TimeDelta::FromMilliseconds(kEnforceMemoryPolicyDelayMs));
624 } 629 }
625 630
626 } // namespace discardable_memory 631 } // namespace discardable_memory
OLDNEW

Powered by Google App Engine
This is Rietveld 408576698