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

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

Issue 2667343004: Move purging memory from OnMemoryStateChange() to OnPurgeMemory() in discardable_memory (Closed)
Patch Set: Fix test Created 3 years, 10 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 | « components/discardable_memory/service/discardable_shared_memory_manager.h ('k') | no next file » | 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 #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 387 matching lines...) Expand 10 before | Expand all | Expand 10 after
398 } 398 }
399 399
400 size_t DiscardableSharedMemoryManager::GetBytesAllocated() { 400 size_t DiscardableSharedMemoryManager::GetBytesAllocated() {
401 base::AutoLock lock(lock_); 401 base::AutoLock lock(lock_);
402 402
403 return bytes_allocated_; 403 return bytes_allocated_;
404 } 404 }
405 405
406 void DiscardableSharedMemoryManager::OnMemoryStateChange( 406 void DiscardableSharedMemoryManager::OnMemoryStateChange(
407 base::MemoryState state) { 407 base::MemoryState state) {
408 // Don't use SetMemoryLimit() as it free up existing allocations.
bashi 2017/02/07 02:42:22 As noted in https://cs.chromium.org/chromium/src/b
reveman 2017/02/07 03:34:07 nit: s/free/frees/ maybe also mention here that O
bashi 2017/02/07 04:31:35 Done.
409 base::AutoLock lock(lock_);
408 switch (state) { 410 switch (state) {
409 case base::MemoryState::NORMAL: 411 case base::MemoryState::NORMAL:
410 SetMemoryLimit(default_memory_limit_); 412 memory_limit_ = default_memory_limit_;
411 break; 413 break;
412 case base::MemoryState::THROTTLED: 414 case base::MemoryState::THROTTLED:
413 SetMemoryLimit(0); 415 memory_limit_ = 0;
414 break; 416 break;
415 case base::MemoryState::SUSPENDED: 417 case base::MemoryState::SUSPENDED:
416 // Note that SUSPENDED never occurs in the main browser process so far. 418 // Note that SUSPENDED never occurs in the main browser process so far.
417 // Fall through. 419 // Fall through.
418 case base::MemoryState::UNKNOWN: 420 case base::MemoryState::UNKNOWN:
419 NOTREACHED(); 421 NOTREACHED();
420 break; 422 break;
421 } 423 }
422 } 424 }
423 425
426 void DiscardableSharedMemoryManager::OnPurgeMemory() {
427 base::AutoLock lock(lock_);
428 ReduceMemoryUsageUntilWithinLimit(0);
429 }
430
424 void DiscardableSharedMemoryManager::AllocateLockedDiscardableSharedMemory( 431 void DiscardableSharedMemoryManager::AllocateLockedDiscardableSharedMemory(
425 int client_id, 432 int client_id,
426 size_t size, 433 size_t size,
427 int32_t id, 434 int32_t id,
428 base::SharedMemoryHandle* shared_memory_handle) { 435 base::SharedMemoryHandle* shared_memory_handle) {
429 base::AutoLock lock(lock_); 436 base::AutoLock lock(lock_);
430 437
431 // Make sure |id| is not already in use. 438 // Make sure |id| is not already in use.
432 MemorySegmentMap& client_segments = clients_[client_id]; 439 MemorySegmentMap& client_segments = clients_[client_id];
433 if (client_segments.find(id) != client_segments.end()) { 440 if (client_segments.find(id) != client_segments.end()) {
(...skipping 183 matching lines...) Expand 10 before | Expand all | Expand 10 after
617 return; 624 return;
618 625
619 enforce_memory_policy_pending_ = true; 626 enforce_memory_policy_pending_ = true;
620 DCHECK(enforce_memory_policy_task_runner_); 627 DCHECK(enforce_memory_policy_task_runner_);
621 enforce_memory_policy_task_runner_->PostDelayedTask( 628 enforce_memory_policy_task_runner_->PostDelayedTask(
622 FROM_HERE, enforce_memory_policy_callback_, 629 FROM_HERE, enforce_memory_policy_callback_,
623 base::TimeDelta::FromMilliseconds(kEnforceMemoryPolicyDelayMs)); 630 base::TimeDelta::FromMilliseconds(kEnforceMemoryPolicyDelayMs));
624 } 631 }
625 632
626 } // namespace discardable_memory 633 } // namespace discardable_memory
OLDNEW
« no previous file with comments | « components/discardable_memory/service/discardable_shared_memory_manager.h ('k') | no next file » | no next file with comments »

Powered by Google App Engine
This is Rietveld 408576698