 7605e12a51
			
		
	
	
		7605e12a51
		
	
	
	
	
		
			
			Import the headers used by the pvrdma device. Part of them are interfaces between the guest driver and the device, imported under include/standart-headers/drivers/infiniband/... . Signed-off-by: Marcel Apfelbaum <marcel@redhat.com> Signed-off-by: Yuval Shaia <yuval.shaia@oracle.com>
		
			
				
	
	
		
			384 lines
		
	
	
		
			9.8 KiB
		
	
	
	
		
			C
		
	
	
	
	
	
			
		
		
	
	
			384 lines
		
	
	
		
			9.8 KiB
		
	
	
	
		
			C
		
	
	
	
	
	
| /*
 | |
|  * Copyright (c) 2012-2016 VMware, Inc.  All rights reserved.
 | |
|  *
 | |
|  * This program is free software; you can redistribute it and/or
 | |
|  * modify it under the terms of EITHER the GNU General Public License
 | |
|  * version 2 as published by the Free Software Foundation or the BSD
 | |
|  * 2-Clause License. This program is distributed in the hope that it
 | |
|  * will be useful, but WITHOUT ANY WARRANTY; WITHOUT EVEN THE IMPLIED
 | |
|  * WARRANTY OF MERCHANTABILITY OR FITNESS FOR A PARTICULAR PURPOSE.
 | |
|  * See the GNU General Public License version 2 for more details at
 | |
|  * http://www.gnu.org/licenses/old-licenses/gpl-2.0.en.html.
 | |
|  *
 | |
|  * You should have received a copy of the GNU General Public License
 | |
|  * along with this program available in the file COPYING in the main
 | |
|  * directory of this source tree.
 | |
|  *
 | |
|  * The BSD 2-Clause License
 | |
|  *
 | |
|  *     Redistribution and use in source and binary forms, with or
 | |
|  *     without modification, are permitted provided that the following
 | |
|  *     conditions are met:
 | |
|  *
 | |
|  *      - Redistributions of source code must retain the above
 | |
|  *        copyright notice, this list of conditions and the following
 | |
|  *        disclaimer.
 | |
|  *
 | |
|  *      - 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 COPYRIGHT HOLDERS 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
 | |
|  * COPYRIGHT HOLDER 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.
 | |
|  */
 | |
| 
 | |
| #ifndef __PVRDMA_VERBS_H__
 | |
| #define __PVRDMA_VERBS_H__
 | |
| 
 | |
| #include "standard-headers/linux/types.h"
 | |
| 
 | |
| union pvrdma_gid {
 | |
| 	uint8_t	raw[16];
 | |
| 	struct {
 | |
| 		uint64_t	subnet_prefix;
 | |
| 		uint64_t	interface_id;
 | |
| 	} global;
 | |
| };
 | |
| 
 | |
| enum pvrdma_link_layer {
 | |
| 	PVRDMA_LINK_LAYER_UNSPECIFIED,
 | |
| 	PVRDMA_LINK_LAYER_INFINIBAND,
 | |
| 	PVRDMA_LINK_LAYER_ETHERNET,
 | |
| };
 | |
| 
 | |
| enum pvrdma_mtu {
 | |
| 	PVRDMA_MTU_256  = 1,
 | |
| 	PVRDMA_MTU_512  = 2,
 | |
| 	PVRDMA_MTU_1024 = 3,
 | |
| 	PVRDMA_MTU_2048 = 4,
 | |
| 	PVRDMA_MTU_4096 = 5,
 | |
| };
 | |
| 
 | |
| static inline int pvrdma_mtu_enum_to_int(enum pvrdma_mtu mtu)
 | |
| {
 | |
| 	switch (mtu) {
 | |
| 	case PVRDMA_MTU_256:	return  256;
 | |
| 	case PVRDMA_MTU_512:	return  512;
 | |
| 	case PVRDMA_MTU_1024:	return 1024;
 | |
| 	case PVRDMA_MTU_2048:	return 2048;
 | |
| 	case PVRDMA_MTU_4096:	return 4096;
 | |
| 	default:		return   -1;
 | |
| 	}
 | |
| }
 | |
| 
 | |
| static inline enum pvrdma_mtu pvrdma_mtu_int_to_enum(int mtu)
 | |
