Commit e6f85600 authored by Bob Peterson's avatar Bob Peterson Committed by Andreas Gruenbacher

gfs2: split glock instantiation off from do_promote

Before this patch, function do_promote had a section of code that did
the actual instantiation.  This patch splits that off into its own
function, gfs2_instantiate, which prepares us for the next patch that
will use that function.
Signed-off-by: default avatarBob Peterson <rpeterso@redhat.com>
Signed-off-by: default avatarAndreas Gruenbacher <agruenba@redhat.com>
parent 60d8bae9
...@@ -472,6 +472,21 @@ find_first_strong_holder(struct gfs2_glock *gl) ...@@ -472,6 +472,21 @@ find_first_strong_holder(struct gfs2_glock *gl)
return NULL; return NULL;
} }
/*
* gfs2_instantiate - Call the glops instantiate function
* @gl: The glock
*
* Returns: 0 if instantiate was successful, 2 if type specific operation is
* underway, or error.
*/
static int gfs2_instantiate(struct gfs2_holder *gh)
{
struct gfs2_glock *gl = gh->gh_gl;
const struct gfs2_glock_operations *glops = gl->gl_ops;
return glops->go_instantiate(gh);
}
/** /**
* do_promote - promote as many requests as possible on the current queue * do_promote - promote as many requests as possible on the current queue
* @gl: The glock * @gl: The glock
...@@ -484,7 +499,6 @@ static int do_promote(struct gfs2_glock *gl) ...@@ -484,7 +499,6 @@ static int do_promote(struct gfs2_glock *gl)
__releases(&gl->gl_lockref.lock) __releases(&gl->gl_lockref.lock)
__acquires(&gl->gl_lockref.lock) __acquires(&gl->gl_lockref.lock)
{ {
const struct gfs2_glock_operations *glops = gl->gl_ops;
struct gfs2_holder *gh, *tmp, *first_gh; struct gfs2_holder *gh, *tmp, *first_gh;
bool incompat_holders_demoted = false; bool incompat_holders_demoted = false;
bool lock_released; bool lock_released;
...@@ -513,10 +527,10 @@ __acquires(&gl->gl_lockref.lock) ...@@ -513,10 +527,10 @@ __acquires(&gl->gl_lockref.lock)
first_gh = gh; first_gh = gh;
} }
if (gh->gh_list.prev == &gl->gl_holders && if (gh->gh_list.prev == &gl->gl_holders &&
!(gh->gh_flags & GL_SKIP) && glops->go_instantiate) { !(gh->gh_flags & GL_SKIP) && gl->gl_ops->go_instantiate) {
lock_released = true; lock_released = true;
spin_unlock(&gl->gl_lockref.lock); spin_unlock(&gl->gl_lockref.lock);
ret = glops->go_instantiate(gh); ret = gfs2_instantiate(gh);
spin_lock(&gl->gl_lockref.lock); spin_lock(&gl->gl_lockref.lock);
if (ret) { if (ret) {
if (ret == 1) if (ret == 1)
......
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