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

Side by Side Diff: chrome/nacl/nacl_listener.cc

Issue 7395024: For Linux, create a ZygoteForkDelegate that uses the nacl_helper executable (Closed) Base URL: svn://svn.chromium.org/chrome/trunk/src
Patch Set: Presubmit: fixing a copyright header. Created 9 years, 5 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 | « chrome/nacl/nacl_listener.h ('k') | chrome/nacl/nacl_main.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 (c) 2011 The Chromium Authors. All rights reserved. 1 // Copyright (c) 2011 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 "chrome/nacl/nacl_launcher_thread.h" 5 #include "chrome/nacl/nacl_listener.h"
6 6
7 #include <vector> 7 #include <errno.h>
8 8
9 #include "base/atomicops.h" 9 #include "base/command_line.h"
10 #include "base/logging.h"
10 #include "base/memory/scoped_ptr.h" 11 #include "base/memory/scoped_ptr.h"
12 #include "base/message_loop.h"
11 #include "chrome/common/nacl_messages.h" 13 #include "chrome/common/nacl_messages.h"
14 #include "ipc/ipc_channel.h"
15 #include "ipc/ipc_switches.h"
12 #include "native_client/src/shared/imc/nacl_imc.h" 16 #include "native_client/src/shared/imc/nacl_imc.h"
13 17
14 #if defined(OS_LINUX) 18 #if defined(OS_LINUX)
15 #include "content/common/child_process_sandbox_support_linux.h" 19 #include "content/common/child_process_sandbox_support_linux.h"
16 #endif 20 #endif
17 21
18 #if defined(OS_WIN) 22 #if defined(OS_WIN)
19 #include <fcntl.h> 23 #include <fcntl.h>
20 #include <io.h> 24 #include <io.h>
21 #endif 25 #endif
22 26
27 // This is ugly. We need an interface header file for the exported
28 // sel_ldr interfaces.
29 // TODO(gregoryd,sehr): Add an interface header.
30 #if defined(OS_WIN)
31 typedef HANDLE NaClHandle;
32 #else
33 typedef int NaClHandle;
34 #endif // NaClHandle
35
23 #if defined(OS_MACOSX) 36 #if defined(OS_MACOSX)
24 namespace { 37 namespace {
25 38
26 // On Mac OS X, shm_open() works in the sandbox but does not give us 39 // On Mac OS X, shm_open() works in the sandbox but does not give us
27 // an FD that we can map as PROT_EXEC. Rather than doing an IPC to 40 // an FD that we can map as PROT_EXEC. Rather than doing an IPC to
28 // get an executable SHM region when CreateMemoryObject() is called, 41 // get an executable SHM region when CreateMemoryObject() is called,
29 // we preallocate one on startup, since NaCl's sel_ldr only needs one 42 // we preallocate one on startup, since NaCl's sel_ldr only needs one
30 // of them. This saves a round trip. 43 // of them. This saves a round trip.
31 44
32 base::subtle::Atomic32 g_shm_fd = -1; 45 base::subtle::Atomic32 g_shm_fd = -1;
(...skipping 16 matching lines...) Expand all
49 return result_fd; 62 return result_fd;
50 } 63 }
51 } 64 }
52 // Fall back to NaCl's default implementation. 65 // Fall back to NaCl's default implementation.
53 return -1; 66 return -1;
54 } 67 }
55 68
56 } // namespace 69 } // namespace
57 #endif // defined(OS_MACOSX) 70 #endif // defined(OS_MACOSX)
58 71
59 // This is ugly. We need an interface header file for the exported 72 extern "C" int NaClMainForChromium(int handle_count,
60 // sel_ldr interfaces. 73 const NaClHandle* handles,
61 // TODO(gregoryd,sehr): Add an interface header.
62 #if defined(OS_WIN)
63 typedef HANDLE NaClHandle;
64 #else
65 typedef int NaClHandle;
66 #endif // NaClHandle
67
68 // This is currently necessary because we have a conflict between
69 // NaCl's LOG_FATAL (from platform/nacl_log.h) and Chromium's
70 // LOG_FATAL (from base/logging.h).
71 extern "C" int NaClMainForChromium(int handle_count, const NaClHandle* handles,
72 int debug); 74 int debug);
73 extern "C" void NaClSetIrtFileDesc(int fd); 75 extern "C" void NaClSetIrtFileDesc(int fd);
74 76
75 NaClLauncherThread::NaClLauncherThread(bool debug) { 77 NaClListener::NaClListener() {}
76 debug_enabled_ = debug ? 1 : 0; 78
79 NaClListener::~NaClListener() {}
80
81 void NaClListener::Listen() {
82 std::string channel_name =
83 CommandLine::ForCurrentProcess()->GetSwitchValueASCII(
84 switches::kProcessChannelID);
85 IPC::Channel channel(channel_name, IPC::Channel::MODE_CLIENT, this);
86 CHECK(channel.Connect());
87 MessageLoop::current()->Run();
77 } 88 }
78 89
79 NaClLauncherThread::~NaClLauncherThread() { 90 bool NaClListener::OnMessageReceived(const IPC::Message& msg) {
80 }
81
82 NaClLauncherThread* NaClLauncherThread::current() {
83 return static_cast<NaClLauncherThread*>(ChildThread::current());
84 }
85
86 bool NaClLauncherThread::OnControlMessageReceived(const IPC::Message& msg) {
87 bool handled = true; 91 bool handled = true;
88 IPC_BEGIN_MESSAGE_MAP(NaClLauncherThread, msg) 92 IPC_BEGIN_MESSAGE_MAP(NaClListener, msg)
89 IPC_MESSAGE_HANDLER(NaClProcessMsg_Start, OnStartSelLdr) 93 IPC_MESSAGE_HANDLER(NaClProcessMsg_Start, OnStartSelLdr)
90 IPC_MESSAGE_UNHANDLED(handled = false) 94 IPC_MESSAGE_UNHANDLED(handled = false)
91 IPC_END_MESSAGE_MAP() 95 IPC_END_MESSAGE_MAP()
92 return handled; 96 return handled;
93 } 97 }
94 98
95 void NaClLauncherThread::OnStartSelLdr( 99 void NaClListener::OnStartSelLdr(
96 std::vector<nacl::FileDescriptor> handles, 100 std::vector<nacl::FileDescriptor> handles,
97 bool have_irt_file) { 101 bool have_irt_file) {
98 #if defined(OS_LINUX) 102 #if defined(OS_LINUX)
99 nacl::SetCreateMemoryObjectFunc( 103 nacl::SetCreateMemoryObjectFunc(
100 child_process_sandbox_support::MakeSharedMemorySegmentViaIPC); 104 child_process_sandbox_support::MakeSharedMemorySegmentViaIPC);
101 #elif defined(OS_MACOSX) 105 #elif defined(OS_MACOSX)
102 nacl::SetCreateMemoryObjectFunc(CreateMemoryObject); 106 nacl::SetCreateMemoryObjectFunc(CreateMemoryObject);
103 CHECK(handles.size() >= 1); 107 CHECK(handles.size() >= 1);
104 g_shm_fd = nacl::ToNativeHandle(handles[handles.size() - 1]); 108 g_shm_fd = nacl::ToNativeHandle(handles[handles.size() - 1]);
105 handles.pop_back(); 109 handles.pop_back();
(...skipping 14 matching lines...) Expand all
120 int irt_desc = irt_handle; 124 int irt_desc = irt_handle;
121 #endif 125 #endif
122 NaClSetIrtFileDesc(irt_desc); 126 NaClSetIrtFileDesc(irt_desc);
123 } 127 }
124 128
125 scoped_array<NaClHandle> array(new NaClHandle[handles.size()]); 129 scoped_array<NaClHandle> array(new NaClHandle[handles.size()]);
126 for (size_t i = 0; i < handles.size(); i++) { 130 for (size_t i = 0; i < handles.size(); i++) {
127 array[i] = nacl::ToNativeHandle(handles[i]); 131 array[i] = nacl::ToNativeHandle(handles[i]);
128 } 132 }
129 NaClMainForChromium(static_cast<int>(handles.size()), array.get(), 133 NaClMainForChromium(static_cast<int>(handles.size()), array.get(),
130 debug_enabled_); 134 false /* debug */);
131 } 135 }
OLDNEW
« no previous file with comments | « chrome/nacl/nacl_listener.h ('k') | chrome/nacl/nacl_main.cc » ('j') | no next file with comments »

Powered by Google App Engine
This is Rietveld 408576698