Btrfs: Tune stripe selection for raid1 and raid10
authorChris Mason <chris.mason@oracle.com>
Tue, 29 Apr 2008 18:12:09 +0000 (14:12 -0400)
committerChris Mason <chris.mason@oracle.com>
Thu, 25 Sep 2008 15:04:02 +0000 (11:04 -0400)
Signed-off-by: Chris Mason <chris.mason@oracle.com>
fs/btrfs/volumes.c

index 57ab755aca76b3f70cd8c6a44a2c18364a52a38d..6d8dd4438c76ca388109d5b83ebc6018a6f21c8b 100644 (file)
@@ -1509,17 +1509,17 @@ again:
        if (map->type & BTRFS_BLOCK_GROUP_RAID1) {
                if (unplug_page || (rw & (1 << BIO_RW)))
                        num_stripes = map->num_stripes;
-               else if (mirror_num) {
+               else if (mirror_num)
                        stripe_index = mirror_num - 1;
-               } else {
-                       u64 orig_stripe_nr = stripe_nr;
-                       stripe_index = do_div(orig_stripe_nr, num_stripes);
-               }
+               else
+                       stripe_index = current->pid % map->num_stripes;
+
        } else if (map->type & BTRFS_BLOCK_GROUP_DUP) {
                if (rw & (1 << BIO_RW))
                        num_stripes = map->num_stripes;
                else if (mirror_num)
                        stripe_index = mirror_num - 1;
+
        } else if (map->type & BTRFS_BLOCK_GROUP_RAID10) {
                int factor = map->num_stripes / map->sub_stripes;
 
@@ -1530,11 +1530,8 @@ again:
                        num_stripes = map->sub_stripes;
                else if (mirror_num)
                        stripe_index += mirror_num - 1;
-               else {
-                       u64 orig_stripe_nr = stripe_nr;
-                       stripe_index += do_div(orig_stripe_nr,
-                                              map->sub_stripes);
-               }
+               else
+                       stripe_index += current->pid % map->sub_stripes;
        } else {
                /*
                 * after this do_div call, stripe_nr is the number of stripes