Commit 1f16033c authored by Anand Jain's avatar Anand Jain Committed by David Sterba

btrfs: warn for any missed cleanup at btrfs_close_one_device

During my recent search for the root cause of a reported bug, I realized
that it's a good idea to issue a warning for missed cleanup instead of
using debug-only assertions. Since most installations run with debug off,
missed cleanups and premature calls to close could go unnoticed. However,
these issues are serious enough to warrant reporting and fixing.
Signed-off-by: default avatarAnand Jain <anand.jain@oracle.com>
Reviewed-by: default avatarDavid Sterba <dsterba@suse.com>
Signed-off-by: default avatarDavid Sterba <dsterba@suse.com>
parent 7533583e
...@@ -1150,10 +1150,10 @@ static void btrfs_close_one_device(struct btrfs_device *device) ...@@ -1150,10 +1150,10 @@ static void btrfs_close_one_device(struct btrfs_device *device)
device->last_flush_error = 0; device->last_flush_error = 0;
/* Verify the device is back in a pristine state */ /* Verify the device is back in a pristine state */
ASSERT(!test_bit(BTRFS_DEV_STATE_FLUSH_SENT, &device->dev_state)); WARN_ON(test_bit(BTRFS_DEV_STATE_FLUSH_SENT, &device->dev_state));
ASSERT(!test_bit(BTRFS_DEV_STATE_REPLACE_TGT, &device->dev_state)); WARN_ON(test_bit(BTRFS_DEV_STATE_REPLACE_TGT, &device->dev_state));
ASSERT(list_empty(&device->dev_alloc_list)); WARN_ON(!list_empty(&device->dev_alloc_list));
ASSERT(list_empty(&device->post_commit_list)); WARN_ON(!list_empty(&device->post_commit_list));
} }
static void close_fs_devices(struct btrfs_fs_devices *fs_devices) static void close_fs_devices(struct btrfs_fs_devices *fs_devices)
......
Markdown is supported
0%
or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment