2018-04-20 09:49:10 -06:00
/* SPDX-License-Identifier: ((GPL-2.0 WITH Linux-syscall-note) OR Linux-OpenIB) */
2016-07-21 19:06:38 +08:00
/*
* Copyright ( c ) 2016 Hisilicon Limited .
*
* 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 .
*/
2016-10-19 20:13:07 +03:00
# ifndef HNS_ABI_USER_H
# define HNS_ABI_USER_H
# include <linux/types.h>
2016-07-21 19:06:38 +08:00
struct hns_roce_ib_create_cq {
2018-03-20 14:19:51 -06:00
__aligned_u64 buf_addr ;
__aligned_u64 db_addr ;
2018-03-09 18:36:30 +08:00
} ;
struct hns_roce_ib_create_cq_resp {
2018-03-20 14:19:51 -06:00
__aligned_u64 cqn ; /* Only 32 bits used, 64 for compat */
__aligned_u64 cap_flags ;
2016-07-21 19:06:38 +08:00
} ;
2018-11-24 16:49:21 +08:00
struct hns_roce_ib_create_srq {
__aligned_u64 buf_addr ;
__aligned_u64 db_addr ;
__aligned_u64 que_addr ;
} ;
2019-01-23 10:09:27 +08:00
struct hns_roce_ib_create_srq_resp {
__u32 srqn ;
__u32 reserved ;
} ;
2016-07-21 19:06:38 +08:00
struct hns_roce_ib_create_qp {
2018-03-20 14:19:51 -06:00
__aligned_u64 buf_addr ;
__aligned_u64 db_addr ;
2016-07-21 19:06:38 +08:00
__u8 log_sq_bb_count ;
__u8 log_sq_stride ;
__u8 sq_no_prefetch ;
__u8 reserved [ 5 ] ;
2018-08-02 10:38:05 +08:00
__aligned_u64 sdb_addr ;
2016-07-21 19:06:38 +08:00
} ;
2018-03-09 18:36:29 +08:00
struct hns_roce_ib_create_qp_resp {
2018-03-20 14:19:51 -06:00
__aligned_u64 cap_flags ;
2018-03-09 18:36:29 +08:00
} ;
2016-07-21 19:06:38 +08:00
struct hns_roce_ib_alloc_ucontext_resp {
__u32 qp_tab_size ;
2018-03-09 18:36:29 +08:00
__u32 reserved ;
2016-07-21 19:06:38 +08:00
} ;
2018-03-14 14:39:42 -06:00
struct hns_roce_ib_alloc_pd_resp {
__u32 pdn ;
} ;
2016-10-19 20:13:07 +03:00
# endif /* HNS_ABI_USER_H */