Add a bunch of cycle_kernel_lock() calls

All of the open() functions which don't need the BKL on their face may
still depend on its acquisition to serialize opens against driver
initialization.  So make those functions acquire then release the BKL to be
on the safe side.

Signed-off-by: Jonathan Corbet <corbet@lwn.net>
This commit is contained in:
Jonathan Corbet 2008-05-18 15:32:43 -06:00
parent 0b28067688
commit f2b9857eee
21 changed files with 45 additions and 55 deletions

View file

@ -28,6 +28,7 @@
#include <linux/init.h> #include <linux/init.h>
#include <linux/delay.h> #include <linux/delay.h>
#include <linux/interrupt.h> #include <linux/interrupt.h>
#include <linux/smp_lock.h>
#include <linux/wait.h> #include <linux/wait.h>
#include <asm/uaccess.h> #include <asm/uaccess.h>
#include "i2c.h" #include "i2c.h"
@ -375,10 +376,9 @@ int __init eeprom_init(void)
} }
/* Opens the device. */ /* Opens the device. */
/* BKL not needed: no global resources accessed */
static int eeprom_open(struct inode * inode, struct file * file) static int eeprom_open(struct inode * inode, struct file * file)
{ {
cycle_kernel_lock();
if(iminor(inode) != EEPROM_MINOR_NR) if(iminor(inode) != EEPROM_MINOR_NR)
return -ENXIO; return -ENXIO;
if(imajor(inode) != EEPROM_MAJOR_NR) if(imajor(inode) != EEPROM_MAJOR_NR)

View file

@ -15,6 +15,7 @@
#include <linux/module.h> #include <linux/module.h>
#include <linux/sched.h> #include <linux/sched.h>
#include <linux/slab.h> #include <linux/slab.h>
#include <linux/smp_lock.h>
#include <linux/errno.h> #include <linux/errno.h>
#include <linux/kernel.h> #include <linux/kernel.h>
#include <linux/fs.h> #include <linux/fs.h>
@ -566,6 +567,7 @@ i2c_readreg(unsigned char theSlave, unsigned char theReg)
static int static int
i2c_open(struct inode *inode, struct file *filp) i2c_open(struct inode *inode, struct file *filp)
{ {
cycle_kernel_lock();
return 0; return 0;
} }

View file

@ -11,6 +11,7 @@
#include <linux/string.h> #include <linux/string.h>
#include <linux/fs.h> #include <linux/fs.h>
#include <linux/mm.h> #include <linux/mm.h>
#include <linux/smp_lock.h>
#include <linux/spinlock.h> #include <linux/spinlock.h>
#include <linux/stddef.h> #include <linux/stddef.h>
@ -2302,11 +2303,11 @@ static int cryptocop_job_setup(struct cryptocop_prio_job **pj, struct cryptocop_
return 0; return 0;
} }
/* No BKL needed here - no global resources accessed */
static int cryptocop_open(struct inode *inode, struct file *filp) static int cryptocop_open(struct inode *inode, struct file *filp)
{ {
int p = iminor(inode); int p = iminor(inode);
cycle_kernel_lock();
if (p != CRYPTOCOP_MINOR) return -EINVAL; if (p != CRYPTOCOP_MINOR) return -EINVAL;
filp->private_data = NULL; filp->private_data = NULL;

View file

@ -33,6 +33,7 @@
#include <linux/fs.h> #include <linux/fs.h>
#include <linux/string.h> #include <linux/string.h>
#include <linux/init.h> #include <linux/init.h>
#include <linux/smp_lock.h>
#include <asm/etraxi2c.h> #include <asm/etraxi2c.h>
@ -636,6 +637,7 @@ i2c_readreg(unsigned char theSlave, unsigned char theReg)
static int static int
i2c_open(struct inode *inode, struct file *filp) i2c_open(struct inode *inode, struct file *filp)
{ {
cycle_kernel_lock();
return 0; return 0;
} }

View file

@ -17,6 +17,7 @@
#include <linux/cdev.h> #include <linux/cdev.h>
#include <linux/ioport.h> #include <linux/ioport.h>
#include <linux/pci.h> #include <linux/pci.h>
#include <linux/smp_lock.h>
#include <asm/uaccess.h> #include <asm/uaccess.h>
#include <asm/io.h> #include <asm/io.h>
@ -153,12 +154,11 @@ static ssize_t cs5535_gpio_read(struct file *file, char __user *buf,
return count; return count;
} }
/* No BKL needed here - "mask" is the only global resource used
here and it's a boot-time parameter */
static int cs5535_gpio_open(struct inode *inode, struct file *file) static int cs5535_gpio_open(struct inode *inode, struct file *file)
{ {
u32 m = iminor(inode); u32 m = iminor(inode);
cycle_kernel_lock();
/* the mask says which pins are usable by this driver */ /* the mask says which pins are usable by this driver */
if ((mask & (1 << m)) == 0) if ((mask & (1 << m)) == 0)
return -EINVAL; return -EINVAL;

View file

@ -56,6 +56,7 @@
#include <linux/errno.h> /* for -EBUSY */ #include <linux/errno.h> /* for -EBUSY */
#include <linux/ioport.h> /* for request_region */ #include <linux/ioport.h> /* for request_region */
#include <linux/delay.h> /* for loops_per_jiffy */ #include <linux/delay.h> /* for loops_per_jiffy */
#include <linux/smp_lock.h> /* cycle_kernel_lock() */
#include <asm/io.h> /* for inb_p, outb_p, inb, outb, etc. */ #include <asm/io.h> /* for inb_p, outb_p, inb, outb, etc. */
#include <asm/uaccess.h> /* for get_user, etc. */ #include <asm/uaccess.h> /* for get_user, etc. */
#include <linux/wait.h> /* for wait_queue */ #include <linux/wait.h> /* for wait_queue */
@ -288,12 +289,12 @@ static int dtlk_ioctl(struct inode *inode,
} }
} }
/* No BKL needed here; "dtlk_busy" is the only global resource, /* Note that nobody ever sets dtlk_busy... */
and it is not ever set by anybody (test is broken) */
static int dtlk_open(struct inode *inode, struct file *file) static int dtlk_open(struct inode *inode, struct file *file)
{ {
TRACE_TEXT("(dtlk_open"); TRACE_TEXT("(dtlk_open");
cycle_kernel_lock();
nonseekable_open(inode, file); nonseekable_open(inode, file);
switch (iminor(inode)) { switch (iminor(inode)) {
case DTLK_MINOR: case DTLK_MINOR:

View file

@ -98,6 +98,7 @@
#include <linux/major.h> #include <linux/major.h>
#include <linux/wait.h> #include <linux/wait.h>
#include <linux/device.h> #include <linux/device.h>
#include <linux/smp_lock.h>
#include <linux/tty.h> #include <linux/tty.h>
#include <linux/tty_flip.h> #include <linux/tty_flip.h>
@ -2931,42 +2932,11 @@ ip2_ipl_ioctl ( struct inode *pInode, struct file *pFile, UINT cmd, ULONG arg )
static int static int
ip2_ipl_open( struct inode *pInode, struct file *pFile ) ip2_ipl_open( struct inode *pInode, struct file *pFile )
{ {
unsigned int iplminor = iminor(pInode);
i2eBordStrPtr pB;
i2ChanStrPtr pCh;
#ifdef IP2DEBUG_IPL #ifdef IP2DEBUG_IPL
printk (KERN_DEBUG "IP2IPL: open\n" ); printk (KERN_DEBUG "IP2IPL: open\n" );
#endif #endif
cycle_kernel_lock();
switch(iplminor) {
// These are the IPL devices
case 0:
case 4:
case 8:
case 12:
break;
// These are the status devices
case 1:
case 5:
case 9:
case 13:
break;
// These are the debug devices
case 2:
case 6:
case 10:
case 14:
pB = i2BoardPtrTable[iplminor / 4];
pCh = (i2ChanStrPtr) pB->i2eChannelPtr;
break;
// This is the trace device
case 3:
break;
}
return 0; return 0;
} }

View file

@ -20,6 +20,7 @@
#include <linux/mutex.h> #include <linux/mutex.h>
#include <linux/nsc_gpio.h> #include <linux/nsc_gpio.h>
#include <linux/platform_device.h> #include <linux/platform_device.h>
#include <linux/smp_lock.h>
#include <asm/uaccess.h> #include <asm/uaccess.h>
#define DEVNAME "pc8736x_gpio" #define DEVNAME "pc8736x_gpio"
@ -212,12 +213,12 @@ static struct nsc_gpio_ops pc8736x_gpio_ops = {
.gpio_current = pc8736x_gpio_current .gpio_current = pc8736x_gpio_current
}; };
/* No BKL needed here; no global resources accessed */
static int pc8736x_gpio_open(struct inode *inode, struct file *file) static int pc8736x_gpio_open(struct inode *inode, struct file *file)
{ {
unsigned m = iminor(inode); unsigned m = iminor(inode);
file->private_data = &pc8736x_gpio_ops; file->private_data = &pc8736x_gpio_ops;
cycle_kernel_lock();
dev_dbg(&pdev->dev, "open %d\n", m); dev_dbg(&pdev->dev, "open %d\n", m);
if (m >= PC8736X_GPIO_CT) if (m >= PC8736X_GPIO_CT)

View file

@ -66,6 +66,7 @@
#include <linux/poll.h> #include <linux/poll.h>
#include <linux/major.h> #include <linux/major.h>
#include <linux/ppdev.h> #include <linux/ppdev.h>
#include <linux/smp_lock.h>
#include <asm/uaccess.h> #include <asm/uaccess.h>
#define PP_VERSION "ppdev: user-space parallel port driver" #define PP_VERSION "ppdev: user-space parallel port driver"
@ -633,12 +634,12 @@ static int pp_ioctl(struct inode *inode, struct file *file,
return 0; return 0;
} }
/* No BKL needed here: only local resources used */
static int pp_open (struct inode * inode, struct file * file) static int pp_open (struct inode * inode, struct file * file)
{ {
unsigned int minor = iminor(inode); unsigned int minor = iminor(inode);
struct pp_struct *pp; struct pp_struct *pp;
cycle_kernel_lock();
if (minor >= PARPORT_MAX) if (minor >= PARPORT_MAX)
return -ENXIO; return -ENXIO;

View file

@ -12,6 +12,7 @@
#include <linux/kernel.h> #include <linux/kernel.h>
#include <linux/init.h> #include <linux/init.h>
#include <linux/platform_device.h> #include <linux/platform_device.h>
#include <linux/smp_lock.h>
#include <asm/uaccess.h> #include <asm/uaccess.h>
#include <asm/io.h> #include <asm/io.h>
@ -46,12 +47,12 @@ struct nsc_gpio_ops scx200_gpio_ops = {
}; };
EXPORT_SYMBOL_GPL(scx200_gpio_ops); EXPORT_SYMBOL_GPL(scx200_gpio_ops);
/* No BKL needed here: no global resources used */
static int scx200_gpio_open(struct inode *inode, struct file *file) static int scx200_gpio_open(struct inode *inode, struct file *file)
{ {
unsigned m = iminor(inode); unsigned m = iminor(inode);
file->private_data = &scx200_gpio_ops; file->private_data = &scx200_gpio_ops;
cycle_kernel_lock();
if (m >= MAX_PINS) if (m >= MAX_PINS)
return -EINVAL; return -EINVAL;
return nonseekable_open(inode, file); return nonseekable_open(inode, file);

View file

@ -21,6 +21,7 @@
#include <linux/fs.h> #include <linux/fs.h>
#include <linux/init.h> #include <linux/init.h>
#include <linux/module.h> #include <linux/module.h>
#include <linux/smp_lock.h>
#include <asm/io.h> #include <asm/io.h>
#include <asm/reboot.h> #include <asm/reboot.h>
@ -232,11 +233,11 @@ static ssize_t tanbac_tb0219_write(struct file *file, const char __user *data,
return i; return i;
} }
/* No BKL needed here; no global resources accessed */
static int tanbac_tb0219_open(struct inode *inode, struct file *file) static int tanbac_tb0219_open(struct inode *inode, struct file *file)
{ {
unsigned int minor; unsigned int minor;
cycle_kernel_lock();
minor = iminor(inode); minor = iminor(inode);
switch (minor) { switch (minor) {
case 0: case 0:

View file

@ -27,6 +27,7 @@
#include <linux/kernel.h> #include <linux/kernel.h>
#include <linux/module.h> #include <linux/module.h>
#include <linux/platform_device.h> #include <linux/platform_device.h>
#include <linux/smp_lock.h>
#include <linux/spinlock.h> #include <linux/spinlock.h>
#include <linux/types.h> #include <linux/types.h>
@ -543,12 +544,11 @@ static ssize_t gpio_write(struct file *file, const char __user *data,
return i; return i;
} }
/* No BKL needed here; only global (giu_nr_pins) is only set
at probe time */
static int gpio_open(struct inode *inode, struct file *file) static int gpio_open(struct inode *inode, struct file *file)
{ {
unsigned int pin; unsigned int pin;
cycle_kernel_lock();
pin = iminor(inode); pin = iminor(inode);
if (pin >= giu_nr_pins) if (pin >= giu_nr_pins)
return -EBADF; return -EBADF;

View file

@ -45,6 +45,7 @@
#include <linux/cdev.h> #include <linux/cdev.h>
#include <linux/idr.h> #include <linux/idr.h>
#include <linux/mutex.h> #include <linux/mutex.h>
#include <linux/smp_lock.h>
#include <asm/uaccess.h> #include <asm/uaccess.h>
@ -1155,11 +1156,11 @@ static unsigned int ib_ucm_poll(struct file *filp,
return mask; return mask;
} }
/* No BKL needed here: no global resources used */
static int ib_ucm_open(struct inode *inode, struct file *filp) static int ib_ucm_open(struct inode *inode, struct file *filp)
{ {
struct ib_ucm_file *file; struct ib_ucm_file *file;
cycle_kernel_lock();
file = kmalloc(sizeof(*file), GFP_KERNEL); file = kmalloc(sizeof(*file), GFP_KERNEL);
if (!file) if (!file)
return -ENOMEM; return -ENOMEM;

View file

@ -39,6 +39,7 @@
#include <linux/highmem.h> #include <linux/highmem.h>
#include <linux/io.h> #include <linux/io.h>
#include <linux/jiffies.h> #include <linux/jiffies.h>
#include <linux/smp_lock.h>
#include <asm/pgtable.h> #include <asm/pgtable.h>
#include "ipath_kernel.h" #include "ipath_kernel.h"
@ -1812,10 +1813,10 @@ done:
return ret; return ret;
} }
/* No BKL needed here */
static int ipath_open(struct inode *in, struct file *fp) static int ipath_open(struct inode *in, struct file *fp)
{ {
/* The real work is performed later in ipath_assign_port() */ /* The real work is performed later in ipath_assign_port() */
cycle_kernel_lock();
fp->private_data = kzalloc(sizeof(struct ipath_filedata), GFP_KERNEL); fp->private_data = kzalloc(sizeof(struct ipath_filedata), GFP_KERNEL);
return fp->private_data ? 0 : -ENOMEM; return fp->private_data ? 0 : -ENOMEM;
} }

View file

@ -17,6 +17,7 @@
#include <linux/poll.h> #include <linux/poll.h>
#include <linux/proc_fs.h> #include <linux/proc_fs.h>
#include <linux/skbuff.h> #include <linux/skbuff.h>
#include <linux/smp_lock.h>
#include <asm/uaccess.h> #include <asm/uaccess.h>
#include "platform.h" #include "platform.h"
@ -400,6 +401,7 @@ static unsigned int um_idi_poll(struct file *file, poll_table * wait)
static int um_idi_open(struct inode *inode, struct file *file) static int um_idi_open(struct inode *inode, struct file *file)
{ {
cycle_kernel_lock();
return (0); return (0);
} }

View file

@ -21,6 +21,7 @@
#include <linux/list.h> #include <linux/list.h>
#include <linux/poll.h> #include <linux/poll.h>
#include <linux/kmod.h> #include <linux/kmod.h>
#include <linux/smp_lock.h>
#include "platform.h" #include "platform.h"
#undef ID_MASK #undef ID_MASK
@ -580,6 +581,7 @@ xdi_copy_from_user(void *os_handle, void *dst, const void __user *src, int lengt
*/ */
static int divas_open(struct inode *inode, struct file *file) static int divas_open(struct inode *inode, struct file *file)
{ {
cycle_kernel_lock();
return (0); return (0);
} }

View file

@ -39,6 +39,7 @@
#include <linux/if_arp.h> #include <linux/if_arp.h>
#include <linux/ip.h> #include <linux/ip.h>
#include <linux/tcp.h> #include <linux/tcp.h>
#include <linux/smp_lock.h>
#include <linux/spinlock.h> #include <linux/spinlock.h>
#include <linux/rwsem.h> #include <linux/rwsem.h>
#include <linux/stddef.h> #include <linux/stddef.h>
@ -351,9 +352,9 @@ static const int npindex_to_ethertype[NUM_NP] = {
* Open instances of /dev/ppp can be in one of three states: * Open instances of /dev/ppp can be in one of three states:
* unattached, attached to a ppp unit, or attached to a ppp channel. * unattached, attached to a ppp unit, or attached to a ppp channel.
*/ */
/* No BKL needed here */
static int ppp_open(struct inode *inode, struct file *file) static int ppp_open(struct inode *inode, struct file *file)
{ {
cycle_kernel_lock();
/* /*
* This could (should?) be enforced by the permissions on /dev/ppp. * This could (should?) be enforced by the permissions on /dev/ppp.
*/ */

View file

@ -84,6 +84,7 @@
#include <linux/pci.h> #include <linux/pci.h>
#include <linux/time.h> #include <linux/time.h>
#include <linux/mutex.h> #include <linux/mutex.h>
#include <linux/smp_lock.h>
#include <asm/io.h> #include <asm/io.h>
#include <asm/irq.h> #include <asm/irq.h>
#include <asm/uaccess.h> #include <asm/uaccess.h>
@ -862,13 +863,13 @@ out:
} /* End twa_chrdev_ioctl() */ } /* End twa_chrdev_ioctl() */
/* This function handles open for the character device */ /* This function handles open for the character device */
/* NOTE that this function will race with remove; adding BKL /* NOTE that this function will race with remove. */
will not help. */
static int twa_chrdev_open(struct inode *inode, struct file *file) static int twa_chrdev_open(struct inode *inode, struct file *file)
{ {
unsigned int minor_number; unsigned int minor_number;
int retval = TW_IOCTL_ERROR_OS_ENODEV; int retval = TW_IOCTL_ERROR_OS_ENODEV;
cycle_kernel_lock();
minor_number = iminor(inode); minor_number = iminor(inode);
if (minor_number >= twa_device_extension_count) if (minor_number >= twa_device_extension_count)
goto out; goto out;

View file

@ -198,6 +198,7 @@
#include <linux/module.h> #include <linux/module.h>
#include <linux/reboot.h> #include <linux/reboot.h>
#include <linux/smp_lock.h>
#include <linux/spinlock.h> #include <linux/spinlock.h>
#include <linux/interrupt.h> #include <linux/interrupt.h>
#include <linux/moduleparam.h> #include <linux/moduleparam.h>
@ -1027,12 +1028,12 @@ out:
} /* End tw_chrdev_ioctl() */ } /* End tw_chrdev_ioctl() */
/* This function handles open for the character device */ /* This function handles open for the character device */
/* NOTE that this function races with remove - adding BKL /* NOTE that this function races with remove. */
won't help */
static int tw_chrdev_open(struct inode *inode, struct file *file) static int tw_chrdev_open(struct inode *inode, struct file *file)
{ {
unsigned int minor_number; unsigned int minor_number;
cycle_kernel_lock();
dprintk(KERN_WARNING "3w-xxxx: tw_ioctl_open()\n"); dprintk(KERN_WARNING "3w-xxxx: tw_ioctl_open()\n");
minor_number = iminor(inode); minor_number = iminor(inode);

View file

@ -46,6 +46,7 @@
#include <linux/pci.h> #include <linux/pci.h>
#include <linux/init.h> #include <linux/init.h>
#include <linux/dma-mapping.h> #include <linux/dma-mapping.h>
#include <linux/smp_lock.h>
#include <scsi/scsicam.h> #include <scsi/scsicam.h>
#include "scsi.h" #include "scsi.h"
@ -3273,12 +3274,11 @@ mega_init_scb(adapter_t *adapter)
* *
* Routines for the character/ioctl interface to the driver. Find out if this * Routines for the character/ioctl interface to the driver. Find out if this
* is a valid open. * is a valid open.
*
* No BKL needed here.
*/ */
static int static int
megadev_open (struct inode *inode, struct file *filep) megadev_open (struct inode *inode, struct file *filep)
{ {
cycle_kernel_lock();
/* /*
* Only allow superuser to access private ioctl interface * Only allow superuser to access private ioctl interface
*/ */

View file

@ -33,6 +33,7 @@
#include <linux/spinlock.h> #include <linux/spinlock.h>
#include <linux/interrupt.h> #include <linux/interrupt.h>
#include <linux/delay.h> #include <linux/delay.h>
#include <linux/smp_lock.h>
#include <linux/uio.h> #include <linux/uio.h>
#include <asm/uaccess.h> #include <asm/uaccess.h>
#include <linux/fs.h> #include <linux/fs.h>
@ -2860,10 +2861,10 @@ static void megasas_shutdown(struct pci_dev *pdev)
/** /**
* megasas_mgmt_open - char node "open" entry point * megasas_mgmt_open - char node "open" entry point
* No BKL is needed here.
*/ */
static int megasas_mgmt_open(struct inode *inode, struct file *filep) static int megasas_mgmt_open(struct inode *inode, struct file *filep)
{ {
cycle_kernel_lock();
/* /*
* Allow only those users with admin rights * Allow only those users with admin rights
*/ */