Commit ab3555b4 authored by Biju Das's avatar Biju Das Committed by Jonathan Cameron

iio: chemical: atlas-sensor: Convert enum->pointer for data in the match tables

Convert enum->pointer for data in the match tables, so that
device_get_match_data() can do match against OF/ACPI/I2C tables, once i2c
bus type match support added to it.

Replace enum->struct *atlas_device for data in the match table. Simplify
the probe() by replacing device_get_match_data() and ID lookup for
retrieving data by i2c_get_match_data().

While at it, add const qualifier to struct atlas_device and drop inner
trailing commas from OF table.
Signed-off-by: default avatarBiju Das <biju.das.jz@bp.renesas.com>
Reviewed-by: default avatarAndy Shevchenko <andriy.shevchenko@linux.intel.com>
Link: https://lore.kernel.org/r/20230818185531.336672-1-biju.das.jz@bp.renesas.comSigned-off-by: default avatarJonathan Cameron <Jonathan.Cameron@huawei.com>
parent 2b0ddc83
...@@ -87,7 +87,7 @@ enum { ...@@ -87,7 +87,7 @@ enum {
struct atlas_data { struct atlas_data {
struct i2c_client *client; struct i2c_client *client;
struct iio_trigger *trig; struct iio_trigger *trig;
struct atlas_device *chip; const struct atlas_device *chip;
struct regmap *regmap; struct regmap *regmap;
struct irq_work work; struct irq_work work;
unsigned int interrupt_enabled; unsigned int interrupt_enabled;
...@@ -353,7 +353,7 @@ struct atlas_device { ...@@ -353,7 +353,7 @@ struct atlas_device {
int delay; int delay;
}; };
static struct atlas_device atlas_devices[] = { static const struct atlas_device atlas_devices[] = {
[ATLAS_PH_SM] = { [ATLAS_PH_SM] = {
.channels = atlas_ph_channels, .channels = atlas_ph_channels,
.num_channels = 3, .num_channels = 3,
...@@ -589,30 +589,29 @@ static const struct iio_info atlas_info = { ...@@ -589,30 +589,29 @@ static const struct iio_info atlas_info = {
}; };
static const struct i2c_device_id atlas_id[] = { static const struct i2c_device_id atlas_id[] = {
{ "atlas-ph-sm", ATLAS_PH_SM }, { "atlas-ph-sm", (kernel_ulong_t)&atlas_devices[ATLAS_PH_SM] },
{ "atlas-ec-sm", ATLAS_EC_SM }, { "atlas-ec-sm", (kernel_ulong_t)&atlas_devices[ATLAS_EC_SM] },
{ "atlas-orp-sm", ATLAS_ORP_SM }, { "atlas-orp-sm", (kernel_ulong_t)&atlas_devices[ATLAS_ORP_SM] },
{ "atlas-do-sm", ATLAS_DO_SM }, { "atlas-do-sm", (kernel_ulong_t)&atlas_devices[ATLAS_DO_SM] },
{ "atlas-rtd-sm", ATLAS_RTD_SM }, { "atlas-rtd-sm", (kernel_ulong_t)&atlas_devices[ATLAS_RTD_SM] },
{} {}
}; };
MODULE_DEVICE_TABLE(i2c, atlas_id); MODULE_DEVICE_TABLE(i2c, atlas_id);
static const struct of_device_id atlas_dt_ids[] = { static const struct of_device_id atlas_dt_ids[] = {
{ .compatible = "atlas,ph-sm", .data = (void *)ATLAS_PH_SM, }, { .compatible = "atlas,ph-sm", .data = &atlas_devices[ATLAS_PH_SM] },
{ .compatible = "atlas,ec-sm", .data = (void *)ATLAS_EC_SM, }, { .compatible = "atlas,ec-sm", .data = &atlas_devices[ATLAS_EC_SM] },
{ .compatible = "atlas,orp-sm", .data = (void *)ATLAS_ORP_SM, }, { .compatible = "atlas,orp-sm", .data = &atlas_devices[ATLAS_ORP_SM] },
{ .compatible = "atlas,do-sm", .data = (void *)ATLAS_DO_SM, }, { .compatible = "atlas,do-sm", .data = &atlas_devices[ATLAS_DO_SM] },
{ .compatible = "atlas,rtd-sm", .data = (void *)ATLAS_RTD_SM, }, { .compatible = "atlas,rtd-sm", .data = &atlas_devices[ATLAS_RTD_SM] },
{ } { }
}; };
MODULE_DEVICE_TABLE(of, atlas_dt_ids); MODULE_DEVICE_TABLE(of, atlas_dt_ids);
static int atlas_probe(struct i2c_client *client) static int atlas_probe(struct i2c_client *client)
{ {
const struct i2c_device_id *id = i2c_client_get_device_id(client);
struct atlas_data *data; struct atlas_data *data;
struct atlas_device *chip; const struct atlas_device *chip;
struct iio_trigger *trig; struct iio_trigger *trig;
struct iio_dev *indio_dev; struct iio_dev *indio_dev;
int ret; int ret;
...@@ -621,10 +620,7 @@ static int atlas_probe(struct i2c_client *client) ...@@ -621,10 +620,7 @@ static int atlas_probe(struct i2c_client *client)
if (!indio_dev) if (!indio_dev)
return -ENOMEM; return -ENOMEM;
if (!dev_fwnode(&client->dev)) chip = i2c_get_match_data(client);
chip = &atlas_devices[id->driver_data];
else
chip = &atlas_devices[(unsigned long)device_get_match_data(&client->dev)];
indio_dev->info = &atlas_info; indio_dev->info = &atlas_info;
indio_dev->name = ATLAS_DRV_NAME; indio_dev->name = ATLAS_DRV_NAME;
......
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