blob: 59de526a0159998ad313e9b33008f6886546cfcd (
plain)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
|
// 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_
|