aboutsummaryrefslogtreecommitdiffstats
path: root/drivers/hwmon
diff options
context:
space:
mode:
authorRobert Coulson <rob.coulson@gmail.com>2013-05-09 01:45:54 -0400
committerGuenter Roeck <linux@roeck-us.net>2013-06-27 13:29:01 -0400
commit3a8fe3315571e896489d2e271ffe7f935bfc5ce8 (patch)
treec97f18dc6b5326d0dfee71bac65d318d994896f8 /drivers/hwmon
parentcd6c8a4297ad036a155966db49982d6807e23ef8 (diff)
hwmon: (ds1621) Add ds1721 update interval sysfs attribute
The ds1721 device can be configured for 9..12 bit resolutions; add a sysfs attribute for userspace to configure this attribute. The definition, description, details, and usage are shown in the documentation and were crafted from an LM73 driver patch done by Chris Verges & Guenter Roeck). Signed-off-by: Robert Coulson <rob.coulson@gmail.com> Signed-off-by: Guenter Roeck <linux@roeck-us.net>
Diffstat (limited to 'drivers/hwmon')
-rw-r--r--drivers/hwmon/ds1621.c56
1 files changed, 56 insertions, 0 deletions
diff --git a/drivers/hwmon/ds1621.c b/drivers/hwmon/ds1621.c
index 6942617666a4..b5d80fb851d0 100644
--- a/drivers/hwmon/ds1621.c
+++ b/drivers/hwmon/ds1621.c
@@ -274,7 +274,47 @@ static ssize_t show_alarm(struct device *dev, struct device_attribute *da,
274 return sprintf(buf, "%d\n", !!(data->conf & attr->index)); 274 return sprintf(buf, "%d\n", !!(data->conf & attr->index));
275} 275}
276 276
277static ssize_t show_convrate(struct device *dev, struct device_attribute *da,
278 char *buf)
279{
280 struct i2c_client *client = to_i2c_client(dev);
281 struct ds1621_data *data = i2c_get_clientdata(client);
282 return scnprintf(buf, PAGE_SIZE, "%hu\n", data->update_interval);
283}
284
285static ssize_t set_convrate(struct device *dev, struct device_attribute *da,
286 const char *buf, size_t count)
287{
288 struct i2c_client *client = to_i2c_client(dev);
289 struct ds1621_data *data = i2c_get_clientdata(client);
290 unsigned long convrate;
291 s32 err;
292 int resol = 0;
293
294 err = kstrtoul(buf, 10, &convrate);
295 if (err)
296 return err;
297
298 /* Convert rate into resolution bits */
299 while (resol < (ARRAY_SIZE(ds1721_convrates) - 1) &&
300 convrate > ds1721_convrates[resol])
301 resol++;
302
303 mutex_lock(&data->update_lock);
304 data->conf = i2c_smbus_read_byte_data(client, DS1621_REG_CONF);
305 data->conf &= ~DS1621_REG_CONFIG_RESOL;
306 data->conf |= (resol << DS1621_REG_CONFIG_RESOL_SHIFT);
307 i2c_smbus_write_byte_data(client, DS1621_REG_CONF, data->conf);
308 data->update_interval = ds1721_convrates[resol];
309 mutex_unlock(&data->update_lock);
310
311 return count;
312}
313
277static DEVICE_ATTR(alarms, S_IRUGO, show_alarms, NULL); 314static DEVICE_ATTR(alarms, S_IRUGO, show_alarms, NULL);
315static DEVICE_ATTR(update_interval, S_IWUSR | S_IRUGO, show_convrate,
316 set_convrate);
317
278static SENSOR_DEVICE_ATTR(temp1_input, S_IRUGO, show_temp, NULL, 0); 318static SENSOR_DEVICE_ATTR(temp1_input, S_IRUGO, show_temp, NULL, 0);
279static SENSOR_DEVICE_ATTR(temp1_min, S_IWUSR | S_IRUGO, show_temp, set_temp, 1); 319static SENSOR_DEVICE_ATTR(temp1_min, S_IWUSR | S_IRUGO, show_temp, set_temp, 1);
280static SENSOR_DEVICE_ATTR(temp1_max, S_IWUSR | S_IRUGO, show_temp, set_temp, 2); 320static SENSOR_DEVICE_ATTR(temp1_max, S_IWUSR | S_IRUGO, show_temp, set_temp, 2);
@@ -290,11 +330,27 @@ static struct attribute *ds1621_attributes[] = {
290 &sensor_dev_attr_temp1_min_alarm.dev_attr.attr, 330 &sensor_dev_attr_temp1_min_alarm.dev_attr.attr,
291 &sensor_dev_attr_temp1_max_alarm.dev_attr.attr, 331 &sensor_dev_attr_temp1_max_alarm.dev_attr.attr,
292 &dev_attr_alarms.attr, 332 &dev_attr_alarms.attr,
333 &dev_attr_update_interval.attr,
293 NULL 334 NULL
294}; 335};
295 336
337static umode_t ds1621_attribute_visible(struct kobject *kobj,
338 struct attribute *attr, int index)
339{
340 struct device *dev = container_of(kobj, struct device, kobj);
341 struct i2c_client *client = to_i2c_client(dev);
342 struct ds1621_data *data = i2c_get_clientdata(client);
343
344 if (attr == &dev_attr_update_interval.attr)
345 if (data->kind != ds1721)
346 /* shhh, we're hiding update_interval */
347 return 0;
348 return attr->mode;
349}
350
296static const struct attribute_group ds1621_group = { 351static const struct attribute_group ds1621_group = {
297 .attrs = ds1621_attributes, 352 .attrs = ds1621_attributes,
353 .is_visible = ds1621_attribute_visible
298}; 354};
299 355
300 356