From: Filipe Manana <fdmanana@xxxxxxxx>
The following patches fix a hard to hit race and unecessary flushing of
delalloc regions and waiting for unrelated IO (IO against extents outside
of the block group being relocated).
The race is between relocation and direct IO writes that lead to the
relocation process miss extents and not move them, and later makes us hit
a BUG_ON() if we attempt to read the extents.
Patch 1 just avoids waiting for unrelated ordered extents to complete
while patch 2 fixes the race and avoids flushing delalloc.
Thanks.
V2: Removed the first patch in the v1 series, it was meant for a false
positive.
Filipe Manana (2):
Btrfs: don't wait for unrelated IO to finish before relocation
Btrfs: don't do unnecessary delalloc flushes when relocating
fs/btrfs/ctree.h | 14 ++++++++++
fs/btrfs/dev-replace.c | 4 +--
fs/btrfs/extent-tree.c | 69 ++++++++++++++++++++++++++++++++++++++++++++-----
fs/btrfs/inode.c | 8 ++++++
fs/btrfs/ioctl.c | 2 +-
fs/btrfs/ordered-data.c | 26 ++++++++++++++-----
fs/btrfs/ordered-data.h | 6 +++--
fs/btrfs/relocation.c | 10 +++----
fs/btrfs/super.c | 2 +-
fs/btrfs/transaction.c | 2 +-
10 files changed, 117 insertions(+), 26 deletions(-)
--
2.7.0.rc3
--
To unsubscribe from this list: send the line "unsubscribe linux-btrfs" in
the body of a message to majordomo@xxxxxxxxxxxxxxx
More majordomo info at http://vger.kernel.org/majordomo-info.html