aboutsummaryrefslogtreecommitdiffstats
path: root/drivers/hwmon/ds1621.c
diff options
context:
space:
mode:
Diffstat (limited to 'drivers/hwmon/ds1621.c')
-rw-r--r--drivers/hwmon/ds1621.c51
1 files changed, 19 insertions, 32 deletions
diff --git a/drivers/hwmon/ds1621.c b/drivers/hwmon/ds1621.c
index d5ac422d73b2..ccf0fe617e5f 100644
--- a/drivers/hwmon/ds1621.c
+++ b/drivers/hwmon/ds1621.c
@@ -63,10 +63,7 @@ MODULE_PARM_DESC(polarity, "Output's polarity: 0 = active high, 1 = active low")
63#define DS1621_ALARM_TEMP_HIGH 0x40 63#define DS1621_ALARM_TEMP_HIGH 0x40
64#define DS1621_ALARM_TEMP_LOW 0x20 64#define DS1621_ALARM_TEMP_LOW 0x20
65 65
66/* Conversions. Rounding and limit checking is only done on the TO_REG 66/* Conversions */
67 variants. Note that you should be a bit careful with which arguments
68 these macros are called: arguments may be evaluated more than once.
69 Fixing this is just not worth it. */
70#define ALARMS_FROM_REG(val) ((val) & \ 67#define ALARMS_FROM_REG(val) ((val) & \
71 (DS1621_ALARM_TEMP_HIGH | DS1621_ALARM_TEMP_LOW)) 68 (DS1621_ALARM_TEMP_HIGH | DS1621_ALARM_TEMP_LOW))
72 69
@@ -101,7 +98,7 @@ static struct i2c_driver ds1621_driver = {
101 98
102/* All registers are word-sized, except for the configuration register. 99/* All registers are word-sized, except for the configuration register.
103 DS1621 uses a high-byte first convention, which is exactly opposite to 100 DS1621 uses a high-byte first convention, which is exactly opposite to
104 the usual practice. */ 101 the SMBus standard. */
105static int ds1621_read_value(struct i2c_client *client, u8 reg) 102static int ds1621_read_value(struct i2c_client *client, u8 reg)
106{ 103{
107 if (reg == DS1621_REG_CONF) 104 if (reg == DS1621_REG_CONF)
@@ -110,9 +107,6 @@ static int ds1621_read_value(struct i2c_client *client, u8 reg)
110 return swab16(i2c_smbus_read_word_data(client, reg)); 107 return swab16(i2c_smbus_read_word_data(client, reg));
111} 108}
112 109
113/* All registers are word-sized, except for the configuration register.
114 DS1621 uses a high-byte first convention, which is exactly opposite to
115 the usual practice. */
116static int ds1621_write_value(struct i2c_client *client, u8 reg, u16 value) 110static int ds1621_write_value(struct i2c_client *client, u8 reg, u16 value)
117{ 111{
118 if (reg == DS1621_REG_CONF) 112 if (reg == DS1621_REG_CONF)
@@ -204,7 +198,7 @@ static int ds1621_detect(struct i2c_adapter *adapter, int address,
204 int kind) 198 int kind)
205{ 199{
206 int conf, temp; 200 int conf, temp;
207 struct i2c_client *new_client; 201 struct i2c_client *client;
208 struct ds1621_data *data; 202 struct ds1621_data *data;
209 int err = 0; 203 int err = 0;
210 204
@@ -221,55 +215,48 @@ static int ds1621_detect(struct i2c_adapter *adapter, int address,
221 goto exit; 215 goto exit;
222 } 216 }
223 217
224 new_client = &data->client; 218 client = &data->client;
225 i2c_set_clientdata(new_client, data); 219 i2c_set_clientdata(client, data);
226 new_client->addr = address; 220 client->addr = address;
227 new_client->adapter = adapter; 221 client->adapter = adapter;
228 new_client->driver = &ds1621_driver; 222 client->driver = &ds1621_driver;
229 new_client->flags = 0;
230
231 223
232 /* Now, we do the remaining detection. It is lousy. */ 224 /* Now, we do the remaining detection. It is lousy. */
233 if (kind < 0) { 225 if (kind < 0) {
234 /* The NVB bit should be low if no EEPROM write has been 226 /* The NVB bit should be low if no EEPROM write has been
235 requested during the latest 10ms, which is highly 227 requested during the latest 10ms, which is highly
236 improbable in our case. */ 228 improbable in our case. */
237 conf = ds1621_read_value(new_client, DS1621_REG_CONF); 229 conf = ds1621_read_value(client, DS1621_REG_CONF);
238 if (conf & DS1621_REG_CONFIG_NVB) 230 if (conf & DS1621_REG_CONFIG_NVB)
239 goto exit_free; 231 goto exit_free;
240 /* The 7 lowest bits of a temperature should always be 0. */ 232 /* The 7 lowest bits of a temperature should always be 0. */
241 temp = ds1621_read_value(new_client, DS1621_REG_TEMP); 233 temp = ds1621_read_value(client, DS1621_REG_TEMP);
242 if (temp & 0x007f) 234 if (temp & 0x007f)
243 goto exit_free; 235 goto exit_free;
244 temp = ds1621_read_value(new_client, DS1621_REG_TEMP_MIN); 236 temp = ds1621_read_value(client, DS1621_REG_TEMP_MIN);
245 if (temp & 0x007f) 237 if (temp & 0x007f)
246 goto exit_free; 238 goto exit_free;
247 temp = ds1621_read_value(new_client, DS1621_REG_TEMP_MAX); 239 temp = ds1621_read_value(client, DS1621_REG_TEMP_MAX);
248 if (temp & 0x007f) 240 if (temp & 0x007f)
249 goto exit_free; 241 goto exit_free;
250 } 242 }
251 243
252 /* Determine the chip type - only one kind supported! */
253 if (kind <= 0)
254 kind = ds1621;
255
256 /* Fill in remaining client fields and put it into the global list */ 244 /* Fill in remaining client fields and put it into the global list */
257 strlcpy(new_client->name, "ds1621", I2C_NAME_SIZE); 245 strlcpy(client->name, "ds1621", I2C_NAME_SIZE);
258 data->valid = 0;
259 mutex_init(&data->update_lock); 246 mutex_init(&data->update_lock);
260 247
261 /* Tell the I2C layer a new client has arrived */ 248 /* Tell the I2C layer a new client has arrived */
262 if ((err = i2c_attach_client(new_client))) 249 if ((err = i2c_attach_client(client)))
263 goto exit_free; 250 goto exit_free;
264 251
265 /* Initialize the DS1621 chip */ 252 /* Initialize the DS1621 chip */
266 ds1621_init_client(new_client); 253 ds1621_init_client(client);
267 254
268 /* Register sysfs hooks */ 255 /* Register sysfs hooks */
269 if ((err = sysfs_create_group(&new_client->dev.kobj, &ds1621_group))) 256 if ((err = sysfs_create_group(&client->dev.kobj, &ds1621_group)))
270 goto exit_detach; 257 goto exit_detach;
271 258
272 data->class_dev = hwmon_device_register(&new_client->dev); 259 data->class_dev = hwmon_device_register(&client->dev);
273 if (IS_ERR(data->class_dev)) { 260 if (IS_ERR(data->class_dev)) {
274 err = PTR_ERR(data->class_dev); 261 err = PTR_ERR(data->class_dev);
275 goto exit_remove_files; 262 goto exit_remove_files;
@@ -278,9 +265,9 @@ static int ds1621_detect(struct i2c_adapter *adapter, int address,
278 return 0; 265 return 0;
279 266
280 exit_remove_files: 267 exit_remove_files:
281 sysfs_remove_group(&new_client->dev.kobj, &ds1621_group); 268 sysfs_remove_group(&client->dev.kobj, &ds1621_group);
282 exit_detach: 269 exit_detach:
283 i2c_detach_client(new_client); 270 i2c_detach_client(client);
284 exit_free: 271 exit_free:
285 kfree(data); 272 kfree(data);
286 exit: 273 exit: