public inbox for linux-kernel@vger.kernel.org
 help / color / mirror / Atom feed
* Big kernel lock in release functions
@ 2001-10-04 17:14 David C. Hansen
  0 siblings, 0 replies; only message in thread
From: David C. Hansen @ 2001-10-04 17:14 UTC (permalink / raw)
  To: Linux kernel mailing list

  I've been looking at use of the big kernel lock in a lot of different
places in the kernel.  I've noticed that there are quite a few uses in
devices' release functions, with no obvious purpose.  Take a look at
arch/m68k/atari/joystick.c:

    lock_kernel();
    joystick[minor].active = 0;
    joystick[minor].ready = 0;

    if ((joystick[0].active == 0) && (joystick[1].active == 0))
        ikbd_joystick_disable();
    unlock_kernel();

  But, there are other places in the same file where the same operations
are performed with no locking at all (except for
ikbd_joystick_disable()). Is there a reason to have locking in the
release function but not in the read or open functions?  
  This is a quite common practice in release functions throughout the
kernel.  In 2.4.10, I counted 108 different places where the BKL is used
in a release function.  I'm not claiming that all of these are
unnecessary, but I believe a big chunk of them are.  

--
David C. Hansen
haveblue@us.ibm.com
IBM LTC Base/OS Group
(503)578-4080

^ permalink raw reply	[flat|nested] only message in thread

only message in thread, other threads:[~2001-10-04 17:14 UTC | newest]

Thread overview: (only message) (download: mbox.gz follow: Atom feed
-- links below jump to the message on this page --
2001-10-04 17:14 Big kernel lock in release functions David C. Hansen

This is a public inbox, see mirroring instructions
for how to clone and mirror all data and code used for this inbox