| {
 | |
| 	switch (mtu) {
 | |
| 	case 256:	return PVRDMA_MTU_256;
 | |
| 	case 512:	return PVRDMA_MTU_512;
 | |
| 	case 1024:	return PVRDMA_MTU_1024;
 | |
| 	case 2048:	return PVRDMA_MTU_2048;
 | |
| 	case 4096:
 | |
| 	default:	return PVRDMA_MTU_4096;
 | |
| 	}
 | |
| }
 | |
| 
 | |
| enum pvrdma_port_state {
 | |
| 	PVRDMA_PORT_NOP			= 0,
 | |
| 	PVRDMA_PORT_DOWN		= 1,
 | |
| 	PVRDMA_PORT_INIT		= 2,
 | |
| 	PVRDMA_PORT_ARMED		= 3,
 | |
| 	PVRDMA_PORT_ACTIVE		= 4,
 | |
| 	PVRDMA_PORT_ACTIVE_DEFER	= 5,
 | |
| };
 | |
| 
 | |
| enum pvrdma_port_cap_flags {
 | |
| 	PVRDMA_PORT_SM				= 1 <<  1,
 | |
| 	PVRDMA_PORT_NOTICE_SUP			= 1 <<  2,
 | |
| 	PVRDMA_PORT_TRAP_SUP			= 1 <<  3,
 | |
| 	PVRDMA_PORT_OPT_IPD_SUP			= 1 <<  4,
 | |
| 	PVRDMA_PORT_AUTO_MIGR_SUP		= 1 <<  5,
 | |
| 	PVRDMA_PORT_SL_MAP_SUP			= 1 <<  6,
 | |
| 	PVRDMA_PORT_MKEY_NVRAM			= 1 <<  7,
 | |
| 	PVRDMA_PORT_PKEY_NVRAM			= 1 <<  8,
 | |
| 	PVRDMA_PORT_LED_INFO_SUP		= 1 <<  9,
 | |
| 	PVRDMA_PORT_SM_DISABLED			= 1 << 10,
 | |
| 	PVRDMA_PORT_SYS_IMAGE_GUID_SUP		= 1 << 11,
 | |
| 	PVRDMA_PORT_PKEY_SW_EXT_PORT_TRAP_SUP	= 1 << 12,
 | |
| 	PVRDMA_PORT_EXTENDED_SPEEDS_SUP		= 1 << 14,
 | |
| 	PVRDMA_PORT_CM_SUP			= 1 << 16,
 | |
| 	PVRDMA_PORT_SNMP_TUNNEL_SUP		= 1 << 17,
 | |
| 	PVRDMA_PORT_REINIT_SUP			= 1 << 18,
 | |
| 	PVRDMA_PORT_DEVICE_MGMT_SUP		= 1 << 19,
 | |
| 	PVRDMA_PORT_VENDOR_CLASS_SUP		= 1 << 20,
 | |
| 	PVRDMA_PORT_DR_NOTICE_SUP		= 1 << 21,
 | |
| 	PVRDMA_PORT_CAP_MASK_NOTICE_SUP		= 1 << 22,
 | |
| 	PVRDMA_PORT_BOOT_MGMT_SUP		= 1 << 23,
 | |
| 	PVRDMA_PORT_LINK_LATENCY_SUP		= 1 << 24,
 | |
| 	PVRDMA_PORT_CLIENT_REG_SUP		= 1 << 25,
 | |
| 	PVRDMA_PORT_IP_BASED_GIDS		= 1 << 26,
 | |
| 	PVRDMA_PORT_CAP_FLAGS_MAX		= PVRDMA_PORT_IP_BASED_GIDS,
 | |
| };
 | |
| 
 | |
| enum pvrdma_port_width {
 | |
| 	PVRDMA_WIDTH_1X		= 1,
 | |
| 	PVRDMA_WIDTH_4X		= 2,
 | |
| 	PVRDMA_WIDTH_8X		= 4,
 | |
| 	PVRDMA_WIDTH_12X	= 8,
 | |
| };
 | |
| 
 | |
| static inline int pvrdma_width_enum_to_int(enum pvrdma_port_width width)
 | |
| {
 | |
| 	switch (width) {
 | |
| 	case PVRDMA_WIDTH_1X:	return  1;
 | |
| 	case PVRDMA_WIDTH_4X:	return  4;
 | |
| 	case PVRDMA_WIDTH_8X:	return  8;
 | |
| 	case PVRDMA_WIDTH_12X:	return 12;
 | |
| 	default:		return -1;
 | |
| 	}
 | |
| }
 | |
| 
 | |
