Chromium Code Reviews| OLD | NEW |
|---|---|
| 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 "content/child/child_discardable_shared_memory_manager.h" | 5 #include "content/child/child_discardable_shared_memory_manager.h" |
| 6 | 6 |
| 7 #include "base/atomic_sequence_num.h" | 7 #include "base/atomic_sequence_num.h" |
| 8 #include "base/bind.h" | 8 #include "base/bind.h" |
| 9 #include "base/debug/crash_logging.h" | 9 #include "base/debug/crash_logging.h" |
| 10 #include "base/memory/discardable_memory.h" | 10 #include "base/memory/discardable_memory.h" |
| (...skipping 53 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... | |
| 64 } | 64 } |
| 65 | 65 |
| 66 private: | 66 private: |
| 67 ChildDiscardableSharedMemoryManager* const manager_; | 67 ChildDiscardableSharedMemoryManager* const manager_; |
| 68 scoped_ptr<DiscardableSharedMemoryHeap::Span> span_; | 68 scoped_ptr<DiscardableSharedMemoryHeap::Span> span_; |
| 69 bool is_locked_; | 69 bool is_locked_; |
| 70 | 70 |
| 71 DISALLOW_COPY_AND_ASSIGN(DiscardableMemoryImpl); | 71 DISALLOW_COPY_AND_ASSIGN(DiscardableMemoryImpl); |
| 72 }; | 72 }; |
| 73 | 73 |
| 74 void DeletedDiscardableSharedMemory( | |
|
Avi (use Gerrit)
2015/03/27 21:13:01
We name functions based on what they do, not when
reveman
2015/03/27 21:27:34
Hm, this is supposed to handle the notification th
Avi (use Gerrit)
2015/03/27 21:38:46
Something like SendMemoryDeletedMessage?. I'm look
reveman
2015/03/27 21:53:52
SendDeletedDiscardableSharedMemoryMessage where "D
| |
| 75 scoped_refptr<ThreadSafeSender> sender, DiscardableSharedMemoryId id) { | |
| 76 sender->Send(new ChildProcessHostMsg_DeletedDiscardableSharedMemory(id)); | |
| 77 } | |
| 78 | |
| 74 } // namespace | 79 } // namespace |
| 75 | 80 |
| 76 ChildDiscardableSharedMemoryManager::ChildDiscardableSharedMemoryManager( | 81 ChildDiscardableSharedMemoryManager::ChildDiscardableSharedMemoryManager( |
| 77 ThreadSafeSender* sender) | 82 ThreadSafeSender* sender) : heap_(base::GetPageSize()), sender_(sender) { |
| 78 : heap_(base::GetPageSize()), sender_(sender), weak_ptr_factory_(this) { | |
| 79 } | 83 } |
| 80 | 84 |
| 81 ChildDiscardableSharedMemoryManager::~ChildDiscardableSharedMemoryManager() { | 85 ChildDiscardableSharedMemoryManager::~ChildDiscardableSharedMemoryManager() { |
| 82 // Cancel all DeletedDiscardableSharedMemory callbacks. | |
| 83 weak_ptr_factory_.InvalidateWeakPtrs(); | |
| 84 | |
| 85 // TODO(reveman): Determine if this DCHECK can be enabled. crbug.com/430533 | 86 // TODO(reveman): Determine if this DCHECK can be enabled. crbug.com/430533 |
| 86 // DCHECK_EQ(heap_.GetSize(), heap_.GetSizeOfFreeLists()); | 87 // DCHECK_EQ(heap_.GetSize(), heap_.GetSizeOfFreeLists()); |
| 87 if (heap_.GetSize()) | 88 if (heap_.GetSize()) |
| 88 MemoryUsageChanged(0, 0); | 89 MemoryUsageChanged(0, 0); |
| 89 } | 90 } |
| 90 | 91 |
| 91 scoped_ptr<base::DiscardableMemory> | 92 scoped_ptr<base::DiscardableMemory> |
| 92 ChildDiscardableSharedMemoryManager::AllocateLockedDiscardableMemory( | 93 ChildDiscardableSharedMemoryManager::AllocateLockedDiscardableMemory( |
| 93 size_t size) { | 94 size_t size) { |
| 94 base::AutoLock lock(lock_); | 95 base::AutoLock lock(lock_); |
| (...skipping 65 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... | |
| 160 DiscardableSharedMemoryId new_id = | 161 DiscardableSharedMemoryId new_id = |
| 161 g_next_discardable_shared_memory_id.GetNext(); | 162 g_next_discardable_shared_memory_id.GetNext(); |
| 162 | 163 |
| 163 // Ask parent process to allocate a new discardable shared memory segment. | 164 // Ask parent process to allocate a new discardable shared memory segment. |
| 164 scoped_ptr<base::DiscardableSharedMemory> shared_memory( | 165 scoped_ptr<base::DiscardableSharedMemory> shared_memory( |
| 165 AllocateLockedDiscardableSharedMemory(allocation_size_in_bytes, new_id)); | 166 AllocateLockedDiscardableSharedMemory(allocation_size_in_bytes, new_id)); |
| 166 | 167 |
| 167 // Create span for allocated memory. | 168 // Create span for allocated memory. |
| 168 scoped_ptr<DiscardableSharedMemoryHeap::Span> new_span(heap_.Grow( | 169 scoped_ptr<DiscardableSharedMemoryHeap::Span> new_span(heap_.Grow( |
| 169 shared_memory.Pass(), allocation_size_in_bytes, | 170 shared_memory.Pass(), allocation_size_in_bytes, |
| 170 base::Bind( | 171 base::Bind(&DeletedDiscardableSharedMemory, sender_, new_id))); |
| 171 &ChildDiscardableSharedMemoryManager::DeletedDiscardableSharedMemory, | |
| 172 weak_ptr_factory_.GetWeakPtr(), new_id))); | |
| 173 | 172 |
| 174 // Unlock and insert any left over memory into free lists. | 173 // Unlock and insert any left over memory into free lists. |
| 175 if (pages < pages_to_allocate) { | 174 if (pages < pages_to_allocate) { |
| 176 scoped_ptr<DiscardableSharedMemoryHeap::Span> leftover = | 175 scoped_ptr<DiscardableSharedMemoryHeap::Span> leftover = |
| 177 heap_.Split(new_span.get(), pages); | 176 heap_.Split(new_span.get(), pages); |
| 178 leftover->shared_memory()->Unlock( | 177 leftover->shared_memory()->Unlock( |
| 179 leftover->start() * base::GetPageSize() - | 178 leftover->start() * base::GetPageSize() - |
| 180 reinterpret_cast<size_t>(leftover->shared_memory()->memory()), | 179 reinterpret_cast<size_t>(leftover->shared_memory()->memory()), |
| 181 leftover->length() * base::GetPageSize()); | 180 leftover->length() * base::GetPageSize()); |
| 182 heap_.MergeIntoFreeLists(leftover.Pass()); | 181 heap_.MergeIntoFreeLists(leftover.Pass()); |
| (...skipping 81 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... | |
| 264 sender_->Send( | 263 sender_->Send( |
| 265 new ChildProcessHostMsg_SyncAllocateLockedDiscardableSharedMemory( | 264 new ChildProcessHostMsg_SyncAllocateLockedDiscardableSharedMemory( |
| 266 size, id, &handle)); | 265 size, id, &handle)); |
| 267 CHECK(base::SharedMemory::IsHandleValid(handle)); | 266 CHECK(base::SharedMemory::IsHandleValid(handle)); |
| 268 scoped_ptr<base::DiscardableSharedMemory> memory( | 267 scoped_ptr<base::DiscardableSharedMemory> memory( |
| 269 new base::DiscardableSharedMemory(handle)); | 268 new base::DiscardableSharedMemory(handle)); |
| 270 CHECK(memory->Map(size)); | 269 CHECK(memory->Map(size)); |
| 271 return memory.Pass(); | 270 return memory.Pass(); |
| 272 } | 271 } |
| 273 | 272 |
| 274 void ChildDiscardableSharedMemoryManager::DeletedDiscardableSharedMemory( | |
| 275 DiscardableSharedMemoryId id) { | |
| 276 sender_->Send(new ChildProcessHostMsg_DeletedDiscardableSharedMemory(id)); | |
| 277 } | |
| 278 | |
| 279 void ChildDiscardableSharedMemoryManager::MemoryUsageChanged( | 273 void ChildDiscardableSharedMemoryManager::MemoryUsageChanged( |
| 280 size_t new_bytes_total, | 274 size_t new_bytes_total, |
| 281 size_t new_bytes_free) const { | 275 size_t new_bytes_free) const { |
| 282 TRACE_COUNTER2("renderer", "DiscardableMemoryUsage", "allocated", | 276 TRACE_COUNTER2("renderer", "DiscardableMemoryUsage", "allocated", |
| 283 new_bytes_total - new_bytes_free, "free", new_bytes_free); | 277 new_bytes_total - new_bytes_free, "free", new_bytes_free); |
| 284 | 278 |
| 285 static const char kDiscardableMemoryAllocatedKey[] = | 279 static const char kDiscardableMemoryAllocatedKey[] = |
| 286 "discardable-memory-allocated"; | 280 "discardable-memory-allocated"; |
| 287 base::debug::SetCrashKeyValue(kDiscardableMemoryAllocatedKey, | 281 base::debug::SetCrashKeyValue(kDiscardableMemoryAllocatedKey, |
| 288 base::Uint64ToString(new_bytes_total)); | 282 base::Uint64ToString(new_bytes_total)); |
| 289 | 283 |
| 290 static const char kDiscardableMemoryFreeKey[] = "discardable-memory-free"; | 284 static const char kDiscardableMemoryFreeKey[] = "discardable-memory-free"; |
| 291 base::debug::SetCrashKeyValue(kDiscardableMemoryFreeKey, | 285 base::debug::SetCrashKeyValue(kDiscardableMemoryFreeKey, |
| 292 base::Uint64ToString(new_bytes_free)); | 286 base::Uint64ToString(new_bytes_free)); |
| 293 } | 287 } |
| 294 | 288 |
| 295 } // namespace content | 289 } // namespace content |
| OLD | NEW |