Hello Brian and Mark, On 11/16/2015 06:32 PM, Javier Martinez Canillas wrote: > On 11/16/2015 05:47 PM, Brian Norris wrote: >> On Mon, Nov 16, 2015 at 05:00:43PM -0300, Javier Martinez Canillas wrote: >>> On 11/16/2015 04:24 PM, Brian Norris wrote: [snip] >>>> I don't think you have problems only with bad FDTs. I think you have a >>>> problem with perfectly valid DTs. >>>> >>> >>> Agreed, I wonder if spi_uevent() shouldn't be changed to report both the >>> OF and old SPI modaliases to avoid breaking a lot of drivers but at the >>> same time allowing DT-only drivers to not need an SPI ID table. >> >> That's the solution I imagined, though I haven't tested it yet. I don't >> see much precedent for reporting multiple modaliases, so there could be >> some kind of ABI issues around that too. >> > > Ok, I'm glad that we agree. This definitely needs to be discussed with more > people. I'll re-spin my patch and post a v2 reporting multiple modaliases > tomorrow after testing. > So I had some time today to test this approach but unfortunately it seems this workaround will not be possible because AFAICT kmod only takes into account the last MODALIAS reported as a uevent. I still have to check the kmod source code but that's my conclusion from trying to report both aliases. When looking at the uevent sysfs entry for the device, I see that both aliases are reported but if only a OF alias is built into the module, then kmod does not auto load the module unless the OF MODALIAS is the last one reported, i.e: # grep MODALIAS /sys/devices/platform/12d40000.spi/spi_master/spi2/spi2.0/uevent MODALIAS=spi:cros-ec-spi MODALIAS=of:Ncros-ecT<NULL>Cgoogle,cros-ec-spi # modinfo cros_ec_spi | grep alias alias: of:N*T*Cgoogle,cros-ec-spi* If I invert the order on which the uevent are reported, then the module is not autoloaded, i.e: # grep MODALIAS /sys/devices/platform/12d40000.spi/spi_master/spi2/spi2.0/uevent MODALIAS=of:Ncros-ecT<NULL>Cgoogle,cros-ec-spi MODALIAS=spi:cros-ec-spi # modinfo cros_ec_spi | grep alias alias: of:N*T*Cgoogle,cros-ec-spi* In this case only is loaded if the module has a spi:<alias>, i.e: # modinfo cros_ec_spi | grep alias alias: of:N*T*Cgoogle,cros-ec-spi* alias: spi:cros-ec-spi IOW, even when is possible to report more than one MODALIAS, user-space seems to only use the last one reported so using both don't work. Of course kmod can be changed to check for more than one MODALIAS but since the kernel should not break old user-space, the fact that a single MODALIAS was reported seems to be an ABI now due how is used. Best regards, -- Javier Martinez Canillas Open Source Group Samsung Research America -- To unsubscribe from this list: send the line "unsubscribe linux-spi" in the body of a message to majordomo@xxxxxxxxxxxxxxx More majordomo info at http://vger.kernel.org/majordomo-info.html