Commit d0dabf7e authored by NeilBrown's avatar NeilBrown

md/raid6: remove expectation that Q device is immediately after P device.


Code currently assumes that the devices in a raid6 stripe are
  0 1 ... N-1 P Q
in some rotated order.  We will shortly add new layouts in which
this strict pattern is broken.
So remove this expectation.  We still assume that the data disks
are roughly in-order.  However P and Q can be inserted anywhere within
that order.
Signed-off-by: default avatarNeilBrown <neilb@suse.de>
parent 112bf897
This diff is collapsed.
...@@ -196,15 +196,16 @@ enum reconstruct_states { ...@@ -196,15 +196,16 @@ enum reconstruct_states {
struct stripe_head { struct stripe_head {
struct hlist_node hash; struct hlist_node hash;
struct list_head lru; /* inactive_list or handle_list */ struct list_head lru; /* inactive_list or handle_list */
struct raid5_private_data *raid_conf; struct raid5_private_data *raid_conf;
sector_t sector; /* sector of this row */ sector_t sector; /* sector of this row */
int pd_idx; /* parity disk index */ short pd_idx; /* parity disk index */
unsigned long state; /* state flags */ short qd_idx; /* 'Q' disk index for raid6 */
atomic_t count; /* nr of active thread/requests */ unsigned long state; /* state flags */
atomic_t count; /* nr of active thread/requests */
spinlock_t lock; spinlock_t lock;
int bm_seq; /* sequence number for bitmap flushes */ int bm_seq; /* sequence number for bitmap flushes */
int disks; /* disks in stripe */ int disks; /* disks in stripe */
enum check_states check_state; enum check_states check_state;
enum reconstruct_states reconstruct_state; enum reconstruct_states reconstruct_state;
/* stripe_operations /* stripe_operations
......
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