Source-Changes-HG archive

[Date Prev][Date Next][Thread Prev][Thread Next][Date Index][Thread Index][Old Index]

[src/trunk]: src Add a NetBSD native futex implementation, mostly written by ...



details:   https://anonhg.NetBSD.org/src/rev/d1a66b283f42
branches:  trunk
changeset: 1009555:d1a66b283f42
user:      thorpej <thorpej%NetBSD.org@localhost>
date:      Sun Apr 26 18:53:31 2020 +0000

description:
Add a NetBSD native futex implementation, mostly written by riastradh@.
Map the COMPAT_LINUX futex calls to the native ones.

diffstat:

 distrib/sets/lists/comp/mi                    |     3 +-
 distrib/sets/lists/tests/mi                   |     4 +-
 lib/libc/include/futex_private.h              |    64 +
 sys/compat/linux/arch/alpha/syscalls.master   |    16 +-
 sys/compat/linux/arch/amd64/syscalls.master   |    16 +-
 sys/compat/linux/arch/arm/syscalls.master     |    16 +-
 sys/compat/linux/arch/i386/syscalls.master    |    11 +-
 sys/compat/linux/arch/m68k/syscalls.master    |    16 +-
 sys/compat/linux/arch/mips/syscalls.master    |    16 +-
 sys/compat/linux/arch/powerpc/syscalls.master |    16 +-
 sys/compat/linux/common/linux_emuldata.h      |     5 +-
 sys/compat/linux/common/linux_exec.c          |    34 +-
 sys/compat/linux/common/linux_futex.c         |   776 +---------
 sys/compat/linux/common/linux_futex.h         |    93 -
 sys/compat/linux/common/linux_mod.c           |     7 +-
 sys/compat/linux32/arch/amd64/syscalls.master |    15 +-
 sys/compat/linux32/common/linux32_misc.c      |    70 +-
 sys/compat/netbsd32/files.netbsd32            |     3 +-
 sys/compat/netbsd32/netbsd32_futex.c          |   134 +
 sys/compat/netbsd32/syscalls.master           |     9 +-
 sys/kern/files.kern                           |     3 +-
 sys/kern/init_main.c                          |     7 +-
 sys/kern/kern_lwp.c                           |    14 +-
 sys/kern/kern_proc.c                          |    11 +-
 sys/kern/sys_futex.c                          |  1977 +++++++++++++++++++++++++
 sys/kern/syscalls.master                      |     9 +-
 sys/sys/Makefile                              |     4 +-
 sys/sys/futex.h                               |   186 ++
 sys/sys/lwp.h                                 |     4 +-
 tests/lib/libc/sys/Makefile                   |     7 +-
 tests/lib/libc/sys/t_futex_ops.c              |  1294 ++++++++++++++++
 tests/lib/libc/sys/t_futex_robust.c           |   408 +++++
 32 files changed, 4257 insertions(+), 991 deletions(-)

diffs (truncated from 5810 to 300 lines):

diff -r 4b872d20c8f7 -r d1a66b283f42 distrib/sets/lists/comp/mi
--- a/distrib/sets/lists/comp/mi        Sun Apr 26 17:00:31 2020 +0000
+++ b/distrib/sets/lists/comp/mi        Sun Apr 26 18:53:31 2020 +0000
@@ -1,4 +1,4 @@
-#      $NetBSD: mi,v 1.2321 2020/04/04 19:26:51 christos Exp $
+#      $NetBSD: mi,v 1.2322 2020/04/26 18:53:31 thorpej Exp $
 #
 # Note: don't delete entries from here - mark them as "obsolete" instead.
 ./etc/mtree/set.comp                           comp-sys-root
@@ -3059,6 +3059,7 @@
 ./usr/include/sys/float_ieee754.h              comp-c-include
 ./usr/include/sys/fnv_hash.h                   comp-obsolete           obsolete
 ./usr/include/sys/fstypes.h                    comp-c-include
+./usr/include/sys/futex.h                      comp-c-include
 ./usr/include/sys/gcq.h                                comp-c-include
 ./usr/include/sys/gmon.h                       comp-c-include
 ./usr/include/sys/gpio.h                       comp-c-include
diff -r 4b872d20c8f7 -r d1a66b283f42 distrib/sets/lists/tests/mi
--- a/distrib/sets/lists/tests/mi       Sun Apr 26 17:00:31 2020 +0000
+++ b/distrib/sets/lists/tests/mi       Sun Apr 26 18:53:31 2020 +0000
@@ -1,4 +1,4 @@
-# $NetBSD: mi,v 1.836 2020/04/19 13:22:58 maxv Exp $
+# $NetBSD: mi,v 1.837 2020/04/26 18:53:32 thorpej Exp $
 #
 # Note: don't delete entries from here - mark them as "obsolete" instead.
 #
