]> Pileus Git - ~andy/linux/blobdiff - drivers/net/mlx4/pd.c
Merge branch 'fixes' of git://git.kernel.org/pub/scm/linux/kernel/git/ieee1394/linux1...
[~andy/linux] / drivers / net / mlx4 / pd.c
index 5210a0f31413af234efdc0dc52c1519aa15eed86..1286b886dcea5d6f54f32f7e22374ee600fd36ca 100644 (file)
 #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;