All of lore.kernel.org
 help / color / mirror / Atom feed
* [PATCH] Fix SPI Chipselect/Clock bug for sun6i
@ 2020-12-26  9:58 ` Ralf Schlatterbeck
  0 siblings, 0 replies; 10+ messages in thread
From: Ralf Schlatterbeck @ 2020-12-26  9:58 UTC (permalink / raw)
  To: Mark Brown, Maxime Ripard, Chen-Yu Tsai, linux-spi, linux-arm-kernel

This patch makes additional GPIOs usable as chipselects for SPI.
It is available for years on the linux-sunxi SPIdev page at
http://linux-sunxi.org/SPIdev and probably is originally by the user
"Mirko" there. I've tried unsuccessfully to contact the author.
Note that contrary to what is stated on the page above, the bug doesn't
have cosmetic implications only:

The SPI-Driver for the H2 Allwinner processor in the Linux kernel is
supposed to support normal GPIOs as additional chipselects but fails to
do so without the patch.

For oscilloscope screenshots with/without the patch, see my blog post
https://blog.runtux.com/posts/2019/04/18/
or the discussion in the armbian forum at
https://forum.armbian.com/topic/4330-spi-gpio-chip-select-support/
(my logo there is a penguin).
Please bear with me if I'm not following proper procedures, this is my
first patch to the kernel in years.

Thanks
Ralf Schlatterbeck

From 682ae1848b0df00cceb4c76486b971826b2737a9 Mon Sep 17 00:00:00 2001
From: Ralf Schlatterbeck <rsc@runtux.com>
Date: Thu, 11 Apr 2019 16:21:54 +0200
Subject: [PATCH] Fix SPI Chipselect/Clock bug for sun6i
Signed-off-by: Ralf Schlatterbeck <rsc@runtux.com>

The current sun6i SPI implementation initializes the transfer too early,
resulting in SCK going high before the transer. When using an additional
(gpio) chipselect with sun6i, the chipselect is asserted at a time when
clock is high, making the SPI transfer fail.  This patch from the sunxi
spidev page http://linux-sunxi.org/SPIdev fixes this, without the patch
no additional gpio chipselects can be used. The relevant code seems to
be from the user "Mirko" of the linux-sunxi wiki page, I was unable to
contact the original author.
---
 drivers/spi/spi-sun6i.c | 6 +++++-
 1 file changed, 5 insertions(+), 1 deletion(-)

diff --git a/drivers/spi/spi-sun6i.c b/drivers/spi/spi-sun6i.c
index 19238e1b76b4..9b292c6ade50 100644
--- a/drivers/spi/spi-sun6i.c
+++ b/drivers/spi/spi-sun6i.c
@@ -290,6 +290,10 @@ static int sun6i_spi_transfer_one(struct spi_master *master,
 	}
 
 	sun6i_spi_write(sspi, SUN6I_CLK_CTL_REG, reg);
+	/* Finally enable the bus - doing so before might raise SCK to HIGH */
+	sun6i_spi_write(sspi, SUN6I_GBL_CTL_REG,
+			sun6i_spi_read(sspi, SUN6I_GBL_CTL_REG)
+			| SUN6I_GBL_CTL_BUS_ENABLE);
 
 	/* Setup the transfer now... */
 	if (sspi->tx_buf)
@@ -398,7 +402,7 @@ static int sun6i_spi_runtime_resume(struct device *dev)
 	}
 
 	sun6i_spi_write(sspi, SUN6I_GBL_CTL_REG,
-			SUN6I_GBL_CTL_BUS_ENABLE | SUN6I_GBL_CTL_MASTER | SUN6I_GBL_CTL_TP);
+			SUN6I_GBL_CTL_MASTER | SUN6I_GBL_CTL_TP);
 
 	return 0;
 
-- 
2.20.1
-- 
Dr. Ralf Schlatterbeck                  Tel:   +43/2243/26465-16
Open Source Consulting                  www:   www.runtux.com
Reichergasse 131, A-3411 Weidling       email: office@runtux.com

^ permalink raw reply related	[flat|nested] 10+ messages in thread

* [PATCH] Fix SPI Chipselect/Clock bug for sun6i
@ 2020-12-26  9:58 ` Ralf Schlatterbeck
  0 siblings, 0 replies; 10+ messages in thread
