On 03/12/2018 12:09 PM, Dmitry Torokhov wrote: > This will make code instantiating I2C device a bit clearer. > > Signed-off-by: Dmitry Torokhov <dmitry.torokhov@xxxxxxxxx> Applied to my working branch for atmel_mxt_ts + chromeos_laptop.c for v4.17. Thanks! > --- > drivers/platform/chrome/chromeos_laptop.c | 35 +++++++++++++++-------- > 1 file changed, 23 insertions(+), 12 deletions(-) > > diff --git a/drivers/platform/chrome/chromeos_laptop.c b/drivers/platform/chrome/chromeos_laptop.c > index 08ce7a105e768..96e962ff38e87 100644 > --- a/drivers/platform/chrome/chromeos_laptop.c > +++ b/drivers/platform/chrome/chromeos_laptop.c > @@ -120,36 +120,47 @@ static struct i2c_board_info atmel_1664s_device = { > .flags = I2C_CLIENT_WAKE, > }; > > +static int chromeos_laptop_get_irq_from_dmi(const char *dmi_name) > +{ > + const struct dmi_device *dmi_dev; > + const struct dmi_dev_onboard *dev_data; > + > + dmi_dev = dmi_find_device(DMI_DEV_TYPE_DEV_ONBOARD, dmi_name, NULL); > + if (!dmi_dev) { > + pr_err("failed to find DMI device '%s'\n", dmi_name); > + return -ENOENT; > + } > + > + dev_data = dmi_dev->device_data; > + if (!dev_data) { > + pr_err("failed to get data from DMI for '%s'\n", dmi_name); > + return -EINVAL; > + } > + > + return dev_data->instance; > +} > + > static struct i2c_client *__add_probed_i2c_device( > const char *name, > int bus, > struct i2c_board_info *info, > const unsigned short *alt_addr_list) > { > - const struct dmi_device *dmi_dev; > - const struct dmi_dev_onboard *dev_data; > struct i2c_adapter *adapter; > struct i2c_client *client = NULL; > const unsigned short addr_list[] = { info->addr, I2C_CLIENT_END }; > > if (bus < 0) > return NULL; > + > /* > * If a name is specified, look for irq platform information stashed > * in DMI_DEV_TYPE_DEV_ONBOARD by the Chrome OS custom system firmware. > */ > if (name) { > - dmi_dev = dmi_find_device(DMI_DEV_TYPE_DEV_ONBOARD, name, NULL); > - if (!dmi_dev) { > - pr_err("failed to dmi find device %s\n", name); > - return NULL; > - } > - dev_data = (struct dmi_dev_onboard *)dmi_dev->device_data; > - if (!dev_data) { > - pr_err("failed to get data from dmi for %s\n", name); > + info->irq = chromeos_laptop_get_irq_from_dmi(name); > + if (info->irq < 0) > return NULL; > - } > - info->irq = dev_data->instance; > } > > adapter = i2c_get_adapter(bus); > -- Benson Leung Staff Software Engineer Chrome OS Kernel Google Inc. bleung@xxxxxxxxxx Chromium OS Project bleung@xxxxxxxxxxxx
Attachment:
signature.asc
Description: OpenPGP digital signature