Received: by 2002:a05:6a10:9848:0:0:0:0 with SMTP id x8csp3706947pxf; Mon, 5 Apr 2021 20:51:40 -0700 (PDT) X-Google-Smtp-Source: ABdhPJxbq6N0BQyBMqNvL7TuILF0sUBuIPbyA2rDoSyvSmtUT+ozVqFlc+CCp/d6xHF7afVOmrNQ X-Received: by 2002:a92:d78f:: with SMTP id d15mr22053419iln.112.1617681100802; Mon, 05 Apr 2021 20:51:40 -0700 (PDT) ARC-Seal: i=1; a=rsa-sha256; t=1617681100; cv=none; d=google.com; s=arc-20160816; b=FdQQPR1XqzZ4MfSlY/ZnxAbur1skJRNEIWU/pNu7PDOduKoAn+bMCys1xjIR9aUroI P+BW9uffFhYHEmhVc67l3OZvvWhOT5ubJjASYG5yaiTlRGc5ulmlWzq10GTKwyr9/ZWI VObhViWzCi3Uq9NdPTz3Kx4/UjBpA0FDoFcCzzZgT62wewVrNnNPncWocn+toOB3HNg9 pH3a+RyD3ZdSXhAE3ocUjUPDTi2Mnx0Rrp3m0Cl0uDABTaAuED1XVJtRQ0nputQg8Xr3 SsnhmpjiwVxG4fal415ziSMV0tp1I4mDvExXigGeDW5mXDvw3Lh/2VknsEHLRBMXXMYN mo4g== 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:to:from:subject; bh=watIRcpvFM0uXwHfuPI27SX1FOOdR3Vbh4xfmdsAak8=; b=PA56w72l/eypIkpSq23JlUB1iFHyQD8OXaPGIwzGWIHw6c5gi2UN40qkuRuUFEIAXF GC8VATdG15keu15rn4Jj7ozeAGLp0g2Ry4JrkkFgPhTakXQxvdZuHax5sb/dMaEu/DPC 7vk+dDjLRZ0bATclkYSvAaHLhs/+oZJv/Df6XG5FmqnCP7RwF4yikLiOev0bN7ULamZ5 Mj2azNoebXa/qi81A42m8VPFJbePksRnvvCp+efzkoljoyvV4MM67FTIbIqDTlwSH81a 6q6EnTy04A8jYHWJs/5c3zbJc6t4bfG5m6SMA/YDywifU/Ge9bNKxpodsD/wffqWjdDF X7Fg== ARC-Authentication-Results: i=1; mx.google.com; spf=pass (google.com: domain of linux-nfs-owner@vger.kernel.org designates 23.128.96.18 as permitted sender) smtp.mailfrom=linux-nfs-owner@vger.kernel.org; dmarc=fail (p=NONE sp=NONE dis=NONE) header.from=oracle.com Return-Path: Received: from vger.kernel.org (vger.kernel.org. [23.128.96.18]) by mx.google.com with ESMTP id g25si16392230ioc.83.2021.04.05.20.51.27; Mon, 05 Apr 2021 20:51:40 -0700 (PDT) Received-SPF: pass (google.com: domain of linux-nfs-owner@vger.kernel.org designates 23.128.96.18 as permitted sender) client-ip=23.128.96.18; Authentication-Results: mx.google.com; spf=pass (google.com: domain of linux-nfs-owner@vger.kernel.org designates 23.128.96.18 as permitted sender) smtp.mailfrom=linux-nfs-owner@vger.kernel.org; dmarc=fail (p=NONE sp=NONE dis=NONE) header.from=oracle.com Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S242443AbhDEQfb (ORCPT + 99 others); Mon, 5 Apr 2021 12:35:31 -0400 Received: from mail.kernel.org ([198.145.29.99]:40894 "EHLO mail.kernel.org" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S242432AbhDEQfb (ORCPT ); Mon, 5 Apr 2021 12:35:31 -0400 Received: by mail.kernel.org (Postfix) with ESMTPSA id B392D61398; Mon, 5 Apr 2021 16:35:24 +0000 (UTC) Subject: [PATCH v1 6/6] xprtrdma: Avoid Send Queue wrapping From: Chuck Lever To: linux-rdma@vger.kernel.org, linux-nfs@vger.kernel.org Date: Mon, 05 Apr 2021 12:35:24 -0400 Message-ID: <161764052395.29855.5602569735350576645.stgit@manet.1015granger.net> In-Reply-To: <161764034907.29855.614994107807503843.stgit@manet.1015granger.net> References: <161764034907.29855.614994107807503843.stgit@manet.1015granger.net> User-Agent: StGit/0.23-29-ga622f1 MIME-Version: 1.0 Content-Type: text/plain; charset="utf-8" Content-Transfer-Encoding: 7bit Precedence: bulk List-ID: X-Mailing-List: linux-nfs@vger.kernel.org Send WRs can be signalled or unsignalled. A signalled Send WR always has a matching Send completion, while a unsignalled Send has a completion only if the Send WR fails. xprtrdma has a Send account mechanism that is designed to reduce the number of signalled Send WRs. This in turn mitigates the interrupt rate of the underlying device. RDMA consumers can't leave all Sends unsignaled, however, because providers rely on Send completions to maintain their Send Queue head and tail pointers. xprtrdma counts the number of unsignaled Send WRs that have been posted to ensure that Sends are signalled often enough to prevent the Send Queue from wrapping. This mechanism neglected to account for FastReg WRs, which are posted on the Send Queue but never signalled. As a result, the Send Queue wrapped on occasion, resulting in duplication completions of FastReg and LocalInv WRs. Signed-off-by: Chuck Lever --- net/sunrpc/xprtrdma/frwr_ops.c | 17 +++++++++++++++-- net/sunrpc/xprtrdma/verbs.c | 16 +--------------- 2 files changed, 16 insertions(+), 17 deletions(-) diff --git a/net/sunrpc/xprtrdma/frwr_ops.c b/net/sunrpc/xprtrdma/frwr_ops.c index 951ae20485f3..43a412ea337a 100644 --- a/net/sunrpc/xprtrdma/frwr_ops.c +++ b/net/sunrpc/xprtrdma/frwr_ops.c @@ -390,11 +390,13 @@ static void frwr_cid_init(struct rpcrdma_ep *ep, */ int frwr_send(struct rpcrdma_xprt *r_xprt, struct rpcrdma_req *req) { + struct ib_send_wr *post_wr, *send_wr = &req->rl_wr; struct rpcrdma_ep *ep = r_xprt->rx_ep; - struct ib_send_wr *post_wr; struct rpcrdma_mr *mr; + unsigned int num_wrs; - post_wr = &req->rl_wr; + num_wrs = 1; + post_wr = send_wr; list_for_each_entry(mr, &req->rl_registered, mr_list) { struct rpcrdma_frwr *frwr; @@ -409,8 +411,19 @@ int frwr_send(struct rpcrdma_xprt *r_xprt, struct rpcrdma_req *req) frwr->fr_regwr.wr.send_flags = 0; post_wr = &frwr->fr_regwr.wr; + ++num_wrs; } + if ((kref_read(&req->rl_kref) > 1) || num_wrs > ep->re_send_count) { + send_wr->send_flags |= IB_SEND_SIGNALED; + ep->re_send_count = min_t(unsigned int, ep->re_send_batch, + num_wrs - ep->re_send_count); + } else { + send_wr->send_flags &= ~IB_SEND_SIGNALED; + ep->re_send_count -= num_wrs; + } + + trace_xprtrdma_post_send(req); return ib_post_send(ep->re_id->qp, post_wr, NULL); } diff --git a/net/sunrpc/xprtrdma/verbs.c b/net/sunrpc/xprtrdma/verbs.c index d4e573eef416..55c45cad2c8a 100644 --- a/net/sunrpc/xprtrdma/verbs.c +++ b/net/sunrpc/xprtrdma/verbs.c @@ -1365,21 +1365,7 @@ static void rpcrdma_regbuf_free(struct rpcrdma_regbuf *rb) */ int rpcrdma_post_sends(struct rpcrdma_xprt *r_xprt, struct rpcrdma_req *req) { - struct ib_send_wr *send_wr = &req->rl_wr; - struct rpcrdma_ep *ep = r_xprt->rx_ep; - int rc; - - if (!ep->re_send_count || kref_read(&req->rl_kref) > 1) { - send_wr->send_flags |= IB_SEND_SIGNALED; - ep->re_send_count = ep->re_send_batch; - } else { - send_wr->send_flags &= ~IB_SEND_SIGNALED; - --ep->re_send_count; - } - - trace_xprtrdma_post_send(req); - rc = frwr_send(r_xprt, req); - if (rc) + if (frwr_send(r_xprt, req)) return -ENOTCONN; return 0; }