diff options
Diffstat (limited to 'drivers/hwmon')
-rw-r--r-- | drivers/hwmon/adm1026.c | 52 |
1 files changed, 21 insertions, 31 deletions
diff --git a/drivers/hwmon/adm1026.c b/drivers/hwmon/adm1026.c index 9f44ed7ebb7b..a20af03f4fc6 100644 --- a/drivers/hwmon/adm1026.c +++ b/drivers/hwmon/adm1026.c | |||
@@ -232,9 +232,6 @@ static int adm1026_scaling[] = { /* .001 Volts */ | |||
232 | #define DAC_TO_REG(val) (SENSORS_LIMIT(((((val)*255)+500)/2500), 0, 255)) | 232 | #define DAC_TO_REG(val) (SENSORS_LIMIT(((((val)*255)+500)/2500), 0, 255)) |
233 | #define DAC_FROM_REG(val) (((val)*2500)/255) | 233 | #define DAC_FROM_REG(val) (((val)*2500)/255) |
234 | 234 | ||
235 | /* Typically used with systems using a v9.1 VRM spec ? */ | ||
236 | #define ADM1026_INIT_VRM 91 | ||
237 | |||
238 | /* Chip sampling rates | 235 | /* Chip sampling rates |
239 | * | 236 | * |
240 | * Some sensors are not updated more frequently than once per second | 237 | * Some sensors are not updated more frequently than once per second |
@@ -264,7 +261,6 @@ struct pwm_data { | |||
264 | struct adm1026_data { | 261 | struct adm1026_data { |
265 | struct i2c_client client; | 262 | struct i2c_client client; |
266 | struct device *hwmon_dev; | 263 | struct device *hwmon_dev; |
267 | enum chips type; | ||
268 | 264 | ||
269 | struct mutex update_lock; | 265 | struct mutex update_lock; |
270 | int valid; /* !=0 if following fields are valid */ | 266 | int valid; /* !=0 if following fields are valid */ |
@@ -387,7 +383,6 @@ static void adm1026_init_client(struct i2c_client *client) | |||
387 | "and temp limits enabled.\n"); | 383 | "and temp limits enabled.\n"); |
388 | } | 384 | } |
389 | 385 | ||
390 | value = data->config3; | ||
391 | if (data->config3 & CFG3_GPIO16_ENABLE) { | 386 | if (data->config3 & CFG3_GPIO16_ENABLE) { |
392 | dev_dbg(&client->dev, "GPIO16 enabled. THERM " | 387 | dev_dbg(&client->dev, "GPIO16 enabled. THERM " |
393 | "pin disabled.\n"); | 388 | "pin disabled.\n"); |
@@ -1230,8 +1225,7 @@ static ssize_t show_vrm_reg(struct device *dev, struct device_attribute *attr, c | |||
1230 | static ssize_t store_vrm_reg(struct device *dev, struct device_attribute *attr, const char *buf, | 1225 | static ssize_t store_vrm_reg(struct device *dev, struct device_attribute *attr, const char *buf, |
1231 | size_t count) | 1226 | size_t count) |
1232 | { | 1227 | { |
1233 | struct i2c_client *client = to_i2c_client(dev); | 1228 | struct adm1026_data *data = dev_get_drvdata(dev); |
1234 | struct adm1026_data *data = i2c_get_clientdata(client); | ||
1235 | 1229 | ||
1236 | data->vrm = simple_strtol(buf, NULL, 10); | 1230 | data->vrm = simple_strtol(buf, NULL, 10); |
1237 | return count; | 1231 | return count; |
@@ -1242,7 +1236,7 @@ static DEVICE_ATTR(vrm, S_IRUGO | S_IWUSR, show_vrm_reg, store_vrm_reg); | |||
1242 | static ssize_t show_alarms_reg(struct device *dev, struct device_attribute *attr, char *buf) | 1236 | static ssize_t show_alarms_reg(struct device *dev, struct device_attribute *attr, char *buf) |
1243 | { | 1237 | { |
1244 | struct adm1026_data *data = adm1026_update_device(dev); | 1238 | struct adm1026_data *data = adm1026_update_device(dev); |
1245 | return sprintf(buf, "%ld\n", (long) (data->alarms)); | 1239 | return sprintf(buf, "%ld\n", data->alarms); |
1246 | } | 1240 | } |
1247 | 1241 | ||
1248 | static DEVICE_ATTR(alarms, S_IRUGO, show_alarms_reg, NULL); | 1242 | static DEVICE_ATTR(alarms, S_IRUGO, show_alarms_reg, NULL); |
@@ -1641,7 +1635,7 @@ static int adm1026_detect(struct i2c_adapter *adapter, int address, | |||
1641 | int kind) | 1635 | int kind) |
1642 | { | 1636 | { |
1643 | int company, verstep; | 1637 | int company, verstep; |
1644 | struct i2c_client *new_client; | 1638 | struct i2c_client *client; |
1645 | struct adm1026_data *data; | 1639 | struct adm1026_data *data; |
1646 | int err = 0; | 1640 | int err = 0; |
1647 | const char *type_name = ""; | 1641 | const char *type_name = ""; |
@@ -1660,26 +1654,25 @@ static int adm1026_detect(struct i2c_adapter *adapter, int address, | |||
1660 | goto exit; | 1654 | goto exit; |
1661 | } | 1655 | } |
1662 | 1656 | ||
1663 | new_client = &data->client; | 1657 | client = &data->client; |
1664 | i2c_set_clientdata(new_client, data); | 1658 | i2c_set_clientdata(client, data); |
1665 | new_client->addr = address; | 1659 | client->addr = address; |
1666 | new_client->adapter = adapter; | 1660 | client->adapter = adapter; |
1667 | new_client->driver = &adm1026_driver; | 1661 | client->driver = &adm1026_driver; |
1668 | new_client->flags = 0; | ||
1669 | 1662 | ||
1670 | /* Now, we do the remaining detection. */ | 1663 | /* Now, we do the remaining detection. */ |
1671 | 1664 | ||
1672 | company = adm1026_read_value(new_client, ADM1026_REG_COMPANY); | 1665 | company = adm1026_read_value(client, ADM1026_REG_COMPANY); |
1673 | verstep = adm1026_read_value(new_client, ADM1026_REG_VERSTEP); | 1666 | verstep = adm1026_read_value(client, ADM1026_REG_VERSTEP); |
1674 | 1667 | ||
1675 | dev_dbg(&new_client->dev, "Detecting device at %d,0x%02x with" | 1668 | dev_dbg(&client->dev, "Detecting device at %d,0x%02x with" |
1676 | " COMPANY: 0x%02x and VERSTEP: 0x%02x\n", | 1669 | " COMPANY: 0x%02x and VERSTEP: 0x%02x\n", |
1677 | i2c_adapter_id(new_client->adapter), new_client->addr, | 1670 | i2c_adapter_id(client->adapter), client->addr, |
1678 | company, verstep); | 1671 | company, verstep); |
1679 | 1672 | ||
1680 | /* If auto-detecting, Determine the chip type. */ | 1673 | /* If auto-detecting, Determine the chip type. */ |
1681 | if (kind <= 0) { | 1674 | if (kind <= 0) { |
1682 | dev_dbg(&new_client->dev, "Autodetecting device at %d,0x%02x " | 1675 | dev_dbg(&client->dev, "Autodetecting device at %d,0x%02x " |
1683 | "...\n", i2c_adapter_id(adapter), address); | 1676 | "...\n", i2c_adapter_id(adapter), address); |
1684 | if (company == ADM1026_COMPANY_ANALOG_DEV | 1677 | if (company == ADM1026_COMPANY_ANALOG_DEV |
1685 | && verstep == ADM1026_VERSTEP_ADM1026) { | 1678 | && verstep == ADM1026_VERSTEP_ADM1026) { |
@@ -1695,7 +1688,7 @@ static int adm1026_detect(struct i2c_adapter *adapter, int address, | |||
1695 | verstep); | 1688 | verstep); |
1696 | kind = any_chip; | 1689 | kind = any_chip; |
1697 | } else { | 1690 | } else { |
1698 | dev_dbg(&new_client->dev, ": Autodetection " | 1691 | dev_dbg(&client->dev, ": Autodetection " |
1699 | "failed\n"); | 1692 | "failed\n"); |
1700 | /* Not an ADM1026 ... */ | 1693 | /* Not an ADM1026 ... */ |
1701 | if (kind == 0) { /* User used force=x,y */ | 1694 | if (kind == 0) { /* User used force=x,y */ |
@@ -1704,7 +1697,6 @@ static int adm1026_detect(struct i2c_adapter *adapter, int address, | |||
1704 | "force_adm1026.\n", | 1697 | "force_adm1026.\n", |
1705 | i2c_adapter_id(adapter), address); | 1698 | i2c_adapter_id(adapter), address); |
1706 | } | 1699 | } |
1707 | err = 0; | ||
1708 | goto exitfree; | 1700 | goto exitfree; |
1709 | } | 1701 | } |
1710 | } | 1702 | } |
@@ -1723,28 +1715,26 @@ static int adm1026_detect(struct i2c_adapter *adapter, int address, | |||
1723 | err = -EFAULT; | 1715 | err = -EFAULT; |
1724 | goto exitfree; | 1716 | goto exitfree; |
1725 | } | 1717 | } |
1726 | strlcpy(new_client->name, type_name, I2C_NAME_SIZE); | 1718 | strlcpy(client->name, type_name, I2C_NAME_SIZE); |
1727 | 1719 | ||
1728 | /* Fill in the remaining client fields */ | 1720 | /* Fill in the remaining client fields */ |
1729 | data->type = kind; | ||
1730 | data->valid = 0; | ||
1731 | mutex_init(&data->update_lock); | 1721 | mutex_init(&data->update_lock); |
1732 | 1722 | ||
1733 | /* Tell the I2C layer a new client has arrived */ | 1723 | /* Tell the I2C layer a new client has arrived */ |
1734 | if ((err = i2c_attach_client(new_client))) | 1724 | if ((err = i2c_attach_client(client))) |
1735 | goto exitfree; | 1725 | goto exitfree; |
1736 | 1726 | ||
1737 | /* Set the VRM version */ | 1727 | /* Set the VRM version */ |
1738 | data->vrm = vid_which_vrm(); | 1728 | data->vrm = vid_which_vrm(); |
1739 | 1729 | ||
1740 | /* Initialize the ADM1026 chip */ | 1730 | /* Initialize the ADM1026 chip */ |
1741 | adm1026_init_client(new_client); | 1731 | adm1026_init_client(client); |
1742 | 1732 | ||
1743 | /* Register sysfs hooks */ | 1733 | /* Register sysfs hooks */ |
1744 | if ((err = sysfs_create_group(&new_client->dev.kobj, &adm1026_group))) | 1734 | if ((err = sysfs_create_group(&client->dev.kobj, &adm1026_group))) |
1745 | goto exitdetach; | 1735 | goto exitdetach; |
1746 | 1736 | ||
1747 | data->hwmon_dev = hwmon_device_register(&new_client->dev); | 1737 | data->hwmon_dev = hwmon_device_register(&client->dev); |
1748 | if (IS_ERR(data->hwmon_dev)) { | 1738 | if (IS_ERR(data->hwmon_dev)) { |
1749 | err = PTR_ERR(data->hwmon_dev); | 1739 | err = PTR_ERR(data->hwmon_dev); |
1750 | goto exitremove; | 1740 | goto exitremove; |
@@ -1754,9 +1744,9 @@ static int adm1026_detect(struct i2c_adapter *adapter, int address, | |||
1754 | 1744 | ||
1755 | /* Error out and cleanup code */ | 1745 | /* Error out and cleanup code */ |
1756 | exitremove: | 1746 | exitremove: |
1757 | sysfs_remove_group(&new_client->dev.kobj, &adm1026_group); | 1747 | sysfs_remove_group(&client->dev.kobj, &adm1026_group); |
1758 | exitdetach: | 1748 | exitdetach: |
1759 | i2c_detach_client(new_client); | 1749 | i2c_detach_client(client); |
1760 | exitfree: | 1750 | exitfree: |
1761 | kfree(data); | 1751 | kfree(data); |
1762 | exit: | 1752 | exit: |