Blame src/unix/linux-syscalls.c

Packit Service 7c31a4
/* Copyright Joyent, Inc. and other Node contributors. All rights reserved.
Packit Service 7c31a4
 *
Packit Service 7c31a4
 * Permission is hereby granted, free of charge, to any person obtaining a copy
Packit Service 7c31a4
 * of this software and associated documentation files (the "Software"), to
Packit Service 7c31a4
 * deal in the Software without restriction, including without limitation the
Packit Service 7c31a4
 * rights to use, copy, modify, merge, publish, distribute, sublicense, and/or
Packit Service 7c31a4
 * sell copies of the Software, and to permit persons to whom the Software is
Packit Service 7c31a4
 * furnished to do so, subject to the following conditions:
Packit Service 7c31a4
 *
Packit Service 7c31a4
 * The above copyright notice and this permission notice shall be included in
Packit Service 7c31a4
 * all copies or substantial portions of the Software.
Packit Service 7c31a4
 *
Packit Service 7c31a4
 * THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR
Packit Service 7c31a4
 * IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY,
Packit Service 7c31a4
 * FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE
Packit Service 7c31a4
 * AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER
Packit Service 7c31a4
 * LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING
Packit Service 7c31a4
 * FROM, OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS
Packit Service 7c31a4
 * IN THE SOFTWARE.
Packit Service 7c31a4
 */
