2022-05-21 05:06:31

by Javier Martinez Canillas

[permalink] [raw]
Subject: [PATCH] drm/st7735r: Fix module autoloading for Okaya RH128128T

The SPI core always reports a "MODALIAS=spi:<foo>", even if the device was
registered via OF. This means that the st7735r.ko module won't autoload if
a DT has a node with a compatible "okaya,rh128128t" string.

In that case, kmod expects a "MODALIAS=of:N*T*Cokaya,rh128128t" uevent but
instead will get a "MODALIAS=spi:rh128128t", which is not present in the
list of aliases:

$ modinfo drivers/gpu/drm/tiny/st7735r.ko | grep alias
alias: of:N*T*Cokaya,rh128128tC*
alias: of:N*T*Cokaya,rh128128t
alias: of:N*T*Cjianda,jd-t18003-t01C*
alias: of:N*T*Cjianda,jd-t18003-t01
alias: spi:jd-t18003-t01

To workaround this issue, add in the SPI table an entry for that device.

Fixes: d1d511d516f7 ("drm: tiny: st7735r: Add support for Okaya RH128128T")
Signed-off-by: Javier Martinez Canillas <[email protected]>
---

drivers/gpu/drm/tiny/st7735r.c | 1 +
1 file changed, 1 insertion(+)

diff --git a/drivers/gpu/drm/tiny/st7735r.c b/drivers/gpu/drm/tiny/st7735r.c
index 29d618093e94..e0f02d367d88 100644
--- a/drivers/gpu/drm/tiny/st7735r.c
+++ b/drivers/gpu/drm/tiny/st7735r.c
@@ -174,6 +174,7 @@ MODULE_DEVICE_TABLE(of, st7735r_of_match);

static const struct spi_device_id st7735r_id[] = {
{ "jd-t18003-t01", (uintptr_t)&jd_t18003_t01_cfg },
+ { "rh128128t", (uintptr_t)&rh128128t_cfg },
{ },
};
MODULE_DEVICE_TABLE(spi, st7735r_id);
--
2.36.1



2022-05-23 05:58:26

by David Lechner

[permalink] [raw]
Subject: Re: [PATCH] drm/st7735r: Fix module autoloading for Okaya RH128128T

On 5/20/22 4:16 AM, Javier Martinez Canillas wrote:
> The SPI core always reports a "MODALIAS=spi:<foo>", even if the device was
> registered via OF. This means that the st7735r.ko module won't autoload if
> a DT has a node with a compatible "okaya,rh128128t" string.
>
> In that case, kmod expects a "MODALIAS=of:N*T*Cokaya,rh128128t" uevent but
> instead will get a "MODALIAS=spi:rh128128t", which is not present in the
> list of aliases:
>
> $ modinfo drivers/gpu/drm/tiny/st7735r.ko | grep alias
> alias: of:N*T*Cokaya,rh128128tC*
> alias: of:N*T*Cokaya,rh128128t
> alias: of:N*T*Cjianda,jd-t18003-t01C*
> alias: of:N*T*Cjianda,jd-t18003-t01
> alias: spi:jd-t18003-t01
>
> To workaround this issue, add in the SPI table an entry for that device.
>
> Fixes: d1d511d516f7 ("drm: tiny: st7735r: Add support for Okaya RH128128T")
> Signed-off-by: Javier Martinez Canillas <[email protected]>
> ---

Acked-by: David Lechner <[email protected]>


2022-05-23 07:59:50

by Geert Uytterhoeven

[permalink] [raw]
Subject: Re: [PATCH] drm/st7735r: Fix module autoloading for Okaya RH128128T

Hi Javier,

CC spi

On Fri, May 20, 2022 at 11:16 AM Javier Martinez Canillas
<[email protected]> wrote:
> The SPI core always reports a "MODALIAS=spi:<foo>", even if the device was
> registered via OF. This means that the st7735r.ko module won't autoload if
> a DT has a node with a compatible "okaya,rh128128t" string.
>
> In that case, kmod expects a "MODALIAS=of:N*T*Cokaya,rh128128t" uevent but
> instead will get a "MODALIAS=spi:rh128128t", which is not present in the
> list of aliases:
>
> $ modinfo drivers/gpu/drm/tiny/st7735r.ko | grep alias
> alias: of:N*T*Cokaya,rh128128tC*
> alias: of:N*T*Cokaya,rh128128t
> alias: of:N*T*Cjianda,jd-t18003-t01C*
> alias: of:N*T*Cjianda,jd-t18003-t01
> alias: spi:jd-t18003-t01
>
> To workaround this issue, add in the SPI table an entry for that device.
>
> Fixes: d1d511d516f7 ("drm: tiny: st7735r: Add support for Okaya RH128128T")
> Signed-off-by: Javier Martinez Canillas <[email protected]>

Thanks for your patch!
We really need to fix this at the subsystem level.

Reviewed-by: Geert Uytterhoeven <[email protected]>


> --- a/drivers/gpu/drm/tiny/st7735r.c
> +++ b/drivers/gpu/drm/tiny/st7735r.c
> @@ -174,6 +174,7 @@ MODULE_DEVICE_TABLE(of, st7735r_of_match);
>
> static const struct spi_device_id st7735r_id[] = {
> { "jd-t18003-t01", (uintptr_t)&jd_t18003_t01_cfg },
> + { "rh128128t", (uintptr_t)&rh128128t_cfg },
> { },
> };
> MODULE_DEVICE_TABLE(spi, st7735r_id);

Gr{oetje,eeting}s,

Geert

--
Geert Uytterhoeven -- There's lots of Linux beyond ia32 -- [email protected]

In personal conversations with technical people, I call myself a hacker. But
when I'm talking to journalists I just say "programmer" or something like that.
-- Linus Torvalds

2022-05-23 14:12:44

by Javier Martinez Canillas

[permalink] [raw]
Subject: Re: [PATCH] drm/st7735r: Fix module autoloading for Okaya RH128128T

Hello Geert,

On 5/20/22 14:02, Geert Uytterhoeven wrote:
> Hi Javier,
>
> CC spi
>
> On Fri, May 20, 2022 at 11:16 AM Javier Martinez Canillas
> <[email protected]> wrote:
>> The SPI core always reports a "MODALIAS=spi:<foo>", even if the device was
>> registered via OF. This means that the st7735r.ko module won't autoload if
>> a DT has a node with a compatible "okaya,rh128128t" string.
>>
>> In that case, kmod expects a "MODALIAS=of:N*T*Cokaya,rh128128t" uevent but
>> instead will get a "MODALIAS=spi:rh128128t", which is not present in the
>> list of aliases:
>>
>> $ modinfo drivers/gpu/drm/tiny/st7735r.ko | grep alias
>> alias: of:N*T*Cokaya,rh128128tC*
>> alias: of:N*T*Cokaya,rh128128t
>> alias: of:N*T*Cjianda,jd-t18003-t01C*
>> alias: of:N*T*Cjianda,jd-t18003-t01
>> alias: spi:jd-t18003-t01
>>
>> To workaround this issue, add in the SPI table an entry for that device.
>>
>> Fixes: d1d511d516f7 ("drm: tiny: st7735r: Add support for Okaya RH128128T")
>> Signed-off-by: Javier Martinez Canillas <[email protected]>
>
> Thanks for your patch!
> We really need to fix this at the subsystem level.
>

Yes, agreed.

> Reviewed-by: Geert Uytterhoeven <[email protected]>
>

Thanks! I've pushed this to drm-misc (drm-misc-next) with your Reviewed-by
and David's Acked-by.

--
Best regards,

Javier Martinez Canillas
Linux Engineering
Red Hat