2020-06-29 14:05:08 +03:00
|
|
|
/* SPDX-License-Identifier: (GPL-2.0-only OR BSD-3-Clause) */
|
2016-10-01 21:59:57 +03:00
|
|
|
/* QLogic qed NIC Driver
|
2017-01-01 13:57:00 +02:00
|
|
|
* Copyright (c) 2015-2017 QLogic Corporation
|
2020-06-29 14:05:09 +03:00
|
|
|
* Copyright (c) 2019-2020 Marvell International Ltd.
|
2016-10-01 21:59:57 +03:00
|
|
|
*/
|
2020-06-29 14:05:08 +03:00
|
|
|
|
2016-10-01 21:59:57 +03:00
|
|
|
#ifndef _QED_ROCE_H
|
|
|
|
#define _QED_ROCE_H
|
|
|
|
#include <linux/types.h>
|
|
|
|
#include <linux/slab.h>
|
2016-10-01 21:59:59 +03:00
|
|
|
|
2016-10-13 22:57:02 +03:00
|
|
|
#if IS_ENABLED(CONFIG_QED_RDMA)
|
2017-06-20 16:00:02 +03:00
|
|
|
void qed_roce_dpm_dcbx(struct qed_hwfn *p_hwfn, struct qed_ptt *p_ptt);
|
2016-10-01 21:59:57 +03:00
|
|
|
#else
|
2017-06-20 16:00:02 +03:00
|
|
|
static inline void qed_roce_dpm_dcbx(struct qed_hwfn *p_hwfn,
|
|
|
|
struct qed_ptt *p_ptt) {}
|
2016-10-01 21:59:57 +03:00
|
|
|
#endif
|
2017-06-21 16:22:45 +03:00
|
|
|
|
|
|
|
int qed_roce_setup(struct qed_hwfn *p_hwfn);
|
|
|
|
void qed_roce_stop(struct qed_hwfn *p_hwfn);
|
|
|
|
int qed_roce_init_hw(struct qed_hwfn *p_hwfn, struct qed_ptt *p_ptt);
|
|
|
|
int qed_roce_alloc_cid(struct qed_hwfn *p_hwfn, u16 *cid);
|
|
|
|
int qed_roce_destroy_qp(struct qed_hwfn *p_hwfn, struct qed_rdma_qp *qp);
|
|
|
|
|
|
|
|
int qed_roce_query_qp(struct qed_hwfn *p_hwfn,
|
|
|
|
struct qed_rdma_qp *qp,
|
|
|
|
struct qed_rdma_query_qp_out_params *out_params);
|
|
|
|
|
|
|
|
int qed_roce_modify_qp(struct qed_hwfn *p_hwfn,
|
|
|
|
struct qed_rdma_qp *qp,
|
|
|
|
enum qed_roce_qp_state prev_state,
|
|
|
|
struct qed_rdma_modify_qp_in_params *params);
|
|
|
|
|
2016-10-01 21:59:57 +03:00
|
|
|
#endif
|