Commit a6307ff9 authored by Jinshan Xiong's avatar Jinshan Xiong Committed by Greg Kroah-Hartman

staging/lustre/osc: osc_lock_weight endless loop fix

With huge number of pages to scan by osc_lock_weight() it is likely
CLP_GANG_RESCHED is returned from osc_page_gang_lookup() and the scan
will be repeated again from the start. To be sure that the scan is
progressing across those restarts, next scan should be started from
the last scanned page index plus one.

Xyratex-bug-id: MRP-2145
Signed-off-by: default avatarAlexander Zarochentsev <alexander.zarochentsev@seagate.com>
Signed-off-by: default avatarJinshan Xiong <jinshan.xiong@intel.com>
Reviewed-on: http://review.whamcloud.com/12362
Intel-bug-id: https://jira.hpdd.intel.com/browse/LU-5781Reviewed-by: default avatarBobi Jam <bobijam@hotmail.com>
Reviewed-by: default avatarJames Simmons <uja.ornl@gmail.com>
Signed-off-by: default avatarOleg Drokin <green@linuxhacker.ru>
Signed-off-by: default avatarGreg Kroah-Hartman <gregkh@linuxfoundation.org>
parent c9cc8d0f
...@@ -634,11 +634,10 @@ static int weigh_cb(const struct lu_env *env, struct cl_io *io, ...@@ -634,11 +634,10 @@ static int weigh_cb(const struct lu_env *env, struct cl_io *io,
if (cl_page_is_vmlocked(env, page) || if (cl_page_is_vmlocked(env, page) ||
PageDirty(page->cp_vmpage) || PageWriteback(page->cp_vmpage) PageDirty(page->cp_vmpage) || PageWriteback(page->cp_vmpage)
) { )
(*(unsigned long *)cbdata)++;
return CLP_GANG_ABORT; return CLP_GANG_ABORT;
}
*(pgoff_t *)cbdata = osc_index(ops) + 1;
return CLP_GANG_OKAY; return CLP_GANG_OKAY;
} }
...@@ -648,7 +647,7 @@ static unsigned long osc_lock_weight(const struct lu_env *env, ...@@ -648,7 +647,7 @@ static unsigned long osc_lock_weight(const struct lu_env *env,
{ {
struct cl_io *io = &osc_env_info(env)->oti_io; struct cl_io *io = &osc_env_info(env)->oti_io;
struct cl_object *obj = cl_object_top(&oscobj->oo_cl); struct cl_object *obj = cl_object_top(&oscobj->oo_cl);
unsigned long npages = 0; pgoff_t page_index;
int result; int result;
io->ci_obj = obj; io->ci_obj = obj;
...@@ -657,11 +656,12 @@ static unsigned long osc_lock_weight(const struct lu_env *env, ...@@ -657,11 +656,12 @@ static unsigned long osc_lock_weight(const struct lu_env *env,
if (result != 0) if (result != 0)
return result; return result;
page_index = cl_index(obj, extent->start);
do { do {
result = osc_page_gang_lookup(env, io, oscobj, result = osc_page_gang_lookup(env, io, oscobj,
cl_index(obj, extent->start), page_index,
cl_index(obj, extent->end), cl_index(obj, extent->end),
weigh_cb, (void *)&npages); weigh_cb, (void *)&page_index);
if (result == CLP_GANG_ABORT) if (result == CLP_GANG_ABORT)
break; break;
if (result == CLP_GANG_RESCHED) if (result == CLP_GANG_RESCHED)
...@@ -669,7 +669,7 @@ static unsigned long osc_lock_weight(const struct lu_env *env, ...@@ -669,7 +669,7 @@ static unsigned long osc_lock_weight(const struct lu_env *env,
} while (result != CLP_GANG_OKAY); } while (result != CLP_GANG_OKAY);
cl_io_fini(env, io); cl_io_fini(env, io);
return npages; return result == CLP_GANG_ABORT ? 1 : 0;
} }
/** /**
......
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