diff options
author | Steve Wise <swise@opengridcomputing.com> | 2010-09-10 12:14:53 -0400 |
---|---|---|
committer | Roland Dreier <rolandd@cisco.com> | 2010-09-28 13:46:30 -0400 |
commit | 13fecb83b410b147343e6c7b0427d244ef77b526 (patch) | |
tree | 452a4df2f7703f74872d72a982fa703b03582280 /drivers | |
parent | af93fb5dcc6b1cba5fd0861d349b3f9c93144bc0 (diff) |
RDMA/cxgb4: Zero out ISGL padding
The HW design requires zeroing any pad in SGLs.
Signed-off-by: Steve Wise <swise@opengridcomputing.com>
Signed-off-by: Roland Dreier <rolandd@cisco.com>
Diffstat (limited to 'drivers')
-rw-r--r-- | drivers/infiniband/hw/cxgb4/qp.c | 4 |
1 files changed, 4 insertions, 0 deletions
diff --git a/drivers/infiniband/hw/cxgb4/qp.c b/drivers/infiniband/hw/cxgb4/qp.c index 4f5dd66da39d..bdbf54d517d9 100644 --- a/drivers/infiniband/hw/cxgb4/qp.c +++ b/drivers/infiniband/hw/cxgb4/qp.c | |||
@@ -263,6 +263,9 @@ static int build_immd(struct t4_sq *sq, struct fw_ri_immd *immdp, | |||
263 | rem -= len; | 263 | rem -= len; |
264 | } | 264 | } |
265 | } | 265 | } |
266 | len = roundup(plen + sizeof *immdp, 16) - (plen + sizeof *immdp); | ||
267 | if (len) | ||
268 | memset(dstp, 0, len); | ||
266 | immdp->op = FW_RI_DATA_IMMD; | 269 | immdp->op = FW_RI_DATA_IMMD; |
267 | immdp->r1 = 0; | 270 | immdp->r1 = 0; |
268 | immdp->r2 = 0; | 271 | immdp->r2 = 0; |
@@ -292,6 +295,7 @@ static int build_isgl(__be64 *queue_start, __be64 *queue_end, | |||
292 | if (++flitp == queue_end) | 295 | if (++flitp == queue_end) |
293 | flitp = queue_start; | 296 | flitp = queue_start; |
294 | } | 297 | } |
298 | *flitp = (__force __be64)0; | ||
295 | isglp->op = FW_RI_DATA_ISGL; | 299 | isglp->op = FW_RI_DATA_ISGL; |
296 | isglp->r1 = 0; | 300 | isglp->r1 = 0; |
297 | isglp->nsge = cpu_to_be16(num_sge); | 301 | isglp->nsge = cpu_to_be16(num_sge); |