Btrfs: extent_map and data=ordered fixes for space balancing
authorZheng Yan <zheng.yan@oracle.com>
Fri, 26 Sep 2008 14:05:38 +0000 (10:05 -0400)
committerChris Mason <chris.mason@oracle.com>
Fri, 26 Sep 2008 14:05:38 +0000 (10:05 -0400)
commit5b21f2ed3f2947b5195b65c9fdbdd9e52904cc03
tree9af8f539ac487c163f3207bc065767c3c8b37ae7
parente465768938f95388723b0fd3c50a0ae48173edb9
Btrfs: extent_map and data=ordered fixes for space balancing

* Add an EXTENT_BOUNDARY state bit to keep the writepage code
from merging data extents that are in the process of being
relocated.  This allows us to do accounting for them properly.

* The balancing code relocates data extents indepdent of the underlying
inode.  The extent_map code was modified to properly account for
things moving around (invalidating extent_map caches in the inode).

* Don't take the drop_mutex in the create_subvol ioctl.  It isn't
required.

* Fix walking of the ordered extent list to avoid races with sys_unlink

* Change the lock ordering rules.  Transaction start goes outside
the drop_mutex.  This allows btrfs_commit_transaction to directly
drop the relocation trees.

Signed-off-by: Chris Mason <chris.mason@oracle.com>
fs/btrfs/ctree.c
fs/btrfs/ctree.h
fs/btrfs/extent_io.c
fs/btrfs/extent_io.h
fs/btrfs/file.c
fs/btrfs/inode-map.c
fs/btrfs/inode.c
fs/btrfs/ioctl.c
fs/btrfs/ordered-data.c
fs/btrfs/transaction.c