Re: [PATCH] tpm_tis_spi: add missing SPI device ID entries

From: Jarkko Sakkinen
Date: Mon May 31 2021 - 01:37:29 EST


On Thu, May 27, 2021 at 05:23:52PM +0200, Javier Martinez Canillas wrote:
> The SPI core always reports a "MODALIAS=spi:<foo>", even if the device was
> registered via OF. This means that this module won't auto-load if a DT has
> for example has a node with a compatible "infineon,slb9670" string.
>
> In that case kmod will expect a "MODALIAS=of:N*T*Cinfineon,slb9670" uevent
> but instead will get a "MODALIAS=spi:slb9670", which is not present in the
> kernel module aliases:
>
> $ modinfo drivers/char/tpm/tpm_tis_spi.ko | grep alias
> alias: of:N*T*Cgoogle,cr50C*
> alias: of:N*T*Cgoogle,cr50
> alias: of:N*T*Ctcg,tpm_tis-spiC*
> alias: of:N*T*Ctcg,tpm_tis-spi
> alias: of:N*T*Cinfineon,slb9670C*
> alias: of:N*T*Cinfineon,slb9670
> alias: of:N*T*Cst,st33htpm-spiC*
> alias: of:N*T*Cst,st33htpm-spi
> alias: spi:cr50
> alias: spi:tpm_tis_spi
> alias: acpi*:SMO0768:*
>
> To workaround this issue, add in the SPI device ID table all the entries
> that are present in the OF device ID table.
>
> Reported-by: Alexander Wellbrock <a.wellbrock@xxxxxxxxxxx>
> Signed-off-by: Javier Martinez Canillas <javierm@xxxxxxxxxx>
> ---
>
> drivers/char/tpm/tpm_tis_spi_main.c | 2 ++
> 1 file changed, 2 insertions(+)
>
> diff --git a/drivers/char/tpm/tpm_tis_spi_main.c b/drivers/char/tpm/tpm_tis_spi_main.c
> index 3856f6ebcb3..de4209003a4 100644
> --- a/drivers/char/tpm/tpm_tis_spi_main.c
> +++ b/drivers/char/tpm/tpm_tis_spi_main.c
> @@ -260,6 +260,8 @@ static int tpm_tis_spi_remove(struct spi_device *dev)
> }
>
> static const struct spi_device_id tpm_tis_spi_id[] = {
> + { "st33htpm-spi", (unsigned long)tpm_tis_spi_probe },
> + { "slb9670", (unsigned long)tpm_tis_spi_probe },
> { "tpm_tis_spi", (unsigned long)tpm_tis_spi_probe },
> { "cr50", (unsigned long)cr50_spi_probe },
> {}
> --
> 2.31.1
>
>

Reviewed-by: Jarkko Sakkinen <jarkko@xxxxxxxxxx>

/Jarkko