aboutsummaryrefslogtreecommitdiffstats
path: root/drivers/infiniband
diff options
context:
space:
mode:
authorKrishna Kumar <krkumar2@in.ibm.com>2006-10-16 00:39:01 -0400
committerRoland Dreier <rolandd@cisco.com>2006-11-29 18:33:04 -0500
commite82153b54d75af31d5d4a84efe441e5719f34cfc (patch)
treecf4fad6438d0d8affa229af1fd02a754bf88450a /drivers/infiniband
parent0215ffb08ce99e2bb59eca114a99499a4d06e704 (diff)
RDMA/cma: Optimize cma_bind_loopback() to check for empty list
Optimize to test for an empty list first. This ends up simplifying the code too. Signed-off-by: Krishna Kumar <krkumar2@in.ibm.com> Acked-by: Sean Hefty <sean.hefty@intel.com> Signed-off-by: Roland Dreier <rolandd@cisco.com>
Diffstat (limited to 'drivers/infiniband')
-rw-r--r--drivers/infiniband/core/cma.c15
1 files changed, 7 insertions, 8 deletions
diff --git a/drivers/infiniband/core/cma.c b/drivers/infiniband/core/cma.c
index 845090b0859c..4975d8154a78 100644
--- a/drivers/infiniband/core/cma.c
+++ b/drivers/infiniband/core/cma.c
@@ -1481,19 +1481,18 @@ static int cma_bind_loopback(struct rdma_id_private *id_priv)
1481 u8 p; 1481 u8 p;
1482 1482
1483 mutex_lock(&lock); 1483 mutex_lock(&lock);
1484 if (list_empty(&dev_list)) {
1485 ret = -ENODEV;
1486 goto out;
1487 }
1484 list_for_each_entry(cma_dev, &dev_list, list) 1488 list_for_each_entry(cma_dev, &dev_list, list)
1485 for (p = 1; p <= cma_dev->device->phys_port_cnt; ++p) 1489 for (p = 1; p <= cma_dev->device->phys_port_cnt; ++p)
1486 if (!ib_query_port (cma_dev->device, p, &port_attr) && 1490 if (!ib_query_port(cma_dev->device, p, &port_attr) &&
1487 port_attr.state == IB_PORT_ACTIVE) 1491 port_attr.state == IB_PORT_ACTIVE)
1488 goto port_found; 1492 goto port_found;
1489 1493
1490 if (!list_empty(&dev_list)) { 1494 p = 1;
1491 p = 1; 1495 cma_dev = list_entry(dev_list.next, struct cma_device, list);
1492 cma_dev = list_entry(dev_list.next, struct cma_device, list);
1493 } else {
1494 ret = -ENODEV;
1495 goto out;
1496 }
1497 1496
1498port_found: 1497port_found:
1499 ret = ib_get_cached_gid(cma_dev->device, p, 0, &gid); 1498 ret = ib_get_cached_gid(cma_dev->device, p, 0, &gid);