Chromium Code Reviews| OLD | NEW |
|---|---|
| 1 // Copyright (c) 2012 The Chromium Authors. All rights reserved. | 1 // Copyright (c) 2012 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 #ifndef COMPONENTS_NACL_BROWSER_NACL_PROCESS_HOST_H_ | 5 #ifndef COMPONENTS_NACL_BROWSER_NACL_PROCESS_HOST_H_ |
| 6 #define COMPONENTS_NACL_BROWSER_NACL_PROCESS_HOST_H_ | 6 #define COMPONENTS_NACL_BROWSER_NACL_PROCESS_HOST_H_ |
| 7 | 7 |
| 8 #include "build/build_config.h" | 8 #include "build/build_config.h" |
| 9 | 9 |
| 10 #include <string> | |
| 11 #include <utility> | |
| 12 #include <vector> | |
| 13 | |
| 10 #include "base/files/file.h" | 14 #include "base/files/file.h" |
| 11 #include "base/files/file_path.h" | 15 #include "base/files/file_path.h" |
| 12 #include "base/files/file_util_proxy.h" | 16 #include "base/files/file_util_proxy.h" |
| 13 #include "base/memory/ref_counted.h" | 17 #include "base/memory/ref_counted.h" |
| 14 #include "base/memory/shared_memory.h" | 18 #include "base/memory/shared_memory.h" |
| 15 #include "base/memory/weak_ptr.h" | 19 #include "base/memory/weak_ptr.h" |
| 16 #include "base/message_loop/message_loop.h" | 20 #include "base/message_loop/message_loop.h" |
| 17 #include "base/process/process.h" | 21 #include "base/process/process.h" |
| 18 #include "components/nacl/common/nacl_types.h" | 22 #include "components/nacl/common/nacl_types.h" |
| 19 #include "content/public/browser/browser_child_process_host_delegate.h" | 23 #include "content/public/browser/browser_child_process_host_delegate.h" |
| (...skipping 11 matching lines...) Expand all Loading... | |
| 31 | 35 |
| 32 namespace IPC { | 36 namespace IPC { |
| 33 class ChannelProxy; | 37 class ChannelProxy; |
| 34 } | 38 } |
| 35 | 39 |
| 36 namespace nacl { | 40 namespace nacl { |
| 37 | 41 |
| 38 class NaClHostMessageFilter; | 42 class NaClHostMessageFilter; |
| 39 void* AllocateAddressSpaceASLR(base::ProcessHandle process, size_t size); | 43 void* AllocateAddressSpaceASLR(base::ProcessHandle process, size_t size); |
| 40 | 44 |
| 45 class ResourceFileInfo { | |
|
Mark Seaborn
2015/02/09 04:48:34
It's rather confusing that you have three Resource
Yusuke Sato
2015/02/11 05:54:20
I defined these structs to use exactly the same ty
| |
| 46 MOVE_ONLY_TYPE_FOR_CPP_03(ResourceFileInfo, RValue); | |
| 47 public: | |
| 48 ResourceFileInfo(); | |
| 49 ResourceFileInfo(base::File file, | |
| 50 const NaClFileToken& file_token, | |
| 51 const std::string& file_key); | |
| 52 ~ResourceFileInfo(); | |
| 53 | |
| 54 ResourceFileInfo(RValue other); | |
| 55 ResourceFileInfo& operator=(RValue other); | |
| 56 | |
| 57 base::File file_; | |
|
Mark Seaborn
2015/02/09 04:48:34
Nit: If these are public, they shouldn't have a "_
Yusuke Sato
2015/02/11 05:54:20
Removed the class. Done.
| |
| 58 NaClFileToken file_token_; | |
| 59 std::string file_key_; | |
| 60 }; | |
| 61 | |
| 41 // Represents the browser side of the browser <--> NaCl communication | 62 // Represents the browser side of the browser <--> NaCl communication |
| 42 // channel. There will be one NaClProcessHost per NaCl process | 63 // channel. There will be one NaClProcessHost per NaCl process |
| 43 // The browser is responsible for starting the NaCl process | 64 // The browser is responsible for starting the NaCl process |
| 44 // when requested by the renderer. | 65 // when requested by the renderer. |
| 45 // After that, most of the communication is directly between NaCl plugin | 66 // After that, most of the communication is directly between NaCl plugin |
| 46 // running in the renderer and NaCl processes. | 67 // running in the renderer and NaCl processes. |
| 47 class NaClProcessHost : public content::BrowserChildProcessHostDelegate { | 68 class NaClProcessHost : public content::BrowserChildProcessHostDelegate { |
| 48 public: | 69 public: |
| 49 // manifest_url: the URL of the manifest of the Native Client plugin being | 70 // manifest_url: the URL of the manifest of the Native Client plugin being |
| 50 // executed. | 71 // executed. |
| 51 // nexe_file: A file that corresponds to the nexe module to be loaded. | 72 // nexe_file: A file that corresponds to the nexe module to be loaded. |
| 52 // nexe_token: A cache validation token for nexe_file. | 73 // nexe_token: A cache validation token for nexe_file. |
| 53 // permissions: PPAPI permissions, to control access to private APIs. | 74 // permissions: PPAPI permissions, to control access to private APIs. |
| 54 // render_view_id: RenderView routing id, to control access to private APIs. | 75 // render_view_id: RenderView routing id, to control access to private APIs. |
| 55 // permission_bits: controls which interfaces the NaCl plugin can use. | 76 // permission_bits: controls which interfaces the NaCl plugin can use. |
| 56 // uses_nonsfi_mode: whether the program should be loaded under non-SFI mode. | 77 // uses_nonsfi_mode: whether the program should be loaded under non-SFI mode. |
| 57 // off_the_record: was the process launched from an incognito renderer? | 78 // off_the_record: was the process launched from an incognito renderer? |
| 58 // process_type: the type of NaCl process. | 79 // process_type: the type of NaCl process. |
| 59 // profile_directory: is the path of current profile directory. | 80 // profile_directory: is the path of current profile directory. |
| 60 NaClProcessHost(const GURL& manifest_url, | 81 NaClProcessHost( |
| 61 base::File nexe_file, | 82 const GURL& manifest_url, |
| 62 const NaClFileToken& nexe_token, | 83 base::File nexe_file, |
| 63 ppapi::PpapiPermissions permissions, | 84 const NaClFileToken& nexe_token, |
| 64 int render_view_id, | 85 scoped_ptr<ResourceFileInfo[]> resource_files_info, |
| 65 uint32 permission_bits, | 86 size_t resource_files_info_len, |
|
Mark Seaborn
2015/02/09 04:48:34
How about making resource_files_info a vector inst
Yusuke Sato
2015/02/11 05:54:20
It was difficult to do so for the move-only class,
| |
| 66 bool uses_nonsfi_mode, | 87 ppapi::PpapiPermissions permissions, |
| 67 bool off_the_record, | 88 int render_view_id, |
| 68 NaClAppProcessType process_type, | 89 uint32 permission_bits, |
| 69 const base::FilePath& profile_directory); | 90 bool uses_nonsfi_mode, |
| 91 bool off_the_record, | |
| 92 NaClAppProcessType process_type, | |
| 93 const base::FilePath& profile_directory); | |
| 70 ~NaClProcessHost() override; | 94 ~NaClProcessHost() override; |
| 71 | 95 |
| 72 void OnProcessCrashed(int exit_status) override; | 96 void OnProcessCrashed(int exit_status) override; |
| 73 | 97 |
| 74 // Do any minimal work that must be done at browser startup. | 98 // Do any minimal work that must be done at browser startup. |
| 75 static void EarlyStartup(); | 99 static void EarlyStartup(); |
| 76 | 100 |
| 77 // Specifies throttling time in milliseconds for PpapiHostMsg_Keepalive IPCs. | 101 // Specifies throttling time in milliseconds for PpapiHostMsg_Keepalive IPCs. |
| 78 static void SetPpapiKeepAliveThrottleForTesting(unsigned milliseconds); | 102 static void SetPpapiKeepAliveThrottleForTesting(unsigned milliseconds); |
| 79 | 103 |
| (...skipping 95 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... | |
| 175 // created. | 199 // created. |
| 176 void OnPpapiChannelsCreated( | 200 void OnPpapiChannelsCreated( |
| 177 const IPC::ChannelHandle& browser_channel_handle, | 201 const IPC::ChannelHandle& browser_channel_handle, |
| 178 const IPC::ChannelHandle& ppapi_renderer_channel_handle, | 202 const IPC::ChannelHandle& ppapi_renderer_channel_handle, |
| 179 const IPC::ChannelHandle& trusted_renderer_channel_handle, | 203 const IPC::ChannelHandle& trusted_renderer_channel_handle, |
| 180 const IPC::ChannelHandle& manifest_service_channel_handle); | 204 const IPC::ChannelHandle& manifest_service_channel_handle); |
| 181 | 205 |
| 182 GURL manifest_url_; | 206 GURL manifest_url_; |
| 183 base::File nexe_file_; | 207 base::File nexe_file_; |
| 184 NaClFileToken nexe_token_; | 208 NaClFileToken nexe_token_; |
| 209 scoped_ptr<ResourceFileInfo[]> resource_files_info_; | |
| 210 size_t resource_files_info_len_; | |
| 185 | 211 |
| 186 ppapi::PpapiPermissions permissions_; | 212 ppapi::PpapiPermissions permissions_; |
| 187 | 213 |
| 188 #if defined(OS_WIN) | 214 #if defined(OS_WIN) |
| 189 // This field becomes true when the broker successfully launched | 215 // This field becomes true when the broker successfully launched |
| 190 // the NaCl loader. | 216 // the NaCl loader. |
| 191 bool process_launched_by_broker_; | 217 bool process_launched_by_broker_; |
| 192 #endif | 218 #endif |
| 193 // The NaClHostMessageFilter that requested this NaCl process. We use | 219 // The NaClHostMessageFilter that requested this NaCl process. We use |
| 194 // this for sending the reply once the process has started. | 220 // this for sending the reply once the process has started. |
| (...skipping 41 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... | |
| 236 base::File socket_for_sel_ldr_; | 262 base::File socket_for_sel_ldr_; |
| 237 | 263 |
| 238 base::WeakPtrFactory<NaClProcessHost> weak_factory_; | 264 base::WeakPtrFactory<NaClProcessHost> weak_factory_; |
| 239 | 265 |
| 240 DISALLOW_COPY_AND_ASSIGN(NaClProcessHost); | 266 DISALLOW_COPY_AND_ASSIGN(NaClProcessHost); |
| 241 }; | 267 }; |
| 242 | 268 |
| 243 } // namespace nacl | 269 } // namespace nacl |
| 244 | 270 |
| 245 #endif // COMPONENTS_NACL_BROWSER_NACL_PROCESS_HOST_H_ | 271 #endif // COMPONENTS_NACL_BROWSER_NACL_PROCESS_HOST_H_ |
| OLD | NEW |