Packit Service 7c31a4
Packit Service 7c31a4
#include "linux-syscalls.h"
Packit Service 7c31a4
#include <unistd.h>
Packit Service 7c31a4
#include <signal.h>
Packit Service 7c31a4
#include <sys/syscall.h>
Packit Service 7c31a4
#include <sys/types.h>
Packit Service 7c31a4
#include <errno.h>
Packit Service 7c31a4
Packit Service 7c31a4
#if defined(__arm__)
Packit Service 7c31a4
# if defined(__thumb__) || defined(__ARM_EABI__)
Packit Service 7c31a4
#  define UV_SYSCALL_BASE 0
Packit Service 7c31a4
# else
Packit Service 7c31a4
#  define UV_SYSCALL_BASE 0x900000
Packit Service 7c31a4
# endif
Packit Service 7c31a4
#endif /* __arm__ */
Packit Service 7c31a4
Packit Service 7c31a4
#ifndef __NR_recvmmsg
Packit Service 7c31a4
# if defined(__x86_64__)
Packit Service 7c31a4
#  define __NR_recvmmsg 299
Packit Service 7c31a4
# elif defined(__arm__)
Packit Service 7c31a4
#  define __NR_recvmmsg (UV_SYSCALL_BASE + 365)
Packit Service 7c31a4
# endif
Packit Service 7c31a4
#endif /* __NR_recvmsg */
Packit Service 7c31a4
Packit Service 7c31a4
#ifndef __NR_sendmmsg
Packit Service 7c31a4
# if defined(__x86_64__)
Packit Service 7c31a4
#  define __NR_sendmmsg 307
Packit Service 7c31a4
# elif defined(__arm__)
Packit Service 7c31a4
#  define __NR_sendmmsg (UV_SYSCALL_BASE + 374)
Packit Service 7c31a4
# endif
Packit Service 7c31a4
#endif /* __NR_sendmmsg */
Packit Service 7c31a4
Packit Service 7c31a4
#ifndef __NR_utimensat
Packit Service 7c31a4
# if defined(__x86_64__)
Packit Service 7c31a4
#  define __NR_utimensat 280
Packit Service 7c31a4
# elif defined(__i386__)
Packit Service 7c31a4
#  define __NR_utimensat 320
Packit Service 7c31a4
# elif defined(__arm__)
Packit Service 7c31a4
#  define __NR_utimensat (UV_SYSCALL_BASE + 348)
Packit Service 7c31a4
# endif
Packit Service 7c31a4
#endif /* __NR_utimensat */
Packit Service 7c31a4
Packit Service 7c31a4
#ifndef __NR_preadv
Packit Service 7c31a4
# if defined(__x86_64__)
Packit Service 7c31a4
#  define __NR_preadv 295
Packit Service 7c31a4
# elif defined(__i386__)
Packit Service 7c31a4
#  define __NR_preadv 333
Packit Service 7c31a4
# elif defined(__arm__)
Packit Service 7c31a4
#  define __NR_preadv (UV_SYSCALL_BASE + 361)
Packit Service 7c31a4
# endif
Packit Service 7c31a4
#endif /* __NR_preadv */
Packit Service 7c31a4
Packit Service 7c31a4
#ifndef __NR_pwritev
Packit Service 7c31a4
# if defined(__x86_64__)
Packit Service 7c31a4
#  define __NR_pwritev 296
Packit Service 7c31a4
# elif defined(__i386__)
Packit Service 7c31a4
#  define __NR_pwritev 334
Packit Service 7c31a4
# elif defined(__arm__)
Packit Service 7c31a4
#  define __NR_pwritev (UV_SYSCALL_BASE + 362)
Packit Service 7c31a4
# endif
Packit Service 7c31a4
#endif /* __NR_pwritev */
Packit Service 7c31a4
Packit Service 7c31a4
#ifndef __NR_dup3
Packit Service 7c31a4
# if defined(__x86_64__)
Packit Service 7c31a4
#  define __NR_dup3 292
Packit Service 7c31a4
# elif defined(__i386__)
Packit Service 7c31a4
#  define __NR_dup3 330
Packit Service 7c31a4
# elif defined(__arm__)
Packit Service 7c31a4
#  define __NR_dup3 (UV_SYSCALL_BASE + 358)
Packit Service 7c31a4
# endif
Packit Service 7c31a4
#endif /* __NR_pwritev */
Packit Service 7c31a4
Packit Service e2ebee
#ifndef __NR_copy_file_range
Packit Service e2ebee
# if defined(__x86_64__)
Packit Service e2ebee
#  define __NR_copy_file_range 326
Packit Service e2ebee
# elif defined(__i386__)
Packit Service e2ebee
#  define __NR_copy_file_range 377
Packit Service e2ebee
# elif defined(__s390__)
Packit Service e2ebee
#  define __NR_copy_file_range 375
Packit Service e2ebee
# elif defined(__arm__)
Packit Service e2ebee
#  define __NR_copy_file_range (UV_SYSCALL_BASE + 391)
Packit Service e2ebee
# elif defined(__aarch64__)
Packit Service e2ebee
#  define __NR_copy_file_range 285
Packit Service e2ebee
# elif defined(__powerpc__)
Packit Service e2ebee
#  define __NR_copy_file_range 379
Packit Service e2ebee
# elif defined(__arc__)
Packit Service e2ebee
#  define __NR_copy_file_range 285
Packit Service e2ebee
# endif
Packit Service e2ebee
#endif /* __NR_copy_file_range */
Packit Service e2ebee
Packit Service 7c31a4
#ifndef __NR_statx
Packit Service 7c31a4
# if defined(__x86_64__)
Packit Service 7c31a4
#  define __NR_statx 332
Packit Service 7c31a4
# elif defined(__i386__)
Packit Service 7c31a4
#  define __NR_statx 383
Packit Service 7c31a4
# elif defined(__aarch64__)
Packit Service 7c31a4
#  define __NR_statx 397
Packit Service 7c31a4
# elif defined(__arm__)
Packit Service 7c31a4
#  define __NR_statx (UV_SYSCALL_BASE + 397)
Packit Service 7c31a4
# elif defined(__ppc__)
Packit Service 7c31a4
#  define __NR_statx 383
Packit Service 7c31a4
# elif defined(__s390__)
Packit Service 7c31a4
#  define __NR_statx 379
Packit Service 7c31a4
# endif
Packit Service 7c31a4
#endif /* __NR_statx */
Packit Service 7c31a4
Packit Service 7c31a4
#ifndef __NR_getrandom
Packit Service 7c31a4
# if defined(__x86_64__)
Packit Service 7c31a4
#  define __NR_getrandom 318
Packit Service 7c31a4
# elif defined(__i386__)
Packit Service 7c31a4
#  define __NR_getrandom 355
Packit Service 7c31a4
# elif defined(__aarch64__)
Packit Service 7c31a4
#  define __NR_getrandom 384
Packit Service 7c31a4
# elif defined(__arm__)
Packit Service 7c31a4
#  define __NR_getrandom (UV_SYSCALL_BASE + 384)
Packit Service 7c31a4
# elif defined(__ppc__)
Packit Service 7c31a4
#  define __NR_getrandom 359
Packit Service 7c31a4
# elif defined(__s390__)
Packit Service 7c31a4
#  define __NR_getrandom 349
Packit Service 7c31a4
# endif
Packit Service 7c31a4
#endif /* __NR_getrandom */
Packit Service 7c31a4
Packit Service 7c31a4
struct uv__mmsghdr;
Packit Service 7c31a4
Packit Service e2ebee
int uv__sendmmsg(int fd, struct uv__mmsghdr* mmsg, unsigned int vlen) {
Packit Service e2ebee
#if defined(__i386__)
Packit Service e2ebee
  unsigned long args[4];
Packit Service e2ebee
  int rc;
Packit Service e2ebee
Packit Service e2ebee
  args[0] = (unsigned long) fd;
Packit Service e2ebee
  args[1] = (unsigned long) mmsg;
Packit Service e2ebee
  args[2] = (unsigned long) vlen;
Packit Service e2ebee
  args[3] = /* flags */ 0;
Packit Service e2ebee
Packit Service e2ebee
  /* socketcall() raises EINVAL when SYS_SENDMMSG is not supported. */
Packit Service e2ebee
  rc = syscall(/* __NR_socketcall */ 102, 20 /* SYS_SENDMMSG */, args);
Packit Service e2ebee
  if (rc == -1)
Packit Service e2ebee
    if (errno == EINVAL)
Packit Service e2ebee
      errno = ENOSYS;
Packit Service e2ebee
Packit Service e2ebee
  return rc;
Packit Service e2ebee
#elif defined(__NR_sendmmsg)
Packit Service e2ebee
  return syscall(__NR_sendmmsg, fd, mmsg, vlen, /* flags */ 0);
Packit Service 7c31a4
#else
Packit Service 7c31a4
  return errno = ENOSYS, -1;
Packit Service 7c31a4
#endif
Packit Service 7c31a4
}
Packit Service 7c31a4
Packit Service 7c31a4
Packit Service e2ebee
int uv__recvmmsg(int fd, struct uv__mmsghdr* mmsg, unsigned int vlen) {
Packit Service e2ebee
#if defined(__i386__)
Packit Service e2ebee
  unsigned long args[5];
Packit Service e2ebee
  int rc;
Packit Service e2ebee
Packit Service e2ebee
  args[0] = (unsigned long) fd;
Packit Service e2ebee
  args[1] = (unsigned long) mmsg;
Packit Service e2ebee
  args[2] = (unsigned long) vlen;
Packit Service e2ebee
  args[3] = /* flags */ 0;
Packit Service e2ebee
  args[4] = /* timeout */ 0;
Packit Service e2ebee
Packit Service e2ebee
  /* socketcall() raises EINVAL when SYS_RECVMMSG is not supported. */
Packit Service e2ebee
  rc = syscall(/* __NR_socketcall */ 102, 19 /* SYS_RECVMMSG */, args);
Packit Service e2ebee
  if (rc == -1)
Packit Service e2ebee
    if (errno == EINVAL)
Packit Service e2ebee
      errno = ENOSYS;
Packit Service e2ebee
Packit Service e2ebee
  return rc;
Packit Service e2ebee
#elif defined(__NR_recvmmsg)
Packit Service e2ebee
  return syscall(__NR_recvmmsg, fd, mmsg, vlen, /* flags */ 0, /* timeout */ 0);
Packit Service 7c31a4
#else
Packit Service 7c31a4
  return errno = ENOSYS, -1;
Packit Service 7c31a4
#endif
Packit Service 7c31a4
}
Packit Service 7c31a4
Packit Service 7c31a4
Packit Service 7c31a4
ssize_t uv__preadv(int fd, const struct iovec *iov, int iovcnt, int64_t offset) {
Packit Service 7c31a4
#if defined(__NR_preadv)
Packit Service 7c31a4
  return syscall(__NR_preadv, fd, iov, iovcnt, (long)offset, (long)(offset >> 32));
Packit Service 7c31a4
#else
Packit Service 7c31a4
  return errno = ENOSYS, -1;
Packit Service 7c31a4
#endif
Packit Service 7c31a4
}
Packit Service 7c31a4
Packit Service 7c31a4
Packit Service 7c31a4
ssize_t uv__pwritev(int fd, const struct iovec *iov, int iovcnt, int64_t offset) {
Packit Service 7c31a4
#if defined(__NR_pwritev)
Packit Service 7c31a4
  return syscall(__NR_pwritev, fd, iov, iovcnt, (long)offset, (long)(offset >> 32));
Packit Service 7c31a4
#else
Packit Service 7c31a4
  return errno = ENOSYS, -1;
Packit Service 7c31a4
#endif
Packit Service 7c31a4
}
Packit Service 7c31a4
Packit Service 7c31a4
Packit Service 7c31a4
int uv__dup3(int oldfd, int newfd, int flags) {
Packit Service 7c31a4
#if defined(__NR_dup3)
Packit Service 7c31a4
  return syscall(__NR_dup3, oldfd, newfd, flags);
Packit Service 7c31a4
#else
Packit Service 7c31a4
  return errno = ENOSYS, -1;
Packit Service 7c31a4
#endif
Packit Service 7c31a4
}
Packit Service 7c31a4
Packit Service 7c31a4
Packit Service e2ebee
ssize_t
Packit Service e2ebee
uv__fs_copy_file_range(int fd_in,
Packit Service e2ebee
                       ssize_t* off_in,
Packit Service e2ebee
                       int fd_out,
Packit Service e2ebee
                       ssize_t* off_out,
Packit Service e2ebee
                       size_t len,
Packit Service e2ebee
                       unsigned int flags)
