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

Unified Diff: native_client_sdk/src/libraries/nacl_io/mount_node_socket.h

Issue 22587003: [NaCl SDK] Add UDP and TCP Sockets (Closed) Base URL: svn://svn.chromium.org/chrome/trunk/src
Patch Set: Running tests on package Created 7 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: native_client_sdk/src/libraries/nacl_io/mount_node_socket.h
diff --git a/native_client_sdk/src/libraries/nacl_io/mount_node_socket.h b/native_client_sdk/src/libraries/nacl_io/mount_node_socket.h
new file mode 100644
index 0000000000000000000000000000000000000000..337c3c5f1f5e6e42618bc5f938d1155632596791
--- /dev/null
+++ b/native_client_sdk/src/libraries/nacl_io/mount_node_socket.h
@@ -0,0 +1,102 @@
+// Copyright (c) 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.
+
+#ifndef LIBRARIES_NACL_IO_MOUNT_NODE_SOCKET_H_
+#define LIBRARIES_NACL_IO_MOUNT_NODE_SOCKET_H_
+
+#include "nacl_io/ossocket.h"
+#ifdef PROVIDES_SOCKET_API
+
+#include <ppapi/c/pp_errors.h>
+#include <ppapi/c/pp_resource.h>
+#include <ppapi/c/ppb_net_address.h>
+
+#include "nacl_io/mount.h"
+#include "nacl_io/pepper_interface.h"
+
+namespace nacl_io {
+
+class MountSocket;
+
+class MountNodeSocket : public MountNode {
+ public:
+ explicit MountNodeSocket(Mount* mount);
+
+ protected:
+ virtual void Destroy();
+ virtual Error Init(int flags) = 0;
+
+ public:
+ virtual uint32_t GetEventStatus();
+
+ // Normal read/write operations on a file (recv/send).
+ virtual Error Read(size_t offs, void* buf, size_t count, int* out_bytes);
+ virtual Error Write(size_t offs,
+ const void* buf,
+ size_t count,
+ int* out_bytes);
+
+ // Unsuported Functions
+ virtual Error Accept(const struct sockaddr* addr, socklen_t len);
+ virtual Error Listen(int backlog);
+ virtual Error GetSockOpt(int lvl, int optname, void* optval, socklen_t* len);
+ virtual Error SetSockOpt(int lvl,
+ int optname,
+ const void* optval,
+ socklen_t len);
+ virtual Error Shutdown(int how);
+ virtual Error MMap(void* addr,
+ size_t length,
+ int prot,
+ int flags,
+ size_t offset,
+ void** out_addr);
+
+ // Normal Functions.
+ virtual Error Bind(const struct sockaddr* addr, socklen_t len);
+ virtual Error Connect(const struct sockaddr* addr, socklen_t len);
+ virtual Error Recv(void* buf, size_t len, int flags, int* out_len);
+ virtual Error RecvFrom(void* buf,
+ size_t len,
+ int flags,
+ struct sockaddr* src_addr,
+ socklen_t* addrlen,
+ int* out_len);
+
+ virtual Error Send(const void* buf, size_t len, int flags, int* out_len);
+ virtual Error SendTo(const void* buf,
+ size_t len,
+ int flags,
+ const struct sockaddr* dest_addr,
+ socklen_t addrlen,
+ int* out_len);
+
+ virtual Error GetPeerName(struct sockaddr* addr, socklen_t* len);
+ virtual Error GetSockName(struct sockaddr* addr, socklen_t* len);
+
+ protected:
+ NetAddressInterface* NetAddress();
+ PP_Resource SockAddrToResource(const struct sockaddr* addr, socklen_t len);
+ socklen_t ResourceToSockAddr(PP_Resource addr,
+ socklen_t len,
+ struct sockaddr* out_addr);
+
+ bool EquivalentAddress(PP_Resource addr1, PP_Resource addr2);
binji 2013/08/09 19:28:06 Maybe IsEquivalentAddress? I prefer functions to s
noelallen1 2013/08/09 22:53:22 Done.
+ Error PPErrorToErrno(int error);
+
+ protected:
+ PP_Resource socket_resource_;
binji 2013/08/09 19:28:06 used ScopedResource instead?
noelallen1 2013/08/09 22:53:22 Can't. mount_->ppapi_ isn't available until Init.
+ PP_Resource local_addr_;
+ PP_Resource remote_addr_;
+
+ friend class KernelProxy;
+ friend class MountSocket;
+};
+
+
+} // namespace nacl_io
+
+
+#endif // PROVIDES_SOCKET_API
+#endif // LIBRARIES_NACL_IO_MOUNT_NODE_SOCKET_H_

Powered by Google App Engine
This is Rietveld 408576698