Chromium Code Reviews
chromiumcodereview-hr@appspot.gserviceaccount.com (chromiumcodereview-hr) | Please choose your nickname with Settings | Help | Chromium Project | Gerrit Changes | Sign out
(435)

Unified Diff: components/nacl/loader/nonsfi/nonsfi_main.cc

Issue 100373005: Initial implementation of Bare Metal Mode for NaCl. (Closed) Base URL: svn://svn.chromium.org/chrome/trunk/src
Patch Set: Created 7 years ago
Use n/p to move between diff chunks; N/P to move between comments. Draft comments are only viewable by you.
Jump to:
View side-by-side diff with in-line comments
Download patch
Index: components/nacl/loader/nonsfi/nonsfi_main.cc
diff --git a/components/nacl/loader/nonsfi/nonsfi_main.cc b/components/nacl/loader/nonsfi/nonsfi_main.cc
new file mode 100644
index 0000000000000000000000000000000000000000..e927e71398708ec2b3205362fbb9d59309d2f2a8
--- /dev/null
+++ b/components/nacl/loader/nonsfi/nonsfi_main.cc
@@ -0,0 +1,166 @@
+// Copyright 2013 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 "components/nacl/loader/nonsfi/nonsfi_main.h"
+
+#include "base/logging.h"
+#include "base/memory/scoped_ptr.h"
+#include "components/nacl/loader/nonsfi/elf_loader.h"
+#include "native_client/src/include/elf_auxv.h"
+#include "native_client/src/include/nacl_macros.h"
+#include "native_client/src/public/secure_service.h"
+#include "native_client/src/shared/srpc/nacl_srpc.h"
+#include "native_client/src/trusted/desc/nacl_desc_base.h"
+#include "native_client/src/trusted/desc/nacl_desc_imc.h"
+#include "native_client/src/trusted/desc/nrd_all_modules.h"
+#include "native_client/src/trusted/desc/nrd_xfer.h"
+#include "native_client/src/trusted/service_runtime/nacl_error_code.h"
+
+namespace nacl {
+namespace nonsfi {
+namespace {
+
+struct NaClDescUnrefer {
+ void operator()(struct NaClDesc* desc) const {
+ NaClDescUnref(desc);
+ }
+};
+
+void LoadModuleRpc(struct NaClSrpcRpc* rpc,
+ struct NaClSrpcArg** in_args,
+ struct NaClSrpcArg** out_args,
+ struct NaClSrpcClosure* done_cls) {
+ rpc->result = NACL_SRPC_RESULT_INTERNAL;
+
+ ::scoped_ptr<struct NaClDesc, NaClDescUnrefer> desc(in_args[0]->u.hval);
+ ElfImage image;
+ if (image.Read(desc.get()) != LOAD_OK) {
+ LOG(ERROR) << "LoadModuleRpc: Failed to read binary.";
+ return;
+ }
+
+ if (image.Load(desc.get()) != LOAD_OK) {
+ LOG(ERROR) << "LoadModuleRpc: Failed to load the image";
+ return;
+ }
+
+ uintptr_t entry_point = image.entry_point();
+ rpc->result = NACL_SRPC_RESULT_OK;
+
+ // Run for testing. TODO(hidehiko): Remove this.
+ uintptr_t info[] = {
+ 0, // Do not use fini.
+ 0, // envc.
+ 0, // argc.
+ 0, // Null terminate for argv.
+ 0, // Null terminate for envv.
+ AT_NULL,
+ 0, // Null terminate for auxv.
+ };
+ reinterpret_cast<void (*)(uintptr_t*)>(entry_point)(info);
+}
+
+const static struct NaClSrpcHandlerDesc kNonSfiServiceHandlers[] = {
+ { NACL_SECURE_SERVICE_LOAD_MODULE, LoadModuleRpc, },
+ { static_cast<const char*>(NULL), static_cast<NaClSrpcMethod>(NULL), },
+};
+
+// Creates two socketpairs to communicate with the host process.
+void CreateSecureSocketPair(struct NaClDesc* secure_pair[2],
+ struct NaClDesc* pair[2]) {
+ // Set up a secure pair.
+ if (NaClCommonDescMakeBoundSock(secure_pair)) {
+ LOG(FATAL) << "Cound not create secure service socket\n";
+ }
+
+ // Set up a service pair.
+ if (NaClCommonDescMakeBoundSock(pair)) {
+ LOG(FATAL) << "Could not create service socket";
+ }
+}
+
+// Wraps handle by NaClDesc, and sends sercure_service_address and
Mark Seaborn 2013/12/17 21:18:55 Typo: "sercure"
hidehiko 2013/12/18 08:38:03 Done.
+// service_address via the created descriptor.
+struct NaClDesc* SetUpBootstrapChannel(NaClHandle handle,
+ struct NaClDesc* secure_service_address,
+ struct NaClDesc* service_address) {
+ if (secure_service_address == NULL) {
+ LOG(FATAL) << "SetUpBootstrapChannel: secure_service_address is not set";
+ }
+
+ if (service_address == NULL) {
+ LOG(FATAL) << "SetUpBootstrapChannel: secure_service_address is not set";
+ }
+
+ struct NaClDescImcDesc* channel =
+ static_cast<struct NaClDescImcDesc*>(malloc(sizeof *channel));
+ if (channel == NULL) {
+ LOG(FATAL) << "SetUpBootstrapChannel: no memory";
+ }
+
+ if (!NaClDescImcDescCtor(channel, handle)) {
+ LOG(FATAL) << "SetUpBootstrapChannel: cannot construct IMC descriptor "
+ << "object for inherited descriptor: " << handle;
+ }
+
+ // Send the descriptors to the host.
+ struct NaClDesc* descs[2] = {
+ secure_service_address,
+ service_address,
+ };
+
+ struct NaClImcTypedMsgHdr hdr;
Mark Seaborn 2013/12/17 21:18:55 You've missed initialising "hdr.flags = 0;"
hidehiko 2013/12/18 08:38:03 Good catch. Fixed.
+ hdr.iov = static_cast<struct NaClImcMsgIoVec*>(NULL);
+ hdr.iov_length = 0;
+ hdr.ndescv = descs;
+ hdr.ndesc_length = NACL_ARRAY_SIZE(descs);
+
+ ssize_t error = (*NACL_VTBL(NaClDesc, channel)->SendMsg)(
+ reinterpret_cast<struct NaClDesc*>(channel), &hdr, 0);
+ if (error) {
+ LOG(FATAL) << "SetUpBootstrapChannel: SendMsg failed, error = " << error;
+ }
+ return reinterpret_cast<struct NaClDesc*>(channel);
+}
+
+// Starts to listen to the port and runs the server loop.
+void ServiceAccept(struct NaClDesc* port) {
+ struct NaClDesc* connected_desc = NULL;
+ int status = (*NACL_VTBL(NaClDesc, port)->AcceptConn)(port, &connected_desc);
+ if (status) {
+ LOG(ERROR) << "ServiceAccept: Failed to accept " << status;
+ return;
+ }
+
+ NaClSrpcServerLoop(connected_desc, kNonSfiServiceHandlers, NULL);
+}
+
+} // namespace
+
+void MainStart(NaClHandle imc_bootstrap_handle) {
+ NaClSrpcModuleInit();
+
+ struct NaClDesc* secure_pair[2] = { NULL, NULL };
+ struct NaClDesc* pair[2] = { NULL, NULL };
+ CreateSecureSocketPair(secure_pair, pair);
+ ::scoped_ptr<struct NaClDesc, NaClDescUnrefer> secure_port(secure_pair[0]);
+ ::scoped_ptr<struct NaClDesc, NaClDescUnrefer> secure_address(
+ secure_pair[1]);
+ ::scoped_ptr<struct NaClDesc, NaClDescUnrefer> service_port(pair[0]);
+ ::scoped_ptr<struct NaClDesc, NaClDescUnrefer> service_address(pair[1]);
+
+ ::scoped_ptr<struct NaClDesc, NaClDescUnrefer> channel(
+ SetUpBootstrapChannel(imc_bootstrap_handle,
+ secure_address.get(), service_address.get()));
+ if (!channel) {
+ LOG(ERROR) << "MainStart: Failed to set up bootstrap channel.";
+ return;
+ }
+
+ // Start the SRPC server loop.
+ ServiceAccept(secure_port.get());
+}
+
+} // namespace nonsfi
+} // namespace nacl
« components/nacl/loader/nonsfi/elf_loader.cc ('K') | « components/nacl/loader/nonsfi/nonsfi_main.h ('k') | no next file » | no next file with comments »

Powered by Google App Engine
This is Rietveld 408576698