162306a36Sopenharmony_ci// SPDX-License-Identifier: GPL-2.0 OR Linux-OpenIB 262306a36Sopenharmony_ci/* 362306a36Sopenharmony_ci * Copyright (c) 2017 Mellanox Technologies Ltd. All rights reserved. 462306a36Sopenharmony_ci */ 562306a36Sopenharmony_ci 662306a36Sopenharmony_ci#include "rxe.h" 762306a36Sopenharmony_ci#include "rxe_hw_counters.h" 862306a36Sopenharmony_ci 962306a36Sopenharmony_cistatic const struct rdma_stat_desc rxe_counter_descs[] = { 1062306a36Sopenharmony_ci [RXE_CNT_SENT_PKTS].name = "sent_pkts", 1162306a36Sopenharmony_ci [RXE_CNT_RCVD_PKTS].name = "rcvd_pkts", 1262306a36Sopenharmony_ci [RXE_CNT_DUP_REQ].name = "duplicate_request", 1362306a36Sopenharmony_ci [RXE_CNT_OUT_OF_SEQ_REQ].name = "out_of_seq_request", 1462306a36Sopenharmony_ci [RXE_CNT_RCV_RNR].name = "rcvd_rnr_err", 1562306a36Sopenharmony_ci [RXE_CNT_SND_RNR].name = "send_rnr_err", 1662306a36Sopenharmony_ci [RXE_CNT_RCV_SEQ_ERR].name = "rcvd_seq_err", 1762306a36Sopenharmony_ci [RXE_CNT_COMPLETER_SCHED].name = "ack_deferred", 1862306a36Sopenharmony_ci [RXE_CNT_RETRY_EXCEEDED].name = "retry_exceeded_err", 1962306a36Sopenharmony_ci [RXE_CNT_RNR_RETRY_EXCEEDED].name = "retry_rnr_exceeded_err", 2062306a36Sopenharmony_ci [RXE_CNT_COMP_RETRY].name = "completer_retry_err", 2162306a36Sopenharmony_ci [RXE_CNT_SEND_ERR].name = "send_err", 2262306a36Sopenharmony_ci [RXE_CNT_LINK_DOWNED].name = "link_downed", 2362306a36Sopenharmony_ci [RXE_CNT_RDMA_SEND].name = "rdma_sends", 2462306a36Sopenharmony_ci [RXE_CNT_RDMA_RECV].name = "rdma_recvs", 2562306a36Sopenharmony_ci}; 2662306a36Sopenharmony_ci 2762306a36Sopenharmony_ciint rxe_ib_get_hw_stats(struct ib_device *ibdev, 2862306a36Sopenharmony_ci struct rdma_hw_stats *stats, 2962306a36Sopenharmony_ci u32 port, int index) 3062306a36Sopenharmony_ci{ 3162306a36Sopenharmony_ci struct rxe_dev *dev = to_rdev(ibdev); 3262306a36Sopenharmony_ci unsigned int cnt; 3362306a36Sopenharmony_ci 3462306a36Sopenharmony_ci if (!port || !stats) 3562306a36Sopenharmony_ci return -EINVAL; 3662306a36Sopenharmony_ci 3762306a36Sopenharmony_ci for (cnt = 0; cnt < ARRAY_SIZE(rxe_counter_descs); cnt++) 3862306a36Sopenharmony_ci stats->value[cnt] = atomic64_read(&dev->stats_counters[cnt]); 3962306a36Sopenharmony_ci 4062306a36Sopenharmony_ci return ARRAY_SIZE(rxe_counter_descs); 4162306a36Sopenharmony_ci} 4262306a36Sopenharmony_ci 4362306a36Sopenharmony_cistruct rdma_hw_stats *rxe_ib_alloc_hw_port_stats(struct ib_device *ibdev, 4462306a36Sopenharmony_ci u32 port_num) 4562306a36Sopenharmony_ci{ 4662306a36Sopenharmony_ci BUILD_BUG_ON(ARRAY_SIZE(rxe_counter_descs) != RXE_NUM_OF_COUNTERS); 4762306a36Sopenharmony_ci 4862306a36Sopenharmony_ci return rdma_alloc_hw_stats_struct(rxe_counter_descs, 4962306a36Sopenharmony_ci ARRAY_SIZE(rxe_counter_descs), 5062306a36Sopenharmony_ci RDMA_HW_STATS_DEFAULT_LIFESPAN); 5162306a36Sopenharmony_ci} 52