From d2635525b0ff9e16a1245faf4f3ea3ba7cbeb602 Mon Sep 17 00:00:00 2001 From: Eli Cohen Date: Tue, 22 Mar 2011 22:38:48 +0000 Subject: [PATCH] --- yaml --- r: 242643 b: refs/heads/master c: 9ace5e0176f165f04537497143506621d33a0139 h: refs/heads/master i: 242641: 33007f6b99139bdd34ec62ec68803ae8a5b5b70b 242639: bb79789af0e5e8e1e18494e35ffdf63b7d1dd5b7 v: v3 --- [refs] | 2 +- trunk/drivers/net/mlx4/pd.c | 8 ++++++++ 2 files changed, 9 insertions(+), 1 deletion(-) diff --git a/[refs] b/[refs] index eb3ff91c5762..a9f306978501 100644 --- a/[refs] +++ b/[refs] @@ -1,2 +1,2 @@ --- -refs/heads/master: 42d1e017e2f040c3e3d62b6cfa3a26351a865d04 +refs/heads/master: 9ace5e0176f165f04537497143506621d33a0139 diff --git a/trunk/drivers/net/mlx4/pd.c b/trunk/drivers/net/mlx4/pd.c index 5210a0f31413..1286b886dcea 100644 --- a/trunk/drivers/net/mlx4/pd.c +++ b/trunk/drivers/net/mlx4/pd.c @@ -39,6 +39,10 @@ #include "mlx4.h" #include "icm.h" +enum { + MLX4_NUM_RESERVED_UARS = 8 +}; + int mlx4_pd_alloc(struct mlx4_dev *dev, u32 *pdn) { struct mlx4_priv *priv = mlx4_priv(dev); @@ -104,6 +108,10 @@ int mlx4_bf_alloc(struct mlx4_dev *dev, struct mlx4_bf *bf) if (!list_empty(&priv->bf_list)) uar = list_entry(priv->bf_list.next, struct mlx4_uar, bf_list); else { + if (mlx4_bitmap_avail(&priv->uar_table.bitmap) < MLX4_NUM_RESERVED_UARS) { + err = -ENOMEM; + goto out; + } uar = kmalloc(sizeof *uar, GFP_KERNEL); if (!uar) { err = -ENOMEM;