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 ¤t_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