xref: /freebsd/contrib/ofed/libcxgb4/cxgb4-abi.h (revision 87181516ef48be852d5e5fee53c6e0dbfc62f21e)
1*d6b92ffaSHans Petter Selasky /*
2*d6b92ffaSHans Petter Selasky  * Copyright (c) 2006-2016 Chelsio, Inc. All rights reserved.
3*d6b92ffaSHans Petter Selasky  *
4*d6b92ffaSHans Petter Selasky  * This software is available to you under a choice of one of two
5*d6b92ffaSHans Petter Selasky  * licenses.  You may choose to be licensed under the terms of the GNU
6*d6b92ffaSHans Petter Selasky  * General Public License (GPL) Version 2, available from the file
7*d6b92ffaSHans Petter Selasky  * COPYING in the main directory of this source tree, or the
8*d6b92ffaSHans Petter Selasky  * OpenIB.org BSD license below:
9*d6b92ffaSHans Petter Selasky  *
10*d6b92ffaSHans Petter Selasky  *     Redistribution and use in source and binary forms, with or
11*d6b92ffaSHans Petter Selasky  *     without modification, are permitted provided that the following
12*d6b92ffaSHans Petter Selasky  *     conditions are met:
13*d6b92ffaSHans Petter Selasky  *
14*d6b92ffaSHans Petter Selasky  *      - Redistributions of source code must retain the above
15*d6b92ffaSHans Petter Selasky  *        copyright notice, this list of conditions and the following
16*d6b92ffaSHans Petter Selasky  *        disclaimer.
17*d6b92ffaSHans Petter Selasky  *
18*d6b92ffaSHans Petter Selasky  *      - Redistributions in binary form must reproduce the above
19*d6b92ffaSHans Petter Selasky  *        copyright notice, this list of conditions and the following
20*d6b92ffaSHans Petter Selasky  *        disclaimer in the documentation and/or other materials
21*d6b92ffaSHans Petter Selasky  *        provided with the distribution.
22*d6b92ffaSHans Petter Selasky  *
23*d6b92ffaSHans Petter Selasky  * THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND,
24*d6b92ffaSHans Petter Selasky  * EXPRESS OR IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF
25*d6b92ffaSHans Petter Selasky  * MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE AND
26*d6b92ffaSHans Petter Selasky  * NONINFRINGEMENT. IN NO EVENT SHALL THE AUTHORS OR COPYRIGHT HOLDERS
27*d6b92ffaSHans Petter Selasky  * BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER LIABILITY, WHETHER IN AN
28*d6b92ffaSHans Petter Selasky  * ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM, OUT OF OR IN
29*d6b92ffaSHans Petter Selasky  * CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE
30*d6b92ffaSHans Petter Selasky  * SOFTWARE.
31*d6b92ffaSHans Petter Selasky  */
32*d6b92ffaSHans Petter Selasky #ifndef IWCH_ABI_H
33*d6b92ffaSHans Petter Selasky #define IWCH_ABI_H
34*d6b92ffaSHans Petter Selasky 
35*d6b92ffaSHans Petter Selasky #include <stdint.h>
36*d6b92ffaSHans Petter Selasky #include <infiniband/kern-abi.h>
37*d6b92ffaSHans Petter Selasky 
38*d6b92ffaSHans Petter Selasky struct c4iw_alloc_ucontext_resp {
39*d6b92ffaSHans Petter Selasky 	struct ibv_get_context_resp ibv_resp;
40*d6b92ffaSHans Petter Selasky 	__u64 status_page_key;
41*d6b92ffaSHans Petter Selasky 	__u32 status_page_size;
42*d6b92ffaSHans Petter Selasky 	__u32 reserved;
43*d6b92ffaSHans Petter Selasky };
44*d6b92ffaSHans Petter Selasky 
45*d6b92ffaSHans Petter Selasky struct c4iw_alloc_pd_resp {
46*d6b92ffaSHans Petter Selasky 	struct ibv_alloc_pd_resp ibv_resp;
47*d6b92ffaSHans Petter Selasky 	uint32_t pdid;
48*d6b92ffaSHans Petter Selasky };
49*d6b92ffaSHans Petter Selasky 
50*d6b92ffaSHans Petter Selasky struct c4iw_create_cq_resp {
51*d6b92ffaSHans Petter Selasky 	struct ibv_create_cq_resp ibv_resp;
52*d6b92ffaSHans Petter Selasky 	__u64 key;
53*d6b92ffaSHans Petter Selasky 	__u64 gts_key;
54*d6b92ffaSHans Petter Selasky 	__u64 memsize;
55*d6b92ffaSHans Petter Selasky 	__u32 cqid;
56*d6b92ffaSHans Petter Selasky 	__u32 size;
57*d6b92ffaSHans Petter Selasky 	__u32 qid_mask;
58*d6b92ffaSHans Petter Selasky 	__u32 reserved;
59*d6b92ffaSHans Petter Selasky };
60*d6b92ffaSHans Petter Selasky 
61*d6b92ffaSHans Petter Selasky enum {
62*d6b92ffaSHans Petter Selasky 	C4IW_QPF_ONCHIP = (1<<0),
63*d6b92ffaSHans Petter Selasky };
64*d6b92ffaSHans Petter Selasky 
65*d6b92ffaSHans Petter Selasky struct c4iw_create_qp_resp_v0 {
66*d6b92ffaSHans Petter Selasky 	struct ibv_create_qp_resp ibv_resp;
67*d6b92ffaSHans Petter Selasky 	__u64 sq_key;
68*d6b92ffaSHans Petter Selasky 	__u64 rq_key;
69*d6b92ffaSHans Petter Selasky 	__u64 sq_db_gts_key;
70*d6b92ffaSHans Petter Selasky 	__u64 rq_db_gts_key;
71*d6b92ffaSHans Petter Selasky 	__u64 sq_memsize;
72*d6b92ffaSHans Petter Selasky 	__u64 rq_memsize;
73*d6b92ffaSHans Petter Selasky 	__u32 sqid;
74*d6b92ffaSHans Petter Selasky 	__u32 rqid;
75*d6b92ffaSHans Petter Selasky 	__u32 sq_size;
76*d6b92ffaSHans Petter Selasky 	__u32 rq_size;
77*d6b92ffaSHans Petter Selasky 	__u32 qid_mask;
78*d6b92ffaSHans Petter Selasky };
79*d6b92ffaSHans Petter Selasky 
80*d6b92ffaSHans Petter Selasky struct c4iw_create_qp_resp {
81*d6b92ffaSHans Petter Selasky 	struct ibv_create_qp_resp ibv_resp;
82*d6b92ffaSHans Petter Selasky 	__u64 ma_sync_key;
83*d6b92ffaSHans Petter Selasky 	__u64 sq_key;
84*d6b92ffaSHans Petter Selasky 	__u64 rq_key;
85*d6b92ffaSHans Petter Selasky 	__u64 sq_db_gts_key;
86*d6b92ffaSHans Petter Selasky 	__u64 rq_db_gts_key;
87*d6b92ffaSHans Petter Selasky 	__u64 sq_memsize;
88*d6b92ffaSHans Petter Selasky 	__u64 rq_memsize;
89*d6b92ffaSHans Petter Selasky 	__u32 sqid;
90*d6b92ffaSHans Petter Selasky 	__u32 rqid;
91*d6b92ffaSHans Petter Selasky 	__u32 sq_size;
92*d6b92ffaSHans Petter Selasky 	__u32 rq_size;
93*d6b92ffaSHans Petter Selasky 	__u32 qid_mask;
94*d6b92ffaSHans Petter Selasky 	__u32 flags;
95*d6b92ffaSHans Petter Selasky };
96*d6b92ffaSHans Petter Selasky #endif				/* IWCH_ABI_H */
97