diff options
| author | Qu Wenruo <wqu@suse.com> | 2024-08-24 19:36:43 +0930 | 
|---|---|---|
| committer | David Sterba <dsterba@suse.com> | 2024-09-10 16:51:20 +0200 | 
| commit | 9ca0e58cb752b09816f56f7a3147a39773d5e831 (patch) | |
| tree | 8c77a8bb3590efea95e1503642cf5a29ae3aae8b /drivers/usb/cdns3/cdns3-ep0.c | |
| parent | ac325fc2aad513072722387a71bf857c938aae4e (diff) | |
btrfs: merge btrfs_orig_bbio_end_io() into btrfs_bio_end_io()
There are only two differences between the two functions:
- btrfs_orig_bbio_end_io() does extra error propagation
  This is mostly to allow tolerance for write errors.
- btrfs_orig_bbio_end_io() does extra pending_ios check
  This check can handle both the original bio, or the cloned one.
  (All accounting happens in the original one).
This makes btrfs_orig_bbio_end_io() a much safer call.
In fact we already had a double freeing error due to usage of
btrfs_bio_end_io() in the error path of btrfs_submit_chunk().
So just move the whole content of btrfs_orig_bbio_end_io() into
btrfs_bio_end_io().
For normal paths this brings no change, because they are already calling
btrfs_orig_bbio_end_io() in the first place.
For error paths (not only inside bio.c but also external callers), this
change will introduce extra checks, especially for external callers, as
they will error out without submitting the btrfs bio.
But considering it's already in the error path, such slower but much
safer checks are still an overall win.
Signed-off-by: Qu Wenruo <wqu@suse.com>
Reviewed-by: David Sterba <dsterba@suse.com>
Signed-off-by: David Sterba <dsterba@suse.com>
Diffstat (limited to 'drivers/usb/cdns3/cdns3-ep0.c')
0 files changed, 0 insertions, 0 deletions
