linux-kernel.vger.kernel.org archive mirror
 help / color / mirror / Atom feed
* Re: [linux-sunxi] [PATCH 3/3] MTD: m25p80: Add option to limit SPI transfer size.
       [not found] ` <3b0c112672f364452e80c333048161eaffb655db.1430403750.git.hramrach@gmail.com>
@ 2015-04-30 14:58   ` Julian Calaby
  2015-05-20 23:27     ` Brian Norris
  0 siblings, 1 reply; 15+ messages in thread
From: Julian Calaby @ 2015-04-30 14:58 UTC (permalink / raw)
  To: Michal Suchanek
  Cc: linux-sunxi, Rob Herring, Pawel Moll, Mark Rutland, Ian Campbell,
	Kumar Gala, David Woodhouse, Brian Norris, Marek Vasut,
	Huang Shijie, Rafał Miłecki, Ben Hutchings,
	Alison Chaiken, Mika Westerberg,
	Bean Huo 霍斌斌 (beanhuo),
	grmoore, devicetree, linux-kernel, linux-mtd

Hi Michal,

On Thu, Apr 30, 2015 at 11:46 PM, Michal Suchanek <hramrach@gmail.com> wrote:
> My SPI driver does not support DMA so sizes larger than 64 bytes return
> an error. Add an option to limit transfer size so m25p80 can be used
> with reduced speed with such controller.

I suspect that this will be rejected as the maximum transfer size is a
property of the SPI controller, not the device and should be exported
to the device driver from the controller, not specified in the
device's binding.

Thanks,

-- 
Julian Calaby

Email: julian.calaby@gmail.com
Profile: http://www.google.com/profiles/julian.calaby/

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

* Re: [PATCH 0/3] Using SPI NOR flah on sunxi.
       [not found] <cover.1430403750.git.hramrach@gmail.com>
       [not found] ` <3b0c112672f364452e80c333048161eaffb655db.1430403750.git.hramrach@gmail.com>
@ 2015-04-30 16:30 ` Thomas.Betker
  2015-04-30 16:56   ` Michal Suchanek
       [not found] ` <55132b4496e7fe73f949186c0f140f3e4fd4e2c7.1430403750.git.hramrach@gmail.com>
                   ` (2 subsequent siblings)
  4 siblings, 1 reply; 15+ messages in thread
From: Thomas.Betker @ 2015-04-30 16:30 UTC (permalink / raw)
  To: Michal Suchanek
  Cc: Alison Chaiken, Huang Shijie, Bean Huo ????????? (beanhuo),
	Ben Hutchings, Brian Norris, devicetree, David Woodhouse,
	Kumar Gala, grmoore, Ian Campbell, linux-kernel, linux-mtd,
	linux-mtd, linux-sunxi, Marek Vasut, Mark Rutland,
	Mika Westerberg, Pawel Moll, Rob Herring, Rafa?? Mi??ecki

Hello Michal:

> I tried to connect a SPI NOR flash to my sunxi board and due to the 
current
> sunxi SPI driver limitations it does not work.
> 
> The SPI driver returns an error when more than 64 bytes are 
> transferred at once
> due to lack of DMA support.

Wouldn't it be easier to fix the SPI driver to handle transfers larger 
than 64 bytes, filling and draining the FIFO multiple times if neccessary? 
(As far as I can tell, most SPI drivers do this.)

Just asking,
Thomas

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

