Chromium Code Reviews| OLD | NEW |
|---|---|
| (Empty) | |
| 1 // Copyright (c) 2013 The Chromium Authors. All rights reserved. | |
| 2 // Use of this source code is governed by a BSD-style license that can be | |
| 3 // found in the LICENSE file. | |
| 4 | |
| 5 #include "content/child/child_shared_bitmap_manager.h" | |
| 6 | |
| 7 #include "content/child/child_thread.h" | |
| 8 #include "content/common/child_process_messages.h" | |
| 9 #include "ui/gfx/size.h" | |
| 10 | |
| 11 namespace content { | |
| 12 | |
| 13 ChildSharedBitmapManager::ChildSharedBitmapManager( | |
| 14 scoped_refptr<ThreadSafeSender> sender) | |
| 15 : sender_(sender) {} | |
| 16 | |
| 17 ChildSharedBitmapManager::~ChildSharedBitmapManager() {} | |
| 18 | |
| 19 scoped_ptr<cc::SharedBitmap> ChildSharedBitmapManager::AllocateSharedBitmap( | |
| 20 const gfx::Size& size) { | |
| 21 TRACE_EVENT2("renderer", | |
| 22 "ChildSharedBitmapManager::AllocateSharedMemory", | |
| 23 "width", | |
| 24 size.width(), | |
| 25 "height", | |
| 26 size.height()); | |
| 27 size_t memory_size = cc::SharedBitmap::GetSizeInBytes(size); | |
|
piman
2014/02/18 21:38:20
Do we need to protect against overflow here? Can c
| |
| 28 cc::SharedBitmapId id = cc::SharedBitmap::GenerateId(); | |
| 29 scoped_ptr<base::SharedMemory> memory; | |
| 30 #if defined(OS_POSIX) | |
| 31 base::SharedMemoryHandle handle; | |
| 32 sender_->Send(new ChildProcessHostMsg_SyncAllocateSharedBitmap( | |
| 33 memory_size, id, &handle)); | |
| 34 memory = make_scoped_ptr(new base::SharedMemory(handle, false)); | |
| 35 memory->Map(memory_size); | |
| 36 #else | |
| 37 memory = | |
| 38 make_scoped_ptr(ChildThread::AllocateSharedMemory(memory_size, sender_)); | |
|
piman
2014/02/18 21:38:20
nit: or memory.reset(ChildThread::AllocateSharedMe
| |
| 39 CHECK(memory); | |
| 40 memory->Map(memory_size); | |
| 41 base::SharedMemoryHandle handle_to_send = memory->handle(); | |
|
piman
2014/02/18 21:38:20
Is that safe?
Assume the child (renderer) does li
| |
| 42 sender_->Send(new ChildProcessHostMsg_AllocatedSharedBitmap( | |
| 43 memory_size, handle_to_send, id)); | |
| 44 #endif | |
| 45 return scoped_ptr<cc::SharedBitmap>(new cc::SharedBitmap( | |
| 46 memory.release(), | |
| 47 id, | |
| 48 base::Bind(&ChildSharedBitmapManager::FreeSharedMemory, | |
| 49 base::Unretained(this)))); | |
|
piman
2014/02/18 21:38:20
What makes Unretained safe?
| |
| 50 } | |
| 51 | |
| 52 scoped_ptr<cc::SharedBitmap> ChildSharedBitmapManager::GetSharedBitmapFromId( | |
| 53 const gfx::Size&, | |
| 54 const cc::SharedBitmapId&) { | |
| 55 NOTREACHED(); | |
| 56 return scoped_ptr<cc::SharedBitmap>(); | |
| 57 } | |
| 58 | |
| 59 scoped_ptr<cc::SharedBitmap> ChildSharedBitmapManager::GetBitmapForSharedMemory( | |
| 60 base::SharedMemory* mem) { | |
| 61 cc::SharedBitmapId id = cc::SharedBitmap::GenerateId(); | |
| 62 base::SharedMemoryHandle handle_to_send = mem->handle(); | |
| 63 #if defined(OS_POSIX) | |
| 64 if (!mem->ShareToProcess(base::GetCurrentProcessHandle(), &handle_to_send)) | |
| 65 return scoped_ptr<cc::SharedBitmap>(); | |
| 66 #endif | |
| 67 sender_->Send(new ChildProcessHostMsg_AllocatedSharedBitmap( | |
| 68 mem->mapped_size(), handle_to_send, id)); | |
| 69 return scoped_ptr<cc::SharedBitmap>(new cc::SharedBitmap( | |
| 70 mem, | |
| 71 id, | |
| 72 base::Bind(&ChildSharedBitmapManager::ReleaseSharedBitmap, | |
| 73 base::Unretained(this)))); | |
|
piman
2014/02/18 21:38:20
What makes Unretained safe?
| |
| 74 } | |
| 75 | |
| 76 void ChildSharedBitmapManager::FreeSharedMemory(cc::SharedBitmap* bitmap) { | |
| 77 TRACE_EVENT0("renderer", "ChildSharedBitmapManager::FreeSharedMemory"); | |
| 78 sender_->Send(new ChildProcessHostMsg_DeletedSharedBitmap(bitmap->id())); | |
| 79 delete bitmap->memory(); | |
| 80 } | |
| 81 | |
| 82 void ChildSharedBitmapManager::ReleaseSharedBitmap(cc::SharedBitmap* handle) { | |
| 83 TRACE_EVENT0("renderer", "ChildSharedBitmapManager::ReleaseSharedBitmap"); | |
| 84 sender_->Send(new ChildProcessHostMsg_DeletedSharedBitmap(handle->id())); | |
| 85 } | |
| 86 | |
| 87 } // namespace content | |
| OLD | NEW |