[PATCH 1/2] mtd: spi-nor: When a flash memory is missing do not report an error

Michael Walle michael at walle.cc
Thu Jul 14 14:51:56 PDT 2022


Am 2022-07-14 22:55, schrieb Michal Suchánek:
> On Thu, Jul 14, 2022 at 09:41:48PM +0200, Michael Walle wrote:
>> Hi,
>> 
>> Am 2022-07-14 21:19, schrieb Michal Suchanek:
>> > It is normal that devices are designed with multiple types of storage,
>> > and only some types of storage are present.
>> >
>> > The kernel can handle this situation gracefully for many types of
>> > storage devices such as mmc or ata but it reports and error when spi
>> > flash is not present.
>> >
>> > Only print a notice that the storage device is missing when no response
>> > to the identify command is received.
>> >
>> > Consider reply buffers with all bits set to the same value no response.
>> 
>> I'm not sure you can compare SPI with ATA and MMC. I'm just speaking 
>> of
>> DT now, but there, for ATA and MMC you just describe the controller 
>> and
>> it will auto-detect the connected storage. Whereas with SPI you 
>> describe
> 
> Why does mmc assume storage and SDIO must be descibed? Why the special
> casing?

I can't follow you here. My SDIO wireless card just works in an SD
slot and doesn't have to be described.

>> both the controller and the flash. So I'd argue that your hardware
>> description is wrong if it describes a flash which is not present.
> 
> At any rate the situation is the same - the storage may be present
> sometimes. I don't think assuming some kind of device by defualt is a
> sound practice.

Where is the assumption when the DT tells you there is a flash
on a specific chip select but actually there it isn't. Shouldn't
the DT then be fixed?

Maybe I don't understand your problem. What are you trying to
solve? I mean this just demotes an error to an info message.

> However, when the board is designed for a specific kind of device which
> is not always present, and the kernel can detect the device, it is
> perfectly fine to describe it.
> 
> The alternative is to not use the device at all, even when present,
> which is kind of useless.

Or let the bootloader update your device tree and disable the device
if it's not there? Or load an overlay if it is there?

-michael



More information about the linux-arm-kernel mailing list