Received: by 2002:a25:8b91:0:0:0:0:0 with SMTP id j17csp574725ybl; Fri, 24 Jan 2020 05:47:16 -0800 (PST) X-Google-Smtp-Source: APXvYqwTmp0CXCv3yQeWhpvE6X0FNX6+QIS9n9dx1E3zUFQrd4MvdasCImxp4+g/IJ+7IqV8ferx X-Received: by 2002:a9d:7618:: with SMTP id k24mr2766947otl.65.1579873636688; Fri, 24 Jan 2020 05:47:16 -0800 (PST) ARC-Seal: i=1; a=rsa-sha256; t=1579873636; cv=none; d=google.com; s=arc-20160816; b=qS1gSMa/wyIZp7bUFFPbJjIPAicVh+UldhONvjuA/D7nDMAVKmjIWzdar5rLUXnu/d Nwt+AMuMCkSFbKpKN94GzoIWVrPFvrkuJviUMqIxGxfhHh/2oMOSo6aqsRlljcvn0/F7 QEN9dxIKtRL5tmVfAlemi1KTuP4p/ZaNJd+m4YJrnBNG2S+OclYZC1VA/rnvGLR9cxxH zwOu1c8lzaUeGVf4RofaUYPMYX/9k++VRELYg6frftJ3Qf3zQI34HLuXIXprfYNq+gqg ytHIPh5qOGuN79nhSwrqPTgb2QSTdd6JCpdKI9NTiN+wGLl2ynuSf+yACOQLBJ/Lfo6w A8IQ== ARC-Message-Signature: i=1; a=rsa-sha256; c=relaxed/relaxed; d=google.com; s=arc-20160816; h=list-id:precedence:sender:content-transfer-encoding:mime-version :user-agent:references:in-reply-to:message-id:date:subject:cc:to :from:dkim-signature; bh=+2ccqoWpIFDXRF3t/QK+7gPOzkawyBJ1/zPYQTjIoHE=; b=Ct/oIp+svZ8+Ye0NoZV2pogHsUzDlA3sPAXtPf+OuO/CVBI2U2U+WzCWpxrmlwxArG 3lAc0k7XNr46tiKU3HJfCfXfbkmWWv0jA7UbBQx3Q5klTSHYS74+QvC1iur25oir7us2 dWCVupprwBZ0KmJPTcQzz4DNaKIvoo2CbqqG8wlJR0apEH6IIaOn64NK39wUb+TEAL6Z H8S2OO9qYxIQI3tdlVDtNRKf3qA0lDP42V9XLfn/aO/ejeeCCp0mY3TwZbiwChwHiDzM ZrmNGxuXs0QG7hTflYRRop4737uj8yBqFey/TRU7zw0cY5xugcVx2+5h+4Kn3/dUQdKG brlw== ARC-Authentication-Results: i=1; mx.google.com; dkim=pass header.i=@kernel.org header.s=default header.b=rer0DpVD; spf=pass (google.com: best guess record for domain of linux-kernel-owner@vger.kernel.org designates 209.132.180.67 as permitted sender) smtp.mailfrom=linux-kernel-owner@vger.kernel.org Return-Path: Received: from vger.kernel.org (vger.kernel.org. [209.132.180.67]) by mx.google.com with ESMTP id g138si2461812oib.190.2020.01.24.05.47.04; Fri, 24 Jan 2020 05:47:16 -0800 (PST) Received-SPF: pass (google.com: best guess record for domain of linux-kernel-owner@vger.kernel.org designates 209.132.180.67 as permitted sender) client-ip=209.132.180.67; Authentication-Results: mx.google.com; dkim=pass header.i=@kernel.org header.s=default header.b=rer0DpVD; spf=pass (google.com: best guess record for domain of linux-kernel-owner@vger.kernel.org designates 209.132.180.67 as permitted sender) smtp.mailfrom=linux-kernel-owner@vger.kernel.org Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S2388439AbgAXJ4t (ORCPT + 99 others); Fri, 24 Jan 2020 04:56:49 -0500 Received: from mail.kernel.org ([198.145.29.99]:60462 "EHLO mail.kernel.org" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S2388041AbgAXJ4o (ORCPT ); Fri, 24 Jan 2020 04:56:44 -0500 Received: from localhost (unknown [145.15.244.15]) (using TLSv1.2 with cipher ECDHE-RSA-AES256-GCM-SHA384 (256/256 bits)) (No client certificate requested) by mail.kernel.org (Postfix) with ESMTPSA id B7EF120718; Fri, 24 Jan 2020 09:56:42 +0000 (UTC) DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/simple; d=kernel.org; s=default; t=1579859803; bh=VEAXVtawNZWjqSncdjTQU1KbB8Ll62kkZMsKfIoEfbU=; h=From:To:Cc:Subject:Date:In-Reply-To:References:From; b=rer0DpVDStAnsMFFwfXUdBbwOKhnYV3KZP8UV6Hn0hgB/z9eaU/KExqgQs6+wyKBV rJ6mmZmk4LKfjZvw2r6hkVHWf22UH+wDkisyFBn0b7ROb9VMCuiq6i10iorEj8S+zS mpq+ic/mSjg73CdBPW1Ouu7NAuP5Xgo7JSzfMEWY= From: Greg Kroah-Hartman To: linux-kernel@vger.kernel.org Cc: Greg Kroah-Hartman , stable@vger.kernel.org, Jack Morgenstein , Leon Romanovsky , Jason Gunthorpe , Sasha Levin Subject: [PATCH 4.14 186/343] IB/mlx5: Add missing XRC options to QP optional params mask Date: Fri, 24 Jan 2020 10:30:04 +0100 Message-Id: <20200124092944.483089058@linuxfoundation.org> X-Mailer: git-send-email 2.25.0 In-Reply-To: <20200124092919.490687572@linuxfoundation.org> References: <20200124092919.490687572@linuxfoundation.org> User-Agent: quilt/0.66 MIME-Version: 1.0 Content-Type: text/plain; charset=UTF-8 Content-Transfer-Encoding: 8bit Sender: linux-kernel-owner@vger.kernel.org Precedence: bulk List-ID: X-Mailing-List: linux-kernel@vger.kernel.org From: Jack Morgenstein [ Upstream commit 8f4426aa19fcdb9326ac44154a117b1a3a5ae126 ] The QP transition optional parameters for the various transition for XRC QPs are identical to those for RC QPs. Many of the XRC QP transition optional parameter bits are missing from the QP optional mask table. These omissions caused failures when doing XRC QP state transitions. For example, when trying to change the response timer of an XRC receive QP via the RTS2RTS transition, the new timer value was ignored because MLX5_QP_OPTPAR_RNR_TIMEOUT bit was missing from the optional params mask for XRC qps for the RTS2RTS transition. Fix this by adding the missing XRC optional parameters for all QP transitions to the opt_mask table. Fixes: e126ba97dba9 ("mlx5: Add driver for Mellanox Connect-IB adapters") Fixes: a4774e9095de ("IB/mlx5: Fix opt param mask according to firmware spec") Signed-off-by: Jack Morgenstein Signed-off-by: Leon Romanovsky Signed-off-by: Jason Gunthorpe Signed-off-by: Sasha Levin --- drivers/infiniband/hw/mlx5/qp.c | 21 +++++++++++++++++++++ 1 file changed, 21 insertions(+) diff --git a/drivers/infiniband/hw/mlx5/qp.c b/drivers/infiniband/hw/mlx5/qp.c index 5a7dcb5afe6e3..84c962820aa2a 100644 --- a/drivers/infiniband/hw/mlx5/qp.c +++ b/drivers/infiniband/hw/mlx5/qp.c @@ -2357,6 +2357,11 @@ static enum mlx5_qp_optpar opt_mask[MLX5_QP_NUM_STATE][MLX5_QP_NUM_STATE][MLX5_Q [MLX5_QP_ST_UD] = MLX5_QP_OPTPAR_PKEY_INDEX | MLX5_QP_OPTPAR_Q_KEY | MLX5_QP_OPTPAR_PRI_PORT, + [MLX5_QP_ST_XRC] = MLX5_QP_OPTPAR_RRE | + MLX5_QP_OPTPAR_RAE | + MLX5_QP_OPTPAR_RWE | + MLX5_QP_OPTPAR_PKEY_INDEX | + MLX5_QP_OPTPAR_PRI_PORT, }, [MLX5_QP_STATE_RTR] = { [MLX5_QP_ST_RC] = MLX5_QP_OPTPAR_ALT_ADDR_PATH | @@ -2390,6 +2395,12 @@ static enum mlx5_qp_optpar opt_mask[MLX5_QP_NUM_STATE][MLX5_QP_NUM_STATE][MLX5_Q MLX5_QP_OPTPAR_RWE | MLX5_QP_OPTPAR_PM_STATE, [MLX5_QP_ST_UD] = MLX5_QP_OPTPAR_Q_KEY, + [MLX5_QP_ST_XRC] = MLX5_QP_OPTPAR_ALT_ADDR_PATH | + MLX5_QP_OPTPAR_RRE | + MLX5_QP_OPTPAR_RAE | + MLX5_QP_OPTPAR_RWE | + MLX5_QP_OPTPAR_PM_STATE | + MLX5_QP_OPTPAR_RNR_TIMEOUT, }, }, [MLX5_QP_STATE_RTS] = { @@ -2406,6 +2417,12 @@ static enum mlx5_qp_optpar opt_mask[MLX5_QP_NUM_STATE][MLX5_QP_NUM_STATE][MLX5_Q [MLX5_QP_ST_UD] = MLX5_QP_OPTPAR_Q_KEY | MLX5_QP_OPTPAR_SRQN | MLX5_QP_OPTPAR_CQN_RCV, + [MLX5_QP_ST_XRC] = MLX5_QP_OPTPAR_RRE | + MLX5_QP_OPTPAR_RAE | + MLX5_QP_OPTPAR_RWE | + MLX5_QP_OPTPAR_RNR_TIMEOUT | + MLX5_QP_OPTPAR_PM_STATE | + MLX5_QP_OPTPAR_ALT_ADDR_PATH, }, }, [MLX5_QP_STATE_SQER] = { @@ -2417,6 +2434,10 @@ static enum mlx5_qp_optpar opt_mask[MLX5_QP_NUM_STATE][MLX5_QP_NUM_STATE][MLX5_Q MLX5_QP_OPTPAR_RWE | MLX5_QP_OPTPAR_RAE | MLX5_QP_OPTPAR_RRE, + [MLX5_QP_ST_XRC] = MLX5_QP_OPTPAR_RNR_TIMEOUT | + MLX5_QP_OPTPAR_RWE | + MLX5_QP_OPTPAR_RAE | + MLX5_QP_OPTPAR_RRE, }, }, }; -- 2.20.1