提交 e82153b5 编写于 作者: K Krishna Kumar 提交者: Roland Dreier

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: NKrishna Kumar <krkumar2@in.ibm.com>
Acked-by: NSean Hefty <sean.hefty@intel.com>
Signed-off-by: NRoland Dreier <rolandd@cisco.com>
上级 0215ffb0
...@@ -1481,19 +1481,18 @@ static int cma_bind_loopback(struct rdma_id_private *id_priv) ...@@ -1481,19 +1481,18 @@ static int cma_bind_loopback(struct rdma_id_private *id_priv)
u8 p; u8 p;
mutex_lock(&lock); mutex_lock(&lock);
if (list_empty(&dev_list)) {
ret = -ENODEV;
goto out;
}
list_for_each_entry(cma_dev, &dev_list, list) list_for_each_entry(cma_dev, &dev_list, list)
for (p = 1; p <= cma_dev->device->phys_port_cnt; ++p) for (p = 1; p <= cma_dev->device->phys_port_cnt; ++p)
if (!ib_query_port (cma_dev->device, p, &port_attr) && if (!ib_query_port(cma_dev->device, p, &port_attr) &&
port_attr.state == IB_PORT_ACTIVE) port_attr.state == IB_PORT_ACTIVE)
goto port_found; goto port_found;
if (!list_empty(&dev_list)) {
p = 1; p = 1;
cma_dev = list_entry(dev_list.next, struct cma_device, list); cma_dev = list_entry(dev_list.next, struct cma_device, list);
} else {
ret = -ENODEV;
goto out;
}
port_found: port_found:
ret = ib_get_cached_gid(cma_dev->device, p, 0, &gid); ret = ib_get_cached_gid(cma_dev->device, p, 0, &gid);
......
Markdown is supported
0% .
You are about to add 0 people to the discussion. Proceed with caution.
先完成此消息的编辑!
想要评论请 注册