kern/122047: [ext2fs] incorrect handling of UF_IMMUTABLE / UF_APPEND flag on EXT2FS (maybe others)

Ighighi Ighighi ighighi at gmail.com
Thu May 29 06:46:36 UTC 2008


See attached patch.
-------------- next part --------------
#
# (!c) 2008 by Ighighi
#
# See http://www.freebsd.org/cgi/query-pr.cgi?pr=kern/122047
#
# This patch adds a "vfs.e2fs.userflags" sysctl to permit regular users
# to set/clear the APPEND/IMMUTABLE filesystem flags on EXT2 filesystems.
# As a bonus, it also sets st_birthtime to zero.
#
# Built and tested on FreeBSD 6.3-STABLE (RELENG_6).
# Known to patch on -CURRENT
#
# To install, run as root:
#   /sbin/umount -v -t ext2fs -a
#   /sbin/kldunload -v ext2fs
#   /usr/bin/patch -d /usr < /path/to/ext2fs.patch
#   cd /sys/modules/ext2fs/
#   make clean obj depend && make && make install
#   /sbin/kldload -v ext2fs
#   /sbin/sysctl vfs.e2fs.userflags=1  # 0 is default
#   /sbin/mount -v -t ext2fs -a
#

--- src/sys/gnu/fs/ext2fs/ext2_inode_cnv.c.orig	2005-06-14 22:36:10.000000000 -0400
+++ src/sys/gnu/fs/ext2fs/ext2_inode_cnv.c	2008-05-28 15:15:27.527318854 -0430
@@ -30,11 +30,19 @@
 #include <sys/lock.h>
 #include <sys/stat.h>
 #include <sys/vnode.h>
+#include <sys/kernel.h>
+#include <sys/sysctl.h>
 
 #include <gnu/fs/ext2fs/inode.h>
 #include <gnu/fs/ext2fs/ext2_fs.h>
 #include <gnu/fs/ext2fs/ext2_extern.h>
 
+SYSCTL_DECL(_vfs_e2fs);
+
+static int userflags = 0;
+SYSCTL_INT(_vfs_e2fs, OID_AUTO, userflags, CTLFLAG_RW,
+    &userflags, 0, "Users may set/clear filesystem flags");
+
 void
 ext2_print_inode( in )
 	struct inode *in;
@@ -83,8 +91,17 @@ ext2_ei2i(ei, ip)
 	ip->i_mtime = ei->i_mtime;
 	ip->i_ctime = ei->i_ctime;
 	ip->i_flags = 0;
-	ip->i_flags |= (ei->i_flags & EXT2_APPEND_FL) ? APPEND : 0;
-	ip->i_flags |= (ei->i_flags & EXT2_IMMUTABLE_FL) ? IMMUTABLE : 0;
+	if (userflags) {
+		if (ei->i_flags & EXT2_APPEND_FL)
+			ip->i_flags |= UF_APPEND;
+		if (ei->i_flags & EXT2_IMMUTABLE_FL)
+			ip->i_flags |= UF_IMMUTABLE;
+	} else {
+		if (ei->i_flags & EXT2_APPEND_FL)
+			ip->i_flags |= APPEND;
+		if (ei->i_flags & EXT2_IMMUTABLE_FL)
+			ip->i_flags |= IMMUTABLE;
+	}
 	ip->i_blocks = ei->i_blocks;
 	ip->i_gen = ei->i_generation;
 	ip->i_uid = ei->i_uid;
--- src/sys/gnu/fs/ext2fs/ext2_lookup.c.orig	2006-01-04 15:32:00.000000000 -0400
+++ src/sys/gnu/fs/ext2fs/ext2_lookup.c	2008-05-28 13:35:16.841349269 -0430
@@ -66,7 +66,7 @@ static int dirchk = 1;
 static int dirchk = 0;
 #endif
 
-static SYSCTL_NODE(_vfs, OID_AUTO, e2fs, CTLFLAG_RD, 0, "EXT2FS filesystem");
+SYSCTL_NODE(_vfs, OID_AUTO, e2fs, CTLFLAG_RW, 0, "EXT2FS filesystem");
 SYSCTL_INT(_vfs_e2fs, OID_AUTO, dircheck, CTLFLAG_RW, &dirchk, 0, "");
 
 /*
--- src/sys/gnu/fs/ext2fs/ext2_vnops.c.orig	2006-02-19 20:53:14.000000000 -0400
+++ src/sys/gnu/fs/ext2fs/ext2_vnops.c	2008-05-28 07:58:02.189157441 -0430
@@ -358,6 +358,8 @@ ext2_getattr(ap)
 	vap->va_mtime.tv_nsec = ip->i_mtimensec;
 	vap->va_ctime.tv_sec = ip->i_ctime;
 	vap->va_ctime.tv_nsec = ip->i_ctimensec;
+	vap->va_birthtime.tv_sec = 0;
+	vap->va_birthtime.tv_nsec = 0;
 	vap->va_flags = ip->i_flags;
 	vap->va_gen = ip->i_gen;
 	vap->va_blocksize = vp->v_mount->mnt_stat.f_iosize;


More information about the freebsd-fs mailing list