@@ -3120,6 +3120,8 @@
 ./usr/tests/lib/libc/sys/t_dup                 tests-lib-tests         compattestfile,atf
 ./usr/tests/lib/libc/sys/t_fork                        tests-lib-tests         compattestfile,atf
 ./usr/tests/lib/libc/sys/t_fsync               tests-lib-tests         compattestfile,atf
+./usr/tests/lib/libc/sys/t_futex_ops           tests-lib-tests         compattestfile,atf
+./usr/tests/lib/libc/sys/t_futex_robust                tests-lib-tests         compattestfile,atf
 ./usr/tests/lib/libc/sys/t_getcontext          tests-lib-tests         compattestfile,atf
 ./usr/tests/lib/libc/sys/t_getgroups           tests-lib-tests         compattestfile,atf
 ./usr/tests/lib/libc/sys/t_getitimer           tests-lib-tests         compattestfile,atf
diff -r 4b872d20c8f7 -r d1a66b283f42 lib/libc/include/futex_private.h
--- /dev/null   Thu Jan 01 00:00:00 1970 +0000
+++ b/lib/libc/include/futex_private.h  Sun Apr 26 18:53:31 2020 +0000
@@ -0,0 +1,64 @@
+/*     $NetBSD: futex_private.h,v 1.1 2020/04/26 18:53:32 thorpej Exp $        */
+
+/*-
+ * Copyright (c) 2019 The NetBSD Foundation, Inc.
+ * All rights reserved.
+ *
+ * This code is derived from software contributed to The NetBSD Foundation
+ * by Jason R. Thorpe.
+ *
+ * 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 NETBSD FOUNDATION, INC. 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 FOUNDATION 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.
+ */
+
+#ifndef __LIBC_FUTEX_PRIVATE
+#define __LIBC_FUTEX_PRIVATE
+
+#if defined(_LIBC)
+#include "namespace.h"
+#endif
+
+#include <sys/cdefs.h>
+#include <sys/syscall.h>
+#include <sys/futex.h>
+#include <unistd.h>
+
+static inline int __unused
+__futex(volatile int *uaddr, int op, int val, const struct timespec *timeout,
+       volatile int *uaddr2, int val2, int val3)
+{
+       return syscall(SYS___futex, uaddr, op, val, timeout, uaddr2,
+                       val2, val3);
+}
+
+static inline int __unused
+__futex_set_robust_list(void *head, size_t len)
+{
+       return syscall(SYS___futex_set_robust_list, head, len);
+}
+
+static inline int __unused
+__futex_get_robust_list(lwpid_t lwpid, void **headp, size_t *lenp)
+{
+       return syscall(SYS___futex_get_robust_list, lwpid, headp, lenp);
+}
+
+#endif /* __LIBC_FUTEX_PRIVATE */
diff -r 4b872d20c8f7 -r d1a66b283f42 sys/compat/linux/arch/alpha/syscalls.master
--- a/sys/compat/linux/arch/alpha/syscalls.master       Sun Apr 26 17:00:31 2020 +0000
+++ b/sys/compat/linux/arch/alpha/syscalls.master       Sun Apr 26 18:53:31 2020 +0000
@@ -1,4 +1,4 @@
-       $NetBSD: syscalls.master,v 1.96 2019/11/09 23:44:31 jdolecek Exp $
+       $NetBSD: syscalls.master,v 1.97 2020/04/26 18:53:32 thorpej Exp $
 ;
 ;      @(#)syscalls.master     8.1 (Berkeley) 7/19/93
 
@@ -740,11 +740,15 @@
                            struct linux_timespec *timeout, \
                            linux_sigset_t *sigset); }
 465    UNIMPL          unshare
-466    STD             { int|linux_sys||set_robust_list( \
-                           struct linux_robust_list_head *head, size_t len); }
-467    STD             { int|linux_sys||get_robust_list(int pid, \
-                           struct linux_robust_list_head **head, \
-                           size_t *len); }
+                       ;
+                       ; The NetBSD native robust list calls have different
+                       ; argument names / types, but they are ABI-compatible
+                       ; with Linux.
+                       ;
+466    NOARGS          { int|sys||__futex_set_robust_list(void *head, \
+                           size_t len); }
+467    NOARGS          { int|sys||__futex_get_robust_list(lwpid_t lwpid, \
+                           void **headp, size_t *lenp); }
 468    UNIMPL          splice
 469    UNIMPL          sync_file_range
 470    UNIMPL          tee
diff -r 4b872d20c8f7 -r d1a66b283f42 sys/compat/linux/arch/amd64/syscalls.master
--- a/sys/compat/linux/arch/amd64/syscalls.master       Sun Apr 26 17:00:31 2020 +0000
+++ b/sys/compat/linux/arch/amd64/syscalls.master       Sun Apr 26 18:53:31 2020 +0000
@@ -1,4 +1,4 @@
-       $NetBSD: syscalls.master,v 1.61 2019/11/09 23:44:31 jdolecek Exp $
+       $NetBSD: syscalls.master,v 1.62 2020/04/26 18:53:32 thorpej Exp $
 
 ;      @(#)syscalls.master     8.1 (Berkeley) 7/19/93
 
@@ -497,11 +497,15 @@
                            struct linux_timespec *timeout, \
                            linux_sigset_t *sigset); }
 272    UNIMPL          unshare
-273    STD             { int|linux_sys||set_robust_list( \
-                           struct linux_robust_list_head *head, size_t len); }
-274    STD             { int|linux_sys||get_robust_list(int pid, \
-                           struct linux_robust_list_head **head, \
-                           size_t *len); }
+                       ;
+                       ; The NetBSD native robust list calls have different
+                       ; argument names / types, but they are ABI-compatible
+                       ; with Linux.
+                       ;
+273    NOARGS          { int|sys||__futex_set_robust_list(void *head, \
+                           size_t len); }
+274    NOARGS          { int|sys||__futex_get_robust_list(lwpid_t lwpid, \
+                           void **headp, size_t *lenp); }
 275    UNIMPL          splice
 276    UNIMPL          tee
 277    UNIMPL          sync_file_range