From: Ralf Schlatterbeck @ 2020-12-26  9:58 UTC (permalink / raw)
  To: Mark Brown, Maxime Ripard, Chen-Yu Tsai, linux-spi, linux-arm-kernel

This patch makes additional GPIOs usable as chipselects for SPI.
It is available for years on the linux-sunxi SPIdev page at
http://linux-sunxi.org/SPIdev and probably is originally by the user
"Mirko" there. I've tried unsuccessfully to contact the author.
Note that contrary to what is stated on the page above, the bug doesn't
have cosmetic implications only:

The SPI-Driver for the H2 Allwinner processor in the Linux kernel is
supposed to support normal GPIOs as additional chipselects but fails to
do so without the patch.

For oscilloscope screenshots with/without the patch, see my blog post
https://blog.runtux.com/posts/2019/04/18/
or the discussion in the armbian forum at
https://forum.armbian.com/topic/4330-spi-gpio-chip-select-support/
(my logo there is a penguin).
Please bear with me if I'm not following proper procedures, this is my
first patch to the kernel in years.

Thanks
Ralf Schlatterbeck

From 682ae1848b0df00cceb4c76486b971826b2737a9 Mon Sep 17 00:00:00 2001
From: Ralf Schlatterbeck <rsc@runtux.com>
Date: Thu, 11 Apr 2019 16:21:54 +0200
Subject: [PATCH] Fix SPI Chipselect/Clock bug for sun6i
Signed-off-by: Ralf Schlatterbeck <rsc@runtux.com>

The current sun6i SPI implementation initializes the transfer too early,
resulting in SCK going high before the transer. When using an additional
(gpio) chipselect with sun6i, the chipselect is asserted at a time when
clock is high, making the SPI transfer fail.  This patch from the sunxi
spidev page http://linux-sunxi.org/SPIdev fixes this, without the patch
no additional gpio chipselects can be used. The relevant code seems to
be from the user "Mirko" of the linux-sunxi wiki page, I was unable to
contact the original author.
---
 drivers/spi/spi-sun6i.c | 6 +++++-
 1 file changed, 5 insertions(+), 1 deletion(-)

diff --git a/drivers/spi/spi-sun6i.c b/drivers/spi/spi-sun6i.c
index 19238e1b76b4..9b292c6ade50 100644
--- a/drivers/spi/spi-sun6i.c
+++ b/drivers/spi/spi-sun6i.c
@@ -290,6 +290,10 @@ static int sun6i_spi_transfer_one(struct spi_master *master,
 	}
 
 	sun6i_spi_write(sspi, SUN6I_CLK_CTL_REG, reg);
+	/* Finally enable the bus - doing so before might raise SCK to HIGH */
+	sun6i_spi_write(sspi, SUN6I_GBL_CTL_REG,
+			sun6i_spi_read(sspi, SUN6I_GBL_CTL_REG)
+			| SUN6I_GBL_CTL_BUS_ENABLE);
 
 	/* Setup the transfer now... */
 	if (sspi->tx_buf)
@@ -398,7 +402,7 @@ static int sun6i_spi_runtime_resume(struct device *dev)
 	}
 
 	sun6i_spi_write(sspi, SUN6I_GBL_CTL_REG,
-			SUN6I_GBL_CTL_BUS_ENABLE | SUN6I_GBL_CTL_MASTER | SUN6I_GBL_CTL_TP);
+			SUN6I_GBL_CTL_MASTER | SUN6I_GBL_CTL_TP);
 
 	return 0;
 
