[<prev] [next>] [<thread-prev] [thread-next>] [day] [month] [year] [list]
Message-ID: <CALeDE9NKOdA-kA-SgbgiE8+corLBW8bh8he-Xqe+wkmQ9ja-xg@mail.gmail.com>
Date: Sat, 29 May 2021 14:50:01 +0100
From: Peter Robinson <pbrobinson@...il.com>
To: Javier Martinez Canillas <javierm@...hat.com>
Cc: linux-kernel@...r.kernel.org,
Alexander Wellbrock <a.wellbrock@...lbox.org>,
Jarkko Sakkinen <jarkko@...nel.org>,
Jason Gunthorpe <jgg@...pe.ca>,
Peter Huewe <peterhuewe@....de>,
linux-integrity@...r.kernel.org
Subject: Re: [PATCH] tpm_tis_spi: add missing SPI device ID entries
On Thu, May 27, 2021 at 4:24 PM Javier Martinez Canillas
<javierm@...hat.com> 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@...lbox.org>
> Signed-off-by: Javier Martinez Canillas <javierm@...hat.com>
Tested-by: Peter Robinson <pbrobinson@...il.com>
Tested on a Raspberry Pi4, with an Iridium 9670 module on 5.12.7 with
tpm_tis_spi built as a module.
> ---
>
> 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
>
Powered by blists - more mailing lists