Received: by 10.223.176.5 with SMTP id f5csp3417479wra; Mon, 29 Jan 2018 12:53:28 -0800 (PST) X-Google-Smtp-Source: AH8x227rn2Q05edHl9VNBoF4dj6A239MjAVduK2tWGB3309zv54sDfeFtF1cgqd7T8nypT5KCjM+ X-Received: by 10.101.74.5 with SMTP id s5mr23411566pgq.105.1517259208431; Mon, 29 Jan 2018 12:53:28 -0800 (PST) ARC-Seal: i=1; a=rsa-sha256; t=1517259208; cv=none; d=google.com; s=arc-20160816; b=cDQddNOgeaUN7Ms8GJDtPfiqfDiEGW3p9R5h4K62WTg5BOENZFltz/ZUA+vd2kS9N/ 7JXAxXD+qNZT5h3wa4x2CZk6TnbZr+z0AL1Pv7bQtDpVGxOT/lPUH7rC6AXw/1GOE2K+ XuwcM3k1Icfd3V0H/aXd2pQ3kLA+feO9ygcfNcEEWcPAsbCRXhPaHw+wjSCO0buumiZV kOFKAvh8rkAqhIJCCxm4FI+qL7BqR5ED+LMor+yETs7hgK9L2IwWLEeZ7v5vC2Whn+Bj SoKTN+dnCxloky/5js46XfTdBb0nWUTQsaNKlpHFywnO0yoVtO7UG7VkhFwWBBzPco8Z puqw== ARC-Message-Signature: i=1; a=rsa-sha256; c=relaxed/relaxed; d=google.com; s=arc-20160816; h=list-id:precedence:sender:mime-version:user-agent:references :in-reply-to:message-id:date:subject:cc:to:from :arc-authentication-results; bh=wfr9Mriye9DjZ68d+7VdnpPn52GcZqp+4Pa7ZgzZSkk=; b=UJLRpMdcR15ITebYLCTlQ9FH9Chg71lWU2rVSZ2e5TmUdGaXWGLnliXVRR7wL9hyfk e2qr0EP54wgRpcdyd81R8MY0zwheppSbt5R1hWPsoLrIi/VEYNwpWi6SZR5xEBLu2nsf Eph8Stb/OeS0CdhSndBFgshwuygZiLbm5UJwv1NkO0H6BU+2RcE60I5mAKHY1de3DDrX 2pD/uTetm1RDUTN9unLrYw8ic7o4UK+vuikbojFA0NKoSvx8Qs1JFYMNmG2GsARlS1ol cSPX235zfQtYhHSDpBUZyuSx3HxGMJBcz4FuskKrYigx0NZSIoU2zskeW7W/MxTp2v8n xSFw== ARC-Authentication-Results: i=1; mx.google.com; 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 m185si1496717pfc.278.2018.01.29.12.53.14; Mon, 29 Jan 2018 12:53:28 -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; 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 S1753613AbeA2Uvp (ORCPT + 99 others); Mon, 29 Jan 2018 15:51:45 -0500 Received: from mail.linuxfoundation.org ([140.211.169.12]:57682 "EHLO mail.linuxfoundation.org" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S1753516AbeA2UKk (ORCPT ); Mon, 29 Jan 2018 15:10:40 -0500 Received: from localhost (LFbn-1-12258-90.w90-92.abo.wanadoo.fr [90.92.71.90]) by mail.linuxfoundation.org (Postfix) with ESMTPSA id 6F6622F41; Mon, 29 Jan 2018 13:03:37 +0000 (UTC) From: Greg Kroah-Hartman To: linux-kernel@vger.kernel.org Cc: Greg Kroah-Hartman , stable@vger.kernel.org, Neil Horman , boyang@redhat.com, Shrikrishna Khare , "VMware, Inc." , "David S. Miller" Subject: [PATCH 4.4 70/74] vmxnet3: repair memory leak Date: Mon, 29 Jan 2018 13:57:15 +0100 Message-Id: <20180129123850.691793258@linuxfoundation.org> X-Mailer: git-send-email 2.16.1 In-Reply-To: <20180129123847.507563674@linuxfoundation.org> References: <20180129123847.507563674@linuxfoundation.org> User-Agent: quilt/0.65 MIME-Version: 1.0 Content-Type: text/plain; charset=UTF-8 Sender: linux-kernel-owner@vger.kernel.org Precedence: bulk List-ID: X-Mailing-List: linux-kernel@vger.kernel.org 4.4-stable review patch. If anyone has any objections, please let me know. ------------------ From: Neil Horman [ Upstream commit 848b159835ddef99cc4193083f7e786c3992f580 ] with the introduction of commit b0eb57cb97e7837ebb746404c2c58c6f536f23fa, it appears that rq->buf_info is improperly handled. While it is heap allocated when an rx queue is setup, and freed when torn down, an old line of code in vmxnet3_rq_destroy was not properly removed, leading to rq->buf_info[0] being set to NULL prior to its being freed, causing a memory leak, which eventually exhausts the system on repeated create/destroy operations (for example, when the mtu of a vmxnet3 interface is changed frequently. Fix is pretty straight forward, just move the NULL set to after the free. Tested by myself with successful results Applies to net, and should likely be queued for stable, please Signed-off-by: Neil Horman Reported-By: boyang@redhat.com CC: boyang@redhat.com CC: Shrikrishna Khare CC: "VMware, Inc." CC: David S. Miller Acked-by: Shrikrishna Khare Signed-off-by: David S. Miller Signed-off-by: Greg Kroah-Hartman --- drivers/net/vmxnet3/vmxnet3_drv.c | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) --- a/drivers/net/vmxnet3/vmxnet3_drv.c +++ b/drivers/net/vmxnet3/vmxnet3_drv.c @@ -1563,7 +1563,6 @@ static void vmxnet3_rq_destroy(struct vm rq->rx_ring[i].basePA); rq->rx_ring[i].base = NULL; } - rq->buf_info[i] = NULL; } if (rq->comp_ring.base) { @@ -1578,6 +1577,7 @@ static void vmxnet3_rq_destroy(struct vm (rq->rx_ring[0].size + rq->rx_ring[1].size); dma_free_coherent(&adapter->pdev->dev, sz, rq->buf_info[0], rq->buf_info_pa); + rq->buf_info[0] = rq->buf_info[1] = NULL; } }