* Re: [PATCH 0/3] Using SPI NOR flah on sunxi.
  2015-04-30 16:30 ` [PATCH 0/3] Using SPI NOR flah on sunxi Thomas.Betker
@ 2015-04-30 16:56   ` Michal Suchanek
  2015-04-30 18:34     ` Marek Vasut
  0 siblings, 1 reply; 15+ messages in thread
From: Michal Suchanek @ 2015-04-30 16:56 UTC (permalink / raw)
  To: Thomas.Betker
  Cc: Alison Chaiken, Huang Shijie, Bean Huo ????????? (beanhuo),
	Ben Hutchings, Brian Norris, devicetree, David Woodhouse,
	Kumar Gala, grmoore, Ian Campbell, Linux Kernel Mailing List,
	linux-mtd, linux-mtd, linux-sunxi, Marek Vasut, Mark Rutland,
	Mika Westerberg, Pawel Moll, Rob Herring, Rafa?? Mi??ecki

On 30 April 2015 at 18:30,  <Thomas.Betker@rohde-schwarz.com> wrote:
> Hello Michal:
>
>> I tried to connect a SPI NOR flash to my sunxi board and due to the
> current
>> sunxi SPI driver limitations it does not work.
>>
>> The SPI driver returns an error when more than 64 bytes are
>> transferred at once
>> due to lack of DMA support.
>
> Wouldn't it be easier to fix the SPI driver to handle transfers larger
> than 64 bytes, filling and draining the FIFO multiple times if neccessary?
> (As far as I can tell, most SPI drivers do this.)
>

Yes, the intent is to fix this by adding dma support to the driver, eventually.

The patch might be still useful for other hardware with developing SPI support.

Thanks

Michal

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

* Re: [PATCH 0/3] Using SPI NOR flah on sunxi.
  2015-04-30 16:56   ` Michal Suchanek
@ 2015-04-30 18:34     ` Marek Vasut
  2015-05-20 23:54       ` Brian Norris
  0 siblings, 1 reply; 15+ messages in thread
From: Marek Vasut @ 2015-04-30 18:34 UTC (permalink / raw)
  To: Michal Suchanek
  Cc: Thomas.Betker, Alison Chaiken, Huang Shijie,
	Bean Huo ????????? (beanhuo),
	Ben Hutchings, Brian Norris, devicetree, David Woodhouse,
	Kumar Gala, grmoore, Ian Campbell, Linux Kernel Mailing List,
	linux-mtd, linux-mtd, linux-sunxi, Mark Rutland, Mika Westerberg,
	Pawel Moll, Rob Herring, Rafa?? Mi??ecki

On Thursday, April 30, 2015 at 06:56:18 PM, Michal Suchanek wrote:
> On 30 April 2015 at 18:30,  <Thomas.Betker@rohde-schwarz.com> wrote:
> > Hello Michal:
> >> I tried to connect a SPI NOR flash to my sunxi board and due to the
> > 
> > current
> > 
> >> sunxi SPI driver limitations it does not work.
> >> 
> >> The SPI driver returns an error when more than 64 bytes are
> >> transferred at once
> >> due to lack of DMA support.
> > 
> > Wouldn't it be easier to fix the SPI driver to handle transfers larger
> > than 64 bytes, filling and draining the FIFO multiple times if
> > neccessary? (As far as I can tell, most SPI drivers do this.)
> 
> Yes, the intent is to fix this by adding dma support to the driver,
> eventually.
> 
> The patch might be still useful for other hardware with developing SPI
> support.

Please just fix the controller driver to correctly handle arbitrary transfer
lengths.

Best regards,
Marek Vasut

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

