blob: 912fd18a84dfa9aa0d5f8298b9e742eb2bdc0b94 [file] [log] [blame]
Ben Murdochca12bfa2013-07-23 11:17:05 +01001// Copyright (c) 2012 The Chromium Authors. All rights reserved.
2// Use of this source code is governed by a BSD-style license that can be
3// found in the LICENSE file.
4
Torne (Richard Coles)2a99a7e2013-03-28 15:31:22 +00005#include <errno.h>
Ben Murdoch58e6fbe2013-07-26 10:20:38 +01006
Torne (Richard Coles)2a99a7e2013-03-28 15:31:22 +00007#include "nacl_io/kernel_intercept.h"
8#include "nacl_io/kernel_proxy.h"
9#include "nacl_io/kernel_wrap.h"
Ben Murdoch58e6fbe2013-07-26 10:20:38 +010010#include "nacl_io/osmman.h"
Torne (Richard Coles)a36e5922013-08-05 13:57:33 +010011#include "nacl_io/ossocket.h"
Torne (Richard Coles)2a99a7e2013-03-28 15:31:22 +000012#include "nacl_io/pepper_interface.h"
13#include "nacl_io/pepper_interface.h"
14#include "nacl_io/real_pepper_interface.h"
15
Ben Murdochca12bfa2013-07-23 11:17:05 +010016using namespace nacl_io;
Torne (Richard Coles)2a99a7e2013-03-28 15:31:22 +000017
Ben Murdoch58e6fbe2013-07-26 10:20:38 +010018#define ON_NOSYS_RETURN(x) \
19 if (!ki_is_initialized()) { \
20 errno = ENOSYS; \
21 return x; \
22 }
23
Torne (Richard Coles)2a99a7e2013-03-28 15:31:22 +000024static KernelProxy* s_kp;
25
26void ki_init(void* kp) {
27 ki_init_ppapi(kp, 0, NULL);
28}
29
30void ki_init_ppapi(void* kp,
31 PP_Instance instance,
32 PPB_GetInterface get_browser_interface) {
33 kernel_wrap_init();
34
35 if (kp == NULL) kp = new KernelProxy();
36 s_kp = static_cast<KernelProxy*>(kp);
37
38 PepperInterface* ppapi = NULL;
39 if (instance && get_browser_interface)
40 ppapi = new RealPepperInterface(instance, get_browser_interface);
41
42 s_kp->Init(ppapi);
43}
44
45int ki_is_initialized() {
46 return s_kp != NULL;
47}
48
49void ki_uninit() {
Ben Murdoch58e6fbe2013-07-26 10:20:38 +010050 kernel_wrap_uninit();
Torne (Richard Coles)2a99a7e2013-03-28 15:31:22 +000051 s_kp = NULL;
52}
53
Ben Murdoch58e6fbe2013-07-26 10:20:38 +010054
Torne (Richard Coles)2a99a7e2013-03-28 15:31:22 +000055int ki_chdir(const char* path) {
Ben Murdoch58e6fbe2013-07-26 10:20:38 +010056 ON_NOSYS_RETURN(-1);
Torne (Richard Coles)2a99a7e2013-03-28 15:31:22 +000057 return s_kp->chdir(path);
58}
59
60char* ki_getcwd(char* buf, size_t size) {
61 // gtest uses getcwd in a static initializer. If we haven't initialized the
62 // kernel-intercept yet, just return ".".
63 if (!ki_is_initialized()) {
64 if (size < 2) {
65 errno = ERANGE;
66 return NULL;
67 }
68 buf[0] = '.';
69 buf[1] = 0;
70 return buf;
71 }
72 return s_kp->getcwd(buf, size);
73}
74
75char* ki_getwd(char* buf) {
Ben Murdoch58e6fbe2013-07-26 10:20:38 +010076 ON_NOSYS_RETURN(NULL);
Torne (Richard Coles)2a99a7e2013-03-28 15:31:22 +000077 return s_kp->getwd(buf);
78}
79
80int ki_dup(int oldfd) {
Ben Murdoch58e6fbe2013-07-26 10:20:38 +010081 ON_NOSYS_RETURN(-1);
Torne (Richard Coles)2a99a7e2013-03-28 15:31:22 +000082 return s_kp->dup(oldfd);
83}
84
85int ki_dup2(int oldfd, int newfd) {
Ben Murdoch58e6fbe2013-07-26 10:20:38 +010086 ON_NOSYS_RETURN(-1);
Torne (Richard Coles)2a99a7e2013-03-28 15:31:22 +000087 return s_kp->dup2(oldfd, newfd);
88}
89
90int ki_chmod(const char *path, mode_t mode) {
Ben Murdoch58e6fbe2013-07-26 10:20:38 +010091 ON_NOSYS_RETURN(-1);
Torne (Richard Coles)2a99a7e2013-03-28 15:31:22 +000092 return s_kp->chmod(path, mode);
93}
94
95int ki_stat(const char *path, struct stat *buf) {
Ben Murdoch58e6fbe2013-07-26 10:20:38 +010096 ON_NOSYS_RETURN(-1);
Torne (Richard Coles)2a99a7e2013-03-28 15:31:22 +000097 return s_kp->stat(path, buf);
98}
99
100int ki_mkdir(const char *path, mode_t mode) {
Ben Murdoch58e6fbe2013-07-26 10:20:38 +0100101 ON_NOSYS_RETURN(-1);
Torne (Richard Coles)2a99a7e2013-03-28 15:31:22 +0000102 return s_kp->mkdir(path, mode);
103}
104
105int ki_rmdir(const char *path) {
Ben Murdoch58e6fbe2013-07-26 10:20:38 +0100106 ON_NOSYS_RETURN(-1);
Torne (Richard Coles)2a99a7e2013-03-28 15:31:22 +0000107 return s_kp->rmdir(path);
108}
109
110int ki_mount(const char *source, const char *target, const char *filesystemtype,
111 unsigned long mountflags, const void *data) {
Ben Murdoch58e6fbe2013-07-26 10:20:38 +0100112 ON_NOSYS_RETURN(-1);
Torne (Richard Coles)2a99a7e2013-03-28 15:31:22 +0000113 return s_kp->mount(source, target, filesystemtype, mountflags, data);
114}
115
116int ki_umount(const char *path) {
Ben Murdoch58e6fbe2013-07-26 10:20:38 +0100117 ON_NOSYS_RETURN(-1);
Torne (Richard Coles)2a99a7e2013-03-28 15:31:22 +0000118 return s_kp->umount(path);
119}
120
121int ki_open(const char *path, int oflag) {
Ben Murdoch58e6fbe2013-07-26 10:20:38 +0100122 ON_NOSYS_RETURN(-1);
Torne (Richard Coles)2a99a7e2013-03-28 15:31:22 +0000123 return s_kp->open(path, oflag);
124}
125
126ssize_t ki_read(int fd, void *buf, size_t nbyte) {
Ben Murdoch58e6fbe2013-07-26 10:20:38 +0100127 ON_NOSYS_RETURN(-1);
Torne (Richard Coles)2a99a7e2013-03-28 15:31:22 +0000128 return s_kp->read(fd, buf, nbyte);
129}
130
131ssize_t ki_write(int fd, const void *buf, size_t nbyte) {
Ben Murdoch58e6fbe2013-07-26 10:20:38 +0100132 ON_NOSYS_RETURN(-1);
Torne (Richard Coles)2a99a7e2013-03-28 15:31:22 +0000133 return s_kp->write(fd, buf, nbyte);
134}
135
136int ki_fstat(int fd, struct stat *buf){
Ben Murdoch58e6fbe2013-07-26 10:20:38 +0100137 ON_NOSYS_RETURN(-1);
Torne (Richard Coles)2a99a7e2013-03-28 15:31:22 +0000138 return s_kp->fstat(fd, buf);
139}
140
141int ki_getdents(int fd, void *buf, unsigned int count) {
Ben Murdoch58e6fbe2013-07-26 10:20:38 +0100142 ON_NOSYS_RETURN(-1);
Torne (Richard Coles)2a99a7e2013-03-28 15:31:22 +0000143 return s_kp->getdents(fd, buf, count);
144}
145
Torne (Richard Coles)90dce4d2013-05-29 14:40:03 +0100146int ki_ftruncate(int fd, off_t length) {
Ben Murdoch58e6fbe2013-07-26 10:20:38 +0100147 ON_NOSYS_RETURN(-1);
Torne (Richard Coles)90dce4d2013-05-29 14:40:03 +0100148 return s_kp->ftruncate(fd, length);
149}
150
Torne (Richard Coles)2a99a7e2013-03-28 15:31:22 +0000151int ki_fsync(int fd) {
Ben Murdoch58e6fbe2013-07-26 10:20:38 +0100152 ON_NOSYS_RETURN(-1);
Torne (Richard Coles)2a99a7e2013-03-28 15:31:22 +0000153 return s_kp->fsync(fd);
154}
155
156int ki_isatty(int fd) {
Ben Murdoch58e6fbe2013-07-26 10:20:38 +0100157 ON_NOSYS_RETURN(0);
Torne (Richard Coles)2a99a7e2013-03-28 15:31:22 +0000158 return s_kp->isatty(fd);
159}
160
161int ki_close(int fd) {
Ben Murdoch58e6fbe2013-07-26 10:20:38 +0100162 ON_NOSYS_RETURN(-1);
Torne (Richard Coles)2a99a7e2013-03-28 15:31:22 +0000163 return s_kp->close(fd);
164}
165
166off_t ki_lseek(int fd, off_t offset, int whence) {
Ben Murdoch58e6fbe2013-07-26 10:20:38 +0100167 ON_NOSYS_RETURN(-1);
Torne (Richard Coles)2a99a7e2013-03-28 15:31:22 +0000168 return s_kp->lseek(fd, offset, whence);
169}
170
171int ki_remove(const char* path) {
Ben Murdoch58e6fbe2013-07-26 10:20:38 +0100172 ON_NOSYS_RETURN(-1);
Torne (Richard Coles)2a99a7e2013-03-28 15:31:22 +0000173 return s_kp->remove(path);
174}
175
176int ki_unlink(const char* path) {
Ben Murdoch58e6fbe2013-07-26 10:20:38 +0100177 ON_NOSYS_RETURN(-1);
Torne (Richard Coles)2a99a7e2013-03-28 15:31:22 +0000178 return s_kp->unlink(path);
179}
180
181int ki_access(const char* path, int amode) {
Ben Murdoch58e6fbe2013-07-26 10:20:38 +0100182 ON_NOSYS_RETURN(-1);
Torne (Richard Coles)2a99a7e2013-03-28 15:31:22 +0000183 return s_kp->access(path, amode);
184}
185
186int ki_link(const char* oldpath, const char* newpath) {
Ben Murdoch58e6fbe2013-07-26 10:20:38 +0100187 ON_NOSYS_RETURN(-1);
Torne (Richard Coles)2a99a7e2013-03-28 15:31:22 +0000188 return s_kp->link(oldpath, newpath);
189}
190
191int ki_symlink(const char* oldpath, const char* newpath) {
Ben Murdoch58e6fbe2013-07-26 10:20:38 +0100192 ON_NOSYS_RETURN(-1);
Torne (Richard Coles)2a99a7e2013-03-28 15:31:22 +0000193 return s_kp->symlink(oldpath, newpath);
194}
195
196void* ki_mmap(void* addr, size_t length, int prot, int flags, int fd,
197 off_t offset) {
Ben Murdoch58e6fbe2013-07-26 10:20:38 +0100198 ON_NOSYS_RETURN(MAP_FAILED);
Torne (Richard Coles)2a99a7e2013-03-28 15:31:22 +0000199 return s_kp->mmap(addr, length, prot, flags, fd, offset);
200}
201
202int ki_munmap(void* addr, size_t length) {
Ben Murdoch58e6fbe2013-07-26 10:20:38 +0100203 ON_NOSYS_RETURN(-1);
Torne (Richard Coles)2a99a7e2013-03-28 15:31:22 +0000204 return s_kp->munmap(addr, length);
205}
206
207int ki_open_resource(const char* file) {
Ben Murdoch58e6fbe2013-07-26 10:20:38 +0100208 ON_NOSYS_RETURN(-1); return s_kp->open_resource(file);
Torne (Richard Coles)2a99a7e2013-03-28 15:31:22 +0000209}
Ben Murdocheb525c52013-07-10 11:40:50 +0100210
211int ki_ioctl(int d, int request, char* argp) {
Ben Murdoch58e6fbe2013-07-26 10:20:38 +0100212 ON_NOSYS_RETURN(-1);
Ben Murdocheb525c52013-07-10 11:40:50 +0100213 return s_kp->ioctl(d, request, argp);
214}
215
216int ki_chown(const char* path, uid_t owner, gid_t group) {
Ben Murdoch58e6fbe2013-07-26 10:20:38 +0100217 ON_NOSYS_RETURN(-1);
Ben Murdocheb525c52013-07-10 11:40:50 +0100218 return s_kp->chown(path, owner, group);
219}
220
221int ki_fchown(int fd, uid_t owner, gid_t group) {
Ben Murdoch58e6fbe2013-07-26 10:20:38 +0100222 ON_NOSYS_RETURN(-1);
Ben Murdocheb525c52013-07-10 11:40:50 +0100223 return s_kp->fchown(fd, owner, group);
224}
225
226int ki_lchown(const char* path, uid_t owner, gid_t group) {
Ben Murdoch58e6fbe2013-07-26 10:20:38 +0100227 ON_NOSYS_RETURN(-1);
Ben Murdocheb525c52013-07-10 11:40:50 +0100228 return s_kp->lchown(path, owner, group);
229}
230
231int ki_utime(const char* filename, const struct utimbuf* times) {
Ben Murdoch58e6fbe2013-07-26 10:20:38 +0100232 ON_NOSYS_RETURN(-1);
Ben Murdocheb525c52013-07-10 11:40:50 +0100233 return s_kp->utime(filename, times);
234}
Torne (Richard Coles)a36e5922013-08-05 13:57:33 +0100235
Ben Murdoch32409262013-08-07 11:04:47 +0100236int ki_poll(struct pollfd *fds, nfds_t nfds, int timeout) {
237 return s_kp->poll(fds, nfds, timeout);
238}
239
240int ki_select(int nfds, fd_set* readfds, fd_set* writefds,
241 fd_set* exceptfds, struct timeval* timeout) {
242 return s_kp->select(nfds, readfds, writefds, exceptfds, timeout);
243}
244
Ben Murdochbb1529c2013-08-08 10:24:53 +0100245int ki_tcflush(int fd, int queue_selector) {
246 ON_NOSYS_RETURN(-1);
247 return s_kp->tcflush(fd, queue_selector);
248}
249
250int ki_tcgetattr(int fd, struct termios* termios_p) {
251 ON_NOSYS_RETURN(-1);
252 return s_kp->tcgetattr(fd, termios_p);
253}
254
255int ki_tcsetattr(int fd, int optional_actions,
256 const struct termios *termios_p) {
257 ON_NOSYS_RETURN(-1);
258 return s_kp->tcsetattr(fd, optional_actions, termios_p);
259}
260
Torne (Richard Coles)a36e5922013-08-05 13:57:33 +0100261#ifdef PROVIDES_SOCKET_API
262// Socket Functions
263int ki_accept(int fd, struct sockaddr* addr, socklen_t* len) {
264 return s_kp->accept(fd, addr, len);
265}
266
267int ki_bind(int fd, const struct sockaddr* addr, socklen_t len) {
268 return s_kp->bind(fd, addr, len);
269}
270
271int ki_connect(int fd, const struct sockaddr* addr, socklen_t len) {
272 return s_kp->connect(fd, addr, len);
273}
274
Ben Murdochbb1529c2013-08-08 10:24:53 +0100275struct hostent* ki_gethostbyname(const char* name) {
276 return s_kp->gethostbyname(name);
277}
278
Torne (Richard Coles)a36e5922013-08-05 13:57:33 +0100279int ki_getpeername(int fd, struct sockaddr* addr, socklen_t* len) {
280 return s_kp->getpeername(fd, addr, len);
281}
282
283int ki_getsockname(int fd, struct sockaddr* addr, socklen_t* len) {
284 return s_kp->getsockname(fd, addr, len);
285}
286int ki_getsockopt(int fd, int lvl, int optname, void* optval, socklen_t* len) {
287 return s_kp->getsockopt(fd, lvl, optname, optval, len);
288}
289
Ben Murdochbb1529c2013-08-08 10:24:53 +0100290void ki_herror(const char *s) {
291 return s_kp->herror(s);
292}
293
294const char *ki_hstrerror(int err) {
295 return s_kp->hstrerror(err);
296}
297
Torne (Richard Coles)a36e5922013-08-05 13:57:33 +0100298int ki_listen(int fd, int backlog) {
299 return s_kp->listen(fd, backlog);
300}
301
302ssize_t ki_recv(int fd, void* buf, size_t len, int flags) {
303 return s_kp->recv(fd, buf, len, flags);
304}
305
306ssize_t ki_recvfrom(int fd, void* buf, size_t len, int flags,
307 struct sockaddr* addr, socklen_t* addrlen) {
308 return s_kp->recvfrom(fd, buf, len, flags, addr, addrlen);
309}
310
311ssize_t ki_recvmsg(int fd, struct msghdr* msg, int flags) {
312 return s_kp->recvmsg(fd, msg, flags);
313}
314
315ssize_t ki_send(int fd, const void* buf, size_t len, int flags) {
316 return s_kp->send(fd, buf, len, flags);
317}
318
319ssize_t ki_sendto(int fd, const void* buf, size_t len, int flags,
320 const struct sockaddr* addr, socklen_t addrlen) {
321 return s_kp->sendto(fd, buf, len, flags, addr, addrlen);
322}
323
324ssize_t ki_sendmsg(int fd, const struct msghdr* msg, int flags) {
325 return s_kp->sendmsg(fd, msg, flags);
326}
327
328int ki_setsockopt(int fd, int lvl, int optname, const void* optval,
329 socklen_t len) {
330 return s_kp->setsockopt(fd, lvl, optname, optval, len);
331}
332
333int ki_shutdown(int fd, int how) {
334 return s_kp->shutdown(fd, how);
335}
336
337int ki_socket(int domain, int type, int protocol) {
338 return s_kp->socket(domain, type, protocol);
339}
340
341int ki_socketpair(int domain, int type, int protocol, int* sv) {
342 return s_kp->socketpair(domain, type, protocol, sv);
343}
Ben Murdochbb1529c2013-08-08 10:24:53 +0100344#endif // PROVIDES_SOCKET_API