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

Unified Diff: mojo/monacl/gen/mojo_syscall.cc.template

Issue 385983008: Mojo + NaCl prototype. (Closed) Base URL: https://chromium.googlesource.com/chromium/src.git@master
Patch Set: Dead files Created 6 years, 4 months 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: mojo/monacl/gen/mojo_syscall.cc.template
diff --git a/mojo/monacl/gen/mojo_syscall.cc.template b/mojo/monacl/gen/mojo_syscall.cc.template
new file mode 100644
index 0000000000000000000000000000000000000000..f8f86135fe0a9e7884176ec27dc0f78d6bc097d8
--- /dev/null
+++ b/mojo/monacl/gen/mojo_syscall.cc.template
@@ -0,0 +1,202 @@
+// Copyright 2014 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.
+
+// WARNING this file was generated by $script_name
+// Do not edit by hand.
+
+#include "mojo/monacl/mojo_syscall.h"
+
+#include <stdio.h>
+
+#include "mojo/public/c/system/core.h"
+#include "native_client/src/public/nacl_app.h"
+#include "native_client/src/trusted/desc/nacl_desc_custom.h"
+#include "native_client/src/trusted/service_runtime/nacl_copy.h"
+#include "native_client/src/trusted/service_runtime/sel_ldr.h"
+
+namespace {
+
+class ScopedCopyLock {
Mark Seaborn 2014/08/26 16:25:53 How about putting all these definitions into a nor
Nick Bray (chromium) 2014/09/03 23:45:03 Moved out templates and inline functions.
+ public:
+ explicit ScopedCopyLock(struct NaClApp *nap) : nap_(nap) {
Mark Seaborn 2014/08/26 16:25:53 Use "* " spacing in Chromium code. Same elsewhere
Nick Bray (chromium) 2014/09/03 23:45:03 Done.
+ NaClCopyTakeLock(nap_);
+ }
+ ~ScopedCopyLock() {
+ NaClCopyDropLock(nap_);
+ }
+ private:
+ struct NaClApp *nap_;
+};
+
+static INLINE uintptr_t NaClUserToSysAddrArray(
+ struct NaClApp *nap,
+ uintptr_t uaddr,
Mark Seaborn 2014/08/26 16:25:53 Nit: use uint32_t (as you do below)
Nick Bray (chromium) 2014/09/03 23:45:03 Done.
+ size_t count,
+ size_t size) {
+ // TODO overflow checking
Mark Seaborn 2014/08/26 16:25:52 Nit: "TODO(ncbray)"
Nick Bray (chromium) 2014/09/03 23:45:02 Done.
+ size_t range = count * size;
+ return NaClUserToSysAddrRange(nap, uaddr, range);
+}
+
+template <typename T> bool ConvertScalarInput(
Mark Seaborn 2014/08/26 16:25:52 "Convert" is vague. How about ReadScalarInput or
Nick Bray (chromium) 2014/09/03 23:45:03 Although correct for this function, all the "conve
+ struct NaClApp *nap,
+ uint32_t user_ptr,
+ T* value) {
+ if (user_ptr) {
+ uintptr_t temp = NaClUserToSysAddrRange(nap, user_ptr, sizeof(T));
Mark Seaborn 2014/08/26 16:25:53 Nit: 'temp' -> 'sys_addr'
Nick Bray (chromium) 2014/09/03 23:45:02 Breaks naming used in related functions.
+ if (temp != kNaClBadAddress) {
+ *value = *reinterpret_cast<T volatile*>(temp);
+ return true;
+ }
+ }
+ return false;
+}
+
+template <typename T> bool ConvertScalarOutput(
Mark Seaborn 2014/08/26 16:25:53 This looks like it would be like ConvertScalarInpu
Nick Bray (chromium) 2014/09/03 23:45:03 Part of larger naming discussion. (See above)
+ struct NaClApp *nap,
+ uint32_t user_ptr,
+ T volatile** sys_ptr) {
+ if (user_ptr) {
+ uintptr_t temp = NaClUserToSysAddrRange(nap, user_ptr, sizeof(T));
+ if (temp != kNaClBadAddress) {
+ *sys_ptr = reinterpret_cast<T volatile*>(temp);
+ return true;
+ }
+ }
+ return false;
Mark Seaborn 2014/08/26 16:25:53 Security bug: this leaves *sys_ptr undefined, so t
Nick Bray (chromium) 2014/09/03 23:45:03 The caller will always early out. Added paranoid
+}
+
+template <typename T> bool ConvertScalarInOut(
+ struct NaClApp *nap,
+ uint32_t user_ptr,
+ bool optional,
+ T* value,
+ T volatile** sys_ptr) {
+ if (user_ptr) {
+ uintptr_t temp = NaClUserToSysAddrRange(nap, user_ptr, sizeof(T));
+ if (temp != kNaClBadAddress) {
+ T volatile* converted = reinterpret_cast<T volatile*>(temp);
+ *sys_ptr = converted;
+ *value = *converted;
+ return true;
+ }
+ } else if (optional) {
+ *sys_ptr = 0;
+ *value = static_cast<T>(0); // Paranoia.
+ return true;
+ }
+ return false;
+}
+
+template <typename T> bool ConvertArray(
+ struct NaClApp *nap,
+ uint32_t user_ptr,
+ uint32_t length,
+ bool optional,
+ T** sys_ptr) {
+ if (user_ptr) {
+ uintptr_t temp = NaClUserToSysAddrArray(nap, user_ptr, length, sizeof(T));
+ if (temp != kNaClBadAddress) {
+ *sys_ptr = reinterpret_cast<T*>(temp);
+ return true;
+ }
+ } else if (optional) {
+ *sys_ptr = 0;
+ return true;
+ }
+ return false;
+}
+
+template <typename T> bool ConvertBytes(
+ struct NaClApp *nap,
+ uint32_t user_ptr,
+ uint32_t length,
+ bool optional,
+ T** sys_ptr) {
+ if (user_ptr) {
+ uintptr_t temp = NaClUserToSysAddrRange(nap, user_ptr, length);
+ if (temp != kNaClBadAddress) {
+ *sys_ptr = reinterpret_cast<T*>(temp);
+ return true;
+ }
+ } else if (optional) {
+ *sys_ptr = 0;
+ return true;
+ }
+ return false;
+}
+
+// TODO(ncbray): size validation and complete copy.
+// TODO(ncbray): ensure non-null / missized structs are covered by a test case.
+template <typename T> bool ConvertStruct(
+ struct NaClApp *nap,
+ uint32_t user_ptr,
+ bool optional,
+ T** sys_ptr) {
+ if (user_ptr) {
+ uintptr_t temp = NaClUserToSysAddrRange(nap, user_ptr, sizeof(T));
+ if (temp != kNaClBadAddress) {
+ *sys_ptr = reinterpret_cast<T*>(temp);
+ return true;
+ }
+ } else if (optional) {
+ *sys_ptr = 0;
+ return true;
+ }
+ return false;
+}
+
+void MojoDescDestroy(void *handle) {
+ UNREFERENCED_PARAMETER(handle);
+}
+
+ssize_t MojoDescSendMsg(void *handle,
+ const struct NaClImcTypedMsgHdr *msg,
+ int flags) {
+ UNREFERENCED_PARAMETER(flags);
+
+ struct NaClApp *nap = static_cast<struct NaClApp*>(handle);
+
+ if (msg->iov_length != 1 || msg->iov[0].length < 8 || msg->ndesc_length != 0) {
+ return -1;
+ }
+
+ uint32_t *params = static_cast<uint32_t*>(msg->iov[0].base);
+ uint32_t numParams = msg->iov[0].length / sizeof(*params);
+
+ uint32_t msgType = params[0];
+ switch (msgType) {
+$body
+ default:
+ return -1;
+ }
+
+ return -1;
+}
+
+ssize_t MojoDescRecvMsg(void *handle,
+ struct NaClImcTypedMsgHdr *msg,
+ int flags) {
+ UNREFERENCED_PARAMETER(handle);
+ UNREFERENCED_PARAMETER(msg);
+ UNREFERENCED_PARAMETER(flags);
+
+ return -1;
+}
+
+struct NaClDesc *MakeMojoDesc(struct NaClApp *nap) {
+ struct NaClDescCustomFuncs funcs = NACL_DESC_CUSTOM_FUNCS_INITIALIZER;
+ funcs.Destroy = MojoDescDestroy;
+ funcs.SendMsg = MojoDescSendMsg;
+ funcs.RecvMsg = MojoDescRecvMsg;
+ return NaClDescMakeCustomDesc(nap, &funcs);
+}
+
+} // namespace
+
+#define NACL_MOJO_DESC 8
+
+void InjectMojo(struct NaClApp *nap) {
+ NaClAppSetDesc(nap, NACL_MOJO_DESC, MakeMojoDesc(nap));
+}

Powered by Google App Engine
This is Rietveld 408576698