From: Bob Peterson <rpeterso@redhat.com>
To: cluster-devel.redhat.com
Subject: [Cluster-devel] GFS2: Always call gfs2_holder_uninit after gfs_holder_init?
Date: Fri, 15 Apr 2016 10:30:08 -0400 (EDT) [thread overview]
Message-ID: <229783496.51602257.1460730608253.JavaMail.zimbra@redhat.com> (raw)
In-Reply-To: <20160415014438.GB24605@ceres>
----- Original Message -----
> Hi,
>
> I am trying to understand some of the internals of glocks. It looks like the
> basic pattern is:
>
> 1. Initialize a holder with gfs2_holder_init
> 2. Enqueue this holder onto the glock
> 3. Dequeue the holder
> 4. Uninitialize the holder with gfs2_holder_uninit
>
> My question is this: are there situations where the holder structure does not
> need to be uninitialized? I ask because I have run across a couple of
> cases where it is not, such as in gfs2_get_flags:
>
> gfs2_holder_init(ip->i_gl, LM_ST_SHARED, 0, &gh);
> error = gfs2_glock_nq(&gh);
> if (error)
> return error;
> ...
> gfs2_glock_dq(&gh);
> gfs2_holder_uninit(&gh);
>
> Is this correct? Here gh is initialized but never uninitialized on the error
> path. It seems like this would cause an inaccurate lockref count. In
> many other cases the holder structure is uninitialized, even if lock
> acquisition fails.
>
> Thanks,
>
> Daniel
Hi Daniel,
The glock init/uninit stuff serves to get a reference on the glock, and
we need to take great care to do proper accounting on the glock reference
count, or the glock won't go away, which can cause (1) problems syncing
the metadata to disk, and (2) problems unmounting the file system.
The code you pointed out, gfs2_get_flags, appears to be a bug.
I agree with you that it should probably do holder_uninit in the error
case. I can patch it up if you want, unless you want to submit a patch.
However, under normal circumstances, the gfs2_glock_nq should not fail
especially for a SHARED lock like that. It can fail if the file system
is being unmounted, or other very unlikely circumstances.
Regards,
Bob Peterson
Red Hat File Systems
next prev parent reply other threads:[~2016-04-15 14:30 UTC|newest]
Thread overview: 3+ messages / expand[flat|nested] mbox.gz Atom feed top
2016-04-15 1:44 [Cluster-devel] GFS2: Always call gfs2_holder_uninit after gfs_holder_init? Daniel DeFreez
2016-04-15 14:30 ` Bob Peterson [this message]
2016-04-15 20:30 ` Daniel DeFreez
Reply instructions:
You may reply publicly to this message via plain-text email
using any one of the following methods:
* Save the following mbox file, import it into your mail client,
and reply-to-all from there: mbox
Avoid top-posting and favor interleaved quoting:
https://en.wikipedia.org/wiki/Posting_style#Interleaved_style
* Reply using the --to, --cc, and --in-reply-to
switches of git-send-email(1):
git send-email \
--in-reply-to=229783496.51602257.1460730608253.JavaMail.zimbra@redhat.com \
--to=rpeterso@redhat.com \
/path/to/YOUR_REPLY
https://kernel.org/pub/software/scm/git/docs/git-send-email.html
* If your mail client supports setting the In-Reply-To header
via mailto: links, try the mailto: link
Be sure your reply has a Subject: header at the top and a blank line
before the message body.
This is a public inbox, see mirroring instructions
for how to clone and mirror all data and code used for this inbox;
as well as URLs for NNTP newsgroup(s).