1cdcd52d4SBartosz Sobczak /*- 2cdcd52d4SBartosz Sobczak * SPDX-License-Identifier: GPL-2.0 or Linux-OpenIB 3cdcd52d4SBartosz Sobczak * 4777e472cSBartosz Sobczak * Copyright (C) 2019 - 2022 Intel Corporation 5cdcd52d4SBartosz Sobczak * 6cdcd52d4SBartosz Sobczak * This software is available to you under a choice of one of two 7cdcd52d4SBartosz Sobczak * licenses. You may choose to be licensed under the terms of the GNU 8cdcd52d4SBartosz Sobczak * General Public License (GPL) Version 2, available from the file 9cdcd52d4SBartosz Sobczak * COPYING in the main directory of this source tree, or the 10cdcd52d4SBartosz Sobczak * OpenFabrics.org BSD license below: 11cdcd52d4SBartosz Sobczak * 12cdcd52d4SBartosz Sobczak * Redistribution and use in source and binary forms, with or 13cdcd52d4SBartosz Sobczak * without modification, are permitted provided that the following 14cdcd52d4SBartosz Sobczak * conditions are met: 15cdcd52d4SBartosz Sobczak * 16cdcd52d4SBartosz Sobczak * - Redistributions of source code must retain the above 17cdcd52d4SBartosz Sobczak * copyright notice, this list of conditions and the following 18cdcd52d4SBartosz Sobczak * disclaimer. 19cdcd52d4SBartosz Sobczak * 20cdcd52d4SBartosz Sobczak * - Redistributions in binary form must reproduce the above 21cdcd52d4SBartosz Sobczak * copyright notice, this list of conditions and the following 22cdcd52d4SBartosz Sobczak * disclaimer in the documentation and/or other materials 23cdcd52d4SBartosz Sobczak * provided with the distribution. 24cdcd52d4SBartosz Sobczak * 25cdcd52d4SBartosz Sobczak * THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, 26cdcd52d4SBartosz Sobczak * EXPRESS OR IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF 27cdcd52d4SBartosz Sobczak * MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE AND 28cdcd52d4SBartosz Sobczak * NONINFRINGEMENT. IN NO EVENT SHALL THE AUTHORS OR COPYRIGHT HOLDERS 29cdcd52d4SBartosz Sobczak * BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER LIABILITY, WHETHER IN AN 30cdcd52d4SBartosz Sobczak * ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM, OUT OF OR IN 31cdcd52d4SBartosz Sobczak * CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE 32cdcd52d4SBartosz Sobczak * SOFTWARE. 33cdcd52d4SBartosz Sobczak */ 34cdcd52d4SBartosz Sobczak 35cdcd52d4SBartosz Sobczak #ifndef IRDMA_UMAIN_H 36cdcd52d4SBartosz Sobczak #define IRDMA_UMAIN_H 37cdcd52d4SBartosz Sobczak 38cdcd52d4SBartosz Sobczak #include <sys/queue.h> 39cdcd52d4SBartosz Sobczak #include <infiniband/verbs.h> 40cdcd52d4SBartosz Sobczak #include <infiniband/driver.h> 41cdcd52d4SBartosz Sobczak 42cdcd52d4SBartosz Sobczak #include "osdep.h" 43cdcd52d4SBartosz Sobczak #include "irdma.h" 44cdcd52d4SBartosz Sobczak #include "irdma_defs.h" 45cdcd52d4SBartosz Sobczak #include "i40iw_hw.h" 46cdcd52d4SBartosz Sobczak #include "irdma_user.h" 47cdcd52d4SBartosz Sobczak 48cdcd52d4SBartosz Sobczak #define PFX "libirdma-" 49cdcd52d4SBartosz Sobczak 50cdcd52d4SBartosz Sobczak #define IRDMA_BASE_PUSH_PAGE 1 51cdcd52d4SBartosz Sobczak #define IRDMA_U_MINCQ_SIZE 4 52cdcd52d4SBartosz Sobczak #define IRDMA_DB_SHADOW_AREA_SIZE 64 53cdcd52d4SBartosz Sobczak #define IRDMA_DB_CQ_OFFSET 64 54cdcd52d4SBartosz Sobczak 55cdcd52d4SBartosz Sobczak LIST_HEAD(list_head, irdma_cq_buf); 56cdcd52d4SBartosz Sobczak LIST_HEAD(list_head_cmpl, irdma_cmpl_gen); 57cdcd52d4SBartosz Sobczak 58777e472cSBartosz Sobczak enum irdma_supported_wc_flags_ex { 59777e472cSBartosz Sobczak IRDMA_STANDARD_WC_FLAGS_EX = IBV_WC_EX_WITH_BYTE_LEN 60cdcd52d4SBartosz Sobczak | IBV_WC_EX_WITH_IMM 61cdcd52d4SBartosz Sobczak | IBV_WC_EX_WITH_QP_NUM 62cdcd52d4SBartosz Sobczak | IBV_WC_EX_WITH_SRC_QP 63777e472cSBartosz Sobczak | IBV_WC_EX_WITH_SL, 64cdcd52d4SBartosz Sobczak }; 65cdcd52d4SBartosz Sobczak 66cdcd52d4SBartosz Sobczak struct irdma_udevice { 67cdcd52d4SBartosz Sobczak struct verbs_device ibv_dev; 68cdcd52d4SBartosz Sobczak }; 69cdcd52d4SBartosz Sobczak 70cdcd52d4SBartosz Sobczak struct irdma_uah { 71cdcd52d4SBartosz Sobczak struct ibv_ah ibv_ah; 72cdcd52d4SBartosz Sobczak uint32_t ah_id; 73cdcd52d4SBartosz Sobczak struct ibv_global_route grh; 74cdcd52d4SBartosz Sobczak }; 75cdcd52d4SBartosz Sobczak 76cdcd52d4SBartosz Sobczak struct irdma_upd { 77cdcd52d4SBartosz Sobczak struct ibv_pd ibv_pd; 78cdcd52d4SBartosz Sobczak void *arm_cq_page; 79cdcd52d4SBartosz Sobczak void *arm_cq; 80cdcd52d4SBartosz Sobczak uint32_t pd_id; 81cdcd52d4SBartosz Sobczak }; 82cdcd52d4SBartosz Sobczak 83cdcd52d4SBartosz Sobczak struct irdma_uvcontext { 84cdcd52d4SBartosz Sobczak struct ibv_context ibv_ctx; 85cdcd52d4SBartosz Sobczak struct irdma_upd *iwupd; 86cdcd52d4SBartosz Sobczak struct irdma_uk_attrs uk_attrs; 87cdcd52d4SBartosz Sobczak void *db; 88cdcd52d4SBartosz Sobczak int abi_ver; 89*35105900SBartosz Sobczak bool legacy_mode:1; 90*35105900SBartosz Sobczak bool use_raw_attrs:1; 91cdcd52d4SBartosz Sobczak }; 92cdcd52d4SBartosz Sobczak 93cdcd52d4SBartosz Sobczak struct irdma_uqp; 94cdcd52d4SBartosz Sobczak 95cdcd52d4SBartosz Sobczak struct irdma_cq_buf { 96cdcd52d4SBartosz Sobczak LIST_ENTRY(irdma_cq_buf) list; 97cdcd52d4SBartosz Sobczak struct irdma_cq_uk cq; 98cdcd52d4SBartosz Sobczak struct verbs_mr vmr; 99cdcd52d4SBartosz Sobczak }; 100cdcd52d4SBartosz Sobczak 101777e472cSBartosz Sobczak extern pthread_mutex_t sigusr1_wait_mutex; 102777e472cSBartosz Sobczak 103cdcd52d4SBartosz Sobczak struct verbs_cq { 104cdcd52d4SBartosz Sobczak union { 105cdcd52d4SBartosz Sobczak struct ibv_cq cq; 106cdcd52d4SBartosz Sobczak struct ibv_cq_ex cq_ex; 107cdcd52d4SBartosz Sobczak }; 108cdcd52d4SBartosz Sobczak }; 109cdcd52d4SBartosz Sobczak 110cdcd52d4SBartosz Sobczak struct irdma_ucq { 111cdcd52d4SBartosz Sobczak struct verbs_cq verbs_cq; 112cdcd52d4SBartosz Sobczak struct verbs_mr vmr; 113cdcd52d4SBartosz Sobczak struct verbs_mr vmr_shadow_area; 114cdcd52d4SBartosz Sobczak pthread_spinlock_t lock; 115cdcd52d4SBartosz Sobczak size_t buf_size; 116cdcd52d4SBartosz Sobczak bool is_armed; 117cdcd52d4SBartosz Sobczak bool skip_arm; 118cdcd52d4SBartosz Sobczak bool arm_sol; 119cdcd52d4SBartosz Sobczak bool skip_sol; 120cdcd52d4SBartosz Sobczak int comp_vector; 121cdcd52d4SBartosz Sobczak struct irdma_uqp *uqp; 122cdcd52d4SBartosz Sobczak struct irdma_cq_uk cq; 123cdcd52d4SBartosz Sobczak struct list_head resize_list; 124cdcd52d4SBartosz Sobczak /* for extended CQ completion fields */ 125cdcd52d4SBartosz Sobczak struct irdma_cq_poll_info cur_cqe; 126cdcd52d4SBartosz Sobczak }; 127cdcd52d4SBartosz Sobczak 128cdcd52d4SBartosz Sobczak struct irdma_uqp { 129cdcd52d4SBartosz Sobczak struct ibv_qp ibv_qp; 130cdcd52d4SBartosz Sobczak struct irdma_ucq *send_cq; 131cdcd52d4SBartosz Sobczak struct irdma_ucq *recv_cq; 132cdcd52d4SBartosz Sobczak struct verbs_mr vmr; 133cdcd52d4SBartosz Sobczak size_t buf_size; 134cdcd52d4SBartosz Sobczak uint32_t irdma_drv_opt; 135cdcd52d4SBartosz Sobczak pthread_spinlock_t lock; 136cdcd52d4SBartosz Sobczak uint16_t sq_sig_all; 137cdcd52d4SBartosz Sobczak uint16_t qperr; 138cdcd52d4SBartosz Sobczak uint16_t rsvd; 139cdcd52d4SBartosz Sobczak uint32_t pending_rcvs; 140cdcd52d4SBartosz Sobczak uint32_t wq_size; 141cdcd52d4SBartosz Sobczak struct ibv_recv_wr *pend_rx_wr; 142cdcd52d4SBartosz Sobczak struct irdma_qp_uk qp; 143cdcd52d4SBartosz Sobczak enum ibv_qp_type qp_type; 144cdcd52d4SBartosz Sobczak }; 145cdcd52d4SBartosz Sobczak 146cdcd52d4SBartosz Sobczak /* irdma_uverbs.c */ 147cdcd52d4SBartosz Sobczak int irdma_uquery_device_ex(struct ibv_context *context, 148cdcd52d4SBartosz Sobczak const struct ibv_query_device_ex_input *input, 149cdcd52d4SBartosz Sobczak struct ibv_device_attr_ex *attr, size_t attr_size); 150cdcd52d4SBartosz Sobczak int irdma_uquery_port(struct ibv_context *context, uint8_t port, 151cdcd52d4SBartosz Sobczak struct ibv_port_attr *attr); 152cdcd52d4SBartosz Sobczak struct ibv_pd *irdma_ualloc_pd(struct ibv_context *context); 153cdcd52d4SBartosz Sobczak int irdma_ufree_pd(struct ibv_pd *pd); 154cdcd52d4SBartosz Sobczak int irdma_uquery_device(struct ibv_context *, struct ibv_device_attr *); 155cdcd52d4SBartosz Sobczak struct ibv_mr *irdma_ureg_mr(struct ibv_pd *pd, void *addr, size_t length, 156cdcd52d4SBartosz Sobczak int access); 157cdcd52d4SBartosz Sobczak int irdma_udereg_mr(struct ibv_mr *mr); 158777e472cSBartosz Sobczak 159777e472cSBartosz Sobczak int irdma_urereg_mr(struct verbs_mr *mr, int flags, struct ibv_pd *pd, void *addr, 160777e472cSBartosz Sobczak size_t length, int access); 161777e472cSBartosz Sobczak 162cdcd52d4SBartosz Sobczak struct ibv_mw *irdma_ualloc_mw(struct ibv_pd *pd, enum ibv_mw_type type); 163cdcd52d4SBartosz Sobczak int irdma_ubind_mw(struct ibv_qp *qp, struct ibv_mw *mw, 164cdcd52d4SBartosz Sobczak struct ibv_mw_bind *mw_bind); 165cdcd52d4SBartosz Sobczak int irdma_udealloc_mw(struct ibv_mw *mw); 166cdcd52d4SBartosz Sobczak struct ibv_cq *irdma_ucreate_cq(struct ibv_context *context, int cqe, 167cdcd52d4SBartosz Sobczak struct ibv_comp_channel *channel, 168cdcd52d4SBartosz Sobczak int comp_vector); 169cdcd52d4SBartosz Sobczak struct ibv_cq_ex *irdma_ucreate_cq_ex(struct ibv_context *context, 170cdcd52d4SBartosz Sobczak struct ibv_cq_init_attr_ex *attr_ex); 171cdcd52d4SBartosz Sobczak void irdma_ibvcq_ex_fill_priv_funcs(struct irdma_ucq *iwucq, 172cdcd52d4SBartosz Sobczak struct ibv_cq_init_attr_ex *attr_ex); 173cdcd52d4SBartosz Sobczak int irdma_uresize_cq(struct ibv_cq *cq, int cqe); 174cdcd52d4SBartosz Sobczak int irdma_udestroy_cq(struct ibv_cq *cq); 175cdcd52d4SBartosz Sobczak int irdma_upoll_cq(struct ibv_cq *cq, int entries, struct ibv_wc *entry); 176cdcd52d4SBartosz Sobczak int irdma_uarm_cq(struct ibv_cq *cq, int solicited); 177cdcd52d4SBartosz Sobczak void irdma_cq_event(struct ibv_cq *cq); 178cdcd52d4SBartosz Sobczak struct ibv_qp *irdma_ucreate_qp(struct ibv_pd *pd, 179cdcd52d4SBartosz Sobczak struct ibv_qp_init_attr *attr); 180cdcd52d4SBartosz Sobczak int irdma_uquery_qp(struct ibv_qp *qp, struct ibv_qp_attr *attr, int attr_mask, 181cdcd52d4SBartosz Sobczak struct ibv_qp_init_attr *init_attr); 182cdcd52d4SBartosz Sobczak int irdma_umodify_qp(struct ibv_qp *qp, struct ibv_qp_attr *attr, 183cdcd52d4SBartosz Sobczak int attr_mask); 184cdcd52d4SBartosz Sobczak int irdma_udestroy_qp(struct ibv_qp *qp); 185cdcd52d4SBartosz Sobczak int irdma_upost_send(struct ibv_qp *ib_qp, struct ibv_send_wr *ib_wr, 186cdcd52d4SBartosz Sobczak struct ibv_send_wr **bad_wr); 187cdcd52d4SBartosz Sobczak int irdma_upost_recv(struct ibv_qp *ib_qp, struct ibv_recv_wr *ib_wr, 188cdcd52d4SBartosz Sobczak struct ibv_recv_wr **bad_wr); 189cdcd52d4SBartosz Sobczak struct ibv_ah *irdma_ucreate_ah(struct ibv_pd *ibpd, struct ibv_ah_attr *attr); 190cdcd52d4SBartosz Sobczak int irdma_udestroy_ah(struct ibv_ah *ibah); 191cdcd52d4SBartosz Sobczak int irdma_uattach_mcast(struct ibv_qp *qp, const union ibv_gid *gid, 192cdcd52d4SBartosz Sobczak uint16_t lid); 193cdcd52d4SBartosz Sobczak int irdma_udetach_mcast(struct ibv_qp *qp, const union ibv_gid *gid, 194cdcd52d4SBartosz Sobczak uint16_t lid); 195cdcd52d4SBartosz Sobczak void irdma_async_event(struct ibv_context *context, 196cdcd52d4SBartosz Sobczak struct ibv_async_event *event); 197cdcd52d4SBartosz Sobczak void irdma_set_hw_attrs(struct irdma_hw_attrs *attrs); 198cdcd52d4SBartosz Sobczak void *irdma_mmap(int fd, off_t offset); 199cdcd52d4SBartosz Sobczak void irdma_munmap(void *map); 200cdcd52d4SBartosz Sobczak #endif /* IRDMA_UMAIN_H */ 201