Commit 89c057ca authored by Dasaratharaman Chandramouli's avatar Dasaratharaman Chandramouli Committed by Doug Ledford

IB/hfi1: Cleanup UD packet handler.

Cleanup hfi1_ud_rcv to not have to look at the packet
header fields multiple times. The fields are looked up
once and used throughout the function. Also fix sc
computation when validating MAD packets.
Reviewed-by: default avatarDennis Dalessandro <dennis.dalessandro@intel.com>
Reviewed-by: default avatarDean Luick <dean.luick@intel.com>
Reviewed-by: default avatarIra Weiny <ira.weiny@intel.com>
Signed-off-by: default avatarDasaratharaman Chandramouli <dasaratharaman.chandramouli@intel.com>
Signed-off-by: default avatarDon Hiatt <don.hiatt@intel.com>
Signed-off-by: default avatarDennis Dalessandro <dennis.dalessandro@intel.com>
Signed-off-by: default avatarDoug Ledford <dledford@redhat.com>
parent d4d602e9
...@@ -664,13 +664,13 @@ void hfi1_ud_rcv(struct hfi1_packet *packet) ...@@ -664,13 +664,13 @@ void hfi1_ud_rcv(struct hfi1_packet *packet)
struct hfi1_other_headers *ohdr = packet->ohdr; struct hfi1_other_headers *ohdr = packet->ohdr;
int opcode; int opcode;
u32 hdrsize = packet->hlen; u32 hdrsize = packet->hlen;
u32 pad;
struct ib_wc wc; struct ib_wc wc;
u32 qkey; u32 qkey;
u32 src_qp; u32 src_qp;
u16 dlid, pkey; u16 dlid, pkey;
int mgmt_pkey_idx = -1; int mgmt_pkey_idx = -1;
struct hfi1_ibport *ibp = &packet->rcd->ppd->ibport_data; struct hfi1_ibport *ibp = &packet->rcd->ppd->ibport_data;
struct hfi1_pportdata *ppd = ppd_from_ibp(ibp);
struct hfi1_ib_header *hdr = packet->hdr; struct hfi1_ib_header *hdr = packet->hdr;
u32 rcv_flags = packet->rcv_flags; u32 rcv_flags = packet->rcv_flags;
void *data = packet->ebuf; void *data = packet->ebuf;
...@@ -678,31 +678,34 @@ void hfi1_ud_rcv(struct hfi1_packet *packet) ...@@ -678,31 +678,34 @@ void hfi1_ud_rcv(struct hfi1_packet *packet)
struct rvt_qp *qp = packet->qp; struct rvt_qp *qp = packet->qp;
bool has_grh = rcv_flags & HFI1_HAS_GRH; bool has_grh = rcv_flags & HFI1_HAS_GRH;
u8 sc5 = hdr2sc((struct hfi1_message_header *)hdr, packet->rhf); u8 sc5 = hdr2sc((struct hfi1_message_header *)hdr, packet->rhf);
u32 bth1;
u8 sl_from_sc, sl;
u16 slid;
u8 extra_bytes;
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 = be16_to_cpu(hdr->lrh[1]);
bth1 = be32_to_cpu(ohdr->bth[1]);
slid = be16_to_cpu(hdr->lrh[3]);
pkey = (u16)be32_to_cpu(ohdr->bth[0]);
sl = (be16_to_cpu(hdr->lrh[0]) >> 4) & 0xf;
extra_bytes = (be32_to_cpu(ohdr->bth[0]) >> 20) & 3;
extra_bytes += (SIZE_OF_CRC << 2);
sl_from_sc = ibp->sc_to_sl[sc5];
/*
* The opcode is in the low byte when its in network order
* (top byte when in host order).
*/
opcode = be32_to_cpu(ohdr->bth[0]) >> 24; opcode = be32_to_cpu(ohdr->bth[0]) >> 24;
opcode &= 0xff; opcode &= 0xff;
pkey = (u16)be32_to_cpu(ohdr->bth[0]);
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
* and drop incomplete packets. * and drop incomplete packets.
*/ */
pad = (be32_to_cpu(ohdr->bth[0]) >> 20) & 3; if (unlikely(tlen < (hdrsize + extra_bytes)))
if (unlikely(tlen < (hdrsize + pad + 4)))
goto drop; goto drop;
tlen -= hdrsize + pad + 4; tlen -= hdrsize + extra_bytes;
/* /*
* Check that the permissive LID is only used on QP0 * Check that the permissive LID is only used on QP0
...@@ -713,10 +716,6 @@ void hfi1_ud_rcv(struct hfi1_packet *packet) ...@@ -713,10 +716,6 @@ void hfi1_ud_rcv(struct hfi1_packet *packet)
hdr->lrh[3] == IB_LID_PERMISSIVE)) hdr->lrh[3] == IB_LID_PERMISSIVE))
goto drop; goto drop;
if (qp->ibqp.qp_num > 1) { if (qp->ibqp.qp_num > 1) {
struct hfi1_pportdata *ppd = ppd_from_ibp(ibp);
u16 slid;
slid = be16_to_cpu(hdr->lrh[3]);
if (unlikely(rcv_pkey_check(ppd, pkey, sc5, slid))) { if (unlikely(rcv_pkey_check(ppd, pkey, sc5, slid))) {
/* /*
* Traps will not be sent for packets dropped * Traps will not be sent for packets dropped
...@@ -725,12 +724,9 @@ void hfi1_ud_rcv(struct hfi1_packet *packet) ...@@ -725,12 +724,9 @@ void hfi1_ud_rcv(struct hfi1_packet *packet)
* IB spec (release 1.3, section 10.9.4) * IB spec (release 1.3, section 10.9.4)
*/ */
hfi1_bad_pqkey(ibp, OPA_TRAP_BAD_P_KEY, hfi1_bad_pqkey(ibp, OPA_TRAP_BAD_P_KEY,
pkey, pkey, sl,
(be16_to_cpu(hdr->lrh[0]) >> 4) &
0xF,
src_qp, qp->ibqp.qp_num, src_qp, qp->ibqp.qp_num,
be16_to_cpu(hdr->lrh[3]), slid, dlid);
be16_to_cpu(hdr->lrh[1]));
return; return;
} }
} else { } else {
...@@ -740,22 +736,18 @@ void hfi1_ud_rcv(struct hfi1_packet *packet) ...@@ -740,22 +736,18 @@ void hfi1_ud_rcv(struct hfi1_packet *packet)
goto drop; goto drop;
} }
if (unlikely(qkey != qp->qkey)) { if (unlikely(qkey != qp->qkey)) {
hfi1_bad_pqkey(ibp, OPA_TRAP_BAD_Q_KEY, qkey, hfi1_bad_pqkey(ibp, OPA_TRAP_BAD_Q_KEY, qkey, sl,
(be16_to_cpu(hdr->lrh[0]) >> 4) & 0xF,
src_qp, qp->ibqp.qp_num, src_qp, qp->ibqp.qp_num,
be16_to_cpu(hdr->lrh[3]), slid, dlid);
be16_to_cpu(hdr->lrh[1]));
return; return;
} }
/* Drop invalid MAD packets (see 13.5.3.1). */ /* Drop invalid MAD packets (see 13.5.3.1). */
if (unlikely(qp->ibqp.qp_num == 1 && if (unlikely(qp->ibqp.qp_num == 1 &&
(tlen > 2048 || (tlen > 2048 || (sc5 == 0xF))))
(be16_to_cpu(hdr->lrh[0]) >> 12) == 15)))
goto drop; goto drop;
} else { } else {
/* Received on QP0, and so by definition, this is an SMP */ /* Received on QP0, and so by definition, this is an SMP */
struct opa_smp *smp = (struct opa_smp *)data; struct opa_smp *smp = (struct opa_smp *)data;
u16 slid = be16_to_cpu(hdr->lrh[3]);
if (opa_smp_check(ibp, pkey, sc5, qp, slid, smp)) if (opa_smp_check(ibp, pkey, sc5, qp, slid, smp))
goto drop; goto drop;
...@@ -838,7 +830,6 @@ void hfi1_ud_rcv(struct hfi1_packet *packet) ...@@ -838,7 +830,6 @@ void hfi1_ud_rcv(struct hfi1_packet *packet)
qp->ibqp.qp_type == IB_QPT_SMI) { qp->ibqp.qp_type == IB_QPT_SMI) {
if (mgmt_pkey_idx < 0) { if (mgmt_pkey_idx < 0) {
if (net_ratelimit()) { if (net_ratelimit()) {
struct hfi1_pportdata *ppd = ppd_from_ibp(ibp);
struct hfi1_devdata *dd = ppd->dd; struct hfi1_devdata *dd = ppd->dd;
dd_dev_err(dd, "QP type %d mgmt_pkey_idx < 0 and packet not dropped???\n", dd_dev_err(dd, "QP type %d mgmt_pkey_idx < 0 and packet not dropped???\n",
...@@ -851,8 +842,8 @@ void hfi1_ud_rcv(struct hfi1_packet *packet) ...@@ -851,8 +842,8 @@ void hfi1_ud_rcv(struct hfi1_packet *packet)
wc.pkey_index = 0; wc.pkey_index = 0;
} }
wc.slid = be16_to_cpu(hdr->lrh[3]); wc.slid = slid;
wc.sl = ibp->sc_to_sl[sc5]; wc.sl = sl_from_sc;
/* /*
* Save the LMC lower bits if the destination LID is a unicast LID. * Save the LMC lower bits if the destination LID is a unicast LID.
......
Markdown is supported
0%
or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment