]> asedeno.scripts.mit.edu Git - linux.git/commitdiff
RDMA/bnxt_re: Make use of create AH sleepable flag
authorGal Pressman <galpress@amazon.com>
Wed, 12 Dec 2018 09:09:07 +0000 (11:09 +0200)
committerJason Gunthorpe <jgg@mellanox.com>
Wed, 19 Dec 2018 23:28:03 +0000 (16:28 -0700)
When in a sleepable (non-atomic) context, wait for firmware completion
instead of polling for it.

Signed-off-by: Gal Pressman <galpress@amazon.com>
Acked-by: Selvin Xavier <selvin.xavier@broadcom.com>
Signed-off-by: Jason Gunthorpe <jgg@mellanox.com>
drivers/infiniband/hw/bnxt_re/ib_verbs.c
drivers/infiniband/hw/bnxt_re/qplib_sp.c
drivers/infiniband/hw/bnxt_re/qplib_sp.h

index ece45e7aee2031179ad85ea6b66c479709031e9b..7f934c2d90eb559c179d8676f6c5fa7c8d1c2283 100644 (file)
@@ -723,7 +723,8 @@ struct ib_ah *bnxt_re_create_ah(struct ib_pd *ib_pd,
        }
 
        memcpy(ah->qplib_ah.dmac, ah_attr->roce.dmac, ETH_ALEN);
-       rc = bnxt_qplib_create_ah(&rdev->qplib_res, &ah->qplib_ah);
+       rc = bnxt_qplib_create_ah(&rdev->qplib_res, &ah->qplib_ah,
+                                 !(flags & RDMA_CREATE_AH_SLEEPABLE));
        if (rc) {
                dev_err(rdev_to_dev(rdev), "Failed to allocate HW AH");
                goto fail;
@@ -959,7 +960,7 @@ static struct bnxt_re_ah *bnxt_re_create_shadow_qp_ah
        /* Have DMAC same as SMAC */
        ether_addr_copy(ah->qplib_ah.dmac, rdev->netdev->dev_addr);
 
-       rc = bnxt_qplib_create_ah(&rdev->qplib_res, &ah->qplib_ah);
+       rc = bnxt_qplib_create_ah(&rdev->qplib_res, &ah->qplib_ah, false);
        if (rc) {
                dev_err(rdev_to_dev(rdev),
                        "Failed to allocate HW AH for Shadow QP");
index 5216b5f844cc44be4742f76423d86e913a8046d2..8f4b19ea409c0c38935d26f0f876a444cc2cd4ad 100644 (file)
@@ -488,7 +488,8 @@ int bnxt_qplib_add_pkey(struct bnxt_qplib_res *res,
 }
 
 /* AH */
-int bnxt_qplib_create_ah(struct bnxt_qplib_res *res, struct bnxt_qplib_ah *ah)
+int bnxt_qplib_create_ah(struct bnxt_qplib_res *res, struct bnxt_qplib_ah *ah,
+                        bool block)
 {
        struct bnxt_qplib_rcfw *rcfw = res->rcfw;
        struct cmdq_create_ah req;
@@ -522,7 +523,7 @@ int bnxt_qplib_create_ah(struct bnxt_qplib_res *res, struct bnxt_qplib_ah *ah)
        req.dest_mac[2] = cpu_to_le16(temp16[2]);
 
        rc = bnxt_qplib_rcfw_send_message(rcfw, (void *)&req, (void *)&resp,
-                                         NULL, 1);
+                                         NULL, block);
        if (rc)
                return rc;
 
index 8079d7f5a0085b063d827fd57aeca6ddbb084c56..53145aa1e7ffbca357cc99e605b298ccba8437ca 100644 (file)
@@ -241,7 +241,8 @@ int bnxt_qplib_get_dev_attr(struct bnxt_qplib_rcfw *rcfw,
 int bnxt_qplib_set_func_resources(struct bnxt_qplib_res *res,
                                  struct bnxt_qplib_rcfw *rcfw,
                                  struct bnxt_qplib_ctx *ctx);
-int bnxt_qplib_create_ah(struct bnxt_qplib_res *res, struct bnxt_qplib_ah *ah);
+int bnxt_qplib_create_ah(struct bnxt_qplib_res *res, struct bnxt_qplib_ah *ah,
+                        bool block);
 int bnxt_qplib_destroy_ah(struct bnxt_qplib_res *res, struct bnxt_qplib_ah *ah);
 int bnxt_qplib_alloc_mrw(struct bnxt_qplib_res *res,
                         struct bnxt_qplib_mrw *mrw);