aboutsummaryrefslogtreecommitdiffstats
path: root/fs/ext4/ioctl.c
diff options
context:
space:
mode:
Diffstat (limited to 'fs/ext4/ioctl.c')
-rw-r--r--fs/ext4/ioctl.c17
1 files changed, 16 insertions, 1 deletions
diff --git a/fs/ext4/ioctl.c b/fs/ext4/ioctl.c
index 9f3044ac6994..3e14060b398e 100644
--- a/fs/ext4/ioctl.c
+++ b/fs/ext4/ioctl.c
@@ -34,7 +34,7 @@ long ext4_ioctl(struct file *filp, unsigned int cmd, unsigned long arg)
34 return put_user(flags, (int __user *) arg); 34 return put_user(flags, (int __user *) arg);
35 case EXT4_IOC_SETFLAGS: { 35 case EXT4_IOC_SETFLAGS: {
36 handle_t *handle = NULL; 36 handle_t *handle = NULL;
37 int err; 37 int err, migrate = 0;
38 struct ext4_iloc iloc; 38 struct ext4_iloc iloc;
39 unsigned int oldflags; 39 unsigned int oldflags;
40 unsigned int jflag; 40 unsigned int jflag;
@@ -82,6 +82,17 @@ long ext4_ioctl(struct file *filp, unsigned int cmd, unsigned long arg)
82 if (!capable(CAP_SYS_RESOURCE)) 82 if (!capable(CAP_SYS_RESOURCE))
83 goto flags_out; 83 goto flags_out;
84 } 84 }
85 if (oldflags & EXT4_EXTENTS_FL) {
86 /* We don't support clearning extent flags */
87 if (!(flags & EXT4_EXTENTS_FL)) {
88 err = -EOPNOTSUPP;
89 goto flags_out;
90 }
91 } else if (flags & EXT4_EXTENTS_FL) {
92 /* migrate the file */
93 migrate = 1;
94 flags &= ~EXT4_EXTENTS_FL;
95 }
85 96
86 handle = ext4_journal_start(inode, 1); 97 handle = ext4_journal_start(inode, 1);
87 if (IS_ERR(handle)) { 98 if (IS_ERR(handle)) {
@@ -109,6 +120,10 @@ flags_err:
109 120
110 if ((jflag ^ oldflags) & (EXT4_JOURNAL_DATA_FL)) 121 if ((jflag ^ oldflags) & (EXT4_JOURNAL_DATA_FL))
111 err = ext4_change_inode_journal_flag(inode, jflag); 122 err = ext4_change_inode_journal_flag(inode, jflag);
123 if (err)
124 goto flags_out;
125 if (migrate)
126 err = ext4_ext_migrate(inode);
112flags_out: 127flags_out:
113 mutex_unlock(&inode->i_mutex); 128 mutex_unlock(&inode->i_mutex);
114 mnt_drop_write(filp->f_path.mnt); 129 mnt_drop_write(filp->f_path.mnt);