Received: by 2002:a05:6a10:8c0a:0:0:0:0 with SMTP id go10csp492863pxb; Wed, 3 Mar 2021 08:11:25 -0800 (PST) X-Google-Smtp-Source: ABdhPJzShQOtkrt/7dY4R8rAm5W/QF0cXVhcP5FVwPxV8PK8jYR0AAr/ERobHvOX+zhPyyxEofUN X-Received: by 2002:a17:907:1692:: with SMTP id hc18mr4714892ejc.265.1614787885116; Wed, 03 Mar 2021 08:11:25 -0800 (PST) ARC-Seal: i=1; a=rsa-sha256; t=1614787885; cv=none; d=google.com; s=arc-20160816; b=bo97lHUw1/T3xseWWQ2pk7nr7wEr1S7VWR6Pvj91/s3lU5Y8JnkSeMJqbSRycp1sq7 Z3owGF3T6pFmB1nXUPUyiXCYRv0OJ8c5rNvifTmZW3TJ18+y4aflKOifbJRA3mg/6c2z 8W/L0vryyBHcEMchDgEW2qlv+GsJ6KBF6gtC9GWvOsPMe9xYSqRhyyFfcM/FQWj/Iccu m+9OdCnx7mCsVruKJyiw76ZxMyE/wHVgAlmE5I29HmAJUyw9B8JTR7nfF0oTsVEct6Jc JeBGX4UhsgXUApNech82Fb08WnoA37ovRu9nTRFbnHHZofGSjhexLR01c5tPs5eqRcks 3D4g== ARC-Message-Signature: i=1; a=rsa-sha256; c=relaxed/relaxed; d=google.com; s=arc-20160816; h=list-id:precedence:content-transfer-encoding:mime-version :user-agent:references:in-reply-to:message-id:date:subject:cc:to :from:dkim-signature; bh=kgDT07CyQ8m4dtYLlZrAvOvSXnKI7nWnv1xush4Bzig=; b=m/iyLPDw2C/xcfTRSCwUSqGDlH3BTxWCdYl7Pts0VHjEaQ851LtD6a5XCnFC8AcLDe WLHRahKw7HIFcFpTyb4sHf01oiaetcKLXEpPIBOFVVUUHBTecCA56aqC4CoPVFNn8zFJ y8/WNfMmZRLkmcEr7j/ci94U7G1BAZvF1Zv7t1hyPOoUg9JPfDpFLBYu757dwQsgenNc 4gDgUn8GXcjls0ZKM+7FXoTUDUCUcGZLeJzkv2ORP1Rr6L/yaaZMV64wJiBfW1Z+QxaS 8ntnuk1FKpP3IAMbPJlZ9RUnoQmo5qxbThrRIbl4Xw8Xw1ZwizuB1EVyxT+xUwf8aJVw obyg== ARC-Authentication-Results: i=1; mx.google.com; dkim=pass header.i=@linuxfoundation.org header.s=korg header.b=eiU8olbP; spf=pass (google.com: domain of linux-kernel-owner@vger.kernel.org designates 23.128.96.18 as permitted sender) smtp.mailfrom=linux-kernel-owner@vger.kernel.org; dmarc=pass (p=NONE sp=NONE dis=NONE) header.from=linuxfoundation.org Return-Path: Received: from vger.kernel.org (vger.kernel.org. [23.128.96.18]) by mx.google.com with ESMTP id se15si6923467ejb.204.2021.03.03.08.10.39; Wed, 03 Mar 2021 08:11:25 -0800 (PST) Received-SPF: pass (google.com: domain of linux-kernel-owner@vger.kernel.org designates 23.128.96.18 as permitted sender) client-ip=23.128.96.18; Authentication-Results: mx.google.com; dkim=pass header.i=@linuxfoundation.org header.s=korg header.b=eiU8olbP; spf=pass (google.com: domain of linux-kernel-owner@vger.kernel.org designates 23.128.96.18 as permitted sender) smtp.mailfrom=linux-kernel-owner@vger.kernel.org; dmarc=pass (p=NONE sp=NONE dis=NONE) header.from=linuxfoundation.org Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S1346534AbhCAXtF (ORCPT + 99 others); Mon, 1 Mar 2021 18:49:05 -0500 Received: from mail.kernel.org ([198.145.29.99]:58726 "EHLO mail.kernel.org" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S239099AbhCASJW (ORCPT ); Mon, 1 Mar 2021 13:09:22 -0500 Received: by mail.kernel.org (Postfix) with ESMTPSA id 009C0651F9; Mon, 1 Mar 2021 17:20:12 +0000 (UTC) DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/simple; d=linuxfoundation.org; s=korg; t=1614619213; bh=w9zisUQUAS9w/SiuNx6MHff6SU7ALi5/FRiFoGc3Rf4=; h=From:To:Cc:Subject:Date:In-Reply-To:References:From; b=eiU8olbPd7D21mWuH6L/+nSvbYeCm8UZWtMT8Pa+8cfM30bAsAavw9AQz3dgyfDBF 2SyLXkycm0jAZAxbaXXsBHjEo8DiRhqXThw1fEGHZWq4fRA2I/sz6Ki7EHZjglKqsw 5orKUv5ck8d67K+F/WdEMEQvY9U4ac6fSFEaVRxI= From: Greg Kroah-Hartman To: linux-kernel@vger.kernel.org Cc: Greg Kroah-Hartman , stable@vger.kernel.org, Jason Gunthorpe , Chuck Lever , Sasha Levin Subject: [PATCH 5.10 374/663] svcrdma: Hold private mutex while invoking rdma_accept() Date: Mon, 1 Mar 2021 17:10:22 +0100 Message-Id: <20210301161200.356835363@linuxfoundation.org> X-Mailer: git-send-email 2.30.1 In-Reply-To: <20210301161141.760350206@linuxfoundation.org> References: <20210301161141.760350206@linuxfoundation.org> User-Agent: quilt/0.66 MIME-Version: 1.0 Content-Type: text/plain; charset=UTF-8 Content-Transfer-Encoding: 8bit Precedence: bulk List-ID: X-Mailing-List: linux-kernel@vger.kernel.org From: Chuck Lever [ Upstream commit 0ac24c320c4d89a9de6ec802591398b8675c7b3c ] RDMA core mutex locking was restructured by commit d114c6feedfe ("RDMA/cma: Add missing locking to rdma_accept()") [Aug 2020]. When lock debugging is enabled, the RPC/RDMA server trips over the new lockdep assertion in rdma_accept() because it doesn't call rdma_accept() from its CM event handler. As a temporary fix, have svc_rdma_accept() take the handler_mutex explicitly. In the meantime, let's consider how to restructure the RPC/RDMA transport to invoke rdma_accept() from the proper context. Calls to svc_rdma_accept() are serialized with calls to svc_rdma_free() by the generic RPC server layer. Suggested-by: Jason Gunthorpe Link: https://lore.kernel.org/linux-rdma/20210209154014.GO4247@nvidia.com/ Fixes: d114c6feedfe ("RDMA/cma: Add missing locking to rdma_accept()") Signed-off-by: Chuck Lever Signed-off-by: Sasha Levin --- net/sunrpc/xprtrdma/svc_rdma_transport.c | 6 +++--- 1 file changed, 3 insertions(+), 3 deletions(-) diff --git a/net/sunrpc/xprtrdma/svc_rdma_transport.c b/net/sunrpc/xprtrdma/svc_rdma_transport.c index fb044792b571c..5f7e3d12523fe 100644 --- a/net/sunrpc/xprtrdma/svc_rdma_transport.c +++ b/net/sunrpc/xprtrdma/svc_rdma_transport.c @@ -475,9 +475,6 @@ static struct svc_xprt *svc_rdma_accept(struct svc_xprt *xprt) if (!svc_rdma_post_recvs(newxprt)) goto errout; - /* Swap out the handler */ - newxprt->sc_cm_id->event_handler = svc_rdma_cma_handler; - /* Construct RDMA-CM private message */ pmsg.cp_magic = rpcrdma_cmp_magic; pmsg.cp_version = RPCRDMA_CMP_VERSION; @@ -498,7 +495,10 @@ static struct svc_xprt *svc_rdma_accept(struct svc_xprt *xprt) } conn_param.private_data = &pmsg; conn_param.private_data_len = sizeof(pmsg); + rdma_lock_handler(newxprt->sc_cm_id); + newxprt->sc_cm_id->event_handler = svc_rdma_cma_handler; ret = rdma_accept(newxprt->sc_cm_id, &conn_param); + rdma_unlock_handler(newxprt->sc_cm_id); if (ret) { trace_svcrdma_accept_err(newxprt, ret); goto errout; -- 2.27.0