diff options
| author | Arnd Bergmann <arnd@arndb.de> | 2010-07-04 00:02:28 +0200 | 
|---|---|---|
| committer | Jesse Barnes <jbarnes@virtuousgeek.org> | 2010-10-15 13:09:47 -0700 | 
| commit | 991f739544a0923b70fb69b115edb880ff9fcc4a (patch) | |
| tree | 74ebd40122d120e058d9f245ac5e3c989c40ef3a /drivers/pci/proc.c | |
| parent | 93e75faba3982767d425323aec5726282d3ad7a2 (diff) | |
| download | olio-linux-3.10-991f739544a0923b70fb69b115edb880ff9fcc4a.tar.xz olio-linux-3.10-991f739544a0923b70fb69b115edb880ff9fcc4a.zip  | |
PCI: kill BKL in /proc/pci
All operations in the pci procfs ioctl functions are
atomic, so no lock is needed here.
Also add a compat_ioctl method, since all the commands
are compatible in 32 bit mode.
Signed-off-by: Arnd Bergmann <arnd@arndb.de>
Cc: Jesse Barnes <jbarnes@virtuousgeek.org>
Cc: Tejun Heo <tj@kernel.org>
Cc: linux-pci@vger.kernel.org
Signed-off-by: Jesse Barnes <jbarnes@virtuousgeek.org>
Diffstat (limited to 'drivers/pci/proc.c')
| -rw-r--r-- | drivers/pci/proc.c | 4 | 
1 files changed, 1 insertions, 3 deletions
diff --git a/drivers/pci/proc.c b/drivers/pci/proc.c index 01f0306525a..297b72c880a 100644 --- a/drivers/pci/proc.c +++ b/drivers/pci/proc.c @@ -212,8 +212,6 @@ static long proc_bus_pci_ioctl(struct file *file, unsigned int cmd,  #endif /* HAVE_PCI_MMAP */  	int ret = 0; -	lock_kernel(); -  	switch (cmd) {  	case PCIIOC_CONTROLLER:  		ret = pci_domain_nr(dev->bus); @@ -242,7 +240,6 @@ static long proc_bus_pci_ioctl(struct file *file, unsigned int cmd,  		break;  	}; -	unlock_kernel();  	return ret;  } @@ -306,6 +303,7 @@ static const struct file_operations proc_bus_pci_operations = {  	.read		= proc_bus_pci_read,  	.write		= proc_bus_pci_write,  	.unlocked_ioctl	= proc_bus_pci_ioctl, +	.compat_ioctl	= proc_bus_pci_ioctl,  #ifdef HAVE_PCI_MMAP  	.open		= proc_bus_pci_open,  	.release	= proc_bus_pci_release,  |