diff options
| author | Thomas Gleixner <tglx@linutronix.de> | 2016-01-12 11:01:12 +0100 | 
|---|---|---|
| committer | Thomas Gleixner <tglx@linutronix.de> | 2016-01-12 11:01:12 +0100 | 
| commit | 1f16f116b01c110db20ab808562c8b8bc3ee3d6e (patch) | |
| tree | 44db563f64cf5f8d62af8f99a61e2b248c44ea3a /drivers/infiniband/hw/mlx4/srq.c | |
| parent | 03724ac3d48f8f0e3caf1d30fa134f8fd96c94e2 (diff) | |
| parent | f9eccf24615672896dc13251410c3f2f33a14f95 (diff) | |
Merge branches 'clockevents/4.4-fixes' and 'clockevents/4.5-fixes' of http://git.linaro.org/people/daniel.lezcano/linux into timers/urgent
Pull in fixes from Daniel Lezcano:
 - Fix the vt8500 timer leading to a system lock up when dealing with too
   small delta (Roman Volkov)
 - Select the CLKSRC_MMIO when the fsl_ftm_timer is enabled with COMPILE_TEST
   (Daniel Lezcano)
 - Prevent to compile timers using the 'iomem' API when the architecture has
   not HAS_IOMEM set (Richard Weinberger)
Diffstat (limited to 'drivers/infiniband/hw/mlx4/srq.c')
| -rw-r--r-- | drivers/infiniband/hw/mlx4/srq.c | 11 | 
1 files changed, 8 insertions, 3 deletions
| diff --git a/drivers/infiniband/hw/mlx4/srq.c b/drivers/infiniband/hw/mlx4/srq.c index dce5dfe3a70e..8d133c40fa0e 100644 --- a/drivers/infiniband/hw/mlx4/srq.c +++ b/drivers/infiniband/hw/mlx4/srq.c @@ -34,6 +34,7 @@  #include <linux/mlx4/qp.h>  #include <linux/mlx4/srq.h>  #include <linux/slab.h> +#include <linux/vmalloc.h>  #include "mlx4_ib.h"  #include "user.h" @@ -172,8 +173,12 @@ struct ib_srq *mlx4_ib_create_srq(struct ib_pd *pd,  		srq->wrid = kmalloc(srq->msrq.max * sizeof (u64), GFP_KERNEL);  		if (!srq->wrid) { -			err = -ENOMEM; -			goto err_mtt; +			srq->wrid = __vmalloc(srq->msrq.max * sizeof(u64), +					      GFP_KERNEL, PAGE_KERNEL); +			if (!srq->wrid) { +				err = -ENOMEM; +				goto err_mtt; +			}  		}  	} @@ -204,7 +209,7 @@ err_wrid:  	if (pd->uobject)  		mlx4_ib_db_unmap_user(to_mucontext(pd->uobject->context), &srq->db);  	else -		kfree(srq->wrid); +		kvfree(srq->wrid);  err_mtt:  	mlx4_mtt_cleanup(dev->dev, &srq->mtt); | 
