From 1d409b9bff6db50d8be7736f41ccd3c39e7a3b5a Mon Sep 17 00:00:00 2001 From: Theodore Ts'o Date: Thu, 31 May 2012 23:46:01 -0400 Subject: [PATCH] --- yaml --- r: 309969 b: refs/heads/master c: 79906964a187c405db72a3abc60eb9b50d804fbc h: refs/heads/master i: 309967: f12b29ac6c9be7707c0a6ea25d7a49b31a4559c3 v: v3 --- [refs] | 2 +- trunk/fs/ext4/ioctl.c | 12 +++++++++--- 2 files changed, 10 insertions(+), 4 deletions(-) diff --git a/[refs] b/[refs] index 0a1401a50e57..8fd0a9514e57 100644 --- a/[refs] +++ b/[refs] @@ -1,2 +1,2 @@ --- -refs/heads/master: 9660755100ae7677d65772a28e16d475a2ee9eab +refs/heads/master: 79906964a187c405db72a3abc60eb9b50d804fbc diff --git a/trunk/fs/ext4/ioctl.c b/trunk/fs/ext4/ioctl.c index feba55a225a6..8ad112ae0ade 100644 --- a/trunk/fs/ext4/ioctl.c +++ b/trunk/fs/ext4/ioctl.c @@ -38,7 +38,7 @@ long ext4_ioctl(struct file *filp, unsigned int cmd, unsigned long arg) handle_t *handle = NULL; int err, migrate = 0; struct ext4_iloc iloc; - unsigned int oldflags; + unsigned int oldflags, mask, i; unsigned int jflag; if (!inode_owner_or_capable(inode)) @@ -115,8 +115,14 @@ long ext4_ioctl(struct file *filp, unsigned int cmd, unsigned long arg) if (err) goto flags_err; - flags = flags & EXT4_FL_USER_MODIFIABLE; - flags |= oldflags & ~EXT4_FL_USER_MODIFIABLE; + for (i = 0, mask = 1; i < 32; i++, mask <<= 1) { + if (!(mask & EXT4_FL_USER_MODIFIABLE)) + continue; + if (mask & flags) + ext4_set_inode_flag(inode, i); + else + ext4_clear_inode_flag(inode, i); + } ei->i_flags = flags; ext4_set_inode_flags(inode);