* Re: [PATCH 1/3] MTD: m25p80: fix write return value.
       [not found] ` <55132b4496e7fe73f949186c0f140f3e4fd4e2c7.1430403750.git.hramrach@gmail.com>
@ 2015-04-30 18:43   ` Marek Vasut
  2015-04-30 21:37     ` Michal Suchanek
  0 siblings, 1 reply; 15+ messages in thread
From: Marek Vasut @ 2015-04-30 18:43 UTC (permalink / raw)
  To: Michal Suchanek
  Cc: linux-sunxi, Rob Herring, Pawel Moll, Mark Rutland, Ian Campbell,
	Kumar Gala, David Woodhouse, Brian Norris, Huang Shijie,
	 Rafał Miłecki, Ben Hutchings, Alison Chaiken,
	Mika Westerberg, Bean Huo 霍斌斌 (beanhuo),
	grmoore, devicetree, linux-kernel, linux-mtd

On Thursday, April 30, 2015 at 03:33:47 PM, Michal Suchanek wrote:
> The size of written data was added to user supplied value rather than
> written at the provided address.

You might want to work on the commit message a little, something like
the following, but feel free to reword as seen fit.

The 'retlen' points to a variable representing the number of data bytes 
written/read (see include/linux/mtd/mtd.h) by the current invocation of
the function. This variable must be set, not incremented.

Otherwise, the patch is correct I believe:

Acked-by: Marek Vasut <marex@denx.de>

> Signed-off-by: Michal Suchanek <hramrach@gmail.com>
> ---
>  drivers/mtd/devices/m25p80.c | 2 +-
>  1 file changed, 1 insertion(+), 1 deletion(-)
> 
> diff --git a/drivers/mtd/devices/m25p80.c b/drivers/mtd/devices/m25p80.c
> index 7c8b169..0b2bc21 100644
> --- a/drivers/mtd/devices/m25p80.c
> +++ b/drivers/mtd/devices/m25p80.c
> @@ -102,7 +102,7 @@ static void m25p80_write(struct spi_nor *nor, loff_t
> to, size_t len,
> 
>  	spi_sync(spi, &m);
> 
> -	*retlen += m.actual_length - cmd_sz;
> +	*retlen = m.actual_length - cmd_sz;
>  }
> 
>  static inline unsigned int m25p80_rx_nbits(struct spi_nor *nor)

Best regards,
Marek Vasut

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

* Re: [PATCH 1/3] MTD: m25p80: fix write return value.
  2015-04-30 18:43   ` [PATCH 1/3] MTD: m25p80: fix write return value Marek Vasut
@ 2015-04-30 21:37     ` Michal Suchanek
  0 siblings, 0 replies; 15+ messages in thread
From: Michal Suchanek @ 2015-04-30 21:37 UTC (permalink / raw)
  To: Marek Vasut
  Cc: linux-sunxi, Rob Herring, Pawel Moll, Mark Rutland, Ian Campbell,
	Kumar Gala, David Woodhouse, Brian Norris, Huang Shijie,
	Rafał Miłecki, Ben Hutchings, Alison Chaiken,
	Mika Westerberg, Bean Huo 霍斌斌 (beanhuo),
	grmoore, devicetree, Linux Kernel Mailing List, linux-mtd

On 30 April 2015 at 20:43, Marek Vasut <marex@denx.de> wrote:
> On Thursday, April 30, 2015 at 03:33:47 PM, Michal Suchanek wrote:
>> The size of written data was added to user supplied value rather than
>> written at the provided address.
>
> You might want to work on the commit message a little, something like
> the following, but feel free to reword as seen fit.
>
> The 'retlen' points to a variable representing the number of data bytes
> written/read (see include/linux/mtd/mtd.h) by the current invocation of
> the function. This variable must be set, not incremented.
>
> Otherwise, the patch is correct I believe:
>
> Acked-by: Marek Vasut <marex@denx.de>
>

ok, I will send an updated version.

Thanks

Michal

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

* Re: [linux-sunxi] Re: [PATCH 0/3] Using SPI NOR flah on sunxi.
       [not found] ` <jwv4mnwfppf.fsf-monnier+gmane.comp.hardware.netbook.arm.sunxi@gnu.org>
@ 2015-05-04 10:32   ` Michal Suchanek
  0 siblings, 0 replies; 15+ messages in thread
From: Michal Suchanek @ 2015-05-04 10:32 UTC (permalink / raw)
  To: monnier; +Cc: linux-sunxi, devicetree, Linux Kernel Mailing List, linux-mtd

Hello,

On 1 May 2015 at 14:27, Stefan Monnier <monnier@iro.umontreal.ca> wrote:
>> The SPI driver returns an error when more than 64 bytes are
>> transferred at once due to lack of DMA support.
>
> Have you tried the dmaengine patch and make the SPI driver use it?
>

The dmaengine is already merged or queued in sunxi-wip but the SPI
glue fell through the cracks. I found it after digging through the
archives so I will see if it works for me.

Thanks

Michal

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

* Re: [linux-sunxi] [PATCH 3/3] MTD: m25p80: Add option to limit SPI transfer size.
  2015-04-30 14:58   ` [linux-sunxi] [PATCH 3/3] MTD: m25p80: Add option to limit SPI transfer size Julian Calaby
