On Sat, Feb 23, 2019 at 01:39:48AM +0800, Anand Jain wrote: > In preparation to make trans argument of btrfs_setxattr() a mandatory, > start the transaction in btrfs_set_prop_trans. > > Signed-off-by: Anand Jain <anand.j...@oracle.com> > --- > v4: born > fs/btrfs/props.c | 21 ++++++++++++++++++++- > 1 file changed, 20 insertions(+), 1 deletion(-) > > diff --git a/fs/btrfs/props.c b/fs/btrfs/props.c > index e581da1bfbb6..f878ba3160f0 100644 > --- a/fs/btrfs/props.c > +++ b/fs/btrfs/props.c > @@ -4,6 +4,7 @@ > */ > > #include <linux/hashtable.h> > +#include <linux/iversion.h> > #include "props.h" > #include "btrfs_inode.h" > #include "transaction.h" > @@ -103,7 +104,25 @@ static int btrfs_set_prop(struct btrfs_trans_handle > *trans, struct inode *inode, > int btrfs_set_prop_trans(struct inode *inode, const char *name, > const char *value, size_t value_len, int flags) > { > - return btrfs_set_prop(NULL, inode, name, value, value_len, flags); > + struct btrfs_root *root = BTRFS_I(inode)->root; > + struct btrfs_trans_handle *trans; > + int ret; > + > + trans = btrfs_start_transaction(root, 2); > + if (IS_ERR(trans)) > + return PTR_ERR(trans); > + > + ret = btrfs_set_prop(trans, inode, name, value, value_len, flags); > + > + if (!ret) { > + inode_inc_iversion(inode); > + inode->i_ctime = current_time(inode); > + set_bit(BTRFS_INODE_COPY_EVERYTHING, > &BTRFS_I(inode)->runtime_flags); > + ret = btrfs_update_inode(trans, root, inode); > + ASSERT(!ret);
This is not right. The previous code uses BUG_ON which is also not right, but does not silently continue if asserts are compiled out. Please add proper error handling here. > + } > + btrfs_end_transaction(trans); > + return ret; > } > > static int iterate_object_props(struct btrfs_root *root, > -- > 1.8.3.1