diff options
| -rw-r--r-- | fs/ext4/ext4.h | 2 | ||||
| -rw-r--r-- | fs/ext4/ioctl.c | 17 |
2 files changed, 17 insertions, 2 deletions
diff --git a/fs/ext4/ext4.h b/fs/ext4/ext4.h index 9b6ad8f19bc9..068adc1d5607 100644 --- a/fs/ext4/ext4.h +++ b/fs/ext4/ext4.h | |||
| @@ -245,7 +245,7 @@ struct flex_groups { | |||
| 245 | #define EXT4_RESERVED_FL 0x80000000 /* reserved for ext4 lib */ | 245 | #define EXT4_RESERVED_FL 0x80000000 /* reserved for ext4 lib */ |
| 246 | 246 | ||
| 247 | #define EXT4_FL_USER_VISIBLE 0x000BDFFF /* User visible flags */ | 247 | #define EXT4_FL_USER_VISIBLE 0x000BDFFF /* User visible flags */ |
| 248 | #define EXT4_FL_USER_MODIFIABLE 0x000380FF /* User modifiable flags */ | 248 | #define EXT4_FL_USER_MODIFIABLE 0x000B80FF /* User modifiable flags */ |
| 249 | 249 | ||
| 250 | /* | 250 | /* |
| 251 | * Inode dynamic state flags | 251 | * Inode dynamic state flags |
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); | ||
| 112 | flags_out: | 127 | flags_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); |