@ 2015-05-20 23:27     ` Brian Norris
  0 siblings, 0 replies; 15+ messages in thread
From: Brian Norris @ 2015-05-20 23:27 UTC (permalink / raw)
  To: Julian Calaby
  Cc: Michal Suchanek, linux-sunxi, Rob Herring, Pawel Moll,
	Mark Rutland, Ian Campbell, Kumar Gala, David Woodhouse,
	Marek Vasut, Huang Shijie, Rafał Miłecki,
	Ben Hutchings, Alison Chaiken, Mika Westerberg,
	Bean Huo 霍斌斌 (beanhuo),
	grmoore, devicetree, linux-kernel, linux-mtd

On Fri, May 01, 2015 at 12:58:52AM +1000, Julian Calaby wrote:
> On Thu, Apr 30, 2015 at 11:46 PM, Michal Suchanek <hramrach@gmail.com> wrote:
> > My SPI driver does not support DMA so sizes larger than 64 bytes return
> > an error. Add an option to limit transfer size so m25p80 can be used
> > with reduced speed with such controller.
> 
> I suspect that this will be rejected as the maximum transfer size is a
> property of the SPI controller, not the device and should be exported
> to the device driver from the controller, not specified in the
> device's binding.

Absolutely correct. This does not belong in the device tree.

Brian

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

* Re: [PATCH 2/3] MTD: spi-nor: check for short writes in spi_nor_write.
       [not found] ` <50c40ef17ab6566f35ef5a4426bf23567f896db7.1430403750.git.hramrach@gmail.com>
@ 2015-05-20 23:38   ` Brian Norris
  2015-05-21  8:39     ` Michal Suchanek
  0 siblings, 1 reply; 15+ messages in thread
From: Brian Norris @ 2015-05-20 23:38 UTC (permalink / raw)
  To: Michal Suchanek
  Cc: linux-sunxi, Rob Herring, Pawel Moll, Mark Rutland, Ian Campbell,
	Kumar Gala, David Woodhouse, Marek Vasut, Huang Shijie,
	Rafał Miłecki, Ben Hutchings, Alison Chaiken,
	Mika Westerberg, Bean Huo 霍斌斌 (beanhuo),
	grmoore, devicetree, linux-kernel, linux-mtd, linux-spi,
	Mark Brown

+ linux-spi, Mark

On Thu, Apr 30, 2015 at 03:38:50PM +0200, Michal Suchanek wrote:
> My SPI controller driver does not support DMA so writes are truncated to
> FIFO size.

Which SPI master driver?

> Check the amount of data actually written by the driver.

I'm not sure if we should just reactively use the retlen, or if we
should be communicating such a limitation via the SPI API. Thoughts?

Brian

