diff options
author | Josef Bacik <josef@toxicpanda.com> | 2020-07-21 11:24:27 -0400 |
---|---|---|
committer | David Sterba <dsterba@suse.com> | 2020-07-27 12:55:46 +0200 |
commit | f95ebdbed46a4d8b9fdb7bff109fdbb6fc9a6dc8 (patch) | |
tree | d5617a8f3013b378b7b9e58fd9b1f5da047e4d1c | |
parent | 3ebac17ce593490bff48d8eb0b4b97b97d8609fa (diff) | |
download | lwn-f95ebdbed46a4d8b9fdb7bff109fdbb6fc9a6dc8.tar.gz lwn-f95ebdbed46a4d8b9fdb7bff109fdbb6fc9a6dc8.zip |
btrfs: don't WARN if we abort a transaction with EROFS
If we got some sort of corruption via a read and call
btrfs_handle_fs_error() we'll set BTRFS_FS_STATE_ERROR on the fs and
complain. If a subsequent trans handle trips over this it'll get EROFS
and then abort. However at that point we're not aborting for the
original reason, we're aborting because we've been flipped read only.
We do not need to WARN_ON() here.
CC: stable@vger.kernel.org # 5.4+
Signed-off-by: Josef Bacik <josef@toxicpanda.com>
Reviewed-by: David Sterba <dsterba@suse.com>
Signed-off-by: David Sterba <dsterba@suse.com>
-rw-r--r-- | fs/btrfs/ctree.h | 2 |
1 files changed, 1 insertions, 1 deletions
diff --git a/fs/btrfs/ctree.h b/fs/btrfs/ctree.h index b70c2024296f..9c7e466f27a9 100644 --- a/fs/btrfs/ctree.h +++ b/fs/btrfs/ctree.h @@ -3279,7 +3279,7 @@ do { \ /* Report first abort since mount */ \ if (!test_and_set_bit(BTRFS_FS_STATE_TRANS_ABORTED, \ &((trans)->fs_info->fs_state))) { \ - if ((errno) != -EIO) { \ + if ((errno) != -EIO && (errno) != -EROFS) { \ WARN(1, KERN_DEBUG \ "BTRFS: Transaction aborted (error %d)\n", \ (errno)); \ |