-- 
2.20.1
-- 
Dr. Ralf Schlatterbeck                  Tel:   +43/2243/26465-16
Open Source Consulting                  www:   www.runtux.com
Reichergasse 131, A-3411 Weidling       email: office@runtux.com

_______________________________________________
linux-arm-kernel mailing list
linux-arm-kernel@lists.infradead.org
http://lists.infradead.org/mailman/listinfo/linux-arm-kernel

^ permalink raw reply related	[flat|nested] 10+ messages in thread

* Re: [PATCH] Fix SPI Chipselect/Clock bug for sun6i
  2020-12-26  9:58 ` Ralf Schlatterbeck
@ 2021-01-08  8:58   ` Maxime Ripard
  -1 siblings, 0 replies; 10+ messages in thread
From: Maxime Ripard @ 2021-01-08  8:58 UTC (permalink / raw)
  To: Ralf Schlatterbeck; +Cc: Mark Brown, Chen-Yu Tsai, linux-spi, linux-arm-kernel

Hi,

On Sat, Dec 26, 2020 at 10:58:45AM +0100, Ralf Schlatterbeck wrote:
> This patch makes additional GPIOs usable as chipselects for SPI.
> It is available for years on the linux-sunxi SPIdev page at
> http://linux-sunxi.org/SPIdev and probably is originally by the user
> "Mirko" there. I've tried unsuccessfully to contact the author.
> Note that contrary to what is stated on the page above, the bug doesn't
> have cosmetic implications only:
> 
> The SPI-Driver for the H2 Allwinner processor in the Linux kernel is
> supposed to support normal GPIOs as additional chipselects but fails to
> do so without the patch.
> 
> For oscilloscope screenshots with/without the patch, see my blog post
> https://blog.runtux.com/posts/2019/04/18/
> or the discussion in the armbian forum at
> https://forum.armbian.com/topic/4330-spi-gpio-chip-select-support/
> (my logo there is a penguin).
> Please bear with me if I'm not following proper procedures, this is my
> first patch to the kernel in years.
> 
> Thanks
> Ralf Schlatterbeck
> 
> From 682ae1848b0df00cceb4c76486b971826b2737a9 Mon Sep 17 00:00:00 2001
> From: Ralf Schlatterbeck <rsc@runtux.com>
> Date: Thu, 11 Apr 2019 16:21:54 +0200
> Subject: [PATCH] Fix SPI Chipselect/Clock bug for sun6i
> Signed-off-by: Ralf Schlatterbeck <rsc@runtux.com>
> 
> The current sun6i SPI implementation initializes the transfer too early,
> resulting in SCK going high before the transer. When using an additional
> (gpio) chipselect with sun6i, the chipselect is asserted at a time when
> clock is high, making the SPI transfer fail.  This patch from the sunxi
> spidev page http://linux-sunxi.org/SPIdev fixes this, without the patch
> no additional gpio chipselects can be used. The relevant code seems to
> be from the user "Mirko" of the linux-sunxi wiki page, I was unable to
> contact the original author.

Unfortunately, without the author's Signed-off-by (and yours), we can't
merge that patch.

Maxime

^ permalink raw reply	[flat|nested] 10+ messages in thread

