aboutsummaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
authorJonathan Corbet <corbet@lwn.net>2008-05-16 16:01:12 -0400
committerJonathan Corbet <corbet@lwn.net>2008-06-20 16:05:51 -0400
commit057e7c7ff9f91a36a761588c53826bd6a710aeba (patch)
tree001de53a930643f3b00f0cc83ea58670a9815c9f
parent65f37b790bd7ba15413838579470296a709c45e6 (diff)
infiniband: more BKL pushdown
Be extra-cautious and protect the remaining open() functions. Signed-off-by: Jonathan Corbet <corbet@lwn.net>
-rw-r--r--drivers/infiniband/core/user_mad.c7
-rw-r--r--drivers/infiniband/core/uverbs_main.c9
2 files changed, 13 insertions, 3 deletions
diff --git a/drivers/infiniband/core/user_mad.c b/drivers/infiniband/core/user_mad.c
index 3aa2db54eae4..1fc17940a765 100644
--- a/drivers/infiniband/core/user_mad.c
+++ b/drivers/infiniband/core/user_mad.c
@@ -47,6 +47,7 @@
47#include <linux/kref.h> 47#include <linux/kref.h>
48#include <linux/compat.h> 48#include <linux/compat.h>
49#include <linux/semaphore.h> 49#include <linux/semaphore.h>
50#include <linux/smp_lock.h>
50 51
51#include <asm/uaccess.h> 52#include <asm/uaccess.h>
52 53
@@ -783,14 +784,17 @@ static int ib_umad_open(struct inode *inode, struct file *filp)
783 struct ib_umad_file *file; 784 struct ib_umad_file *file;
784 int ret = 0; 785 int ret = 0;
785 786
787 lock_kernel();
786 spin_lock(&port_lock); 788 spin_lock(&port_lock);
787 port = umad_port[iminor(inode) - IB_UMAD_MINOR_BASE]; 789 port = umad_port[iminor(inode) - IB_UMAD_MINOR_BASE];
788 if (port) 790 if (port)
789 kref_get(&port->umad_dev->ref); 791 kref_get(&port->umad_dev->ref);
790 spin_unlock(&port_lock); 792 spin_unlock(&port_lock);
791 793
792 if (!port) 794 if (!port) {
795 unlock_kernel();
793 return -ENXIO; 796 return -ENXIO;
797 }
794 798
795 mutex_lock(&port->file_mutex); 799 mutex_lock(&port->file_mutex);
796 800
@@ -819,6 +823,7 @@ static int ib_umad_open(struct inode *inode, struct file *filp)
819 823
820out: 824out:
821 mutex_unlock(&port->file_mutex); 825 mutex_unlock(&port->file_mutex);
826 unlock_kernel();
822 return ret; 827 return ret;
823} 828}
824 829
diff --git a/drivers/infiniband/core/uverbs_main.c b/drivers/infiniband/core/uverbs_main.c
index cc1afa28c181..8ede1e475ce6 100644
--- a/drivers/infiniband/core/uverbs_main.c
+++ b/drivers/infiniband/core/uverbs_main.c
@@ -45,6 +45,7 @@
45#include <linux/file.h> 45#include <linux/file.h>
46#include <linux/mount.h> 46#include <linux/mount.h>
47#include <linux/cdev.h> 47#include <linux/cdev.h>
48#include <linux/smp_lock.h>
48 49
49#include <asm/uaccess.h> 50#include <asm/uaccess.h>
50 51
@@ -616,14 +617,17 @@ static int ib_uverbs_open(struct inode *inode, struct file *filp)
616 struct ib_uverbs_file *file; 617 struct ib_uverbs_file *file;
617 int ret; 618 int ret;
618 619
620 lock_kernel();
619 spin_lock(&map_lock); 621 spin_lock(&map_lock);
620 dev = dev_table[iminor(inode) - IB_UVERBS_BASE_MINOR]; 622 dev = dev_table[iminor(inode) - IB_UVERBS_BASE_MINOR];
621 if (dev) 623 if (dev)
622 kref_get(&dev->ref); 624 kref_get(&dev->ref);
623 spin_unlock(&map_lock); 625 spin_unlock(&map_lock);
624 626
625 if (!dev) 627 if (!dev) {
628 unlock_kernel();
626 return -ENXIO; 629 return -ENXIO;
630 }
627 631
628 if (!try_module_get(dev->ib_dev->owner)) { 632 if (!try_module_get(dev->ib_dev->owner)) {
629 ret = -ENODEV; 633 ret = -ENODEV;
@@ -644,6 +648,7 @@ static int ib_uverbs_open(struct inode *inode, struct file *filp)
644 648
645 filp->private_data = file; 649 filp->private_data = file;
646 650
651 unlock_kernel();
647 return 0; 652 return 0;
648 653
649err_module: 654err_module:
@@ -651,7 +656,7 @@ err_module:
651 656
652err: 657err:
653 kref_put(&dev->ref, ib_uverbs_release_dev); 658 kref_put(&dev->ref, ib_uverbs_release_dev);
654 659 unlock_kernel();
655 return ret; 660 return ret;
656} 661}
657 662