> Signed-off-by: Michal Suchanek <hramrach@gmail.com>
> ---
>  drivers/mtd/spi-nor/spi-nor.c | 42 +++++++++++++++++-------------------------
>  1 file changed, 17 insertions(+), 25 deletions(-)
> 
> diff --git a/drivers/mtd/spi-nor/spi-nor.c b/drivers/mtd/spi-nor/spi-nor.c
> index 14a5d23..75904b5 100644
> --- a/drivers/mtd/spi-nor/spi-nor.c
> +++ b/drivers/mtd/spi-nor/spi-nor.c
> @@ -807,7 +807,7 @@ static int spi_nor_write(struct mtd_info *mtd, loff_t to, size_t len,
>  	size_t *retlen, const u_char *buf)
>  {
>  	struct spi_nor *nor = mtd_to_spi_nor(mtd);
> -	u32 page_offset, page_size, i;
> +	u32 page_offset, page_remainder, page_size, i;
>  	int ret;
>  
>  	dev_dbg(nor->dev, "to 0x%08x, len %zd\n", (u32)to, len);
> @@ -816,36 +816,28 @@ static int spi_nor_write(struct mtd_info *mtd, loff_t to, size_t len,
>  	if (ret)
>  		return ret;
>  
> -	write_enable(nor);
> -
> -	page_offset = to & (nor->page_size - 1);
> -
> -	/* do all the bytes fit onto one page? */
> -	if (page_offset + len <= nor->page_size) {
> -		nor->write(nor, to, len, retlen, buf);
> -	} else {
> -		/* the size of data remaining on the first page */
> -		page_size = nor->page_size - page_offset;
> -		nor->write(nor, to, page_size, retlen, buf);
> +	/* write everything in nor->page_size chunks */
> +	/* check the size of data actually written */
> +	for (i = 0; i < len; i += *retlen) {
> +		page_size = len - i;
> +		page_offset = (to + i) & (nor->page_size - 1);
> +		page_remainder = nor->page_size - page_offset;
> +		if (page_size > nor->page_size)
> +			page_size = nor->page_size;
> +		if (page_remainder && (page_size > page_remainder))
> +			page_size = page_remainder;
>  
> -		/* write everything in nor->page_size chunks */
> -		for (i = page_size; i < len; i += page_size) {
> -			page_size = len - i;
> -			if (page_size > nor->page_size)
> -				page_size = nor->page_size;
> -
> -			ret = spi_nor_wait_till_ready(nor);
> -			if (ret)
> -				goto write_err;
> +		write_enable(nor);
>  
> -			write_enable(nor);
> +		nor->write(nor, to + i, page_size, retlen, buf + i);
>  
> -			nor->write(nor, to + i, page_size, retlen, buf + i);
> -		}
> +		ret = spi_nor_wait_till_ready(nor);
> +		if (ret)
> +			goto write_err;
>  	}
>  
> -	ret = spi_nor_wait_till_ready(nor);
>  write_err:
> +	*retlen = i;
>  	spi_nor_unlock_and_unprep(nor, SPI_NOR_OPS_WRITE);
>  	return ret;
>  }

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

* Re: [PATCH 0/3] Using SPI NOR flah on sunxi.
  2015-04-30 18:34     ` Marek Vasut
@ 2015-05-20 23:54       ` Brian Norris
  0 siblings, 0 replies; 15+ messages in thread
From: Brian Norris @ 2015-05-20 23:54 UTC (permalink / raw)
  To: Marek Vasut
  Cc: Michal Suchanek, Thomas.Betker, Alison Chaiken, Huang Shijie,
	Bean Huo ????????? (beanhuo),
	Ben Hutchings, devicetree, David Woodhouse, Kumar Gala, grmoore,
	Ian Campbell, Linux Kernel Mailing List, linux-mtd, linux-mtd,
	linux-sunxi, Mark Rutland, Mika Westerberg, Pawel Moll,
	Rob Herring, Rafa?? Mi??ecki, linux-spi, Mark Brown

On Thu, Apr 30, 2015 at 08:34:36PM +0200, Marek Vasut wrote:
> On Thursday, April 30, 2015 at 06:56:18 PM, Michal Suchanek wrote:
> > On 30 April 2015 at 18:30,  <Thomas.Betker@rohde-schwarz.com> wrote:
> > > Hello Michal:
> > >> I tried to connect a SPI NOR flash to my sunxi board and due to the
> > > 
> > > current
> > > 
> > >> sunxi SPI driver limitations it does not work.
> > >> 
> > >> The SPI driver returns an error when more than 64 bytes are
> > >> transferred at once
> > >> due to lack of DMA support.
> > > 
> > > Wouldn't it be easier to fix the SPI driver to handle transfers larger
> > > than 64 bytes, filling and draining the FIFO multiple times if
> > > neccessary? (As far as I can tell, most SPI drivers do this.)
> > 
> > Yes, the intent is to fix this by adding dma support to the driver,
> > eventually.
> > 
> > The patch might be still useful for other hardware with developing SPI
> > support.
> 
> Please just fix the controller driver to correctly handle arbitrary transfer
> lengths.

Just noticed this. Yes, that would definitely be a better option!

Brian

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

* Re: [PATCH 2/3] MTD: spi-nor: check for short writes in spi_nor_write.
  2015-05-20 23:38   ` [PATCH 2/3] MTD: spi-nor: check for short writes in spi_nor_write Brian Norris
@ 2015-05-21  8:39     ` Michal Suchanek
  2015-05-21 10:28       ` Mark Brown
  0 siblings, 1 reply; 15+ messages in thread
From: Michal Suchanek @ 2015-05-21  8:39 UTC (permalink / raw)
  To: Brian Norris
  Cc: linux-sunxi, Rob Herring, Pawel Moll, Mark Rutland, Ian Campbell,
	Kumar Gala, David Woodhouse, Marek Vasut, Huang Shijie,
	Rafał Miłecki, Ben Hutchings, Alison Chaiken,
	Mika Westerberg, Bean Huo 霍斌斌 (beanhuo),
	grmoore, devicetree, Linux Kernel Mailing List, linux-mtd,
	linux-spi, Mark Brown

On 21 May 2015 at 01:38, Brian Norris <computersforpeace@gmail.com> wrote:
> + linux-spi, Mark
>
> On Thu, Apr 30, 2015 at 03:38:50PM +0200, Michal Suchanek wrote:
>> My SPI controller driver does not support DMA so writes are truncated to
>> FIFO size.
>
> Which SPI master driver?

I am using sunxi SPI driver. The dmaengine support for sunxi is not
yet in mainline kernel so the SPI master functionality is limited.

>
>> Check the amount of data actually written by the driver.
>
> I'm not sure if we should just reactively use the retlen, or if we
> should be communicating such a limitation via the SPI API. Thoughts?
>

Is there any driver that would break if the SPI master truncated
writes when the message is too long rather than returning an error an
refusing the transfer?

m25p80 as is would because it assumes all data is always written.

Some display driver I tried earlier has an option to limit transfer
size actively in the driver.

Thanks

Michal

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

* Re: [PATCH 2/3] MTD: spi-nor: check for short writes in spi_nor_write.
  2015-05-21  8:39     ` Michal Suchanek
@ 2015-05-21 10:28       ` Mark Brown
  2015-05-22  7:17         ` Brian Norris
  0 siblings, 1 reply; 15+ messages in thread
From: Mark Brown @ 2015-05-21 10:28 UTC (permalink / raw)
  To: Michal Suchanek
  Cc: Brian Norris, linux-sunxi, Rob Herring, Pawel Moll, Mark Rutland,
	Ian Campbell, Kumar Gala, David Woodhouse, Marek Vasut,
	Huang Shijie, Rafał Miłecki, Ben Hutchings,
	Alison Chaiken, Mika Westerberg,
	Bean Huo 霍斌斌 (beanhuo),
	grmoore, devicetree, Linux Kernel Mailing List, linux-mtd,
	linux-spi

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

On Thu, May 21, 2015 at 10:39:13AM +0200, Michal Suchanek wrote:
> On 21 May 2015 at 01:38, Brian Norris <computersforpeace@gmail.com> wrote:

Why is this thread about SPI error handling CCed to quite so many
people?

> >> Check the amount of data actually written by the driver.

> > I'm not sure if we should just reactively use the retlen, or if we
> > should be communicating such a limitation via the SPI API. Thoughts?

> Is there any driver that would break if the SPI master truncated
> writes when the message is too long rather than returning an error an
> refusing the transfer?

Any such driver is buggy, the actual length transferred has always been
a part of the SPI API.  We should probably expose limitations so clients
can query in advance (we don't at the minute) but it'd be a while before
clients could rely on that information being useful and it's still
possible things can be truncated by error.

With modern drivers using transfer_one() where we have control of the
chip select we do also have the ability to add support to the core for
chopping large transfers up into smaller ones that the hardware can
handle transparently.  That won't for everything though since it depends
on us being able to manually control the chip select which not all
hardware can do.

[-- Attachment #2: Digital signature --]
[-- Type: application/pgp-signature, Size: 473 bytes --]

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

* Re: [PATCH 2/3] MTD: spi-nor: check for short writes in spi_nor_write.
  2015-05-21 10:28       ` Mark Brown
@ 2015-05-22  7:17         ` Brian Norris
  2015-05-22  7:25           ` Brian Norris
  0 siblings, 1 reply; 15+ messages in thread
From: Brian Norris @ 2015-05-22  7:17 UTC (permalink / raw)
  To: Mark Brown
  Cc: Michal Suchanek, linux-sunxi, Rob Herring, Pawel Moll,
	Mark Rutland, Ian Campbell, Kumar Gala, David Woodhouse,
	Marek Vasut, Huang Shijie, Rafał Miłecki,
	Ben Hutchings, Alison Chaiken, Mika Westerberg,
	Bean Huo 霍斌斌 (beanhuo),
	grmoore, devicetree, Linux Kernel Mailing List, linux-mtd,
	linux-spi

On Thu, May 21, 2015 at 11:28:02AM +0100, Mark Brown wrote:
> On Thu, May 21, 2015 at 10:39:13AM +0200, Michal Suchanek wrote:
> > On 21 May 2015 at 01:38, Brian Norris <computersforpeace@gmail.com> wrote:
> 
> Why is this thread about SPI error handling CCed to quite so many
> people?

I can't really speak for the original patch author, who created the CC
list. I added you for comment on the SPI API (thanks BTW).

This is part of a series that included an ill-conceived DT binding for
recording a "max transfer length" property in the flash node. That's one
step that easily blows up the CC list for the series, as there are 5 DT
maintainers and a mailing list. Others are contributors to the m25p80 /
spi-nor drivers. (All in all, you can probably trace this back to
scripts/get_maintainer.pl.)

> > >> Check the amount of data actually written by the driver.
> 
> > > I'm not sure if we should just reactively use the retlen, or if we
> > > should be communicating such a limitation via the SPI API. Thoughts?
> 
> > Is there any driver that would break if the SPI master truncated
> > writes when the message is too long rather than returning an error an
> > refusing the transfer?
> 
> Any such driver is buggy, the actual length transferred has always been
> a part of the SPI API.

OK, so m25p80.c currently checks the retlen
(spi_message::actual_length), but it doesn't actually handle it well if
the SPI master can't write a full page-size chunk in one go. It looks
like we'd leave holes in the programmed data right now.

So that qualifies as buggy, and that's part of what Michal is trying to
fix, I think. Admittedly, as he's using an out-of-tree driver, I'm not
sure I know exactly what failure modes he is hitting yet.

> We should probably expose limitations so clients
> can query in advance (we don't at the minute) but it'd be a while before
> clients could rely on that information being useful and it's still
> possible things can be truncated by error.

That might help in the long run. In this case, I think we might be able
to get by (for a properly-functioning SPI driver with a limited transfer
size) with the current API, and handling the 'return length < message
length' case better.

BTW, one extra note for Michal regarding your SPI controller/driver
transfer length limitation: you would do well to try as much as possible
to allow full NOR pages to be programmed in one SPINOR_OP_PP sequence. I
know of some SPI NOR that, though they are byte addressable, actually
have opaque internal ECC which is encoded on page boundaries, so you
get better flash lifetime if you program on page boundaries, rather than
on whatever smaller chunk size your SPI driver supports. So that might
require a little more work on your SPI driver.

Brian

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

* Re: [PATCH 2/3] MTD: spi-nor: check for short writes in spi_nor_write.
  2015-05-22  7:17         ` Brian Norris
@ 2015-05-22  7:25           ` Brian Norris
  2015-05-22  9:37             ` Mark Brown
  0 siblings, 1 reply; 15+ messages in thread
From: Brian Norris @ 2015-05-22  7:25 UTC (permalink / raw)
  To: Mark Brown
  Cc: Michal Suchanek, linux-sunxi, Marek Vasut,
	Rafał Miłecki, Alison Chaiken, Mika Westerberg,
	Bean Huo 霍斌斌 (beanhuo),
	Linux Kernel Mailing List, linux-mtd, linux-spi

(trimming CC a little this time, though it's still a bit large)

On Fri, May 22, 2015 at 12:17:27AM -0700, Brian Norris wrote:
> Admittedly, as he's using an out-of-tree driver, I'm not
> sure I know exactly what failure modes he is hitting yet.

Sorry, I realized I misread here. He's using spi-sunxi. Given that...

... is this code even valid?

static int sun6i_spi_transfer_one(struct spi_master *master,
                                  struct spi_device *spi,
                                  struct spi_transfer *tfr)
{
...
	/* We don't support transfer larger than the FIFO */
	if (tfr->len > SUN6I_FIFO_DEPTH)
		return -EINVAL;

Seems like it should be looping over the transfer in multiple chunks
instead.

Brian

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

* Re: [PATCH 2/3] MTD: spi-nor: check for short writes in spi_nor_write.
  2015-05-22  7:25           ` Brian Norris
@ 2015-05-22  9:37             ` Mark Brown
  0 siblings, 0 replies; 15+ messages in thread
From: Mark Brown @ 2015-05-22  9:37 UTC (permalink / raw)
  To: Brian Norris
  Cc: Michal Suchanek, linux-sunxi, Marek Vasut,
	Rafał Miłecki, Alison Chaiken, Mika Westerberg,
	Bean Huo 霍斌斌 (beanhuo),
	Linux Kernel Mailing List, linux-mtd, linux-spi

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

On Fri, May 22, 2015 at 12:25:05AM -0700, Brian Norris wrote:
> On Fri, May 22, 2015 at 12:17:27AM -0700, Brian Norris wrote:

> > Admittedly, as he's using an out-of-tree driver, I'm not
> > sure I know exactly what failure modes he is hitting yet.

> Sorry, I realized I misread here. He's using spi-sunxi. Given that...

> ... is this code even valid?

> static int sun6i_spi_transfer_one(struct spi_master *master,
>                                   struct spi_device *spi,
>                                   struct spi_transfer *tfr)
> {
> ...
> 	/* We don't support transfer larger than the FIFO */
> 	if (tfr->len > SUN6I_FIFO_DEPTH)
> 		return -EINVAL;

> Seems like it should be looping over the transfer in multiple chunks
> instead.

Well, it's not ideal.  Like I say I think that logic probably belongs in
the core rather than individual drivers then we minimise the problems,
if I remember correctly there was the suggestion that the DMA code was
going to follow soon and be used for larger transfers when the original
driver was merged.

[-- Attachment #2: Digital signature --]
[-- Type: application/pgp-signature, Size: 473 bytes --]

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

end of thread, other threads:[~2015-05-22  9:37 UTC | newest]

Thread overview: 15+ messages (download: mbox.gz / follow: Atom feed)
-- links below jump to the message on this page --
     [not found] <cover.1430403750.git.hramrach@gmail.com>
     [not found] ` <3b0c112672f364452e80c333048161eaffb655db.1430403750.git.hramrach@gmail.com>
2015-04-30 14:58   ` [linux-sunxi] [PATCH 3/3] MTD: m25p80: Add option to limit SPI transfer size Julian Calaby
2015-05-20 23:27     ` Brian Norris
2015-04-30 16:30 ` [PATCH 0/3] Using SPI NOR flah on sunxi Thomas.Betker
2015-04-30 16:56   ` Michal Suchanek
2015-04-30 18:34     ` Marek Vasut
2015-05-20 23:54       ` Brian Norris
     [not found] ` <55132b4496e7fe73f949186c0f140f3e4fd4e2c7.1430403750.git.hramrach@gmail.com>
2015-04-30 18:43   ` [PATCH 1/3] MTD: m25p80: fix write return value Marek Vasut
2015-04-30 21:37     ` Michal Suchanek
     [not found] ` <jwv4mnwfppf.fsf-monnier+gmane.comp.hardware.netbook.arm.sunxi@gnu.org>
2015-05-04 10:32   ` [linux-sunxi] Re: [PATCH 0/3] Using SPI NOR flah on sunxi Michal Suchanek
     [not found] ` <50c40ef17ab6566f35ef5a4426bf23567f896db7.1430403750.git.hramrach@gmail.com>
2015-05-20 23:38   ` [PATCH 2/3] MTD: spi-nor: check for short writes in spi_nor_write Brian Norris
2015-05-21  8:39     ` Michal Suchanek
2015-05-21 10:28       ` Mark Brown
2015-05-22  7:17         ` Brian Norris
2015-05-22  7:25           ` Brian Norris
2015-05-22  9:37             ` Mark Brown

This is a public inbox, see mirroring instructions
for how to clone and mirror all data and code used for this inbox;
as well as URLs for NNTP newsgroup(s).