Hello Lee, On 09/11/2014 10:00 AM, Sjoerd Simons wrote: >> > > >> > > -static const struct of_device_id mxt_of_match[] = { >> > > - { .compatible = "atmel,maxtouch", }, >> > > - {}, >> > > -}; >> > > -MODULE_DEVICE_TABLE(of, mxt_of_match); >> > > - >> > > static const struct i2c_device_id mxt_id[] = { >> > > { "qt602240_ts", 0 }, >> > > { "atmel_mxt_ts", 0 }, >> > > { "atmel_mxt_tp", 0 }, >> > > + { "maxtouch", 0 }, >> > > { "mXT224", 0 }, >> > > { } >> > > }; >> > > @@ -2286,7 +2281,6 @@ static struct i2c_driver mxt_driver = { >> > > .driver = { >> > > .name = "atmel_mxt_ts", >> > > .owner = THIS_MODULE, >> > > - .of_match_table = of_match_ptr(mxt_of_match), >> > > .pm = &mxt_pm_ops, >> > > }, >> > > .probe = mxt_probe, >> > > >> > >> > I see that Lee is working to allow the I2C subsystem to not need an I2C ID >> > table to match [0]. I'll let Lee to comment what the future plans are and if >> > his series are going to solve your issue since I'm not that familiar with the >> > I2C core. >> >> It's wrong to expect DT to probe these devices without a compatible >> string. It does so at the moment, but this is a bi-product and not >> the correct method. > > Ok, which means removing the mxt_of_match table in this patch is wrong.. > I'll fix that for for a V2. > > However that makes adding the "maxtouch" string to the i2c device table > somewhat cumbersome as it only gets added in this case to ensure > module-autoloading can happen as the modalias presented to userspace is > going still going to be i2c:maxtouch. > > Tbh, the bigger problem this is pointing out is that for I2C devices > with only an OF compability tring module auto-loading is broken... > To expand on what Sjoerd already said and just to be sure everyone is on the same page. The problem is that right now the driver reports the following modalias: # cat /sys/class/i2c-adapter/i2c-8/8-004b/modalias i2c:maxtouch but if you look at the module information, that is not a valid alias: # modinfo atmel_mxt_ts | grep alias alias: i2c:mXT224 alias: i2c:atmel_mxt_tp alias: i2c:atmel_mxt_ts alias: i2c:qt602240_ts alias: of:N*T*Catmel,maxtouch* which means that udev/kmod can't load the module automatically based on the alias information. The aliases are filled by both MODULE_DEVICE_TABLE(i2c, mxt_id) and MODULE_DEVICE_TABLE(of, mxt_of_match) so after Sjoerd's patch: # cat /sys/class/i2c-adapter/i2c-8/8-004b/modalias i2c:maxtouch # modinfo atmel_mxt_ts | grep alias alias: i2c:mXT224 alias: i2c:maxtouch alias: i2c:atmel_mxt_tp alias: i2c:atmel_mxt_ts alias: i2c:qt602240_ts which matches the reported uevent so the module will be auto-loaded. This is because the I2C subsystem hardcodes i2c:<client->name>, if you look at drivers/i2c/i2c-core.c: /* uevent helps with hotplug: modprobe -q $(MODALIAS) */ static int i2c_device_uevent(struct device *dev, struct kobj_uevent_env *env) { ... if (add_uevent_var(env, "MODALIAS=%s%s", I2C_MODULE_PREFIX, client->name)) ... } I've looked at Lee's series and AFAICT that remains the same so I second Sjoerd that module auto-loading will continue to be broken. Best regards, Javier -- To unsubscribe from this list: send the line "unsubscribe linux-input" in the body of a message to majordomo@xxxxxxxxxxxxxxx More majordomo info at http://vger.kernel.org/majordomo-info.html