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

Side by Side Diff: base/memory/discardable_memory_ashmem.cc

Issue 285493004: [Mac] A couple of improvements for DiscardableMemory (Closed) Base URL: svn://svn.chromium.org/chrome/trunk/src
Patch Set: Created 6 years, 7 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 | Annotate | Revision Log
« no previous file with comments | « no previous file | base/memory/discardable_memory_emulated.cc » ('j') | 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 "base/memory/discardable_memory_ashmem.h" 5 #include "base/memory/discardable_memory_ashmem.h"
6 6
7 #include "base/memory/discardable_memory_ashmem_allocator.h" 7 #include "base/memory/discardable_memory_ashmem_allocator.h"
8 8
9 namespace base { 9 namespace base {
10 namespace internal { 10 namespace internal {
11 11
12 DiscardableMemoryAshmem::DiscardableMemoryAshmem( 12 DiscardableMemoryAshmem::DiscardableMemoryAshmem(
13 size_t bytes, 13 size_t bytes,
14 DiscardableMemoryAshmemAllocator* allocator, 14 DiscardableMemoryAshmemAllocator* allocator,
15 DiscardableMemoryManager* manager) 15 DiscardableMemoryManager* manager)
16 : bytes_(bytes), 16 : bytes_(bytes),
17 allocator_(allocator), 17 allocator_(allocator),
18 manager_(manager), 18 manager_(manager),
19 is_locked_(false) { 19 is_locked_(false) {
20 manager_->Register(this, bytes_); 20 manager_->Register(this, bytes_);
21 } 21 }
22 22
23 DiscardableMemoryAshmem::~DiscardableMemoryAshmem() { 23 DiscardableMemoryAshmem::~DiscardableMemoryAshmem() {
24 if (is_locked_) 24 if (is_locked_)
25 manager_->ReleaseLock(this); 25 Unlock();
26 26
27 manager_->Unregister(this); 27 manager_->Unregister(this);
28 } 28 }
29 29
30 bool DiscardableMemoryAshmem::Initialize() { 30 bool DiscardableMemoryAshmem::Initialize() {
31 return Lock() == DISCARDABLE_MEMORY_LOCK_STATUS_PURGED; 31 return Lock() != DISCARDABLE_MEMORY_LOCK_STATUS_FAILED;
32 } 32 }
33 33
34 DiscardableMemoryLockStatus DiscardableMemoryAshmem::Lock() { 34 DiscardableMemoryLockStatus DiscardableMemoryAshmem::Lock() {
35 DCHECK(!is_locked_);
36
35 bool purged = false; 37 bool purged = false;
36 if (!manager_->AcquireLock(this, &purged)) 38 if (!manager_->AcquireLock(this, &purged))
37 return DISCARDABLE_MEMORY_LOCK_STATUS_FAILED; 39 return DISCARDABLE_MEMORY_LOCK_STATUS_FAILED;
38 40
41 is_locked_ = true;
39 return purged ? DISCARDABLE_MEMORY_LOCK_STATUS_PURGED 42 return purged ? DISCARDABLE_MEMORY_LOCK_STATUS_PURGED
40 : DISCARDABLE_MEMORY_LOCK_STATUS_SUCCESS; 43 : DISCARDABLE_MEMORY_LOCK_STATUS_SUCCESS;
41 } 44 }
42 45
43 void DiscardableMemoryAshmem::Unlock() { 46 void DiscardableMemoryAshmem::Unlock() {
47 DCHECK(is_locked_);
44 manager_->ReleaseLock(this); 48 manager_->ReleaseLock(this);
49 is_locked_ = false;
45 } 50 }
46 51
47 void* DiscardableMemoryAshmem::Memory() const { 52 void* DiscardableMemoryAshmem::Memory() const {
53 DCHECK(is_locked_);
48 DCHECK(ashmem_chunk_); 54 DCHECK(ashmem_chunk_);
49 return ashmem_chunk_->Memory(); 55 return ashmem_chunk_->Memory();
50 } 56 }
51 57
52 bool DiscardableMemoryAshmem::AllocateAndAcquireLock() { 58 bool DiscardableMemoryAshmem::AllocateAndAcquireLock() {
53 DCHECK(!is_locked_);
54 is_locked_ = true;
55
56 if (ashmem_chunk_) 59 if (ashmem_chunk_)
57 return ashmem_chunk_->Lock(); 60 return ashmem_chunk_->Lock();
58 61
59 ashmem_chunk_ = allocator_->Allocate(bytes_); 62 ashmem_chunk_ = allocator_->Allocate(bytes_);
60 return false; 63 return false;
61 } 64 }
62 65
63 void DiscardableMemoryAshmem::ReleaseLock() { 66 void DiscardableMemoryAshmem::ReleaseLock() {
64 DCHECK(is_locked_);
65 ashmem_chunk_->Unlock(); 67 ashmem_chunk_->Unlock();
66 is_locked_ = false;
67 } 68 }
68 69
69 void DiscardableMemoryAshmem::Purge() { 70 void DiscardableMemoryAshmem::Purge() {
70 DCHECK(!is_locked_);
71 ashmem_chunk_.reset(); 71 ashmem_chunk_.reset();
72 } 72 }
73 73
74 } // namespace internal 74 } // namespace internal
75 } // namespace base 75 } // namespace base
OLDNEW
« no previous file with comments | « no previous file | base/memory/discardable_memory_emulated.cc » ('j') | no next file with comments »

Powered by Google App Engine
This is Rietveld 408576698