Received: by 2002:ad5:474a:0:0:0:0:0 with SMTP id i10csp472603imu; Mon, 5 Nov 2018 04:04:52 -0800 (PST) X-Google-Smtp-Source: AJdET5d6yzi8xNpsODjElb04nwZTINl50Z4jXM2QzZ4Xg31hyrsFb489pXP1iDdV0LZ+AmmsjBKM X-Received: by 2002:a63:ed09:: with SMTP id d9-v6mr19671568pgi.305.1541419492596; Mon, 05 Nov 2018 04:04:52 -0800 (PST) ARC-Seal: i=1; a=rsa-sha256; t=1541419492; cv=none; d=google.com; s=arc-20160816; b=SwD/hdFB5DNkheeNbwTQgi6U0vq2OFMxiSF8XUmyahk/0hg7QrnrB2hFQPkr2n0z9u E8Me13JUaUUgLGWVCnOZDrqHfHiJ4RfInF4/l8hnOfnbrncR9LqxHZ5MjvI4YTneRDY9 hc/BIwk7cW03xAOWyMdOHnBV6/eB6iJ4fdgGr2LhExGK5kHAkz83XfjEIstfn4e3diuE XwHmuieQqtZDKv8wwb376LF73CKGxSEwn83FLI9UEKh1jipSdbnlVx2/xSwm68y2sEUB 0IiXsO43CnloVcW6KRWxvNQHjL8+r0Ppk1v1KIgQn7jxTNk2jHMCBfA2MS+d+LM+32WV YcZw== ARC-Message-Signature: i=1; a=rsa-sha256; c=relaxed/relaxed; d=google.com; s=arc-20160816; h=list-id:precedence:sender:date:message-id:in-reply-to:subject:cc:to :from:dkim-signature; bh=nXSRv8x5bNPPK9GWrikJWsKHaKaxYbqnOozf/4jj5I8=; b=g1kESN2IyKqF+jzZSV07/JhvngBvGTK/HXeegdrEGj+GemlcXe3VZ3hnoRaGRlCY6g +fDTqGTQoempGh70va7g056s+XQxTfbgEj+Thqh5tYENTulHGj0EkTm7ddEs/VmkNvsf tCBR1JxVnEvIPzE62vrmoxlOGMU1mSzewnAzqdLcpoGbqN4dTkBCJbVmceDg/7CtShW6 4eIXlvTqLF6j3jjgEWi2tLhvTOFdEj669VvCHtSxngoQlF9b6fWKbB0bCxFeQQM20j+e c8h7CbStL3p3xFrG5kSpy2/N8/DAUiCTWbwOJLWzOEUtnA3ZMBxfac+lg5xpXhkysqeI ImUw== ARC-Authentication-Results: i=1; mx.google.com; dkim=fail header.i=@sirena.org.uk header.s=20170815-heliosphere header.b="PfAzt8/t"; 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=fail (p=NONE sp=NONE dis=NONE) header.from=kernel.org Return-Path: Received: from vger.kernel.org (vger.kernel.org. [209.132.180.67]) by mx.google.com with ESMTP id w5-v6si44067101pgj.506.2018.11.05.04.04.18; Mon, 05 Nov 2018 04:04:52 -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=fail header.i=@sirena.org.uk header.s=20170815-heliosphere header.b="PfAzt8/t"; 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=fail (p=NONE sp=NONE dis=NONE) header.from=kernel.org Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S1729466AbeKEVXP (ORCPT + 99 others); Mon, 5 Nov 2018 16:23:15 -0500 Received: from heliosphere.sirena.org.uk ([172.104.155.198]:48334 "EHLO heliosphere.sirena.org.uk" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S1726723AbeKEVXO (ORCPT ); Mon, 5 Nov 2018 16:23:14 -0500 DKIM-Signature: v=1; a=rsa-sha256; q=dns/txt; c=relaxed/relaxed; d=sirena.org.uk; s=20170815-heliosphere; h=Date:Message-Id:In-Reply-To: Subject:Cc:To:From:Sender:Reply-To:MIME-Version:Content-Type: Content-Transfer-Encoding:Content-ID:Content-Description:Resent-Date: Resent-From:Resent-Sender:Resent-To:Resent-Cc:Resent-Message-ID:References: List-Id:List-Help:List-Unsubscribe:List-Subscribe:List-Post:List-Owner: List-Archive; bh=nXSRv8x5bNPPK9GWrikJWsKHaKaxYbqnOozf/4jj5I8=; b=PfAzt8/tkCNq ySe/mHnAmMVfXdQytRjd5HvmOqgenZqyD9nlEIRUuNL5WoMTT8MtdyoOcB73j0k23rJ+CLz4YRiVk vgiUNmGMz6GcwbxXzir6ZP43r5EwDs1ZOGuuwMlekNjluaSRRqRXVMEQN3Am3DInW1przdJSLx7ML JRbEU=; Received: from cpc102320-sgyl38-2-0-cust46.18-2.cable.virginm.net ([82.37.168.47] helo=debutante.sirena.org.uk) by heliosphere.sirena.org.uk with esmtpa (Exim 4.89) (envelope-from ) id 1gJdbf-0008Km-9z; Mon, 05 Nov 2018 12:03:47 +0000 Received: by debutante.sirena.org.uk (Postfix, from userid 1000) id 0C2521124D98; Mon, 5 Nov 2018 12:03:47 +0000 (GMT) From: Mark Brown To: Alok Chauhan Cc: Mark Brown , swboyd@chromium.org, dianders@chromium.org, Mark Brown , linux-spi@vger.kernel.org, linux-kernel@vger.kernel.org, linux-arm-msm@vger.kernel.org, linux-spi@vger.kernel.org Subject: Applied "spi: spi-geni-qcom: Simplify probe function" to the spi tree In-Reply-To: <1540485629-5970-3-git-send-email-alokc@codeaurora.org> Message-Id: <20181105120347.0C2521124D98@debutante.sirena.org.uk> Date: Mon, 5 Nov 2018 12:03:47 +0000 (GMT) Sender: linux-kernel-owner@vger.kernel.org Precedence: bulk List-ID: X-Mailing-List: linux-kernel@vger.kernel.org The patch spi: spi-geni-qcom: Simplify probe function has been applied to the spi tree at https://git.kernel.org/pub/scm/linux/kernel/git/broonie/spi.git All being well this means that it will be integrated into the linux-next tree (usually sometime in the next 24 hours) and sent to Linus during the next merge window (or sooner if it is a bug fix), however if problems are discovered then the patch may be dropped or reverted. You may get further e-mails resulting from automated or manual testing and review of the tree, please engage with people reporting problems and send followup patches addressing any issues that are reported if needed. If any updates are required or you are submitting further changes they should be sent as incremental updates against current git, existing patches will not be replaced. Please add any relevant lists and maintainers to the CCs when replying to this mail. Thanks, Mark From 6a34e285de9afc4441ee81ce76865acd30ed9263 Mon Sep 17 00:00:00 2001 From: Alok Chauhan Date: Thu, 25 Oct 2018 22:10:29 +0530 Subject: [PATCH] spi: spi-geni-qcom: Simplify probe function Re-arrange existing APIs in probe function to avoid using goto and remove redundant variables. Signed-off-by: Alok Chauhan Reviewed-by: Douglas Anderson Reviewed-by: Stephen Boyd Signed-off-by: Mark Brown --- drivers/spi/spi-geni-qcom.c | 49 ++++++++++++++++++------------------- 1 file changed, 24 insertions(+), 25 deletions(-) diff --git a/drivers/spi/spi-geni-qcom.c b/drivers/spi/spi-geni-qcom.c index d1830fbf2fc6..fdb7cb88fb56 100644 --- a/drivers/spi/spi-geni-qcom.c +++ b/drivers/spi/spi-geni-qcom.c @@ -535,11 +535,30 @@ static irqreturn_t geni_spi_isr(int irq, void *data) static int spi_geni_probe(struct platform_device *pdev) { - int ret; + int ret, irq; struct spi_master *spi; struct spi_geni_master *mas; struct resource *res; - struct geni_se *se; + void __iomem *base; + struct clk *clk; + + irq = platform_get_irq(pdev, 0); + if (irq < 0) { + dev_err(&pdev->dev, "Err getting IRQ %d\n", irq); + return irq; + } + + res = platform_get_resource(pdev, IORESOURCE_MEM, 0); + base = devm_ioremap_resource(&pdev->dev, res); + if (IS_ERR(base)) + return PTR_ERR(base); + + clk = devm_clk_get(&pdev->dev, "se"); + if (IS_ERR(clk)) { + dev_err(&pdev->dev, "Err getting SE Core clk %ld\n", + PTR_ERR(clk)); + return PTR_ERR(clk); + } spi = spi_alloc_master(&pdev->dev, sizeof(*mas)); if (!spi) @@ -547,27 +566,15 @@ static int spi_geni_probe(struct platform_device *pdev) platform_set_drvdata(pdev, spi); mas = spi_master_get_devdata(spi); + mas->irq = irq; mas->dev = &pdev->dev; mas->se.dev = &pdev->dev; mas->se.wrapper = dev_get_drvdata(pdev->dev.parent); - se = &mas->se; + mas->se.base = base; + mas->se.clk = clk; spi->bus_num = -1; spi->dev.of_node = pdev->dev.of_node; - mas->se.clk = devm_clk_get(&pdev->dev, "se"); - if (IS_ERR(mas->se.clk)) { - ret = PTR_ERR(mas->se.clk); - dev_err(&pdev->dev, "Err getting SE Core clk %d\n", ret); - goto spi_geni_probe_err; - } - - res = platform_get_resource(pdev, IORESOURCE_MEM, 0); - se->base = devm_ioremap_resource(&pdev->dev, res); - if (IS_ERR(se->base)) { - ret = PTR_ERR(se->base); - goto spi_geni_probe_err; - } - spi->mode_bits = SPI_CPOL | SPI_CPHA | SPI_LOOP | SPI_CS_HIGH; spi->bits_per_word_mask = SPI_BPW_RANGE_MASK(4, 32); spi->num_chipselect = 4; @@ -586,13 +593,6 @@ static int spi_geni_probe(struct platform_device *pdev) if (ret) goto spi_geni_probe_runtime_disable; - mas->irq = platform_get_irq(pdev, 0); - if (mas->irq < 0) { - ret = mas->irq; - dev_err(&pdev->dev, "Err getting IRQ %d\n", ret); - goto spi_geni_probe_runtime_disable; - } - ret = request_irq(mas->irq, geni_spi_isr, IRQF_TRIGGER_HIGH, "spi_geni", spi); if (ret) @@ -607,7 +607,6 @@ static int spi_geni_probe(struct platform_device *pdev) free_irq(mas->irq, spi); spi_geni_probe_runtime_disable: pm_runtime_disable(&pdev->dev); -spi_geni_probe_err: spi_master_put(spi); return ret; } -- 2.19.0.rc2