| enum pvrdma_port_speed {
 | |
| 	PVRDMA_SPEED_SDR	= 1,
 | |
| 	PVRDMA_SPEED_DDR	= 2,
 | |
| 	PVRDMA_SPEED_QDR	= 4,
 | |
| 	PVRDMA_SPEED_FDR10	= 8,
 | |
| 	PVRDMA_SPEED_FDR	= 16,
 | |
| 	PVRDMA_SPEED_EDR	= 32,
 | |
| };
 | |
| 
 | |
| struct pvrdma_port_attr {
 | |
| 	enum pvrdma_port_state	state;
 | |
| 	enum pvrdma_mtu		max_mtu;
 | |
| 	enum pvrdma_mtu		active_mtu;
 | |
| 	uint32_t			gid_tbl_len;
 | |
| 	uint32_t			port_cap_flags;
 | |
| 	uint32_t			max_msg_sz;
 | |
| 	uint32_t			bad_pkey_cntr;
 | |
| 	uint32_t			qkey_viol_cntr;
 | |
| 	uint16_t			pkey_tbl_len;
 | |
| 	uint16_t			lid;
 | |
| 	uint16_t			sm_lid;
 | |
| 	uint8_t			lmc;
 | |
| 	uint8_t			max_vl_num;
 | |
| 	uint8_t			sm_sl;
 | |
| 	uint8_t			subnet_timeout;
 | |
| 	uint8_t			init_type_reply;
 | |
| 	uint8_t			active_width;
 | |
| 	uint8_t			active_speed;
 | |
| 	uint8_t			phys_state;
 | |
| 	uint8_t			reserved[2];
 | |
| };
 | |
| 
 | |
| struct pvrdma_global_route {
 | |
| 	union pvrdma_gid	dgid;
 | |
| 	uint32_t			flow_label;
 | |
| 	uint8_t			sgid_index;
 | |
| 	uint8_t			hop_limit;
 | |
| 	uint8_t			traffic_class;
 | |
| 	uint8_t			reserved;
 | |
| };
 | |
| 
 | |
| struct pvrdma_grh {
 | |
| 	uint32_t			version_tclass_flow;
 | |
| 	uint16_t			paylen;
 | |
| 	uint8_t			next_hdr;
 | |
| 	uint8_t			hop_limit;
 | |
| 	union pvrdma_gid	sgid;
 | |
| 	union pvrdma_gid	dgid;
 | |
| };
 | |
| 
 | |
| enum pvrdma_ah_flags {
 | |
| 	PVRDMA_AH_GRH = 1,
 | |
| };
 | |
| 
 | |
| enum pvrdma_rate {
 | |
| 	PVRDMA_RATE_PORT_CURRENT	= 0,
 | |
| 	PVRDMA_RATE_2_5_GBPS		= 2,
 | |
| 	PVRDMA_RATE_5_GBPS		= 5,
 | |
| 	PVRDMA_RATE_10_GBPS		= 3,
 | |
| 	PVRDMA_RATE_20_GBPS		= 6,
 | |
| 	PVRDMA_RATE_30_GBPS		= 4,
 | |
| 	PVRDMA_RATE_40_GBPS		= 7,
 | |
| 	PVRDMA_RATE_60_GBPS		= 8,
 | |
| 	PVRDMA_RATE_80_GBPS		= 9,
 | |
| 	PVRDMA_RATE_120_GBPS		= 10,
 | |
| 	PVRDMA_RATE_14_GBPS		= 11,
 | |
| 	PVRDMA_RATE_56_GBPS		= 12,
 | |
| 	PVRDMA_RATE_112_GBPS		= 13,
 | |
| 	PVRDMA_RATE_168_GBPS		= 14,
 | |
| 	PVRDMA_RATE_25_GBPS		= 15,
 | |
| 	PVRDMA_RATE_100_GBPS		= 16,
 | |
| 	PVRDMA_RATE_200_GBPS		= 17,
 | |
| 	PVRDMA_RATE_300_GBPS		= 18,
 | |
| };
 | |
| 
 | |
| struct pvrdma_ah_attr {
 | |
| 	struct pvrdma_global_route	grh;
 | |
| 	uint16_t				dlid;
 | |
| 	uint16_t				vlan_id;
 | |
| 	uint8_t				sl;
 | |
| 	uint8_t				src_path_bits;
 | |
| 	uint8_t				static_rate;
 | |
| 	uint8_t				ah_flags;
 | |
| 	uint8_t				port_num;
 | |
| 	uint8_t				dmac[6];
 | |
| 	uint8_t				reserved;
 | |
| };
 | |
| 
 | |
| enum pvrdma_cq_notify_flags {
 | |
| 	PVRDMA_CQ_SOLICITED		= 1 << 0,
 | |
| 	PVRDMA_CQ_NEXT_COMP		= 1 << 1,
 | |
| 	PVRDMA_CQ_SOLICITED_MASK	= PVRDMA_CQ_SOLICITED |
 | |
| 					  PVRDMA_CQ_NEXT_COMP,
 | |
| 	PVRDMA_CQ_REPORT_MISSED_EVENTS	= 1 << 2,
 | |
| };
 | |
| 
 | |
| struct pvrdma_qp_cap {
 | |
| 	uint32_t	max_send_wr;
 | |
| 	uint32_t	max_recv_wr;
 | |
| 	uint32_t	max_send_sge;
 | |
| 	uint32_t	max_recv_sge;
 | |
| 	uint32_t	max_inline_data;
 | |
| 	uint32_t	reserved;
 | |
| };
 | |
| 
 | |
| enum pvrdma_sig_type {
 | |
| 	PVRDMA_SIGNAL_ALL_WR,
 | |
| 	PVRDMA_SIGNAL_REQ_WR,
 | |
| };
 | |
| 
 | |
| enum pvrdma_qp_type {
 | |
| 	PVRDMA_QPT_SMI,
 | |
| 	PVRDMA_QPT_GSI,
 | |
| 	PVRDMA_QPT_RC,
 | |
| 	PVRDMA_QPT_UC,
 | |
| 	PVRDMA_QPT_UD,
 | |
| 	PVRDMA_QPT_RAW_IPV6,
 | |
| 	PVRDMA_QPT_RAW_ETHERTYPE,
 | |
| 	PVRDMA_QPT_RAW_PACKET = 8,
 | |
| 	PVRDMA_QPT_XRC_INI = 9,
 | |
| 	PVRDMA_QPT_XRC_TGT,
 | |
| 	PVRDMA_QPT_MAX,
 | |
| };
 | |
| 
 | |
| enum pvrdma_qp_create_flags {
 | |
| 	PVRDMA_QP_CREATE_IPOPVRDMA_UD_LSO		= 1 << 0,
 | |
| 	PVRDMA_QP_CREATE_BLOCK_MULTICAST_LOOPBACK	= 1 << 1,
 | |
| };
 | |
| 
 | |
| enum pvrdma_qp_attr_mask {
 | |
| 	PVRDMA_QP_STATE			= 1 << 0,
 | |
| 	PVRDMA_QP_CUR_STATE		= 1 << 1,
 | |
| 	PVRDMA_QP_EN_SQD_ASYNC_NOTIFY	= 1 << 2,
 | |
| 	PVRDMA_QP_ACCESS_FLAGS		= 1 << 3,
 | |
| 	PVRDMA_QP_PKEY_INDEX		= 1 << 4,
 | |
| 	PVRDMA_QP_PORT			= 1 << 5,
 | |
| 	PVRDMA_QP_QKEY			= 1 << 6,
 | |
| 	PVRDMA_QP_AV			= 1 << 7,
 | |
| 	PVRDMA_QP_PATH_MTU		= 1 << 8,
 | |
| 	PVRDMA_QP_TIMEOUT		= 1 << 9,
 | |
| 	PVRDMA_QP_RETRY_CNT		= 1 << 10,
 | |
| 	PVRDMA_QP_RNR_RETRY		= 1 << 11,
 | |
| 	PVRDMA_QP_RQ_PSN		= 1 << 12,
 | |
| 	PVRDMA_QP_MAX_QP_RD_ATOMIC	= 1 << 13,
 | |
| 	PVRDMA_QP_ALT_PATH		= 1 << 14,
 | |
| 	PVRDMA_QP_MIN_RNR_TIMER		= 1 << 15,
 | |
| 	PVRDMA_QP_SQ_PSN		= 1 << 16,
 | |
| 	PVRDMA_QP_MAX_DEST_RD_ATOMIC	= 1 << 17,
 | |
| 	PVRDMA_QP_PATH_MIG_STATE	= 1 << 18,
 | |
| 	PVRDMA_QP_CAP			= 1 << 19,
 | |
| 	PVRDMA_QP_DEST_QPN		= 1 << 20,
 | |
| 	PVRDMA_QP_ATTR_MASK_MAX		= PVRDMA_QP_DEST_QPN,
 | |
| };
 | |
