summaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
-rw-r--r--components/nacl/browser/nacl_process_host.cc27
-rw-r--r--components/nacl/browser/nacl_process_host.h10
-rw-r--r--components/nacl/common/nacl_messages.h5
-rw-r--r--components/nacl/loader/nacl_listener.cc6
4 files changed, 41 insertions, 7 deletions
diff --git a/components/nacl/browser/nacl_process_host.cc b/components/nacl/browser/nacl_process_host.cc
index 6ef4986..5919766 100644
--- a/components/nacl/browser/nacl_process_host.cc
+++ b/components/nacl/browser/nacl_process_host.cc
@@ -654,6 +654,8 @@ bool NaClProcessHost::OnMessageReceived(const IPC::Message& msg) {
IPC_MESSAGE_HANDLER_DELAY_REPLY(
NaClProcessMsg_AttachDebugExceptionHandler,
OnAttachDebugExceptionHandler)
+ IPC_MESSAGE_HANDLER(NaClProcessHostMsg_DebugStubPortSelected,
+ OnDebugStubPortSelected)
#endif
IPC_MESSAGE_HANDLER(NaClProcessHostMsg_PpapiChannelsCreated,
OnPpapiChannelsCreated)
@@ -755,12 +757,20 @@ void NaClProcessHost::SendMessageToRenderer(
}
}
+void NaClProcessHost::SetDebugStubPort(uint16_t port) {
+ NaClBrowser* nacl_browser = NaClBrowser::GetInstance();
+ if (nacl_browser->HasGdbDebugStubPortListener()) {
+ nacl_browser->FireGdbDebugStubPortOpened(port);
+ }
+ // Set debug stub port on the process object.
+ process_->SetNaClDebugStubPort(port);
+}
+
+#if defined(OS_POSIX)
// TCP port we chose for NaCl debug stub. It can be any other number.
static const int kInitialDebugStubPort = 4014;
-#if defined(OS_POSIX)
net::SocketDescriptor NaClProcessHost::GetDebugStubSocketHandle() {
- NaClBrowser* nacl_browser = NaClBrowser::GetInstance();
net::SocketDescriptor s = net::kInvalidSocket;
// We always try to allocate the default port first. If this fails, we then
// allocate any available port.
@@ -772,12 +782,8 @@ net::SocketDescriptor NaClProcessHost::GetDebugStubSocketHandle() {
s = net::TCPListenSocket::CreateAndBindAnyPort("127.0.0.1", &port);
}
if (s != net::kInvalidSocket) {
- if (nacl_browser->HasGdbDebugStubPortListener()) {
- nacl_browser->FireGdbDebugStubPortOpened(port);
- }
+ SetDebugStubPort(port);
}
- // Set debug stub port on the process object.
- process_->SetNaClDebugStubPort(port);
if (s == net::kInvalidSocket) {
LOG(ERROR) << "failed to open socket for debug stub";
return net::kInvalidSocket;
@@ -794,6 +800,13 @@ net::SocketDescriptor NaClProcessHost::GetDebugStubSocketHandle() {
}
#endif
+#if defined(OS_WIN)
+void NaClProcessHost::OnDebugStubPortSelected(uint16_t debug_stub_port) {
+ CHECK(!uses_nonsfi_mode_);
+ SetDebugStubPort(debug_stub_port);
+}
+#endif
+
bool NaClProcessHost::StartNaClExecution() {
NaClBrowser* nacl_browser = NaClBrowser::GetInstance();
diff --git a/components/nacl/browser/nacl_process_host.h b/components/nacl/browser/nacl_process_host.h
index 37af81a..634e5b8 100644
--- a/components/nacl/browser/nacl_process_host.h
+++ b/components/nacl/browser/nacl_process_host.h
@@ -106,12 +106,22 @@ class NaClProcessHost : public content::BrowserChildProcessHostDelegate {
bool LaunchNaClGdb();
+ // Mark the process as using a particular GDB debug stub port and notify
+ // listeners.
+ void SetDebugStubPort(uint16_t port);
+
#if defined(OS_POSIX)
// Create bound TCP socket in the browser process so that the NaCl GDB debug
// stub can use it to accept incoming connections even when the Chrome sandbox
// is enabled.
net::SocketDescriptor GetDebugStubSocketHandle();
#endif
+
+#if defined(OS_WIN)
+ // Called when the debug stub port has been selected.
+ void OnDebugStubPortSelected(uint16_t debug_stub_port);
+#endif
+
bool LaunchSelLdr();
// BrowserChildProcessHostDelegate implementation:
diff --git a/components/nacl/common/nacl_messages.h b/components/nacl/common/nacl_messages.h
index 2b1fbba..bb58f9e 100644
--- a/components/nacl/common/nacl_messages.h
+++ b/components/nacl/common/nacl_messages.h
@@ -66,6 +66,11 @@ IPC_MESSAGE_CONTROL0(NaClProcessMsg_StopBroker)
IPC_SYNC_MESSAGE_CONTROL1_1(NaClProcessMsg_AttachDebugExceptionHandler,
std::string, /* Internal process info */
bool /* Result */)
+
+// Notify the browser process that the NaCl process has bound the given
+// TCP port number to use for the GDB debug stub.
+IPC_MESSAGE_CONTROL1(NaClProcessHostMsg_DebugStubPortSelected,
+ uint16_t /* debug_stub_port */)
#endif
// Used by the NaCl process to query a database in the browser. The database
diff --git a/components/nacl/loader/nacl_listener.cc b/components/nacl/loader/nacl_listener.cc
index e7b8f4c..f527191 100644
--- a/components/nacl/loader/nacl_listener.cc
+++ b/components/nacl/loader/nacl_listener.cc
@@ -109,6 +109,10 @@ int AttachDebugExceptionHandler(const void* info, size_t info_size) {
return result;
}
+void DebugStubPortSelectedHandler(uint16_t port) {
+ g_listener->Send(new NaClProcessHostMsg_DebugStubPortSelected(port));
+}
+
#endif
// Creates the PPAPI IPC channel between the NaCl IRT and the host
@@ -464,6 +468,8 @@ void NaClListener::OnStart(const nacl::NaClStartParams& params) {
#if defined(OS_WIN)
args->broker_duplicate_handle_func = BrokerDuplicateHandle;
args->attach_debug_exception_handler_func = AttachDebugExceptionHandler;
+ args->debug_stub_server_port_selected_handler_func =
+ DebugStubPortSelectedHandler;
#endif
#if defined(OS_LINUX)
args->prereserved_sandbox_size = prereserved_sandbox_size_;