Ram Amrani | ac1b36e | 2016-10-10 13:15:32 +0300 | [diff] [blame] | 1 | /* 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 | |
| 35 | int qedr_query_device(struct ib_device *ibdev, |
| 36 | struct ib_device_attr *attr, struct ib_udata *udata); |
| 37 | int qedr_query_port(struct ib_device *, u8 port, struct ib_port_attr *props); |
| 38 | int qedr_modify_port(struct ib_device *, u8 port, int mask, |
| 39 | struct ib_port_modify *props); |
| 40 | |
Kalderon, Michal | e6a38c5 | 2017-07-26 14:41:52 +0300 | [diff] [blame] | 41 | int qedr_iw_query_gid(struct ib_device *ibdev, u8 port, |
| 42 | int index, union ib_gid *gid); |
Ram Amrani | ac1b36e | 2016-10-10 13:15:32 +0300 | [diff] [blame] | 43 | |
Ram Amrani | a7efd77 | 2016-10-10 13:15:33 +0300 | [diff] [blame] | 44 | int qedr_query_pkey(struct ib_device *, u8 port, u16 index, u16 *pkey); |
| 45 | |
Ram Amrani | ac1b36e | 2016-10-10 13:15:32 +0300 | [diff] [blame] | 46 | struct ib_ucontext *qedr_alloc_ucontext(struct ib_device *, struct ib_udata *); |
| 47 | int qedr_dealloc_ucontext(struct ib_ucontext *); |
| 48 | |
| 49 | int qedr_mmap(struct ib_ucontext *, struct vm_area_struct *vma); |
Ram Amrani | a7efd77 | 2016-10-10 13:15:33 +0300 | [diff] [blame] | 50 | struct ib_pd *qedr_alloc_pd(struct ib_device *, |
| 51 | struct ib_ucontext *, struct ib_udata *); |
| 52 | int qedr_dealloc_pd(struct ib_pd *pd); |
| 53 | |
| 54 | struct 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); |
| 58 | int qedr_resize_cq(struct ib_cq *, int cqe, struct ib_udata *); |
| 59 | int qedr_destroy_cq(struct ib_cq *); |
| 60 | int qedr_arm_cq(struct ib_cq *ibcq, enum ib_cq_notify_flags flags); |
Ram Amrani | cecbcdd | 2016-10-10 13:15:34 +0300 | [diff] [blame] | 61 | struct ib_qp *qedr_create_qp(struct ib_pd *, struct ib_qp_init_attr *attrs, |
| 62 | struct ib_udata *); |
| 63 | int qedr_modify_qp(struct ib_qp *, struct ib_qp_attr *attr, |
| 64 | int attr_mask, struct ib_udata *udata); |
| 65 | int qedr_query_qp(struct ib_qp *, struct ib_qp_attr *qp_attr, |
| 66 | int qp_attr_mask, struct ib_qp_init_attr *); |
| 67 | int qedr_destroy_qp(struct ib_qp *ibqp); |
Ram Amrani | a7efd77 | 2016-10-10 13:15:33 +0300 | [diff] [blame] | 68 | |
Yuval Bason | 3491c9e | 2018-08-09 17:29:37 +0300 | [diff] [blame] | 69 | struct ib_srq *qedr_create_srq(struct ib_pd *ibpd, |
| 70 | struct ib_srq_init_attr *attr, |
| 71 | struct ib_udata *udata); |
| 72 | int qedr_modify_srq(struct ib_srq *ibsrq, struct ib_srq_attr *attr, |
| 73 | enum ib_srq_attr_mask attr_mask, struct ib_udata *udata); |
| 74 | int qedr_query_srq(struct ib_srq *ibsrq, struct ib_srq_attr *attr); |
| 75 | int qedr_destroy_srq(struct ib_srq *ibsrq); |
| 76 | int qedr_post_srq_recv(struct ib_srq *ibsrq, const struct ib_recv_wr *wr, |
| 77 | const struct ib_recv_wr **bad_recv_wr); |
Dasaratharaman Chandramouli | 9089885 | 2017-04-29 14:41:18 -0400 | [diff] [blame] | 78 | struct ib_ah *qedr_create_ah(struct ib_pd *ibpd, struct rdma_ah_attr *attr, |
Moni Shoua | 477864c | 2016-11-23 08:23:24 +0200 | [diff] [blame] | 79 | struct ib_udata *udata); |
Ram Amrani | 0488677 | 2016-10-10 13:15:38 +0300 | [diff] [blame] | 80 | int qedr_destroy_ah(struct ib_ah *ibah); |
| 81 | |
Ram Amrani | e0290cc | 2016-10-10 13:15:35 +0300 | [diff] [blame] | 82 | int qedr_dereg_mr(struct ib_mr *); |
| 83 | struct ib_mr *qedr_get_dma_mr(struct ib_pd *, int acc); |
| 84 | |
| 85 | struct ib_mr *qedr_reg_user_mr(struct ib_pd *, u64 start, u64 length, |
| 86 | u64 virt, int acc, struct ib_udata *); |
| 87 | |
| 88 | int qedr_map_mr_sg(struct ib_mr *ibmr, struct scatterlist *sg, |
| 89 | int sg_nents, unsigned int *sg_offset); |
| 90 | |
| 91 | struct ib_mr *qedr_alloc_mr(struct ib_pd *pd, enum ib_mr_type mr_type, |
| 92 | u32 max_num_sg); |
Ram Amrani | afa0e13 | 2016-10-10 13:15:36 +0300 | [diff] [blame] | 93 | int qedr_poll_cq(struct ib_cq *, int num_entries, struct ib_wc *wc); |
Bart Van Assche | d34ac5c | 2018-07-18 09:25:32 -0700 | [diff] [blame] | 94 | int qedr_post_send(struct ib_qp *, const struct ib_send_wr *, |
| 95 | const struct ib_send_wr **bad_wr); |
| 96 | int qedr_post_recv(struct ib_qp *, const struct ib_recv_wr *, |
| 97 | const struct ib_recv_wr **bad_wr); |
Ram Amrani | 993d1b5 | 2016-10-10 13:15:39 +0300 | [diff] [blame] | 98 | int 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 | |
| 105 | int qedr_port_immutable(struct ib_device *ibdev, u8 port_num, |
| 106 | struct ib_port_immutable *immutable); |
Ram Amrani | ac1b36e | 2016-10-10 13:15:32 +0300 | [diff] [blame] | 107 | #endif |