From: Baokun Li Date: Wed, 22 Jan 2025 11:05:25 +0000 (+0800) Subject: ext4: replace opencoded ext4_end_io_end() in ext4_put_io_end() X-Git-Tag: v6.15-rc1~145^2~48 X-Git-Url: http://git.ipfire.org/?a=commitdiff_plain;h=2f94b537c48db155f5aa68d63b747f9d82248341;p=thirdparty%2Fkernel%2Flinux.git ext4: replace opencoded ext4_end_io_end() in ext4_put_io_end() This reduces duplicate code and ensures that a “potential data loss” warning is available if the unwritten conversion fails. Signed-off-by: Baokun Li Reviewed-by: Jan Kara Reviewed-by: Zhang Yi Link: https://patch.msgid.link/20250122110533.4116662-2-libaokun@huaweicloud.com Signed-off-by: Theodore Ts'o --- diff --git a/fs/ext4/page-io.c b/fs/ext4/page-io.c index 69b8a7221a2b1..f53b018ea259b 100644 --- a/fs/ext4/page-io.c +++ b/fs/ext4/page-io.c @@ -299,18 +299,13 @@ void ext4_put_io_end_defer(ext4_io_end_t *io_end) int ext4_put_io_end(ext4_io_end_t *io_end) { - int err = 0; - if (refcount_dec_and_test(&io_end->count)) { - if (io_end->flag & EXT4_IO_END_UNWRITTEN) { - err = ext4_convert_unwritten_io_end_vec(io_end->handle, - io_end); - io_end->handle = NULL; - ext4_clear_io_unwritten_flag(io_end); - } + if (io_end->flag & EXT4_IO_END_UNWRITTEN) + return ext4_end_io_end(io_end); + ext4_release_io_end(io_end); } - return err; + return 0; } ext4_io_end_t *ext4_get_io_end(ext4_io_end_t *io_end)