From: guenter.roeck@ericsson.com (Guenter Roeck)
To: linux-arm-kernel@lists.infradead.org
Subject: [PATCH v2] MAX1111: Fix Race condition causing NULL pointer exception
Date: Mon, 11 Jul 2011 14:03:13 -0700 [thread overview]
Message-ID: <1310418193.21224.14.camel@groeck-laptop> (raw)
In-Reply-To: <1602583.Pi9fQvRk5m@bloomfield>
On Mon, 2011-07-11 at 16:36 -0400, Pavel Herrmann wrote:
> On Monday 11 of July 2011 22:11:48 Jean Delvare wrote:
> > > spi_sync call uses its spi_message parameter to keep completion
> > > information, having this structure static is not thread-safe,
> > > potentially causing one thread having pointers to memory on or above
> > > other threads stack. use mutex to prevent multiple access
> >
> > This has nothing to do with static, as a matter of fact the structure
> > is dynamically allocated. The bottom line is that the driver structure
> > is such that calls to max1111_read() must be serialized.
>
> the structure is dynamically allocated, but the pointer used to hold it is a
> static global var.
This is true only if CONFIG_SHARPSL_PM is defined, and it assumes that
the driver is instantiated exactly once. That is pretty badly broken
(the commit introducing it even admits that), and should be fixed. This
does not happen CONFIG_SHARPSL_PM is not defined. If CONFIG_SHARPSL_PM
_is_ defined in your environment, and you do have multiple instances of
the driver (ie if you have multiple MAX1111 chips in your system), a
severe problem is that max1111_read_channel() does not identify the
driver instance. That can not be fixed with a mutex.
> "static" in this context meant "shared by all threads"
>
I think it would make sense to stick with common terminology. In your
definition, almost all global variables of all programs out there would
be defined as "static".
Guenter
next prev parent reply other threads:[~2011-07-11 21:03 UTC|newest]
Thread overview: 9+ messages / expand[flat|nested] mbox.gz Atom feed top
2011-07-11 18:47 [PATCH v2] MAX1111: Fix Race condition causing NULL pointer exception Pavel Herrmann
2011-07-11 20:11 ` Jean Delvare
2011-07-11 20:36 ` Pavel Herrmann
2011-07-11 21:03 ` Guenter Roeck [this message]
2011-07-11 21:49 ` Pavel Herrmann
2011-07-12 6:48 ` Jean Delvare
2011-07-11 20:56 ` [Zaurus-devel] " Stanislav Brabec
-- strict thread matches above, loose matches on Subject: below --
2011-06-03 20:00 Pavel Herrmann
2011-06-29 20:11 ` Pavel Herrmann
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=1310418193.21224.14.camel@groeck-laptop \
--to=guenter.roeck@ericsson.com \
--cc=linux-arm-kernel@lists.infradead.org \
/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