Packit Service e2ebee
{
Packit Service e2ebee
#ifdef __NR_copy_file_range
Packit Service e2ebee
  return syscall(__NR_copy_file_range,
Packit Service e2ebee
                 fd_in,
Packit Service e2ebee
                 off_in,
Packit Service e2ebee
                 fd_out,
Packit Service e2ebee
                 off_out,
Packit Service e2ebee
                 len,
Packit Service e2ebee
                 flags);
Packit Service e2ebee
#else
Packit Service e2ebee
  return errno = ENOSYS, -1;
Packit Service e2ebee
#endif
Packit Service e2ebee
}
Packit Service e2ebee
Packit Service e2ebee
Packit Service 7c31a4
int uv__statx(int dirfd,
Packit Service 7c31a4
              const char* path,
Packit Service 7c31a4
              int flags,
Packit Service 7c31a4
              unsigned int mask,
Packit Service 7c31a4
              struct uv__statx* statxbuf) {
Packit Service 7c31a4
  /* __NR_statx make Android box killed by SIGSYS.
Packit Service 7c31a4
   * That looks like a seccomp2 sandbox filter rejecting the system call.
Packit Service 7c31a4
   */
Packit Service 7c31a4
#if defined(__NR_statx) && !defined(__ANDROID__)
Packit Service 7c31a4
  return syscall(__NR_statx, dirfd, path, flags, mask, statxbuf);
Packit Service 7c31a4
#else
Packit Service 7c31a4
  return errno = ENOSYS, -1;
Packit Service 7c31a4
#endif
Packit Service 7c31a4
}
Packit Service 7c31a4
Packit Service 7c31a4
Packit Service 7c31a4
ssize_t uv__getrandom(void* buf, size_t buflen, unsigned flags) {
Packit Service 7c31a4
#if defined(__NR_getrandom)
Packit Service 7c31a4
  return syscall(__NR_getrandom, buf, buflen, flags);
Packit Service 7c31a4
#else
Packit Service 7c31a4
  return errno = ENOSYS, -1;
Packit Service 7c31a4
#endif
Packit Service 7c31a4
}