diff options
author | Filipe Manana <[email protected]> | 2021-12-13 08:45:14 +0000 |
---|---|---|
committer | David Sterba <[email protected]> | 2022-01-07 14:18:26 +0100 |
commit | 1b58ae0e4d3ede95ee968a3f097298a57cf711ba (patch) | |
tree | 57be27468fa015f25fe8bfc100223e6e6975825b /drivers/usb/cdns3/cdns3-ti.c | |
parent | 82187d2ecdfb22ab7ee05f388402a39236d31428 (diff) |
btrfs: skip transaction commit after failure to create subvolume
At ioctl.c:create_subvol(), when we fail to create a subvolume we always
commit the transaction. In most cases this is a no-op, since all the error
paths, except for one, abort the transaction - the only exception is when
we fail to insert the new root item into the root tree, in that case we
don't abort the transaction because we didn't do anything that is
irreversible - however we end up committing the transaction which although
is not a functional problem, it adds unnecessary rotation of the backup
roots in the superblock and unnecessary work.
So change that to commit a transaction only when no error happened,
otherwise just call btrfs_end_transaction() to release our reference on
the transaction.
Reviewed-by: Nikolay Borisov <[email protected]>
Signed-off-by: Filipe Manana <[email protected]>
Signed-off-by: David Sterba <[email protected]>
Diffstat (limited to 'drivers/usb/cdns3/cdns3-ti.c')
0 files changed, 0 insertions, 0 deletions