diff options
| author | Linus Torvalds <torvalds@linux-foundation.org> | 2011-07-09 02:25:45 -0400 |
|---|---|---|
| committer | Linus Torvalds <torvalds@linux-foundation.org> | 2011-07-09 02:25:45 -0400 |
| commit | 1acc9309eb2674533944f48dbaaa53e7750e3947 (patch) | |
| tree | 255f346c01a33906b612852d5fb008da1f4520da | |
| parent | c2d197e82b6267fd3338f3fbcb12750ca9f5abda (diff) | |
| parent | 149e2d76b4886c4c7ff5e077646a8ba3563c8026 (diff) | |
Merge branch 'for-linus' of git://git.kernel.org/pub/scm/linux/kernel/git/mason/btrfs-unstable
* 'for-linus' of git://git.kernel.org/pub/scm/linux/kernel/git/mason/btrfs-unstable:
btrfs: fix oops when doing space balance
Btrfs: don't panic if we get an error while balancing V2
btrfs: add missing options displayed in mount output
| -rw-r--r-- | fs/btrfs/ctree.h | 5 | ||||
| -rw-r--r-- | fs/btrfs/inode.c | 12 | ||||
| -rw-r--r-- | fs/btrfs/super.c | 6 | ||||
| -rw-r--r-- | fs/btrfs/volumes.c | 3 |
4 files changed, 20 insertions, 6 deletions
diff --git a/fs/btrfs/ctree.h b/fs/btrfs/ctree.h index f30ac05dbda7..3b859a3e6a0e 100644 --- a/fs/btrfs/ctree.h +++ b/fs/btrfs/ctree.h | |||
| @@ -1335,6 +1335,11 @@ struct btrfs_ioctl_defrag_range_args { | |||
| 1335 | */ | 1335 | */ |
| 1336 | #define BTRFS_STRING_ITEM_KEY 253 | 1336 | #define BTRFS_STRING_ITEM_KEY 253 |
| 1337 | 1337 | ||
| 1338 | /* | ||
| 1339 | * Flags for mount options. | ||
| 1340 | * | ||
| 1341 | * Note: don't forget to add new options to btrfs_show_options() | ||
| 1342 | */ | ||
| 1338 | #define BTRFS_MOUNT_NODATASUM (1 << 0) | 1343 | #define BTRFS_MOUNT_NODATASUM (1 << 0) |
| 1339 | #define BTRFS_MOUNT_NODATACOW (1 << 1) | 1344 | #define BTRFS_MOUNT_NODATACOW (1 << 1) |
| 1340 | #define BTRFS_MOUNT_NOBARRIER (1 << 2) | 1345 | #define BTRFS_MOUNT_NOBARRIER (1 << 2) |
diff --git a/fs/btrfs/inode.c b/fs/btrfs/inode.c index d340f63d8f07..3601f0aebddf 100644 --- a/fs/btrfs/inode.c +++ b/fs/btrfs/inode.c | |||
| @@ -2678,12 +2678,14 @@ noinline int btrfs_update_inode(struct btrfs_trans_handle *trans, | |||
| 2678 | int ret; | 2678 | int ret; |
| 2679 | 2679 | ||
| 2680 | /* | 2680 | /* |
| 2681 | * If root is tree root, it means this inode is used to | 2681 | * If the inode is a free space inode, we can deadlock during commit |
| 2682 | * store free space information. And these inodes are updated | 2682 | * if we put it into the delayed code. |
| 2683 | * when committing the transaction, so they needn't delaye to | 2683 | * |
| 2684 | * be updated, or deadlock will occured. | 2684 | * The data relocation inode should also be directly updated |
| 2685 | * without delay | ||
| 2685 | */ | 2686 | */ |
| 2686 | if (!is_free_space_inode(root, inode)) { | 2687 | if (!is_free_space_inode(root, inode) |
| 2688 | && root->root_key.objectid != BTRFS_DATA_RELOC_TREE_OBJECTID) { | ||
| 2687 | ret = btrfs_delayed_update_inode(trans, root, inode); | 2689 | ret = btrfs_delayed_update_inode(trans, root, inode); |
| 2688 | if (!ret) | 2690 | if (!ret) |
| 2689 | btrfs_set_inode_last_trans(trans, inode); | 2691 | btrfs_set_inode_last_trans(trans, inode); |
diff --git a/fs/btrfs/super.c b/fs/btrfs/super.c index 0bb4ebbb71b7..15634d4648d7 100644 --- a/fs/btrfs/super.c +++ b/fs/btrfs/super.c | |||
| @@ -723,6 +723,12 @@ static int btrfs_show_options(struct seq_file *seq, struct vfsmount *vfs) | |||
| 723 | seq_puts(seq, ",clear_cache"); | 723 | seq_puts(seq, ",clear_cache"); |
| 724 | if (btrfs_test_opt(root, USER_SUBVOL_RM_ALLOWED)) | 724 | if (btrfs_test_opt(root, USER_SUBVOL_RM_ALLOWED)) |
| 725 | seq_puts(seq, ",user_subvol_rm_allowed"); | 725 | seq_puts(seq, ",user_subvol_rm_allowed"); |
| 726 | if (btrfs_test_opt(root, ENOSPC_DEBUG)) | ||
| 727 | seq_puts(seq, ",enospc_debug"); | ||
| 728 | if (btrfs_test_opt(root, AUTO_DEFRAG)) | ||
| 729 | seq_puts(seq, ",autodefrag"); | ||
| 730 | if (btrfs_test_opt(root, INODE_MAP_CACHE)) | ||
| 731 | seq_puts(seq, ",inode_cache"); | ||
| 726 | return 0; | 732 | return 0; |
| 727 | } | 733 | } |
| 728 | 734 | ||
diff --git a/fs/btrfs/volumes.c b/fs/btrfs/volumes.c index 1efa56e18f9b..19450bc53632 100644 --- a/fs/btrfs/volumes.c +++ b/fs/btrfs/volumes.c | |||
| @@ -2098,7 +2098,8 @@ int btrfs_balance(struct btrfs_root *dev_root) | |||
| 2098 | chunk_root->root_key.objectid, | 2098 | chunk_root->root_key.objectid, |
| 2099 | found_key.objectid, | 2099 | found_key.objectid, |
| 2100 | found_key.offset); | 2100 | found_key.offset); |
| 2101 | BUG_ON(ret && ret != -ENOSPC); | 2101 | if (ret && ret != -ENOSPC) |
| 2102 | goto error; | ||
| 2102 | key.offset = found_key.offset - 1; | 2103 | key.offset = found_key.offset - 1; |
| 2103 | } | 2104 | } |
| 2104 | ret = 0; | 2105 | ret = 0; |
