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

Side by Side Diff: content/child/child_shared_bitmap_manager.cc

Issue 148243013: Add shared bitmap managers for browser and renderer processes. (Closed) Base URL: svn://svn.chromium.org/chrome/trunk/src
Patch Set: Created 6 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 | Annotate | Revision Log
OLDNEW
(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
OLDNEW

Powered by Google App Engine
This is Rietveld 408576698