diff options
author | Or Gerlitz <ogerlitz@mellanox.com> | 2012-01-11 12:03:51 -0500 |
---|---|---|
committer | Roland Dreier <roland@purestorage.com> | 2012-03-08 15:34:27 -0500 |
commit | d927d505c59a0c7353343174e6225c43c61fba6d (patch) | |
tree | 8fe928291acb9c6975f7c03514566933edeef7d5 /drivers/infiniband/hw/mthca | |
parent | 3eae7c9f97415ac1f5ab5db4eeb03cde689eb427 (diff) |
IB: Change CQE "csum_ok" field to a bit flag
Use a bit in wc_flags rather then a whole integer to hold the
"checksum OK" flag. By itself, this change doesn't reduce the size of
struct ib_wc on 64bit machines -- it stays on 56 bytes because of
padding. However, it will allow to add more fields in the future
without enlarging the struct. Also, it will let us have a unified
approach with future libibverbs checksum offload reporting, because a
bit flag doesn't break the library ABI.
This patch was suggested during conversation with Liran Liss
<liranl@mellanox.com>.
Signed-off-by: Or Gerlitz <ogerlitz@mellanox.com>
Reviewed-by: Sean Hefty <sean.hefty@intel.com>
Signed-off-by: Roland Dreier <roland@purestorage.com>
Diffstat (limited to 'drivers/infiniband/hw/mthca')
-rw-r--r-- | drivers/infiniband/hw/mthca/mthca_cq.c | 3 |
1 files changed, 2 insertions, 1 deletions
diff --git a/drivers/infiniband/hw/mthca/mthca_cq.c b/drivers/infiniband/hw/mthca/mthca_cq.c index 53157b86a1ba..40ba83338155 100644 --- a/drivers/infiniband/hw/mthca/mthca_cq.c +++ b/drivers/infiniband/hw/mthca/mthca_cq.c | |||
@@ -643,7 +643,8 @@ static inline int mthca_poll_one(struct mthca_dev *dev, | |||
643 | entry->wc_flags |= cqe->g_mlpath & 0x80 ? IB_WC_GRH : 0; | 643 | entry->wc_flags |= cqe->g_mlpath & 0x80 ? IB_WC_GRH : 0; |
644 | checksum = (be32_to_cpu(cqe->rqpn) >> 24) | | 644 | checksum = (be32_to_cpu(cqe->rqpn) >> 24) | |
645 | ((be32_to_cpu(cqe->my_ee) >> 16) & 0xff00); | 645 | ((be32_to_cpu(cqe->my_ee) >> 16) & 0xff00); |
646 | entry->csum_ok = (cqe->sl_ipok & 1 && checksum == 0xffff); | 646 | entry->wc_flags |= (cqe->sl_ipok & 1 && checksum == 0xffff) ? |
647 | IB_WC_IP_CSUM_OK : 0; | ||
647 | } | 648 | } |
648 | 649 | ||
649 | entry->status = IB_WC_SUCCESS; | 650 | entry->status = IB_WC_SUCCESS; |