Module Name: src Committed By: christos Date: Sun May 19 22:25:49 UTC 2024
Modified Files: src/include: unistd.h src/lib/libc/compat/include: unistd.h src/lib/libc/compat/sys: Makefile.inc src/lib/libc/sys: Makefile.inc src/sys/compat/common: compat_mod.h files.common src/sys/compat/netbsd32: files.netbsd32 netbsd32_netbsd.c syscalls.conf syscalls.master src/sys/conf: files src/sys/kern: sys_descrip.c syscalls.conf syscalls.master src/sys/modules: Makefile src/sys/rump: Makefile.rump Added Files: src/lib/libc/compat/sys: compat_dup3.c src/sys/compat/common: compat_110_mod.c sys_decrip_110.c src/sys/compat/netbsd32: netbsd32_compat_110.c src/sys/conf: compat_netbsd110.config src/sys/modules/compat_110: Makefile src/sys/modules/compat_netbsd32_110: Makefile Log Message: version dup3 To generate a diff of this commit: cvs rdiff -u -r1.164 -r1.165 src/include/unistd.h cvs rdiff -u -r1.3 -r1.4 src/lib/libc/compat/include/unistd.h cvs rdiff -u -r1.11 -r1.12 src/lib/libc/compat/sys/Makefile.inc cvs rdiff -u -r0 -r1.1 src/lib/libc/compat/sys/compat_dup3.c cvs rdiff -u -r1.253 -r1.254 src/lib/libc/sys/Makefile.inc cvs rdiff -u -r0 -r1.1 src/sys/compat/common/compat_110_mod.c \ src/sys/compat/common/sys_decrip_110.c cvs rdiff -u -r1.10 -r1.11 src/sys/compat/common/compat_mod.h cvs rdiff -u -r1.11 -r1.12 src/sys/compat/common/files.common cvs rdiff -u -r1.55 -r1.56 src/sys/compat/netbsd32/files.netbsd32 cvs rdiff -u -r0 -r1.1 src/sys/compat/netbsd32/netbsd32_compat_110.c cvs rdiff -u -r1.235 -r1.236 src/sys/compat/netbsd32/netbsd32_netbsd.c cvs rdiff -u -r1.18 -r1.19 src/sys/compat/netbsd32/syscalls.conf cvs rdiff -u -r1.144 -r1.145 src/sys/compat/netbsd32/syscalls.master cvs rdiff -u -r0 -r1.1 src/sys/conf/compat_netbsd110.config cvs rdiff -u -r1.1312 -r1.1313 src/sys/conf/files cvs rdiff -u -r1.49 -r1.50 src/sys/kern/sys_descrip.c cvs rdiff -u -r1.32 -r1.33 src/sys/kern/syscalls.conf cvs rdiff -u -r1.311 -r1.312 src/sys/kern/syscalls.master cvs rdiff -u -r1.286 -r1.287 src/sys/modules/Makefile cvs rdiff -u -r0 -r1.1 src/sys/modules/compat_110/Makefile cvs rdiff -u -r0 -r1.1 src/sys/modules/compat_netbsd32_110/Makefile cvs rdiff -u -r1.136 -r1.137 src/sys/rump/Makefile.rump Please note that diffs are not public domain; they are subject to the copyright notices on the relevant files.
Modified files: Index: src/include/unistd.h diff -u src/include/unistd.h:1.164 src/include/unistd.h:1.165 --- src/include/unistd.h:1.164 Fri Jan 19 13:40:35 2024 +++ src/include/unistd.h Sun May 19 18:25:47 2024 @@ -1,4 +1,4 @@ -/* $NetBSD: unistd.h,v 1.164 2024/01/19 18:40:35 christos Exp $ */ +/* $NetBSD: unistd.h,v 1.165 2024/05/19 22:25:47 christos Exp $ */ /*- * Copyright (c) 1998, 1999, 2008 The NetBSD Foundation, Inc. @@ -329,7 +329,9 @@ int acct(const char *); int closefrom(int); int des_cipher(const char *, char *, long, int); int des_setkey(const char *); -int dup3(int, int, int); +#ifndef __LIBC12_SOURCE__ +int dup3(int, int, int) __RENAME(__dup3110); +#endif void endusershell(void); int exect(const char *, char * const *, char * const *); int execvpe(const char *, char * const *, char * const *); Index: src/lib/libc/compat/include/unistd.h diff -u src/lib/libc/compat/include/unistd.h:1.3 src/lib/libc/compat/include/unistd.h:1.4 --- src/lib/libc/compat/include/unistd.h:1.3 Sat Jan 20 09:52:46 2024 +++ src/lib/libc/compat/include/unistd.h Sun May 19 18:25:47 2024 @@ -1,4 +1,4 @@ -/* $NetBSD: unistd.h,v 1.3 2024/01/20 14:52:46 christos Exp $ */ +/* $NetBSD: unistd.h,v 1.4 2024/05/19 22:25:47 christos Exp $ */ /*- * Copyright (c) 1998, 1999 The NetBSD Foundation, Inc. @@ -64,8 +64,12 @@ #define _COMPAT_UNISTD_H_ __BEGIN_DECLS -pid_t vfork(void) __returns_twice; -pid_t __vfork14(void) __returns_twice; + +pid_t vfork(void) __returns_twice; +pid_t __vfork14(void) __returns_twice; +int dup3(int, int, int); +int __dup3110(int, int, int); + __END_DECLS #endif /* !_COMPAT_UNISTD_H_ */ Index: src/lib/libc/compat/sys/Makefile.inc diff -u src/lib/libc/compat/sys/Makefile.inc:1.11 src/lib/libc/compat/sys/Makefile.inc:1.12 --- src/lib/libc/compat/sys/Makefile.inc:1.11 Mon Nov 1 01:53:45 2021 +++ src/lib/libc/compat/sys/Makefile.inc Sun May 19 18:25:47 2024 @@ -1,8 +1,8 @@ -# $NetBSD: Makefile.inc,v 1.11 2021/11/01 05:53:45 thorpej Exp $ +# $NetBSD: Makefile.inc,v 1.12 2024/05/19 22:25:47 christos Exp $ .PATH: ${COMPATDIR}/sys SRCS+= compat_getdents.c compat_getdirentries.c compat_msync.c \ - compat_ntp_gettime.c compat_sched.c \ + compat_ntp_gettime.c compat_sched.c compat_dup3.c \ compat_semctl.c compat_sigaltstack.c compat_stat.c compat___stat13.c \ compat_statfs.c compat_statvfs.c compat_socket.c compat_getfh.c \ compat_fhopen.c compat___fhstat30.c compat_fhstatvfs.c compat_fhstatvfs1.c \ Index: src/lib/libc/sys/Makefile.inc diff -u src/lib/libc/sys/Makefile.inc:1.253 src/lib/libc/sys/Makefile.inc:1.254 --- src/lib/libc/sys/Makefile.inc:1.253 Thu Aug 3 08:24:46 2023 +++ src/lib/libc/sys/Makefile.inc Sun May 19 18:25:48 2024 @@ -1,4 +1,4 @@ -# $NetBSD: Makefile.inc,v 1.253 2023/08/03 12:24:46 nia Exp $ +# $NetBSD: Makefile.inc,v 1.254 2024/05/19 22:25:48 christos Exp $ # @(#)Makefile.inc 8.3 (Berkeley) 10/24/94 # sys sources @@ -102,7 +102,7 @@ ASM=\ chdir.S chflags.S chmod.S chown.S chroot.S \ clock_getcpuclockid2.S \ __clock_getres50.S __clock_gettime50.S \ - dup.S dup2.S dup3.S \ + dup.S dup2.S __dup3110.S \ eventfd.S \ extattrctl.S \ extattr_delete_fd.S extattr_delete_file.S \ Index: src/sys/compat/common/compat_mod.h diff -u src/sys/compat/common/compat_mod.h:1.10 src/sys/compat/common/compat_mod.h:1.11 --- src/sys/compat/common/compat_mod.h:1.10 Sat Dec 9 10:21:01 2023 +++ src/sys/compat/common/compat_mod.h Sun May 19 18:25:48 2024 @@ -1,4 +1,4 @@ -/* $NetBSD: compat_mod.h,v 1.10 2023/12/09 15:21:01 pgoyette Exp $ */ +/* $NetBSD: compat_mod.h,v 1.11 2024/05/19 22:25:48 christos Exp $ */ /*- * Copyright (c) 2013, 2019 The NetBSD Foundation, Inc. @@ -32,13 +32,18 @@ #ifndef _COMPAT_MOD_H #define _COMPAT_MOD_H +#ifdef COMPAT_110 +int compat_110_init(void); +int compat_110_fini(void); +int sys_descrip_110_init(void); +int sys_descrip_110_fini(void); +#endif + #ifdef COMPAT_100 int compat_100_init(void); int compat_100_fini(void); int kern_event_100_init(void); int kern_event_100_fini(void); -void usb_100_init(void); -void usb_100_fini(void); #endif #ifdef COMPAT_90 Index: src/sys/compat/common/files.common diff -u src/sys/compat/common/files.common:1.11 src/sys/compat/common/files.common:1.12 --- src/sys/compat/common/files.common:1.11 Sat Dec 9 10:21:01 2023 +++ src/sys/compat/common/files.common Sun May 19 18:25:48 2024 @@ -1,4 +1,4 @@ -# $NetBSD: files.common,v 1.11 2023/12/09 15:21:01 pgoyette Exp $ +# $NetBSD: files.common,v 1.12 2024/05/19 22:25:48 christos Exp $ # # Generic utility files, used by various compat options. @@ -114,7 +114,10 @@ file compat/common/net_inet6_nd_90.c co # Compatibility code for NetBSD 10.0 file compat/common/compat_100_mod.c compat_100 file compat/common/kern_event_100.c compat_100 -#file compat/common/usb_subr_100.c compat_100 + +# Compatibility code for NetBSD 11.0 +file compat/common/compat_110_mod.c compat_110 +file compat/common/sys_descrip_110.c compat_110 # # Sources for sysv ipc compatibility across the versions. Index: src/sys/compat/netbsd32/files.netbsd32 diff -u src/sys/compat/netbsd32/files.netbsd32:1.55 src/sys/compat/netbsd32/files.netbsd32:1.56 --- src/sys/compat/netbsd32/files.netbsd32:1.55 Sun Jul 30 02:52:20 2023 +++ src/sys/compat/netbsd32/files.netbsd32 Sun May 19 18:25:48 2024 @@ -1,4 +1,4 @@ -# $NetBSD: files.netbsd32,v 1.55 2023/07/30 06:52:20 rin Exp $ +# $NetBSD: files.netbsd32,v 1.56 2024/05/19 22:25:48 christos Exp $ # # config file description for machine-independent netbsd32 compat code. # included by ports that need it. @@ -66,3 +66,4 @@ file compat/netbsd32/netbsd32_compat_60. file compat/netbsd32/netbsd32_compat_80.c compat_netbsd32 & compat_80 file compat/netbsd32/netbsd32_compat_90.c compat_netbsd32 & compat_90 file compat/netbsd32/netbsd32_compat_100.c compat_netbsd32 & compat_100 +file compat/netbsd32/netbsd32_compat_110.c compat_netbsd32 & compat_110 Index: src/sys/compat/netbsd32/netbsd32_netbsd.c diff -u src/sys/compat/netbsd32/netbsd32_netbsd.c:1.235 src/sys/compat/netbsd32/netbsd32_netbsd.c:1.236 --- src/sys/compat/netbsd32/netbsd32_netbsd.c:1.235 Sun Jul 30 01:30:45 2023 +++ src/sys/compat/netbsd32/netbsd32_netbsd.c Sun May 19 18:25:48 2024 @@ -1,4 +1,4 @@ -/* $NetBSD: netbsd32_netbsd.c,v 1.235 2023/07/30 05:30:45 rin Exp $ */ +/* $NetBSD: netbsd32_netbsd.c,v 1.236 2024/05/19 22:25:48 christos Exp $ */ /* * Copyright (c) 1998, 2001, 2008, 2018 Matthew R. Green @@ -27,7 +27,7 @@ */ #include <sys/cdefs.h> -__KERNEL_RCSID(0, "$NetBSD: netbsd32_netbsd.c,v 1.235 2023/07/30 05:30:45 rin Exp $"); +__KERNEL_RCSID(0, "$NetBSD: netbsd32_netbsd.c,v 1.236 2024/05/19 22:25:48 christos Exp $"); /* * below are all the standard NetBSD system calls, in the 32bit @@ -2462,7 +2462,7 @@ netbsd32__sched_protect(struct lwp *l, } int -netbsd32_dup3(struct lwp *l, const struct netbsd32_dup3_args *uap, +netbsd32___dup3110(struct lwp *l, const struct netbsd32___dup3110_args *uap, register_t *retval) { /* { @@ -2470,13 +2470,13 @@ netbsd32_dup3(struct lwp *l, const struc syscallarg(int) to; syscallarg(int) flags; } */ - struct sys_dup3_args ua; + struct sys___dup3110_args ua; NETBSD32TO64_UAP(from); NETBSD32TO64_UAP(to); NETBSD32TO64_UAP(flags); - return sys_dup3(l, &ua, retval); + return sys___dup3110(l, &ua, retval); } int Index: src/sys/compat/netbsd32/syscalls.conf diff -u src/sys/compat/netbsd32/syscalls.conf:1.18 src/sys/compat/netbsd32/syscalls.conf:1.19 --- src/sys/compat/netbsd32/syscalls.conf:1.18 Mon Dec 19 18:19:51 2022 +++ src/sys/compat/netbsd32/syscalls.conf Sun May 19 18:25:48 2024 @@ -1,4 +1,4 @@ -# $NetBSD: syscalls.conf,v 1.18 2022/12/19 23:19:51 pgoyette Exp $ +# $NetBSD: syscalls.conf,v 1.19 2024/05/19 22:25:48 christos Exp $ sysnames="netbsd32_syscalls.c" sysnumhdr="netbsd32_syscall.h" @@ -6,7 +6,7 @@ syssw="netbsd32_sysent.c" sysarghdr="netbsd32_syscallargs.h" systrace="netbsd32_systrace_args.c" sysautoload="netbsd32_syscalls_autoload.c" -compatopts="compat_43 compat_09 compat_10 compat_11 compat_12 compat_13 compat_14 compat_15 compat_16 compat_20 compat_30 compat_40 compat_50 compat_60 compat_70 compat_80 compat_90 compat_100" +compatopts="compat_43 compat_09 compat_10 compat_11 compat_12 compat_13 compat_14 compat_15 compat_16 compat_20 compat_30 compat_40 compat_50 compat_60 compat_70 compat_80 compat_90 compat_100 compat_110" libcompatopts="" switchname="netbsd32_sysent" Index: src/sys/compat/netbsd32/syscalls.master diff -u src/sys/compat/netbsd32/syscalls.master:1.144 src/sys/compat/netbsd32/syscalls.master:1.145 --- src/sys/compat/netbsd32/syscalls.master:1.144 Sun Jul 30 02:52:20 2023 +++ src/sys/compat/netbsd32/syscalls.master Sun May 19 18:25:48 2024 @@ -1,4 +1,4 @@ - $NetBSD: syscalls.master,v 1.144 2023/07/30 06:52:20 rin Exp $ + $NetBSD: syscalls.master,v 1.145 2024/05/19 22:25:48 christos Exp $ ; from: NetBSD: syscalls.master,v 1.81 1998/07/05 08:49:50 jonathan Exp ; @(#)syscalls.master 8.2 (Berkeley) 1/13/94 @@ -1069,7 +1069,8 @@ netbsd32_size_t fh_size, netbsd32_statp_t sb); } 452 OBSOL 5.99 quotactl 453 STD { int|netbsd32||pipe2(netbsd32_intp fildes, int flags); } -454 STD { int|netbsd32||dup3(int from, int to, int flags); } +454 COMPAT_110 MODULAR compat_netbsd32_110 \ + { int|netbsd32||dup3(int from, int to, int flags); } 455 STD { int|netbsd32||kqueue1(int flags); } 456 STD { int|netbsd32||paccept(int s, \ netbsd32_sockaddrp_t name, \ @@ -1229,3 +1230,5 @@ netbsd32_epoll_eventp_t events, int maxevents, \ netbsd32_timespecp_t timeout, \ netbsd32_sigsetp_t sigmask); } +505 STD { int|netbsd32|110|dup3(int from, int to, \ + int flags); } Index: src/sys/conf/files diff -u src/sys/conf/files:1.1312 src/sys/conf/files:1.1313 --- src/sys/conf/files:1.1312 Tue Apr 2 18:30:03 2024 +++ src/sys/conf/files Sun May 19 18:25:48 2024 @@ -1,4 +1,4 @@ -# $NetBSD: files,v 1.1312 2024/04/02 22:30:03 charlotte Exp $ +# $NetBSD: files,v 1.1313 2024/05/19 22:25:48 christos Exp $ # @(#)files.newconf 7.5 (Berkeley) 5/10/93 version 20171118 @@ -151,7 +151,8 @@ defflag opt_efi.h EFI_RUNTIME # compatibility options # defflag opt_compat_netbsd.h COMPAT_NETBSD -defflag opt_compat_netbsd.h COMPAT_100: COMPAT_NETBSD +defflag opt_compat_netbsd.h COMPAT_110: COMPAT_NETBSD +defflag opt_compat_netbsd.h COMPAT_100: COMPAT_110, COMPAT_NETBSD defflag opt_compat_netbsd.h COMPAT_90: COMPAT_100, COMPAT_NETBSD defflag opt_compat_netbsd.h COMPAT_80: COMPAT_90, COMPAT_NETBSD defflag opt_compat_netbsd.h COMPAT_70: COMPAT_80, COMPAT_NETBSD Index: src/sys/kern/sys_descrip.c diff -u src/sys/kern/sys_descrip.c:1.49 src/sys/kern/sys_descrip.c:1.50 --- src/sys/kern/sys_descrip.c:1.49 Sun May 19 11:56:55 2024 +++ src/sys/kern/sys_descrip.c Sun May 19 18:25:48 2024 @@ -1,4 +1,4 @@ -/* $NetBSD: sys_descrip.c,v 1.49 2024/05/19 15:56:55 christos Exp $ */ +/* $NetBSD: sys_descrip.c,v 1.50 2024/05/19 22:25:48 christos Exp $ */ /*- * Copyright (c) 2008, 2020 The NetBSD Foundation, Inc. @@ -67,7 +67,7 @@ */ #include <sys/cdefs.h> -__KERNEL_RCSID(0, "$NetBSD: sys_descrip.c,v 1.49 2024/05/19 15:56:55 christos Exp $"); +__KERNEL_RCSID(0, "$NetBSD: sys_descrip.c,v 1.50 2024/05/19 22:25:48 christos Exp $"); #include <sys/param.h> #include <sys/systm.h> @@ -149,7 +149,7 @@ dodup(struct lwp *l, int from, int to, i } int -sys_dup3(struct lwp *l, const struct sys_dup3_args *uap, register_t *retval) +sys___dup3110(struct lwp *l, const struct sys___dup3110_args *uap, register_t *retval) { /* { syscallarg(int) from; Index: src/sys/kern/syscalls.conf diff -u src/sys/kern/syscalls.conf:1.32 src/sys/kern/syscalls.conf:1.33 --- src/sys/kern/syscalls.conf:1.32 Fri Jul 28 14:19:01 2023 +++ src/sys/kern/syscalls.conf Sun May 19 18:25:48 2024 @@ -1,4 +1,4 @@ -# $NetBSD: syscalls.conf,v 1.32 2023/07/28 18:19:01 christos Exp $ +# $NetBSD: syscalls.conf,v 1.33 2024/05/19 22:25:48 christos Exp $ sysnames="syscalls.c" sysnumhdr="../sys/syscall.h" @@ -11,7 +11,7 @@ sysalign=1 rumpcalls="../rump/librump/rumpkern/rump_syscalls.c" rumpcallshdr="../rump/include/rump/rump_syscalls.h" rumpsysmap="../rump/rump.sysmap" -compatopts="compat_43 compat_09 compat_10 compat_11 compat_12 compat_13 compat_14 compat_15 compat_16 compat_20 compat_30 compat_40 compat_50 compat_60 compat_70 compat_80 compat_90 compat_100" +compatopts="compat_43 compat_09 compat_10 compat_11 compat_12 compat_13 compat_14 compat_15 compat_16 compat_20 compat_30 compat_40 compat_50 compat_60 compat_70 compat_80 compat_90 compat_100 compat_110" libcompatopts="" switchname="sysent" Index: src/sys/kern/syscalls.master diff -u src/sys/kern/syscalls.master:1.311 src/sys/kern/syscalls.master:1.312 --- src/sys/kern/syscalls.master:1.311 Fri Jul 28 14:19:01 2023 +++ src/sys/kern/syscalls.master Sun May 19 18:25:48 2024 @@ -1,4 +1,4 @@ - $NetBSD: syscalls.master,v 1.311 2023/07/28 18:19:01 christos Exp $ + $NetBSD: syscalls.master,v 1.312 2024/05/19 22:25:48 christos Exp $ ; @(#)syscalls.master 8.2 (Berkeley) 1/13/94 @@ -954,7 +954,8 @@ ; 452 only ever appeared in 5.99.x and can be reused after netbsd-7 452 OBSOL 5.99 quotactl 453 STD RUMP { int|sys||pipe2(int *fildes, int flags); } -454 STD RUMP { int|sys||dup3(int from, int to, int flags); } +454 COMPAT_110 MODULAR compat_110 RUMP \ + { int|sys||dup3(int from, int to, int flags); } 455 STD RUMP { int|sys||kqueue1(int flags); } 456 STD RUMP { int|sys||paccept(int s, struct sockaddr *name, \ socklen_t *anamelen, const sigset_t *mask, \ @@ -1063,3 +1064,4 @@ struct epoll_event *events, int maxevents, \ const struct timespec *timeout, \ const sigset_t *sigmask); } +505 STD RUMP { int|sys|110|dup3(int from, int to, int flags); } Index: src/sys/modules/Makefile diff -u src/sys/modules/Makefile:1.286 src/sys/modules/Makefile:1.287 --- src/sys/modules/Makefile:1.286 Thu May 9 08:09:59 2024 +++ src/sys/modules/Makefile Sun May 19 18:25:49 2024 @@ -1,4 +1,4 @@ -# $NetBSD: Makefile,v 1.286 2024/05/09 12:09:59 pho Exp $ +# $NetBSD: Makefile,v 1.287 2024/05/19 22:25:49 christos Exp $ .include <bsd.own.mk> @@ -12,6 +12,7 @@ SUBDIR+= compat_43 compat_sysctl_09_43 SUBDIR+= compat_09 compat_10 compat_12 compat_13 compat_14 SUBDIR+= compat_16 compat_20 compat_30 compat_40 compat_50 SUBDIR+= compat_60 compat_70 compat_80 compat_90 compat_100 +SUBDIR+= compat_110 SUBDIR+= compat_sysv_10 compat_sysv_14 compat_sysv_50 @@ -318,6 +319,7 @@ SUBDIR+= compat_netbsd32_20 compat_netbs SUBDIR+= compat_netbsd32_40 compat_netbsd32_50 SUBDIR+= compat_netbsd32_60 compat_netbsd32_80 SUBDIR+= compat_netbsd32_90 compat_netbsd32_100 +SUBDIR+= compat_netbsd32_110 SUBDIR+= compat_netbsd32_43 SUBDIR+= compat_netbsd32_coredump SUBDIR+= compat_netbsd32_mqueue Index: src/sys/rump/Makefile.rump diff -u src/sys/rump/Makefile.rump:1.136 src/sys/rump/Makefile.rump:1.137 --- src/sys/rump/Makefile.rump:1.136 Sun Feb 4 13:52:36 2024 +++ src/sys/rump/Makefile.rump Sun May 19 18:25:49 2024 @@ -1,4 +1,4 @@ -# $NetBSD: Makefile.rump,v 1.136 2024/02/04 18:52:36 andvar Exp $ +# $NetBSD: Makefile.rump,v 1.137 2024/05/19 22:25:49 christos Exp $ # .if !defined(_RUMP_MK) @@ -48,7 +48,7 @@ CPPFLAGS+= -DMIPS1=1 # which NetBSD compat to build RUMP_NBCOMPAT?=default .if ${RUMP_NBCOMPAT} == "all" || ${RUMP_NBCOMPAT} == "default" -RUMP_NBCOMPAT= 50 60 70 80 90 100 +RUMP_NBCOMPAT= 50 60 70 80 90 100 110 .endif .if ${RUMP_NBCOMPAT} == "none" RUMP_NBCOMPAT= Added files: Index: src/lib/libc/compat/sys/compat_dup3.c diff -u /dev/null src/lib/libc/compat/sys/compat_dup3.c:1.1 --- /dev/null Sun May 19 18:25:49 2024 +++ src/lib/libc/compat/sys/compat_dup3.c Sun May 19 18:25:48 2024 @@ -0,0 +1,62 @@ +/* $NetBSD: compat_dup3.c,v 1.1 2024/05/19 22:25:48 christos Exp $ */ + +/*- + * Copyright (c) 2024 The NetBSD Foundation, Inc. + * All rights reserved. + * + * This code is derived from software contributed to The NetBSD Foundation + * by Christos Zoulas. + * + * 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. + */ +#include <sys/cdefs.h> +#if defined(LIBC_SCCS) && !defined(lint) +__RCSID("$NetBSD: compat_dup3.c,v 1.1 2024/05/19 22:25:48 christos Exp $"); +#endif /* LIBC_SCCS and not lint */ + +#include "namespace.h" +#define __LIBC12_SOURCE__ +#include <fcntl.h> +#include <compat/include/unistd.h> + +__warn_references(dup3, + "warning: reference to compatibility dup3(); include <unistd.h> to generate correct reference") + +int +dup3(int oldfd, int newfd, int flags) +{ + if (oldfd != newfd) { + return __dup3110(oldfd, newfd, flags); + } + if (flags & (O_NONBLOCK|O_NOSIGPIPE)) { + int e = fcntl(newfd, F_GETFL, 0); + if (e == -1) + return -1; + e |= flags & (O_NONBLOCK|O_NOSIGPIPE); + e = fcntl(newfd, F_SETFL, e); + if (e == -1) + return -1; + } + if (flags & O_CLOEXEC) + return fcntl(newfd, F_SETFD, FD_CLOEXEC); + return 0; +} Index: src/sys/compat/common/compat_110_mod.c diff -u /dev/null src/sys/compat/common/compat_110_mod.c:1.1 --- /dev/null Sun May 19 18:25:49 2024 +++ src/sys/compat/common/compat_110_mod.c Sun May 19 18:25:48 2024 @@ -0,0 +1,79 @@ +/* $NetBSD: compat_110_mod.c,v 1.1 2024/05/19 22:25:48 christos Exp $ */ + +/*- + * Copyright (c) 2019 The NetBSD Foundation, Inc. + * All rights reserved. + * + * This code is derived from software developed for The NetBSD Foundation + * by Paul Goyette + * + * 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. + */ + +/* + * Linkage for the compat module: spaghetti. + */ + +#if defined(_KERNEL_OPT) +#include "opt_compat_netbsd.h" +#endif + +#include <sys/cdefs.h> +__KERNEL_RCSID(0, "$NetBSD: compat_110_mod.c,v 1.1 2024/05/19 22:25:48 christos Exp $"); + +#include <sys/systm.h> +#include <sys/module.h> + +#include <compat/common/compat_util.h> +#include <compat/common/compat_mod.h> + +int +compat_110_init(void) +{ + + return sys_descrip_110_init(); +} + +int +compat_110_fini(void) +{ + + return sys_descrip_110_fini(); +} + +MODULE(MODULE_CLASS_EXEC, compat_110, NULL); + +static int +compat_110_modcmd(modcmd_t cmd, void *arg) +{ + + switch (cmd) { + case MODULE_CMD_INIT: + return compat_110_init(); + + case MODULE_CMD_FINI: + return compat_110_fini(); + + default: + return ENOTTY; + } +} Index: src/sys/compat/common/sys_decrip_110.c diff -u /dev/null src/sys/compat/common/sys_decrip_110.c:1.1 --- /dev/null Sun May 19 18:25:49 2024 +++ src/sys/compat/common/sys_decrip_110.c Sun May 19 18:25:48 2024 @@ -0,0 +1,74 @@ +/* $NetBSD: sys_decrip_110.c,v 1.1 2024/05/19 22:25:48 christos Exp $ */ + +/*- + * Copyright (c) 2024 The NetBSD Foundation, Inc. + * All rights reserved. + * + * 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. + */ +#include <sys/cdefs.h> +__KERNEL_RCSID(0, "$NetBSD: sys_decrip_110.c,v 1.1 2024/05/19 22:25:48 christos Exp $"); + +#if defined(_KERNEL_OPT) +#include "opt_compat_netbsd.h" +#endif + +#include <sys/param.h> +#include <sys/filedesc.h> +#include <sys/syscall.h> +#include <sys/syscallvar.h> +#include <sys/syscallargs.h> + +#include <compat/common/compat_mod.h> + +static const struct syscall_package sys_descrip_110_syscalls[] = { + { SYS_compat_110_dup3, 0, + (sy_call_t *)compat_110_sys_dup3 }, + { 0, 0, NULL }, +}; + +int +sys_descrip_110_init(void) +{ + + return syscall_establish(NULL, sys_descrip_110_syscalls); +} + +int +sys_descrip_110_fini(void) +{ + + return syscall_disestablish(NULL, sys_descrip_110_syscalls); +} + +int +compat_110_sys_dup3(struct lwp *l, const struct compat_110_sys_dup3_args *uap, + register_t *retval) +{ + /* { + syscallarg(int) from; + syscallarg(int) to; + syscallarg(int) flags; + } */ + return dodup(l, SCARG(uap, from), SCARG(uap, to), SCARG(uap, flags), + retval); +} Index: src/sys/compat/netbsd32/netbsd32_compat_110.c diff -u /dev/null src/sys/compat/netbsd32/netbsd32_compat_110.c:1.1 --- /dev/null Sun May 19 18:25:49 2024 +++ src/sys/compat/netbsd32/netbsd32_compat_110.c Sun May 19 18:25:48 2024 @@ -0,0 +1,88 @@ +/* $NetBSD: netbsd32_compat_110.c,v 1.1 2024/05/19 22:25:48 christos Exp $ */ + +/*- + * Copyright (c) 2024 The NetBSD Foundation, Inc. + * All rights reserved. + * + * This code is derived from software developed for The NetBSD Foundation + * by Christos Zoulas. + * + * 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. + */ + +#include <sys/cdefs.h> +__KERNEL_RCSID(0, "$NetBSD: netbsd32_compat_110.c,v 1.1 2024/05/19 22:25:48 christos Exp $"); + +#include <sys/types.h> +#include <sys/filedesc.h> +#include <sys/module.h> +#include <sys/syscallvar.h> +#include <sys/syscallargs.h> +#include <sys/systm.h> + +#include <compat/netbsd32/netbsd32.h> +#include <compat/netbsd32/netbsd32_syscall.h> +#include <compat/netbsd32/netbsd32_syscallargs.h> + +int +compat_110_netbsd32_dup3(struct lwp *l, + const struct compat_110_netbsd32_dup3_args *uap, register_t *retval) +{ + /* { + syscallarg(int) from; + syscallarg(int) to; + syscallarg(int) flags; + syscallarg(const netbsd32_kevent100p_t) changelist; + syscallarg(netbsd32_size_t) nchanges; + syscallarg(netbsd32_kevent100p_t) eventlist; + syscallarg(netbsd32_size_t) nevents; + syscallarg(netbsd32_timespecp_t) timeout; + } */ + return dodup(l, SCARG(uap, from), SCARG(uap, to), SCARG(uap, flags), + retval); +} + +static struct syscall_package compat_netbsd32_110_syscalls[] = { + { NETBSD32_SYS_compat_110_netbsd32_dup3, 0, + (sy_call_t *)compat_110_netbsd32_dup3 }, + { 0, 0, NULL }, +}; + +MODULE(MODULE_CLASS_EXEC, compat_netbsd32_110, "compat_netbsd32,compat_110"); + +static int +compat_netbsd32_110_modcmd(modcmd_t cmd, void *arg) +{ + + switch (cmd) { + case MODULE_CMD_INIT: + return syscall_establish(&emul_netbsd32, + compat_netbsd32_110_syscalls); + + case MODULE_CMD_FINI: + return syscall_disestablish(&emul_netbsd32, + compat_netbsd32_110_syscalls); + + default: + return ENOTTY; + } +} Index: src/sys/conf/compat_netbsd110.config diff -u /dev/null src/sys/conf/compat_netbsd110.config:1.1 --- /dev/null Sun May 19 18:25:49 2024 +++ src/sys/conf/compat_netbsd110.config Sun May 19 18:25:48 2024 @@ -0,0 +1,9 @@ +# $NetBSD: compat_netbsd110.config,v 1.1 2024/05/19 22:25:48 christos Exp $ + +# Common fragment for all NetBSD targets wanting NetBSD 10.0 and newer +# compatibility support. +# +# Note that COMPAT_110 implies all newer COMPAT_XX options. + +include "conf/compat_netbsd.config" +options COMPAT_110 # NetBSD 11.0 and beyond. Index: src/sys/modules/compat_110/Makefile diff -u /dev/null src/sys/modules/compat_110/Makefile:1.1 --- /dev/null Sun May 19 18:25:49 2024 +++ src/sys/modules/compat_110/Makefile Sun May 19 18:25:49 2024 @@ -0,0 +1,13 @@ +# $NetBSD: Makefile,v 1.1 2024/05/19 22:25:49 christos Exp $ + +.include "../Makefile.inc" + +.PATH: ${S}/compat/common + +KMOD= compat_110 + +CPPFLAGS+= -DCOMPAT_110 + +SRCS+= compat_110_mod.c sys_decrip_110.c + +.include <bsd.kmodule.mk> Index: src/sys/modules/compat_netbsd32_110/Makefile diff -u /dev/null src/sys/modules/compat_netbsd32_110/Makefile:1.1 --- /dev/null Sun May 19 18:25:49 2024 +++ src/sys/modules/compat_netbsd32_110/Makefile Sun May 19 18:25:49 2024 @@ -0,0 +1,14 @@ +# $NetBSD: Makefile,v 1.1 2024/05/19 22:25:49 christos Exp $ + +.include "../Makefile.inc" + +.PATH: ${S}/compat/netbsd32 + +KMOD= compat_netbsd32_110 + +CPPFLAGS+= -DCOMPAT_NETBSD32 +CPPFLAGS+= -DCOMPAT_110 + +SRCS+= netbsd32_compat_110.c + +.include <bsd.kmodule.mk>