blob: 0b7d0124b16cc93228d9e0e287af9de48ef4bcc5 [file] [log] [blame]
Ram Amraniac1b36e2016-10-10 13:15:32 +03001/* QLogic qedr NIC Driver
2 * Copyright (c) 2015-2016 QLogic Corporation
3 *
4 * This software is available to you under a choice of one of two
5 * licenses. You may choose to be licensed under the terms of the GNU
6 * General Public License (GPL) Version 2, available from the file
7 * COPYING in the main directory of this source tree, or the
8 * OpenIB.org BSD license below:
9 *
10 * Redistribution and use in source and binary forms, with or
11 * without modification, are permitted provided that the following
12 * conditions are met:
13 *
14 * - Redistributions of source code must retain the above
15 * copyright notice, this list of conditions and the following
16 * disclaimer.
17 *
18 * - Redistributions in binary form must reproduce the above
19 * copyright notice, this list of conditions and the following
20 * disclaimer in the documentation and /or other materials
21 * provided with the distribution.
22 *
23 * THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND,
24 * EXPRESS OR IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF
25 * MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE AND
26 * NONINFRINGEMENT. IN NO EVENT SHALL THE AUTHORS OR COPYRIGHT HOLDERS
27 * BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER LIABILITY, WHETHER IN AN
28 * ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM, OUT OF OR IN
29 * CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE
30 * SOFTWARE.
31 */
32#ifndef __QEDR_VERBS_H__
33#define __QEDR_VERBS_H__
34
35int qedr_query_device(struct ib_device *ibdev,
36 struct ib_device_attr *attr, struct ib_udata *udata);
37int qedr_query_port(struct ib_device *, u8 port, struct ib_port_attr *props);
38int qedr_modify_port(struct ib_device *, u8 port, int mask,
39 struct ib_port_modify *props);
40
Kalderon, Michale6a38c52017-07-26 14:41:52 +030041int qedr_iw_query_gid(struct ib_device *ibdev, u8 port,
42 int index, union ib_gid *gid);
Ram Amraniac1b36e2016-10-10 13:15:32 +030043
Ram Amrania7efd772016-10-10 13:15:33 +030044int qedr_query_pkey(struct ib_device *, u8 port, u16 index, u16 *pkey);
45
Ram Amraniac1b36e2016-10-10 13:15:32 +030046struct ib_ucontext *qedr_alloc_ucontext(struct ib_device *, struct ib_udata *);
47int qedr_dealloc_ucontext(struct ib_ucontext *);
48
49int qedr_mmap(struct ib_ucontext *, struct vm_area_struct *vma);
Ram Amrania7efd772016-10-10 13:15:33 +030050struct ib_pd *qedr_alloc_pd(struct ib_device *,
51 struct ib_ucontext *, struct ib_udata *);
52int qedr_dealloc_pd(struct ib_pd *pd);
53
54struct ib_cq *qedr_create_cq(struct ib_device *ibdev,
55 const struct ib_cq_init_attr *attr,
56 struct ib_ucontext *ib_ctx,
57 struct ib_udata *udata);
58int qedr_resize_cq(struct ib_cq *, int cqe, struct ib_udata *);
59int qedr_destroy_cq(struct ib_cq *);
60int qedr_arm_cq(struct ib_cq *ibcq, enum ib_cq_notify_flags flags);
Ram Amranicecbcdd2016-10-10 13:15:34 +030061struct ib_qp *qedr_create_qp(struct ib_pd *, struct ib_qp_init_attr *attrs,
62 struct ib_udata *);
63int qedr_modify_qp(struct ib_qp *, struct ib_qp_attr *attr,
64 int attr_mask, struct ib_udata *udata);
65int qedr_query_qp(struct ib_qp *, struct ib_qp_attr *qp_attr,
66 int qp_attr_mask, struct ib_qp_init_attr *);
67int qedr_destroy_qp(struct ib_qp *ibqp);
Ram Amrania7efd772016-10-10 13:15:33 +030068
Yuval Bason3491c9e2018-08-09 17:29:37 +030069struct ib_srq *qedr_create_srq(struct ib_pd *ibpd,
70 struct ib_srq_init_attr *attr,
71 struct ib_udata *udata);
72int qedr_modify_srq(struct ib_srq *ibsrq, struct ib_srq_attr *attr,
73 enum ib_srq_attr_mask attr_mask, struct ib_udata *udata);
74int qedr_query_srq(struct ib_srq *ibsrq, struct ib_srq_attr *attr);
75int qedr_destroy_srq(struct ib_srq *ibsrq);
76int qedr_post_srq_recv(struct ib_srq *ibsrq, const struct ib_recv_wr *wr,
77 const struct ib_recv_wr **bad_recv_wr);
Dasaratharaman Chandramouli90898852017-04-29 14:41:18 -040078struct ib_ah *qedr_create_ah(struct ib_pd *ibpd, struct rdma_ah_attr *attr,
Moni Shoua477864c2016-11-23 08:23:24 +020079 struct ib_udata *udata);
Ram Amrani04886772016-10-10 13:15:38 +030080int qedr_destroy_ah(struct ib_ah *ibah);
81
Ram Amranie0290cc2016-10-10 13:15:35 +030082int qedr_dereg_mr(struct ib_mr *);
83struct ib_mr *qedr_get_dma_mr(struct ib_pd *, int acc);
84
85struct ib_mr *qedr_reg_user_mr(struct ib_pd *, u64 start, u64 length,
86 u64 virt, int acc, struct ib_udata *);
87
88int qedr_map_mr_sg(struct ib_mr *ibmr, struct scatterlist *sg,
89 int sg_nents, unsigned int *sg_offset);
90
91struct ib_mr *qedr_alloc_mr(struct ib_pd *pd, enum ib_mr_type mr_type,
92 u32 max_num_sg);
Ram Amraniafa0e132016-10-10 13:15:36 +030093int qedr_poll_cq(struct ib_cq *, int num_entries, struct ib_wc *wc);
Bart Van Assched34ac5c2018-07-18 09:25:32 -070094int qedr_post_send(struct ib_qp *, const struct ib_send_wr *,
95 const struct ib_send_wr **bad_wr);
96int qedr_post_recv(struct ib_qp *, const struct ib_recv_wr *,
97 const struct ib_recv_wr **bad_wr);
Ram Amrani993d1b52016-10-10 13:15:39 +030098int qedr_process_mad(struct ib_device *ibdev, int process_mad_flags,
99 u8 port_num, const struct ib_wc *in_wc,
100 const struct ib_grh *in_grh,
101 const struct ib_mad_hdr *in_mad,
102 size_t in_mad_size, struct ib_mad_hdr *out_mad,
103 size_t *out_mad_size, u16 *out_mad_pkey_index);
104
105int qedr_port_immutable(struct ib_device *ibdev, u8 port_num,
106 struct ib_port_immutable *immutable);
Ram Amraniac1b36e2016-10-10 13:15:32 +0300107#endif