On Fri, Nov 11, 2016 at 11:08:57AM +0100, Jan Kara wrote: > On Thu 10-11-16 14:46:39, Ross Zwisler wrote: > > On Tue, Nov 08, 2016 at 12:08:08PM +0100, Jan Kara wrote: > > > Currently we have S_DAX set inode->i_flags for a regular file whenever > > > ext4 is mounted with dax mount option. However in some cases we cannot > > > really do DAX - e.g. when inode is marked to use data journalling, when > > > inode data is being encrypted, or when inode is stored inline. Make sure > > > S_DAX flag is appropriately set/cleared in these cases. > > > > > > Signed-off-by: Jan Kara <jack@xxxxxxx> > > > --- > > <> > > > diff --git a/fs/ext4/super.c b/fs/ext4/super.c > > > index 20da99da0a34..b3108e6fa5f3 100644 > > > --- a/fs/ext4/super.c > > > +++ b/fs/ext4/super.c > > > @@ -1126,6 +1126,10 @@ static int ext4_set_context(struct inode *inode, const void *ctx, size_t len, > > > ext4_set_inode_flag(inode, EXT4_INODE_ENCRYPT); > > > ext4_clear_inode_state(inode, > > > EXT4_STATE_MAY_INLINE_DATA); > > > + /* > > > + * Update inode->i_flags - e.g. S_DAX may get disabled > > > + */ > > > + ext4_set_inode_flags(inode); > > > } > > > return res; > > > } > > > @@ -1140,6 +1144,7 @@ static int ext4_set_context(struct inode *inode, const void *ctx, size_t len, > > > len, 0); > > > if (!res) { > > > ext4_set_inode_flag(inode, EXT4_INODE_ENCRYPT); > > > + /* Update inode->i_flags - e.g. S_DAX may get disabled */ > > > > Missing call to ext4_set_inode_flags(inode)? > > Yeah, fixed. Thanks! Cool, you can add: Reviewed-by: Ross Zwisler <ross.zwisler@xxxxxxxxxxxxxxx> -- To unsubscribe from this list: send the line "unsubscribe linux-ext4" in the body of a message to majordomo@xxxxxxxxxxxxxxx More majordomo info at http://vger.kernel.org/majordomo-info.html