Received: by 2002:a05:6a10:f347:0:0:0:0 with SMTP id d7csp13009510pxu; Sat, 2 Jan 2021 21:54:39 -0800 (PST) X-Google-Smtp-Source: ABdhPJxltcKAFD/s0hBt1DyDRxqTcRmqFDTHelyxPiaIGcUtAH9lNn17aF85qnoy7ZdMJ876SFZY X-Received: by 2002:a05:6402:8da:: with SMTP id d26mr63424215edz.157.1609653279338; Sat, 02 Jan 2021 21:54:39 -0800 (PST) ARC-Seal: i=1; a=rsa-sha256; t=1609653279; cv=none; d=google.com; s=arc-20160816; b=UmUgfM3b1a0H24f60pJbD2vpF5me1NiVU+zX1Rl2Vn+vNvMplkna4wBeT9VaaSoPLI R22n5mG6Iqspy0QmG7L0nWGkICey0g+BxgGvhZxDqVorvLX9GkwQM+KtQzFZ+c1GDWj1 ShCqJzs6L9nrmMKB/G4WasjAjlaJ7bl+2OFJCXKA9EILWvCkSyrWqWiTSSKcP42AWE4T jM67zWEal+f5bZ6TEmiNUWPbpGUfuOFGuONU39mSLPJNzLcvdCYAwYR4/JPTnTjBkcqt vwQ+LeJGR4hjLFLLlsNdScTQaKQHj9BPtSpUfNy6jgqdu5p9rLt9mcHCNBUu752meqUc 5wpA== ARC-Message-Signature: i=1; a=rsa-sha256; c=relaxed/relaxed; d=google.com; s=arc-20160816; h=list-id:precedence:content-transfer-encoding:content-language :in-reply-to:mime-version:user-agent:date:message-id:from:references :to:subject:cc:ironport-sdr:ironport-sdr; bh=n4EabRt+umDIKob/k6HrHxFfQS67NK/ltcD0IB+ofAE=; b=AQ5SeAMDil5G6L4SKkgAU50R8lZi2pIhAWSqxUi6iu+5iC5Wrz2EBc1idERXD7egUp jl4UUFgxlXZzbQuRQNfvWFJYKldY7/bJMANSFO4HMHOo2+r5JbhsXtUCxcYuR5h345Rm QITVVqN5rQxvXaOJtWo9Xpo4evHsaqbNgFYqAXH3SJnAFNVC87wPp0hPFZgZpXMO8m2n C7I9q/fv/zV/pS7btCNzIaQAEhg5KHMPBWPrdk5Oxm35D7EH3kRVGoy8VWu3Qip35HSH OJThb0CjTqZBkEoxSiAzTMiOcoroW6wLFPIkjc3mkrUlzCgy4STzz/7gRThuUqsRkZyy 9mVA== ARC-Authentication-Results: i=1; mx.google.com; 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=fail (p=NONE sp=NONE dis=NONE) header.from=intel.com Return-Path: Received: from vger.kernel.org (vger.kernel.org. [23.128.96.18]) by mx.google.com with ESMTP id hb41si26164519ejc.81.2021.01.02.21.53.52; Sat, 02 Jan 2021 21:54:39 -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; 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=fail (p=NONE sp=NONE dis=NONE) header.from=intel.com Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S1726042AbhACFvQ (ORCPT + 99 others); Sun, 3 Jan 2021 00:51:16 -0500 Received: from mga17.intel.com ([192.55.52.151]:3749 "EHLO mga17.intel.com" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S1725275AbhACFvP (ORCPT ); Sun, 3 Jan 2021 00:51:15 -0500 IronPort-SDR: UedIH9wEWaFzvH3jRUuwCB7Uu4FB0Qh3sKHmdxRHKrhxuPfL9wnLSqabIt6UrmLKXZ4oGZXO6e BzLQ9NZti7kQ== X-IronPort-AV: E=McAfee;i="6000,8403,9852"; a="156639442" X-IronPort-AV: E=Sophos;i="5.78,471,1599548400"; d="scan'208";a="156639442" Received: from orsmga008.jf.intel.com ([10.7.209.65]) by fmsmga107.fm.intel.com with ESMTP/TLS/ECDHE-RSA-AES256-GCM-SHA384; 02 Jan 2021 21:49:30 -0800 IronPort-SDR: AZJ3z3f/50BAGBVx8UDBX5zmZx51m+XlxeNwiNuVsZHKwRwbKAFslm7Yam1MbcUTkq6wc4xLWU WtLbyvtH3ijQ== X-IronPort-AV: E=Sophos;i="5.78,471,1599548400"; d="scan'208";a="377891336" Received: from blu2-mobl3.ccr.corp.intel.com (HELO [10.255.29.85]) ([10.255.29.85]) by orsmga008-auth.jf.intel.com with ESMTP/TLS/ECDHE-RSA-AES256-GCM-SHA384; 02 Jan 2021 21:49:27 -0800 Cc: baolu.lu@linux.intel.com, kjlu@umn.edu, David Woodhouse , Joerg Roedel , Will Deacon , Jiang Liu , Thomas Gleixner , iommu@lists.linux-foundation.org, linux-kernel@vger.kernel.org Subject: Re: [PATCH] iommu/intel: Fix memleak in intel_irq_remapping_alloc To: dinghao.liu@zju.edu.cn References: <20210102095029.29053-1-dinghao.liu@zju.edu.cn> <18add30d-a830-c531-6fd2-58a1898b157f@linux.intel.com> <50870a42.15f1a.176c66eaf92.Coremail.dinghao.liu@zju.edu.cn> From: Lu Baolu Message-ID: <6e1ce9ac-ac17-2b16-84d3-a18c011768f2@linux.intel.com> Date: Sun, 3 Jan 2021 13:49:25 +0800 User-Agent: Mozilla/5.0 (Windows NT 10.0; Win64; x64; rv:78.0) Gecko/20100101 Thunderbird/78.6.0 MIME-Version: 1.0 In-Reply-To: <50870a42.15f1a.176c66eaf92.Coremail.dinghao.liu@zju.edu.cn> Content-Type: text/plain; charset=utf-8; format=flowed Content-Language: en-US Content-Transfer-Encoding: 7bit Precedence: bulk List-ID: X-Mailing-List: linux-kernel@vger.kernel.org On 2021/1/3 12:08, dinghao.liu@zju.edu.cn wrote: >> Hi, >> >> On 2021/1/2 17:50, Dinghao Liu wrote: >>> When irq_domain_get_irq_data() or irqd_cfg() fails >>> meanwhile i == 0, data allocated by kzalloc() has not >>> been freed before returning, which leads to memleak. >>> >>> Fixes: b106ee63abccb ("irq_remapping/vt-d: Enhance Intel IR driver to support hierarchical irqdomains") >>> Signed-off-by: Dinghao Liu >>> --- >>> drivers/iommu/intel/irq_remapping.c | 2 ++ >>> 1 file changed, 2 insertions(+) >>> >>> diff --git a/drivers/iommu/intel/irq_remapping.c b/drivers/iommu/intel/irq_remapping.c >>> index aeffda92b10b..cdaeed36750f 100644 >>> --- a/drivers/iommu/intel/irq_remapping.c >>> +++ b/drivers/iommu/intel/irq_remapping.c >>> @@ -1354,6 +1354,8 @@ static int intel_irq_remapping_alloc(struct irq_domain *domain, >>> irq_cfg = irqd_cfg(irq_data); >>> if (!irq_data || !irq_cfg) { >>> ret = -EINVAL; >>> + kfree(data); >>> + data = NULL; >> >> Do you need to check (i == 0) here? @data will not be used anymore as it >> goes to out branch, why setting it to NULL here? >> > > data will be passed to ire_data->chip_data when i == 0 and > intel_free_irq_resources() will free it on failure. Thus I Isn't it going to "goto out_free_data"? If "i == 0", the allocated @data won't be freed by intel_free_irq_resources(), hence memory leaking. Does this patch aim to fix this? Best regards, baolu > set it to NULL to prevent double-free. However, if we add > a check (i == 0) here, we will not need to set it to NULL. > If this is better, I will resend a new patch soon. > > Regards, > Dinghao >