Commit de248805 authored by Guenter Roeck's avatar Guenter Roeck

hwmon: (lm85) Use boolean to determine if VID5 is configured

ADT7463 and ADT7468 optionally support VID5 instead of the standard +12V
measurement input. Use a boolean to identify the chip configuration instead of
hardcoding it several times.
Signed-off-by: default avatarGuenter Roeck <guenter.roeck@ericsson.com>
Acked-by: default avatarJean Delvare <khali@linux-fr.org>
parent 502b5a01
...@@ -306,6 +306,8 @@ struct lm85_data { ...@@ -306,6 +306,8 @@ struct lm85_data {
const int *freq_map; const int *freq_map;
enum chips type; enum chips type;
bool has_vid5; /* true if VID5 is configured for ADT7463 or ADT7468 */
struct mutex update_lock; struct mutex update_lock;
int valid; /* !=0 if following fields are valid */ int valid; /* !=0 if following fields are valid */
unsigned long last_reading; /* In jiffies */ unsigned long last_reading; /* In jiffies */
...@@ -420,8 +422,7 @@ static ssize_t show_vid_reg(struct device *dev, struct device_attribute *attr, ...@@ -420,8 +422,7 @@ static ssize_t show_vid_reg(struct device *dev, struct device_attribute *attr,
struct lm85_data *data = lm85_update_device(dev); struct lm85_data *data = lm85_update_device(dev);
int vid; int vid;
if ((data->type == adt7463 || data->type == adt7468) && if (data->has_vid5) {
(data->vid & 0x80)) {
/* 6-pin VID (VRM 10) */ /* 6-pin VID (VRM 10) */
vid = vid_from_reg(data->vid & 0x3f, data->vrm); vid = vid_from_reg(data->vid & 0x3f, data->vrm);
} else { } else {
...@@ -1321,9 +1322,13 @@ static int lm85_probe(struct i2c_client *client, ...@@ -1321,9 +1322,13 @@ static int lm85_probe(struct i2c_client *client,
/* The ADT7463/68 have an optional VRM 10 mode where pin 21 is used /* The ADT7463/68 have an optional VRM 10 mode where pin 21 is used
as a sixth digital VID input rather than an analog input. */ as a sixth digital VID input rather than an analog input. */
data->vid = lm85_read_value(client, LM85_REG_VID); if (data->type == adt7463 || data->type == adt7468) {
if (!((data->type == adt7463 || data->type == adt7468) && u8 vid = lm85_read_value(client, LM85_REG_VID);
(data->vid & 0x80))) if (vid & 0x80)
data->has_vid5 = true;
}
if (!data->has_vid5)
if ((err = sysfs_create_group(&client->dev.kobj, if ((err = sysfs_create_group(&client->dev.kobj,
&lm85_group_in4))) &lm85_group_in4)))
goto err_remove_files; goto err_remove_files;
...@@ -1457,11 +1462,8 @@ static struct lm85_data *lm85_update_device(struct device *dev) ...@@ -1457,11 +1462,8 @@ static struct lm85_data *lm85_update_device(struct device *dev)
lm85_read_value(client, LM85_REG_FAN(i)); lm85_read_value(client, LM85_REG_FAN(i));
} }
if (!((data->type == adt7463 || data->type == adt7468) && if (!data->has_vid5)
(data->vid & 0x80))) { data->in[4] = lm85_read_value(client, LM85_REG_IN(4));
data->in[4] = lm85_read_value(client,
LM85_REG_IN(4));
}
if (data->type == adt7468) if (data->type == adt7468)
data->cfg5 = lm85_read_value(client, ADT7468_REG_CFG5); data->cfg5 = lm85_read_value(client, ADT7468_REG_CFG5);
...@@ -1528,8 +1530,7 @@ static struct lm85_data *lm85_update_device(struct device *dev) ...@@ -1528,8 +1530,7 @@ static struct lm85_data *lm85_update_device(struct device *dev)
lm85_read_value(client, LM85_REG_FAN_MIN(i)); lm85_read_value(client, LM85_REG_FAN_MIN(i));
} }
if (!((data->type == adt7463 || data->type == adt7468) && if (!data->has_vid5) {
(data->vid & 0x80))) {
data->in_min[4] = lm85_read_value(client, data->in_min[4] = lm85_read_value(client,
LM85_REG_IN_MIN(4)); LM85_REG_IN_MIN(4));
data->in_max[4] = lm85_read_value(client, data->in_max[4] = lm85_read_value(client,
......
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