Linux Newbie help
 help / color / mirror / Atom feed
From: Arjan van de Ven <arjan@infradead.org>
To: Rajat Jain <rajat.noida.india@gmail.com>
Cc: kernel mail <kernelnewbies@nl.linux.org>,
	newbie <linux-newbie@vger.kernel.org>
Subject: Re: Need for a new spinlock API?
Date: Wed, 21 Mar 2007 08:32:10 +0100	[thread overview]
Message-ID: <1174462330.1158.113.camel@laptopd505.fenrus.org> (raw)
In-Reply-To: <b115cb5f0703202053n1b8bfd4bo39cd046e04fb15a2@mail.gmail.com>

On Wed, 2007-03-21 at 09:23 +0530, Rajat Jain wrote:
> Hi,
> 
> We often have a case where a driver wants to access its data structure
> in process context as well as in interrupt context (in its ISR). In
> such scenarios, we generally use spin_lock_irqsave() to grab the lock
> as well as disable all the local interrupts. AFAIK, disabling of local
> interrupts is required so as to avoid running your ISR (which needs
> the lock) while process context is holding the lock. However, this
> also disables any other ISRs (which DO NOT need the lock) on the local
> processor.
> 
> Isn't this sub-optimal? Shouldn't there be a finer grained locking?

actually it's optimal.
It's fastest to delay the interrupts a little and be done with what you
want to do under the lock quickly, and THEN take the interrupt. This
means the lock hold time is short, which significantly reduces
contention on this lock...

also it's really hard to impossible to get the more complex locking
scenarios and dependencies right in this context; it's just so much
simpler (and even this simple drivers get it wrong often .. :)


-- 
if you want to mail me at work (you don't), use arjan (at) linux.intel.com
Test the interaction between Linux and your BIOS via http://www.linuxfirmwarekit.org

-
To unsubscribe from this list: send the line "unsubscribe linux-newbie" in
the body of a message to majordomo@vger.kernel.org
More majordomo info at  http://vger.kernel.org/majordomo-info.html
Please read the FAQ at http://www.linux-learn.org/faqs

  reply	other threads:[~2007-03-21  7:32 UTC|newest]

Thread overview: 17+ messages / expand[flat|nested]  mbox.gz  Atom feed  top
2007-03-21  3:53 Need for a new spinlock API? Rajat Jain
2007-03-21  7:32 ` Arjan van de Ven [this message]
2007-03-21 18:59   ` anubhav rakshit
2007-03-21 21:03     ` Arjan van de Ven
2007-03-21 23:07       ` Tzahi Fadida
2007-03-22  1:12       ` Rajat Jain
2007-03-22  4:17         ` Ajay Singh (ajaysi)
2007-03-22  4:33           ` Rajat Jain
2007-03-22  4:55             ` Ajay Singh (ajaysi)
2007-03-22  5:59               ` Rajat Jain
2007-03-22  8:51                 ` Arjan van de Ven
2007-03-22  8:50         ` Arjan van de Ven
2007-04-04  3:26   ` Rajat Jain
2007-04-04  5:38     ` anubhav rakshit
  -- strict thread matches above, loose matches on Subject: below --
2007-04-04  3:50 GAggarwal
2007-04-04  5:10 ` Rajat Jain
2007-04-04  5:34 GAggarwal

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=1174462330.1158.113.camel@laptopd505.fenrus.org \
    --to=arjan@infradead.org \
    --cc=kernelnewbies@nl.linux.org \
    --cc=linux-newbie@vger.kernel.org \
    --cc=rajat.noida.india@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