xref: /OK3568_Linux_fs/kernel/drivers/net/ethernet/ibm/ehea/ehea_qmr.h (revision 4882a59341e53eb6f0b4789bf948001014eff981)
1*4882a593Smuzhiyun /* SPDX-License-Identifier: GPL-2.0-or-later */
2*4882a593Smuzhiyun /*
3*4882a593Smuzhiyun  *  linux/drivers/net/ethernet/ibm/ehea/ehea_qmr.h
4*4882a593Smuzhiyun  *
5*4882a593Smuzhiyun  *  eHEA ethernet device driver for IBM eServer System p
6*4882a593Smuzhiyun  *
7*4882a593Smuzhiyun  *  (C) Copyright IBM Corp. 2006
8*4882a593Smuzhiyun  *
9*4882a593Smuzhiyun  *  Authors:
10*4882a593Smuzhiyun  *       Christoph Raisch <raisch@de.ibm.com>
11*4882a593Smuzhiyun  *       Jan-Bernd Themann <themann@de.ibm.com>
12*4882a593Smuzhiyun  *       Thomas Klein <tklein@de.ibm.com>
13*4882a593Smuzhiyun  */
14*4882a593Smuzhiyun 
15*4882a593Smuzhiyun #ifndef __EHEA_QMR_H__
16*4882a593Smuzhiyun #define __EHEA_QMR_H__
17*4882a593Smuzhiyun 
18*4882a593Smuzhiyun #include <linux/prefetch.h>
19*4882a593Smuzhiyun #include "ehea.h"
20*4882a593Smuzhiyun #include "ehea_hw.h"
21*4882a593Smuzhiyun 
22*4882a593Smuzhiyun /*
23*4882a593Smuzhiyun  * page size of ehea hardware queues
24*4882a593Smuzhiyun  */
25*4882a593Smuzhiyun 
26*4882a593Smuzhiyun #define EHEA_PAGESHIFT         12
27*4882a593Smuzhiyun #define EHEA_PAGESIZE          (1UL << EHEA_PAGESHIFT)
28*4882a593Smuzhiyun #define EHEA_SECTSIZE          (1UL << 24)
29*4882a593Smuzhiyun #define EHEA_PAGES_PER_SECTION (EHEA_SECTSIZE >> EHEA_PAGESHIFT)
30*4882a593Smuzhiyun #define EHEA_HUGEPAGESHIFT     34
31*4882a593Smuzhiyun #define EHEA_HUGEPAGE_SIZE     (1UL << EHEA_HUGEPAGESHIFT)
32*4882a593Smuzhiyun #define EHEA_HUGEPAGE_PFN_MASK ((EHEA_HUGEPAGE_SIZE - 1) >> PAGE_SHIFT)
33*4882a593Smuzhiyun 
34*4882a593Smuzhiyun #if ((1UL << SECTION_SIZE_BITS) < EHEA_SECTSIZE)
35*4882a593Smuzhiyun #error eHEA module cannot work if kernel sectionsize < ehea sectionsize
36*4882a593Smuzhiyun #endif
37*4882a593Smuzhiyun 
38*4882a593Smuzhiyun /* Some abbreviations used here:
39*4882a593Smuzhiyun  *
40*4882a593Smuzhiyun  * WQE  - Work Queue Entry
41*4882a593Smuzhiyun  * SWQE - Send Work Queue Entry
42*4882a593Smuzhiyun  * RWQE - Receive Work Queue Entry
43*4882a593Smuzhiyun  * CQE  - Completion Queue Entry
44*4882a593Smuzhiyun  * EQE  - Event Queue Entry
45*4882a593Smuzhiyun  * MR   - Memory Region
46*4882a593Smuzhiyun  */
47*4882a593Smuzhiyun 
48*4882a593Smuzhiyun /* Use of WR_ID field for EHEA */
49*4882a593Smuzhiyun #define EHEA_WR_ID_COUNT   EHEA_BMASK_IBM(0, 19)
50*4882a593Smuzhiyun #define EHEA_WR_ID_TYPE    EHEA_BMASK_IBM(20, 23)
51*4882a593Smuzhiyun #define EHEA_SWQE2_TYPE    0x1
52*4882a593Smuzhiyun #define EHEA_SWQE3_TYPE    0x2
53*4882a593Smuzhiyun #define EHEA_RWQE2_TYPE    0x3
54*4882a593Smuzhiyun #define EHEA_RWQE3_TYPE    0x4
55*4882a593Smuzhiyun #define EHEA_WR_ID_INDEX   EHEA_BMASK_IBM(24, 47)
56*4882a593Smuzhiyun #define EHEA_WR_ID_REFILL  EHEA_BMASK_IBM(48, 63)
57*4882a593Smuzhiyun 
58*4882a593Smuzhiyun struct ehea_vsgentry {
59*4882a593Smuzhiyun 	u64 vaddr;
60*4882a593Smuzhiyun 	u32 l_key;
61*4882a593Smuzhiyun 	u32 len;
62*4882a593Smuzhiyun };
63*4882a593Smuzhiyun 
64*4882a593Smuzhiyun /* maximum number of sg entries allowed in a WQE */
65*4882a593Smuzhiyun #define EHEA_MAX_WQE_SG_ENTRIES  	252
66*4882a593Smuzhiyun #define SWQE2_MAX_IMM            	(0xD0 - 0x30)
67*4882a593Smuzhiyun #define SWQE3_MAX_IMM            	224
68*4882a593Smuzhiyun 
69*4882a593Smuzhiyun /* tx control flags for swqe */
70*4882a593Smuzhiyun #define EHEA_SWQE_CRC                   0x8000
71*4882a593Smuzhiyun #define EHEA_SWQE_IP_CHECKSUM           0x4000
72*4882a593Smuzhiyun #define EHEA_SWQE_TCP_CHECKSUM          0x2000
73*4882a593Smuzhiyun #define EHEA_SWQE_TSO                   0x1000
74*4882a593Smuzhiyun #define EHEA_SWQE_SIGNALLED_COMPLETION  0x0800
75*4882a593Smuzhiyun #define EHEA_SWQE_VLAN_INSERT           0x0400
76*4882a593Smuzhiyun #define EHEA_SWQE_IMM_DATA_PRESENT      0x0200
77*4882a593Smuzhiyun #define EHEA_SWQE_DESCRIPTORS_PRESENT   0x0100
78*4882a593Smuzhiyun #define EHEA_SWQE_WRAP_CTL_REC          0x0080
79*4882a593Smuzhiyun #define EHEA_SWQE_WRAP_CTL_FORCE        0x0040
80*4882a593Smuzhiyun #define EHEA_SWQE_BIND                  0x0020
81*4882a593Smuzhiyun #define EHEA_SWQE_PURGE                 0x0010
82*4882a593Smuzhiyun 
83*4882a593Smuzhiyun /* sizeof(struct ehea_swqe) less the union */
84*4882a593Smuzhiyun #define SWQE_HEADER_SIZE		32
85*4882a593Smuzhiyun 
86*4882a593Smuzhiyun struct ehea_swqe {
87*4882a593Smuzhiyun 	u64 wr_id;
88*4882a593Smuzhiyun 	u16 tx_control;
89*4882a593Smuzhiyun 	u16 vlan_tag;
90*4882a593Smuzhiyun 	u8 reserved1;
91*4882a593Smuzhiyun 	u8 ip_start;
92*4882a593Smuzhiyun 	u8 ip_end;
93*4882a593Smuzhiyun 	u8 immediate_data_length;
94*4882a593Smuzhiyun 	u8 tcp_offset;
95*4882a593Smuzhiyun 	u8 reserved2;
96*4882a593Smuzhiyun 	u16 reserved2b;
97*4882a593Smuzhiyun 	u8 wrap_tag;
98*4882a593Smuzhiyun 	u8 descriptors;		/* number of valid descriptors in WQE */
99*4882a593Smuzhiyun 	u16 reserved3;
100*4882a593Smuzhiyun 	u16 reserved4;
101*4882a593Smuzhiyun 	u16 mss;
102*4882a593Smuzhiyun 	u32 reserved5;
103*4882a593Smuzhiyun 	union {
104*4882a593Smuzhiyun 		/*  Send WQE Format 1 */
105*4882a593Smuzhiyun 		struct {
106*4882a593Smuzhiyun 			struct ehea_vsgentry sg_list[EHEA_MAX_WQE_SG_ENTRIES];
107*4882a593Smuzhiyun 		} no_immediate_data;
108*4882a593Smuzhiyun 
109*4882a593Smuzhiyun 		/*  Send WQE Format 2 */
110*4882a593Smuzhiyun 		struct {
111*4882a593Smuzhiyun 			struct ehea_vsgentry sg_entry;
112*4882a593Smuzhiyun 			/* 0x30 */
113*4882a593Smuzhiyun 			u8 immediate_data[SWQE2_MAX_IMM];
114*4882a593Smuzhiyun 			/* 0xd0 */
115*4882a593Smuzhiyun 			struct ehea_vsgentry sg_list[EHEA_MAX_WQE_SG_ENTRIES-1];
116*4882a593Smuzhiyun 		} immdata_desc __packed;
117*4882a593Smuzhiyun 
118*4882a593Smuzhiyun 		/*  Send WQE Format 3 */
119*4882a593Smuzhiyun 		struct {
120*4882a593Smuzhiyun 			u8 immediate_data[SWQE3_MAX_IMM];
121*4882a593Smuzhiyun 		} immdata_nodesc;
122*4882a593Smuzhiyun 	} u;
123*4882a593Smuzhiyun };
124*4882a593Smuzhiyun 
125*4882a593Smuzhiyun struct ehea_rwqe {
126*4882a593Smuzhiyun 	u64 wr_id;		/* work request ID */
127*4882a593Smuzhiyun 	u8 reserved1[5];
128*4882a593Smuzhiyun 	u8 data_segments;
129*4882a593Smuzhiyun 	u16 reserved2;
130*4882a593Smuzhiyun 	u64 reserved3;
131*4882a593Smuzhiyun 	u64 reserved4;
132*4882a593Smuzhiyun 	struct ehea_vsgentry sg_list[EHEA_MAX_WQE_SG_ENTRIES];
133*4882a593Smuzhiyun };
134*4882a593Smuzhiyun 
135*4882a593Smuzhiyun #define EHEA_CQE_VLAN_TAG_XTRACT   0x0400
136*4882a593Smuzhiyun 
137*4882a593Smuzhiyun #define EHEA_CQE_TYPE_RQ           0x60
138*4882a593Smuzhiyun #define EHEA_CQE_STAT_ERR_MASK     0x700F
139*4882a593Smuzhiyun #define EHEA_CQE_STAT_FAT_ERR_MASK 0xF
140*4882a593Smuzhiyun #define EHEA_CQE_BLIND_CKSUM       0x8000
141*4882a593Smuzhiyun #define EHEA_CQE_STAT_ERR_TCP      0x4000
142*4882a593Smuzhiyun #define EHEA_CQE_STAT_ERR_IP       0x2000
143*4882a593Smuzhiyun #define EHEA_CQE_STAT_ERR_CRC      0x1000
144*4882a593Smuzhiyun 
145*4882a593Smuzhiyun /* Defines which bad send cqe stati lead to a port reset */
146*4882a593Smuzhiyun #define EHEA_CQE_STAT_RESET_MASK   0x0002
147*4882a593Smuzhiyun 
148*4882a593Smuzhiyun struct ehea_cqe {
149*4882a593Smuzhiyun 	u64 wr_id;		/* work request ID from WQE */
150*4882a593Smuzhiyun 	u8 type;
151*4882a593Smuzhiyun 	u8 valid;
152*4882a593Smuzhiyun 	u16 status;
153*4882a593Smuzhiyun 	u16 reserved1;
154*4882a593Smuzhiyun 	u16 num_bytes_transfered;
155*4882a593Smuzhiyun 	u16 vlan_tag;
156*4882a593Smuzhiyun 	u16 inet_checksum_value;
157*4882a593Smuzhiyun 	u8 reserved2;
158*4882a593Smuzhiyun 	u8 header_length;
159*4882a593Smuzhiyun 	u16 reserved3;
160*4882a593Smuzhiyun 	u16 page_offset;
161*4882a593Smuzhiyun 	u16 wqe_count;
162*4882a593Smuzhiyun 	u32 qp_token;
163*4882a593Smuzhiyun 	u32 timestamp;
164*4882a593Smuzhiyun 	u32 reserved4;
165*4882a593Smuzhiyun 	u64 reserved5[3];
166*4882a593Smuzhiyun };
167*4882a593Smuzhiyun 
168*4882a593Smuzhiyun #define EHEA_EQE_VALID           EHEA_BMASK_IBM(0, 0)
169*4882a593Smuzhiyun #define EHEA_EQE_IS_CQE          EHEA_BMASK_IBM(1, 1)
170*4882a593Smuzhiyun #define EHEA_EQE_IDENTIFIER      EHEA_BMASK_IBM(2, 7)
171*4882a593Smuzhiyun #define EHEA_EQE_QP_CQ_NUMBER    EHEA_BMASK_IBM(8, 31)
172*4882a593Smuzhiyun #define EHEA_EQE_QP_TOKEN        EHEA_BMASK_IBM(32, 63)
173*4882a593Smuzhiyun #define EHEA_EQE_CQ_TOKEN        EHEA_BMASK_IBM(32, 63)
174*4882a593Smuzhiyun #define EHEA_EQE_KEY             EHEA_BMASK_IBM(32, 63)
175*4882a593Smuzhiyun #define EHEA_EQE_PORT_NUMBER     EHEA_BMASK_IBM(56, 63)
176*4882a593Smuzhiyun #define EHEA_EQE_EQ_NUMBER       EHEA_BMASK_IBM(48, 63)
177*4882a593Smuzhiyun #define EHEA_EQE_SM_ID           EHEA_BMASK_IBM(48, 63)
178*4882a593Smuzhiyun #define EHEA_EQE_SM_MECH_NUMBER  EHEA_BMASK_IBM(48, 55)
179*4882a593Smuzhiyun #define EHEA_EQE_SM_PORT_NUMBER  EHEA_BMASK_IBM(56, 63)
180*4882a593Smuzhiyun 
181*4882a593Smuzhiyun #define EHEA_AER_RESTYPE_QP  0x8
182*4882a593Smuzhiyun #define EHEA_AER_RESTYPE_CQ  0x4
183*4882a593Smuzhiyun #define EHEA_AER_RESTYPE_EQ  0x3
184*4882a593Smuzhiyun 
185*4882a593Smuzhiyun /* Defines which affiliated errors lead to a port reset */
186*4882a593Smuzhiyun #define EHEA_AER_RESET_MASK   0xFFFFFFFFFEFFFFFFULL
187*4882a593Smuzhiyun #define EHEA_AERR_RESET_MASK  0xFFFFFFFFFFFFFFFFULL
188*4882a593Smuzhiyun 
189*4882a593Smuzhiyun struct ehea_eqe {
190*4882a593Smuzhiyun 	u64 entry;
191*4882a593Smuzhiyun };
192*4882a593Smuzhiyun 
193*4882a593Smuzhiyun #define ERROR_DATA_LENGTH  EHEA_BMASK_IBM(52, 63)
194*4882a593Smuzhiyun #define ERROR_DATA_TYPE    EHEA_BMASK_IBM(0, 7)
195*4882a593Smuzhiyun 
hw_qeit_calc(struct hw_queue * queue,u64 q_offset)196*4882a593Smuzhiyun static inline void *hw_qeit_calc(struct hw_queue *queue, u64 q_offset)
197*4882a593Smuzhiyun {
198*4882a593Smuzhiyun 	struct ehea_page *current_page;
199*4882a593Smuzhiyun 
200*4882a593Smuzhiyun 	if (q_offset >= queue->queue_length)
201*4882a593Smuzhiyun 		q_offset -= queue->queue_length;
202*4882a593Smuzhiyun 	current_page = (queue->queue_pages)[q_offset >> EHEA_PAGESHIFT];
203*4882a593Smuzhiyun 	return &current_page->entries[q_offset & (EHEA_PAGESIZE - 1)];
204*4882a593Smuzhiyun }
205*4882a593Smuzhiyun 
hw_qeit_get(struct hw_queue * queue)206*4882a593Smuzhiyun static inline void *hw_qeit_get(struct hw_queue *queue)
207*4882a593Smuzhiyun {
208*4882a593Smuzhiyun 	return hw_qeit_calc(queue, queue->current_q_offset);
209*4882a593Smuzhiyun }
210*4882a593Smuzhiyun 
hw_qeit_inc(struct hw_queue * queue)211*4882a593Smuzhiyun static inline void hw_qeit_inc(struct hw_queue *queue)
212*4882a593Smuzhiyun {
213*4882a593Smuzhiyun 	queue->current_q_offset += queue->qe_size;
214*4882a593Smuzhiyun 	if (queue->current_q_offset >= queue->queue_length) {
215*4882a593Smuzhiyun 		queue->current_q_offset = 0;
216*4882a593Smuzhiyun 		/* toggle the valid flag */
217*4882a593Smuzhiyun 		queue->toggle_state = (~queue->toggle_state) & 1;
218*4882a593Smuzhiyun 	}
219*4882a593Smuzhiyun }
220*4882a593Smuzhiyun 
hw_qeit_get_inc(struct hw_queue * queue)221*4882a593Smuzhiyun static inline void *hw_qeit_get_inc(struct hw_queue *queue)
222*4882a593Smuzhiyun {
223*4882a593Smuzhiyun 	void *retvalue = hw_qeit_get(queue);
224*4882a593Smuzhiyun 	hw_qeit_inc(queue);
225*4882a593Smuzhiyun 	return retvalue;
226*4882a593Smuzhiyun }
227*4882a593Smuzhiyun 
hw_qeit_get_inc_valid(struct hw_queue * queue)228*4882a593Smuzhiyun static inline void *hw_qeit_get_inc_valid(struct hw_queue *queue)
229*4882a593Smuzhiyun {
230*4882a593Smuzhiyun 	struct ehea_cqe *retvalue = hw_qeit_get(queue);
231*4882a593Smuzhiyun 	u8 valid = retvalue->valid;
232*4882a593Smuzhiyun 	void *pref;
233*4882a593Smuzhiyun 
234*4882a593Smuzhiyun 	if ((valid >> 7) == (queue->toggle_state & 1)) {
235*4882a593Smuzhiyun 		/* this is a good one */
236*4882a593Smuzhiyun 		hw_qeit_inc(queue);
237*4882a593Smuzhiyun 		pref = hw_qeit_calc(queue, queue->current_q_offset);
238*4882a593Smuzhiyun 		prefetch(pref);
239*4882a593Smuzhiyun 		prefetch(pref + 128);
240*4882a593Smuzhiyun 	} else
241*4882a593Smuzhiyun 		retvalue = NULL;
242*4882a593Smuzhiyun 	return retvalue;
243*4882a593Smuzhiyun }
244*4882a593Smuzhiyun 
hw_qeit_get_valid(struct hw_queue * queue)245*4882a593Smuzhiyun static inline void *hw_qeit_get_valid(struct hw_queue *queue)
246*4882a593Smuzhiyun {
247*4882a593Smuzhiyun 	struct ehea_cqe *retvalue = hw_qeit_get(queue);
248*4882a593Smuzhiyun 	void *pref;
249*4882a593Smuzhiyun 	u8 valid;
250*4882a593Smuzhiyun 
251*4882a593Smuzhiyun 	pref = hw_qeit_calc(queue, queue->current_q_offset);
252*4882a593Smuzhiyun 	prefetch(pref);
253*4882a593Smuzhiyun 	prefetch(pref + 128);
254*4882a593Smuzhiyun 	prefetch(pref + 256);
255*4882a593Smuzhiyun 	valid = retvalue->valid;
256*4882a593Smuzhiyun 	if (!((valid >> 7) == (queue->toggle_state & 1)))
257*4882a593Smuzhiyun 		retvalue = NULL;
258*4882a593Smuzhiyun 	return retvalue;
259*4882a593Smuzhiyun }
260*4882a593Smuzhiyun 
hw_qeit_reset(struct hw_queue * queue)261*4882a593Smuzhiyun static inline void *hw_qeit_reset(struct hw_queue *queue)
262*4882a593Smuzhiyun {
263*4882a593Smuzhiyun 	queue->current_q_offset = 0;
264*4882a593Smuzhiyun 	return hw_qeit_get(queue);
265*4882a593Smuzhiyun }
266*4882a593Smuzhiyun 
hw_qeit_eq_get_inc(struct hw_queue * queue)267*4882a593Smuzhiyun static inline void *hw_qeit_eq_get_inc(struct hw_queue *queue)
268*4882a593Smuzhiyun {
269*4882a593Smuzhiyun 	u64 last_entry_in_q = queue->queue_length - queue->qe_size;
270*4882a593Smuzhiyun 	void *retvalue;
271*4882a593Smuzhiyun 
272*4882a593Smuzhiyun 	retvalue = hw_qeit_get(queue);
273*4882a593Smuzhiyun 	queue->current_q_offset += queue->qe_size;
274*4882a593Smuzhiyun 	if (queue->current_q_offset > last_entry_in_q) {
275*4882a593Smuzhiyun 		queue->current_q_offset = 0;
276*4882a593Smuzhiyun 		queue->toggle_state = (~queue->toggle_state) & 1;
277*4882a593Smuzhiyun 	}
278*4882a593Smuzhiyun 	return retvalue;
279*4882a593Smuzhiyun }
280*4882a593Smuzhiyun 
hw_eqit_eq_get_inc_valid(struct hw_queue * queue)281*4882a593Smuzhiyun static inline void *hw_eqit_eq_get_inc_valid(struct hw_queue *queue)
282*4882a593Smuzhiyun {
283*4882a593Smuzhiyun 	void *retvalue = hw_qeit_get(queue);
284*4882a593Smuzhiyun 	u32 qe = *(u8 *)retvalue;
285*4882a593Smuzhiyun 	if ((qe >> 7) == (queue->toggle_state & 1))
286*4882a593Smuzhiyun 		hw_qeit_eq_get_inc(queue);
287*4882a593Smuzhiyun 	else
288*4882a593Smuzhiyun 		retvalue = NULL;
289*4882a593Smuzhiyun 	return retvalue;
290*4882a593Smuzhiyun }
291*4882a593Smuzhiyun 
ehea_get_next_rwqe(struct ehea_qp * qp,int rq_nr)292*4882a593Smuzhiyun static inline struct ehea_rwqe *ehea_get_next_rwqe(struct ehea_qp *qp,
293*4882a593Smuzhiyun 						   int rq_nr)
294*4882a593Smuzhiyun {
295*4882a593Smuzhiyun 	struct hw_queue *queue;
296*4882a593Smuzhiyun 
297*4882a593Smuzhiyun 	if (rq_nr == 1)
298*4882a593Smuzhiyun 		queue = &qp->hw_rqueue1;
299*4882a593Smuzhiyun 	else if (rq_nr == 2)
300*4882a593Smuzhiyun 		queue = &qp->hw_rqueue2;
301*4882a593Smuzhiyun 	else
302*4882a593Smuzhiyun 		queue = &qp->hw_rqueue3;
303*4882a593Smuzhiyun 
304*4882a593Smuzhiyun 	return hw_qeit_get_inc(queue);
305*4882a593Smuzhiyun }
306*4882a593Smuzhiyun 
ehea_get_swqe(struct ehea_qp * my_qp,int * wqe_index)307*4882a593Smuzhiyun static inline struct ehea_swqe *ehea_get_swqe(struct ehea_qp *my_qp,
308*4882a593Smuzhiyun 					      int *wqe_index)
309*4882a593Smuzhiyun {
310*4882a593Smuzhiyun 	struct hw_queue *queue = &my_qp->hw_squeue;
311*4882a593Smuzhiyun 	struct ehea_swqe *wqe_p;
312*4882a593Smuzhiyun 
313*4882a593Smuzhiyun 	*wqe_index = (queue->current_q_offset) >> (7 + EHEA_SG_SQ);
314*4882a593Smuzhiyun 	wqe_p = hw_qeit_get_inc(&my_qp->hw_squeue);
315*4882a593Smuzhiyun 
316*4882a593Smuzhiyun 	return wqe_p;
317*4882a593Smuzhiyun }
318*4882a593Smuzhiyun 
ehea_post_swqe(struct ehea_qp * my_qp,struct ehea_swqe * swqe)319*4882a593Smuzhiyun static inline void ehea_post_swqe(struct ehea_qp *my_qp, struct ehea_swqe *swqe)
320*4882a593Smuzhiyun {
321*4882a593Smuzhiyun 	iosync();
322*4882a593Smuzhiyun 	ehea_update_sqa(my_qp, 1);
323*4882a593Smuzhiyun }
324*4882a593Smuzhiyun 
ehea_poll_rq1(struct ehea_qp * qp,int * wqe_index)325*4882a593Smuzhiyun static inline struct ehea_cqe *ehea_poll_rq1(struct ehea_qp *qp, int *wqe_index)
326*4882a593Smuzhiyun {
327*4882a593Smuzhiyun 	struct hw_queue *queue = &qp->hw_rqueue1;
328*4882a593Smuzhiyun 
329*4882a593Smuzhiyun 	*wqe_index = (queue->current_q_offset) >> (7 + EHEA_SG_RQ1);
330*4882a593Smuzhiyun 	return hw_qeit_get_valid(queue);
331*4882a593Smuzhiyun }
332*4882a593Smuzhiyun 
ehea_inc_cq(struct ehea_cq * cq)333*4882a593Smuzhiyun static inline void ehea_inc_cq(struct ehea_cq *cq)
334*4882a593Smuzhiyun {
335*4882a593Smuzhiyun 	hw_qeit_inc(&cq->hw_queue);
336*4882a593Smuzhiyun }
337*4882a593Smuzhiyun 
ehea_inc_rq1(struct ehea_qp * qp)338*4882a593Smuzhiyun static inline void ehea_inc_rq1(struct ehea_qp *qp)
339*4882a593Smuzhiyun {
340*4882a593Smuzhiyun 	hw_qeit_inc(&qp->hw_rqueue1);
341*4882a593Smuzhiyun }
342*4882a593Smuzhiyun 
ehea_poll_cq(struct ehea_cq * my_cq)343*4882a593Smuzhiyun static inline struct ehea_cqe *ehea_poll_cq(struct ehea_cq *my_cq)
344*4882a593Smuzhiyun {
345*4882a593Smuzhiyun 	return hw_qeit_get_valid(&my_cq->hw_queue);
346*4882a593Smuzhiyun }
347*4882a593Smuzhiyun 
348*4882a593Smuzhiyun #define EHEA_CQ_REGISTER_ORIG 0
349*4882a593Smuzhiyun #define EHEA_EQ_REGISTER_ORIG 0
350*4882a593Smuzhiyun 
351*4882a593Smuzhiyun enum ehea_eq_type {
352*4882a593Smuzhiyun 	EHEA_EQ = 0,		/* event queue              */
353*4882a593Smuzhiyun 	EHEA_NEQ		/* notification event queue */
354*4882a593Smuzhiyun };
355*4882a593Smuzhiyun 
356*4882a593Smuzhiyun struct ehea_eq *ehea_create_eq(struct ehea_adapter *adapter,
357*4882a593Smuzhiyun 			       enum ehea_eq_type type,
358*4882a593Smuzhiyun 			       const u32 length, const u8 eqe_gen);
359*4882a593Smuzhiyun 
360*4882a593Smuzhiyun int ehea_destroy_eq(struct ehea_eq *eq);
361*4882a593Smuzhiyun 
362*4882a593Smuzhiyun struct ehea_eqe *ehea_poll_eq(struct ehea_eq *eq);
363*4882a593Smuzhiyun 
364*4882a593Smuzhiyun struct ehea_cq *ehea_create_cq(struct ehea_adapter *adapter, int cqe,
365*4882a593Smuzhiyun 			       u64 eq_handle, u32 cq_token);
366*4882a593Smuzhiyun 
367*4882a593Smuzhiyun int ehea_destroy_cq(struct ehea_cq *cq);
368*4882a593Smuzhiyun 
369*4882a593Smuzhiyun struct ehea_qp *ehea_create_qp(struct ehea_adapter *adapter, u32 pd,
370*4882a593Smuzhiyun 			       struct ehea_qp_init_attr *init_attr);
371*4882a593Smuzhiyun 
372*4882a593Smuzhiyun int ehea_destroy_qp(struct ehea_qp *qp);
373*4882a593Smuzhiyun 
374*4882a593Smuzhiyun int ehea_reg_kernel_mr(struct ehea_adapter *adapter, struct ehea_mr *mr);
375*4882a593Smuzhiyun 
376*4882a593Smuzhiyun int ehea_gen_smr(struct ehea_adapter *adapter, struct ehea_mr *old_mr,
377*4882a593Smuzhiyun 		 struct ehea_mr *shared_mr);
378*4882a593Smuzhiyun 
379*4882a593Smuzhiyun int ehea_rem_mr(struct ehea_mr *mr);
380*4882a593Smuzhiyun 
381*4882a593Smuzhiyun u64 ehea_error_data(struct ehea_adapter *adapter, u64 res_handle,
382*4882a593Smuzhiyun 		    u64 *aer, u64 *aerr);
383*4882a593Smuzhiyun 
384*4882a593Smuzhiyun int ehea_add_sect_bmap(unsigned long pfn, unsigned long nr_pages);
385*4882a593Smuzhiyun int ehea_rem_sect_bmap(unsigned long pfn, unsigned long nr_pages);
386*4882a593Smuzhiyun int ehea_create_busmap(void);
387*4882a593Smuzhiyun void ehea_destroy_busmap(void);
388*4882a593Smuzhiyun u64 ehea_map_vaddr(void *caddr);
389*4882a593Smuzhiyun 
390*4882a593Smuzhiyun #endif	/* __EHEA_QMR_H__ */
391