Received: by 2002:a25:1985:0:0:0:0:0 with SMTP id 127csp2202074ybz; Sun, 26 Apr 2020 13:27:31 -0700 (PDT) X-Google-Smtp-Source: APiQypJkI1gFIiFLFYWBSJkv9G3Vq7sYXFcKw5tKpQ8zk2rbxq8w22aaRGh1nuWfqZUL4JzDsp8s X-Received: by 2002:a17:906:2a86:: with SMTP id l6mr17185294eje.273.1587932851307; Sun, 26 Apr 2020 13:27:31 -0700 (PDT) ARC-Seal: i=1; a=rsa-sha256; t=1587932851; cv=none; d=google.com; s=arc-20160816; b=YTGTxGQVsHg+cuV3xIrkCcOyswl9IIBtEC1edho1fe3UV66adg4a8TdMhF4m++YSr0 D063B5jFiz/sLzP+T442z/Hi/kXf4IiPEHGzOH24m5jtU8j04NARU9fdt04JQv3IjGrc NNOzm5jhslJvPygcxujCSK1a0IrskMQWPhlVpmm04nvdaO+5NzjOi9eG84jih6jEBIl4 JOSke+i5MZrcF75Z9LJ2mWsMguXj7Wd9EVQ90SPTB0D85YIwW9ZfNh5FsCQZyva03Kc4 utVO2qzE/RhKywF5+YW3mb7DBMObTnHvXh2cvN3s01lx+8bKagukZotjtWm+n/lFFJu+ jnvQ== 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 :message-id:date:subject:cc:to:from; bh=1pzwZcG4j8zNSOn4aTWz5Orh4hfBpyUZ8Pxt19yPPC4=; b=n7C1DoVLorXlxyINaAfA7S6axIs03F9yKFj+X0/GPpW5hHrI4umIKg0dBeRZgqWqL9 lpKxOfiY4X4m8+mWr+D3ZULTy91gkk/4kExQ/1WBV95vT/WpnQwC9QeU0GNZ7FnJ225y JmjILZ3F3mZ7vF26rUTXeyUVifNA5aKbD0cbHqJezGq01v+W0dBtj5JVh8o1U/udZsQf Zdq2lKBCyh/wfb5tUJBipElcgTj/JGLF2/S7h4Bseh6C2G6Pl661T4AzTxDr2p8y3SHb SjAFwAxbpJoNDwKZpohhFm6jZdDFi+6c5AVi/z+ZjoetUbULU5SfNV0Tz7nb219HqaA/ fERQ== 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 Return-Path: Received: from vger.kernel.org (vger.kernel.org. [23.128.96.18]) by mx.google.com with ESMTP id x5si7202698edr.583.2020.04.26.13.26.54; Sun, 26 Apr 2020 13:27:31 -0700 (PDT) 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 Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S1726233AbgDZUYB (ORCPT + 99 others); Sun, 26 Apr 2020 16:24:01 -0400 Received: from smtp06.smtpout.orange.fr ([80.12.242.128]:47926 "EHLO smtp.smtpout.orange.fr" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S1726196AbgDZUYB (ORCPT ); Sun, 26 Apr 2020 16:24:01 -0400 Received: from localhost.localdomain ([93.23.12.11]) by mwinf5d64 with ME id XYPx2200C0EJ3pp03YPyzM; Sun, 26 Apr 2020 22:23:59 +0200 X-ME-Helo: localhost.localdomain X-ME-Auth: Y2hyaXN0b3BoZS5qYWlsbGV0QHdhbmFkb28uZnI= X-ME-Date: Sun, 26 Apr 2020 22:23:59 +0200 X-ME-IP: 93.23.12.11 From: Christophe JAILLET To: ulf.hansson@linaro.org, drake@endlessm.com, kamlesh.gurudasani@gmail.com, colin.king@canonical.com, linux@rempel-privat.de Cc: linux-mmc@vger.kernel.org, linux-kernel@vger.kernel.org, kernel-janitors@vger.kernel.org, Christophe JAILLET Subject: [PATCH] mmc: alcor: Fix a resource leak in an error handling path in 'alcor_pci_sdmmc_drv_probe()' Date: Sun, 26 Apr 2020 22:23:55 +0200 Message-Id: <20200426202355.43055-1-christophe.jaillet@wanadoo.fr> X-Mailer: git-send-email 2.25.1 MIME-Version: 1.0 Content-Transfer-Encoding: 8bit Sender: linux-kernel-owner@vger.kernel.org Precedence: bulk List-ID: X-Mailing-List: linux-kernel@vger.kernel.org If 'devm_request_threaded_irq()' fails, resources allocated by 'mmc_alloc_host()' must be freed. Fixes: c5413ad815a6 ("mmc: add new Alcor Micro Cardreader SD/MMC driver") Signed-off-by: Christophe JAILLET --- drivers/mmc/host/alcor.c | 6 +++++- 1 file changed, 5 insertions(+), 1 deletion(-) diff --git a/drivers/mmc/host/alcor.c b/drivers/mmc/host/alcor.c index 1aee485d56d4..026ca9194ce5 100644 --- a/drivers/mmc/host/alcor.c +++ b/drivers/mmc/host/alcor.c @@ -1104,7 +1104,7 @@ static int alcor_pci_sdmmc_drv_probe(struct platform_device *pdev) if (ret) { dev_err(&pdev->dev, "Failed to get irq for data line\n"); - return ret; + goto free_host; } mutex_init(&host->cmd_mutex); @@ -1116,6 +1116,10 @@ static int alcor_pci_sdmmc_drv_probe(struct platform_device *pdev) dev_set_drvdata(&pdev->dev, host); mmc_add_host(mmc); return 0; + +free_host: + mmc_free_host(mmc); + return ret; } static int alcor_pci_sdmmc_drv_remove(struct platform_device *pdev) -- 2.25.1