Commit 4d59ed85 authored by Javier Martinez Canillas's avatar Javier Martinez Canillas Committed by Jacek Anaszewski

leds: Export OF module alias information in missing drivers

The I2C core always reports the MODALIAS uevent as "i2c:<modalias>"
regardless of the mechanism that was used to register the device
(i.e: OF or board code) and the table that is used later to match
the driver with the device (i.e: I2C id table or OF match table).

So drivers needs to export the I2C id table and this be built into
the module or udev won't have the necessary information to autoload
the needed driver module when the device is added.

But this means that OF-only drivers needs to have both OF and I2C id
tables that have to be kept in sync and also the dev node compatible
manufacturer prefix is stripped when reporting the MODALIAS. Which can
lead to issues if two vendors use the same I2C device name for example.

To avoid the above, the I2C core behavior may be changed in the future
to not require an SPI device table for OF-only drivers and report the
OF module alias. So, it's better to also export the OF table even when
is unused now to prevent breaking module loading when the core changes.
Signed-off-by: default avatarJavier Martinez Canillas <javier@osg.samsung.com>
Signed-off-by: default avatarJacek Anaszewski <j.anaszewski@samsung.com>
parent ed133352
...@@ -332,6 +332,7 @@ static const struct of_device_id of_pca963x_match[] = { ...@@ -332,6 +332,7 @@ static const struct of_device_id of_pca963x_match[] = {
{ .compatible = "nxp,pca9635", }, { .compatible = "nxp,pca9635", },
{}, {},
}; };
MODULE_DEVICE_TABLE(of, of_pca963x_match);
#else #else
static struct pca963x_platform_data * static struct pca963x_platform_data *
pca963x_dt_init(struct i2c_client *client, struct pca963x_chipdef *chip) pca963x_dt_init(struct i2c_client *client, struct pca963x_chipdef *chip)
......
...@@ -735,6 +735,7 @@ static const struct of_device_id of_tca6507_leds_match[] = { ...@@ -735,6 +735,7 @@ static const struct of_device_id of_tca6507_leds_match[] = {
{ .compatible = "ti,tca6507", }, { .compatible = "ti,tca6507", },
{}, {},
}; };
MODULE_DEVICE_TABLE(of, of_tca6507_leds_match);
#else #else
static struct tca6507_platform_data * static struct tca6507_platform_data *
......
Markdown is supported
0%
or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment