Received: by 2002:ac0:946b:0:0:0:0:0 with SMTP id j40csp2726619imj; Mon, 11 Feb 2019 07:34:43 -0800 (PST) X-Google-Smtp-Source: AHgI3IYjfzYdSRO2OZtIYyb4ygDH+ZEWsMBDbhmVbBh0gQVwWdBKTRMDIYAg+UN51g6kRlv9MI7Z X-Received: by 2002:a62:12d5:: with SMTP id 82mr11443173pfs.255.1549899283891; Mon, 11 Feb 2019 07:34:43 -0800 (PST) ARC-Seal: i=1; a=rsa-sha256; t=1549899283; cv=none; d=google.com; s=arc-20160816; b=SsX62F63r/8slFr3FmnI1cPRMagg0CYXNQudu0YqefWWSvM5hstuLe00VRJjkuZXxF 2hoISRJ6kRMnT3hXvgCbcH01/gpacpcXbHRapSxRENztRTgBO4mRpZvCzh6LYzomfGnV 0Jl0jzaHHNIpBX4iBu22cjsvniRbV3c2gRUBFSzO8XRzgsk5g8IlxW+sgdzegRhw3ZvQ oFO48432eaFl0QnFB8VP6dD197MCOCFRbJLh1o/pebi7N5ttazcmDnn4tIa4uHfi3hvO ajhmDt+e8OUfD1IQugGlG/fLuWqEnCkXmO3m63kLnQD6At+QkkGJerZlFNydhqOE7rE8 1TQQ== 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=8EDf8u/53AvGF3zD9u8vh7CpTB/ciLEKpBR9QzAJfuU=; b=S/IXL7V7Uj9Y3sY+hqUd/mW1EJ3SqGr7JxohasJSE/JlFq7LqXmeMOhXdgE+vf5i5p DioHL2mMkYRbkkWwwaR0vAtj5QTv25LpPgVZegxtuPBw5JPxXblCMNRd0fsS+BlexQ9V BlTt7LxM+boJIyQ9LyeNEJxZZPdgpxswNHHfbkhCVQw3U9eIYkjhNWfmnAI5hOcnlk2D g7ZDdnLcELv3qt1EGN59Z/hdrEONKIUviSZBzlf8VQzbNgWEBUP5Do+nlT//Gg21rC7T V1nU61InPHwiHGR2AfXCFOJWiMSrDeXCuMNql/ZrmKfLNNXLg+IZqCHLmDuTg4xkolpv iMGg== ARC-Authentication-Results: i=1; mx.google.com; dkim=pass header.i=@kernel.org header.s=default header.b=rMiwHvZ5; 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 p1si10807251pld.353.2019.02.11.07.34.27; Mon, 11 Feb 2019 07:34:43 -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=rMiwHvZ5; 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 S2388668AbfBKOxl (ORCPT + 99 others); Mon, 11 Feb 2019 09:53:41 -0500 Received: from mail.kernel.org ([198.145.29.99]:40162 "EHLO mail.kernel.org" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S1729682AbfBKOxk (ORCPT ); Mon, 11 Feb 2019 09:53:40 -0500 Received: from localhost (5356596B.cm-6-7b.dynamic.ziggo.nl [83.86.89.107]) (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 0B2F920855; Mon, 11 Feb 2019 14:53:38 +0000 (UTC) DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/simple; d=kernel.org; s=default; t=1549896819; bh=GlQIYNAE6jRqKANaJ4A8vSe+jJI1X49qao2L/Msl244=; h=From:To:Cc:Subject:Date:In-Reply-To:References:From; b=rMiwHvZ5A4xoKB6TkJn4ZBm2VAqaDzwWrH1XFxYmsmZWClLeMV5mR4SFym1qBRJLd a1Iv7/ID8HXO9I4oXpLWURKXYAehUMnt8ck6Z5gLvBfnusC7kQKXOhoBfg5mTJLo4Z lYfN6ArzyVWRo7yIuWXpVzoDImvM0FL4EC/X0gtw= From: Greg Kroah-Hartman To: linux-kernel@vger.kernel.org Cc: Greg Kroah-Hartman , stable@vger.kernel.org, "Michael J. Ruhl" , Mike Marciniszyn , Dennis Dalessandro , Jason Gunthorpe Subject: [PATCH 4.19 312/313] IB/hfi1: Add limit test for RC/UC send via loopback Date: Mon, 11 Feb 2019 15:19:52 +0100 Message-Id: <20190211141913.632141883@linuxfoundation.org> X-Mailer: git-send-email 2.20.1 In-Reply-To: <20190211141852.749630980@linuxfoundation.org> References: <20190211141852.749630980@linuxfoundation.org> User-Agent: quilt/0.65 X-stable: review X-Patchwork-Hint: ignore 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 4.19-stable review patch. If anyone has any objections, please let me know. ------------------ From: Mike Marciniszyn commit 09ce351dff8e7636af0beb72cd4a86c3904a0500 upstream. Fix potential memory corruption and panic in loopback for IB_WR_SEND variants. The code blindly assumes the posted length will fit in the fetched rwqe, which is not a valid assumption. Fix by adding a limit test, and triggering the appropriate send completion and putting the QP in an error state. This mimics the handling for non-loopback QPs. Fixes: 15703461533a ("IB/{hfi1, qib, rdmavt}: Move ruc_loopback to rdmavt") Cc: #v4.20+ Reviewed-by: Michael J. Ruhl Signed-off-by: Mike Marciniszyn Signed-off-by: Dennis Dalessandro Signed-off-by: Jason Gunthorpe Signed-off-by: Greg Kroah-Hartman Signed-off-by: Mike Marciniszyn --- drivers/infiniband/hw/hfi1/ruc.c | 7 ++++++- drivers/infiniband/hw/qib/qib_ruc.c | 7 ++++++- 2 files changed, 12 insertions(+), 2 deletions(-) --- a/drivers/infiniband/hw/hfi1/ruc.c +++ b/drivers/infiniband/hw/hfi1/ruc.c @@ -278,6 +278,8 @@ send: goto op_err; if (!ret) goto rnr_nak; + if (wqe->length > qp->r_len) + goto inv_err; break; case IB_WR_RDMA_WRITE_WITH_IMM: @@ -445,7 +447,10 @@ op_err: goto err; inv_err: - send_status = IB_WC_REM_INV_REQ_ERR; + send_status = + sqp->ibqp.qp_type == IB_QPT_RC ? + IB_WC_REM_INV_REQ_ERR : + IB_WC_SUCCESS; wc.status = IB_WC_LOC_QP_OP_ERR; goto err; --- a/drivers/infiniband/hw/qib/qib_ruc.c +++ b/drivers/infiniband/hw/qib/qib_ruc.c @@ -274,6 +274,8 @@ again: goto op_err; if (!ret) goto rnr_nak; + if (wqe->length > qp->r_len) + goto inv_err; break; case IB_WR_RDMA_WRITE_WITH_IMM: @@ -434,7 +436,10 @@ op_err: goto err; inv_err: - send_status = IB_WC_REM_INV_REQ_ERR; + send_status = + sqp->ibqp.qp_type == IB_QPT_RC ? + IB_WC_REM_INV_REQ_ERR : + IB_WC_SUCCESS; wc.status = IB_WC_LOC_QP_OP_ERR; goto err;