diff options
author | bradnelson@google.com <bradnelson@google.com@0039d316-1c4b-4281-b951-d872f2087c98> | 2009-09-18 03:01:21 +0000 |
---|---|---|
committer | bradnelson@google.com <bradnelson@google.com@0039d316-1c4b-4281-b951-d872f2087c98> | 2009-09-18 03:01:21 +0000 |
commit | 79970a2cfbe87224954b281984e2e67c593ea13c (patch) | |
tree | 19f8825cd7c8182742f1566bfee5ad45af2bcc23 /chrome | |
parent | c31df6877d7b45075decbe97da47d6c783de62ed (diff) | |
download | chromium_src-79970a2cfbe87224954b281984e2e67c593ea13c.zip chromium_src-79970a2cfbe87224954b281984e2e67c593ea13c.tar.gz chromium_src-79970a2cfbe87224954b281984e2e67c593ea13c.tar.bz2 |
Preparing rollback in case things don't work out.
This rolls back 26540, gregoryd's attempt at a nacl landing.
BUG=None
TEST=None
Review URL: http://codereview.chromium.org/213019
git-svn-id: svn://svn.chromium.org/chrome/trunk/src@26543 0039d316-1c4b-4281-b951-d872f2087c98
Diffstat (limited to 'chrome')
24 files changed, 1 insertions, 800 deletions
diff --git a/chrome/DEPS b/chrome/DEPS index d31dcde..2519453 100644 --- a/chrome/DEPS +++ b/chrome/DEPS @@ -35,8 +35,4 @@ include_rules = [ # On Linux, the zygote needs to access sandbox headers "+sandbox/linux" - - # NativeClient uses the sandbox. - # TODO(gregoryd): confirm this is really needed. - "+sandbox/linux" ] diff --git a/chrome/app/chrome_dll_main.cc b/chrome/app/chrome_dll_main.cc index c2a0e0f..805565d 100644 --- a/chrome/app/chrome_dll_main.cc +++ b/chrome/app/chrome_dll_main.cc @@ -81,7 +81,6 @@ extern int BrowserMain(const MainFunctionParams&); extern int RendererMain(const MainFunctionParams&); extern int PluginMain(const MainFunctionParams&); extern int WorkerMain(const MainFunctionParams&); -extern int NaClMain(const MainFunctionParams&); extern int UtilityMain(const MainFunctionParams&); extern int ProfileImportMain(const MainFunctionParams&); extern int ZygoteMain(const MainFunctionParams&); @@ -580,8 +579,6 @@ int ChromeMain(int argc, char** argv) { #endif } else if (process_type == switches::kWorkerProcess) { rv = WorkerMain(main_params); - } else if (process_type == switches::kNaClProcess) { - rv = NaClMain(main_params); } else if (process_type == switches::kZygoteProcess) { #if defined(OS_LINUX) if (ZygoteMain(main_params)) { diff --git a/chrome/browser/nacl_process_host.cc b/chrome/browser/nacl_process_host.cc deleted file mode 100644 index f466f6a..0000000 --- a/chrome/browser/nacl_process_host.cc +++ /dev/null @@ -1,187 +0,0 @@ -// Copyright (c) 2009 The Chromium Authors. All rights reserved. -// Use of this source code is governed by a BSD-style license that can be -// found in the LICENSE file. - -#include "build/build_config.h" - -#include "chrome/browser/nacl_process_host.h" - -#if defined(OS_POSIX) -#include <fcntl.h> -#endif - -#if defined(OS_POSIX) -#include "base/global_descriptors_posix.h" -#endif -#include "base/path_service.h" -#include "base/process_util.h" -#include "chrome/browser/renderer_host/resource_message_filter.h" -#include "chrome/common/chrome_descriptors.h" -#include "chrome/common/chrome_switches.h" -#include "chrome/common/logging_chrome.h" -#include "chrome/common/nacl_messages.h" -#include "ipc/ipc_switches.h" - -#if defined(OS_WIN) -#include "chrome/browser/sandbox_policy.h" -#endif - -#if defined(OS_POSIX) -#include "ipc/ipc_channel_posix.h" -#endif - -NaClProcessHost::NaClProcessHost( - ResourceDispatcherHost *resource_dispatcher_host) - : ChildProcessHost(NACL_PROCESS, resource_dispatcher_host), - resource_dispatcher_host_(resource_dispatcher_host) { -} - -bool NaClProcessHost::Launch(ResourceMessageFilter* renderer_msg_filter, - const int descriptor, - nacl::FileDescriptor* handle) { - nacl::Handle pair[2]; - bool success = false; - // Create a connected socket - if (nacl::SocketPair(pair) == -1) { - NATIVE_HANDLE(*handle) = nacl::kInvalidHandle; - return false; - } - - // Launch the process - success = LaunchSelLdr(renderer_msg_filter, descriptor, pair[1]); - - if (!success) { - nacl::Close(pair[0]); - NATIVE_HANDLE(*handle) = nacl::kInvalidHandle; - return false; - } - - nacl::Handle duplicate_handle = nacl::kInvalidHandle; -#if NACL_WINDOWS - DuplicateHandle(base::GetCurrentProcessHandle(), - reinterpret_cast<HANDLE>(pair[0]), - renderer_msg_filter->handle(), - reinterpret_cast<HANDLE*>(&duplicate_handle), - GENERIC_READ | GENERIC_WRITE, - FALSE, - DUPLICATE_CLOSE_SOURCE); - *handle = duplicate_handle; -#else - duplicate_handle = pair[0]; - int flags = fcntl(duplicate_handle, F_GETFD); - if (flags != -1) { - flags |= FD_CLOEXEC; - fcntl(duplicate_handle, F_SETFD, flags); - } - // No need to dup the handle - we don't pass it anywhere else so - // it cannot be closed. - handle->fd = duplicate_handle; - handle->auto_close = true; -#endif - - return true; -} - -bool NaClProcessHost::LaunchSelLdr(ResourceMessageFilter* renderer_msg_filter, - const int descriptor, - const nacl::Handle handle) { - if (!CreateChannel()) - return false; - - // Build command line for nacl. - const CommandLine& browser_command_line = *CommandLine::ForCurrentProcess(); - std::wstring exe_path = - browser_command_line.GetSwitchValue(switches::kBrowserSubprocessPath); - if (exe_path.empty() && !PathService::Get(base::FILE_EXE, &exe_path)) - return false; - - CommandLine cmd_line(exe_path); - if (logging::DialogsAreSuppressed()) - cmd_line.AppendSwitch(switches::kNoErrorDialogs); - - // propagate the following switches to the plugin command line (along with - // any associated values) if present in the browser command line - // TODO(gregoryd): check which flags of those below can be supported. - static const wchar_t* const switch_names[] = { - switches::kNoSandbox, - switches::kTestSandbox, - switches::kDisableBreakpad, - switches::kFullMemoryCrashReport, - switches::kEnableLogging, - switches::kDisableLogging, - switches::kLoggingLevel, - switches::kEnableDCHECK, - switches::kSilentDumpOnDCHECK, - switches::kMemoryProfiling, - }; - - for (size_t i = 0; i < arraysize(switch_names); ++i) { - if (browser_command_line.HasSwitch(switch_names[i])) { - cmd_line.AppendSwitchWithValue( - switch_names[i], - browser_command_line.GetSwitchValue(switch_names[i])); - } - } - - cmd_line.AppendSwitchWithValue(switches::kProcessType, - switches::kNaClProcess); - - cmd_line.AppendSwitchWithValue(switches::kProcessChannelID, - ASCIIToWide(channel_id())); - - base::ProcessHandle process = 0; -#if defined(OS_WIN) - process = sandbox::StartProcess(&cmd_line); -#else - base::file_handle_mapping_vector fds_to_map; - const int ipcfd = channel().GetClientFileDescriptor(); - if (ipcfd > -1) - fds_to_map.push_back(std::pair<int, int>( - ipcfd, kPrimaryIPCChannel + base::GlobalDescriptors::kBaseDescriptor)); - base::LaunchApp(cmd_line.argv(), fds_to_map, false, &process); -#endif - - if (!process) - return false; - SetHandle(process); - - // send a message with duplicated handle to sel_ldr - return SendStartMessage(process, descriptor, handle); -} - -bool NaClProcessHost::SendStartMessage(base::ProcessHandle process, - int descriptor, - nacl::Handle handle) { - nacl::FileDescriptor channel; -#if defined(OS_WIN) - if (!DuplicateHandle(GetCurrentProcess(), - reinterpret_cast<HANDLE>(handle), - process, - reinterpret_cast<HANDLE*>(&channel), - GENERIC_READ | GENERIC_WRITE, - FALSE, DUPLICATE_CLOSE_SOURCE)) { - return false; - } -#else - channel.fd = dup(handle); - channel.auto_close = true; -#endif - NaClProcessMsg_StartSelLdr* msg = new NaClProcessMsg_StartSelLdr( - descriptor, channel); - - if (!Send(msg)) { - return false; - } - return true; -} - -void NaClProcessHost::OnMessageReceived(const IPC::Message& msg) { - NOTREACHED() << "Invalid message with type = " << msg.type(); -} - -URLRequestContext* NaClProcessHost::GetRequestContext( - uint32 request_id, - const ViewHostMsg_Resource_Request& request_data) { - return NULL; -} - diff --git a/chrome/browser/nacl_process_host.h b/chrome/browser/nacl_process_host.h deleted file mode 100644 index 59de526..0000000 --- a/chrome/browser/nacl_process_host.h +++ /dev/null @@ -1,55 +0,0 @@ -// Copyright (c) 2009 The Chromium Authors. All rights reserved. -// Use of this source code is governed by a BSD-style license that can be -// found in the LICENSE file. - -#ifndef CHROME_BROWSER_NACL_PROCESS_HOST_H_ -#define CHROME_BROWSER_NACL_PROCESS_HOST_H_ - -#include "build/build_config.h" -#include "chrome/common/child_process_host.h" -#include "chrome/common/nacl_types.h" -#include "native_client/src/shared/imc/nacl_imc.h" - -class ResourceMessageFilter; - -// Represents the browser side of the browser <--> NaCl communication -// channel. There will be one NaClProcessHost per NaCl process -// The browser is responsible for starting the NaCl process -// when requested by the renderer. -// After that, most of the communication is directly between NaCl plugin -// running in the renderer and NaCl processes. -class NaClProcessHost : public ChildProcessHost { - public: - explicit NaClProcessHost(ResourceDispatcherHost *resource_dispatcher_host); - ~NaClProcessHost() {} - - // Initialize the new NaCl process, returning true on success. - bool Launch(ResourceMessageFilter* renderer_msg_filter, - const int descriptor, - nacl::FileDescriptor *handle); - - virtual void OnMessageReceived(const IPC::Message& msg); - - private: - bool LaunchSelLdr(ResourceMessageFilter* renderer_msg_filter, - const int descriptor, - const nacl::Handle handle); - - bool SendStartMessage(base::ProcessHandle process, - int descriptor, - nacl::Handle handle); - - // ResourceDispatcherHost::Receiver implementation: - virtual URLRequestContext* GetRequestContext( - uint32 request_id, - const ViewHostMsg_Resource_Request& request_data); - - virtual bool CanShutdown() { return true; } - - private: - ResourceDispatcherHost* resource_dispatcher_host_; - - DISALLOW_COPY_AND_ASSIGN(NaClProcessHost); -}; - -#endif // CHROME_BROWSER_NACL_PROCESS_HOST_H_ diff --git a/chrome/browser/plugin_service.cc b/chrome/browser/plugin_service.cc index ab5ece1..1d767bd 100644 --- a/chrome/browser/plugin_service.cc +++ b/chrome/browser/plugin_service.cc @@ -23,7 +23,6 @@ #include "chrome/common/notification_type.h" #include "chrome/common/notification_service.h" #include "chrome/common/render_messages.h" -#include "native_client/src/trusted/plugin/nacl_entry_points.h" #include "webkit/glue/plugins/plugin_constants_win.h" #include "webkit/glue/plugins/plugin_list.h" @@ -45,15 +44,6 @@ PluginService::PluginService() NPAPI::PluginList::Singleton()->AddExtraPluginPath( FilePath::FromWStringHack(path)); } - if (command_line->HasSwitch(switches::kInternalNaCl)) { - NPAPI::PluginEntryPoints entry_points = { -#if !defined(OS_LINUX) - NaCl_NP_GetEntryPoints, -#endif - NaCl_NP_Initialize, - NaCl_NP_Shutdown}; - NPAPI::PluginList::UseInternalNaCl(&entry_points); - } #if defined(OS_WIN) hkcu_key_.Create( diff --git a/chrome/browser/renderer_host/browser_render_process_host.cc b/chrome/browser/renderer_host/browser_render_process_host.cc index e9fbe92..b757e46 100644 --- a/chrome/browser/renderer_host/browser_render_process_host.cc +++ b/chrome/browser/renderer_host/browser_render_process_host.cc @@ -342,7 +342,6 @@ bool BrowserRenderProcessHost::Init() { switches::kDisableAudio, switches::kSimpleDataSource, switches::kEnableBenchmarking, - switches::kInternalNaCl, switches::kEnableDatabases, }; diff --git a/chrome/browser/renderer_host/resource_message_filter.cc b/chrome/browser/renderer_host/resource_message_filter.cc index 7aa1d50..781543e 100644 --- a/chrome/browser/renderer_host/resource_message_filter.cc +++ b/chrome/browser/renderer_host/resource_message_filter.cc @@ -26,7 +26,6 @@ #include "chrome/browser/renderer_host/database_dispatcher_host.h" #include "chrome/browser/renderer_host/file_system_accessor.h" #include "chrome/browser/renderer_host/render_widget_helper.h" -#include "chrome/browser/nacl_process_host.h" #include "chrome/browser/spellchecker.h" #include "chrome/browser/spellchecker_platform_engine.h" #include "chrome/browser/worker_host/message_port_dispatcher.h" @@ -291,7 +290,6 @@ bool ResourceMessageFilter::OnMessageReceived(const IPC::Message& msg) { OnReceiveContextMenuMsg(msg)) IPC_MESSAGE_HANDLER_DELAY_REPLY(ViewHostMsg_OpenChannelToPlugin, OnOpenChannelToPlugin) - IPC_MESSAGE_HANDLER(ViewHostMsg_LaunchNaCl, OnLaunchNaCl) IPC_MESSAGE_HANDLER(ViewHostMsg_CreateDedicatedWorker, OnCreateDedicatedWorker) IPC_MESSAGE_HANDLER(ViewHostMsg_CancelCreateDedicatedWorker, @@ -582,12 +580,6 @@ void ResourceMessageFilter::OnOpenChannelToPlugin(const GURL& url, this, url, mime_type, locale, reply_msg); } -void ResourceMessageFilter::OnLaunchNaCl(const int channel_descriptor, - nacl::FileDescriptor* handle) { - NaClProcessHost* nacl_host = new NaClProcessHost(resource_dispatcher_host_); - nacl_host->Launch(this, channel_descriptor, handle); -} - void ResourceMessageFilter::OnCreateDedicatedWorker(const GURL& url, int render_view_route_id, int* route_id) { diff --git a/chrome/browser/renderer_host/resource_message_filter.h b/chrome/browser/renderer_host/resource_message_filter.h index 933a153..00c3b13 100644 --- a/chrome/browser/renderer_host/resource_message_filter.h +++ b/chrome/browser/renderer_host/resource_message_filter.h @@ -25,7 +25,6 @@ #include "chrome/browser/renderer_host/render_widget_helper.h" #include "chrome/browser/renderer_host/resource_dispatcher_host.h" #include "chrome/common/modal_dialog_event.h" -#include "chrome/common/nacl_types.h" #include "chrome/common/notification_registrar.h" #include "chrome/common/transport_dib.h" #include "ipc/ipc_channel_proxy.h" @@ -155,8 +154,6 @@ class ResourceMessageFilter : public IPC::ChannelProxy::MessageFilter, const std::string& mime_type, const std::wstring& locale, IPC::Message* reply_msg); - void OnLaunchNaCl(const int channel_descriptor, - nacl::FileDescriptor* handle); void OnCreateDedicatedWorker(const GURL& url, int render_view_route_id, int* route_id); diff --git a/chrome/browser/sandbox_policy.cc b/chrome/browser/sandbox_policy.cc index 59688b4..13f4ee2 100644 --- a/chrome/browser/sandbox_policy.cc +++ b/chrome/browser/sandbox_policy.cc @@ -359,8 +359,6 @@ base::ProcessHandle StartProcessWithAccess(CommandLine* cmd_line, type = ChildProcessInfo::PLUGIN_PROCESS; } else if (type_str == switches::kWorkerProcess) { type = ChildProcessInfo::WORKER_PROCESS; - } else if (type_str == switches::kNaClProcess) { - type = ChildProcessInfo::NACL_PROCESS; } else if (type_str == switches::kUtilityProcess) { type = ChildProcessInfo::UTILITY_PROCESS; } else { @@ -396,8 +394,6 @@ base::ProcessHandle StartProcessWithAccess(CommandLine* cmd_line, sandbox::TargetPolicy* policy = broker_service->CreatePolicy(); bool on_sandbox_desktop = false; - // TODO(gregoryd): try locked-down policy for sel_ldr after we fix IMC. - // TODO(gregoryd): do we need a new desktop for sel_ldr? if (type == ChildProcessInfo::PLUGIN_PROCESS) { if (!AddPolicyForPlugin(cmd_line, policy)) return 0; diff --git a/chrome/chrome.gyp b/chrome/chrome.gyp index 3b5003f..99dbc97 100644 --- a/chrome/chrome.gyp +++ b/chrome/chrome.gyp @@ -104,26 +104,7 @@ '../views/grid_layout_unittest.cc', ], 'conditions': [ - ['OS=="win"', { - 'nacl_defines': [ - 'NACL_WINDOWS=1', - 'NACL_LINUX=0', - 'NACL_OSX=0', - ], - },], - ['OS=="linux"', { - 'nacl_defines': [ - 'NACL_WINDOWS=0', - 'NACL_LINUX=1', - 'NACL_OSX=0', - ], - },], ['OS=="mac"', { - 'nacl_defines': [ - 'NACL_WINDOWS=0', - 'NACL_LINUX=0', - 'NACL_OSX=1', - ], 'conditions': [ ['branding=="Chrome"', { 'mac_bundle_id': 'com.google.Chrome', @@ -580,8 +561,6 @@ 'common/sandbox_init_wrapper.h', 'common/security_filter_peer.cc', 'common/security_filter_peer.h', - 'common/nacl_messages.h', - 'common/nacl_messages_internal.h', 'common/sqlite_compiled_statement.cc', 'common/sqlite_compiled_statement.h', 'common/sqlite_utils.cc', @@ -694,9 +673,6 @@ '..', '<(INTERMEDIATE_DIR)', ], - 'defines': [ - '<@(nacl_defines)', - ], 'sources': [ # All .cc, .h, .m, and .mm files under browser except for tests and # mocks. @@ -1805,8 +1781,6 @@ 'browser/search_engines/template_url_prepopulate_data.h', 'browser/search_engines/template_url_table_model.cc', 'browser/search_engines/template_url_table_model.h', - 'browser/nacl_process_host.cc', - 'browser/nacl_process_host.h', 'browser/session_startup_pref.cc', 'browser/session_startup_pref.h', 'browser/sessions/base_session_service.cc', @@ -2845,60 +2819,11 @@ ], }, { - 'target_name': 'nacl', - 'type': '<(library)', - 'msvs_guid': '83E86DAF-5763-4711-AD34-5FDAE395560C', - 'dependencies': [ - 'common', - 'chrome_resources', - 'chrome_strings', - '../third_party/npapi/npapi.gyp:npapi', - '../webkit/webkit.gyp:glue', - '../native_client/src/trusted/plugin/plugin_chrome.gyp:npGoogleNaClPluginChrome', - '../native_client/src/trusted/service_runtime/service_runtime.gyp:sel', - '../native_client/src/trusted/validator_x86/validator_x86.gyp:ncvalidate', - '../native_client/src/trusted/platform_qualify/platform_qualify.gyp:platform_qual_lib', - ], - 'include_dirs': [ - '<(INTERMEDIATE_DIR)', - ], - 'defines': [ - 'NACL_BLOCK_SHIFT=5', - 'NACL_BLOCK_SIZE=32', - # TODO(gregoryd): consider getting this from NaCl's common.gypi - 'NACL_TARGET_SUBARCH=32', - 'NACL_BUILD_SUBARCH=32', - '<@(nacl_defines)', - ], - 'sources': [ - # All .cc, .h, .m, and .mm files under nacl except for tests and - # mocks. - 'nacl/sel_main.cc', - 'nacl/nacl_main.cc', - 'nacl/nacl_thread.cc', - 'nacl/nacl_thread.h', - ], - # TODO(gregoryd): consider switching NaCl to use Chrome OS defines - 'conditions': [ - ['OS=="win"', { - 'defines': [ - '__STD_C', - '_CRT_SECURE_NO_DEPRECATE', - '_SCL_SECURE_NO_DEPRECATE', - ], - 'include_dirs': [ - 'third_party/wtl/include', - ], - },], - ], - }, - { 'target_name': 'renderer', 'type': '<(library)', 'msvs_guid': '9301A569-5D2B-4D11-9332-B1E30AEACB8D', 'dependencies': [ 'common', - 'nacl', 'plugin', 'chrome_resources', 'chrome_strings', @@ -3387,8 +3312,6 @@ 'infoplist_strings_tool', # Bring in pdfsqueeze and run it on all pdfs '../build/temp_gyp/pdfsqueeze.gyp:pdfsqueeze', - # This library provides the real implementation for NaClSyscallSeg - '../native_client/src/trusted/service_runtime/arch/x86_32/service_runtime_x86_32.gyp:service_runtime_x86_32_chrome' ], 'rules': [ { diff --git a/chrome/common/child_process_info.h b/chrome/common/child_process_info.h index 9d2d610..fa03c0f 100644 --- a/chrome/common/child_process_info.h +++ b/chrome/common/child_process_info.h @@ -17,7 +17,6 @@ class ChildProcessInfo { RENDER_PROCESS, PLUGIN_PROCESS, WORKER_PROCESS, - NACL_PROCESS, UTILITY_PROCESS, ZYGOTE_PROCESS, SANDBOX_HELPER_PROCESS, diff --git a/chrome/common/chrome_switches.cc b/chrome/common/chrome_switches.cc index 7ab37eb..978c7c6 100644 --- a/chrome/common/chrome_switches.cc +++ b/chrome/common/chrome_switches.cc @@ -71,9 +71,6 @@ const wchar_t kPluginProcess[] = L"plugin"; // Causes the process to run as a worker subprocess. const wchar_t kWorkerProcess[] = L"worker"; -// Causes the process to run as a NativeClient's sel_ldr subprocess. -const wchar_t kNaClProcess[] = L"nacl"; - // Causes the process to run as a utility subprocess. const wchar_t kUtilityProcess[] = L"utility"; @@ -370,9 +367,6 @@ const wchar_t kEnableRemoteFonts[] = L"enable-remote-fonts"; // Use the low fragmentation heap for the CRT. const wchar_t kUseLowFragHeapCrt[] = L"use-lf-heap"; -// Runs the Native Client inside the renderer process. -const wchar_t kInternalNaCl[] = L"internal-nacl"; - #ifndef NDEBUG // Debug only switch to specify which gears plugin dll to load. const wchar_t kGearsPluginPathOverride[] = L"gears-plugin-path"; diff --git a/chrome/common/chrome_switches.h b/chrome/common/chrome_switches.h index 6812b7f..733d706 100644 --- a/chrome/common/chrome_switches.h +++ b/chrome/common/chrome_switches.h @@ -30,7 +30,6 @@ extern const wchar_t kZygoteProcess[]; extern const wchar_t kBrowserSubprocessPath[]; extern const wchar_t kPluginProcess[]; extern const wchar_t kWorkerProcess[]; -extern const wchar_t kNaClProcess[]; extern const wchar_t kUtilityProcess[]; extern const wchar_t kProfileImportProcess[]; extern const wchar_t kSingleProcess[]; @@ -134,8 +133,6 @@ extern const wchar_t kEnableRemoteFonts[]; extern const wchar_t kUseLowFragHeapCrt[]; -extern const wchar_t kInternalNaCl[]; - #ifndef NDEBUG extern const wchar_t kGearsPluginPathOverride[]; #endif diff --git a/chrome/common/nacl_messages.h b/chrome/common/nacl_messages.h deleted file mode 100644 index 8d360dd..0000000 --- a/chrome/common/nacl_messages.h +++ /dev/null @@ -1,19 +0,0 @@ -// Copyright (c) 2009 The Chromium Authors. All rights reserved. -// Use of this source code is governed by a BSD-style license that can be -// found in the LICENSE file. - -// Defines messages between the browser and NaCl process. - -#ifndef CHROME_COMMON_NACL_MESSAGES_H_ -#define CHROME_COMMON_NACL_MESSAGES_H_ - -#include <string> - -#include "base/basictypes.h" -#include "ipc/ipc_message_utils.h" - -#define MESSAGES_INTERNAL_FILE "chrome/common/nacl_messages_internal.h" -#include "ipc/ipc_message_macros.h" - -#endif // CHROME_COMMON_NACL_MESSAGES_H_ - diff --git a/chrome/common/nacl_messages_internal.h b/chrome/common/nacl_messages_internal.h deleted file mode 100644 index 1e43493..0000000 --- a/chrome/common/nacl_messages_internal.h +++ /dev/null @@ -1,18 +0,0 @@ -// Copyright (c) 2006-2009 The Chromium Authors. All rights reserved. -// Use of this source code is governed by a BSD-style license that can be -// found in the LICENSE file. - -#include "ipc/ipc_message_macros.h" -#include "chrome/common/nacl_types.h" - -//----------------------------------------------------------------------------- -// NaClProcess messages -// These are messages sent from the browser to the NaCl process. -IPC_BEGIN_MESSAGES(NaClProcess) - // Tells the NaCl process to start. - IPC_MESSAGE_CONTROL2(NaClProcessMsg_StartSelLdr, - int /* descriptor id */, - nacl::FileDescriptor /* handle value */) - -IPC_END_MESSAGES(NaClProcess) - diff --git a/chrome/common/nacl_types.h b/chrome/common/nacl_types.h deleted file mode 100644 index 5c6072a..0000000 --- a/chrome/common/nacl_types.h +++ /dev/null @@ -1,19 +0,0 @@ -// Copyright (c) 2009 The Chromium Authors. All rights reserved. -// Use of this source code is governed by a BSD-style license that can be -// found in the LICENSE file. - -// Handle passing definitions for NaCl -#ifndef CHROME_COMMON_NACL_TYPES_H_ -#define CHROME_COMMON_NACL_TYPES_H_ - -namespace nacl { -#if defined(OS_WIN) -typedef HANDLE FileDescriptor; -#define NATIVE_HANDLE(desc) (static_cast<HANDLE>(desc)) -#elif defined(OS_POSIX) -typedef base::FileDescriptor FileDescriptor; -#define NATIVE_HANDLE(desc) ((desc).fd) -#endif -} - -#endif // CHROME_COMMON_NACL_TYPES_H_ diff --git a/chrome/common/render_messages_internal.h b/chrome/common/render_messages_internal.h index 50bdf85..2916c17 100644 --- a/chrome/common/render_messages_internal.h +++ b/chrome/common/render_messages_internal.h @@ -21,7 +21,6 @@ #include "base/values.h" #include "chrome/common/css_colors.h" #include "chrome/common/extensions/update_manifest.h" -#include "chrome/common/nacl_types.h" #include "chrome/common/transport_dib.h" #include "chrome/common/view_types.h" #include "ipc/ipc_channel_handle.h" @@ -1066,14 +1065,6 @@ IPC_BEGIN_MESSAGES(ViewHost) IPC::ChannelHandle /* handle to channel */, WebPluginInfo /* info */) - // A renderer sends this to the browser process when it wants to start - // a new instance of the Native Client process. The browser will launch - // the process and return a handle to an IMC channel. - IPC_SYNC_MESSAGE_CONTROL1_1(ViewHostMsg_LaunchNaCl, - int /* channel number, usually 5 */, - nacl::FileDescriptor /* handle - one side - of a socket pair */) - #if defined(OS_LINUX) // A renderer sends this when it needs a browser-side widget for // hosting a windowed plugin. id is the XID of the plugin window, for which diff --git a/chrome/common/sandbox_init_wrapper.cc b/chrome/common/sandbox_init_wrapper.cc index 14006ed..c296ff8 100644 --- a/chrome/common/sandbox_init_wrapper.cc +++ b/chrome/common/sandbox_init_wrapper.cc @@ -27,7 +27,6 @@ void SandboxInitWrapper::InitializeSandbox(const CommandLine& command_line, if (!command_line.HasSwitch(switches::kNoSandbox)) { if ((process_type == switches::kRendererProcess) || (process_type == switches::kWorkerProcess) || - (process_type == switches::kNaClProcess) || (process_type == switches::kUtilityProcess) || (process_type == switches::kPluginProcess && command_line.HasSwitch(switches::kSafePlugins))) { diff --git a/chrome/nacl/nacl_main.cc b/chrome/nacl/nacl_main.cc deleted file mode 100644 index 2d583b1..0000000 --- a/chrome/nacl/nacl_main.cc +++ /dev/null @@ -1,75 +0,0 @@ -// Copyright (c) 2006-2009 The Chromium Authors. All rights reserved. -// Use of this source code is governed by a BSD-style license that can be -// found in the LICENSE file. - -#include "build/build_config.h" - -#if defined(OS_WIN) -#include "app/win_util.h" -#endif -#include "base/command_line.h" -#include "base/message_loop.h" -#include "base/string_util.h" -#include "base/system_monitor.h" -#include "chrome/common/child_process.h" -#include "chrome/common/chrome_constants.h" -#include "chrome/common/chrome_switches.h" -#include "chrome/common/logging_chrome.h" -#include "chrome/common/main_function_params.h" -#include "chrome/nacl/nacl_thread.h" - -#if defined(OS_WIN) -#include "chrome/test/injection_test_dll.h" -#include "sandbox/src/sandbox.h" -#endif - -// main() routine for running as the sel_ldr process. -int NaClMain(const MainFunctionParams& parameters) { - // The main thread of the plugin services IO. - MessageLoopForIO main_message_loop; - std::wstring app_name = chrome::kBrowserAppName; - PlatformThread::SetName(WideToASCII(app_name + L"_NaClMain").c_str()); - - // Initialize the SystemMonitor - base::SystemMonitor::Start(); - -#if defined(OS_WIN) - const CommandLine& parsed_command_line = parameters.command_line_; - - sandbox::TargetServices* target_services = - parameters.sandbox_info_.TargetServices(); - - DLOG(INFO) << "Started plugin with " << - parsed_command_line.command_line_string(); - - HMODULE sandbox_test_module = NULL; - bool no_sandbox = parsed_command_line.HasSwitch(switches::kNoSandbox); - if (target_services && !no_sandbox) { - // The command line might specify a test plugin to load. - if (parsed_command_line.HasSwitch(switches::kTestSandbox)) { - std::wstring test_plugin_name = - parsed_command_line.GetSwitchValue(switches::kTestSandbox); - sandbox_test_module = LoadLibrary(test_plugin_name.c_str()); - DCHECK(sandbox_test_module); - } - } - -#else - NOTIMPLEMENTED() << " non-windows startup, plugin startup dialog etc."; -#endif - - { - ChildProcess nacl_process; - nacl_process.set_main_thread(new NaClThread()); -#if defined(OS_WIN) - if (!no_sandbox && target_services) - target_services->LowerToken(); -#endif - - MessageLoop::current()->Run(); - } - - return 0; -} - - diff --git a/chrome/nacl/nacl_thread.cc b/chrome/nacl/nacl_thread.cc deleted file mode 100644 index 0b669f0..0000000 --- a/chrome/nacl/nacl_thread.cc +++ /dev/null @@ -1,33 +0,0 @@ -// Copyright (c) 2006-2009 The Chromium Authors. All rights reserved. -// Use of this source code is governed by a BSD-style license that can be -// found in the LICENSE file. - -#include "chrome/nacl/nacl_thread.h" - -#include "build/build_config.h" -#include "chrome/common/notification_service.h" -#include "chrome/common/nacl_messages.h" -#include "native_client/src/trusted/service_runtime/include/sys/nacl_imc_api.h" - -int SelMain(const int desc, const NaClHandle handle); - -NaClThread::NaClThread() { -} - -NaClThread::~NaClThread() { -} - -NaClThread* NaClThread::current() { - return static_cast<NaClThread*>(ChildThread::current()); -} - -void NaClThread::OnControlMessageReceived(const IPC::Message& msg) { - IPC_BEGIN_MESSAGE_MAP(NaClThread, msg) - IPC_MESSAGE_HANDLER(NaClProcessMsg_StartSelLdr, OnStartSelLdr) - IPC_END_MESSAGE_MAP() -} - -void NaClThread::OnStartSelLdr(const int channel_descriptor, - const nacl::FileDescriptor handle) { - SelMain(channel_descriptor, NATIVE_HANDLE(handle)); -} diff --git a/chrome/nacl/nacl_thread.h b/chrome/nacl/nacl_thread.h deleted file mode 100644 index a69ce3a..0000000 --- a/chrome/nacl/nacl_thread.h +++ /dev/null @@ -1,35 +0,0 @@ -// Copyright (c) 2006-2009 The Chromium Authors. All rights reserved. -// Use of this source code is governed by a BSD-style license that can be -// found in the LICENSE file. - -#ifndef CHROME_NACL_NACL_THREAD_H_ -#define CHROME_NACL_NACL_THREAD_H_ - -#include "base/file_path.h" -#include "base/native_library.h" -#include "chrome/common/child_thread.h" -#include "chrome/common/nacl_types.h" - -class NotificationService; - -// The NaClThread class represents a background thread where NaCl app gets -// started. -class NaClThread : public ChildThread { - public: - NaClThread(); - ~NaClThread(); - // Returns the one NaCl thread. - static NaClThread* current(); - - private: - virtual void OnControlMessageReceived(const IPC::Message& msg); - void OnStartSelLdr(const int channel_descriptor, - const nacl::FileDescriptor handle); - // TODO(gregoryd): do we need to override Cleanup as in PluginThread? - - scoped_ptr<NotificationService> notification_service_; - - DISALLOW_EVIL_CONSTRUCTORS(NaClThread); -}; - -#endif // CHROME_NACL_NACL_THREAD_H_ diff --git a/chrome/nacl/sel_main.cc b/chrome/nacl/sel_main.cc deleted file mode 100644 index 7174706..0000000 --- a/chrome/nacl/sel_main.cc +++ /dev/null @@ -1,210 +0,0 @@ -// Copyright (c) 2006-2009 The Chromium Authors. All rights reserved. -// Use of this source code is governed by a BSD-style license that can be -// found in the LICENSE file. - -#include "build/build_config.h" - -#include "native_client/src/include/portability.h" - -#if NACL_OSX -#include <crt_externs.h> -#endif - -EXTERN_C_BEGIN -#include "native_client/src/shared/platform/nacl_sync.h" -#include "native_client/src/shared/platform/nacl_sync_checked.h" -#include "native_client/src/trusted/service_runtime/nacl_globals.h" -#include "native_client/src/trusted/service_runtime/expiration.h" -#include "native_client/src/trusted/service_runtime/nacl_app.h" -#include "native_client/src/trusted/service_runtime/nacl_all_modules.h" -#include "native_client/src/trusted/service_runtime/sel_ldr.h" -#include "native_client/src/trusted/platform_qualify/nacl_os_qualify.h" -EXTERN_C_END - -int verbosity = 0; - -#ifdef __GNUC__ - -/* - * GDB's canonical overlay managment routine. - * We need its symbol in the symbol table so don't inline it. - * TODO(dje): add some explanation for the non-GDB person. - */ - -static void __attribute__ ((noinline)) _ovly_debug_event (void) { - /* - * The asm volatile is here as instructed by the GCC docs. - * It's not enough to declare a function noinline. - * GCC will still look inside the function to see if it's worth calling. - */ - asm volatile (""); -} - -#endif - -static void StopForDebuggerInit (const struct NaClApp *state) { - /* Put xlate_base in a place where gdb can find it. */ - nacl_global_xlate_base = state->xlate_base; - -#ifdef __GNUC__ - _ovly_debug_event (); -#endif -} - -int SelMain(const int desc, const NaClHandle handle) { - char *av[1]; - int ac = 1; - - char **envp; - struct NaClApp state; - char *nacl_file = 0; - int main_thread_only = 1; - int export_addr_to = -2; - - struct NaClApp *nap; - - NaClErrorCode errcode; - - int ret_code = 1; -#if NACL_OSX - // Mac dynamic libraries cannot access the environ variable directly. - envp = *_NSGetEnviron(); -#else - extern char **environ; - envp = environ; -#endif - - - if (NaClHasExpired()) { - // TODO(gregoryd): report error to browser? - fprintf(stderr, "This version of Native Client has expired.\n"); - fprintf(stderr, "Please visit: http://code.google.com/p/nativeclient/\n"); - exit(-1); - } - - NaClAllModulesInit(); - - /* used to be -P */ - NaClSrpcFileDescriptor = desc; - /* used to be -X */ - export_addr_to = desc; - - /* to be passed to NaClMain, eventually... */ - av[0] = const_cast<char*>("NaClMain"); - - if (!NaClAppCtor(&state)) { - fprintf(stderr, "Error while constructing app state\n"); - goto done_file_dtor; - } - - state.restrict_to_main_thread = main_thread_only; - - nap = &state; - errcode = LOAD_OK; - - /* import IMC handle - used to be "-i" */ - NaClAddImcHandle(nap, handle, desc); - - /* - * in order to report load error to the browser plugin through the - * secure command channel, we do not immediate jump to cleanup code - * on error. rather, we continue processing (assuming earlier - * errors do not make it inappropriate) until the secure command - * channel is set up, and then bail out. - */ - - /* - * Ensure this operating system platform is supported. - */ - if (!NaClOsIsSupported()) { - errcode = LOAD_UNSUPPORTED_OS_PLATFORM; - nap->module_load_status = errcode; - fprintf(stderr, "Error while loading \"%s\": %s\n", - nacl_file, - NaClErrorString(errcode)); - } - - /* Give debuggers a well known point at which xlate_base is known. */ - StopForDebuggerInit(&state); - - /* - * If export_addr_to is set to a non-negative integer, we create a - * bound socket and socket address pair and bind the former to - * descriptor 3 and the latter to descriptor 4. The socket address - * is written out to the export_addr_to descriptor. - * - * The service runtime also accepts a connection on the bound socket - * and spawns a secure command channel thread to service it. - * - * If export_addr_to is -1, we only create the bound socket and - * socket address pair, and we do not export to an IMC socket. This - * use case is typically only used in testing, where we only "dump" - * the socket address to stdout or similar channel. - */ - if (-2 < export_addr_to) { - NaClCreateServiceSocket(nap); - if (0 <= export_addr_to) { - NaClSendServiceAddressTo(nap, export_addr_to); - /* - * NB: spawns a thread that uses the command channel. we do - * this after NaClAppLoadFile so that NaClApp object is more - * fully populated. Hereafter any changes to nap should be done - * while holding locks. - */ - NaClSecureCommandChannel(nap); - } - } - - NaClXMutexLock(&nap->mu); - nap->module_load_status = LOAD_OK; - NaClXCondVarBroadcast(&nap->cv); - NaClXMutexUnlock(&nap->mu); - - if (NULL != nap->secure_channel) { - /* - * wait for start_module RPC call on secure channel thread. - */ - NaClWaitForModuleStartStatusCall(nap); - } - - /* - * error reporting done; can quit now if there was an error earlier. - */ - if (LOAD_OK != errcode) { - goto done; - } - - /* - * only nap->ehdrs.e_entry is usable, no symbol table is - * available. - */ - if (!NaClCreateMainThread(nap, - ac, - av, - envp)) { - fprintf(stderr, "creating main thread failed\n"); - goto done; - } - - ret_code = NaClWaitForMainThreadToExit(nap); - - /* - * exit_group or equiv kills any still running threads while module - * addr space is still valid. otherwise we'd have to kill threads - * before we clean up the address space. - */ - return ret_code; - - done: - fflush(stdout); - - NaClAppDtor(&state); - - done_file_dtor: - fflush(stdout); - - NaClAllModulesFini(); - - return ret_code; -} - diff --git a/chrome/renderer/render_process.cc b/chrome/renderer/render_process.cc index 6968d93..610e5d3 100644 --- a/chrome/renderer/render_process.cc +++ b/chrome/renderer/render_process.cc @@ -30,9 +30,7 @@ #include "ipc/ipc_channel.h" #include "ipc/ipc_message_utils.h" #include "media/base/media.h" -#include "native_client/src/trusted/plugin/nacl_entry_points.h" #include "webkit/glue/webkit_glue.h" -#include "webkit/glue/plugins/plugin_list.h" //----------------------------------------------------------------------------- @@ -82,16 +80,6 @@ RenderProcess::RenderProcess() StatisticsRecorder::set_dump_on_exit(true); } - if (command_line.HasSwitch(switches::kInternalNaCl)) { - NPAPI::PluginEntryPoints entry_points = { -#if !defined(OS_LINUX) - NaCl_NP_GetEntryPoints, -#endif - NaCl_NP_Initialize, - NaCl_NP_Shutdown}; - NPAPI::PluginList::UseInternalNaCl(&entry_points); - } - FilePath module_path; initialized_media_library_ = PathService::Get(base::DIR_MODULE, &module_path) && diff --git a/chrome/renderer/render_view.cc b/chrome/renderer/render_view.cc index bf59158..4a2335c 100644 --- a/chrome/renderer/render_view.cc +++ b/chrome/renderer/render_view.cc @@ -2281,13 +2281,7 @@ webkit_glue::WebPluginDelegate* RenderView::CreatePluginDelegate( else mime_type_to_use = &mime_type; - bool in_process_plugin = RenderProcess::current()->in_process_plugins(); - if (CommandLine::ForCurrentProcess()->HasSwitch(switches::kInternalNaCl)) { - if (mime_type == "application/x-nacl-srpc") { - in_process_plugin = true; - } - } - if (in_process_plugin) { + if (RenderProcess::current()->in_process_plugins()) { #if defined(OS_WIN) // In-proc plugins aren't supported on Linux or Mac. return WebPluginDelegateImpl::Create( path, *mime_type_to_use, gfx::NativeViewFromId(host_window_)); |