Re: [PATCH] spidev: Make probe to fail early if a spidev compatible is used

From: Javier Martinez Canillas
Date: Fri Nov 19 2021 - 03:32:46 EST


Hello Uwe,

On 11/19/21 08:40, Uwe Kleine-König wrote:

[snip]

>
> It affects c) only if the device tree has a device with compatible =
> "spidev". For such a device the history is:
>
> - Before 956b200a846e ("spi: spidev: Warn loudly if instantiated from
> DT as "spidev"") in v4.1-rc1:
> Just bound silently
>
> - After 956b200a846e up to 6840615f85f6 ("spi: spidev: Add SPI ID
> table") in v5.15-rc6:
> The device was automatically bound with a warning
>
> - After 6840615f85f6:
> The device doesn't bind automatically, when using driver_override
> you get a warning.
>
> - With the proposed patch:
> The device cannot be bound even using driver_override
>

My understanding is that there's an agreement that using "spidev" as the
specific compatible string is something that should not be supported.

> Not this affects also devices that use
>
> compatible = "myvender,devicename", "spidev";
>

This is indeed a corner case and I'm less sure what the kernel should do
about it. I just learned now that of_device_is_compatible() return value
is not a boolean but instead a "score":

https://elixir.bootlin.com/linux/latest/source/drivers/of/base.c#L455

I wonder if we could add another helper that returns the index instead,
and do: of_device_is_compatible_index(spi->dev.of_node, "spidev") == 0

Another option is to add an of_device_is_compatible_specific() helper.

Or just consider DT nodes with a general "spidev" compatible string to
also not be valid. I would lean towards this one I think.

Best regards,
--
Javier Martinez Canillas
Linux Engineering
Red Hat