
Now that support for 32-bit x86 has been removed, we don't have to worry about the top half of `off_t`/`u64` values being chopped off when we try to pass them in registers. Therefore, we no longer need the workaround of pointers to stack-allocated values to syscalls. Note that this changes the system call ABI, so statically linked programs will have to be re-linked.
34 lines
739 B
C++
34 lines
739 B
C++
/*
|
|
* Copyright (c) 2018-2020, Andreas Kling <kling@serenityos.org>
|
|
*
|
|
* SPDX-License-Identifier: BSD-2-Clause
|
|
*/
|
|
|
|
#include <bits/pthread_cancel.h>
|
|
#include <errno.h>
|
|
#include <sys/uio.h>
|
|
#include <syscall.h>
|
|
|
|
extern "C" {
|
|
|
|
ssize_t writev(int fd, const struct iovec* iov, int iov_count)
|
|
{
|
|
return pwritev(fd, iov, iov_count, -1);
|
|
}
|
|
|
|
ssize_t readv(int fd, const struct iovec* iov, int iov_count)
|
|
{
|
|
__pthread_maybe_cancel();
|
|
|
|
int rc = syscall(SC_readv, fd, iov, iov_count);
|
|
__RETURN_WITH_ERRNO(rc, rc, -1);
|
|
}
|
|
|
|
ssize_t pwritev(int fd, struct iovec const* iov, int iov_count, off_t offset)
|
|
{
|
|
__pthread_maybe_cancel();
|
|
|
|
int rc = syscall(SC_pwritev, fd, iov, iov_count, offset);
|
|
__RETURN_WITH_ERRNO(rc, rc, -1);
|
|
}
|
|
}
|