2015-07-09 07:20:15 +00:00
|
|
|
/*-
|
|
|
|
* Copyright (c) 2015 Nuxi, https://nuxi.nl/
|
|
|
|
*
|
|
|
|
* Redistribution and use in source and binary forms, with or without
|
|
|
|
* modification, are permitted provided that the following conditions
|
|
|
|
* are met:
|
|
|
|
* 1. Redistributions of source code must retain the above copyright
|
|
|
|
* notice, this list of conditions and the following disclaimer.
|
|
|
|
* 2. Redistributions in binary form must reproduce the above copyright
|
|
|
|
* notice, this list of conditions and the following disclaimer in the
|
|
|
|
* documentation and/or other materials provided with the distribution.
|
|
|
|
*
|
|
|
|
* THIS SOFTWARE IS PROVIDED BY THE AUTHOR AND CONTRIBUTORS ``AS IS'' AND
|
|
|
|
* ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE
|
|
|
|
* IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE
|
|
|
|
* ARE DISCLAIMED. IN NO EVENT SHALL THE AUTHOR OR CONTRIBUTORS BE LIABLE
|
|
|
|
* FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL
|
|
|
|
* DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS
|
|
|
|
* OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION)
|
|
|
|
* HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT
|
|
|
|
* LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY
|
|
|
|
* OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF
|
|
|
|
* SUCH DAMAGE.
|
|
|
|
*/
|
|
|
|
|
|
|
|
#include <sys/cdefs.h>
|
|
|
|
__FBSDID("$FreeBSD$");
|
|
|
|
|
2015-07-09 16:07:01 +00:00
|
|
|
#include <sys/param.h>
|
Make fstat() and friends work.
Summary:
CloudABI provides access to two different stat structures:
- fdstat, containing file descriptor level status: oflags, file
descriptor type and Capsicum rights, used by cap_rights_get(),
fcntl(F_GETFL), getsockopt(SO_TYPE).
- filestat, containing your regular file status: timestamps, inode
number, used by fstat().
Unlike FreeBSD's stat::st_mode, CloudABI file descriptor types don't
have overloaded meanings (e.g., returning S_ISCHR() for kqueues). Add a
utility function to extract the type of a file descriptor accurately.
CloudABI does not work with O_ACCMODEs. File descriptors have two sets
of Capsicum-style rights: rights that apply to the file descriptor
itself ('base') and rights that apply to any new file descriptors
yielded through openat() ('inheriting'). Though not perfect, we can
pretty safely decompose Capsicum rights to such a pair. This is done in
convert_capabilities().
Test Plan: Tests for these system calls are fairly extensive in cloudlibc.
Reviewers: jonathan, mjg, #manpages
Reviewed By: mjg
Subscribers: imp
Differential Revision: https://reviews.freebsd.org/D3171
2015-07-28 06:36:49 +00:00
|
|
|
#include <sys/capsicum.h>
|
2015-07-09 16:07:01 +00:00
|
|
|
#include <sys/filedesc.h>
|
|
|
|
#include <sys/proc.h>
|
2015-08-01 07:51:48 +00:00
|
|
|
#include <sys/mman.h>
|
Make fstat() and friends work.
Summary:
CloudABI provides access to two different stat structures:
- fdstat, containing file descriptor level status: oflags, file
descriptor type and Capsicum rights, used by cap_rights_get(),
fcntl(F_GETFL), getsockopt(SO_TYPE).
- filestat, containing your regular file status: timestamps, inode
number, used by fstat().
Unlike FreeBSD's stat::st_mode, CloudABI file descriptor types don't
have overloaded meanings (e.g., returning S_ISCHR() for kqueues). Add a
utility function to extract the type of a file descriptor accurately.
CloudABI does not work with O_ACCMODEs. File descriptors have two sets
of Capsicum-style rights: rights that apply to the file descriptor
itself ('base') and rights that apply to any new file descriptors
yielded through openat() ('inheriting'). Though not perfect, we can
pretty safely decompose Capsicum rights to such a pair. This is done in
convert_capabilities().
Test Plan: Tests for these system calls are fairly extensive in cloudlibc.
Reviewers: jonathan, mjg, #manpages
Reviewed By: mjg
Subscribers: imp
Differential Revision: https://reviews.freebsd.org/D3171
2015-07-28 06:36:49 +00:00
|
|
|
#include <sys/socketvar.h>
|
2015-07-09 16:07:01 +00:00
|
|
|
#include <sys/syscallsubr.h>
|
|
|
|
#include <sys/sysproto.h>
|
Make fstat() and friends work.
Summary:
CloudABI provides access to two different stat structures:
- fdstat, containing file descriptor level status: oflags, file
descriptor type and Capsicum rights, used by cap_rights_get(),
fcntl(F_GETFL), getsockopt(SO_TYPE).
- filestat, containing your regular file status: timestamps, inode
number, used by fstat().
Unlike FreeBSD's stat::st_mode, CloudABI file descriptor types don't
have overloaded meanings (e.g., returning S_ISCHR() for kqueues). Add a
utility function to extract the type of a file descriptor accurately.
CloudABI does not work with O_ACCMODEs. File descriptors have two sets
of Capsicum-style rights: rights that apply to the file descriptor
itself ('base') and rights that apply to any new file descriptors
yielded through openat() ('inheriting'). Though not perfect, we can
pretty safely decompose Capsicum rights to such a pair. This is done in
convert_capabilities().
Test Plan: Tests for these system calls are fairly extensive in cloudlibc.
Reviewers: jonathan, mjg, #manpages
Reviewed By: mjg
Subscribers: imp
Differential Revision: https://reviews.freebsd.org/D3171
2015-07-28 06:36:49 +00:00
|
|
|
#include <sys/systm.h>
|
2015-07-09 16:07:01 +00:00
|
|
|
#include <sys/unistd.h>
|
Make fstat() and friends work.
Summary:
CloudABI provides access to two different stat structures:
- fdstat, containing file descriptor level status: oflags, file
descriptor type and Capsicum rights, used by cap_rights_get(),
fcntl(F_GETFL), getsockopt(SO_TYPE).
- filestat, containing your regular file status: timestamps, inode
number, used by fstat().
Unlike FreeBSD's stat::st_mode, CloudABI file descriptor types don't
have overloaded meanings (e.g., returning S_ISCHR() for kqueues). Add a
utility function to extract the type of a file descriptor accurately.
CloudABI does not work with O_ACCMODEs. File descriptors have two sets
of Capsicum-style rights: rights that apply to the file descriptor
itself ('base') and rights that apply to any new file descriptors
yielded through openat() ('inheriting'). Though not perfect, we can
pretty safely decompose Capsicum rights to such a pair. This is done in
convert_capabilities().
Test Plan: Tests for these system calls are fairly extensive in cloudlibc.
Reviewers: jonathan, mjg, #manpages
Reviewed By: mjg
Subscribers: imp
Differential Revision: https://reviews.freebsd.org/D3171
2015-07-28 06:36:49 +00:00
|
|
|
#include <sys/vnode.h>
|
2015-07-09 16:07:01 +00:00
|
|
|
|
2015-07-09 07:20:15 +00:00
|
|
|
#include <compat/cloudabi/cloudabi_proto.h>
|
Make fstat() and friends work.
Summary:
CloudABI provides access to two different stat structures:
- fdstat, containing file descriptor level status: oflags, file
descriptor type and Capsicum rights, used by cap_rights_get(),
fcntl(F_GETFL), getsockopt(SO_TYPE).
- filestat, containing your regular file status: timestamps, inode
number, used by fstat().
Unlike FreeBSD's stat::st_mode, CloudABI file descriptor types don't
have overloaded meanings (e.g., returning S_ISCHR() for kqueues). Add a
utility function to extract the type of a file descriptor accurately.
CloudABI does not work with O_ACCMODEs. File descriptors have two sets
of Capsicum-style rights: rights that apply to the file descriptor
itself ('base') and rights that apply to any new file descriptors
yielded through openat() ('inheriting'). Though not perfect, we can
pretty safely decompose Capsicum rights to such a pair. This is done in
convert_capabilities().
Test Plan: Tests for these system calls are fairly extensive in cloudlibc.
Reviewers: jonathan, mjg, #manpages
Reviewed By: mjg
Subscribers: imp
Differential Revision: https://reviews.freebsd.org/D3171
2015-07-28 06:36:49 +00:00
|
|
|
#include <compat/cloudabi/cloudabi_syscalldefs.h>
|
|
|
|
#include <compat/cloudabi/cloudabi_util.h>
|
|
|
|
|
|
|
|
/* Translation between CloudABI and Capsicum rights. */
|
|
|
|
#define RIGHTS_MAPPINGS \
|
|
|
|
MAPPING(CLOUDABI_RIGHT_FD_DATASYNC, CAP_FSYNC) \
|
|
|
|
MAPPING(CLOUDABI_RIGHT_FD_READ, CAP_READ) \
|
|
|
|
MAPPING(CLOUDABI_RIGHT_FD_SEEK, CAP_SEEK) \
|
|
|
|
MAPPING(CLOUDABI_RIGHT_FD_STAT_PUT_FLAGS, CAP_FCNTL) \
|
|
|
|
MAPPING(CLOUDABI_RIGHT_FD_SYNC, CAP_FSYNC) \
|
|
|
|
MAPPING(CLOUDABI_RIGHT_FD_TELL, CAP_SEEK_TELL) \
|
|
|
|
MAPPING(CLOUDABI_RIGHT_FD_WRITE, CAP_WRITE) \
|
|
|
|
MAPPING(CLOUDABI_RIGHT_FILE_ADVISE) \
|
|
|
|
MAPPING(CLOUDABI_RIGHT_FILE_ALLOCATE, CAP_WRITE) \
|
|
|
|
MAPPING(CLOUDABI_RIGHT_FILE_CREATE_DIRECTORY, CAP_MKDIRAT) \
|
|
|
|
MAPPING(CLOUDABI_RIGHT_FILE_CREATE_FILE, CAP_CREATE) \
|
|
|
|
MAPPING(CLOUDABI_RIGHT_FILE_CREATE_FIFO, CAP_MKFIFOAT) \
|
|
|
|
MAPPING(CLOUDABI_RIGHT_FILE_LINK_SOURCE, CAP_LOOKUP) \
|
|
|
|
MAPPING(CLOUDABI_RIGHT_FILE_LINK_TARGET, CAP_LINKAT) \
|
|
|
|
MAPPING(CLOUDABI_RIGHT_FILE_OPEN, CAP_LOOKUP) \
|
|
|
|
MAPPING(CLOUDABI_RIGHT_FILE_READDIR, CAP_READ) \
|
|
|
|
MAPPING(CLOUDABI_RIGHT_FILE_READLINK, CAP_LOOKUP) \
|
|
|
|
MAPPING(CLOUDABI_RIGHT_FILE_RENAME_SOURCE, CAP_RENAMEAT) \
|
|
|
|
MAPPING(CLOUDABI_RIGHT_FILE_RENAME_TARGET, CAP_LINKAT) \
|
|
|
|
MAPPING(CLOUDABI_RIGHT_FILE_STAT_FGET, CAP_FSTAT) \
|
|
|
|
MAPPING(CLOUDABI_RIGHT_FILE_STAT_FPUT_SIZE, CAP_FTRUNCATE) \
|
|
|
|
MAPPING(CLOUDABI_RIGHT_FILE_STAT_FPUT_TIMES, CAP_FUTIMES) \
|
|
|
|
MAPPING(CLOUDABI_RIGHT_FILE_STAT_GET, CAP_FSTATAT) \
|
|
|
|
MAPPING(CLOUDABI_RIGHT_FILE_STAT_PUT_TIMES, CAP_FUTIMESAT) \
|
|
|
|
MAPPING(CLOUDABI_RIGHT_FILE_SYMLINK, CAP_SYMLINKAT) \
|
|
|
|
MAPPING(CLOUDABI_RIGHT_FILE_UNLINK, CAP_UNLINKAT) \
|
|
|
|
MAPPING(CLOUDABI_RIGHT_MEM_MAP, CAP_MMAP) \
|
|
|
|
MAPPING(CLOUDABI_RIGHT_MEM_MAP_EXEC, CAP_MMAP_X) \
|
|
|
|
MAPPING(CLOUDABI_RIGHT_POLL_FD_READWRITE, CAP_EVENT) \
|
|
|
|
MAPPING(CLOUDABI_RIGHT_POLL_MODIFY, CAP_KQUEUE_CHANGE) \
|
|
|
|
MAPPING(CLOUDABI_RIGHT_POLL_PROC_TERMINATE, CAP_PDWAIT) \
|
|
|
|
MAPPING(CLOUDABI_RIGHT_POLL_WAIT, CAP_KQUEUE_EVENT) \
|
|
|
|
MAPPING(CLOUDABI_RIGHT_PROC_EXEC, CAP_FEXECVE) \
|
|
|
|
MAPPING(CLOUDABI_RIGHT_SOCK_ACCEPT, CAP_ACCEPT) \
|
|
|
|
MAPPING(CLOUDABI_RIGHT_SOCK_BIND_DIRECTORY, CAP_BINDAT) \
|
|
|
|
MAPPING(CLOUDABI_RIGHT_SOCK_BIND_SOCKET, CAP_BIND) \
|
|
|
|
MAPPING(CLOUDABI_RIGHT_SOCK_CONNECT_DIRECTORY, CAP_CONNECTAT) \
|
|
|
|
MAPPING(CLOUDABI_RIGHT_SOCK_CONNECT_SOCKET, CAP_CONNECT) \
|
|
|
|
MAPPING(CLOUDABI_RIGHT_SOCK_LISTEN, CAP_LISTEN) \
|
|
|
|
MAPPING(CLOUDABI_RIGHT_SOCK_SHUTDOWN, CAP_SHUTDOWN) \
|
|
|
|
MAPPING(CLOUDABI_RIGHT_SOCK_STAT_GET, CAP_GETPEERNAME, \
|
|
|
|
CAP_GETSOCKNAME, CAP_GETSOCKOPT)
|
2015-07-09 07:20:15 +00:00
|
|
|
|
|
|
|
int
|
|
|
|
cloudabi_sys_fd_close(struct thread *td, struct cloudabi_sys_fd_close_args *uap)
|
|
|
|
{
|
|
|
|
|
2015-07-09 16:07:01 +00:00
|
|
|
return (kern_close(td, uap->fd));
|
2015-07-09 07:20:15 +00:00
|
|
|
}
|
|
|
|
|
|
|
|
int
|
|
|
|
cloudabi_sys_fd_create1(struct thread *td,
|
|
|
|
struct cloudabi_sys_fd_create1_args *uap)
|
|
|
|
{
|
2015-08-01 07:51:48 +00:00
|
|
|
struct filecaps fcaps = {};
|
2015-07-23 13:52:53 +00:00
|
|
|
struct socket_args socket_args = {
|
|
|
|
.domain = AF_UNIX,
|
|
|
|
};
|
2015-07-09 07:20:15 +00:00
|
|
|
|
2015-07-23 13:52:53 +00:00
|
|
|
switch (uap->type) {
|
2015-08-05 07:37:06 +00:00
|
|
|
case CLOUDABI_FILETYPE_POLL:
|
|
|
|
cap_rights_init(&fcaps.fc_rights, CAP_FSTAT, CAP_KQUEUE);
|
|
|
|
return (kern_kqueue(td, 0, &fcaps));
|
2015-08-01 07:51:48 +00:00
|
|
|
case CLOUDABI_FILETYPE_SHARED_MEMORY:
|
|
|
|
cap_rights_init(&fcaps.fc_rights, CAP_FSTAT, CAP_FTRUNCATE,
|
|
|
|
CAP_MMAP_RWX);
|
|
|
|
return (kern_shm_open(td, SHM_ANON, O_RDWR, 0, &fcaps));
|
2015-07-23 13:52:53 +00:00
|
|
|
case CLOUDABI_FILETYPE_SOCKET_DGRAM:
|
|
|
|
socket_args.type = SOCK_DGRAM;
|
|
|
|
return (sys_socket(td, &socket_args));
|
|
|
|
case CLOUDABI_FILETYPE_SOCKET_SEQPACKET:
|
|
|
|
socket_args.type = SOCK_SEQPACKET;
|
|
|
|
return (sys_socket(td, &socket_args));
|
|
|
|
case CLOUDABI_FILETYPE_SOCKET_STREAM:
|
|
|
|
socket_args.type = SOCK_STREAM;
|
|
|
|
return (sys_socket(td, &socket_args));
|
|
|
|
default:
|
|
|
|
return (EINVAL);
|
|
|
|
}
|
2015-07-09 07:20:15 +00:00
|
|
|
}
|
|
|
|
|
|
|
|
int
|
|
|
|
cloudabi_sys_fd_create2(struct thread *td,
|
|
|
|
struct cloudabi_sys_fd_create2_args *uap)
|
|
|
|
{
|
2015-07-29 17:18:27 +00:00
|
|
|
struct filecaps fcaps1 = {}, fcaps2 = {};
|
2015-07-23 13:52:53 +00:00
|
|
|
int fds[2];
|
|
|
|
int error;
|
|
|
|
|
|
|
|
switch (uap->type) {
|
2015-07-29 17:18:27 +00:00
|
|
|
case CLOUDABI_FILETYPE_FIFO:
|
|
|
|
/*
|
|
|
|
* CloudABI pipes are unidirectional. Restrict rights on
|
|
|
|
* the pipe to simulate this.
|
|
|
|
*/
|
|
|
|
cap_rights_init(&fcaps1.fc_rights, CAP_EVENT, CAP_FCNTL,
|
|
|
|
CAP_FSTAT, CAP_READ);
|
|
|
|
fcaps1.fc_fcntls = CAP_FCNTL_SETFL;
|
|
|
|
cap_rights_init(&fcaps2.fc_rights, CAP_EVENT, CAP_FCNTL,
|
|
|
|
CAP_FSTAT, CAP_WRITE);
|
|
|
|
fcaps2.fc_fcntls = CAP_FCNTL_SETFL;
|
|
|
|
error = kern_pipe(td, fds, 0, &fcaps1, &fcaps2);
|
|
|
|
break;
|
2015-07-23 13:52:53 +00:00
|
|
|
case CLOUDABI_FILETYPE_SOCKET_DGRAM:
|
|
|
|
error = kern_socketpair(td, AF_UNIX, SOCK_DGRAM, 0, fds);
|
|
|
|
break;
|
|
|
|
case CLOUDABI_FILETYPE_SOCKET_SEQPACKET:
|
|
|
|
error = kern_socketpair(td, AF_UNIX, SOCK_SEQPACKET, 0, fds);
|
|
|
|
break;
|
|
|
|
case CLOUDABI_FILETYPE_SOCKET_STREAM:
|
|
|
|
error = kern_socketpair(td, AF_UNIX, SOCK_STREAM, 0, fds);
|
|
|
|
break;
|
|
|
|
default:
|
|
|
|
return (EINVAL);
|
|
|
|
}
|
2015-07-09 07:20:15 +00:00
|
|
|
|
2015-07-23 13:52:53 +00:00
|
|
|
if (error == 0) {
|
|
|
|
td->td_retval[0] = fds[0];
|
|
|
|
td->td_retval[1] = fds[1];
|
|
|
|
}
|
|
|
|
return (0);
|
2015-07-09 07:20:15 +00:00
|
|
|
}
|
|
|
|
|
|
|
|
int
|
|
|
|
cloudabi_sys_fd_datasync(struct thread *td,
|
|
|
|
struct cloudabi_sys_fd_datasync_args *uap)
|
|
|
|
{
|
2015-07-09 16:07:01 +00:00
|
|
|
struct fsync_args fsync_args = {
|
|
|
|
.fd = uap->fd
|
|
|
|
};
|
2015-07-09 07:20:15 +00:00
|
|
|
|
2015-07-09 16:07:01 +00:00
|
|
|
/* Call into fsync(), as FreeBSD lacks fdatasync(). */
|
|
|
|
return (sys_fsync(td, &fsync_args));
|
2015-07-09 07:20:15 +00:00
|
|
|
}
|
|
|
|
|
|
|
|
int
|
|
|
|
cloudabi_sys_fd_dup(struct thread *td, struct cloudabi_sys_fd_dup_args *uap)
|
|
|
|
{
|
|
|
|
|
2015-07-11 18:53:30 +00:00
|
|
|
return (kern_dup(td, FDDUP_NORMAL, 0, uap->from, 0));
|
2015-07-09 07:20:15 +00:00
|
|
|
}
|
|
|
|
|
|
|
|
int
|
|
|
|
cloudabi_sys_fd_replace(struct thread *td,
|
|
|
|
struct cloudabi_sys_fd_replace_args *uap)
|
|
|
|
{
|
2015-07-09 16:07:01 +00:00
|
|
|
int error;
|
|
|
|
|
|
|
|
/*
|
|
|
|
* CloudABI's equivalent to dup2(). CloudABI processes should
|
|
|
|
* not depend on hardcoded file descriptor layouts, but simply
|
|
|
|
* use the file descriptor numbers that are allocated by the
|
|
|
|
* kernel. Duplicating file descriptors to arbitrary numbers
|
|
|
|
* should not be done.
|
|
|
|
*
|
|
|
|
* Invoke kern_dup() with FDDUP_MUSTREPLACE, so that we return
|
|
|
|
* EBADF when duplicating to a nonexistent file descriptor. Also
|
|
|
|
* clear the return value, as this system call yields no return
|
|
|
|
* value.
|
|
|
|
*/
|
2015-07-10 11:01:30 +00:00
|
|
|
error = kern_dup(td, FDDUP_MUSTREPLACE, 0, uap->from, uap->to);
|
2015-07-09 16:07:01 +00:00
|
|
|
td->td_retval[0] = 0;
|
|
|
|
return (error);
|
2015-07-09 07:20:15 +00:00
|
|
|
}
|
|
|
|
|
|
|
|
int
|
|
|
|
cloudabi_sys_fd_seek(struct thread *td, struct cloudabi_sys_fd_seek_args *uap)
|
|
|
|
{
|
2015-07-09 16:07:01 +00:00
|
|
|
struct lseek_args lseek_args = {
|
|
|
|
.fd = uap->fd,
|
|
|
|
.offset = uap->offset
|
|
|
|
};
|
|
|
|
|
|
|
|
switch (uap->whence) {
|
|
|
|
case CLOUDABI_WHENCE_CUR:
|
|
|
|
lseek_args.whence = SEEK_CUR;
|
|
|
|
break;
|
|
|
|
case CLOUDABI_WHENCE_END:
|
|
|
|
lseek_args.whence = SEEK_END;
|
|
|
|
break;
|
|
|
|
case CLOUDABI_WHENCE_SET:
|
|
|
|
lseek_args.whence = SEEK_SET;
|
|
|
|
break;
|
|
|
|
default:
|
|
|
|
return (EINVAL);
|
|
|
|
}
|
|
|
|
|
|
|
|
return (sys_lseek(td, &lseek_args));
|
2015-07-09 07:20:15 +00:00
|
|
|
}
|
|
|
|
|
Make fstat() and friends work.
Summary:
CloudABI provides access to two different stat structures:
- fdstat, containing file descriptor level status: oflags, file
descriptor type and Capsicum rights, used by cap_rights_get(),
fcntl(F_GETFL), getsockopt(SO_TYPE).
- filestat, containing your regular file status: timestamps, inode
number, used by fstat().
Unlike FreeBSD's stat::st_mode, CloudABI file descriptor types don't
have overloaded meanings (e.g., returning S_ISCHR() for kqueues). Add a
utility function to extract the type of a file descriptor accurately.
CloudABI does not work with O_ACCMODEs. File descriptors have two sets
of Capsicum-style rights: rights that apply to the file descriptor
itself ('base') and rights that apply to any new file descriptors
yielded through openat() ('inheriting'). Though not perfect, we can
pretty safely decompose Capsicum rights to such a pair. This is done in
convert_capabilities().
Test Plan: Tests for these system calls are fairly extensive in cloudlibc.
Reviewers: jonathan, mjg, #manpages
Reviewed By: mjg
Subscribers: imp
Differential Revision: https://reviews.freebsd.org/D3171
2015-07-28 06:36:49 +00:00
|
|
|
/* Converts a file descriptor to a CloudABI file descriptor type. */
|
|
|
|
cloudabi_filetype_t
|
|
|
|
cloudabi_convert_filetype(const struct file *fp)
|
|
|
|
{
|
|
|
|
struct socket *so;
|
|
|
|
struct vnode *vp;
|
|
|
|
|
|
|
|
switch (fp->f_type) {
|
|
|
|
case DTYPE_FIFO:
|
|
|
|
return (CLOUDABI_FILETYPE_FIFO);
|
|
|
|
case DTYPE_KQUEUE:
|
|
|
|
return (CLOUDABI_FILETYPE_POLL);
|
|
|
|
case DTYPE_PIPE:
|
|
|
|
return (CLOUDABI_FILETYPE_FIFO);
|
|
|
|
case DTYPE_PROCDESC:
|
|
|
|
return (CLOUDABI_FILETYPE_PROCESS);
|
|
|
|
case DTYPE_SHM:
|
|
|
|
return (CLOUDABI_FILETYPE_SHARED_MEMORY);
|
|
|
|
case DTYPE_SOCKET:
|
|
|
|
so = fp->f_data;
|
|
|
|
switch (so->so_type) {
|
|
|
|
case SOCK_DGRAM:
|
|
|
|
return (CLOUDABI_FILETYPE_SOCKET_DGRAM);
|
|
|
|
case SOCK_SEQPACKET:
|
|
|
|
return (CLOUDABI_FILETYPE_SOCKET_SEQPACKET);
|
|
|
|
case SOCK_STREAM:
|
|
|
|
return (CLOUDABI_FILETYPE_SOCKET_STREAM);
|
|
|
|
default:
|
|
|
|
return (CLOUDABI_FILETYPE_UNKNOWN);
|
|
|
|
}
|
|
|
|
case DTYPE_VNODE:
|
|
|
|
vp = fp->f_vnode;
|
|
|
|
switch (vp->v_type) {
|
|
|
|
case VBLK:
|
|
|
|
return (CLOUDABI_FILETYPE_BLOCK_DEVICE);
|
|
|
|
case VCHR:
|
|
|
|
return (CLOUDABI_FILETYPE_CHARACTER_DEVICE);
|
|
|
|
case VDIR:
|
|
|
|
return (CLOUDABI_FILETYPE_DIRECTORY);
|
|
|
|
case VFIFO:
|
|
|
|
return (CLOUDABI_FILETYPE_FIFO);
|
|
|
|
case VLNK:
|
|
|
|
return (CLOUDABI_FILETYPE_SYMBOLIC_LINK);
|
|
|
|
case VREG:
|
|
|
|
return (CLOUDABI_FILETYPE_REGULAR_FILE);
|
|
|
|
case VSOCK:
|
|
|
|
return (CLOUDABI_FILETYPE_SOCKET_STREAM);
|
|
|
|
default:
|
|
|
|
return (CLOUDABI_FILETYPE_UNKNOWN);
|
|
|
|
}
|
|
|
|
default:
|
|
|
|
return (CLOUDABI_FILETYPE_UNKNOWN);
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
2015-07-29 12:42:45 +00:00
|
|
|
/* Removes rights that conflict with the file descriptor type. */
|
Make fstat() and friends work.
Summary:
CloudABI provides access to two different stat structures:
- fdstat, containing file descriptor level status: oflags, file
descriptor type and Capsicum rights, used by cap_rights_get(),
fcntl(F_GETFL), getsockopt(SO_TYPE).
- filestat, containing your regular file status: timestamps, inode
number, used by fstat().
Unlike FreeBSD's stat::st_mode, CloudABI file descriptor types don't
have overloaded meanings (e.g., returning S_ISCHR() for kqueues). Add a
utility function to extract the type of a file descriptor accurately.
CloudABI does not work with O_ACCMODEs. File descriptors have two sets
of Capsicum-style rights: rights that apply to the file descriptor
itself ('base') and rights that apply to any new file descriptors
yielded through openat() ('inheriting'). Though not perfect, we can
pretty safely decompose Capsicum rights to such a pair. This is done in
convert_capabilities().
Test Plan: Tests for these system calls are fairly extensive in cloudlibc.
Reviewers: jonathan, mjg, #manpages
Reviewed By: mjg
Subscribers: imp
Differential Revision: https://reviews.freebsd.org/D3171
2015-07-28 06:36:49 +00:00
|
|
|
static void
|
2015-07-29 12:42:45 +00:00
|
|
|
cloudabi_remove_conflicting_rights(cloudabi_filetype_t filetype,
|
|
|
|
cloudabi_rights_t *base, cloudabi_rights_t *inheriting)
|
Make fstat() and friends work.
Summary:
CloudABI provides access to two different stat structures:
- fdstat, containing file descriptor level status: oflags, file
descriptor type and Capsicum rights, used by cap_rights_get(),
fcntl(F_GETFL), getsockopt(SO_TYPE).
- filestat, containing your regular file status: timestamps, inode
number, used by fstat().
Unlike FreeBSD's stat::st_mode, CloudABI file descriptor types don't
have overloaded meanings (e.g., returning S_ISCHR() for kqueues). Add a
utility function to extract the type of a file descriptor accurately.
CloudABI does not work with O_ACCMODEs. File descriptors have two sets
of Capsicum-style rights: rights that apply to the file descriptor
itself ('base') and rights that apply to any new file descriptors
yielded through openat() ('inheriting'). Though not perfect, we can
pretty safely decompose Capsicum rights to such a pair. This is done in
convert_capabilities().
Test Plan: Tests for these system calls are fairly extensive in cloudlibc.
Reviewers: jonathan, mjg, #manpages
Reviewed By: mjg
Subscribers: imp
Differential Revision: https://reviews.freebsd.org/D3171
2015-07-28 06:36:49 +00:00
|
|
|
{
|
|
|
|
|
|
|
|
/*
|
|
|
|
* CloudABI has a small number of additional rights bits to
|
|
|
|
* disambiguate between multiple purposes. Remove the bits that
|
|
|
|
* don't apply to the type of the file descriptor.
|
|
|
|
*
|
|
|
|
* As file descriptor access modes (O_ACCMODE) has been fully
|
|
|
|
* replaced by rights bits, CloudABI distinguishes between
|
|
|
|
* rights that apply to the file descriptor itself (base) versus
|
|
|
|
* rights of new file descriptors derived from them
|
|
|
|
* (inheriting). The code below approximates the pair by
|
|
|
|
* decomposing depending on the file descriptor type.
|
|
|
|
*
|
|
|
|
* We need to be somewhat accurate about which actions can
|
|
|
|
* actually be performed on the file descriptor, as functions
|
|
|
|
* like fcntl(fd, F_GETFL) are emulated on top of this.
|
|
|
|
*/
|
|
|
|
switch (filetype) {
|
|
|
|
case CLOUDABI_FILETYPE_DIRECTORY:
|
2015-07-29 12:42:45 +00:00
|
|
|
*base &= CLOUDABI_RIGHT_FD_STAT_PUT_FLAGS |
|
Make fstat() and friends work.
Summary:
CloudABI provides access to two different stat structures:
- fdstat, containing file descriptor level status: oflags, file
descriptor type and Capsicum rights, used by cap_rights_get(),
fcntl(F_GETFL), getsockopt(SO_TYPE).
- filestat, containing your regular file status: timestamps, inode
number, used by fstat().
Unlike FreeBSD's stat::st_mode, CloudABI file descriptor types don't
have overloaded meanings (e.g., returning S_ISCHR() for kqueues). Add a
utility function to extract the type of a file descriptor accurately.
CloudABI does not work with O_ACCMODEs. File descriptors have two sets
of Capsicum-style rights: rights that apply to the file descriptor
itself ('base') and rights that apply to any new file descriptors
yielded through openat() ('inheriting'). Though not perfect, we can
pretty safely decompose Capsicum rights to such a pair. This is done in
convert_capabilities().
Test Plan: Tests for these system calls are fairly extensive in cloudlibc.
Reviewers: jonathan, mjg, #manpages
Reviewed By: mjg
Subscribers: imp
Differential Revision: https://reviews.freebsd.org/D3171
2015-07-28 06:36:49 +00:00
|
|
|
CLOUDABI_RIGHT_FD_SYNC | CLOUDABI_RIGHT_FILE_ADVISE |
|
|
|
|
CLOUDABI_RIGHT_FILE_CREATE_DIRECTORY |
|
|
|
|
CLOUDABI_RIGHT_FILE_CREATE_FILE |
|
|
|
|
CLOUDABI_RIGHT_FILE_CREATE_FIFO |
|
|
|
|
CLOUDABI_RIGHT_FILE_LINK_SOURCE |
|
|
|
|
CLOUDABI_RIGHT_FILE_LINK_TARGET |
|
|
|
|
CLOUDABI_RIGHT_FILE_OPEN |
|
|
|
|
CLOUDABI_RIGHT_FILE_READDIR |
|
|
|
|
CLOUDABI_RIGHT_FILE_READLINK |
|
|
|
|
CLOUDABI_RIGHT_FILE_RENAME_SOURCE |
|
|
|
|
CLOUDABI_RIGHT_FILE_RENAME_TARGET |
|
|
|
|
CLOUDABI_RIGHT_FILE_STAT_FGET |
|
|
|
|
CLOUDABI_RIGHT_FILE_STAT_FPUT_TIMES |
|
|
|
|
CLOUDABI_RIGHT_FILE_STAT_GET |
|
|
|
|
CLOUDABI_RIGHT_FILE_STAT_PUT_TIMES |
|
|
|
|
CLOUDABI_RIGHT_FILE_SYMLINK |
|
|
|
|
CLOUDABI_RIGHT_FILE_UNLINK |
|
|
|
|
CLOUDABI_RIGHT_POLL_FD_READWRITE |
|
|
|
|
CLOUDABI_RIGHT_SOCK_BIND_DIRECTORY |
|
2015-07-29 12:42:45 +00:00
|
|
|
CLOUDABI_RIGHT_SOCK_CONNECT_DIRECTORY;
|
|
|
|
*inheriting &= CLOUDABI_RIGHT_FD_DATASYNC |
|
|
|
|
CLOUDABI_RIGHT_FD_READ |
|
|
|
|
CLOUDABI_RIGHT_FD_SEEK |
|
|
|
|
CLOUDABI_RIGHT_FD_STAT_PUT_FLAGS |
|
|
|
|
CLOUDABI_RIGHT_FD_SYNC |
|
|
|
|
CLOUDABI_RIGHT_FD_TELL |
|
|
|
|
CLOUDABI_RIGHT_FD_WRITE |
|
|
|
|
CLOUDABI_RIGHT_FILE_ADVISE |
|
|
|
|
CLOUDABI_RIGHT_FILE_ALLOCATE |
|
|
|
|
CLOUDABI_RIGHT_FILE_CREATE_DIRECTORY |
|
|
|
|
CLOUDABI_RIGHT_FILE_CREATE_FILE |
|
|
|
|
CLOUDABI_RIGHT_FILE_CREATE_FIFO |
|
|
|
|
CLOUDABI_RIGHT_FILE_LINK_SOURCE |
|
|
|
|
CLOUDABI_RIGHT_FILE_LINK_TARGET |
|
|
|
|
CLOUDABI_RIGHT_FILE_OPEN |
|
|
|
|
CLOUDABI_RIGHT_FILE_READDIR |
|
|
|
|
CLOUDABI_RIGHT_FILE_READLINK |
|
|
|
|
CLOUDABI_RIGHT_FILE_RENAME_SOURCE |
|
|
|
|
CLOUDABI_RIGHT_FILE_RENAME_TARGET |
|
|
|
|
CLOUDABI_RIGHT_FILE_STAT_FGET |
|
|
|
|
CLOUDABI_RIGHT_FILE_STAT_FPUT_SIZE |
|
|
|
|
CLOUDABI_RIGHT_FILE_STAT_FPUT_TIMES |
|
|
|
|
CLOUDABI_RIGHT_FILE_STAT_GET |
|
|
|
|
CLOUDABI_RIGHT_FILE_STAT_PUT_TIMES |
|
|
|
|
CLOUDABI_RIGHT_FILE_SYMLINK |
|
|
|
|
CLOUDABI_RIGHT_FILE_UNLINK |
|
|
|
|
CLOUDABI_RIGHT_MEM_MAP |
|
|
|
|
CLOUDABI_RIGHT_MEM_MAP_EXEC |
|
|
|
|
CLOUDABI_RIGHT_POLL_FD_READWRITE |
|
|
|
|
CLOUDABI_RIGHT_PROC_EXEC |
|
|
|
|
CLOUDABI_RIGHT_SOCK_BIND_DIRECTORY |
|
|
|
|
CLOUDABI_RIGHT_SOCK_CONNECT_DIRECTORY;
|
Make fstat() and friends work.
Summary:
CloudABI provides access to two different stat structures:
- fdstat, containing file descriptor level status: oflags, file
descriptor type and Capsicum rights, used by cap_rights_get(),
fcntl(F_GETFL), getsockopt(SO_TYPE).
- filestat, containing your regular file status: timestamps, inode
number, used by fstat().
Unlike FreeBSD's stat::st_mode, CloudABI file descriptor types don't
have overloaded meanings (e.g., returning S_ISCHR() for kqueues). Add a
utility function to extract the type of a file descriptor accurately.
CloudABI does not work with O_ACCMODEs. File descriptors have two sets
of Capsicum-style rights: rights that apply to the file descriptor
itself ('base') and rights that apply to any new file descriptors
yielded through openat() ('inheriting'). Though not perfect, we can
pretty safely decompose Capsicum rights to such a pair. This is done in
convert_capabilities().
Test Plan: Tests for these system calls are fairly extensive in cloudlibc.
Reviewers: jonathan, mjg, #manpages
Reviewed By: mjg
Subscribers: imp
Differential Revision: https://reviews.freebsd.org/D3171
2015-07-28 06:36:49 +00:00
|
|
|
break;
|
|
|
|
case CLOUDABI_FILETYPE_FIFO:
|
2015-07-29 12:42:45 +00:00
|
|
|
*base &= CLOUDABI_RIGHT_FD_READ |
|
|
|
|
CLOUDABI_RIGHT_FD_STAT_PUT_FLAGS |
|
|
|
|
CLOUDABI_RIGHT_FD_WRITE |
|
|
|
|
CLOUDABI_RIGHT_FILE_STAT_FGET |
|
|
|
|
CLOUDABI_RIGHT_POLL_FD_READWRITE;
|
Make fstat() and friends work.
Summary:
CloudABI provides access to two different stat structures:
- fdstat, containing file descriptor level status: oflags, file
descriptor type and Capsicum rights, used by cap_rights_get(),
fcntl(F_GETFL), getsockopt(SO_TYPE).
- filestat, containing your regular file status: timestamps, inode
number, used by fstat().
Unlike FreeBSD's stat::st_mode, CloudABI file descriptor types don't
have overloaded meanings (e.g., returning S_ISCHR() for kqueues). Add a
utility function to extract the type of a file descriptor accurately.
CloudABI does not work with O_ACCMODEs. File descriptors have two sets
of Capsicum-style rights: rights that apply to the file descriptor
itself ('base') and rights that apply to any new file descriptors
yielded through openat() ('inheriting'). Though not perfect, we can
pretty safely decompose Capsicum rights to such a pair. This is done in
convert_capabilities().
Test Plan: Tests for these system calls are fairly extensive in cloudlibc.
Reviewers: jonathan, mjg, #manpages
Reviewed By: mjg
Subscribers: imp
Differential Revision: https://reviews.freebsd.org/D3171
2015-07-28 06:36:49 +00:00
|
|
|
*inheriting = 0;
|
|
|
|
break;
|
|
|
|
case CLOUDABI_FILETYPE_POLL:
|
2015-07-29 12:42:45 +00:00
|
|
|
*base &= ~CLOUDABI_RIGHT_FILE_ADVISE;
|
Make fstat() and friends work.
Summary:
CloudABI provides access to two different stat structures:
- fdstat, containing file descriptor level status: oflags, file
descriptor type and Capsicum rights, used by cap_rights_get(),
fcntl(F_GETFL), getsockopt(SO_TYPE).
- filestat, containing your regular file status: timestamps, inode
number, used by fstat().
Unlike FreeBSD's stat::st_mode, CloudABI file descriptor types don't
have overloaded meanings (e.g., returning S_ISCHR() for kqueues). Add a
utility function to extract the type of a file descriptor accurately.
CloudABI does not work with O_ACCMODEs. File descriptors have two sets
of Capsicum-style rights: rights that apply to the file descriptor
itself ('base') and rights that apply to any new file descriptors
yielded through openat() ('inheriting'). Though not perfect, we can
pretty safely decompose Capsicum rights to such a pair. This is done in
convert_capabilities().
Test Plan: Tests for these system calls are fairly extensive in cloudlibc.
Reviewers: jonathan, mjg, #manpages
Reviewed By: mjg
Subscribers: imp
Differential Revision: https://reviews.freebsd.org/D3171
2015-07-28 06:36:49 +00:00
|
|
|
*inheriting = 0;
|
|
|
|
break;
|
|
|
|
case CLOUDABI_FILETYPE_PROCESS:
|
2015-07-29 12:42:45 +00:00
|
|
|
*base &= ~CLOUDABI_RIGHT_FILE_ADVISE;
|
Make fstat() and friends work.
Summary:
CloudABI provides access to two different stat structures:
- fdstat, containing file descriptor level status: oflags, file
descriptor type and Capsicum rights, used by cap_rights_get(),
fcntl(F_GETFL), getsockopt(SO_TYPE).
- filestat, containing your regular file status: timestamps, inode
number, used by fstat().
Unlike FreeBSD's stat::st_mode, CloudABI file descriptor types don't
have overloaded meanings (e.g., returning S_ISCHR() for kqueues). Add a
utility function to extract the type of a file descriptor accurately.
CloudABI does not work with O_ACCMODEs. File descriptors have two sets
of Capsicum-style rights: rights that apply to the file descriptor
itself ('base') and rights that apply to any new file descriptors
yielded through openat() ('inheriting'). Though not perfect, we can
pretty safely decompose Capsicum rights to such a pair. This is done in
convert_capabilities().
Test Plan: Tests for these system calls are fairly extensive in cloudlibc.
Reviewers: jonathan, mjg, #manpages
Reviewed By: mjg
Subscribers: imp
Differential Revision: https://reviews.freebsd.org/D3171
2015-07-28 06:36:49 +00:00
|
|
|
*inheriting = 0;
|
|
|
|
break;
|
|
|
|
case CLOUDABI_FILETYPE_REGULAR_FILE:
|
2015-07-29 12:42:45 +00:00
|
|
|
*base &= CLOUDABI_RIGHT_FD_DATASYNC |
|
|
|
|
CLOUDABI_RIGHT_FD_READ |
|
|
|
|
CLOUDABI_RIGHT_FD_SEEK |
|
|
|
|
CLOUDABI_RIGHT_FD_STAT_PUT_FLAGS |
|
|
|
|
CLOUDABI_RIGHT_FD_SYNC |
|
|
|
|
CLOUDABI_RIGHT_FD_TELL |
|
|
|
|
CLOUDABI_RIGHT_FD_WRITE |
|
|
|
|
CLOUDABI_RIGHT_FILE_ADVISE |
|
|
|
|
CLOUDABI_RIGHT_FILE_ALLOCATE |
|
|
|
|
CLOUDABI_RIGHT_FILE_STAT_FGET |
|
|
|
|
CLOUDABI_RIGHT_FILE_STAT_FPUT_SIZE |
|
|
|
|
CLOUDABI_RIGHT_FILE_STAT_FPUT_TIMES |
|
|
|
|
CLOUDABI_RIGHT_MEM_MAP |
|
|
|
|
CLOUDABI_RIGHT_MEM_MAP_EXEC |
|
|
|
|
CLOUDABI_RIGHT_POLL_FD_READWRITE |
|
|
|
|
CLOUDABI_RIGHT_PROC_EXEC;
|
Make fstat() and friends work.
Summary:
CloudABI provides access to two different stat structures:
- fdstat, containing file descriptor level status: oflags, file
descriptor type and Capsicum rights, used by cap_rights_get(),
fcntl(F_GETFL), getsockopt(SO_TYPE).
- filestat, containing your regular file status: timestamps, inode
number, used by fstat().
Unlike FreeBSD's stat::st_mode, CloudABI file descriptor types don't
have overloaded meanings (e.g., returning S_ISCHR() for kqueues). Add a
utility function to extract the type of a file descriptor accurately.
CloudABI does not work with O_ACCMODEs. File descriptors have two sets
of Capsicum-style rights: rights that apply to the file descriptor
itself ('base') and rights that apply to any new file descriptors
yielded through openat() ('inheriting'). Though not perfect, we can
pretty safely decompose Capsicum rights to such a pair. This is done in
convert_capabilities().
Test Plan: Tests for these system calls are fairly extensive in cloudlibc.
Reviewers: jonathan, mjg, #manpages
Reviewed By: mjg
Subscribers: imp
Differential Revision: https://reviews.freebsd.org/D3171
2015-07-28 06:36:49 +00:00
|
|
|
*inheriting = 0;
|
|
|
|
break;
|
|
|
|
case CLOUDABI_FILETYPE_SHARED_MEMORY:
|
2015-07-29 12:42:45 +00:00
|
|
|
*base &= ~(CLOUDABI_RIGHT_FD_SEEK |
|
Make fstat() and friends work.
Summary:
CloudABI provides access to two different stat structures:
- fdstat, containing file descriptor level status: oflags, file
descriptor type and Capsicum rights, used by cap_rights_get(),
fcntl(F_GETFL), getsockopt(SO_TYPE).
- filestat, containing your regular file status: timestamps, inode
number, used by fstat().
Unlike FreeBSD's stat::st_mode, CloudABI file descriptor types don't
have overloaded meanings (e.g., returning S_ISCHR() for kqueues). Add a
utility function to extract the type of a file descriptor accurately.
CloudABI does not work with O_ACCMODEs. File descriptors have two sets
of Capsicum-style rights: rights that apply to the file descriptor
itself ('base') and rights that apply to any new file descriptors
yielded through openat() ('inheriting'). Though not perfect, we can
pretty safely decompose Capsicum rights to such a pair. This is done in
convert_capabilities().
Test Plan: Tests for these system calls are fairly extensive in cloudlibc.
Reviewers: jonathan, mjg, #manpages
Reviewed By: mjg
Subscribers: imp
Differential Revision: https://reviews.freebsd.org/D3171
2015-07-28 06:36:49 +00:00
|
|
|
CLOUDABI_RIGHT_FD_TELL |
|
|
|
|
CLOUDABI_RIGHT_FILE_ADVISE |
|
|
|
|
CLOUDABI_RIGHT_FILE_ALLOCATE |
|
|
|
|
CLOUDABI_RIGHT_FILE_READDIR);
|
|
|
|
*inheriting = 0;
|
|
|
|
break;
|
|
|
|
case CLOUDABI_FILETYPE_SOCKET_DGRAM:
|
|
|
|
case CLOUDABI_FILETYPE_SOCKET_SEQPACKET:
|
|
|
|
case CLOUDABI_FILETYPE_SOCKET_STREAM:
|
2015-07-29 12:42:45 +00:00
|
|
|
*base &= CLOUDABI_RIGHT_FD_READ |
|
Make fstat() and friends work.
Summary:
CloudABI provides access to two different stat structures:
- fdstat, containing file descriptor level status: oflags, file
descriptor type and Capsicum rights, used by cap_rights_get(),
fcntl(F_GETFL), getsockopt(SO_TYPE).
- filestat, containing your regular file status: timestamps, inode
number, used by fstat().
Unlike FreeBSD's stat::st_mode, CloudABI file descriptor types don't
have overloaded meanings (e.g., returning S_ISCHR() for kqueues). Add a
utility function to extract the type of a file descriptor accurately.
CloudABI does not work with O_ACCMODEs. File descriptors have two sets
of Capsicum-style rights: rights that apply to the file descriptor
itself ('base') and rights that apply to any new file descriptors
yielded through openat() ('inheriting'). Though not perfect, we can
pretty safely decompose Capsicum rights to such a pair. This is done in
convert_capabilities().
Test Plan: Tests for these system calls are fairly extensive in cloudlibc.
Reviewers: jonathan, mjg, #manpages
Reviewed By: mjg
Subscribers: imp
Differential Revision: https://reviews.freebsd.org/D3171
2015-07-28 06:36:49 +00:00
|
|
|
CLOUDABI_RIGHT_FD_STAT_PUT_FLAGS |
|
|
|
|
CLOUDABI_RIGHT_FD_WRITE |
|
|
|
|
CLOUDABI_RIGHT_FILE_STAT_FGET |
|
|
|
|
CLOUDABI_RIGHT_POLL_FD_READWRITE |
|
|
|
|
CLOUDABI_RIGHT_SOCK_ACCEPT |
|
|
|
|
CLOUDABI_RIGHT_SOCK_BIND_SOCKET |
|
|
|
|
CLOUDABI_RIGHT_SOCK_CONNECT_SOCKET |
|
|
|
|
CLOUDABI_RIGHT_SOCK_LISTEN |
|
|
|
|
CLOUDABI_RIGHT_SOCK_SHUTDOWN |
|
2015-07-29 12:42:45 +00:00
|
|
|
CLOUDABI_RIGHT_SOCK_STAT_GET;
|
Make fstat() and friends work.
Summary:
CloudABI provides access to two different stat structures:
- fdstat, containing file descriptor level status: oflags, file
descriptor type and Capsicum rights, used by cap_rights_get(),
fcntl(F_GETFL), getsockopt(SO_TYPE).
- filestat, containing your regular file status: timestamps, inode
number, used by fstat().
Unlike FreeBSD's stat::st_mode, CloudABI file descriptor types don't
have overloaded meanings (e.g., returning S_ISCHR() for kqueues). Add a
utility function to extract the type of a file descriptor accurately.
CloudABI does not work with O_ACCMODEs. File descriptors have two sets
of Capsicum-style rights: rights that apply to the file descriptor
itself ('base') and rights that apply to any new file descriptors
yielded through openat() ('inheriting'). Though not perfect, we can
pretty safely decompose Capsicum rights to such a pair. This is done in
convert_capabilities().
Test Plan: Tests for these system calls are fairly extensive in cloudlibc.
Reviewers: jonathan, mjg, #manpages
Reviewed By: mjg
Subscribers: imp
Differential Revision: https://reviews.freebsd.org/D3171
2015-07-28 06:36:49 +00:00
|
|
|
break;
|
|
|
|
default:
|
|
|
|
*inheriting = 0;
|
|
|
|
break;
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
2015-07-29 12:42:45 +00:00
|
|
|
/* Converts FreeBSD's Capsicum rights to CloudABI's set of rights. */
|
|
|
|
static void
|
|
|
|
convert_capabilities(const cap_rights_t *capabilities,
|
|
|
|
cloudabi_filetype_t filetype, cloudabi_rights_t *base,
|
|
|
|
cloudabi_rights_t *inheriting)
|
|
|
|
{
|
|
|
|
cloudabi_rights_t rights;
|
|
|
|
|
|
|
|
/* Convert FreeBSD bits to CloudABI bits. */
|
|
|
|
rights = 0;
|
|
|
|
#define MAPPING(cloudabi, ...) do { \
|
|
|
|
if (cap_rights_is_set(capabilities, ##__VA_ARGS__)) \
|
|
|
|
rights |= (cloudabi); \
|
|
|
|
} while (0);
|
|
|
|
RIGHTS_MAPPINGS
|
|
|
|
#undef MAPPING
|
|
|
|
|
|
|
|
*base = rights;
|
|
|
|
*inheriting = rights;
|
|
|
|
cloudabi_remove_conflicting_rights(filetype, base, inheriting);
|
|
|
|
}
|
|
|
|
|
2015-07-09 07:20:15 +00:00
|
|
|
int
|
|
|
|
cloudabi_sys_fd_stat_get(struct thread *td,
|
|
|
|
struct cloudabi_sys_fd_stat_get_args *uap)
|
|
|
|
{
|
Make fstat() and friends work.
Summary:
CloudABI provides access to two different stat structures:
- fdstat, containing file descriptor level status: oflags, file
descriptor type and Capsicum rights, used by cap_rights_get(),
fcntl(F_GETFL), getsockopt(SO_TYPE).
- filestat, containing your regular file status: timestamps, inode
number, used by fstat().
Unlike FreeBSD's stat::st_mode, CloudABI file descriptor types don't
have overloaded meanings (e.g., returning S_ISCHR() for kqueues). Add a
utility function to extract the type of a file descriptor accurately.
CloudABI does not work with O_ACCMODEs. File descriptors have two sets
of Capsicum-style rights: rights that apply to the file descriptor
itself ('base') and rights that apply to any new file descriptors
yielded through openat() ('inheriting'). Though not perfect, we can
pretty safely decompose Capsicum rights to such a pair. This is done in
convert_capabilities().
Test Plan: Tests for these system calls are fairly extensive in cloudlibc.
Reviewers: jonathan, mjg, #manpages
Reviewed By: mjg
Subscribers: imp
Differential Revision: https://reviews.freebsd.org/D3171
2015-07-28 06:36:49 +00:00
|
|
|
cloudabi_fdstat_t fsb = {};
|
|
|
|
struct filedesc *fdp;
|
|
|
|
struct file *fp;
|
|
|
|
seq_t seq;
|
|
|
|
cap_rights_t rights;
|
|
|
|
int error, oflags;
|
|
|
|
bool modified;
|
2015-07-09 07:20:15 +00:00
|
|
|
|
Make fstat() and friends work.
Summary:
CloudABI provides access to two different stat structures:
- fdstat, containing file descriptor level status: oflags, file
descriptor type and Capsicum rights, used by cap_rights_get(),
fcntl(F_GETFL), getsockopt(SO_TYPE).
- filestat, containing your regular file status: timestamps, inode
number, used by fstat().
Unlike FreeBSD's stat::st_mode, CloudABI file descriptor types don't
have overloaded meanings (e.g., returning S_ISCHR() for kqueues). Add a
utility function to extract the type of a file descriptor accurately.
CloudABI does not work with O_ACCMODEs. File descriptors have two sets
of Capsicum-style rights: rights that apply to the file descriptor
itself ('base') and rights that apply to any new file descriptors
yielded through openat() ('inheriting'). Though not perfect, we can
pretty safely decompose Capsicum rights to such a pair. This is done in
convert_capabilities().
Test Plan: Tests for these system calls are fairly extensive in cloudlibc.
Reviewers: jonathan, mjg, #manpages
Reviewed By: mjg
Subscribers: imp
Differential Revision: https://reviews.freebsd.org/D3171
2015-07-28 06:36:49 +00:00
|
|
|
/* Obtain file descriptor properties. */
|
|
|
|
fdp = td->td_proc->p_fd;
|
|
|
|
do {
|
|
|
|
error = fget_unlocked(fdp, uap->fd, cap_rights_init(&rights),
|
|
|
|
&fp, &seq);
|
|
|
|
if (error != 0)
|
|
|
|
return (error);
|
|
|
|
if (fp->f_ops == &badfileops) {
|
|
|
|
fdrop(fp, td);
|
|
|
|
return (EBADF);
|
|
|
|
}
|
|
|
|
|
|
|
|
rights = *cap_rights(fdp, uap->fd);
|
|
|
|
oflags = OFLAGS(fp->f_flag);
|
|
|
|
fsb.fs_filetype = cloudabi_convert_filetype(fp);
|
|
|
|
|
|
|
|
modified = fd_modified(fdp, uap->fd, seq);
|
|
|
|
fdrop(fp, td);
|
|
|
|
} while (modified);
|
|
|
|
|
|
|
|
/* Convert file descriptor flags. */
|
|
|
|
if (oflags & O_APPEND)
|
|
|
|
fsb.fs_flags |= CLOUDABI_FDFLAG_APPEND;
|
|
|
|
if (oflags & O_NONBLOCK)
|
|
|
|
fsb.fs_flags |= CLOUDABI_FDFLAG_NONBLOCK;
|
|
|
|
if (oflags & O_SYNC)
|
|
|
|
fsb.fs_flags |= CLOUDABI_FDFLAG_SYNC;
|
|
|
|
|
|
|
|
/* Convert capabilities to CloudABI rights. */
|
|
|
|
convert_capabilities(&rights, fsb.fs_filetype,
|
|
|
|
&fsb.fs_rights_base, &fsb.fs_rights_inheriting);
|
|
|
|
return (copyout(&fsb, (void *)uap->buf, sizeof(fsb)));
|
2015-07-09 07:20:15 +00:00
|
|
|
}
|
|
|
|
|
|
|
|
int
|
|
|
|
cloudabi_sys_fd_stat_put(struct thread *td,
|
|
|
|
struct cloudabi_sys_fd_stat_put_args *uap)
|
|
|
|
{
|
2015-08-05 16:15:43 +00:00
|
|
|
cloudabi_fdstat_t fsb;
|
|
|
|
int error, oflags;
|
2015-07-09 07:20:15 +00:00
|
|
|
|
2015-08-05 16:15:43 +00:00
|
|
|
error = copyin(uap->buf, &fsb, sizeof(fsb));
|
|
|
|
if (error != 0)
|
|
|
|
return (error);
|
|
|
|
|
|
|
|
if (uap->flags == CLOUDABI_FDSTAT_FLAGS) {
|
|
|
|
/* Convert flags. */
|
|
|
|
oflags = 0;
|
|
|
|
if (fsb.fs_flags & CLOUDABI_FDFLAG_APPEND)
|
|
|
|
oflags |= O_APPEND;
|
|
|
|
if (fsb.fs_flags & CLOUDABI_FDFLAG_NONBLOCK)
|
|
|
|
oflags |= O_NONBLOCK;
|
|
|
|
if (fsb.fs_flags & (CLOUDABI_FDFLAG_SYNC |
|
|
|
|
CLOUDABI_FDFLAG_DSYNC | CLOUDABI_FDFLAG_RSYNC))
|
|
|
|
oflags |= O_SYNC;
|
|
|
|
return (kern_fcntl(td, uap->fd, F_SETFL, oflags));
|
|
|
|
}
|
|
|
|
return (EINVAL);
|
2015-07-09 07:20:15 +00:00
|
|
|
}
|
|
|
|
|
|
|
|
int
|
|
|
|
cloudabi_sys_fd_sync(struct thread *td, struct cloudabi_sys_fd_sync_args *uap)
|
|
|
|
{
|
2015-07-09 16:07:01 +00:00
|
|
|
struct fsync_args fsync_args = {
|
|
|
|
.fd = uap->fd
|
|
|
|
};
|
2015-07-09 07:20:15 +00:00
|
|
|
|
2015-07-09 16:07:01 +00:00
|
|
|
return (sys_fsync(td, &fsync_args));
|
2015-07-09 07:20:15 +00:00
|
|
|
}
|