* Re: [PATCH] Fix SPI Chipselect/Clock bug for sun6i
@ 2021-01-08  8:58   ` Maxime Ripard
  0 siblings, 0 replies; 10+ messages in thread
From: Maxime Ripard @ 2021-01-08  8:58 UTC (permalink / raw)
  To: Ralf Schlatterbeck; +Cc: Chen-Yu Tsai, Mark Brown, linux-arm-kernel, linux-spi

Hi,

On Sat, Dec 26, 2020 at 10:58:45AM +0100, Ralf Schlatterbeck wrote:
> This patch makes additional GPIOs usable as chipselects for SPI.
> It is available for years on the linux-sunxi SPIdev page at
> http://linux-sunxi.org/SPIdev and probably is originally by the user
> "Mirko" there. I've tried unsuccessfully to contact the author.
> Note that contrary to what is stated on the page above, the bug doesn't
> have cosmetic implications only:
> 
> The SPI-Driver for the H2 Allwinner processor in the Linux kernel is
> supposed to support normal GPIOs as additional chipselects but fails to
> do so without the patch.
> 
> For oscilloscope screenshots with/without the patch, see my blog post
> https://blog.runtux.com/posts/2019/04/18/
> or the discussion in the armbian forum at
> https://forum.armbian.com/topic/4330-spi-gpio-chip-select-support/
> (my logo there is a penguin).
> Please bear with me if I'm not following proper procedures, this is my
> first patch to the kernel in years.
> 
> Thanks
> Ralf Schlatterbeck
> 
> From 682ae1848b0df00cceb4c76486b971826b2737a9 Mon Sep 17 00:00:00 2001
> From: Ralf Schlatterbeck <rsc@runtux.com>
> Date: Thu, 11 Apr 2019 16:21:54 +0200
> Subject: [PATCH] Fix SPI Chipselect/Clock bug for sun6i
> Signed-off-by: Ralf Schlatterbeck <rsc@runtux.com>
> 
> The current sun6i SPI implementation initializes the transfer too early,
> resulting in SCK going high before the transer. When using an additional
> (gpio) chipselect with sun6i, the chipselect is asserted at a time when
> clock is high, making the SPI transfer fail.  This patch from the sunxi
> spidev page http://linux-sunxi.org/SPIdev fixes this, without the patch
> no additional gpio chipselects can be used. The relevant code seems to
> be from the user "Mirko" of the linux-sunxi wiki page, I was unable to
> contact the original author.

Unfortunately, without the author's Signed-off-by (and yours), we can't
merge that patch.

Maxime

_______________________________________________
linux-arm-kernel mailing list
linux-arm-kernel@lists.infradead.org
http://lists.infradead.org/mailman/listinfo/linux-arm-kernel

^ permalink raw reply	[flat|nested] 10+ messages in thread

* Re: [PATCH] Fix SPI Chipselect/Clock bug for sun6i
  2021-01-08  8:58   ` Maxime Ripard
@ 2021-01-08  9:18     ` Ralf Schlatterbeck
  -1 siblings, 0 replies; 10+ messages in thread
From: Ralf Schlatterbeck @ 2021-01-08  9:18 UTC (permalink / raw)
  To: Maxime Ripard; +Cc: Mark Brown, Chen-Yu Tsai, linux-spi, linux-arm-kernel

On Fri, Jan 08, 2021 at 09:58:55AM +0100, Maxime Ripard wrote:
> 
> Unfortunately, without the author's Signed-off-by (and yours), we can't
> merge that patch.

Thanks for the Reply. I've researched more and found out who the
probable Author of the patch is. I've tried to contact him via Email,
I'll follow up with correct signed-off etc when I've got permission.

Ralf
-- 
Dr. Ralf Schlatterbeck                  Tel:   +43/2243/26465-16
Open Source Consulting                  www:   www.runtux.com
Reichergasse 131, A-3411 Weidling       email: office@runtux.com

^ permalink raw reply	[flat|nested] 10+ messages in thread

* Re: [PATCH] Fix SPI Chipselect/Clock bug for sun6i
@ 2021-01-08  9:18     ` Ralf Schlatterbeck
  0 siblings, 0 replies; 10+ messages in thread
From: Ralf Schlatterbeck @ 2021-01-08  9:18 UTC (permalink / raw)
  To: Maxime Ripard; +Cc: Chen-Yu Tsai, Mark Brown, linux-arm-kernel, linux-spi

