[RFC PATCH] mtd: spi-nor-core: Handle SPI_RX_SLOW in spi_nor_adjust_hwcaps()
Pratyush Yadav
p.yadav at ti.com
Wed Jul 28 19:42:31 CEST 2021
On 28/07/21 11:56PM, Bin Meng wrote:
> When CONFIG_SPI_FLASH_SMART_HWCAPS is on, SPI_RX_SLOW flag of the
> SPI controller is not honored. This adds the missing logic there.
>
> With this patch, SPI flash read works again with ICH SPI controller
> on Intel Crown Bay board.
>
> Signed-off-by: Bin Meng <bmeng.cn at gmail.com>
>
> ---
> The quirky stuff of ICH SPI controller is that it only supports normal
> read (opcode 3) but not fast read (opcode 11), so that's why SPI_RX_SLOW
> was introduced before.
>
> At present the ICH SPI driver does not implement the supports_op() hook.
> I can add a check against opcode 11 there, however I see a comment in
> spi_nor_check_op() saying that SPI controller implementation should not
> check the opcode.
>
> /*
> * First test with 4 address bytes. The opcode itself might be a 3B
> * addressing opcode but we don't care, because SPI controller
> * implementation should not check the opcode, but just the sequence.
> */
>
> drivers/mtd/spi/spi-nor-core.c | 5 +++++
> 1 file changed, 5 insertions(+)
>
> diff --git a/drivers/mtd/spi/spi-nor-core.c b/drivers/mtd/spi/spi-nor-core.c
> index 99e2f16349..e9b46c39b5 100644
> --- a/drivers/mtd/spi/spi-nor-core.c
> +++ b/drivers/mtd/spi/spi-nor-core.c
> @@ -2855,6 +2855,7 @@ spi_nor_adjust_hwcaps(struct spi_nor *nor,
> const struct spi_nor_flash_parameter *params,
> u32 *hwcaps)
> {
> + struct spi_slave *spi = nor->spi;
> unsigned int cap;
>
> /*
> @@ -2879,6 +2880,10 @@ spi_nor_adjust_hwcaps(struct spi_nor *nor,
> if (!(*hwcaps & BIT(cap)))
> continue;
>
> + if ((spi->mode & SPI_RX_SLOW) &&
> + (BIT(cap) == SNOR_HWCAPS_READ_FAST))
> + *hwcaps &= ~BIT(cap);
> +
NACK.
We already check for SPI_RX_SLOW in spi_nor_scan():
/* Some devices cannot do fast-read, no matter what DT tells us */
if ((info->flags & SPI_NOR_NO_FR) || (spi->mode & SPI_RX_SLOW))
params.hwcaps.mask &= ~SNOR_HWCAPS_READ_FAST;
I think the real bug here is that the smart spi_nor_adjust_hwcaps() does
not respect the flash's hwcaps, and only looks to the controller on what
can be supported. Doing the below should fix this:
diff --git a/drivers/mtd/spi/spi-nor-core.c b/drivers/mtd/spi/spi-nor-core.c
index 8dd44c0f1e..4323b49651 100644
--- a/drivers/mtd/spi/spi-nor-core.c
+++ b/drivers/mtd/spi/spi-nor-core.c
@@ -2741,7 +2741,7 @@ spi_nor_adjust_hwcaps(struct spi_nor *nor,
* Enable all caps by default. We will mask them after checking what's
* really supported using spi_mem_supports_op().
*/
- *hwcaps = SNOR_HWCAPS_ALL;
+ *hwcaps = SNOR_HWCAPS_ALL & params->hwcaps.mask;
/* X-X-X modes are not supported yet, mask them all. */
*hwcaps &= ~SNOR_HWCAPS_X_X_X;
Can you please test and confirm if it does indeed fix the issue for you?
> rdidx = spi_nor_hwcaps_read2cmd(BIT(cap));
> if (rdidx >= 0 &&
> spi_nor_check_readop(nor, ¶ms->reads[rdidx]))
> --
> 2.25.1
>
--
Regards,
Pratyush Yadav
Texas Instruments Inc.
More information about the U-Boot
mailing list