diff options
author | Jack Morgenstein <jackm@dev.mellanox.co.il> | 2007-11-14 15:33:27 +0100 |
---|---|---|
committer | Roland Dreier <rolandd@cisco.com> | 2007-11-14 17:20:03 +0100 |
commit | e383d19e90cfbbf8e00512d44194ce175b3f60a2 (patch) | |
tree | fb1c2b81505605998cca9062d10b816784f6559f /drivers | |
parent | RDMA/cxgb3: Set the max_qp_init_rd_atom attribute in query_device (diff) | |
download | linux-e383d19e90cfbbf8e00512d44194ce175b3f60a2.tar.xz linux-e383d19e90cfbbf8e00512d44194ce175b3f60a2.zip |
mlx4_core: Fix thinko in QP destroy (incorrect bitmap_free)
Fix thinko in commit eaf559bf ("mlx4_core: Don't free special QPs in
QP number bitmap"). The old commit had the logic exactly backwards
and ended up freeing *only* special QPs, which not only left the
original bug in place but also introduced the problem that the QP
number bitmap would get full after a while.
Found by Dotan Barak of Mellanox.
Signed-off-by: Jack Morgenstein <jackm@dev.mellanox.co.il>
Signed-off-by: Roland Dreier <rolandd@cisco.com>
Diffstat (limited to 'drivers')
-rw-r--r-- | drivers/net/mlx4/qp.c | 2 |
1 files changed, 1 insertions, 1 deletions
diff --git a/drivers/net/mlx4/qp.c b/drivers/net/mlx4/qp.c index cc4b1be18219..42b47639c81c 100644 --- a/drivers/net/mlx4/qp.c +++ b/drivers/net/mlx4/qp.c @@ -240,7 +240,7 @@ void mlx4_qp_free(struct mlx4_dev *dev, struct mlx4_qp *qp) mlx4_table_put(dev, &qp_table->auxc_table, qp->qpn); mlx4_table_put(dev, &qp_table->qp_table, qp->qpn); - if (qp->qpn < dev->caps.sqp_start + 8) + if (qp->qpn >= dev->caps.sqp_start + 8) mlx4_bitmap_free(&qp_table->bitmap, qp->qpn); } EXPORT_SYMBOL_GPL(mlx4_qp_free); |