On Fri, Jan 08, 2021 at 09:58:55AM +0100, Maxime Ripard wrote:
> 
> Unfortunately, without the author's Signed-off-by (and yours), we can't
> merge that patch.

Thanks for the Reply. I've researched more and found out who the
probable Author of the patch is. I've tried to contact him via Email,
I'll follow up with correct signed-off etc when I've got permission.

Ralf
-- 
Dr. Ralf Schlatterbeck                  Tel:   +43/2243/26465-16
Open Source Consulting                  www:   www.runtux.com
Reichergasse 131, A-3411 Weidling       email: office@runtux.com

_______________________________________________
linux-arm-kernel mailing list
linux-arm-kernel@lists.infradead.org
http://lists.infradead.org/mailman/listinfo/linux-arm-kernel

^ permalink raw reply	[flat|nested] 10+ messages in thread

* Re: [PATCH] Fix SPI Chipselect/Clock bug for sun6i
  2021-01-08  9:18     ` Ralf Schlatterbeck
@ 2021-01-11 16:10       ` Maxime Ripard
  -1 siblings, 0 replies; 10+ messages in thread
From: Maxime Ripard @ 2021-01-11 16:10 UTC (permalink / raw)
  To: Ralf Schlatterbeck; +Cc: Mark Brown, Chen-Yu Tsai, linux-spi, linux-arm-kernel

