Commit 5002dd18 authored by Boaz Harrosh's avatar Boaz Harrosh

exofs: Fix groups code when num_devices is not divisible by group_width

There is a bug when num_devices is not divisible by group_width * mirrors.
We would not return to the proper device and offset when looping on to the
next group.

The fix makes code simpler actually.
Signed-off-by: default avatarBoaz Harrosh <bharrosh@panasas.com>
parent 6e31609b
...@@ -305,8 +305,6 @@ int exofs_check_io(struct exofs_io_state *ios, u64 *resid) ...@@ -305,8 +305,6 @@ int exofs_check_io(struct exofs_io_state *ios, u64 *resid)
struct _striping_info { struct _striping_info {
u64 obj_offset; u64 obj_offset;
u64 group_length; u64 group_length;
u64 total_group_length;
u64 Major;
unsigned dev; unsigned dev;
unsigned unit_off; unsigned unit_off;
}; };
...@@ -343,8 +341,6 @@ static void _calc_stripe_info(struct exofs_io_state *ios, u64 file_offset, ...@@ -343,8 +341,6 @@ static void _calc_stripe_info(struct exofs_io_state *ios, u64 file_offset,
(M * group_depth * stripe_unit); (M * group_depth * stripe_unit);
si->group_length = T - H; si->group_length = T - H;
si->total_group_length = T;
si->Major = M;
} }
static int _add_stripe_unit(struct exofs_io_state *ios, unsigned *cur_pg, static int _add_stripe_unit(struct exofs_io_state *ios, unsigned *cur_pg,
...@@ -450,17 +446,15 @@ static int _prepare_one_group(struct exofs_io_state *ios, u64 length, ...@@ -450,17 +446,15 @@ static int _prepare_one_group(struct exofs_io_state *ios, u64 length,
static int _prepare_for_striping(struct exofs_io_state *ios) static int _prepare_for_striping(struct exofs_io_state *ios)
{ {
u64 length = ios->length; u64 length = ios->length;
u64 offset = ios->offset;
struct _striping_info si; struct _striping_info si;
unsigned devs_in_group = ios->layout->group_width *
ios->layout->mirrors_p1;
int ret = 0; int ret = 0;
_calc_stripe_info(ios, ios->offset, &si);
if (!ios->pages) { if (!ios->pages) {
if (ios->kern_buff) { if (ios->kern_buff) {
struct exofs_per_dev_state *per_dev = &ios->per_dev[0]; struct exofs_per_dev_state *per_dev = &ios->per_dev[0];
_calc_stripe_info(ios, ios->offset, &si);
per_dev->offset = si.obj_offset; per_dev->offset = si.obj_offset;
per_dev->dev = si.dev; per_dev->dev = si.dev;
...@@ -474,6 +468,8 @@ static int _prepare_for_striping(struct exofs_io_state *ios) ...@@ -474,6 +468,8 @@ static int _prepare_for_striping(struct exofs_io_state *ios)
} }
while (length) { while (length) {
_calc_stripe_info(ios, offset, &si);
if (length < si.group_length) if (length < si.group_length)
si.group_length = length; si.group_length = length;
...@@ -481,16 +477,8 @@ static int _prepare_for_striping(struct exofs_io_state *ios) ...@@ -481,16 +477,8 @@ static int _prepare_for_striping(struct exofs_io_state *ios)
if (unlikely(ret)) if (unlikely(ret))
goto out; goto out;
offset += si.group_length;
length -= si.group_length; length -= si.group_length;
si.group_length = si.total_group_length;
si.unit_off = 0;
++si.Major;
si.obj_offset = si.Major * ios->layout->stripe_unit *
ios->layout->group_depth;
si.dev = (si.dev - (si.dev % devs_in_group)) + devs_in_group;
si.dev %= ios->layout->s_numdevs;
} }
out: out:
......
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