diff options
author | Filipe Manana <fdmanana@suse.com> | 2022-08-01 14:57:51 +0100 |
---|---|---|
committer | David Sterba <dsterba@suse.com> | 2022-08-17 16:19:45 +0200 |
commit | 7a6b75b79902e47f46328b57733f2604774fa2d9 (patch) | |
tree | 7f669910ad2fe09b667a01532b91f12ddc6fd89e /fs/btrfs/tree-log.c | |
parent | b40130b23ca4a08c5785d5a3559805916bddba3c (diff) | |
download | lwn-7a6b75b79902e47f46328b57733f2604774fa2d9.tar.gz lwn-7a6b75b79902e47f46328b57733f2604774fa2d9.zip |
btrfs: fix lost error handling when looking up extended ref on log replay
During log replay, when processing inode references, if we get an error
when looking up for an extended reference at __add_inode_ref(), we ignore
it and proceed, returning success (0) if no other error happens after the
lookup. This is obviously wrong because in case an extended reference
exists and it encodes some name not in the log, we need to unlink it,
otherwise the filesystem state will not match the state it had after the
last fsync.
So just make __add_inode_ref() return an error it gets from the extended
reference lookup.
Fixes: f186373fef005c ("btrfs: extended inode refs")
CC: stable@vger.kernel.org # 4.9+
Signed-off-by: Filipe Manana <fdmanana@suse.com>
Reviewed-by: David Sterba <dsterba@suse.com>
Signed-off-by: David Sterba <dsterba@suse.com>
Diffstat (limited to 'fs/btrfs/tree-log.c')
-rw-r--r-- | fs/btrfs/tree-log.c | 4 |
1 files changed, 3 insertions, 1 deletions
diff --git a/fs/btrfs/tree-log.c b/fs/btrfs/tree-log.c index dcf75a8daa20..c1fdd6ef3f4a 100644 --- a/fs/btrfs/tree-log.c +++ b/fs/btrfs/tree-log.c @@ -1146,7 +1146,9 @@ again: extref = btrfs_lookup_inode_extref(NULL, root, path, name, namelen, inode_objectid, parent_objectid, 0, 0); - if (!IS_ERR_OR_NULL(extref)) { + if (IS_ERR(extref)) { + return PTR_ERR(extref); + } else if (extref) { u32 item_size; u32 cur_offset = 0; unsigned long base; |