From: Josef Bacik Date: Fri, 12 Mar 2021 20:25:06 +0000 (-0500) Subject: btrfs: handle btrfs_record_root_in_trans failure in create_subvol X-Git-Tag: accepted/tizen/unified/20230118.172025~7052^2~72 X-Git-Url: http://review.tizen.org/git/?a=commitdiff_plain;h=221581e485751811db3b43148177be2a0bdb2f3c;p=platform%2Fkernel%2Flinux-rpi.git btrfs: handle btrfs_record_root_in_trans failure in create_subvol btrfs_record_root_in_trans will return errors in the future, so handle the error properly in create_subvol. Signed-off-by: Josef Bacik Reviewed-by: David Sterba Signed-off-by: David Sterba --- diff --git a/fs/btrfs/ioctl.c b/fs/btrfs/ioctl.c index 3415a9f..37c92a9 100644 --- a/fs/btrfs/ioctl.c +++ b/fs/btrfs/ioctl.c @@ -721,7 +721,12 @@ static noinline int create_subvol(struct inode *dir, /* Freeing will be done in btrfs_put_root() of new_root */ anon_dev = 0; - btrfs_record_root_in_trans(trans, new_root); + ret = btrfs_record_root_in_trans(trans, new_root); + if (ret) { + btrfs_put_root(new_root); + btrfs_abort_transaction(trans, ret); + goto fail; + } ret = btrfs_create_subvol_root(trans, new_root, root); btrfs_put_root(new_root);