[-- Attachment #1: Type: text/plain, Size: 484 bytes --]

On Fri, Jan 08, 2021 at 10:18:15AM +0100, Ralf Schlatterbeck wrote:
> On Fri, Jan 08, 2021 at 09:58:55AM +0100, Maxime Ripard wrote:
> > 
> > Unfortunately, without the author's Signed-off-by (and yours), we can't
> > merge that patch.
> 
> Thanks for the Reply. I've researched more and found out who the
> probable Author of the patch is. I've tried to contact him via Email,
> I'll follow up with correct signed-off etc when I've got permission.

Great, thanks!
Maxime

[-- Attachment #2: signature.asc --]
[-- Type: application/pgp-signature, Size: 228 bytes --]

^ permalink raw reply	[flat|nested] 10+ messages in thread

* Re: [PATCH] Fix SPI Chipselect/Clock bug for sun6i
@ 2021-01-11 16:10       ` Maxime Ripard
  0 siblings, 0 replies; 10+ messages in thread
From: Maxime Ripard @ 2021-01-11 16:10 UTC (permalink / raw)
  To: Ralf Schlatterbeck; +Cc: Chen-Yu Tsai, Mark Brown, linux-arm-kernel, linux-spi


[-- Attachment #1.1: Type: text/plain, Size: 484 bytes --]

On Fri, Jan 08, 2021 at 10:18:15AM +0100, Ralf Schlatterbeck wrote:
> On Fri, Jan 08, 2021 at 09:58:55AM +0100, Maxime Ripard wrote:
> > 
> > Unfortunately, without the author's Signed-off-by (and yours), we can't
> > merge that patch.
> 
> Thanks for the Reply. I've researched more and found out who the
> probable Author of the patch is. I've tried to contact him via Email,
> I'll follow up with correct signed-off etc when I've got permission.

Great, thanks!
Maxime

[-- Attachment #1.2: signature.asc --]
[-- Type: application/pgp-signature, Size: 228 bytes --]

[-- Attachment #2: Type: text/plain, Size: 176 bytes --]

_______________________________________________
linux-arm-kernel mailing list
linux-arm-kernel@lists.infradead.org
http://lists.infradead.org/mailman/listinfo/linux-arm-kernel

^ permalink raw reply	[flat|nested] 10+ messages in thread

* Re: [PATCH] Fix SPI Chipselect/Clock bug for sun6i
  2021-01-11 16:10       ` Maxime Ripard
@ 2021-05-20 10:00         ` Ralf Schlatterbeck
  -1 siblings, 0 replies; 10+ messages in thread
From: Ralf Schlatterbeck @ 2021-05-20 10:00 UTC (permalink / raw)
  To: Maxime Ripard; +Cc: Mark Brown, Chen-Yu Tsai, linux-spi, linux-arm-kernel

On Mon, Jan 11, 2021 at 05:10:04PM +0100, Maxime Ripard wrote:
> On Fri, Jan 08, 2021 at 10:18:15AM +0100, Ralf Schlatterbeck wrote:
> > On Fri, Jan 08, 2021 at 09:58:55AM +0100, Maxime Ripard wrote:
> > > 
> > > Unfortunately, without the author's Signed-off-by (and yours), we can't
> > > merge that patch.
> > 
> > Thanks for the Reply. I've researched more and found out who the
> > probable Author of the patch is. I've tried to contact him via Email,
> > I'll follow up with correct signed-off etc when I've got permission.
> 
> Great, thanks!
> Maxime

I've finally got permission :-) I'll re-submit in a separate thread.

Ralf
-- 
Dr. Ralf Schlatterbeck                  Tel:   +43/2243/26465-16
Open Source Consulting                  www:   www.runtux.com
Reichergasse 131, A-3411 Weidling       email: office@runtux.com

^ permalink raw reply	[flat|nested] 10+ messages in thread

* Re: [PATCH] Fix SPI Chipselect/Clock bug for sun6i
@ 2021-05-20 10:00         ` Ralf Schlatterbeck
  0 siblings, 0 replies; 10+ messages in thread
From: Ralf Schlatterbeck @ 2021-05-20 10:00 UTC (permalink / raw)
  To: Maxime Ripard; +Cc: Mark Brown, Chen-Yu Tsai, linux-spi, linux-arm-kernel

On Mon, Jan 11, 2021 at 05:10:04PM +0100, Maxime Ripard wrote:
> On Fri, Jan 08, 2021 at 10:18:15AM +0100, Ralf Schlatterbeck wrote:
> > On Fri, Jan 08, 2021 at 09:58:55AM +0100, Maxime Ripard wrote:
> > > 
> > > Unfortunately, without the author's Signed-off-by (and yours), we can't
> > > merge that patch.
> > 
> > Thanks for the Reply. I've researched more and found out who the
> > probable Author of the patch is. I've tried to contact him via Email,
> > I'll follow up with correct signed-off etc when I've got permission.
> 
> Great, thanks!
> Maxime

I've finally got permission :-) I'll re-submit in a separate thread.

Ralf
-- 
Dr. Ralf Schlatterbeck                  Tel:   +43/2243/26465-16
Open Source Consulting                  www:   www.runtux.com
Reichergasse 131, A-3411 Weidling       email: office@runtux.com

_______________________________________________
linux-arm-kernel mailing list
linux-arm-kernel@lists.infradead.org
http://lists.infradead.org/mailman/listinfo/linux-arm-kernel

^ permalink raw reply	[flat|nested] 10+ messages in thread

end of thread, other threads:[~2021-05-20 10:11 UTC | newest]

Thread overview: 10+ messages (download: mbox.gz / follow: Atom feed)
-- links below jump to the message on this page --
2020-12-26  9:58 [PATCH] Fix SPI Chipselect/Clock bug for sun6i Ralf Schlatterbeck
2020-12-26  9:58 ` Ralf Schlatterbeck
2021-01-08  8:58 ` Maxime Ripard
2021-01-08  8:58   ` Maxime Ripard
2021-01-08  9:18   ` Ralf Schlatterbeck
2021-01-08  9:18     ` Ralf Schlatterbeck
2021-01-11 16:10     ` Maxime Ripard
2021-01-11 16:10       ` Maxime Ripard
2021-05-20 10:00       ` Ralf Schlatterbeck
2021-05-20 10:00         ` Ralf Schlatterbeck

This is an external index of several public inboxes,
see mirroring instructions on how to clone and mirror
all data and code used by this external index.