/* SPDX-License-Identifier: ((GPL-2.0 WITH Linux-syscall-note) OR BSD-2-Clause) */ /* * Broadcom NetXtreme-E RoCE driver. * * Copyright (c) 2016 - 2017, Broadcom. All rights reserved. The term * Broadcom refers to Broadcom Limited and/or its subsidiaries. * * This software is available to you under a choice of one of two * licenses. You may choose to be licensed under the terms of the GNU * General Public License (GPL) Version 2, available from the file * COPYING in the main directory of this source tree, or the * BSD license below: * * Redistribution and use in source and binary forms, with or without * modification, are permitted provided that the following conditions * are met: * * 1. Redistributions of source code must retain the above copyright * notice, this list of conditions and the following disclaimer. * 2. Redistributions in binary form must reproduce the above copyright * notice, this list of conditions and the following disclaimer in * the documentation and/or other materials provided with the * distribution. * * THIS SOFTWARE IS PROVIDED BY THE AUTHOR AND CONTRIBUTORS ``AS IS'' * AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, * THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR * PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL THE AUTHOR OR CONTRIBUTORS * BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR * CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF * SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR * BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, * WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT (INCLUDING NEGLIGENCE * OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE OF THIS SOFTWARE, EVEN * IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE. * * Description: Uverbs ABI header file */ #ifndef __BNXT_RE_UVERBS_ABI_H__ #define __BNXT_RE_UVERBS_ABI_H__ #include <linux/types.h> #include <rdma/ib_user_ioctl_cmds.h> #define BNXT_RE_ABI_VERSION … #define BNXT_RE_CHIP_ID0_CHIP_NUM_SFT … #define BNXT_RE_CHIP_ID0_CHIP_REV_SFT … #define BNXT_RE_CHIP_ID0_CHIP_MET_SFT … enum { … }; enum bnxt_re_wqe_mode { … }; enum { … }; struct bnxt_re_uctx_req { … }; struct bnxt_re_uctx_resp { … }; /* * This struct is placed after the ib_uverbs_alloc_pd_resp struct, which is * not 8 byted aligned. To avoid undesired padding in various cases we have to * set this struct to packed. */ struct bnxt_re_pd_resp { … } __attribute__((packed, aligned …)); struct bnxt_re_cq_req { … }; enum bnxt_re_cq_mask { … }; struct bnxt_re_cq_resp { … }; struct bnxt_re_resize_cq_req { … }; struct bnxt_re_qp_req { … }; struct bnxt_re_qp_resp { … }; struct bnxt_re_srq_req { … }; struct bnxt_re_srq_resp { … }; enum bnxt_re_shpg_offt { … }; enum bnxt_re_objects { … }; enum bnxt_re_alloc_page_type { … }; enum bnxt_re_var_alloc_page_attrs { … }; enum bnxt_re_alloc_page_attrs { … }; enum bnxt_re_alloc_page_methods { … }; enum bnxt_re_notify_drv_methods { … }; /* Toggle mem */ enum bnxt_re_get_toggle_mem_type { … }; enum bnxt_re_var_toggle_mem_attrs { … }; enum bnxt_re_toggle_mem_attrs { … }; enum bnxt_re_toggle_mem_methods { … }; #endif /* __BNXT_RE_UVERBS_ABI_H__*/