diff options
author | Jack Morgenstein <jackm@mellanox.co.il> | 2006-03-20 05:35:34 -0500 |
---|---|---|
committer | Roland Dreier <rolandd@cisco.com> | 2006-03-24 18:47:27 -0500 |
commit | ded9ad721d220d47989177076a181ae1f1b93af5 (patch) | |
tree | 4cd58fe6bccaaa133fbba3f22729dda3e6cb213f /drivers/infiniband | |
parent | 0ef61db837c93d4377fabd37182bb6f83ea5ca70 (diff) |
IB/mthca: Check that SRQ WQE size does not exceed device's max value
Guarantee the calculated work queue entry size does not exceed the max
allowable WQE size when creating an SRQ. This is a problem with Arbel
in Tavor-compatibility mode because the current WQE size computation
method rounds up to next power of 2.
Signed-off-by: Jack Morgenstein <jackm@mellanox.co.il>
Signed-off-by: Roland Dreier <rolandd@cisco.com>
Diffstat (limited to 'drivers/infiniband')
-rw-r--r-- | drivers/infiniband/hw/mthca/mthca_srq.c | 4 |
1 files changed, 4 insertions, 0 deletions
diff --git a/drivers/infiniband/hw/mthca/mthca_srq.c b/drivers/infiniband/hw/mthca/mthca_srq.c index 47a6a754a591..4e671e00e42b 100644 --- a/drivers/infiniband/hw/mthca/mthca_srq.c +++ b/drivers/infiniband/hw/mthca/mthca_srq.c | |||
@@ -205,6 +205,10 @@ int mthca_alloc_srq(struct mthca_dev *dev, struct mthca_pd *pd, | |||
205 | ds = max(64UL, | 205 | ds = max(64UL, |
206 | roundup_pow_of_two(sizeof (struct mthca_next_seg) + | 206 | roundup_pow_of_two(sizeof (struct mthca_next_seg) + |
207 | srq->max_gs * sizeof (struct mthca_data_seg))); | 207 | srq->max_gs * sizeof (struct mthca_data_seg))); |
208 | |||
209 | if (ds > dev->limits.max_desc_sz) | ||
210 | return -EINVAL; | ||
211 | |||
208 | srq->wqe_shift = long_log2(ds); | 212 | srq->wqe_shift = long_log2(ds); |
209 | 213 | ||
210 | srq->srqn = mthca_alloc(&dev->srq_table.alloc); | 214 | srq->srqn = mthca_alloc(&dev->srq_table.alloc); |