2018-04-20 09:49:10 -06:00
/* SPDX-License-Identifier: ((GPL-2.0 WITH Linux-syscall-note) OR Linux-OpenIB) */
2016-10-10 13:15:32 +03:00
/* QLogic qedr NIC Driver
* Copyright ( c ) 2015 - 2016 QLogic Corporation
*
* 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
* OpenIB . org BSD license below :
*
* 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 .
*
* THE SOFTWARE IS PROVIDED " AS IS " , WITHOUT WARRANTY OF ANY KIND ,
* EXPRESS OR IMPLIED , INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF
* MERCHANTABILITY , FITNESS FOR A PARTICULAR PURPOSE AND
* NONINFRINGEMENT . IN NO EVENT SHALL THE AUTHORS OR COPYRIGHT HOLDERS
* BE LIABLE FOR ANY CLAIM , DAMAGES OR OTHER LIABILITY , WHETHER IN AN
* ACTION OF CONTRACT , TORT OR OTHERWISE , ARISING FROM , OUT OF OR IN
* CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE
* SOFTWARE .
*/
# ifndef __QEDR_USER_H__
# define __QEDR_USER_H__
# include <linux/types.h>
# define QEDR_ABI_VERSION (8)
/* user kernel communication data structures. */
struct qedr_alloc_ucontext_resp {
2018-03-20 14:19:51 -06:00
__aligned_u64 db_pa ;
2016-10-10 13:15:32 +03:00
__u32 db_size ;
__u32 max_send_wr ;
__u32 max_recv_wr ;
__u32 max_srq_wr ;
__u32 sges_per_send_wr ;
__u32 sges_per_recv_wr ;
__u32 sges_per_srq_wr ;
__u32 max_cqes ;
2017-06-26 19:05:05 +03:00
__u8 dpm_enabled ;
2017-06-26 19:05:06 +03:00
__u8 wids_enabled ;
__u16 wid_count ;
2018-03-20 14:19:48 -06:00
__u32 reserved ;
2016-10-10 13:15:32 +03:00
} ;
2016-10-10 13:15:33 +03:00
struct qedr_alloc_pd_ureq {
2018-03-20 14:19:51 -06:00
__aligned_u64 rsvd1 ;
2016-10-10 13:15:33 +03:00
} ;
struct qedr_alloc_pd_uresp {
__u32 pd_id ;
2018-03-20 14:19:48 -06:00
__u32 reserved ;
2016-10-10 13:15:33 +03:00
} ;
struct qedr_create_cq_ureq {
2018-03-20 14:19:51 -06:00
__aligned_u64 addr ;
__aligned_u64 len ;
2016-10-10 13:15:33 +03:00
} ;
struct qedr_create_cq_uresp {
__u32 db_offset ;
__u16 icid ;
2018-03-20 14:19:48 -06:00
__u16 reserved ;
2016-10-10 13:15:33 +03:00
} ;
2016-10-10 13:15:34 +03:00
struct qedr_create_qp_ureq {
__u32 qp_handle_hi ;
__u32 qp_handle_lo ;
/* SQ */
/* user space virtual address of SQ buffer */
2018-03-20 14:19:51 -06:00
__aligned_u64 sq_addr ;
2016-10-10 13:15:34 +03:00
/* length of SQ buffer */
2018-03-20 14:19:51 -06:00
__aligned_u64 sq_len ;
2016-10-10 13:15:34 +03:00
/* RQ */
/* user space virtual address of RQ buffer */
2018-03-20 14:19:51 -06:00
__aligned_u64 rq_addr ;
2016-10-10 13:15:34 +03:00
/* length of RQ buffer */
2018-03-20 14:19:51 -06:00
__aligned_u64 rq_len ;
2016-10-10 13:15:34 +03:00
} ;
struct qedr_create_qp_uresp {
__u32 qp_id ;
__u32 atomic_supported ;
/* SQ */
__u32 sq_db_offset ;
__u16 sq_icid ;
/* RQ */
__u32 rq_db_offset ;
__u16 rq_icid ;
__u32 rq_db2_offset ;
2018-03-20 14:19:48 -06:00
__u32 reserved ;
2016-10-10 13:15:34 +03:00
} ;
2018-08-09 17:29:38 +03:00
struct qedr_create_srq_ureq {
/* user space virtual address of producer pair */
__aligned_u64 prod_pair_addr ;
/* user space virtual address of SRQ buffer */
__aligned_u64 srq_addr ;
/* length of SRQ buffer */
__aligned_u64 srq_len ;
} ;
struct qedr_create_srq_uresp {
__u16 srq_id ;
__u16 reserved0 ;
__u32 reserved1 ;
} ;
2016-10-10 13:15:32 +03:00
# endif /* __QEDR_USER_H__ */