162306a36Sopenharmony_ci/* SPDX-License-Identifier: GPL-2.0 OR Linux-OpenIB */
262306a36Sopenharmony_ci/*
362306a36Sopenharmony_ci * Copyright (c) 2019 Mellanox Technologies. All rights reserved.
462306a36Sopenharmony_ci */
562306a36Sopenharmony_ci
662306a36Sopenharmony_ci#ifndef _RDMA_COUNTER_H_
762306a36Sopenharmony_ci#define _RDMA_COUNTER_H_
862306a36Sopenharmony_ci
962306a36Sopenharmony_ci#include <linux/mutex.h>
1062306a36Sopenharmony_ci#include <linux/pid_namespace.h>
1162306a36Sopenharmony_ci
1262306a36Sopenharmony_ci#include <rdma/restrack.h>
1362306a36Sopenharmony_ci#include <rdma/rdma_netlink.h>
1462306a36Sopenharmony_ci
1562306a36Sopenharmony_cistruct ib_device;
1662306a36Sopenharmony_cistruct ib_qp;
1762306a36Sopenharmony_ci
1862306a36Sopenharmony_cistruct auto_mode_param {
1962306a36Sopenharmony_ci	int qp_type;
2062306a36Sopenharmony_ci};
2162306a36Sopenharmony_ci
2262306a36Sopenharmony_cistruct rdma_counter_mode {
2362306a36Sopenharmony_ci	enum rdma_nl_counter_mode mode;
2462306a36Sopenharmony_ci	enum rdma_nl_counter_mask mask;
2562306a36Sopenharmony_ci	struct auto_mode_param param;
2662306a36Sopenharmony_ci};
2762306a36Sopenharmony_ci
2862306a36Sopenharmony_cistruct rdma_port_counter {
2962306a36Sopenharmony_ci	struct rdma_counter_mode mode;
3062306a36Sopenharmony_ci	struct rdma_hw_stats *hstats;
3162306a36Sopenharmony_ci	unsigned int num_counters;
3262306a36Sopenharmony_ci	struct mutex lock;
3362306a36Sopenharmony_ci};
3462306a36Sopenharmony_ci
3562306a36Sopenharmony_cistruct rdma_counter {
3662306a36Sopenharmony_ci	struct rdma_restrack_entry	res;
3762306a36Sopenharmony_ci	struct ib_device		*device;
3862306a36Sopenharmony_ci	uint32_t			id;
3962306a36Sopenharmony_ci	struct kref			kref;
4062306a36Sopenharmony_ci	struct rdma_counter_mode	mode;
4162306a36Sopenharmony_ci	struct mutex			lock;
4262306a36Sopenharmony_ci	struct rdma_hw_stats		*stats;
4362306a36Sopenharmony_ci	u32				port;
4462306a36Sopenharmony_ci};
4562306a36Sopenharmony_ci
4662306a36Sopenharmony_civoid rdma_counter_init(struct ib_device *dev);
4762306a36Sopenharmony_civoid rdma_counter_release(struct ib_device *dev);
4862306a36Sopenharmony_ciint rdma_counter_set_auto_mode(struct ib_device *dev, u32 port,
4962306a36Sopenharmony_ci			       enum rdma_nl_counter_mask mask,
5062306a36Sopenharmony_ci			       struct netlink_ext_ack *extack);
5162306a36Sopenharmony_ciint rdma_counter_bind_qp_auto(struct ib_qp *qp, u32 port);
5262306a36Sopenharmony_ciint rdma_counter_unbind_qp(struct ib_qp *qp, bool force);
5362306a36Sopenharmony_ci
5462306a36Sopenharmony_ciint rdma_counter_query_stats(struct rdma_counter *counter);
5562306a36Sopenharmony_ciu64 rdma_counter_get_hwstat_value(struct ib_device *dev, u32 port, u32 index);
5662306a36Sopenharmony_ciint rdma_counter_bind_qpn(struct ib_device *dev, u32 port,
5762306a36Sopenharmony_ci			  u32 qp_num, u32 counter_id);
5862306a36Sopenharmony_ciint rdma_counter_bind_qpn_alloc(struct ib_device *dev, u32 port,
5962306a36Sopenharmony_ci				u32 qp_num, u32 *counter_id);
6062306a36Sopenharmony_ciint rdma_counter_unbind_qpn(struct ib_device *dev, u32 port,
6162306a36Sopenharmony_ci			    u32 qp_num, u32 counter_id);
6262306a36Sopenharmony_ciint rdma_counter_get_mode(struct ib_device *dev, u32 port,
6362306a36Sopenharmony_ci			  enum rdma_nl_counter_mode *mode,
6462306a36Sopenharmony_ci			  enum rdma_nl_counter_mask *mask);
6562306a36Sopenharmony_ci
6662306a36Sopenharmony_ciint rdma_counter_modify(struct ib_device *dev, u32 port,
6762306a36Sopenharmony_ci			unsigned int index, bool enable);
6862306a36Sopenharmony_ci#endif /* _RDMA_COUNTER_H_ */
69