Chromium Code Reviews| OLD | NEW |
|---|---|
| 1 // Copyright 2014 The Chromium Authors. All rights reserved. | 1 // Copyright 2014 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 #include "native_client/src/public/irt_core.h" | 5 #include "native_client/src/public/irt_core.h" |
| 6 #include "native_client/src/trusted/service_runtime/include/sys/unistd.h" | 6 #include "native_client/src/trusted/service_runtime/include/sys/unistd.h" |
| 7 #include "native_client/src/untrusted/irt/irt.h" | 7 #include "native_client/src/untrusted/irt/irt.h" |
| 8 #include "native_client/src/untrusted/irt/irt_private.h" | 8 #include "native_client/src/untrusted/irt/irt_private.h" |
| 9 #include "ppapi/nacl_irt/irt_manifest.h" | |
| 9 #include "ppapi/nacl_irt/irt_ppapi.h" | 10 #include "ppapi/nacl_irt/irt_ppapi.h" |
| 10 #include "ppapi/nacl_irt/plugin_main.h" | 11 #include "ppapi/nacl_irt/plugin_main.h" |
| 11 #include "ppapi/nacl_irt/public/irt_ppapi.h" | 12 #include "ppapi/nacl_irt/public/irt_ppapi.h" |
| 12 #include "ppapi/native_client/src/untrusted/pnacl_irt_shim/irt_shim_ppapi.h" | 13 #include "ppapi/native_client/src/untrusted/pnacl_irt_shim/irt_shim_ppapi.h" |
| 13 | 14 |
| 14 static struct PP_StartFunctions g_pp_functions; | 15 static struct PP_StartFunctions g_pp_functions; |
| 15 | 16 |
| 16 int irt_ppapi_start(const struct PP_StartFunctions* funcs) { | 17 int irt_ppapi_start(const struct PP_StartFunctions* funcs) { |
| 17 // Disable NaCl's open_resource() interface on this thread. | 18 // Disable NaCl's open_resource() interface on this thread. |
| 18 g_is_main_thread = 1; | 19 g_is_main_thread = 1; |
| (...skipping 20 matching lines...) Expand all Loading... | |
| 39 PpapiPluginRegisterThreadCreator, | 40 PpapiPluginRegisterThreadCreator, |
| 40 }; | 41 }; |
| 41 | 42 |
| 42 static int ppapihook_pnacl_private_filter(void) { | 43 static int ppapihook_pnacl_private_filter(void) { |
| 43 int pnacl_mode = sysconf(NACL_ABI__SC_NACL_PNACL_MODE); | 44 int pnacl_mode = sysconf(NACL_ABI__SC_NACL_PNACL_MODE); |
| 44 if (pnacl_mode == -1) | 45 if (pnacl_mode == -1) |
| 45 return 0; | 46 return 0; |
| 46 return pnacl_mode; | 47 return pnacl_mode; |
| 47 } | 48 } |
| 48 | 49 |
| 50 const nacl_irt_resource_open kIrtResourceOpen = { | |
| 51 ppapi::IrtOpenResource, | |
| 52 }; | |
| 53 | |
| 54 static int ppapihook_not_pnacl_private_filter(void) { | |
|
Mark Seaborn
2014/07/25 22:06:35
Nit: remove "ppapihook" from the name. "not_pnacl
| |
| 55 int pnacl_mode = sysconf(NACL_ABI__SC_NACL_PNACL_MODE); | |
| 56 if (pnacl_mode == -1) | |
| 57 return 0; | |
| 58 return !pnacl_mode; | |
| 59 } | |
| 60 | |
| 49 static const struct nacl_irt_interface irt_interfaces[] = { | 61 static const struct nacl_irt_interface irt_interfaces[] = { |
| 50 { NACL_IRT_PPAPIHOOK_v0_1, &nacl_irt_ppapihook, sizeof(nacl_irt_ppapihook), | 62 { NACL_IRT_PPAPIHOOK_v0_1, &nacl_irt_ppapihook, sizeof(nacl_irt_ppapihook), |
| 51 NULL }, | 63 NULL }, |
| 52 { NACL_IRT_PPAPIHOOK_PNACL_PRIVATE_v0_1, | 64 { NACL_IRT_PPAPIHOOK_PNACL_PRIVATE_v0_1, |
| 53 &nacl_irt_ppapihook_pnacl_private, sizeof(nacl_irt_ppapihook_pnacl_private), | 65 &nacl_irt_ppapihook_pnacl_private, sizeof(nacl_irt_ppapihook_pnacl_private), |
| 54 ppapihook_pnacl_private_filter }, | 66 ppapihook_pnacl_private_filter }, |
| 67 // The Chromium implementation of NACL_IRT_RESOURCE_OPEN_v0_1 takes | |
| 68 // precedence over the one supplied by NaCl (which is SRPC-based). | |
|
Mark Seaborn
2014/07/25 22:06:35
You could omit this comment so that we don't have
| |
| 69 { NACL_IRT_RESOURCE_OPEN_v0_1, &kIrtResourceOpen, | |
| 70 sizeof(kIrtResourceOpen), ppapihook_not_pnacl_private_filter }, | |
| 55 }; | 71 }; |
| 56 | 72 |
| 57 size_t chrome_irt_query(const char* interface_ident, | 73 size_t chrome_irt_query(const char* interface_ident, |
| 58 void* table, size_t tablesize) { | 74 void* table, size_t tablesize) { |
| 59 size_t result = nacl_irt_query_core(interface_ident, table, tablesize); | 75 size_t result = nacl_irt_query_list(interface_ident, table, tablesize, |
| 76 irt_interfaces, sizeof(irt_interfaces)); | |
| 60 if (result != 0) | 77 if (result != 0) |
| 61 return result; | 78 return result; |
| 62 return nacl_irt_query_list(interface_ident, table, tablesize, | 79 return nacl_irt_query_core(interface_ident, table, tablesize); |
| 63 irt_interfaces, sizeof(irt_interfaces)); | |
| 64 } | 80 } |
| OLD | NEW |