Received: by 2002:a25:1506:0:0:0:0:0 with SMTP id 6csp1632718ybv; Fri, 21 Feb 2020 00:39:55 -0800 (PST) X-Google-Smtp-Source: APXvYqxZqGmcdl/GAhJpcJHdRXvze9WWUYdliUnvxlcpPDhL4tWaPMl9BzIvEUWwugiRXJdqWmWI X-Received: by 2002:a9d:6e15:: with SMTP id e21mr13482652otr.289.1582274395334; Fri, 21 Feb 2020 00:39:55 -0800 (PST) ARC-Seal: i=1; a=rsa-sha256; t=1582274395; cv=none; d=google.com; s=arc-20160816; b=M6dcMljY2g8cZOnBaPm9P9C1RzYbNulRrgv68BnNADiZ/LacVU0esXxMmoE/XUkahN MD9f2UD5QHAR3B77W4HhvdYsy7lsQHhDRLxw5yK9GJhbC1q0G4XAnlROTO8+vHGmYpDi i69BAz8wwKPgsaBCeIl3jnv18/g4X13WzsPvTCd83EDvi7eDh1vfsOvi3jOzsYTr118R 2rOHcr06on8GwrfiPSXKYQD8FBv0RVvSLnmR2XWgB0+8Lrhxhn2mAuApsyUdcxWoc/vm 9Fqq9YHCOl2f/ANpqpZs/tVoWpGhUUSu8CT1kPc9N69R7QvA4wULrokkOI3/hyLu/J5H 3wMg== 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 :user-agent:references:in-reply-to:message-id:date:subject:cc:to :from:dkim-signature; bh=Xt1+lLogjhXYQIXKfl8WclR6CAGkuuOqun8fcSq8iTQ=; b=Zu0DC3eLO8pN5yGvqIfqI2XJI6xJ01L1yyRT4tn4ENJ6TCoNhy0CLPVcQ6QMsZHPKO zeUTjdSJ6pi13tEs8ycHcKRZiKEpwzG7uvWZbQ/6xM3+n2Dw9dd3yaa7gQxCc1tVcRxz zJC3luFcqjPnfO5PUsZyKATYL/LHxt60mtAke6w6/FBZQ8+8ku01soW5ehvqd/Box6p5 rqdeMeXlaSr9b/epVi051IY+tOMki5JL2CoucqTyf6eFGY5j9ipsYlJpFk3M02P2PFYU KSDBKIg4Mcc38+smt5cicKxKabU7qeNo26bBg1D+URZanMh5W8FyK6m4yeotb49twh35 Iaow== ARC-Authentication-Results: i=1; mx.google.com; dkim=pass header.i=@kernel.org header.s=default header.b=EmtMvusY; 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 s129si487872oig.177.2020.02.21.00.39.43; Fri, 21 Feb 2020 00:39:55 -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=@kernel.org header.s=default header.b=EmtMvusY; 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 S1731157AbgBUIiC (ORCPT + 99 others); Fri, 21 Feb 2020 03:38:02 -0500 Received: from mail.kernel.org ([198.145.29.99]:36332 "EHLO mail.kernel.org" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S1731484AbgBUIDc (ORCPT ); Fri, 21 Feb 2020 03:03:32 -0500 Received: from localhost (83-86-89-107.cable.dynamic.v4.ziggo.nl [83.86.89.107]) (using TLSv1.2 with cipher ECDHE-RSA-AES256-GCM-SHA384 (256/256 bits)) (No client certificate requested) by mail.kernel.org (Postfix) with ESMTPSA id 305B62073A; Fri, 21 Feb 2020 08:03:30 +0000 (UTC) DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/simple; d=kernel.org; s=default; t=1582272211; bh=qXBQpGHuxOcxtmfWos87rZV4Lw8QLXlsO+sJcM2OHFU=; h=From:To:Cc:Subject:Date:In-Reply-To:References:From; b=EmtMvusYMpWzptcPmz/LKzIcDP6bQRDhkcdwexVkgVSBgbMHkE6DoqCrQf8isyXqA +mE/t36ZhG+kz+FvCtr1h+b/PyplcHpfpogFhI+0LGfQQNKAMVMcSxZqLss8TwiwOY ClIvTMV1BWHZkeO4dgFNG0B6uYjOW05aFxJzu2fs= From: Greg Kroah-Hartman To: linux-kernel@vger.kernel.org Cc: Greg Kroah-Hartman , stable@vger.kernel.org, Philippe Schenker , Mark Brown , Sasha Levin Subject: [PATCH 5.4 057/344] spi: fsl-lpspi: fix only one cs-gpio working Date: Fri, 21 Feb 2020 08:37:36 +0100 Message-Id: <20200221072354.228024212@linuxfoundation.org> X-Mailer: git-send-email 2.25.1 In-Reply-To: <20200221072349.335551332@linuxfoundation.org> References: <20200221072349.335551332@linuxfoundation.org> User-Agent: quilt/0.66 MIME-Version: 1.0 Content-Type: text/plain; charset=UTF-8 Content-Transfer-Encoding: 8bit Sender: linux-kernel-owner@vger.kernel.org Precedence: bulk List-ID: X-Mailing-List: linux-kernel@vger.kernel.org From: Philippe Schenker [ Upstream commit bc3a8b295e5bca9d1ec2622a6ba38289f9fd3d8a ] Why it does not work at the moment: - num_chipselect sets the number of cs-gpios that are in the DT. This comes from drivers/spi/spi.c - num_chipselect gets set with devm_spi_register_controller, that is called in drivers/spi/spi.c - devm_spi_register_controller got called after num_chipselect has been used. How this commit fixes the issue: - devm_spi_register_controller gets called before num_chipselect is being used. Fixes: c7a402599504 ("spi: lpspi: use the core way to implement cs-gpio function") Signed-off-by: Philippe Schenker Link: https://lore.kernel.org/r/20191204141312.1411251-1-philippe.schenker@toradex.com Signed-off-by: Mark Brown Signed-off-by: Sasha Levin --- drivers/spi/spi-fsl-lpspi.c | 32 ++++++++++++++++---------------- 1 file changed, 16 insertions(+), 16 deletions(-) diff --git a/drivers/spi/spi-fsl-lpspi.c b/drivers/spi/spi-fsl-lpspi.c index 3528ed5eea9b5..92e460d4f3d10 100644 --- a/drivers/spi/spi-fsl-lpspi.c +++ b/drivers/spi/spi-fsl-lpspi.c @@ -862,6 +862,22 @@ static int fsl_lpspi_probe(struct platform_device *pdev) fsl_lpspi->dev = &pdev->dev; fsl_lpspi->is_slave = is_slave; + controller->bits_per_word_mask = SPI_BPW_RANGE_MASK(8, 32); + controller->transfer_one = fsl_lpspi_transfer_one; + controller->prepare_transfer_hardware = lpspi_prepare_xfer_hardware; + controller->unprepare_transfer_hardware = lpspi_unprepare_xfer_hardware; + controller->mode_bits = SPI_CPOL | SPI_CPHA | SPI_CS_HIGH; + controller->flags = SPI_MASTER_MUST_RX | SPI_MASTER_MUST_TX; + controller->dev.of_node = pdev->dev.of_node; + controller->bus_num = pdev->id; + controller->slave_abort = fsl_lpspi_slave_abort; + + ret = devm_spi_register_controller(&pdev->dev, controller); + if (ret < 0) { + dev_err(&pdev->dev, "spi_register_controller error.\n"); + goto out_controller_put; + } + if (!fsl_lpspi->is_slave) { for (i = 0; i < controller->num_chipselect; i++) { int cs_gpio = of_get_named_gpio(np, "cs-gpios", i); @@ -885,16 +901,6 @@ static int fsl_lpspi_probe(struct platform_device *pdev) controller->prepare_message = fsl_lpspi_prepare_message; } - controller->bits_per_word_mask = SPI_BPW_RANGE_MASK(8, 32); - controller->transfer_one = fsl_lpspi_transfer_one; - controller->prepare_transfer_hardware = lpspi_prepare_xfer_hardware; - controller->unprepare_transfer_hardware = lpspi_unprepare_xfer_hardware; - controller->mode_bits = SPI_CPOL | SPI_CPHA | SPI_CS_HIGH; - controller->flags = SPI_MASTER_MUST_RX | SPI_MASTER_MUST_TX; - controller->dev.of_node = pdev->dev.of_node; - controller->bus_num = pdev->id; - controller->slave_abort = fsl_lpspi_slave_abort; - init_completion(&fsl_lpspi->xfer_done); res = platform_get_resource(pdev, IORESOURCE_MEM, 0); @@ -952,12 +958,6 @@ static int fsl_lpspi_probe(struct platform_device *pdev) if (ret < 0) dev_err(&pdev->dev, "dma setup error %d, use pio\n", ret); - ret = devm_spi_register_controller(&pdev->dev, controller); - if (ret < 0) { - dev_err(&pdev->dev, "spi_register_controller error.\n"); - goto out_controller_put; - } - return 0; out_controller_put: -- 2.20.1