| 
 | |
| enum pvrdma_qp_state {
 | |
| 	PVRDMA_QPS_RESET,
 | |
| 	PVRDMA_QPS_INIT,
 | |
| 	PVRDMA_QPS_RTR,
 | |
| 	PVRDMA_QPS_RTS,
 | |
| 	PVRDMA_QPS_SQD,
 | |
| 	PVRDMA_QPS_SQE,
 | |
| 	PVRDMA_QPS_ERR,
 | |
| };
 | |
| 
 | |
| enum pvrdma_mig_state {
 | |
| 	PVRDMA_MIG_MIGRATED,
 | |
| 	PVRDMA_MIG_REARM,
 | |
| 	PVRDMA_MIG_ARMED,
 | |
| };
 | |
| 
 | |
| enum pvrdma_mw_type {
 | |
| 	PVRDMA_MW_TYPE_1 = 1,
 | |
| 	PVRDMA_MW_TYPE_2 = 2,
 | |
| };
 | |
| 
 | |
| struct pvrdma_srq_attr {
 | |
| 	uint32_t			max_wr;
 | |
| 	uint32_t			max_sge;
 | |
| 	uint32_t			srq_limit;
 | |
| 	uint32_t			reserved;
 | |
| };
 | |
| 
 | |
| struct pvrdma_qp_attr {
 | |
| 	enum pvrdma_qp_state	qp_state;
 | |
| 	enum pvrdma_qp_state	cur_qp_state;
 | |
| 	enum pvrdma_mtu		path_mtu;
 | |
| 	enum pvrdma_mig_state	path_mig_state;
 | |
| 	uint32_t			qkey;
 | |
| 	uint32_t			rq_psn;
 | |
| 	uint32_t			sq_psn;
 | |
| 	uint32_t			dest_qp_num;
 | |
| 	uint32_t			qp_access_flags;
 | |
| 	uint16_t			pkey_index;
 | |
| 	uint16_t			alt_pkey_index;
 | |
| 	uint8_t			en_sqd_async_notify;
 | |
| 	uint8_t			sq_draining;
 | |
| 	uint8_t			max_rd_atomic;
 | |
| 	uint8_t			max_dest_rd_atomic;
 | |
| 	uint8_t			min_rnr_timer;
 | |
| 	uint8_t			port_num;
 | |
| 	uint8_t			timeout;
 | |
| 	uint8_t			retry_cnt;
 | |
| 	uint8_t			rnr_retry;
 | |
| 	uint8_t			alt_port_num;
 | |
| 	uint8_t			alt_timeout;
 | |
| 	uint8_t			reserved[5];
 | |
| 	struct pvrdma_qp_cap	cap;
 | |
| 	struct pvrdma_ah_attr	ah_attr;
 | |
| 	struct pvrdma_ah_attr	alt_ah_attr;
 | |
| };
 | |
| 
 | |
| enum pvrdma_send_flags {
 | |
| 	PVRDMA_SEND_FENCE	= 1 << 0,
 | |
| 	PVRDMA_SEND_SIGNALED	= 1 << 1,
 | |
| 	PVRDMA_SEND_SOLICITED	= 1 << 2,
 | |
| 	PVRDMA_SEND_INLINE	= 1 << 3,
 | |
| 	PVRDMA_SEND_IP_CSUM	= 1 << 4,
 | |
| 	PVRDMA_SEND_FLAGS_MAX	= PVRDMA_SEND_IP_CSUM,
 | |
| };
 | |
| 
 | |
| enum pvrdma_access_flags {
 | |
| 	PVRDMA_ACCESS_LOCAL_WRITE	= 1 << 0,
 | |
| 	PVRDMA_ACCESS_REMOTE_WRITE	= 1 << 1,
 | |
| 	PVRDMA_ACCESS_REMOTE_READ	= 1 << 2,
 | |
| 	PVRDMA_ACCESS_REMOTE_ATOMIC	= 1 << 3,
 | |
| 	PVRDMA_ACCESS_MW_BIND		= 1 << 4,
 | |
| 	PVRDMA_ZERO_BASED		= 1 << 5,
 | |
| 	PVRDMA_ACCESS_ON_DEMAND		= 1 << 6,
 | |
| 	PVRDMA_ACCESS_FLAGS_MAX		= PVRDMA_ACCESS_ON_DEMAND,
 | |
| };
 | |
| 
 | |
| #endif /* __PVRDMA_VERBS_H__ */
 |