Received: by 2002:a25:868d:0:0:0:0:0 with SMTP id z13csp29121ybk; Tue, 12 May 2020 14:23:08 -0700 (PDT) X-Google-Smtp-Source: APiQypLFzsLV1ooie4W0VXs3aTUi+aUXIFL2soTErz5urBjKNrje78MWgT1qgIiShPZcoBa5zp+W X-Received: by 2002:a50:8dc2:: with SMTP id s2mr20365625edh.318.1589318588136; Tue, 12 May 2020 14:23:08 -0700 (PDT) ARC-Seal: i=1; a=rsa-sha256; t=1589318588; cv=none; d=google.com; s=arc-20160816; b=JE3ZSQ9jyhbxCA9JVLrSXodP+Vx+rMa9G5biBBz4zI4+rPtVq2wCthgus7dEIRP4tP Ke5RiMzGc0ZHvjgf711vPhN0XAxfnQv/8QxricW37zF06f8qfeijrOUqIvb3blVyAcRS pD3rFU938wMoaoPdvCXZDGBZBg9rMepPau7uy+pwQSzAsRn2zZdO868P2SJs+T41fcB1 fni+UKCHJrW+wmgJLHjGcM5jDyeH3lbKP1dtLSwhVtQVSCz2Zp1/4Kk2he6hKwoqijId 4oVBdZu6kOpOqWh5b2xB5LLBo7leNfjgtK9krzJKNjTaHEggAxZWBLm/zRwmIa4/IEAx 29dg== 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:cc:to:from :subject:dkim-signature; bh=cc9RbaP1PbGzDZ6es5NE10b7zglpoGibXUKC8RXcruk=; b=uTdWYHNJbZpf/4pao2X56ocsg2pQItc3/5/qXKsmEgEfDeQ0sjFwKk6GiH0bgWg8Y2 JE0H/CgB8cOBJBMX048QzxJkIAuoCSpttcNYvu7Lpq9Dv+QUlcKysFfe8aKK/mBex095 2Vx/61uj2ABeelWzsvy+73KVbhCE87po56NlwQF/sqJYYXixrV7V3ythkWVT/BJs9JIt Bdexy5frXq4fsXbr5ayRfbvUS9hHIuoYYLdcn1e8jaNF8fyYNIhiwh3Nfve/IFSfgZuE 050od5uvc7p5qocvX4q9Z/jsPDniXiQqW4pQxtP/2SIqWEiutf9LfyhOGxPbMbn/hW8/ mVUA== ARC-Authentication-Results: i=1; mx.google.com; dkim=fail header.i=@gmail.com header.s=20161025 header.b=K6feggtg; 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 s9si8153359ejz.335.2020.05.12.14.22.44; Tue, 12 May 2020 14:23:08 -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; dkim=fail header.i=@gmail.com header.s=20161025 header.b=K6feggtg; 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 S1730200AbgELVWX (ORCPT + 99 others); Tue, 12 May 2020 17:22:23 -0400 Received: from lindbergh.monkeyblade.net ([23.128.96.19]:46004 "EHLO lindbergh.monkeyblade.net" rhost-flags-OK-FAIL-OK-FAIL) by vger.kernel.org with ESMTP id S1728220AbgELVWX (ORCPT ); Tue, 12 May 2020 17:22:23 -0400 Received: from mail-qt1-x841.google.com (mail-qt1-x841.google.com [IPv6:2607:f8b0:4864:20::841]) by lindbergh.monkeyblade.net (Postfix) with ESMTPS id 02511C061A0C; Tue, 12 May 2020 14:22:23 -0700 (PDT) Received: by mail-qt1-x841.google.com with SMTP id p12so12410680qtn.13; Tue, 12 May 2020 14:22:22 -0700 (PDT) DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=gmail.com; s=20161025; h=sender:subject:from:to:cc:date:message-id:in-reply-to:references :user-agent:mime-version:content-transfer-encoding; bh=cc9RbaP1PbGzDZ6es5NE10b7zglpoGibXUKC8RXcruk=; b=K6feggtgkeIPWE2/KT5FV5O1Cqz25lEddS8v3A8wV9CgR4KlOX2PUYlLrbQCKBw5wj DiosAIJpkKF1uOkHxZHcnygTuSZwtzn/3dQyww3qWWCHzccrBEXol00XpfojmfkjG00e 4t9iberWW1D4wSPbionjja6jVdErmUOPl5IbDTE/e5fi+AFnzaTjVX2tJsqnmXoHpUhN udKLFcCbsCmuqQDIsYiI4SQ0oafvemDUUKCx5hqf8kXY0ZDccUkRZgdia290d9gRQWqj a9p1qXSq/AxmuGqUUyiIpF8NSp9eyktDavtVocZxEPAaAI7Wpky1+xboypmn/9SftPfx bnlQ== X-Google-DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=1e100.net; s=20161025; h=x-gm-message-state:sender:subject:from:to:cc:date:message-id :in-reply-to:references:user-agent:mime-version :content-transfer-encoding; bh=cc9RbaP1PbGzDZ6es5NE10b7zglpoGibXUKC8RXcruk=; b=lRHn9FY0yiZ99vCqe7yoUmm/hCHUfpP2Vsu85C7ZFBBDceMXxHT+G3JzJtb1xnB50F 4zN95hlYkYHixL8da55oJjr/+44GQfIvHjogwDX8kQNCTIe1vYjRskoaRnUwp4HQ5EQJ Cy+1pb2oM5QLkhrKNBH31b2teTVHXFrSfI1/Gp4Wy60p0Gl16n30GdiMSOChurEOS+ma C1IEAYHtH3UIi7m/K/duM9CLd4IQ0tIIKOWOJJu3Y/uWkSsIrsBV4iSJBqzmL2zyt3Ae oWmj2kBWAjK7LhRFXCXcM8fG0bM4QHYWakGkBKHQMrZr0Dxz/Mop/w39gQiqis1b/3v5 MSGA== X-Gm-Message-State: AGi0PuadXccyA/s+mxElW4bu4d0YAvgwow/GMM0jFJf3H0mA0VZ6cgpw IDPKkxcH0QdbhmVbn3N6xix0G3NB X-Received: by 2002:ac8:105:: with SMTP id e5mr11983950qtg.15.1589318542053; Tue, 12 May 2020 14:22:22 -0700 (PDT) Received: from gateway.1015granger.net (c-68-61-232-219.hsd1.mi.comcast.net. [68.61.232.219]) by smtp.gmail.com with ESMTPSA id w43sm4922425qtw.68.2020.05.12.14.22.21 (version=TLS1_2 cipher=ECDHE-ECDSA-AES128-GCM-SHA256 bits=128/128); Tue, 12 May 2020 14:22:21 -0700 (PDT) Received: from klimt.1015granger.net (klimt.1015granger.net [192.168.1.55]) by gateway.1015granger.net (8.14.7/8.14.7) with ESMTP id 04CLMK4c009881; Tue, 12 May 2020 21:22:20 GMT Subject: [PATCH v2 03/29] svcrdma: Clean up handling of get_rw_ctx errors From: Chuck Lever To: bfields@fieldses.org Cc: linux-nfs@vger.kernel.org, linux-rdma@vger.kernel.org Date: Tue, 12 May 2020 17:22:20 -0400 Message-ID: <20200512212220.5826.25025.stgit@klimt.1015granger.net> In-Reply-To: <20200512211640.5826.77139.stgit@klimt.1015granger.net> References: <20200512211640.5826.77139.stgit@klimt.1015granger.net> User-Agent: StGit/0.22-31-g4b47 MIME-Version: 1.0 Content-Type: text/plain; charset="utf-8" Content-Transfer-Encoding: 7bit Sender: linux-nfs-owner@vger.kernel.org Precedence: bulk List-ID: X-Mailing-List: linux-nfs@vger.kernel.org Clean up: Replace two dprintk call sites with a tracepoint. Signed-off-by: Chuck Lever --- include/trace/events/rpcrdma.h | 25 +++++++++++++++++++++++++ net/sunrpc/xprtrdma/svc_rdma_rw.c | 27 +++++++++++---------------- 2 files changed, 36 insertions(+), 16 deletions(-) diff --git a/include/trace/events/rpcrdma.h b/include/trace/events/rpcrdma.h index f231975064cb..aca9d0f3d769 100644 --- a/include/trace/events/rpcrdma.h +++ b/include/trace/events/rpcrdma.h @@ -1612,6 +1612,31 @@ TRACE_EVENT(svcrdma_dma_map_rw_err, ) ); +TRACE_EVENT(svcrdma_no_rwctx_err, + TP_PROTO( + const struct svcxprt_rdma *rdma, + unsigned int num_sges + ), + + TP_ARGS(rdma, num_sges), + + TP_STRUCT__entry( + __field(unsigned int, num_sges) + __string(device, rdma->sc_cm_id->device->name) + __string(addr, rdma->sc_xprt.xpt_remotebuf) + ), + + TP_fast_assign( + __entry->num_sges = num_sges; + __assign_str(device, rdma->sc_cm_id->device->name); + __assign_str(addr, rdma->sc_xprt.xpt_remotebuf); + ), + + TP_printk("addr=%s device=%s num_sges=%d", + __get_str(addr), __get_str(device), __entry->num_sges + ) +); + TRACE_EVENT(svcrdma_send_pullup, TP_PROTO( unsigned int len diff --git a/net/sunrpc/xprtrdma/svc_rdma_rw.c b/net/sunrpc/xprtrdma/svc_rdma_rw.c index db70709e165a..c2d49f607cfe 100644 --- a/net/sunrpc/xprtrdma/svc_rdma_rw.c +++ b/net/sunrpc/xprtrdma/svc_rdma_rw.c @@ -67,19 +67,22 @@ svc_rdma_get_rw_ctxt(struct svcxprt_rdma *rdma, unsigned int sges) ctxt = kmalloc(struct_size(ctxt, rw_first_sgl, SG_CHUNK_SIZE), GFP_KERNEL); if (!ctxt) - goto out; + goto out_noctx; INIT_LIST_HEAD(&ctxt->rw_list); } ctxt->rw_sg_table.sgl = ctxt->rw_first_sgl; if (sg_alloc_table_chained(&ctxt->rw_sg_table, sges, ctxt->rw_sg_table.sgl, - SG_CHUNK_SIZE)) { - kfree(ctxt); - ctxt = NULL; - } -out: + SG_CHUNK_SIZE)) + goto out_free; return ctxt; + +out_free: + kfree(ctxt); +out_noctx: + trace_svcrdma_no_rwctx_err(rdma, sges); + return NULL; } static void svc_rdma_put_rw_ctxt(struct svcxprt_rdma *rdma, @@ -456,7 +459,7 @@ svc_rdma_build_writes(struct svc_rdma_write_info *info, ctxt = svc_rdma_get_rw_ctxt(rdma, (write_len >> PAGE_SHIFT) + 2); if (!ctxt) - goto out_noctx; + return -ENOMEM; constructor(info, write_len, ctxt); ret = svc_rdma_rw_ctx_init(rdma, ctxt, seg_offset, seg_handle, @@ -484,10 +487,6 @@ svc_rdma_build_writes(struct svc_rdma_write_info *info, dprintk("svcrdma: inadequate space in Write chunk (%u)\n", info->wi_nsegs); return -E2BIG; - -out_noctx: - dprintk("svcrdma: no R/W ctxs available\n"); - return -ENOMEM; } /* Send one of an xdr_buf's kvecs by itself. To send a Reply @@ -637,7 +636,7 @@ static int svc_rdma_build_read_segment(struct svc_rdma_read_info *info, sge_no = PAGE_ALIGN(info->ri_pageoff + len) >> PAGE_SHIFT; ctxt = svc_rdma_get_rw_ctxt(cc->cc_rdma, sge_no); if (!ctxt) - goto out_noctx; + return -ENOMEM; ctxt->rw_nents = sge_no; sg = ctxt->rw_sg_table.sgl; @@ -676,10 +675,6 @@ static int svc_rdma_build_read_segment(struct svc_rdma_read_info *info, cc->cc_sqecount += ret; return 0; -out_noctx: - dprintk("svcrdma: no R/W ctxs available\n"); - return -ENOMEM; - out_overrun: dprintk("svcrdma: request overruns rq_pages\n"); return -EINVAL;