| Index: native_client_sdk/src/libraries/nacl_mounts/kernel_wrap_win.cc
|
| diff --git a/native_client_sdk/src/libraries/nacl_mounts/kernel_wrap_win.cc b/native_client_sdk/src/libraries/nacl_mounts/kernel_wrap_win.cc
|
| new file mode 100644
|
| index 0000000000000000000000000000000000000000..39e31123d0a768e949b4705f8786aae2babac944
|
| --- /dev/null
|
| +++ b/native_client_sdk/src/libraries/nacl_mounts/kernel_wrap_win.cc
|
| @@ -0,0 +1,218 @@
|
| +/* Copyright (c) 2012 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 "nacl_mounts/kernel_wrap.h"
|
| +#include <errno.h>
|
| +#include <fcntl.h>
|
| +#include <stdarg.h>
|
| +#include <string.h>
|
| +#include <sys/types.h> // This must be included before <sys/stat.h>.
|
| +#include <sys/stat.h>
|
| +#include "nacl_mounts/kernel_intercept.h"
|
| +
|
| +namespace {
|
| +
|
| +template <typename SrcStat, typename DstStat>
|
| +void CopyStat(const SrcStat* src, DstStat* dst) {
|
| + memset(dst, 0, sizeof(DstStat));
|
| + dst->st_dev = src->st_dev;
|
| + dst->st_ino = src->st_ino;
|
| + dst->st_mode = src->st_mode;
|
| + dst->st_nlink = src->st_nlink;
|
| + dst->st_uid = src->st_uid;
|
| + dst->st_gid = src->st_gid;
|
| + dst->st_rdev = src->st_rdev;
|
| + dst->st_size = src->st_size;
|
| + dst->st_atime = src->st_atime;
|
| + dst->st_mtime = src->st_mtime;
|
| + dst->st_ctime = src->st_ctime;
|
| +}
|
| +
|
| +} // namespace
|
| +
|
| +EXTERN_C_BEGIN
|
| +
|
| +// This needs to be included because it is defined in read.c, which we wish to
|
| +// override. Define with dummy values for now... though this seems like it will
|
| +// break ftelli64/fgetpos/fstream.
|
| +char _lookuptrailbytes[256] = {0};
|
| +
|
| +int _access(const char* path, int amode) {
|
| + return ki_access(path, amode);
|
| +}
|
| +
|
| +int _chdir(const char* path) {
|
| + return ki_chdir(path);
|
| +}
|
| +
|
| +int _chmod(const char* path, mode_t mode) {
|
| + return ki_chmod(path, mode);
|
| +}
|
| +
|
| +int _close(int fd) {
|
| + return ki_close(fd);
|
| +}
|
| +
|
| +int _close_nolock(int fd) {
|
| + return ki_close(fd);
|
| +}
|
| +
|
| +int _dup(int oldfd) {
|
| + return ki_dup(oldfd);
|
| +}
|
| +
|
| +int _fstat32(int fd, struct _stat32* buf) {
|
| + struct stat ki_buf;
|
| + int res = ki_fstat(fd, &ki_buf);
|
| + CopyStat(&ki_buf, buf);
|
| + return res;
|
| +}
|
| +
|
| +int _fstat64(int fd, struct _stat64* buf) {
|
| + struct stat ki_buf;
|
| + int res = ki_fstat(fd, &ki_buf);
|
| + CopyStat(&ki_buf, buf);
|
| + return res;
|
| +}
|
| +
|
| +int _fstat32i64(int fd, struct _stat32i64* buf) {
|
| + struct stat ki_buf;
|
| + int res = ki_fstat(fd, &ki_buf);
|
| + CopyStat(&ki_buf, buf);
|
| + return res;
|
| +}
|
| +
|
| +int _fstat64i32(int fd, struct _stat64i32* buf) {
|
| + struct stat ki_buf;
|
| + int res = ki_fstat(fd, &ki_buf);
|
| + CopyStat(&ki_buf, buf);
|
| + return res;
|
| +}
|
| +
|
| +int fsync(int fd) {
|
| + return ki_fsync(fd);
|
| +}
|
| +
|
| +char* _getcwd(char* buf, int size) {
|
| + // gtest uses getcwd in a static initializer. If we haven't initialized the
|
| + // kernel-intercept yet, just return ".".
|
| + if (!ki_is_initialized()) {
|
| + if (size < 2) {
|
| + errno = ERANGE;
|
| + return NULL;
|
| + }
|
| + buf[0] = '.';
|
| + buf[1] = 0;
|
| + return buf;
|
| + }
|
| + return ki_getcwd(buf, size);
|
| +}
|
| +
|
| +char* getwd(char* buf) {
|
| + return ki_getwd(buf);
|
| +}
|
| +
|
| +int getdents(int fd, void* buf, unsigned int count) {
|
| + return ki_getdents(fd, buf, count);
|
| +}
|
| +
|
| +int _isatty(int fd) {
|
| + return ki_isatty(fd);
|
| +}
|
| +
|
| +off_t _lseek(int fd, off_t offset, int whence) {
|
| + return ki_lseek(fd, offset, whence);
|
| +}
|
| +
|
| +int _mkdir(const char* path) {
|
| + return ki_mkdir(path, 0777);
|
| +}
|
| +
|
| +int mount(const char* source, const char* target, const char* filesystemtype,
|
| + unsigned long mountflags, const void *data) {
|
| + return ki_mount(source, target, filesystemtype, mountflags, data);
|
| +}
|
| +
|
| +int _open(const char* path, int oflag, ...) {
|
| +#if 0
|
| + // TODO(binji): ki_open should use the pmode parameter. When it does, this
|
| + // will be necessary to add in.
|
| + va_list list;
|
| + int pmode = 0;
|
| + if (oflag & _O_CREAT) {
|
| + va_start(list, oflag);
|
| + pmode = va_arg(list, int);
|
| + va_end(list);
|
| + }
|
| +#endif
|
| + return ki_open(path, oflag);
|
| +}
|
| +
|
| +int _sopen(const char* path, int oflag, int shflag) {
|
| + return ki_open(path, oflag);
|
| +}
|
| +
|
| +errno_t _sopen_s(int* pfh, const char* path, int oflag, int shflag, int pmode) {
|
| + *pfh = ki_open(path, oflag);
|
| + return (*pfh < 0) ? errno : 0;
|
| +}
|
| +
|
| +int _read(int fd, void* buf, size_t nbyte) {
|
| + return ki_read(fd, buf, nbyte);
|
| +}
|
| +
|
| +int _read_nolock(int fd, void* buf, size_t nbyte) {
|
| + return ki_read(fd, buf, nbyte);
|
| +}
|
| +
|
| +int remove(const char* path) {
|
| + return ki_remove(path);
|
| +}
|
| +
|
| +int _rmdir(const char* path) {
|
| + return ki_rmdir(path);
|
| +}
|
| +
|
| +int _stat32(const char* path, struct _stat32* buf) {
|
| + struct stat ki_buf;
|
| + int res = ki_stat(path, &ki_buf);
|
| + CopyStat(&ki_buf, buf);
|
| + return res;
|
| +}
|
| +
|
| +int _stat64(const char* path, struct _stat64* buf) {
|
| + struct stat ki_buf;
|
| + int res = ki_stat(path, &ki_buf);
|
| + CopyStat(&ki_buf, buf);
|
| + return res;
|
| +}
|
| +
|
| +int _stat64i32(const char* path, struct _stat64i32* buf) {
|
| + struct stat ki_buf;
|
| + int res = ki_stat(path, &ki_buf);
|
| + CopyStat(&ki_buf, buf);
|
| + return res;
|
| +}
|
| +
|
| +int _stat32i64(const char* path, struct _stat32i64* buf) {
|
| + struct stat ki_buf;
|
| + int res = ki_stat(path, &ki_buf);
|
| + CopyStat(&ki_buf, buf);
|
| + return res;
|
| +}
|
| +
|
| +int umount(const char* path) {
|
| + return ki_umount(path);
|
| +}
|
| +
|
| +int _unlink(const char* path) {
|
| + return ki_unlink(path);
|
| +}
|
| +
|
| +int _write(int fd, const void* buf, size_t nbyte) {
|
| + return ki_write(fd, buf, nbyte);
|
| +}
|
| +
|
| +EXTERN_C_END
|
|
|