2 * Copyright (c) 2006, 2007, 2008, 2009 QLogic Corporation. All rights reserved.
3 * Copyright (c) 2005, 2006 PathScale, Inc. All rights reserved.
5 * This software is available to you under a choice of one of two
6 * licenses. You may choose to be licensed under the terms of the GNU
7 * General Public License (GPL) Version 2, available from the file
8 * COPYING in the main directory of this source tree, or the
9 * OpenIB.org BSD license below:
11 * Redistribution and use in source and binary forms, with or
12 * without modification, are permitted provided that the following
15 * - Redistributions of source code must retain the above
16 * copyright notice, this list of conditions and the following
19 * - Redistributions in binary form must reproduce the above
20 * copyright notice, this list of conditions and the following
21 * disclaimer in the documentation and/or other materials
22 * provided with the distribution.
24 * THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND,
25 * EXPRESS OR IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF
26 * MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE AND
27 * NONINFRINGEMENT. IN NO EVENT SHALL THE AUTHORS OR COPYRIGHT HOLDERS
28 * BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER LIABILITY, WHETHER IN AN
29 * ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM, OUT OF OR IN
30 * CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE
34 #include <linux/spinlock.h>
35 #include <rdma/ib_smi.h>
41 * Convert the AETH RNR timeout code into the number of microseconds.
43 const u32 ib_qib_rnr_table
[32] = {
44 655360, /* 00: 655.36 */
64 10240, /* 14: 10.24 */
65 15360, /* 15: 15.36 */
66 20480, /* 16: 20.48 */
67 30720, /* 17: 30.72 */
68 40960, /* 18: 40.96 */
69 61440, /* 19: 61.44 */
70 81920, /* 1A: 81.92 */
71 122880, /* 1B: 122.88 */
72 163840, /* 1C: 163.84 */
73 245760, /* 1D: 245.76 */
74 327680, /* 1E: 327.68 */
75 491520 /* 1F: 491.52 */
79 * Validate a RWQE and fill in the SGE state.
82 static int qib_init_sge(struct qib_qp
*qp
, struct qib_rwqe
*wqe
)
86 struct qib_lkey_table
*rkt
;
88 struct qib_sge_state
*ss
;
90 rkt
= &to_idev(qp
->ibqp
.device
)->lk_table
;
91 pd
= to_ipd(qp
->ibqp
.srq
? qp
->ibqp
.srq
->pd
: qp
->ibqp
.pd
);
93 ss
->sg_list
= qp
->r_sg_list
;
95 for (i
= j
= 0; i
< wqe
->num_sge
; i
++) {
96 if (wqe
->sg_list
[i
].length
== 0)
99 if (!qib_lkey_ok(rkt
, pd
, j
? &ss
->sg_list
[j
- 1] : &ss
->sge
,
100 &wqe
->sg_list
[i
], IB_ACCESS_LOCAL_WRITE
))
102 qp
->r_len
+= wqe
->sg_list
[i
].length
;
106 ss
->total_len
= qp
->r_len
;
112 struct qib_sge
*sge
= --j
? &ss
->sg_list
[j
- 1] : &ss
->sge
;
117 memset(&wc
, 0, sizeof(wc
));
118 wc
.wr_id
= wqe
->wr_id
;
119 wc
.status
= IB_WC_LOC_PROT_ERR
;
120 wc
.opcode
= IB_WC_RECV
;
122 /* Signal solicited completion event. */
123 qib_cq_enter(to_icq(qp
->ibqp
.recv_cq
), &wc
, 1);
130 * qib_get_rwqe - copy the next RWQE into the QP's RWQE
132 * @wr_id_only: update qp->r_wr_id only, not qp->r_sge
134 * Return -1 if there is a local error, 0 if no RWQE is available,
135 * otherwise return 1.
137 * Can be called from interrupt level.
139 int qib_get_rwqe(struct qib_qp
*qp
, int wr_id_only
)
145 struct qib_rwqe
*wqe
;
146 void (*handler
)(struct ib_event
*, void *);
151 srq
= to_isrq(qp
->ibqp
.srq
);
152 handler
= srq
->ibsrq
.event_handler
;
160 spin_lock_irqsave(&rq
->lock
, flags
);
161 if (!(ib_qib_state_ops
[qp
->state
] & QIB_PROCESS_RECV_OK
)) {
168 /* Validate tail before using it since it is user writable. */
169 if (tail
>= rq
->size
)
171 if (unlikely(tail
== wq
->head
)) {
175 /* Make sure entry is read after head index is read. */
177 wqe
= get_rwqe_ptr(rq
, tail
);
179 * Even though we update the tail index in memory, the verbs
180 * consumer is not supposed to post more entries until a
181 * completion is generated.
183 if (++tail
>= rq
->size
)
186 if (!wr_id_only
&& !qib_init_sge(qp
, wqe
)) {
190 qp
->r_wr_id
= wqe
->wr_id
;
193 set_bit(QIB_R_WRID_VALID
, &qp
->r_aflags
);
198 * Validate head pointer value and compute
199 * the number of remaining WQEs.
205 n
+= rq
->size
- tail
;
208 if (n
< srq
->limit
) {
212 spin_unlock_irqrestore(&rq
->lock
, flags
);
213 ev
.device
= qp
->ibqp
.device
;
214 ev
.element
.srq
= qp
->ibqp
.srq
;
215 ev
.event
= IB_EVENT_SRQ_LIMIT_REACHED
;
216 handler(&ev
, srq
->ibsrq
.srq_context
);
221 spin_unlock_irqrestore(&rq
->lock
, flags
);
227 * Switch to alternate path.
228 * The QP s_lock should be held and interrupts disabled.
230 void qib_migrate_qp(struct qib_qp
*qp
)
234 qp
->s_mig_state
= IB_MIG_MIGRATED
;
235 qp
->remote_ah_attr
= qp
->alt_ah_attr
;
236 qp
->port_num
= qp
->alt_ah_attr
.port_num
;
237 qp
->s_pkey_index
= qp
->s_alt_pkey_index
;
239 ev
.device
= qp
->ibqp
.device
;
240 ev
.element
.qp
= &qp
->ibqp
;
241 ev
.event
= IB_EVENT_PATH_MIG
;
242 qp
->ibqp
.event_handler(&ev
, qp
->ibqp
.qp_context
);
245 static __be64
get_sguid(struct qib_ibport
*ibp
, unsigned index
)
248 struct qib_pportdata
*ppd
= ppd_from_ibp(ibp
);
252 return ibp
->guids
[index
- 1];
255 static int gid_ok(union ib_gid
*gid
, __be64 gid_prefix
, __be64 id
)
257 return (gid
->global
.interface_id
== id
&&
258 (gid
->global
.subnet_prefix
== gid_prefix
||
259 gid
->global
.subnet_prefix
== IB_DEFAULT_GID_PREFIX
));
264 * This should be called with the QP r_lock held.
266 * The s_lock will be acquired around the qib_migrate_qp() call.
268 int qib_ruc_check_hdr(struct qib_ibport
*ibp
, struct qib_ib_header
*hdr
,
269 int has_grh
, struct qib_qp
*qp
, u32 bth0
)
274 if (qp
->s_mig_state
== IB_MIG_ARMED
&& (bth0
& IB_BTH_MIG_REQ
)) {
276 if (qp
->alt_ah_attr
.ah_flags
& IB_AH_GRH
)
279 if (!(qp
->alt_ah_attr
.ah_flags
& IB_AH_GRH
))
281 guid
= get_sguid(ibp
, qp
->alt_ah_attr
.grh
.sgid_index
);
282 if (!gid_ok(&hdr
->u
.l
.grh
.dgid
, ibp
->gid_prefix
, guid
))
284 if (!gid_ok(&hdr
->u
.l
.grh
.sgid
,
285 qp
->alt_ah_attr
.grh
.dgid
.global
.subnet_prefix
,
286 qp
->alt_ah_attr
.grh
.dgid
.global
.interface_id
))
289 if (!qib_pkey_ok((u16
)bth0
,
290 qib_get_pkey(ibp
, qp
->s_alt_pkey_index
))) {
291 qib_bad_pqkey(ibp
, IB_NOTICE_TRAP_BAD_PKEY
,
293 (be16_to_cpu(hdr
->lrh
[0]) >> 4) & 0xF,
295 hdr
->lrh
[3], hdr
->lrh
[1]);
298 /* Validate the SLID. See Ch. 9.6.1.5 and 17.2.8 */
299 if (be16_to_cpu(hdr
->lrh
[3]) != qp
->alt_ah_attr
.dlid
||
300 ppd_from_ibp(ibp
)->port
!= qp
->alt_ah_attr
.port_num
)
302 spin_lock_irqsave(&qp
->s_lock
, flags
);
304 spin_unlock_irqrestore(&qp
->s_lock
, flags
);
307 if (qp
->remote_ah_attr
.ah_flags
& IB_AH_GRH
)
310 if (!(qp
->remote_ah_attr
.ah_flags
& IB_AH_GRH
))
312 guid
= get_sguid(ibp
,
313 qp
->remote_ah_attr
.grh
.sgid_index
);
314 if (!gid_ok(&hdr
->u
.l
.grh
.dgid
, ibp
->gid_prefix
, guid
))
316 if (!gid_ok(&hdr
->u
.l
.grh
.sgid
,
317 qp
->remote_ah_attr
.grh
.dgid
.global
.subnet_prefix
,
318 qp
->remote_ah_attr
.grh
.dgid
.global
.interface_id
))
321 if (!qib_pkey_ok((u16
)bth0
,
322 qib_get_pkey(ibp
, qp
->s_pkey_index
))) {
323 qib_bad_pqkey(ibp
, IB_NOTICE_TRAP_BAD_PKEY
,
325 (be16_to_cpu(hdr
->lrh
[0]) >> 4) & 0xF,
327 hdr
->lrh
[3], hdr
->lrh
[1]);
330 /* Validate the SLID. See Ch. 9.6.1.5 */
331 if (be16_to_cpu(hdr
->lrh
[3]) != qp
->remote_ah_attr
.dlid
||
332 ppd_from_ibp(ibp
)->port
!= qp
->port_num
)
334 if (qp
->s_mig_state
== IB_MIG_REARM
&&
335 !(bth0
& IB_BTH_MIG_REQ
))
336 qp
->s_mig_state
= IB_MIG_ARMED
;
346 * qib_ruc_loopback - handle UC and RC lookback requests
347 * @sqp: the sending QP
349 * This is called from qib_do_send() to
350 * forward a WQE addressed to the same HCA.
351 * Note that although we are single threaded due to the tasklet, we still
352 * have to protect against post_send(). We don't have to worry about
353 * receive interrupts since this is a connected protocol and all packets
354 * will pass through here.
356 static void qib_ruc_loopback(struct qib_qp
*sqp
)
358 struct qib_ibport
*ibp
= to_iport(sqp
->ibqp
.device
, sqp
->port_num
);
360 struct qib_swqe
*wqe
;
366 enum ib_wc_status send_status
;
371 * Note that we check the responder QP state after
372 * checking the requester's state.
374 qp
= qib_lookup_qpn(ibp
, sqp
->remote_qpn
);
376 spin_lock_irqsave(&sqp
->s_lock
, flags
);
378 /* Return if we are already busy processing a work request. */
379 if ((sqp
->s_flags
& (QIB_S_BUSY
| QIB_S_ANY_WAIT
)) ||
380 !(ib_qib_state_ops
[sqp
->state
] & QIB_PROCESS_OR_FLUSH_SEND
))
383 sqp
->s_flags
|= QIB_S_BUSY
;
386 if (sqp
->s_last
== sqp
->s_head
)
388 wqe
= get_swqe_ptr(sqp
, sqp
->s_last
);
390 /* Return if it is not OK to start a new work reqeust. */
391 if (!(ib_qib_state_ops
[sqp
->state
] & QIB_PROCESS_NEXT_SEND_OK
)) {
392 if (!(ib_qib_state_ops
[sqp
->state
] & QIB_FLUSH_SEND
))
394 /* We are in the error state, flush the work request. */
395 send_status
= IB_WC_WR_FLUSH_ERR
;
400 * We can rely on the entry not changing without the s_lock
401 * being held until we update s_last.
402 * We increment s_cur to indicate s_last is in progress.
404 if (sqp
->s_last
== sqp
->s_cur
) {
405 if (++sqp
->s_cur
>= sqp
->s_size
)
408 spin_unlock_irqrestore(&sqp
->s_lock
, flags
);
410 if (!qp
|| !(ib_qib_state_ops
[qp
->state
] & QIB_PROCESS_RECV_OK
) ||
411 qp
->ibqp
.qp_type
!= sqp
->ibqp
.qp_type
) {
414 * For RC, the requester would timeout and retry so
415 * shortcut the timeouts and just signal too many retries.
417 if (sqp
->ibqp
.qp_type
== IB_QPT_RC
)
418 send_status
= IB_WC_RETRY_EXC_ERR
;
420 send_status
= IB_WC_SUCCESS
;
424 memset(&wc
, 0, sizeof(wc
));
425 send_status
= IB_WC_SUCCESS
;
428 sqp
->s_sge
.sge
= wqe
->sg_list
[0];
429 sqp
->s_sge
.sg_list
= wqe
->sg_list
+ 1;
430 sqp
->s_sge
.num_sge
= wqe
->wr
.num_sge
;
431 sqp
->s_len
= wqe
->length
;
432 switch (wqe
->wr
.opcode
) {
433 case IB_WR_SEND_WITH_IMM
:
434 wc
.wc_flags
= IB_WC_WITH_IMM
;
435 wc
.ex
.imm_data
= wqe
->wr
.ex
.imm_data
;
438 ret
= qib_get_rwqe(qp
, 0);
445 case IB_WR_RDMA_WRITE_WITH_IMM
:
446 if (unlikely(!(qp
->qp_access_flags
& IB_ACCESS_REMOTE_WRITE
)))
448 wc
.wc_flags
= IB_WC_WITH_IMM
;
449 wc
.ex
.imm_data
= wqe
->wr
.ex
.imm_data
;
450 ret
= qib_get_rwqe(qp
, 1);
456 case IB_WR_RDMA_WRITE
:
457 if (unlikely(!(qp
->qp_access_flags
& IB_ACCESS_REMOTE_WRITE
)))
459 if (wqe
->length
== 0)
461 if (unlikely(!qib_rkey_ok(qp
, &qp
->r_sge
.sge
, wqe
->length
,
462 wqe
->rdma_wr
.remote_addr
,
464 IB_ACCESS_REMOTE_WRITE
)))
466 qp
->r_sge
.sg_list
= NULL
;
467 qp
->r_sge
.num_sge
= 1;
468 qp
->r_sge
.total_len
= wqe
->length
;
471 case IB_WR_RDMA_READ
:
472 if (unlikely(!(qp
->qp_access_flags
& IB_ACCESS_REMOTE_READ
)))
474 if (unlikely(!qib_rkey_ok(qp
, &sqp
->s_sge
.sge
, wqe
->length
,
475 wqe
->rdma_wr
.remote_addr
,
477 IB_ACCESS_REMOTE_READ
)))
480 sqp
->s_sge
.sg_list
= NULL
;
481 sqp
->s_sge
.num_sge
= 1;
482 qp
->r_sge
.sge
= wqe
->sg_list
[0];
483 qp
->r_sge
.sg_list
= wqe
->sg_list
+ 1;
484 qp
->r_sge
.num_sge
= wqe
->wr
.num_sge
;
485 qp
->r_sge
.total_len
= wqe
->length
;
488 case IB_WR_ATOMIC_CMP_AND_SWP
:
489 case IB_WR_ATOMIC_FETCH_AND_ADD
:
490 if (unlikely(!(qp
->qp_access_flags
& IB_ACCESS_REMOTE_ATOMIC
)))
492 if (unlikely(!qib_rkey_ok(qp
, &qp
->r_sge
.sge
, sizeof(u64
),
493 wqe
->atomic_wr
.remote_addr
,
495 IB_ACCESS_REMOTE_ATOMIC
)))
497 /* Perform atomic OP and save result. */
498 maddr
= (atomic64_t
*) qp
->r_sge
.sge
.vaddr
;
499 sdata
= wqe
->atomic_wr
.compare_add
;
500 *(u64
*) sqp
->s_sge
.sge
.vaddr
=
501 (wqe
->atomic_wr
.wr
.opcode
== IB_WR_ATOMIC_FETCH_AND_ADD
) ?
502 (u64
) atomic64_add_return(sdata
, maddr
) - sdata
:
503 (u64
) cmpxchg((u64
*) qp
->r_sge
.sge
.vaddr
,
504 sdata
, wqe
->atomic_wr
.swap
);
505 qib_put_mr(qp
->r_sge
.sge
.mr
);
506 qp
->r_sge
.num_sge
= 0;
510 send_status
= IB_WC_LOC_QP_OP_ERR
;
514 sge
= &sqp
->s_sge
.sge
;
516 u32 len
= sqp
->s_len
;
518 if (len
> sge
->length
)
520 if (len
> sge
->sge_length
)
521 len
= sge
->sge_length
;
523 qib_copy_sge(&qp
->r_sge
, sge
->vaddr
, len
, release
);
526 sge
->sge_length
-= len
;
527 if (sge
->sge_length
== 0) {
530 if (--sqp
->s_sge
.num_sge
)
531 *sge
= *sqp
->s_sge
.sg_list
++;
532 } else if (sge
->length
== 0 && sge
->mr
->lkey
) {
533 if (++sge
->n
>= QIB_SEGSZ
) {
534 if (++sge
->m
>= sge
->mr
->mapsz
)
539 sge
->mr
->map
[sge
->m
]->segs
[sge
->n
].vaddr
;
541 sge
->mr
->map
[sge
->m
]->segs
[sge
->n
].length
;
546 qib_put_ss(&qp
->r_sge
);
548 if (!test_and_clear_bit(QIB_R_WRID_VALID
, &qp
->r_aflags
))
551 if (wqe
->wr
.opcode
== IB_WR_RDMA_WRITE_WITH_IMM
)
552 wc
.opcode
= IB_WC_RECV_RDMA_WITH_IMM
;
554 wc
.opcode
= IB_WC_RECV
;
555 wc
.wr_id
= qp
->r_wr_id
;
556 wc
.status
= IB_WC_SUCCESS
;
557 wc
.byte_len
= wqe
->length
;
559 wc
.src_qp
= qp
->remote_qpn
;
560 wc
.slid
= qp
->remote_ah_attr
.dlid
;
561 wc
.sl
= qp
->remote_ah_attr
.sl
;
563 /* Signal completion event if the solicited bit is set. */
564 qib_cq_enter(to_icq(qp
->ibqp
.recv_cq
), &wc
,
565 wqe
->wr
.send_flags
& IB_SEND_SOLICITED
);
568 spin_lock_irqsave(&sqp
->s_lock
, flags
);
571 sqp
->s_rnr_retry
= sqp
->s_rnr_retry_cnt
;
572 qib_send_complete(sqp
, wqe
, send_status
);
577 if (qp
->ibqp
.qp_type
== IB_QPT_UC
)
581 * Note: we don't need the s_lock held since the BUSY flag
582 * makes this single threaded.
584 if (sqp
->s_rnr_retry
== 0) {
585 send_status
= IB_WC_RNR_RETRY_EXC_ERR
;
588 if (sqp
->s_rnr_retry_cnt
< 7)
590 spin_lock_irqsave(&sqp
->s_lock
, flags
);
591 if (!(ib_qib_state_ops
[sqp
->state
] & QIB_PROCESS_RECV_OK
))
593 sqp
->s_flags
|= QIB_S_WAIT_RNR
;
594 sqp
->s_timer
.function
= qib_rc_rnr_retry
;
595 sqp
->s_timer
.expires
= jiffies
+
596 usecs_to_jiffies(ib_qib_rnr_table
[qp
->r_min_rnr_timer
]);
597 add_timer(&sqp
->s_timer
);
601 send_status
= IB_WC_REM_OP_ERR
;
602 wc
.status
= IB_WC_LOC_QP_OP_ERR
;
606 send_status
= IB_WC_REM_INV_REQ_ERR
;
607 wc
.status
= IB_WC_LOC_QP_OP_ERR
;
611 send_status
= IB_WC_REM_ACCESS_ERR
;
612 wc
.status
= IB_WC_LOC_PROT_ERR
;
614 /* responder goes to error state */
615 qib_rc_error(qp
, wc
.status
);
618 spin_lock_irqsave(&sqp
->s_lock
, flags
);
619 qib_send_complete(sqp
, wqe
, send_status
);
620 if (sqp
->ibqp
.qp_type
== IB_QPT_RC
) {
621 int lastwqe
= qib_error_qp(sqp
, IB_WC_WR_FLUSH_ERR
);
623 sqp
->s_flags
&= ~QIB_S_BUSY
;
624 spin_unlock_irqrestore(&sqp
->s_lock
, flags
);
628 ev
.device
= sqp
->ibqp
.device
;
629 ev
.element
.qp
= &sqp
->ibqp
;
630 ev
.event
= IB_EVENT_QP_LAST_WQE_REACHED
;
631 sqp
->ibqp
.event_handler(&ev
, sqp
->ibqp
.qp_context
);
636 sqp
->s_flags
&= ~QIB_S_BUSY
;
638 spin_unlock_irqrestore(&sqp
->s_lock
, flags
);
640 if (qp
&& atomic_dec_and_test(&qp
->refcount
))
645 * qib_make_grh - construct a GRH header
646 * @ibp: a pointer to the IB port
647 * @hdr: a pointer to the GRH header being constructed
648 * @grh: the global route address to send to
649 * @hwords: the number of 32 bit words of header being sent
650 * @nwords: the number of 32 bit words of data being sent
652 * Return the size of the header in 32 bit words.
654 u32
qib_make_grh(struct qib_ibport
*ibp
, struct ib_grh
*hdr
,
655 struct ib_global_route
*grh
, u32 hwords
, u32 nwords
)
657 hdr
->version_tclass_flow
=
658 cpu_to_be32((IB_GRH_VERSION
<< IB_GRH_VERSION_SHIFT
) |
659 (grh
->traffic_class
<< IB_GRH_TCLASS_SHIFT
) |
660 (grh
->flow_label
<< IB_GRH_FLOW_SHIFT
));
661 hdr
->paylen
= cpu_to_be16((hwords
- 2 + nwords
+ SIZE_OF_CRC
) << 2);
662 /* next_hdr is defined by C8-7 in ch. 8.4.1 */
663 hdr
->next_hdr
= IB_GRH_NEXT_HDR
;
664 hdr
->hop_limit
= grh
->hop_limit
;
665 /* The SGID is 32-bit aligned. */
666 hdr
->sgid
.global
.subnet_prefix
= ibp
->gid_prefix
;
667 hdr
->sgid
.global
.interface_id
= grh
->sgid_index
?
668 ibp
->guids
[grh
->sgid_index
- 1] : ppd_from_ibp(ibp
)->guid
;
669 hdr
->dgid
= grh
->dgid
;
671 /* GRH header size in 32-bit words. */
672 return sizeof(struct ib_grh
) / sizeof(u32
);
675 void qib_make_ruc_header(struct qib_qp
*qp
, struct qib_other_headers
*ohdr
,
678 struct qib_ibport
*ibp
= to_iport(qp
->ibqp
.device
, qp
->port_num
);
683 /* Construct the header. */
684 extra_bytes
= -qp
->s_cur_size
& 3;
685 nwords
= (qp
->s_cur_size
+ extra_bytes
) >> 2;
687 if (unlikely(qp
->remote_ah_attr
.ah_flags
& IB_AH_GRH
)) {
688 qp
->s_hdrwords
+= qib_make_grh(ibp
, &qp
->s_hdr
->u
.l
.grh
,
689 &qp
->remote_ah_attr
.grh
,
690 qp
->s_hdrwords
, nwords
);
693 lrh0
|= ibp
->sl_to_vl
[qp
->remote_ah_attr
.sl
] << 12 |
694 qp
->remote_ah_attr
.sl
<< 4;
695 qp
->s_hdr
->lrh
[0] = cpu_to_be16(lrh0
);
696 qp
->s_hdr
->lrh
[1] = cpu_to_be16(qp
->remote_ah_attr
.dlid
);
697 qp
->s_hdr
->lrh
[2] = cpu_to_be16(qp
->s_hdrwords
+ nwords
+ SIZE_OF_CRC
);
698 qp
->s_hdr
->lrh
[3] = cpu_to_be16(ppd_from_ibp(ibp
)->lid
|
699 qp
->remote_ah_attr
.src_path_bits
);
700 bth0
|= qib_get_pkey(ibp
, qp
->s_pkey_index
);
701 bth0
|= extra_bytes
<< 20;
702 if (qp
->s_mig_state
== IB_MIG_MIGRATED
)
703 bth0
|= IB_BTH_MIG_REQ
;
704 ohdr
->bth
[0] = cpu_to_be32(bth0
);
705 ohdr
->bth
[1] = cpu_to_be32(qp
->remote_qpn
);
706 ohdr
->bth
[2] = cpu_to_be32(bth2
);
707 this_cpu_inc(ibp
->pmastats
->n_unicast_xmit
);
711 * qib_do_send - perform a send on a QP
712 * @work: contains a pointer to the QP
714 * Process entries in the send work queue until credit or queue is
715 * exhausted. Only allow one CPU to send a packet per QP (tasklet).
716 * Otherwise, two threads could send packets out of order.
718 void qib_do_send(struct work_struct
*work
)
720 struct qib_qp
*qp
= container_of(work
, struct qib_qp
, s_work
);
721 struct qib_ibport
*ibp
= to_iport(qp
->ibqp
.device
, qp
->port_num
);
722 struct qib_pportdata
*ppd
= ppd_from_ibp(ibp
);
723 int (*make_req
)(struct qib_qp
*qp
);
726 if ((qp
->ibqp
.qp_type
== IB_QPT_RC
||
727 qp
->ibqp
.qp_type
== IB_QPT_UC
) &&
728 (qp
->remote_ah_attr
.dlid
& ~((1 << ppd
->lmc
) - 1)) == ppd
->lid
) {
729 qib_ruc_loopback(qp
);
733 if (qp
->ibqp
.qp_type
== IB_QPT_RC
)
734 make_req
= qib_make_rc_req
;
735 else if (qp
->ibqp
.qp_type
== IB_QPT_UC
)
736 make_req
= qib_make_uc_req
;
738 make_req
= qib_make_ud_req
;
740 spin_lock_irqsave(&qp
->s_lock
, flags
);
742 /* Return if we are already busy processing a work request. */
743 if (!qib_send_ok(qp
)) {
744 spin_unlock_irqrestore(&qp
->s_lock
, flags
);
748 qp
->s_flags
|= QIB_S_BUSY
;
750 spin_unlock_irqrestore(&qp
->s_lock
, flags
);
753 /* Check for a constructed packet to be sent. */
754 if (qp
->s_hdrwords
!= 0) {
756 * If the packet cannot be sent now, return and
757 * the send tasklet will be woken up later.
759 if (qib_verbs_send(qp
, qp
->s_hdr
, qp
->s_hdrwords
,
760 qp
->s_cur_sge
, qp
->s_cur_size
))
762 /* Record that s_hdr is empty. */
765 } while (make_req(qp
));
769 * This should be called with s_lock held.
771 void qib_send_complete(struct qib_qp
*qp
, struct qib_swqe
*wqe
,
772 enum ib_wc_status status
)
777 if (!(ib_qib_state_ops
[qp
->state
] & QIB_PROCESS_OR_FLUSH_SEND
))
780 for (i
= 0; i
< wqe
->wr
.num_sge
; i
++) {
781 struct qib_sge
*sge
= &wqe
->sg_list
[i
];
785 if (qp
->ibqp
.qp_type
== IB_QPT_UD
||
786 qp
->ibqp
.qp_type
== IB_QPT_SMI
||
787 qp
->ibqp
.qp_type
== IB_QPT_GSI
)
788 atomic_dec(&to_iah(wqe
->ud_wr
.ah
)->refcount
);
790 /* See ch. 11.2.4.1 and 10.7.3.1 */
791 if (!(qp
->s_flags
& QIB_S_SIGNAL_REQ_WR
) ||
792 (wqe
->wr
.send_flags
& IB_SEND_SIGNALED
) ||
793 status
!= IB_WC_SUCCESS
) {
796 memset(&wc
, 0, sizeof(wc
));
797 wc
.wr_id
= wqe
->wr
.wr_id
;
799 wc
.opcode
= ib_qib_wc_opcode
[wqe
->wr
.opcode
];
801 if (status
== IB_WC_SUCCESS
)
802 wc
.byte_len
= wqe
->length
;
803 qib_cq_enter(to_icq(qp
->ibqp
.send_cq
), &wc
,
804 status
!= IB_WC_SUCCESS
);
809 if (++last
>= qp
->s_size
)
812 if (qp
->s_acked
== old_last
)
814 if (qp
->s_cur
== old_last
)
816 if (qp
->s_tail
== old_last
)
818 if (qp
->state
== IB_QPS_SQD
&& last
== qp
->s_cur
)