mirror of
https://git.kernel.org/pub/scm/linux/kernel/git/torvalds/linux.git
synced 2025-01-07 22:03:14 +00:00
spi: wpcm-fiu: differentiate between unsupported and invalid requests
When the requested dirmap accesses are outside of the window, it is probably more sensible to return -EINVAL rather than an "unsupported" error code. If however the operation in itself is not supported, then -EOPNOTSUP is likely going to be preferred as it is a standard error code. >From a caller (and reviewer) point of view, distinguising between the two may be helpful because somehow one can be "fixed" while the other will always be refused no matter how hard we try. As part of a wider work to bring spi-nand continuous reads, it was useful to easily catch the upper limit direct mapping boundaries for each controller, with the idea of enlarging this area from a page to an eraseblock, without risking too many regressions. Signed-off-by: Miquel Raynal <miquel.raynal@bootlin.com> Link: https://msgid.link/r/20240522145255.995778-5-miquel.raynal@bootlin.com Signed-off-by: Mark Brown <broonie@kernel.org>
This commit is contained in:
parent
615725a9a8
commit
41b86b1455
@ -378,7 +378,7 @@ static int wpcm_fiu_dirmap_create(struct spi_mem_dirmap_desc *desc)
|
|||||||
int cs = spi_get_chipselect(desc->mem->spi, 0);
|
int cs = spi_get_chipselect(desc->mem->spi, 0);
|
||||||
|
|
||||||
if (desc->info.op_tmpl.data.dir != SPI_MEM_DATA_IN)
|
if (desc->info.op_tmpl.data.dir != SPI_MEM_DATA_IN)
|
||||||
return -ENOTSUPP;
|
return -EOPNOTSUPP;
|
||||||
|
|
||||||
/*
|
/*
|
||||||
* Unfortunately, FIU only supports a 16 MiB direct mapping window (per
|
* Unfortunately, FIU only supports a 16 MiB direct mapping window (per
|
||||||
@ -387,11 +387,11 @@ static int wpcm_fiu_dirmap_create(struct spi_mem_dirmap_desc *desc)
|
|||||||
* flashes that are bigger than 16 MiB.
|
* flashes that are bigger than 16 MiB.
|
||||||
*/
|
*/
|
||||||
if (desc->info.offset + desc->info.length > MAX_MEMORY_SIZE_PER_CS)
|
if (desc->info.offset + desc->info.length > MAX_MEMORY_SIZE_PER_CS)
|
||||||
return -ENOTSUPP;
|
return -EINVAL;
|
||||||
|
|
||||||
/* Don't read past the memory window */
|
/* Don't read past the memory window */
|
||||||
if (cs * MAX_MEMORY_SIZE_PER_CS + desc->info.offset + desc->info.length > fiu->memory_size)
|
if (cs * MAX_MEMORY_SIZE_PER_CS + desc->info.offset + desc->info.length > fiu->memory_size)
|
||||||
return -ENOTSUPP;
|
return -EINVAL;
|
||||||
|
|
||||||
return 0;
|
return 0;
|
||||||
}
|
}
|
||||||
|
Loading…
Reference in New Issue
Block a user