From: Iker Perez del Palomar Sustatxa <iker.perez@xxxxxxxxxxxxxxx> This function will be needed later to configure update_interval Signed-off-by: Iker Perez del Palomar Sustatxa <iker.perez@xxxxxxxxxxxxxxx> --- drivers/hwmon/lm75.c | 63 ++++++++++++++++++++++++++++++---------------------- 1 file changed, 36 insertions(+), 27 deletions(-) diff --git a/drivers/hwmon/lm75.c b/drivers/hwmon/lm75.c index 1d4d060bd695..5ba7277dac69 100644 --- a/drivers/hwmon/lm75.c +++ b/drivers/hwmon/lm75.c @@ -78,6 +78,40 @@ static inline long lm75_reg_to_mc(s16 temp, u8 resolution) return ((temp >> (16 - resolution)) * 1000) >> (resolution - 8); } +static void lm75_remove(void *data) +{ + struct lm75_data *lm75 = data; + struct i2c_client *client = lm75->client; + + i2c_smbus_write_byte_data(client, LM75_REG_CONF, lm75->orig_conf); +} +static int configure_reg(u8 set_mask, u8 clr_mask, struct lm75_data *data, + struct i2c_client *client) +{ + int status, err, new; + struct device *dev = &client->dev; + + /* configure as specified */ + status = i2c_smbus_read_byte_data(client, LM75_REG_CONF); + if (status < 0) { + dev_dbg(dev, "Can't read config? %d\n", status); + return status; + } + data->orig_conf = status; + new = status & ~clr_mask; + new |= set_mask; + if (status != new) + i2c_smbus_write_byte_data(client, LM75_REG_CONF, new); + + err = devm_add_action_or_reset(dev, lm75_remove, data); + if (err) + return err; + + dev_dbg(dev, "Config %02x\n", new); + + return 0; +} + static int lm75_read(struct device *dev, enum hwmon_sensor_types type, u32 attr, int channel, long *val) { @@ -238,14 +272,6 @@ static const struct regmap_config lm75_regmap_config = { .use_single_write = true, }; -static void lm75_remove(void *data) -{ - struct lm75_data *lm75 = data; - struct i2c_client *client = lm75->client; - - i2c_smbus_write_byte_data(client, LM75_REG_CONF, lm75->orig_conf); -} - static int lm75_probe(struct i2c_client *client, const struct i2c_device_id *id) { @@ -253,9 +279,8 @@ lm75_probe(struct i2c_client *client, const struct i2c_device_id *id) struct device *hwmon_dev; struct lm75_data *data; struct lm75_data device_data; - int status, err; + int status; u8 set_mask, clr_mask; - int new; data = &device_data; if (client->dev.of_node) @@ -370,23 +395,7 @@ lm75_probe(struct i2c_client *client, const struct i2c_device_id *id) break; } - /* configure as specified */ - status = i2c_smbus_read_byte_data(client, LM75_REG_CONF); - if (status < 0) { - dev_dbg(dev, "Can't read config? %d\n", status); - return status; - } - data->orig_conf = status; - new = status & ~clr_mask; - new |= set_mask; - if (status != new) - i2c_smbus_write_byte_data(client, LM75_REG_CONF, new); - - err = devm_add_action_or_reset(dev, lm75_remove, data); - if (err) - return err; - - dev_dbg(dev, "Config %02x\n", new); + status = configure_reg(set_mask, clr_mask, data, client); hwmon_dev = devm_hwmon_device_register_with_info(dev, client->name, data, &lm75_chip_info, -- 2.11.0