From: Johan Hovold <johan@kernel.org>
To: Alex Elder <elder@linaro.org>
Cc: Dan Carpenter <dan.carpenter@oracle.com>,
Madhumitha Prabakaran <madhumithabiw@gmail.com>,
devel@driverdev.osuosl.org, elder@kernel.org, johan@kernel.org,
linux-kernel@vger.kernel.org, greybus-dev@lists.linaro.org
Subject: Re: [greybus-dev] [PATCH] Staging: greybus: Fix spinlock_t definition without comment
Date: Mon, 15 Apr 2019 14:59:49 +0200 [thread overview]
Message-ID: <20190415125949.GB775@localhost> (raw)
In-Reply-To: <fd59f7d5-84a0-35ca-b096-a1d2c7e30336@linaro.org>
On Fri, Apr 05, 2019 at 05:50:10PM -0500, Alex Elder wrote:
> On 4/5/19 3:53 PM, Dan Carpenter wrote:
> > On Fri, Apr 05, 2019 at 03:00:46PM -0500, Madhumitha Prabakaran
> > wrote:
> >> Fix spinlock_t definition without comment.
> >>
> >> Signed-off-by: Madhumitha Prabakaran <madhumithabiw@gmail.com>
>
> Madhumitha, the reason one would want a comment associated with
> a lock field in a structure is to get some understanding of why
> it's needed. Saying "protect structure fields" is not enough,
> because that can pretty much be assumed, so a comment like that
> adds no value.
>
> Looking at the code, you can see the lock field protects the
> connection's operations list. It also appears to be needed
> for accessing the state field (reading or updating).
>
> Given that, a better comment might be:
>
> spinlock_t lock; /* operations list and state */
>
> >> --- drivers/staging/greybus/connection.h | 2 +- 1 file changed, 1
> >> insertion(+), 1 deletion(-)
> >>
> >> diff --git a/drivers/staging/greybus/connection.h
> >> b/drivers/staging/greybus/connection.h index
> >> 5ca3befc0636..0aedd246e94a 100644 ---
> >> a/drivers/staging/greybus/connection.h +++
> >> b/drivers/staging/greybus/connection.h @@ -47,7 +47,7 @@ struct
> >> gb_connection { unsigned long flags;
> >>
> >> struct mutex mutex; - spinlock_t lock; + spinlock_t lock; /*
> >> Protect structure fields */ enum gb_connection_state state;
> >
> > What does the mutex do then? Why can't we just use the spinlock for
> > everything?
>
> The mutex needs to be held during enable and disable of a connection.
> Johan might be able to give you a more complete answer but these
> operations (or at least the enable) need to block, so can't hold a
> spinlock.
Yeah, I should have documented this at the time.
You're right that the connection spinlock protects the operation list,
and the mutex the connection state, but there are some other
dependencies here and I don't have time to look at this at the moment.
Better to leave as is, I'd say.
Johan
next prev parent reply other threads:[~2019-04-15 12:59 UTC|newest]
Thread overview: 6+ messages / expand[flat|nested] mbox.gz Atom feed top
2019-04-05 20:00 [PATCH] Staging: greybus: Fix spinlock_t definition without comment Madhumitha Prabakaran
2019-04-05 20:53 ` Dan Carpenter
2019-04-05 22:50 ` [greybus-dev] " Alex Elder
2019-04-06 23:06 ` Madhumthia Prabakaran
2019-04-15 12:59 ` Johan Hovold [this message]
2019-04-06 22:55 ` Madhumthia Prabakaran
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=20190415125949.GB775@localhost \
--to=johan@kernel.org \
--cc=dan.carpenter@oracle.com \
--cc=devel@driverdev.osuosl.org \
--cc=elder@kernel.org \
--cc=elder@linaro.org \
--cc=greybus-dev@lists.linaro.org \
--cc=linux-kernel@vger.kernel.org \
--cc=madhumithabiw@gmail.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