Module Name:    src
Committed By:   thorpej
Date:           Thu Dec 17 03:14:16 UTC 2020

Modified Files:
        src/sys/compat/linux/arch/alpha [thorpej-futex]: syscalls.master
        src/sys/compat/linux/arch/amd64 [thorpej-futex]: syscalls.master
        src/sys/compat/linux/arch/arm [thorpej-futex]: syscalls.master
        src/sys/compat/linux/arch/i386 [thorpej-futex]: syscalls.master
        src/sys/compat/linux/arch/m68k [thorpej-futex]: syscalls.master
        src/sys/compat/linux/arch/mips [thorpej-futex]: syscalls.master
        src/sys/compat/linux/arch/powerpc [thorpej-futex]: syscalls.master
        src/sys/compat/linux/common [thorpej-futex]: linux_file.c

Log Message:
Add suppport for Linux preadv(2) and pwritev(2).  Same as native, except
for the silly way that the offset argument is passed in.


To generate a diff of this commit:
cvs rdiff -u -r1.97.2.1 -r1.97.2.2 \
    src/sys/compat/linux/arch/alpha/syscalls.master
cvs rdiff -u -r1.62.2.1 -r1.62.2.2 \
    src/sys/compat/linux/arch/amd64/syscalls.master
cvs rdiff -u -r1.69.2.1 -r1.69.2.2 \
    src/sys/compat/linux/arch/arm/syscalls.master
cvs rdiff -u -r1.124.2.1 -r1.124.2.2 \
    src/sys/compat/linux/arch/i386/syscalls.master
cvs rdiff -u -r1.95.2.1 -r1.95.2.2 \
    src/sys/compat/linux/arch/m68k/syscalls.master
cvs rdiff -u -r1.68.2.1 -r1.68.2.2 \
    src/sys/compat/linux/arch/mips/syscalls.master
cvs rdiff -u -r1.74.2.1 -r1.74.2.2 \
    src/sys/compat/linux/arch/powerpc/syscalls.master
cvs rdiff -u -r1.118 -r1.118.2.1 src/sys/compat/linux/common/linux_file.c

Please note that diffs are not public domain; they are subject to the
copyright notices on the relevant files.

Modified files:

