]> git.ipfire.org Git - thirdparty/linux.git/commit
btrfs: simplify early error checking in btrfs_page_mkwrite()
authorFilipe Manana <fdmanana@suse.com>
Tue, 13 May 2025 09:27:44 +0000 (10:27 +0100)
committerDavid Sterba <dsterba@suse.com>
Thu, 15 May 2025 16:24:23 +0000 (18:24 +0200)
commita08625f8250622f538641efa159a946b4b546165
treee4d34e212441ddf57e4be5e5fe9cac4abd6b5c78
parentbf1c74ccba9893adee482fbf6ce84b781e5008a3
btrfs: simplify early error checking in btrfs_page_mkwrite()

We have this entangled error checks early at btrfs_page_mkwrite():

1) Try to reserve delalloc space by calling btrfs_delalloc_reserve_space()
   and storing the return value in the ret2 variable;

2) If the reservation succeed, call file_update_time() and store the
   return value in ret2 and also set the local variable 'reserved' to
   true (1);

3) Then do an error check on ret2 to see if any of the previous calls
   failed and if so, jump either to the 'out' label or to the
   'out_noreserve' label, depending on whether 'reserved' is true or
   not.

This is unnecessarily complex. Instead change this to a simpler and
more straightforward approach:

1) Call btrfs_delalloc_reserve_space(), if that returns an error jump to
   the 'out_noreserve' label;

2) The call file_update_time() and if that returns an error jump to the
   'out' label.

Like this there's less nested if statements, no need to use a local
variable to track if space was reserved and if statements are used only
to check errors.

Also move the call to extent_changeset_free() out of the 'out_noreserve'
label and under the 'out' label  since the changeset is allocated only if
the call to reserve delalloc space succeeded.

Reviewed-by: Qu Wenruo <wqu@suse.com>
Signed-off-by: Filipe Manana <fdmanana@suse.com>
Reviewed-by: David Sterba <dsterba@suse.com>
Signed-off-by: David Sterba <dsterba@suse.com>
fs/btrfs/file.c