2 * Copyright 2008, Google Inc.
5 * Redistribution and use in source and binary forms, with or without
6 * modification, are permitted provided that the following conditions are
9 * * Redistributions of source code must retain the above copyright
10 * notice, this list of conditions and the following disclaimer.
11 * * Redistributions in binary form must reproduce the above
12 * copyright notice, this list of conditions and the following disclaimer
13 * in the documentation and/or other materials provided with the
15 * * Neither the name of Google Inc. nor the names of its
16 * contributors may be used to endorse or promote products derived from
17 * this software without specific prior written permission.
19 * THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS
20 * "AS IS" AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT
21 * LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR
22 * A PARTICULAR PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT
23 * OWNER OR CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL,
24 * SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT
25 * LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE,
26 * DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY
27 * THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT
28 * (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE
29 * OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
33 // NaCl inter-module communication primitives.
35 #include "native_client/intermodule_comm/nacl_imc.h"
36 #include "native_client/intermodule_comm/nacl_imc_c.h"
42 int NaClGetLastErrorString(char* buffer
, size_t length
) {
43 return nacl::GetLastErrorString(buffer
, length
);
46 NaClHandle
NaClBoundSocket(const NaClSocketAddress
* address
) {
47 return nacl::BoundSocket(
48 reinterpret_cast<const nacl::SocketAddress
*>(address
));
51 int NaClSocketPair(NaClHandle pair
[2]) {
52 return nacl::SocketPair(pair
);
55 int NaClClose(NaClHandle handle
) {
56 return nacl::Close(handle
);
59 int NaClWouldBlock() {
60 return nacl::WouldBlock();
63 int NaClSendDatagram(NaClHandle socket
, const NaClMessageHeader
* message
,
65 return nacl::SendDatagram(
67 reinterpret_cast<const nacl::MessageHeader
*>(message
),
71 int NaClSendDatagramTo(NaClHandle socket
, const NaClMessageHeader
* message
,
72 int flags
, const NaClSocketAddress
* name
) {
73 return nacl::SendDatagramTo(
75 reinterpret_cast<const nacl::MessageHeader
*>(message
),
77 reinterpret_cast<const nacl::SocketAddress
*>(name
));
80 int NaClSend(NaClHandle socket
, const void* buffer
, size_t length
,
82 return nacl::Send(socket
, buffer
, length
, flags
);
85 int NaClSendTo(NaClHandle socket
, const void* buffer
, size_t length
,
86 int flags
, const NaClSocketAddress
* name
) {
87 return nacl::SendTo(socket
, buffer
, length
, flags
,
88 reinterpret_cast<const nacl::SocketAddress
*>(name
));
91 int NaClReceiveDatagram(NaClHandle socket
, NaClMessageHeader
* message
,
93 return nacl::ReceiveDatagram(socket
,
94 reinterpret_cast<nacl::MessageHeader
*>(message
),
98 int NaClReceive(NaClHandle socket
, void* buffer
, size_t length
, int flags
) {
99 return nacl::Receive(socket
, buffer
, length
, flags
);
102 NaClHandle
NaClCreateMemoryObject(size_t length
) {
103 return nacl::CreateMemoryObject(length
);
106 void* NaClMap(void* start
, size_t length
, int prot
, int flags
,
107 NaClHandle memory
, off_t offset
) {
108 return nacl::Map(start
, length
, prot
, flags
, memory
, offset
);
111 int NaClUnmap(void* start
, size_t length
) {
112 return nacl::Unmap(start
, length
);