Index: src/sys/compat/linux/arch/alpha/syscalls.master
diff -u src/sys/compat/linux/arch/alpha/syscalls.master:1.97.2.1 src/sys/compat/linux/arch/alpha/syscalls.master:1.97.2.2
--- src/sys/compat/linux/arch/alpha/syscalls.master:1.97.2.1	Tue Dec 15 14:07:20 2020
+++ src/sys/compat/linux/arch/alpha/syscalls.master	Thu Dec 17 03:14:15 2020
@@ -1,4 +1,4 @@
-	$NetBSD: syscalls.master,v 1.97.2.1 2020/12/15 14:07:20 thorpej Exp $
+	$NetBSD: syscalls.master,v 1.97.2.2 2020/12/17 03:14:15 thorpej Exp $
 ;
 ;	@(#)syscalls.master	8.1 (Berkeley) 7/19/93
 
@@ -784,8 +784,12 @@
 487	STD		{ int|linux_sys||dup3(int from, int to, int flags); }
 488	STD		{ int|linux_sys||pipe2(int *pfds, int flags); }
 489	UNIMPL		inotify_init1
-490	UNIMPL		preadv
-491	UNIMPL		pwritev
+490	STD		{ int|linux_sys||preadv(int fd, \
+			    const struct iovec *iovp, int iovcnt, \
+			    unsigned long off_lo, unsigned long off_hi); }
+491	STD		{ int|linux_sys||pwritev(int fd, \
+			    const struct iovcnt *iovp, int iovcnt, \
+			    unsigned long off_lo, unsigned long off_hi); }
 492	UNIMPL		rt_tgsigqueueinfo
 493	UNIMPL		perf_counter_open
 494	UNIMPL		fanotify_init

Index: src/sys/compat/linux/arch/amd64/syscalls.master
diff -u src/sys/compat/linux/arch/amd64/syscalls.master:1.62.2.1 src/sys/compat/linux/arch/amd64/syscalls.master:1.62.2.2
--- src/sys/compat/linux/arch/amd64/syscalls.master:1.62.2.1	Tue Dec 15 14:07:20 2020
+++ src/sys/compat/linux/arch/amd64/syscalls.master	Thu Dec 17 03:14:15 2020
@@ -1,4 +1,4 @@
-	$NetBSD: syscalls.master,v 1.62.2.1 2020/12/15 14:07:20 thorpej Exp $
+	$NetBSD: syscalls.master,v 1.62.2.2 2020/12/17 03:14:15 thorpej Exp $
 
 ;	@(#)syscalls.master	8.1 (Berkeley) 7/19/93
 
@@ -539,8 +539,12 @@
 292	STD		{ int|linux_sys||dup3(int from, int to, int flags); }
 293	STD		{ int|linux_sys||pipe2(int *pfds, int flags); }
 294	UNIMPL		inotify_init1
-295	UNIMPL		preadv
-296	UNIMPL		pwritev
+295	STD		{ int|linux_sys||preadv(int fd, \
+			    const struct iovec *iovp, int iovcnt, \
+			    unsigned long off_lo, unsigned long off_hi); }
+296	STD		{ int|linux_sys||pwritev(int fd, \
+			    const struct iovcnt *iovp, int iovcnt, \
+			    unsigned long off_lo, unsigned long off_hi); }
 297	UNIMPL		rt_tgsigqueueinfo
 298	UNIMPL		perf_counter_open
 299	STD		{ int|linux_sys||recvmmsg(int s, \

Index: src/sys/compat/linux/arch/arm/syscalls.master
diff -u src/sys/compat/linux/arch/arm/syscalls.master:1.69.2.1 src/sys/compat/linux/arch/arm/syscalls.master:1.69.2.2
--- src/sys/compat/linux/arch/arm/syscalls.master:1.69.2.1	Tue Dec 15 14:07:21 2020
+++ src/sys/compat/linux/arch/arm/syscalls.master	Thu Dec 17 03:14:15 2020
@@ -1,4 +1,4 @@
-	$NetBSD: syscalls.master,v 1.69.2.1 2020/12/15 14:07:21 thorpej Exp $
+	$NetBSD: syscalls.master,v 1.69.2.2 2020/12/17 03:14:15 thorpej Exp $
 
 ; Derived from sys/compat/linux/arch/*/syscalls.master
 ; and from Linux 2.4.12 arch/arm/kernel/calls.S
@@ -579,8 +579,12 @@
 358	STD		{ int|linux_sys||dup3(int from, int to, int flags); }
 359	STD		{ int|linux_sys||pipe2(int *pfds, int flags); }
 360	UNIMPL		inotify_init1
-361	UNIMPL		preadv
-362	UNIMPL		pwritev
+361	STD		{ int|linux_sys||preadv(int fd, \
+			    const struct iovec *iovp, int iovcnt, \
+			    unsigned long off_lo, unsigned long off_hi); }
+362	STD		{ int|linux_sys||pwritev(int fd, \
+			    const struct iovcnt *iovp, int iovcnt, \
+			    unsigned long off_lo, unsigned long off_hi); }
 363	UNIMPL		rt_tgsigqueueinfo
 364	UNIMPL		perf_counter_open
 365	STD		{ int|linux_sys||recvmmsg(int s, \

Index: src/sys/compat/linux/arch/i386/syscalls.master
diff -u src/sys/compat/linux/arch/i386/syscalls.master:1.124.2.1 src/sys/compat/linux/arch/i386/syscalls.master:1.124.2.2
--- src/sys/compat/linux/arch/i386/syscalls.master:1.124.2.1	Tue Dec 15 14:07:21 2020
+++ src/sys/compat/linux/arch/i386/syscalls.master	Thu Dec 17 03:14:15 2020
@@ -1,4 +1,4 @@
-	$NetBSD: syscalls.master,v 1.124.2.1 2020/12/15 14:07:21 thorpej Exp $
+	$NetBSD: syscalls.master,v 1.124.2.2 2020/12/17 03:14:15 thorpej Exp $
 
 ;	@(#)syscalls.master	8.1 (Berkeley) 7/19/93
 
@@ -546,8 +546,12 @@
 330     STD             { int|linux_sys||dup3(int from, int to, int flags); }
 331     STD             { int|linux_sys||pipe2( int *pfds, int flags); }
 332	UNIMPL		inotify_init1
-333	UNIMPL		preadv
-334	UNIMPL		pwritev
+333	STD		{ int|linux_sys||preadv(int fd, \
+			    const struct iovec *iovp, int iovcnt, \
+			    unsigned long off_lo, unsigned long off_hi); }
+334	STD		{ int|linux_sys||pwritev(int fd, \
+			    const struct iovcnt *iovp, int iovcnt, \
+			    unsigned long off_lo, unsigned long off_hi); }
 335	UNIMPL		rt_tgsigqueueinfo
 336	UNIMPL		perf_counter_open
 337	UNIMPL		recvmmsg

Index: src/sys/compat/linux/arch/m68k/syscalls.master
diff -u src/sys/compat/linux/arch/m68k/syscalls.master:1.95.2.1 src/sys/compat/linux/arch/m68k/syscalls.master:1.95.2.2
--- src/sys/compat/linux/arch/m68k/syscalls.master:1.95.2.1	Tue Dec 15 14:07:21 2020
+++ src/sys/compat/linux/arch/m68k/syscalls.master	Thu Dec 17 03:14:15 2020
@@ -1,4 +1,4 @@
-	$NetBSD: syscalls.master,v 1.95.2.1 2020/12/15 14:07:21 thorpej Exp $
+	$NetBSD: syscalls.master,v 1.95.2.2 2020/12/17 03:14:15 thorpej Exp $
 
 ;	@(#)syscalls.master	8.1 (Berkeley) 7/19/93
 
@@ -564,8 +564,12 @@
 326	STD		{ int|linux_sys||dup3(int from, int to, int flags); }
 327	STD		{ int|linux_sys||pipe2(int *pfds, int flags); }
 328	UNIMPL		inotify_init1
-329	UNIMPL		preadv
-330	UNIMPL		pwritev
+329	STD		{ int|linux_sys||preadv(int fd, \
+			    const struct iovec *iovp, int iovcnt, \
+			    unsigned long off_lo, unsigned long off_hi); }
+330	STD		{ int|linux_sys||pwritev(int fd, \
+			    const struct iovcnt *iovp, int iovcnt, \
+			    unsigned long off_lo, unsigned long off_hi); }
 331	UNIMPL		rt_tgsigqueueinfo
 332	UNIMPL		perf_counter_open
 333	UNIMPL		set_thread_area

Index: src/sys/compat/linux/arch/mips/syscalls.master
diff -u src/sys/compat/linux/arch/mips/syscalls.master:1.68.2.1 src/sys/compat/linux/arch/mips/syscalls.master:1.68.2.2
--- src/sys/compat/linux/arch/mips/syscalls.master:1.68.2.1	Tue Dec 15 14:07:21 2020
+++ src/sys/compat/linux/arch/mips/syscalls.master	Thu Dec 17 03:14:15 2020
@@ -1,4 +1,4 @@
-	$NetBSD: syscalls.master,v 1.68.2.1 2020/12/15 14:07:21 thorpej Exp $  
+	$NetBSD: syscalls.master,v 1.68.2.2 2020/12/17 03:14:15 thorpej Exp $  
 
 ;	@(#)syscalls.master	8.1 (Berkeley) 7/19/93
 
@@ -553,8 +553,12 @@
 327	STD		{ int|linux_sys||dup3(int from, int to, int flags); }
 328	STD		{ int|linux_sys||pipe2(int *pfds, int flags); }
 329	UNIMPL		inotify_init1
-330	UNIMPL		preadv
-331	UNIMPL		pwritev
+330	STD		{ int|linux_sys||preadv(int fd, \
+			    const struct iovec *iovp, int iovcnt, \
+			    unsigned long off_lo, unsigned long off_hi); }
+331	STD		{ int|linux_sys||pwritev(int fd, \
+			    const struct iovcnt *iovp, int iovcnt, \
+			    unsigned long off_lo, unsigned long off_hi); }
 332	UNIMPL		rt_tgsigqueueinfo
 333	UNIMPL		perf_event_open
 334	STD		{ int|linux_sys||accept4(int s, \

Index: src/sys/compat/linux/arch/powerpc/syscalls.master
diff -u src/sys/compat/linux/arch/powerpc/syscalls.master:1.74.2.1 src/sys/compat/linux/arch/powerpc/syscalls.master:1.74.2.2
--- src/sys/compat/linux/arch/powerpc/syscalls.master:1.74.2.1	Tue Dec 15 14:07:21 2020
+++ src/sys/compat/linux/arch/powerpc/syscalls.master	Thu Dec 17 03:14:16 2020
@@ -1,4 +1,4 @@
-	$NetBSD: syscalls.master,v 1.74.2.1 2020/12/15 14:07:21 thorpej Exp $  
+	$NetBSD: syscalls.master,v 1.74.2.2 2020/12/17 03:14:16 thorpej Exp $  
 
 ;	@(#)syscalls.master	8.1 (Berkeley) 7/19/93
 
@@ -553,8 +553,12 @@
 317	STD		{ int|linux_sys||pipe2(int *pfds, int flags); }
 318	UNIMPL		inotify_init1
 319	UNIMPL		perf_event_open
-320	UNIMPL		preadv
-321	UNIMPL		pwritev
+320	STD		{ int|linux_sys||preadv(int fd, \
+			    const struct iovec *iovp, int iovcnt, \
+			    unsigned long off_lo, unsigned long off_hi); }
+321	STD		{ int|linux_sys||pwritev(int fd, \
+			    const struct iovcnt *iovp, int iovcnt, \
+			    unsigned long off_lo, unsigned long off_hi); }
 322	UNIMPL		rt_tgsigqueueinfo
 323	UNIMPL		fanotify_init
 324	UNIMPL		fanotify_mark

Index: src/sys/compat/linux/common/linux_file.c
diff -u src/sys/compat/linux/common/linux_file.c:1.118 src/sys/compat/linux/common/linux_file.c:1.118.2.1
--- src/sys/compat/linux/common/linux_file.c:1.118	Sat May 23 23:42:41 2020
+++ src/sys/compat/linux/common/linux_file.c	Thu Dec 17 03:14:16 2020
@@ -1,4 +1,4 @@
-/*	$NetBSD: linux_file.c,v 1.118 2020/05/23 23:42:41 ad Exp $	*/
+/*	$NetBSD: linux_file.c,v 1.118.2.1 2020/12/17 03:14:16 thorpej Exp $	*/
 
 /*-
  * Copyright (c) 1995, 1998, 2008 The NetBSD Foundation, Inc.
@@ -35,7 +35,7 @@
  */
 
 #include <sys/cdefs.h>
-__KERNEL_RCSID(0, "$NetBSD: linux_file.c,v 1.118 2020/05/23 23:42:41 ad Exp $");
+__KERNEL_RCSID(0, "$NetBSD: linux_file.c,v 1.118.2.1 2020/12/17 03:14:16 thorpej Exp $");
 
 #include <sys/param.h>
 #include <sys/systm.h>
@@ -136,6 +136,23 @@ bsd_to_linux_ioflags(int bflags)
 	return res;
 }
 
+static inline off_t
+linux_hilo_to_off_t(unsigned long hi, unsigned long lo)
+{
+#ifdef _LP64
+	/*
+	 * Linux discards the "hi" portion on LP64 platforms; even though
+	 * glibc puts of the upper 32-bits of the offset into the "hi"
+	 * argument regardless, the "lo" argument has all the bits in
+	 * this case.
+	 */
+	(void) hi;
+	return (off_t)lo;
+#else
+	return (((off_t)hi) << 32) | lo;
+#endif /* _LP64 */
+}
+
 /*
  * creat(2) is an obsolete function, but it's present as a Linux
  * system call, so let's deal with it.
@@ -784,6 +801,56 @@ linux_sys_pwrite(struct lwp *l, const st
 	return sys_pwrite(l, &pra, retval);
 }
 
+/*
+ * preadv(2)
+ */
+int
+linux_sys_preadv(struct lwp *l, const struct linux_sys_preadv_args *uap,
+    register_t *retval)
+{
+	/* {
+		syscallarg(int) fd;
+		syscallarg(const struct iovec *) iovp;
+		syscallarg(int) iovcnt;
+		syscallarg(unsigned long) off_lo;
+		syscallarg(unsigned long) off_hi;
+	} */
+	struct sys_preadv_args ua;
+
+	SCARG(&ua, fd) = SCARG(uap, fd);
+	SCARG(&ua, iovp) = SCARG(uap, iovp);
+	SCARG(&ua, iovcnt) = SCARG(uap, iovcnt);
+	SCARG(&ua, PAD) = 0;
+	SCARG(&ua, offset) = linux_hilo_to_off_t(SCARG(uap, off_hi),
+						 SCARG(uap, off_lo));
+	return sys_preadv(l, &ua, retval);
+}
+
+/*
+ * pwritev(2)
+ */
+int
+linux_sys_pwritev(struct lwp *l, const struct linux_sys_pwritev_args *uap,
+    register_t *retval)
+{
+	/* {
+		syscallarg(int) fd;
+		syscallarg(const struct iovec *) iovp;
+		syscallarg(int) iovcnt;
+		syscallarg(unsigned long) off_lo;
+		syscallarg(unsigned long) off_hi;
+	} */
+	struct sys_pwritev_args ua;
+
+	SCARG(&ua, fd) = SCARG(uap, fd);
+	SCARG(&ua, iovp) = (const void *)SCARG(uap, iovp);
+	SCARG(&ua, iovcnt) = SCARG(uap, iovcnt);
+	SCARG(&ua, PAD) = 0;
+	SCARG(&ua, offset) = linux_hilo_to_off_t(SCARG(uap, off_hi),
+						 SCARG(uap, off_lo));
+	return sys_pwritev(l, &ua, retval);
+}
+
 int
 linux_sys_dup3(struct lwp *l, const struct linux_sys_dup3_args *uap,
     register_t *retval)

Reply via email to