Upstream version 5.34.104.0
[platform/framework/web/crosswalk.git] / src / components / nacl / common / nacl_messages.h
1 // Copyright 2013 The Chromium Authors. All rights reserved.
2 // Use of this source code is governed by a BSD-style license that can be
3 // found in the LICENSE file.
4
5 // Defines messages between the browser and NaCl process.
6
7 // Multiply-included message file, no traditional include guard.
8 #include "base/process/process.h"
9 #include "components/nacl/common/nacl_types.h"
10 #include "ipc/ipc_channel_handle.h"
11 #include "ipc/ipc_message_macros.h"
12 #include "ipc/ipc_platform_file.h"
13
14 #define IPC_MESSAGE_START NaClMsgStart
15
16 IPC_STRUCT_TRAITS_BEGIN(nacl::NaClStartParams)
17   IPC_STRUCT_TRAITS_MEMBER(handles)
18   IPC_STRUCT_TRAITS_MEMBER(debug_stub_server_bound_socket)
19   IPC_STRUCT_TRAITS_MEMBER(validation_cache_enabled)
20   IPC_STRUCT_TRAITS_MEMBER(validation_cache_key)
21   IPC_STRUCT_TRAITS_MEMBER(version)
22   IPC_STRUCT_TRAITS_MEMBER(enable_exception_handling)
23   IPC_STRUCT_TRAITS_MEMBER(enable_debug_stub)
24   IPC_STRUCT_TRAITS_MEMBER(enable_ipc_proxy)
25   IPC_STRUCT_TRAITS_MEMBER(uses_irt)
26   IPC_STRUCT_TRAITS_MEMBER(enable_dyncode_syscalls)
27   IPC_STRUCT_TRAITS_MEMBER(enable_nonsfi_mode)
28 IPC_STRUCT_TRAITS_END()
29
30 //-----------------------------------------------------------------------------
31 // NaClProcess messages
32 // These are messages sent between the browser and the NaCl process.
33 // Tells the NaCl process to start.
34 IPC_MESSAGE_CONTROL1(NaClProcessMsg_Start,
35                      nacl::NaClStartParams /* params */)
36
37 #if defined(OS_WIN)
38 // Tells the NaCl broker to launch a NaCl loader process.
39 IPC_MESSAGE_CONTROL1(NaClProcessMsg_LaunchLoaderThroughBroker,
40                      std::string /* channel ID for the loader */)
41
42 // Notify the browser process that the loader was launched successfully.
43 IPC_MESSAGE_CONTROL2(NaClProcessMsg_LoaderLaunched,
44                      std::string,  /* channel ID for the loader */
45                      base::ProcessHandle /* loader process handle */)
46
47 // Tells the NaCl broker to attach a debug exception handler to the
48 // given NaCl loader process.
49 IPC_MESSAGE_CONTROL3(NaClProcessMsg_LaunchDebugExceptionHandler,
50                      int32 /* pid of the NaCl process */,
51                      base::ProcessHandle /* handle of the NaCl process */,
52                      std::string /* NaCl internal process layout info */)
53
54 // Notify the browser process that the broker process finished
55 // attaching a debug exception handler to the given NaCl loader
56 // process.
57 IPC_MESSAGE_CONTROL2(NaClProcessMsg_DebugExceptionHandlerLaunched,
58                      int32 /* pid */,
59                      bool /* success */)
60
61 // Notify the broker that all loader processes have been terminated and it
62 // should shutdown.
63 IPC_MESSAGE_CONTROL0(NaClProcessMsg_StopBroker)
64
65 // Used by the NaCl process to request that a Windows debug exception
66 // handler be attached to it.
67 IPC_SYNC_MESSAGE_CONTROL1_1(NaClProcessMsg_AttachDebugExceptionHandler,
68                             std::string, /* Internal process info */
69                             bool /* Result */)
70 #endif
71
72 // Used by the NaCl process to query a database in the browser.  The database
73 // contains the signatures of previously validated code chunks.
74 IPC_SYNC_MESSAGE_CONTROL1_1(NaClProcessMsg_QueryKnownToValidate,
75                             std::string, /* A validation signature */
76                             bool /* Can validation be skipped? */)
77
78 // Used by the NaCl process to add a validation signature to the validation
79 // database in the browser.
80 IPC_MESSAGE_CONTROL1(NaClProcessMsg_SetKnownToValidate,
81                      std::string /* A validation signature */)
82
83 // Used by the NaCl process to acquire trusted information about a file directly
84 // from the browser, including the file's path as well as a fresh version of the
85 // file handle.
86 IPC_SYNC_MESSAGE_CONTROL2_2(NaClProcessMsg_ResolveFileToken,
87                             uint64, /* file_token_lo */
88                             uint64, /* file_token_hi */
89                             IPC::PlatformFileForTransit, /* fd */
90                             base::FilePath /* Path opened to get fd */)
91
92 // Notify the browser process that the server side of the PPAPI channel was
93 // created successfully.
94 IPC_MESSAGE_CONTROL2(NaClProcessHostMsg_PpapiChannelsCreated,
95                      IPC::ChannelHandle, /* browser_channel_handle */
96                      IPC::ChannelHandle /* renderer_channel_handle */)