diff options
| author | Takashi Iwai <tiwai@suse.de> | 2018-03-12 17:30:38 +0100 | 
|---|---|---|
| committer | Takashi Iwai <tiwai@suse.de> | 2018-03-12 17:30:38 +0100 | 
| commit | db45dc9540ea4864bb9d22eed30d3e70ed5d56d4 (patch) | |
| tree | c611d75097036ff464e9af31aa729e34c863ec93 /drivers/infiniband/hw/mlx5/qp.c | |
| parent | 40088dc4e1ead7df31728c73f5b51d71da18831d (diff) | |
| parent | a3e39ed1f40e14f24bec0f91c4fa0408fb6c4d02 (diff) | |
Merge tag 'asoc-fix-v4.16-rc5' of https://git.kernel.org/pub/scm/linux/kernel/git/broonie/sound into for-linus
ASoC: Fixes for v4.16
This is a fairly standard collection of fixes, there's no changes to the
core here just a bunch of small device specific changes for single
drivers plus an update to the MAINTAINERS file for the sgl5000.
Diffstat (limited to 'drivers/infiniband/hw/mlx5/qp.c')
| -rw-r--r-- | drivers/infiniband/hw/mlx5/qp.c | 11 | 
1 files changed, 9 insertions, 2 deletions
| diff --git a/drivers/infiniband/hw/mlx5/qp.c b/drivers/infiniband/hw/mlx5/qp.c index 39d24bf694a8..36197fbac63a 100644 --- a/drivers/infiniband/hw/mlx5/qp.c +++ b/drivers/infiniband/hw/mlx5/qp.c @@ -1584,6 +1584,7 @@ static int create_qp_common(struct mlx5_ib_dev *dev, struct ib_pd *pd,  	u32 uidx = MLX5_IB_DEFAULT_UIDX;  	struct mlx5_ib_create_qp ucmd;  	struct mlx5_ib_qp_base *base; +	int mlx5_st;  	void *qpc;  	u32 *in;  	int err; @@ -1592,6 +1593,10 @@ static int create_qp_common(struct mlx5_ib_dev *dev, struct ib_pd *pd,  	spin_lock_init(&qp->sq.lock);  	spin_lock_init(&qp->rq.lock); +	mlx5_st = to_mlx5_st(init_attr->qp_type); +	if (mlx5_st < 0) +		return -EINVAL; +  	if (init_attr->rwq_ind_tbl) {  		if (!udata)  			return -ENOSYS; @@ -1753,7 +1758,7 @@ static int create_qp_common(struct mlx5_ib_dev *dev, struct ib_pd *pd,  	qpc = MLX5_ADDR_OF(create_qp_in, in, qpc); -	MLX5_SET(qpc, qpc, st, to_mlx5_st(init_attr->qp_type)); +	MLX5_SET(qpc, qpc, st, mlx5_st);  	MLX5_SET(qpc, qpc, pm_state, MLX5_QP_PM_MIGRATED);  	if (init_attr->qp_type != MLX5_IB_QPT_REG_UMR) @@ -3095,8 +3100,10 @@ static int __mlx5_ib_modify_qp(struct ib_qp *ibqp,  		goto out;  	if (mlx5_cur >= MLX5_QP_NUM_STATE || mlx5_new >= MLX5_QP_NUM_STATE || -	    !optab[mlx5_cur][mlx5_new]) +	    !optab[mlx5_cur][mlx5_new]) { +		err = -EINVAL;  		goto out; +	}  	op = optab[mlx5_cur][mlx5_new];  	optpar = ib_mask_to_mlx5_opt(attr_mask); | 
