From patchwork Mon Aug 22 18:57:59 2016 Content-Type: text/plain; charset="utf-8" MIME-Version: 1.0 Content-Transfer-Encoding: 7bit X-Patchwork-Submitter: Chuck Lever III X-Patchwork-Id: 9294201 Return-Path: Received: from mail.wl.linuxfoundation.org (pdx-wl-mail.web.codeaurora.org [172.30.200.125]) by pdx-korg-patchwork.web.codeaurora.org (Postfix) with ESMTP id EFF53607F0 for ; Mon, 22 Aug 2016 18:59:22 +0000 (UTC) Received: from mail.wl.linuxfoundation.org (localhost [127.0.0.1]) by mail.wl.linuxfoundation.org (Postfix) with ESMTP id E3B852898D for ; Mon, 22 Aug 2016 18:59:22 +0000 (UTC) Received: by mail.wl.linuxfoundation.org (Postfix, from userid 486) id D8D0D28A30; Mon, 22 Aug 2016 18:59:22 +0000 (UTC) X-Spam-Checker-Version: SpamAssassin 3.3.1 (2010-03-16) on pdx-wl-mail.web.codeaurora.org X-Spam-Level: X-Spam-Status: No, score=-6.8 required=2.0 tests=BAYES_00,DKIM_SIGNED, RCVD_IN_DNSWL_HI,T_DKIM_INVALID autolearn=ham version=3.3.1 Received: from vger.kernel.org (vger.kernel.org [209.132.180.67]) by mail.wl.linuxfoundation.org (Postfix) with ESMTP id 897D22898D for ; Mon, 22 Aug 2016 18:59:22 +0000 (UTC) Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S1752564AbcHVS7U (ORCPT ); Mon, 22 Aug 2016 14:59:20 -0400 Received: from mail-it0-f66.google.com ([209.85.214.66]:33173 "EHLO mail-it0-f66.google.com" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S1753266AbcHVS7T (ORCPT ); Mon, 22 Aug 2016 14:59:19 -0400 Received: by mail-it0-f66.google.com with SMTP id d65so5559097ith.0; Mon, 22 Aug 2016 11:58:00 -0700 (PDT) DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=gmail.com; s=20120113; h=sender:subject:from:to:date:message-id:in-reply-to:references :user-agent:mime-version:content-transfer-encoding; bh=wDfNVPUUN6yVFnBFuWMhzumBAB05DjYHUKOzAiJTOQI=; b=lRgycd04BD+nfq3xHhKGwa7jUBJAdqX47KRXCvIlaI5n7C2rd2ikjhnZB0uuDz/I1Q ZedR+53QnxBncJ4+cSmIz2t7qIJFZfF21zlLrQh7kPpPWGdiloR5A2DTLf7IyHI0T3th 3ubOFnVXcLCtLR+ELreXw2co11ovCO97eSKIhtFOxm53d0JkxpuMDlAyZlZDU6O64dnr k7FpdpLxoLNgy27aL7fsymnVhsWLhM6O6I2eJnm4XhXS8t2D1WlnXxFtl5SWHX+NGpU/ 7V0Uu5ZCwi8vaWGr85URI9zQVlZZ2vywnfrLs/3Gq+yLO1SKV6My5cE2qMsE6/err8L2 gRHA== X-Google-DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=1e100.net; s=20130820; h=x-gm-message-state:sender:subject:from:to:date:message-id :in-reply-to:references:user-agent:mime-version :content-transfer-encoding; bh=wDfNVPUUN6yVFnBFuWMhzumBAB05DjYHUKOzAiJTOQI=; b=dQ5QHtrXqQF7PY0+GaIL3fMnPMDRvy2jqG3KOkQyZquaC4gz/Uq+iocSaJIA7QhVxD 1ugmI/PAMRDFdJlzXV5bZHl+5uAEtF6LtRAVzgt3F/OVUG5V7yrMJGxl8i+UqKFUy3Ld ZTA3z7Z3WAhr/MLQxvawMEiKpifkJmoa9NtBNq6nU14VLRcuEr2hycGjcQzfScNzTOBi V3vo/TZwS06H/RQCpQhplxVS7xiVKuZf7lOyTS9jm10/VUuEXYNvfDDQdjhz3toh9Lt3 jOjCDrQILrSljOokNhigONIqKlU4QrjpLq0JwVX9Qj29vO8UkaRbOys2UYIiMQChPpw1 cmWg== X-Gm-Message-State: AEkoous3NoEKp6wBtIgrmQUuUd9FfkA47/DINWgfFhpJJA10mPWOTOY5gTSt6emzRJcGQA== X-Received: by 10.36.107.211 with SMTP id v202mr21547458itc.51.1471892279808; Mon, 22 Aug 2016 11:57:59 -0700 (PDT) Received: from klimt.1015granger.net ([2604:8800:100:81fc:ec4:7aff:fe6c:6aa0]) by smtp.gmail.com with ESMTPSA id n10sm8266576ith.18.2016.08.22.11.57.59 (version=TLS1_2 cipher=ECDHE-RSA-AES128-GCM-SHA256 bits=128/128); Mon, 22 Aug 2016 11:57:59 -0700 (PDT) Subject: [PATCH v2 3/6] svcrdma: Skip put_page() when send_reply() fails From: Chuck Lever To: linux-rdma@vger.kernel.org, linux-nfs@vger.kernel.org Date: Mon, 22 Aug 2016 14:57:59 -0400 Message-ID: <20160822185759.12076.92949.stgit@klimt.1015granger.net> In-Reply-To: <20160822185459.12076.43516.stgit@klimt.1015granger.net> References: <20160822185459.12076.43516.stgit@klimt.1015granger.net> User-Agent: StGit/0.17.1-dirty MIME-Version: 1.0 Sender: linux-nfs-owner@vger.kernel.org Precedence: bulk List-ID: X-Mailing-List: linux-nfs@vger.kernel.org X-Virus-Scanned: ClamAV using ClamSMTP Message from syslogd@klimt at Aug 18 17:00:37 ... kernel:page:ffffea0020639b00 count:0 mapcount:0 mapping: (null) index:0x0 Aug 18 17:00:37 klimt kernel: flags: 0x2fffff80000000() Aug 18 17:00:37 klimt kernel: page dumped because: VM_BUG_ON_PAGE(page_ref_count(page) == 0) Aug 18 17:00:37 klimt kernel: kernel BUG at /home/cel/src/linux/linux-2.6/include/linux/mm.h:445! Aug 18 17:00:37 klimt kernel: RIP: 0010:[] svc_rdma_sendto+0x641/0x820 [rpcrdma] send_reply() assigns its page argument as the first page of ctxt. On error, send_reply() already invokes svc_rdma_put_context(ctxt, 1); which does a put_page() on that very page. No need to do that again as svc_rdma_sendto exits. Fixes: 3e1eeb980822 ("svcrdma: Close connection when a send error occurs") Signed-off-by: Chuck Lever --- net/sunrpc/xprtrdma/svc_rdma_sendto.c | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) -- To unsubscribe from this list: send the line "unsubscribe linux-nfs" in the body of a message to majordomo@vger.kernel.org More majordomo info at http://vger.kernel.org/majordomo-info.html diff --git a/net/sunrpc/xprtrdma/svc_rdma_sendto.c b/net/sunrpc/xprtrdma/svc_rdma_sendto.c index e5b49e6..3b95b19 100644 --- a/net/sunrpc/xprtrdma/svc_rdma_sendto.c +++ b/net/sunrpc/xprtrdma/svc_rdma_sendto.c @@ -621,7 +621,7 @@ int svc_rdma_sendto(struct svc_rqst *rqstp) ret = send_reply(rdma, rqstp, res_page, rdma_resp, vec, inline_bytes); if (ret < 0) - goto err1; + goto err0; svc_rdma_put_req_map(rdma, vec); dprintk("svcrdma: send_reply returns %d\n", ret);