Module Name:    src
Committed By:   reinoud
Date:           Sat Apr 23 17:46:23 UTC 2022

Modified Files:
        src/sys/compat/netbsd32: netbsd32.h netbsd32_fs.c

Log Message:
Implement support for mounting UDF in compat32
Fixes PR#56801


To generate a diff of this commit:
cvs rdiff -u -r1.139 -r1.140 src/sys/compat/netbsd32/netbsd32.h
cvs rdiff -u -r1.94 -r1.95 src/sys/compat/netbsd32/netbsd32_fs.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/netbsd32/netbsd32.h
diff -u src/sys/compat/netbsd32/netbsd32.h:1.139 src/sys/compat/netbsd32/netbsd32.h:1.140
--- src/sys/compat/netbsd32/netbsd32.h:1.139	Thu Nov 11 17:32:46 2021
+++ src/sys/compat/netbsd32/netbsd32.h	Sat Apr 23 17:46:23 2022
@@ -1,4 +1,4 @@
-/*	$NetBSD: netbsd32.h,v 1.139 2021/11/11 17:32:46 martin Exp $	*/
+/*	$NetBSD: netbsd32.h,v 1.140 2022/04/23 17:46:23 reinoud Exp $	*/
 
 /*
  * Copyright (c) 1998, 2001, 2008, 2015 Matthew R. Green
@@ -1140,6 +1140,25 @@ struct netbsd32_msdosfs_args {
 	int	gmtoff;		/* v3: offset from UTC in seconds */
 };
 
+/* from <udf/udf_mount.h> */
+struct netbsd32_udf_args {
+	uint32_t	 version;	/* version of this structure         */
+	netbsd32_charp	 fspec;		/* mount specifier                   */
+	int32_t		 sessionnr;	/* session specifier, rel of abs     */
+	uint32_t	 udfmflags;	/* mount options                     */
+	int32_t		 gmtoff;	/* offset from UTC in seconds        */
+
+	uid_t		 anon_uid;	/* mapping of anonymous files uid    */
+	gid_t		 anon_gid;	/* mapping of anonymous files gid    */
+	uid_t		 nobody_uid;	/* nobody:nobody will map to -1:-1   */
+	gid_t		 nobody_gid;	/* nobody:nobody will map to -1:-1   */
+
+	uint32_t	 sector_size;	/* for mounting dumps/files          */
+
+	/* extendable */
+	uint8_t	 reserved[32];
+};
+
 /* from <miscfs/genfs/layer.h> */
 struct netbsd32_layer_args {
 	netbsd32_charp target;		/* Target of loopback  */

Index: src/sys/compat/netbsd32/netbsd32_fs.c
diff -u src/sys/compat/netbsd32/netbsd32_fs.c:1.94 src/sys/compat/netbsd32/netbsd32_fs.c:1.95
--- src/sys/compat/netbsd32/netbsd32_fs.c:1.94	Sat Sep 11 10:08:55 2021
+++ src/sys/compat/netbsd32/netbsd32_fs.c	Sat Apr 23 17:46:23 2022
@@ -1,4 +1,4 @@
-/*	$NetBSD: netbsd32_fs.c,v 1.94 2021/09/11 10:08:55 riastradh Exp $	*/
+/*	$NetBSD: netbsd32_fs.c,v 1.95 2022/04/23 17:46:23 reinoud Exp $	*/
 
 /*
  * Copyright (c) 1998, 2001 Matthew R. Green
@@ -27,7 +27,7 @@
  */
 
 #include <sys/cdefs.h>
-__KERNEL_RCSID(0, "$NetBSD: netbsd32_fs.c,v 1.94 2021/09/11 10:08:55 riastradh Exp $");
+__KERNEL_RCSID(0, "$NetBSD: netbsd32_fs.c,v 1.95 2022/04/23 17:46:23 reinoud Exp $");
 
 #include <sys/param.h>
 #include <sys/systm.h>
@@ -53,6 +53,7 @@ __KERNEL_RCSID(0, "$NetBSD: netbsd32_fs.
 #include <fs/tmpfs/tmpfs_args.h>
 #include <fs/msdosfs/bpb.h>
 #include <fs/msdosfs/msdosfsmount.h>
+#include <fs/udf/udf_mount.h>
 #include <ufs/ufs/ufsmount.h>
 #include <miscfs/nullfs/null.h>
 
@@ -790,6 +791,7 @@ netbsd32___mount50(struct lwp *l, const 
 		struct netbsd32_iso_args iso_args;
 		struct netbsd32_nfs_args nfs_args;
 		struct netbsd32_msdosfs_args msdosfs_args;
+		struct netbsd32_udf_args udf_args;
 		struct netbsd32_tmpfs_args tmpfs_args;
 		struct netbsd32_null_args null_args;
 	} fs_args32;
@@ -799,6 +801,7 @@ netbsd32___mount50(struct lwp *l, const 
 		struct iso_args iso_args;
 		struct nfs_args nfs_args;
 		struct msdosfs_args msdosfs_args;
+		struct udf_args udf_args;
 		struct tmpfs_args tmpfs_args;
 		struct null_args null_args;
 	} fs_args;
@@ -925,6 +928,40 @@ netbsd32___mount50(struct lwp *l, const 
 		data_seg = UIO_SYSSPACE;
 		data = &fs_args.msdosfs_args;
 		data_len = sizeof(fs_args.msdosfs_args);
+	} else if (strcmp(mtype, MOUNT_UDF) == 0) {
+		if (data_len != 0 && data_len < sizeof(fs_args32.udf_args))
+			return EINVAL;
+		if ((flags & MNT_GETARGS) == 0) {
+			error = copyin(data, &fs_args32.udf_args,
+			    sizeof(fs_args32.udf_args));
+			if (error)
+				return error;
+			fs_args.udf_args.version =
+			    fs_args32.udf_args.version;
+			fs_args.udf_args.fspec =
+			    NETBSD32PTR64(fs_args32.udf_args.fspec);
+			fs_args.udf_args.sessionnr =
+			    fs_args32.udf_args.sessionnr;
+			fs_args.udf_args.udfmflags =
+			    fs_args32.udf_args.udfmflags;
+			fs_args.udf_args.gmtoff =
+			    fs_args32.udf_args.gmtoff;
+			fs_args.udf_args.anon_uid =
+			    fs_args32.udf_args.anon_uid;
+			fs_args.udf_args.anon_gid =
+			    fs_args32.udf_args.anon_gid;
+			fs_args.udf_args.nobody_uid =
+			    fs_args32.udf_args.nobody_uid;
+			fs_args.udf_args.nobody_gid =
+			    fs_args32.udf_args.nobody_gid;
+			fs_args.udf_args.sector_size =
+			    fs_args32.udf_args.sector_size;
+			memset(fs_args.udf_args.reserved, 0,
+			    sizeof(fs_args.udf_args.reserved));
+		}
+		data_seg = UIO_SYSSPACE;
+		data = &fs_args.udf_args;
+		data_len = sizeof(fs_args.udf_args);
 	} else if (strcmp(mtype, MOUNT_NFS) == 0) {
 		if (data_len != 0 && data_len < sizeof(fs_args32.nfs_args))
 			return EINVAL;
@@ -1032,6 +1069,35 @@ netbsd32___mount50(struct lwp *l, const 
 			error = copyout(&fs_args32.iso_args, udata,
 				    sizeof(fs_args32.iso_args));
 			*retval = sizeof(fs_args32.iso_args);
+		} else if (strcmp(mtype, MOUNT_UDF) == 0) {
+			if (data_len != 0 &&
+			    data_len != sizeof(fs_args.udf_args))
+				return EINVAL;
+			fs_args32.udf_args.version =
+			    fs_args.udf_args.version;
+			NETBSD32PTR32(fs_args32.udf_args.fspec,
+			    fs_args.udf_args.fspec);
+			fs_args32.udf_args.sessionnr =
+			    fs_args.udf_args.sessionnr;
+			fs_args32.udf_args.udfmflags =
+			    fs_args.udf_args.udfmflags;
+			fs_args32.udf_args.gmtoff =
+			    fs_args.udf_args.gmtoff;
+			fs_args32.udf_args.anon_uid =
+			    fs_args.udf_args.anon_uid;
+			fs_args32.udf_args.anon_gid =
+			    fs_args.udf_args.anon_gid;
+			fs_args32.udf_args.nobody_uid =
+			    fs_args.udf_args.nobody_uid;
+			fs_args32.udf_args.nobody_gid =
+			    fs_args.udf_args.nobody_gid;
+			fs_args32.udf_args.sector_size =
+			    fs_args.udf_args.sector_size;
+			memset(fs_args32.udf_args.reserved, 0,
+			    sizeof(fs_args32.udf_args.reserved));
+			error = copyout(&fs_args32.udf_args, udata,
+				    sizeof(fs_args32.udf_args));
+			*retval = sizeof(fs_args32.udf_args);
 		} else if (strcmp(mtype, MOUNT_NFS) == 0) {
 			if (data_len != 0 &&
 			    data_len != sizeof(fs_args.nfs_args))

Reply via email to