IB/hfi1: Add functions to parse 9B headers

These inline functions improve code readability by
enabling callers to read specific fields from the
header without knowledge of byte offsets.

Reviewed-by: Dennis Dalessandro <dennis.dalessandro@intel.com>
Signed-off-by: Don Hiatt <don.hiatt@intel.com>
Signed-off-by: Dasaratharaman Chandramouli <dasaratharaman.chandramouli@intel.com>
Signed-off-by: Dennis Dalessandro <dennis.dalessandro@intel.com>
Signed-off-by: Doug Ledford <dledford@redhat.com>
This commit is contained in:
Don Hiatt 2017-04-09 10:16:22 -07:00 committed by Doug Ledford
parent aad559c21d
commit cb42705792
9 changed files with 102 additions and 47 deletions

View File

@ -285,7 +285,7 @@ static void rcv_hdrerr(struct hfi1_ctxtdata *rcd, struct hfi1_pportdata *ppd,
{ {
struct ib_header *rhdr = packet->hdr; struct ib_header *rhdr = packet->hdr;
u32 rte = rhf_rcv_type_err(packet->rhf); u32 rte = rhf_rcv_type_err(packet->rhf);
int lnh = be16_to_cpu(rhdr->lrh[0]) & 3; int lnh = ib_get_lnh(rhdr);
struct hfi1_ibport *ibp = rcd_to_iport(rcd); struct hfi1_ibport *ibp = rcd_to_iport(rcd);
struct hfi1_devdata *dd = ppd->dd; struct hfi1_devdata *dd = ppd->dd;
struct rvt_dev_info *rdi = &dd->verbs_dev.rdi; struct rvt_dev_info *rdi = &dd->verbs_dev.rdi;
@ -297,7 +297,7 @@ static void rcv_hdrerr(struct hfi1_ctxtdata *rcd, struct hfi1_pportdata *ppd,
/* For TIDERR and RC QPs preemptively schedule a NAK */ /* For TIDERR and RC QPs preemptively schedule a NAK */
struct ib_other_headers *ohdr = NULL; struct ib_other_headers *ohdr = NULL;
u32 tlen = rhf_pkt_len(packet->rhf); /* in bytes */ u32 tlen = rhf_pkt_len(packet->rhf); /* in bytes */
u16 lid = be16_to_cpu(rhdr->lrh[1]); u16 lid = ib_get_dlid(rhdr);
u32 qp_num; u32 qp_num;
u32 rcv_flags = 0; u32 rcv_flags = 0;
@ -416,7 +416,7 @@ static void rcv_hdrerr(struct hfi1_ctxtdata *rcd, struct hfi1_pportdata *ppd,
svc_type = IB_CC_SVCTYPE_UD; svc_type = IB_CC_SVCTYPE_UD;
break; break;
case IB_QPT_UC: case IB_QPT_UC:
rlid = be16_to_cpu(rhdr->lrh[3]); rlid = ib_get_slid(rhdr);
rqpn = qp->remote_qpn; rqpn = qp->remote_qpn;
svc_type = IB_CC_SVCTYPE_UC; svc_type = IB_CC_SVCTYPE_UC;
break; break;
@ -462,7 +462,7 @@ void hfi1_process_ecn_slowpath(struct rvt_qp *qp, struct hfi1_packet *pkt,
struct ib_other_headers *ohdr = pkt->ohdr; struct ib_other_headers *ohdr = pkt->ohdr;
struct ib_grh *grh = NULL; struct ib_grh *grh = NULL;
u32 rqpn = 0, bth1; u32 rqpn = 0, bth1;
u16 rlid, dlid = be16_to_cpu(hdr->lrh[1]); u16 rlid, dlid = ib_get_dlid(hdr);
u8 sc, svc_type; u8 sc, svc_type;
bool is_mcast = false; bool is_mcast = false;
@ -473,7 +473,7 @@ void hfi1_process_ecn_slowpath(struct rvt_qp *qp, struct hfi1_packet *pkt,
case IB_QPT_SMI: case IB_QPT_SMI:
case IB_QPT_GSI: case IB_QPT_GSI:
case IB_QPT_UD: case IB_QPT_UD:
rlid = be16_to_cpu(hdr->lrh[3]); rlid = ib_get_slid(hdr);
rqpn = be32_to_cpu(ohdr->u.ud.deth[1]) & RVT_QPN_MASK; rqpn = be32_to_cpu(ohdr->u.ud.deth[1]) & RVT_QPN_MASK;
svc_type = IB_CC_SVCTYPE_UD; svc_type = IB_CC_SVCTYPE_UD;
is_mcast = (dlid > be16_to_cpu(IB_MULTICAST_LID_BASE)) && is_mcast = (dlid > be16_to_cpu(IB_MULTICAST_LID_BASE)) &&
@ -623,8 +623,7 @@ static void __prescan_rxq(struct hfi1_packet *packet)
packet->hdr = hfi1_get_msgheader(dd, rhf_addr); packet->hdr = hfi1_get_msgheader(dd, rhf_addr);
hdr = packet->hdr; hdr = packet->hdr;
lnh = ib_get_lnh(hdr);
lnh = be16_to_cpu(hdr->lrh[0]) & 3;
if (lnh == HFI1_LRH_BTH) { if (lnh == HFI1_LRH_BTH) {
packet->ohdr = &hdr->u.oth; packet->ohdr = &hdr->u.oth;

View File

@ -1314,8 +1314,7 @@ void receive_interrupt_work(struct work_struct *work);
/* extract service channel from header and rhf */ /* extract service channel from header and rhf */
static inline int hfi1_9B_get_sc5(struct ib_header *hdr, u64 rhf) static inline int hfi1_9B_get_sc5(struct ib_header *hdr, u64 rhf)
{ {
return ((be16_to_cpu(hdr->lrh[0]) >> 12) & 0xf) | return ib_get_sc(hdr) | ((!!(rhf_dc_info(rhf))) << 4);
((!!(rhf_dc_info(rhf))) << 4);
} }
#define HFI1_JKEY_WIDTH 16 #define HFI1_JKEY_WIDTH 16

View File

@ -994,12 +994,12 @@ void hfi1_rc_send_complete(struct rvt_qp *qp, struct ib_header *hdr)
return; return;
/* Find out where the BTH is */ /* Find out where the BTH is */
if ((be16_to_cpu(hdr->lrh[0]) & 3) == HFI1_LRH_BTH) if (ib_get_lnh(hdr) == HFI1_LRH_BTH)
ohdr = &hdr->u.oth; ohdr = &hdr->u.oth;
else else
ohdr = &hdr->u.l.oth; ohdr = &hdr->u.l.oth;
opcode = be32_to_cpu(ohdr->bth[0]) >> 24; opcode = ib_bth_get_opcode(ohdr);
if (opcode >= OP(RDMA_READ_RESPONSE_FIRST) && if (opcode >= OP(RDMA_READ_RESPONSE_FIRST) &&
opcode <= OP(ATOMIC_ACKNOWLEDGE)) { opcode <= OP(ATOMIC_ACKNOWLEDGE)) {
WARN_ON(!qp->s_rdma_ack_cnt); WARN_ON(!qp->s_rdma_ack_cnt);
@ -1524,7 +1524,7 @@ read_middle:
if (!do_rc_ack(qp, aeth, psn, opcode, 0, rcd)) if (!do_rc_ack(qp, aeth, psn, opcode, 0, rcd))
goto ack_done; goto ack_done;
/* Get the number of bytes the message was padded by. */ /* Get the number of bytes the message was padded by. */
pad = (be32_to_cpu(ohdr->bth[0]) >> 20) & 3; pad = ib_bth_get_pad(ohdr);
/* /*
* Check that the data size is >= 0 && <= pmtu. * Check that the data size is >= 0 && <= pmtu.
* Remember to account for ICRC (4). * Remember to account for ICRC (4).
@ -1548,7 +1548,7 @@ read_middle:
if (unlikely(wqe->wr.opcode != IB_WR_RDMA_READ)) if (unlikely(wqe->wr.opcode != IB_WR_RDMA_READ))
goto ack_op_err; goto ack_op_err;
/* Get the number of bytes the message was padded by. */ /* Get the number of bytes the message was padded by. */
pad = (be32_to_cpu(ohdr->bth[0]) >> 20) & 3; pad = ib_bth_get_pad(ohdr);
/* /*
* Check that the data size is >= 1 && <= pmtu. * Check that the data size is >= 1 && <= pmtu.
* Remember to account for ICRC (4). * Remember to account for ICRC (4).
@ -1942,7 +1942,7 @@ void hfi1_rc_rcv(struct hfi1_packet *packet)
is_fecn = process_ecn(qp, packet, false); is_fecn = process_ecn(qp, packet, false);
psn = be32_to_cpu(ohdr->bth[2]); psn = be32_to_cpu(ohdr->bth[2]);
opcode = (bth0 >> 24) & 0xff; opcode = ib_bth_get_opcode(ohdr);
/* /*
* Process responses (ACKs) before anything else. Note that the * Process responses (ACKs) before anything else. Note that the
@ -2073,7 +2073,7 @@ no_immediate_data:
wc.ex.imm_data = 0; wc.ex.imm_data = 0;
send_last: send_last:
/* Get the number of bytes the message was padded by. */ /* Get the number of bytes the message was padded by. */
pad = (bth0 >> 20) & 3; pad = ib_bth_get_pad(ohdr);
/* Check for invalid length. */ /* Check for invalid length. */
/* LAST len should be >= 1 */ /* LAST len should be >= 1 */
if (unlikely(tlen < (hdrsize + pad + 4))) if (unlikely(tlen < (hdrsize + pad + 4)))
@ -2386,7 +2386,7 @@ void hfi1_rc_hdrerr(
return; return;
psn = be32_to_cpu(ohdr->bth[2]); psn = be32_to_cpu(ohdr->bth[2]);
opcode = (bth0 >> 24) & 0xff; opcode = ib_bth_get_opcode(ohdr);
/* Only deal with RDMA Writes for now */ /* Only deal with RDMA Writes for now */
if (opcode < IB_OPCODE_RC_RDMA_READ_RESPONSE_FIRST) { if (opcode < IB_OPCODE_RC_RDMA_READ_RESPONSE_FIRST) {

View File

@ -238,18 +238,18 @@ int hfi1_ruc_check_hdr(struct hfi1_ibport *ibp, struct ib_header *hdr,
qp->alt_ah_attr.grh.dgid.global.interface_id)) qp->alt_ah_attr.grh.dgid.global.interface_id))
goto err; goto err;
} }
if (unlikely(rcv_pkey_check(ppd_from_ibp(ibp), (u16)bth0, if (unlikely(rcv_pkey_check(ppd_from_ibp(ibp), (u16)bth0, sc5,
sc5, be16_to_cpu(hdr->lrh[3])))) { ib_get_slid(hdr)))) {
hfi1_bad_pqkey(ibp, OPA_TRAP_BAD_P_KEY, hfi1_bad_pqkey(ibp, OPA_TRAP_BAD_P_KEY,
(u16)bth0, (u16)bth0,
(be16_to_cpu(hdr->lrh[0]) >> 4) & 0xF, ib_get_sl(hdr),
0, qp->ibqp.qp_num, 0, qp->ibqp.qp_num,
be16_to_cpu(hdr->lrh[3]), ib_get_slid(hdr),
be16_to_cpu(hdr->lrh[1])); ib_get_dlid(hdr));
goto err; goto err;
} }
/* Validate the SLID. See Ch. 9.6.1.5 and 17.2.8 */ /* Validate the SLID. See Ch. 9.6.1.5 and 17.2.8 */
if (be16_to_cpu(hdr->lrh[3]) != qp->alt_ah_attr.dlid || if (ib_get_slid(hdr) != qp->alt_ah_attr.dlid ||
ppd_from_ibp(ibp)->port != qp->alt_ah_attr.port_num) ppd_from_ibp(ibp)->port != qp->alt_ah_attr.port_num)
goto err; goto err;
spin_lock_irqsave(&qp->s_lock, flags); spin_lock_irqsave(&qp->s_lock, flags);
@ -273,18 +273,18 @@ int hfi1_ruc_check_hdr(struct hfi1_ibport *ibp, struct ib_header *hdr,
qp->remote_ah_attr.grh.dgid.global.interface_id)) qp->remote_ah_attr.grh.dgid.global.interface_id))
goto err; goto err;
} }
if (unlikely(rcv_pkey_check(ppd_from_ibp(ibp), (u16)bth0, if (unlikely(rcv_pkey_check(ppd_from_ibp(ibp), (u16)bth0, sc5,
sc5, be16_to_cpu(hdr->lrh[3])))) { ib_get_slid(hdr)))) {
hfi1_bad_pqkey(ibp, OPA_TRAP_BAD_P_KEY, hfi1_bad_pqkey(ibp, OPA_TRAP_BAD_P_KEY,
(u16)bth0, (u16)bth0,
(be16_to_cpu(hdr->lrh[0]) >> 4) & 0xF, ib_get_sl(hdr),
0, qp->ibqp.qp_num, 0, qp->ibqp.qp_num,
be16_to_cpu(hdr->lrh[3]), ib_get_slid(hdr),
be16_to_cpu(hdr->lrh[1])); ib_get_dlid(hdr));
goto err; goto err;
} }
/* Validate the SLID. See Ch. 9.6.1.5 */ /* Validate the SLID. See Ch. 9.6.1.5 */
if (be16_to_cpu(hdr->lrh[3]) != qp->remote_ah_attr.dlid || if (ib_get_slid(hdr) != qp->remote_ah_attr.dlid ||
ppd_from_ibp(ibp)->port != qp->port_num) ppd_from_ibp(ibp)->port != qp->port_num)
goto err; goto err;
if (qp->s_mig_state == IB_MIG_REARM && if (qp->s_mig_state == IB_MIG_REARM &&

View File

@ -51,13 +51,12 @@ u8 ibhdr_exhdr_len(struct ib_header *hdr)
{ {
struct ib_other_headers *ohdr; struct ib_other_headers *ohdr;
u8 opcode; u8 opcode;
u8 lnh = (u8)(be16_to_cpu(hdr->lrh[0]) & 3);
if (lnh == HFI1_LRH_BTH) if (ib_get_lnh(hdr) == HFI1_LRH_BTH)
ohdr = &hdr->u.oth; ohdr = &hdr->u.oth;
else else
ohdr = &hdr->u.l.oth; ohdr = &hdr->u.l.oth;
opcode = be32_to_cpu(ohdr->bth[0]) >> 24; opcode = ib_bth_get_opcode(ohdr);
return hdr_len_by_opcode[opcode] == 0 ? return hdr_len_by_opcode[opcode] == 0 ?
0 : hdr_len_by_opcode[opcode] - (12 + 8); 0 : hdr_len_by_opcode[opcode] - (12 + 8);
} }

View File

@ -320,7 +320,7 @@ void hfi1_uc_rcv(struct hfi1_packet *packet)
process_ecn(qp, packet, true); process_ecn(qp, packet, true);
psn = be32_to_cpu(ohdr->bth[2]); psn = be32_to_cpu(ohdr->bth[2]);
opcode = (bth0 >> 24) & 0xff; opcode = ib_bth_get_opcode(ohdr);
/* Compare the PSN verses the expected PSN. */ /* Compare the PSN verses the expected PSN. */
if (unlikely(cmp_psn(psn, qp->r_psn) != 0)) { if (unlikely(cmp_psn(psn, qp->r_psn) != 0)) {
@ -433,7 +433,7 @@ no_immediate_data:
wc.wc_flags = 0; wc.wc_flags = 0;
send_last: send_last:
/* Get the number of bytes the message was padded by. */ /* Get the number of bytes the message was padded by. */
pad = (be32_to_cpu(ohdr->bth[0]) >> 20) & 3; pad = ib_bth_get_pad(ohdr);
/* Check for invalid length. */ /* Check for invalid length. */
/* LAST len should be >= 1 */ /* LAST len should be >= 1 */
if (unlikely(tlen < (hdrsize + pad + 4))) if (unlikely(tlen < (hdrsize + pad + 4)))
@ -528,7 +528,7 @@ rdma_last_imm:
wc.wc_flags = IB_WC_WITH_IMM; wc.wc_flags = IB_WC_WITH_IMM;
/* Get the number of bytes the message was padded by. */ /* Get the number of bytes the message was padded by. */
pad = (be32_to_cpu(ohdr->bth[0]) >> 20) & 3; pad = ib_bth_get_pad(ohdr);
/* Check for invalid length. */ /* Check for invalid length. */
/* LAST len should be >= 1 */ /* LAST len should be >= 1 */
if (unlikely(tlen < (hdrsize + pad + 4))) if (unlikely(tlen < (hdrsize + pad + 4)))
@ -555,7 +555,7 @@ rdma_last_imm:
case OP(RDMA_WRITE_LAST): case OP(RDMA_WRITE_LAST):
rdma_last: rdma_last:
/* Get the number of bytes the message was padded by. */ /* Get the number of bytes the message was padded by. */
pad = (be32_to_cpu(ohdr->bth[0]) >> 20) & 3; pad = ib_bth_get_pad(ohdr);
/* Check for invalid length. */ /* Check for invalid length. */
/* LAST len should be >= 1 */ /* LAST len should be >= 1 */
if (unlikely(tlen < (hdrsize + pad + 4))) if (unlikely(tlen < (hdrsize + pad + 4)))

View File

@ -688,18 +688,16 @@ void hfi1_ud_rcv(struct hfi1_packet *packet)
qkey = be32_to_cpu(ohdr->u.ud.deth[0]); qkey = be32_to_cpu(ohdr->u.ud.deth[0]);
src_qp = be32_to_cpu(ohdr->u.ud.deth[1]) & RVT_QPN_MASK; src_qp = be32_to_cpu(ohdr->u.ud.deth[1]) & RVT_QPN_MASK;
dlid = be16_to_cpu(hdr->lrh[1]); dlid = ib_get_dlid(hdr);
bth1 = be32_to_cpu(ohdr->bth[1]); bth1 = be32_to_cpu(ohdr->bth[1]);
slid = be16_to_cpu(hdr->lrh[3]); slid = ib_get_slid(hdr);
pkey = (u16)be32_to_cpu(ohdr->bth[0]); pkey = ib_bth_get_pkey(ohdr);
sl = (be16_to_cpu(hdr->lrh[0]) >> 4) & 0xf; opcode = ib_bth_get_opcode(ohdr);
extra_bytes = (be32_to_cpu(ohdr->bth[0]) >> 20) & 3; sl = ib_get_sl(hdr);
extra_bytes = ib_bth_get_pad(ohdr);
extra_bytes += (SIZE_OF_CRC << 2); extra_bytes += (SIZE_OF_CRC << 2);
sl_from_sc = ibp->sc_to_sl[sc5]; sl_from_sc = ibp->sc_to_sl[sc5];
opcode = be32_to_cpu(ohdr->bth[0]) >> 24;
opcode &= 0xff;
process_ecn(qp, packet, (opcode != IB_OPCODE_CNP)); process_ecn(qp, packet, (opcode != IB_OPCODE_CNP));
/* /*
* Get the number of bytes the message was padded by * Get the number of bytes the message was padded by

View File

@ -572,7 +572,7 @@ void hfi1_ib_rcv(struct hfi1_packet *packet)
u16 lid; u16 lid;
/* Check for GRH */ /* Check for GRH */
lnh = be16_to_cpu(hdr->lrh[0]) & 3; lnh = ib_get_lnh(hdr);
if (lnh == HFI1_LRH_BTH) { if (lnh == HFI1_LRH_BTH) {
packet->ohdr = &hdr->u.oth; packet->ohdr = &hdr->u.oth;
} else if (lnh == HFI1_LRH_GRH) { } else if (lnh == HFI1_LRH_GRH) {
@ -591,12 +591,12 @@ void hfi1_ib_rcv(struct hfi1_packet *packet)
trace_input_ibhdr(rcd->dd, hdr); trace_input_ibhdr(rcd->dd, hdr);
opcode = (be32_to_cpu(packet->ohdr->bth[0]) >> 24); opcode = ib_bth_get_opcode(packet->ohdr);
inc_opstats(tlen, &rcd->opstats->stats[opcode]); inc_opstats(tlen, &rcd->opstats->stats[opcode]);
/* Get the destination QP number. */ /* Get the destination QP number. */
qp_num = be32_to_cpu(packet->ohdr->bth[1]) & RVT_QPN_MASK; qp_num = be32_to_cpu(packet->ohdr->bth[1]) & RVT_QPN_MASK;
lid = be16_to_cpu(hdr->lrh[1]); lid = ib_get_dlid(hdr);
if (unlikely((lid >= be16_to_cpu(IB_MULTICAST_LID_BASE)) && if (unlikely((lid >= be16_to_cpu(IB_MULTICAST_LID_BASE)) &&
(lid != be16_to_cpu(IB_LID_PERMISSIVE)))) { (lid != be16_to_cpu(IB_LID_PERMISSIVE)))) {
struct rvt_mcast *mcast; struct rvt_mcast *mcast;
@ -1231,7 +1231,7 @@ int hfi1_verbs_send(struct rvt_qp *qp, struct hfi1_pkt_state *ps)
hdr = &ps->s_txreq->phdr.hdr; hdr = &ps->s_txreq->phdr.hdr;
/* locate the pkey within the headers */ /* locate the pkey within the headers */
lnh = be16_to_cpu(hdr->lrh[0]) & 3; lnh = ib_get_lnh(hdr);
if (lnh == HFI1_LRH_GRH) if (lnh == HFI1_LRH_GRH)
ohdr = &hdr->u.l.oth; ohdr = &hdr->u.l.oth;
else else

View File

@ -181,4 +181,64 @@ static inline void put_ib_ateth_compare(u64 val, struct ib_atomic_eth *ateth)
ib_u64_put(val, &ateth->compare_data); ib_u64_put(val, &ateth->compare_data);
} }
/*
* 9B/IB Packet Format
*/
#define IB_LNH_MASK 3
#define IB_SC_MASK 0xf
#define IB_SC_SHIFT 12
#define IB_SL_MASK 0xf
#define IB_SL_SHIFT 4
static inline u8 ib_get_lnh(struct ib_header *hdr)
{
return (be16_to_cpu(hdr->lrh[0]) & IB_LNH_MASK);
}
static inline u8 ib_get_sc(struct ib_header *hdr)
{
return ((be16_to_cpu(hdr->lrh[0]) >> IB_SC_SHIFT) & IB_SC_MASK);
}
static inline u8 ib_get_sl(struct ib_header *hdr)
{
return ((be16_to_cpu(hdr->lrh[0]) >> IB_SL_SHIFT) & IB_SL_MASK);
}
static inline u16 ib_get_dlid(struct ib_header *hdr)
{
return (be16_to_cpu(hdr->lrh[1]));
}
static inline u16 ib_get_slid(struct ib_header *hdr)
{
return (be16_to_cpu(hdr->lrh[3]));
}
/*
* BTH
*/
#define IB_BTH_OPCODE_MASK 0xff
#define IB_BTH_OPCODE_SHIFT 24
#define IB_BTH_PAD_MASK 3
#define IB_BTH_PKEY_MASK 0xffff
#define IB_BTH_PAD_SHIFT 20
static inline u8 ib_bth_get_pad(struct ib_other_headers *ohdr)
{
return ((be32_to_cpu(ohdr->bth[0]) >> IB_BTH_PAD_SHIFT) &
IB_BTH_PAD_MASK);
}
static inline u16 ib_bth_get_pkey(struct ib_other_headers *ohdr)
{
return (be32_to_cpu(ohdr->bth[0]) & IB_BTH_PKEY_MASK);
}
static inline u8 ib_bth_get_opcode(struct ib_other_headers *ohdr)
{
return ((be32_to_cpu(ohdr->bth[0]) >> IB_BTH_OPCODE_SHIFT) &
IB_BTH_OPCODE_MASK);
}
#endif /* IB_HDRS_H */ #endif /* IB_HDRS_H */