diff -r 4b872d20c8f7 -r d1a66b283f42 sys/compat/linux/arch/arm/syscalls.master
--- a/sys/compat/linux/arch/arm/syscalls.master Sun Apr 26 17:00:31 2020 +0000
+++ b/sys/compat/linux/arch/arm/syscalls.master Sun Apr 26 18:53:31 2020 +0000
@@ -1,4 +1,4 @@
-       $NetBSD: syscalls.master,v 1.68 2019/11/09 23:44:31 jdolecek Exp $
+       $NetBSD: syscalls.master,v 1.69 2020/04/26 18:53:32 thorpej Exp $
 
 ; Derived from sys/compat/linux/arch/*/syscalls.master
 ; and from Linux 2.4.12 arch/arm/kernel/calls.S
@@ -538,11 +538,15 @@
                            struct linux_timespec *timeout, \
                            linux_sigset_t *sigset); }
 337    UNIMPL          unshare
-338    STD             { int|linux_sys||set_robust_list( \
-                           struct linux_robust_list_head *head, size_t len); }
-339    STD             { int|linux_sys||get_robust_list(int pid, \
-                           struct linux_robust_list_head **head, \
-                           size_t *len); }
+                       ;
+                       ; The NetBSD native robust list calls have different
+                       ; argument names / types, but they are ABI-compatible
+                       ; with Linux.
+                       ;
+338    NOARGS          { int|sys||__futex_set_robust_list(void *head, \
+                           size_t len); }
+339    NOARGS          { int|sys||__futex_get_robust_list(lwpid_t lwpid, \
+                           void **headp, size_t *lenp); }
 340    UNIMPL          splice
 341    UNIMPL          sync_file_range2
 342    UNIMPL          tee
diff -r 4b872d20c8f7 -r d1a66b283f42 sys/compat/linux/arch/i386/syscalls.master
--- a/sys/compat/linux/arch/i386/syscalls.master        Sun Apr 26 17:00:31 2020 +0000
+++ b/sys/compat/linux/arch/i386/syscalls.master        Sun Apr 26 18:53:31 2020 +0000
@@ -1,4 +1,4 @@
-       $NetBSD: syscalls.master,v 1.123 2019/11/09 23:44:32 jdolecek Exp $
+       $NetBSD: syscalls.master,v 1.124 2020/04/26 18:53:32 thorpej Exp $
 
 ;      @(#)syscalls.master     8.1 (Berkeley) 7/19/93
 
@@ -511,11 +511,10 @@
                            struct linux_timespec *timeout, \
                            linux_sigset_t *sigset); }
 310    UNIMPL          unshare
-311    STD             { int|linux_sys||set_robust_list( \
-                           struct linux_robust_list_head *head, size_t len); }
-312    STD             { int|linux_sys||get_robust_list(int pid, \
-                           struct linux_robust_list_head **head, \
-                           size_t *len); }
+311    NOARGS          { int|sys||__futex_set_robust_list(void *head, \
+                           size_t len); }
+312    NOARGS          { int|sys||__futex_get_robust_list(lwpid_t lwpid, \
+                           void **headp, size_t *lenp); }
 313    UNIMPL          splice
 314    UNIMPL          sync_file_range
 315    UNIMPL          tee
diff -r 4b872d20c8f7 -r d1a66b283f42 sys/compat/linux/arch/m68k/syscalls.master
--- a/sys/compat/linux/arch/m68k/syscalls.master        Sun Apr 26 17:00:31 2020 +0000
+++ b/sys/compat/linux/arch/m68k/syscalls.master        Sun Apr 26 18:53:31 2020 +0000
@@ -1,4 +1,4 @@
-       $NetBSD: syscalls.master,v 1.94 2019/11/09 23:44:32 jdolecek Exp $
+       $NetBSD: syscalls.master,v 1.95 2020/04/26 18:53:32 thorpej Exp $
 
 ;      @(#)syscalls.master     8.1 (Berkeley) 7/19/93
 
@@ -519,11 +519,15 @@
                            struct linux_timespec *timeout, \
                            linux_sigset_t *sigset); }
 303    UNIMPL          unshare
-304    STD             { int|linux_sys||set_robust_list( \
-                           struct linux_robust_list_head *head, size_t len); }
-305    STD             { int|linux_sys||get_robust_list(int pid, \
-                           struct linux_robust_list_head **head, \
-                           size_t *len); }
+                       ;
+                       ; The NetBSD native robust list calls have different
+                       ; argument names / types, but they are ABI-compatible
+                       ; with Linux.
+                       ;
+304    NOARGS          { int|sys||__futex_set_robust_list(void *head, \
+                           size_t len); }
+305    NOARGS          { int|sys||__futex_get_robust_list(lwpid_t lwpid, \
+                           void **headp, size_t *lenp); }
 306    UNIMPL          splice
 307    UNIMPL          sync_file_range
 308    UNIMPL          tee
diff -r 4b872d20c8f7 -r d1a66b283f42 sys/compat/linux/arch/mips/syscalls.master
--- a/sys/compat/linux/arch/mips/syscalls.master        Sun Apr 26 17:00:31 2020 +0000
+++ b/sys/compat/linux/arch/mips/syscalls.master        Sun Apr 26 18:53:31 2020 +0000
@@ -1,4 +1,4 @@
-       $NetBSD: syscalls.master,v 1.67 2019/11/09 23:44:32 jdolecek Exp $  
+       $NetBSD: syscalls.master,v 1.68 2020/04/26 18:53:32 thorpej Exp $  
 
 ;      @(#)syscalls.master     8.1 (Berkeley) 7/19/93
 
@@ -514,11 +514,15 @@
 306    UNIMPL          tee
 307    UNIMPL          vmsplice
 308    UNIMPL          move_pages
-309    STD             { int|linux_sys||set_robust_list( \
-                           struct linux_robust_list_head *head, size_t len); }
-310    STD             { int|linux_sys||get_robust_list(int pid, \
-                           struct linux_robust_list_head **head, \
-                           size_t *len); }
+                       ;
+                       ; The NetBSD native robust list calls have different
+                       ; argument names / types, but they are ABI-compatible
+                       ; with Linux.
+                       ;
+309    NOARGS          { int|sys||__futex_set_robust_list(void *head, \
+                           size_t len); }
+310    NOARGS          { int|sys||__futex_get_robust_list(lwpid_t lwpid, \
+                           void **headp, size_t *lenp); }
 311    UNIMPL          kexec_load
 312    UNIMPL          getcpu
 313    UNIMPL          epoll_pwait
diff -r 4b872d20c8f7 -r d1a66b283f42 sys/compat/linux/arch/powerpc/syscalls.master
--- a/sys/compat/linux/arch/powerpc/syscalls.master     Sun Apr 26 17:00:31 2020 +0000
+++ b/sys/compat/linux/arch/powerpc/syscalls.master     Sun Apr 26 18:53:31 2020 +0000
@@ -1,4 +1,4 @@
-       $NetBSD: syscalls.master,v 1.73 2019/11/09 23:44:32 jdolecek Exp $  
+       $NetBSD: syscalls.master,v 1.74 2020/04/26 18:53:32 thorpej Exp $  
 
 ;      @(#)syscalls.master     8.1 (Berkeley) 7/19/93
 
@@ -514,11 +514,15 @@
                            linux_umode_t mode); }
 298    STD             { int|linux_sys||faccessat(int fd, const char *path, \
                            int amode); }
-299    STD             { int|linux_sys||set_robust_list( \
-                           struct linux_robust_list_head *head, size_t len); }
-300    STD             { int|linux_sys||get_robust_list(int pid, \
-                           struct linux_robust_list_head **head, \
-                           size_t *len); }
+                       ;
+                       ; The NetBSD native robust list calls have different
+                       ; argument names / types, but they are ABI-compatible
+                       ; with Linux.



Home | Main Index | Thread Index | Old Index