RDMA/efa: Add RDMA write HW statistics counters
authorMichael Margolin <mrgolin@amazon.com>
Mon, 3 Jul 2023 15:34:04 +0000 (15:34 +0000)
committerLeon Romanovsky <leon@kernel.org>
Wed, 12 Jul 2023 12:07:32 +0000 (15:07 +0300)
Update device API and request RDMA write counters if RDMA write is
supported by device. Expose newly added counters through ib core
counters mechanism.

Reviewed-by: Daniel Kranzdorf <dkkranzd@amazon.com>
Reviewed-by: Yonatan Nachum <ynachum@amazon.com>
Signed-off-by: Michael Margolin <mrgolin@amazon.com>
Link: https://lore.kernel.org/r/20230703153404.30877-1-mrgolin@amazon.com
Reviewed-by: Gal Pressman <gal.pressman@linux.dev>
Signed-off-by: Leon Romanovsky <leon@kernel.org>
drivers/infiniband/hw/efa/efa_admin_cmds_defs.h
drivers/infiniband/hw/efa/efa_com_cmd.c
drivers/infiniband/hw/efa/efa_com_cmd.h
drivers/infiniband/hw/efa/efa_verbs.c

index 4e93ef7..9c65bd2 100644 (file)
@@ -66,6 +66,7 @@ enum efa_admin_get_stats_type {
        EFA_ADMIN_GET_STATS_TYPE_BASIC              = 0,
        EFA_ADMIN_GET_STATS_TYPE_MESSAGES           = 1,
        EFA_ADMIN_GET_STATS_TYPE_RDMA_READ          = 2,
+       EFA_ADMIN_GET_STATS_TYPE_RDMA_WRITE         = 3,
 };
 
 enum efa_admin_get_stats_scope {
@@ -570,6 +571,16 @@ struct efa_admin_rdma_read_stats {
        u64 read_resp_bytes;
 };
 
+struct efa_admin_rdma_write_stats {
+       u64 write_wrs;
+
+       u64 write_bytes;
+
+       u64 write_wr_err;
+
+       u64 write_recv_bytes;
+};
+
 struct efa_admin_acq_get_stats_resp {
        struct efa_admin_acq_common_desc acq_common_desc;
 
@@ -579,6 +590,8 @@ struct efa_admin_acq_get_stats_resp {
                struct efa_admin_messages_stats messages_stats;
 
                struct efa_admin_rdma_read_stats rdma_read_stats;
+
+               struct efa_admin_rdma_write_stats rdma_write_stats;
        } u;
 };
 
index 8f8885e..5768118 100644 (file)
@@ -1,6 +1,6 @@
 // SPDX-License-Identifier: GPL-2.0 OR BSD-2-Clause
 /*
- * Copyright 2018-2021 Amazon.com, Inc. or its affiliates. All rights reserved.
+ * Copyright 2018-2023 Amazon.com, Inc. or its affiliates. All rights reserved.
  */
 
 #include "efa_com.h"
@@ -794,6 +794,12 @@ int efa_com_get_stats(struct efa_com_dev *edev,
                result->rdma_read_stats.read_wr_err = resp.u.rdma_read_stats.read_wr_err;
                result->rdma_read_stats.read_resp_bytes = resp.u.rdma_read_stats.read_resp_bytes;
                break;
+       case EFA_ADMIN_GET_STATS_TYPE_RDMA_WRITE:
+               result->rdma_write_stats.write_wrs = resp.u.rdma_write_stats.write_wrs;
+               result->rdma_write_stats.write_bytes = resp.u.rdma_write_stats.write_bytes;
+               result->rdma_write_stats.write_wr_err = resp.u.rdma_write_stats.write_wr_err;
+               result->rdma_write_stats.write_recv_bytes = resp.u.rdma_write_stats.write_recv_bytes;
+               break;
        }
 
        return 0;
index 0898ad5..fc97f37 100644 (file)
@@ -1,6 +1,6 @@
 /* SPDX-License-Identifier: GPL-2.0 OR BSD-2-Clause */
 /*
- * Copyright 2018-2021 Amazon.com, Inc. or its affiliates. All rights reserved.
+ * Copyright 2018-2023 Amazon.com, Inc. or its affiliates. All rights reserved.
  */
 
 #ifndef _EFA_COM_CMD_H_
@@ -262,10 +262,18 @@ struct efa_com_rdma_read_stats {
        u64 read_resp_bytes;
 };
 
+struct efa_com_rdma_write_stats {
+       u64 write_wrs;
+       u64 write_bytes;
+       u64 write_wr_err;
+       u64 write_recv_bytes;
+};
+
 union efa_com_get_stats_result {
        struct efa_com_basic_stats basic_stats;
        struct efa_com_messages_stats messages_stats;
        struct efa_com_rdma_read_stats rdma_read_stats;
+       struct efa_com_rdma_write_stats rdma_write_stats;
 };
 
 int efa_com_create_qp(struct efa_com_dev *edev,
index 2a195c4..7a27d79 100644 (file)
@@ -61,6 +61,10 @@ struct efa_user_mmap_entry {
        op(EFA_RDMA_READ_BYTES, "rdma_read_bytes") \
        op(EFA_RDMA_READ_WR_ERR, "rdma_read_wr_err") \
        op(EFA_RDMA_READ_RESP_BYTES, "rdma_read_resp_bytes") \
+       op(EFA_RDMA_WRITE_WRS, "rdma_write_wrs") \
+       op(EFA_RDMA_WRITE_BYTES, "rdma_write_bytes") \
+       op(EFA_RDMA_WRITE_WR_ERR, "rdma_write_wr_err") \
+       op(EFA_RDMA_WRITE_RECV_BYTES, "rdma_write_recv_bytes") \
 
 #define EFA_STATS_ENUM(ename, name) ename,
 #define EFA_STATS_STR(ename, nam) \
@@ -2080,6 +2084,7 @@ static int efa_fill_port_stats(struct efa_dev *dev, struct rdma_hw_stats *stats,
 {
        struct efa_com_get_stats_params params = {};
        union efa_com_get_stats_result result;
+       struct efa_com_rdma_write_stats *rws;
        struct efa_com_rdma_read_stats *rrs;
        struct efa_com_messages_stats *ms;
        struct efa_com_basic_stats *bs;
@@ -2121,6 +2126,19 @@ static int efa_fill_port_stats(struct efa_dev *dev, struct rdma_hw_stats *stats,
        stats->value[EFA_RDMA_READ_WR_ERR] = rrs->read_wr_err;
        stats->value[EFA_RDMA_READ_RESP_BYTES] = rrs->read_resp_bytes;
 
+       if (EFA_DEV_CAP(dev, RDMA_WRITE)) {
+               params.type = EFA_ADMIN_GET_STATS_TYPE_RDMA_WRITE;
+               err = efa_com_get_stats(&dev->edev, &params, &result);
+               if (err)
+                       return err;
+
+               rws = &result.rdma_write_stats;
+               stats->value[EFA_RDMA_WRITE_WRS] = rws->write_wrs;
+               stats->value[EFA_RDMA_WRITE_BYTES] = rws->write_bytes;
+               stats->value[EFA_RDMA_WRITE_WR_ERR] = rws->write_wr_err;
+               stats->value[EFA_RDMA_WRITE_RECV_BYTES] = rws->write_recv_bytes;
+       }
+
        return ARRAY_SIZE(efa_port_stats_descs);
 }