Received: by 2002:a25:8b91:0:0:0:0:0 with SMTP id j17csp3859812ybl; Mon, 3 Feb 2020 07:54:47 -0800 (PST) X-Google-Smtp-Source: APXvYqyV09Li0pQ0r67q9T0AfPFGqWlYocf9F74MBAW3ogAI103RkBO/kvsseroTJRLp1ZJ8ioVz X-Received: by 2002:a05:6808:a83:: with SMTP id q3mr15533154oij.0.1580745287304; Mon, 03 Feb 2020 07:54:47 -0800 (PST) ARC-Seal: i=1; a=rsa-sha256; t=1580745287; cv=none; d=google.com; s=arc-20160816; b=0TlJ5WOUF+oXKnoUbj5o9NeXmGK9Mk/yhZ5ANa6Dy6qyAxk5lYePFta7RN/36oFYCI O42VBJR/QCNGFkP99SEamLDz4CDZX5ju1jHJP8KO5x44JczLClLE+WlOMd6Ht34hn0pU rlDmg5GbMdlZijycq1JXqwQcEppmEqMf8U+EjydhJyW8RAB90J9rgJEjd024ICm55LSB 4qxN541+oTpPdDDBldVYt8zkxgnbgJFynDAW4Qdq+aOLpuPKpO4ptv9V5drcboNgPDov sEsU10jvHeqHj1/wPenIniXNnSfgMHWwmI8ZU9czJVkF/o00M0vRKSqstA6gGwVkHPXo AOYg== ARC-Message-Signature: i=1; a=rsa-sha256; c=relaxed/relaxed; d=google.com; s=arc-20160816; h=list-id:precedence:sender:mime-version:references:in-reply-to :message-id:date:subject:cc:to:from:dkim-signature; bh=2R3886/w6q71uZmE3lqE7gZfMtiidQ+pH7InOJfEqaA=; b=t9LLkhOlpM9bhKdtLLKtZM+fPv+8C6yRj+uTxpoTpykqnBL2Dc6csBTywDfThECLab 89anBX0rnKM6Pu+DHX0vJkVtDAeHXStLaGFjtR7XTvaJGuS8gaqpMOLCBgo6J9/hwKCV fyv1y/qGArXWfLGH584KPfLsCTa2FIHwBHX9ioMSte/siOQntciPYDpjBjjkYmYVEMe8 LCL2EBlr9x8BuXXkqyrVnrCLX4JvWuGaX6x1bdY9puKAULZfffK1HjJZsWvVCRtlM11j tSsSbjYhn4JkiUfp3PKPzuAWlnkUzHKlJuAuAFhhiJ+T+UpAWSFH9SjWi4XndM/J2WDp w2ug== ARC-Authentication-Results: i=1; mx.google.com; dkim=pass header.i=@st.com header.s=STMicroelectronics header.b=pYxJkcwp; 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; dmarc=pass (p=NONE sp=NONE dis=NONE) header.from=st.com Return-Path: Received: from vger.kernel.org (vger.kernel.org. [209.132.180.67]) by mx.google.com with ESMTP id c64si8411165oig.178.2020.02.03.07.54.22; Mon, 03 Feb 2020 07:54:47 -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; dkim=pass header.i=@st.com header.s=STMicroelectronics header.b=pYxJkcwp; 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; dmarc=pass (p=NONE sp=NONE dis=NONE) header.from=st.com Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S1728254AbgBCNvW (ORCPT + 99 others); Mon, 3 Feb 2020 08:51:22 -0500 Received: from mx08-00178001.pphosted.com ([91.207.212.93]:11190 "EHLO mx07-00178001.pphosted.com" rhost-flags-OK-OK-OK-FAIL) by vger.kernel.org with ESMTP id S1728199AbgBCNvV (ORCPT ); Mon, 3 Feb 2020 08:51:21 -0500 Received: from pps.filterd (m0046660.ppops.net [127.0.0.1]) by mx07-00178001.pphosted.com (8.16.0.42/8.16.0.42) with SMTP id 013Dlotp027606; Mon, 3 Feb 2020 14:51:13 +0100 DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=st.com; h=from : to : cc : subject : date : message-id : in-reply-to : references : mime-version : content-type; s=STMicroelectronics; bh=2R3886/w6q71uZmE3lqE7gZfMtiidQ+pH7InOJfEqaA=; b=pYxJkcwpclhdj3teUM+ERViKiYiNKqnogvchmFlaycWKi5e1kEoEC7GZZ99ppL7rzGAC j/ppCsni1GqQbeo0ULFZJmH+tiTSnsP3ydim6TTkXLTXuGbpCjK1CCpIp8BUvblV3YUj +JtGCFDJZD9Uo2x/7r+uY6L72w2q2hkoxYlV8aAY2eY4Z19gyD3wxbkI/6v6tA4bEXKX vE0pXnUIAmhTORpTlt3m8fyePTDoGrAxB/AabbkUy3JvRz0rIcbOH9zAFSaGYatVX60Y SZLHk4jc/BEjotXDWTsCfVGqj5PZjTjW9yzbLvvtV6sx4Nn7tO65mF6zEqQE3UnmxQrZ TA== Received: from beta.dmz-eu.st.com (beta.dmz-eu.st.com [164.129.1.35]) by mx07-00178001.pphosted.com with ESMTP id 2xvybdsmtv-1 (version=TLSv1.2 cipher=ECDHE-RSA-AES256-GCM-SHA384 bits=256 verify=NOT); Mon, 03 Feb 2020 14:51:13 +0100 Received: from euls16034.sgp.st.com (euls16034.sgp.st.com [10.75.44.20]) by beta.dmz-eu.st.com (STMicroelectronics) with ESMTP id E48E410002A; Mon, 3 Feb 2020 14:51:08 +0100 (CET) Received: from Webmail-eu.st.com (sfhdag6node3.st.com [10.75.127.18]) by euls16034.sgp.st.com (STMicroelectronics) with ESMTP id D8BA72BE228; Mon, 3 Feb 2020 14:51:08 +0100 (CET) Received: from localhost (10.75.127.44) by SFHDAG6NODE3.st.com (10.75.127.18) with Microsoft SMTP Server (TLS) id 15.0.1473.3; Mon, 3 Feb 2020 14:51:08 +0100 From: To: Mark Brown , Maxime Coquelin , Alexandre Torgue , , , , CC: , , Lionel Debieve , Etienne Carriere Subject: [PATCH 2/2] spi: stm32-qspi: properly manage probe errors Date: Mon, 3 Feb 2020 14:50:48 +0100 Message-ID: <20200203135048.1299-3-patrice.chotard@st.com> X-Mailer: git-send-email 2.17.1 In-Reply-To: <20200203135048.1299-1-patrice.chotard@st.com> References: <20200203135048.1299-1-patrice.chotard@st.com> MIME-Version: 1.0 Content-Type: text/plain X-Originating-IP: [10.75.127.44] X-ClientProxiedBy: SFHDAG5NODE1.st.com (10.75.127.13) To SFHDAG6NODE3.st.com (10.75.127.18) X-Proofpoint-Virus-Version: vendor=fsecure engine=2.50.10434:6.0.138,18.0.572 definitions=2020-02-03_04:2020-02-02,2020-02-03 signatures=0 Sender: linux-kernel-owner@vger.kernel.org Precedence: bulk List-ID: X-Mailing-List: linux-kernel@vger.kernel.org From: Lionel Debieve Fix resource release issues when driver probe operation fails. Signed-off-by: Lionel Debieve Signed-off-by: Etienne Carriere Signed-off-by: Patrice Chotard --- drivers/spi/spi-stm32-qspi.c | 27 +++++++++++++++------------ 1 file changed, 15 insertions(+), 12 deletions(-) diff --git a/drivers/spi/spi-stm32-qspi.c b/drivers/spi/spi-stm32-qspi.c index 13bb64bf4c8f..d066f5144c3e 100644 --- a/drivers/spi/spi-stm32-qspi.c +++ b/drivers/spi/spi-stm32-qspi.c @@ -565,7 +565,7 @@ static int stm32_qspi_probe(struct platform_device *pdev) qspi->io_base = devm_ioremap_resource(dev, res); if (IS_ERR(qspi->io_base)) { ret = PTR_ERR(qspi->io_base); - goto err; + goto err_master_put; } qspi->phys_base = res->start; @@ -574,24 +574,26 @@ static int stm32_qspi_probe(struct platform_device *pdev) qspi->mm_base = devm_ioremap_resource(dev, res); if (IS_ERR(qspi->mm_base)) { ret = PTR_ERR(qspi->mm_base); - goto err; + goto err_master_put; } qspi->mm_size = resource_size(res); if (qspi->mm_size > STM32_QSPI_MAX_MMAP_SZ) { ret = -EINVAL; - goto err; + goto err_master_put; } irq = platform_get_irq(pdev, 0); - if (irq < 0) - return irq; + if (irq < 0) { + ret = irq; + goto err_master_put; + } ret = devm_request_irq(dev, irq, stm32_qspi_irq, 0, dev_name(dev), qspi); if (ret) { dev_err(dev, "failed to request irq\n"); - goto err; + goto err_master_put; } init_completion(&qspi->data_completion); @@ -599,26 +601,26 @@ static int stm32_qspi_probe(struct platform_device *pdev) qspi->clk = devm_clk_get(dev, NULL); if (IS_ERR(qspi->clk)) { ret = PTR_ERR(qspi->clk); - goto err; + goto err_master_put; } qspi->clk_rate = clk_get_rate(qspi->clk); if (!qspi->clk_rate) { ret = -EINVAL; - goto err; + goto err_master_put; } ret = clk_prepare_enable(qspi->clk); if (ret) { dev_err(dev, "can not enable the clock\n"); - goto err; + goto err_master_put; } rstc = devm_reset_control_get_exclusive(dev, NULL); if (IS_ERR(rstc)) { ret = PTR_ERR(rstc); if (ret == -EPROBE_DEFER) - goto err; + goto err_qspi_release; } else { reset_control_assert(rstc); udelay(2); @@ -629,7 +631,7 @@ static int stm32_qspi_probe(struct platform_device *pdev) platform_set_drvdata(pdev, qspi); ret = stm32_qspi_dma_setup(qspi); if (ret) - goto err; + goto err_qspi_release; mutex_init(&qspi->lock); @@ -645,8 +647,9 @@ static int stm32_qspi_probe(struct platform_device *pdev) if (!ret) return 0; -err: +err_qspi_release: stm32_qspi_release(qspi); +err_master_put: spi_master_put(qspi->ctrl); return ret; -- 2.17.1