xref: /openbmc/linux/drivers/hwmon/lm78.c (revision 8fa5723aa7e053d498336b48448b292fc2e0458b)
1 /*
2     lm78.c - Part of lm_sensors, Linux kernel modules for hardware
3              monitoring
4     Copyright (c) 1998, 1999  Frodo Looijaard <frodol@dds.nl>
5     Copyright (c) 2007        Jean Delvare <khali@linux-fr.org>
6 
7     This program is free software; you can redistribute it and/or modify
8     it under the terms of the GNU General Public License as published by
9     the Free Software Foundation; either version 2 of the License, or
10     (at your option) any later version.
11 
12     This program is distributed in the hope that it will be useful,
13     but WITHOUT ANY WARRANTY; without even the implied warranty of
14     MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
15     GNU General Public License for more details.
16 
17     You should have received a copy of the GNU General Public License
18     along with this program; if not, write to the Free Software
19     Foundation, Inc., 675 Mass Ave, Cambridge, MA 02139, USA.
20 */
21 
22 #include <linux/module.h>
23 #include <linux/init.h>
24 #include <linux/slab.h>
25 #include <linux/jiffies.h>
26 #include <linux/i2c.h>
27 #include <linux/platform_device.h>
28 #include <linux/ioport.h>
29 #include <linux/hwmon.h>
30 #include <linux/hwmon-vid.h>
31 #include <linux/hwmon-sysfs.h>
32 #include <linux/err.h>
33 #include <linux/mutex.h>
34 #include <asm/io.h>
35 
36 /* ISA device, if found */
37 static struct platform_device *pdev;
38 
39 /* Addresses to scan */
40 static const unsigned short normal_i2c[] = { 0x28, 0x29, 0x2a, 0x2b, 0x2c, 0x2d,
41 						0x2e, 0x2f, I2C_CLIENT_END };
42 static unsigned short isa_address = 0x290;
43 
44 /* Insmod parameters */
45 I2C_CLIENT_INSMOD_2(lm78, lm79);
46 
47 /* Many LM78 constants specified below */
48 
49 /* Length of ISA address segment */
50 #define LM78_EXTENT 8
51 
52 /* Where are the ISA address/data registers relative to the base address */
53 #define LM78_ADDR_REG_OFFSET 5
54 #define LM78_DATA_REG_OFFSET 6
55 
56 /* The LM78 registers */
57 #define LM78_REG_IN_MAX(nr) (0x2b + (nr) * 2)
58 #define LM78_REG_IN_MIN(nr) (0x2c + (nr) * 2)
59 #define LM78_REG_IN(nr) (0x20 + (nr))
60 
61 #define LM78_REG_FAN_MIN(nr) (0x3b + (nr))
62 #define LM78_REG_FAN(nr) (0x28 + (nr))
63 
64 #define LM78_REG_TEMP 0x27
65 #define LM78_REG_TEMP_OVER 0x39
66 #define LM78_REG_TEMP_HYST 0x3a
67 
68 #define LM78_REG_ALARM1 0x41
69 #define LM78_REG_ALARM2 0x42
70 
71 #define LM78_REG_VID_FANDIV 0x47
72 
73 #define LM78_REG_CONFIG 0x40
74 #define LM78_REG_CHIPID 0x49
75 #define LM78_REG_I2C_ADDR 0x48
76 
77 
78 /* Conversions. Rounding and limit checking is only done on the TO_REG
79    variants. */
80 
81 /* IN: mV, (0V to 4.08V)
82    REG: 16mV/bit */
83 static inline u8 IN_TO_REG(unsigned long val)
84 {
85 	unsigned long nval = SENSORS_LIMIT(val, 0, 4080);
86 	return (nval + 8) / 16;
87 }
88 #define IN_FROM_REG(val) ((val) *  16)
89 
90 static inline u8 FAN_TO_REG(long rpm, int div)
91 {
92 	if (rpm <= 0)
93 		return 255;
94 	return SENSORS_LIMIT((1350000 + rpm * div / 2) / (rpm * div), 1, 254);
95 }
96 
97 static inline int FAN_FROM_REG(u8 val, int div)
98 {
99 	return val==0 ? -1 : val==255 ? 0 : 1350000/(val*div);
100 }
101 
102 /* TEMP: mC (-128C to +127C)
103    REG: 1C/bit, two's complement */
104 static inline s8 TEMP_TO_REG(int val)
105 {
106 	int nval = SENSORS_LIMIT(val, -128000, 127000) ;
107 	return nval<0 ? (nval-500)/1000 : (nval+500)/1000;
108 }
109 
110 static inline int TEMP_FROM_REG(s8 val)
111 {
112 	return val * 1000;
113 }
114 
115 #define DIV_FROM_REG(val) (1 << (val))
116 
117 struct lm78_data {
118 	struct i2c_client *client;
119 	struct device *hwmon_dev;
120 	struct mutex lock;
121 	enum chips type;
122 
123 	/* For ISA device only */
124 	const char *name;
125 	int isa_addr;
126 
127 	struct mutex update_lock;
128 	char valid;		/* !=0 if following fields are valid */
129 	unsigned long last_updated;	/* In jiffies */
130 
131 	u8 in[7];		/* Register value */
132 	u8 in_max[7];		/* Register value */
133 	u8 in_min[7];		/* Register value */
134 	u8 fan[3];		/* Register value */
135 	u8 fan_min[3];		/* Register value */
136 	s8 temp;		/* Register value */
137 	s8 temp_over;		/* Register value */
138 	s8 temp_hyst;		/* Register value */
139 	u8 fan_div[3];		/* Register encoding, shifted right */
140 	u8 vid;			/* Register encoding, combined */
141 	u16 alarms;		/* Register encoding, combined */
142 };
143 
144 
145 static int lm78_i2c_detect(struct i2c_client *client, int kind,
146 			   struct i2c_board_info *info);
147 static int lm78_i2c_probe(struct i2c_client *client,
148 			  const struct i2c_device_id *id);
149 static int lm78_i2c_remove(struct i2c_client *client);
150 
151 static int __devinit lm78_isa_probe(struct platform_device *pdev);
152 static int __devexit lm78_isa_remove(struct platform_device *pdev);
153 
154 static int lm78_read_value(struct lm78_data *data, u8 reg);
155 static int lm78_write_value(struct lm78_data *data, u8 reg, u8 value);
156 static struct lm78_data *lm78_update_device(struct device *dev);
157 static void lm78_init_device(struct lm78_data *data);
158 
159 
160 static const struct i2c_device_id lm78_i2c_id[] = {
161 	{ "lm78", lm78 },
162 	{ "lm79", lm79 },
163 	{ }
164 };
165 MODULE_DEVICE_TABLE(i2c, lm78_i2c_id);
166 
167 static struct i2c_driver lm78_driver = {
168 	.class		= I2C_CLASS_HWMON,
169 	.driver = {
170 		.name	= "lm78",
171 	},
172 	.probe		= lm78_i2c_probe,
173 	.remove		= lm78_i2c_remove,
174 	.id_table	= lm78_i2c_id,
175 	.detect		= lm78_i2c_detect,
176 	.address_data	= &addr_data,
177 };
178 
179 static struct platform_driver lm78_isa_driver = {
180 	.driver = {
181 		.owner	= THIS_MODULE,
182 		.name	= "lm78",
183 	},
184 	.probe		= lm78_isa_probe,
185 	.remove		= lm78_isa_remove,
186 };
187 
188 
189 /* 7 Voltages */
190 static ssize_t show_in(struct device *dev, struct device_attribute *da,
191 		       char *buf)
192 {
193 	struct sensor_device_attribute *attr = to_sensor_dev_attr(da);
194 	struct lm78_data *data = lm78_update_device(dev);
195 	return sprintf(buf, "%d\n", IN_FROM_REG(data->in[attr->index]));
196 }
197 
198 static ssize_t show_in_min(struct device *dev, struct device_attribute *da,
199 			   char *buf)
200 {
201 	struct sensor_device_attribute *attr = to_sensor_dev_attr(da);
202 	struct lm78_data *data = lm78_update_device(dev);
203 	return sprintf(buf, "%d\n", IN_FROM_REG(data->in_min[attr->index]));
204 }
205 
206 static ssize_t show_in_max(struct device *dev, struct device_attribute *da,
207 			   char *buf)
208 {
209 	struct sensor_device_attribute *attr = to_sensor_dev_attr(da);
210 	struct lm78_data *data = lm78_update_device(dev);
211 	return sprintf(buf, "%d\n", IN_FROM_REG(data->in_max[attr->index]));
212 }
213 
214 static ssize_t set_in_min(struct device *dev, struct device_attribute *da,
215 			  const char *buf, size_t count)
216 {
217 	struct sensor_device_attribute *attr = to_sensor_dev_attr(da);
218 	struct lm78_data *data = dev_get_drvdata(dev);
219 	unsigned long val = simple_strtoul(buf, NULL, 10);
220 	int nr = attr->index;
221 
222 	mutex_lock(&data->update_lock);
223 	data->in_min[nr] = IN_TO_REG(val);
224 	lm78_write_value(data, LM78_REG_IN_MIN(nr), data->in_min[nr]);
225 	mutex_unlock(&data->update_lock);
226 	return count;
227 }
228 
229 static ssize_t set_in_max(struct device *dev, struct device_attribute *da,
230 			  const char *buf, size_t count)
231 {
232 	struct sensor_device_attribute *attr = to_sensor_dev_attr(da);
233 	struct lm78_data *data = dev_get_drvdata(dev);
234 	unsigned long val = simple_strtoul(buf, NULL, 10);
235 	int nr = attr->index;
236 
237 	mutex_lock(&data->update_lock);
238 	data->in_max[nr] = IN_TO_REG(val);
239 	lm78_write_value(data, LM78_REG_IN_MAX(nr), data->in_max[nr]);
240 	mutex_unlock(&data->update_lock);
241 	return count;
242 }
243 
244 #define show_in_offset(offset)					\
245 static SENSOR_DEVICE_ATTR(in##offset##_input, S_IRUGO,		\
246 		show_in, NULL, offset);				\
247 static SENSOR_DEVICE_ATTR(in##offset##_min, S_IRUGO | S_IWUSR,	\
248 		show_in_min, set_in_min, offset);		\
249 static SENSOR_DEVICE_ATTR(in##offset##_max, S_IRUGO | S_IWUSR,	\
250 		show_in_max, set_in_max, offset);
251 
252 show_in_offset(0);
253 show_in_offset(1);
254 show_in_offset(2);
255 show_in_offset(3);
256 show_in_offset(4);
257 show_in_offset(5);
258 show_in_offset(6);
259 
260 /* Temperature */
261 static ssize_t show_temp(struct device *dev, struct device_attribute *da,
262 			 char *buf)
263 {
264 	struct lm78_data *data = lm78_update_device(dev);
265 	return sprintf(buf, "%d\n", TEMP_FROM_REG(data->temp));
266 }
267 
268 static ssize_t show_temp_over(struct device *dev, struct device_attribute *da,
269 			      char *buf)
270 {
271 	struct lm78_data *data = lm78_update_device(dev);
272 	return sprintf(buf, "%d\n", TEMP_FROM_REG(data->temp_over));
273 }
274 
275 static ssize_t set_temp_over(struct device *dev, struct device_attribute *da,
276 			     const char *buf, size_t count)
277 {
278 	struct lm78_data *data = dev_get_drvdata(dev);
279 	long val = simple_strtol(buf, NULL, 10);
280 
281 	mutex_lock(&data->update_lock);
282 	data->temp_over = TEMP_TO_REG(val);
283 	lm78_write_value(data, LM78_REG_TEMP_OVER, data->temp_over);
284 	mutex_unlock(&data->update_lock);
285 	return count;
286 }
287 
288 static ssize_t show_temp_hyst(struct device *dev, struct device_attribute *da,
289 			      char *buf)
290 {
291 	struct lm78_data *data = lm78_update_device(dev);
292 	return sprintf(buf, "%d\n", TEMP_FROM_REG(data->temp_hyst));
293 }
294 
295 static ssize_t set_temp_hyst(struct device *dev, struct device_attribute *da,
296 			     const char *buf, size_t count)
297 {
298 	struct lm78_data *data = dev_get_drvdata(dev);
299 	long val = simple_strtol(buf, NULL, 10);
300 
301 	mutex_lock(&data->update_lock);
302 	data->temp_hyst = TEMP_TO_REG(val);
303 	lm78_write_value(data, LM78_REG_TEMP_HYST, data->temp_hyst);
304 	mutex_unlock(&data->update_lock);
305 	return count;
306 }
307 
308 static DEVICE_ATTR(temp1_input, S_IRUGO, show_temp, NULL);
309 static DEVICE_ATTR(temp1_max, S_IRUGO | S_IWUSR,
310 		show_temp_over, set_temp_over);
311 static DEVICE_ATTR(temp1_max_hyst, S_IRUGO | S_IWUSR,
312 		show_temp_hyst, set_temp_hyst);
313 
314 /* 3 Fans */
315 static ssize_t show_fan(struct device *dev, struct device_attribute *da,
316 			char *buf)
317 {
318 	struct sensor_device_attribute *attr = to_sensor_dev_attr(da);
319 	struct lm78_data *data = lm78_update_device(dev);
320 	int nr = attr->index;
321 	return sprintf(buf, "%d\n", FAN_FROM_REG(data->fan[nr],
322 		DIV_FROM_REG(data->fan_div[nr])) );
323 }
324 
325 static ssize_t show_fan_min(struct device *dev, struct device_attribute *da,
326 			    char *buf)
327 {
328 	struct sensor_device_attribute *attr = to_sensor_dev_attr(da);
329 	struct lm78_data *data = lm78_update_device(dev);
330 	int nr = attr->index;
331 	return sprintf(buf,"%d\n", FAN_FROM_REG(data->fan_min[nr],
332 		DIV_FROM_REG(data->fan_div[nr])) );
333 }
334 
335 static ssize_t set_fan_min(struct device *dev, struct device_attribute *da,
336 			   const char *buf, size_t count)
337 {
338 	struct sensor_device_attribute *attr = to_sensor_dev_attr(da);
339 	struct lm78_data *data = dev_get_drvdata(dev);
340 	int nr = attr->index;
341 	unsigned long val = simple_strtoul(buf, NULL, 10);
342 
343 	mutex_lock(&data->update_lock);
344 	data->fan_min[nr] = FAN_TO_REG(val, DIV_FROM_REG(data->fan_div[nr]));
345 	lm78_write_value(data, LM78_REG_FAN_MIN(nr), data->fan_min[nr]);
346 	mutex_unlock(&data->update_lock);
347 	return count;
348 }
349 
350 static ssize_t show_fan_div(struct device *dev, struct device_attribute *da,
351 			    char *buf)
352 {
353 	struct sensor_device_attribute *attr = to_sensor_dev_attr(da);
354 	struct lm78_data *data = lm78_update_device(dev);
355 	return sprintf(buf, "%d\n", DIV_FROM_REG(data->fan_div[attr->index]));
356 }
357 
358 /* Note: we save and restore the fan minimum here, because its value is
359    determined in part by the fan divisor.  This follows the principle of
360    least surprise; the user doesn't expect the fan minimum to change just
361    because the divisor changed. */
362 static ssize_t set_fan_div(struct device *dev, struct device_attribute *da,
363 			   const char *buf, size_t count)
364 {
365 	struct sensor_device_attribute *attr = to_sensor_dev_attr(da);
366 	struct lm78_data *data = dev_get_drvdata(dev);
367 	int nr = attr->index;
368 	unsigned long val = simple_strtoul(buf, NULL, 10);
369 	unsigned long min;
370 	u8 reg;
371 
372 	mutex_lock(&data->update_lock);
373 	min = FAN_FROM_REG(data->fan_min[nr],
374 			   DIV_FROM_REG(data->fan_div[nr]));
375 
376 	switch (val) {
377 	case 1: data->fan_div[nr] = 0; break;
378 	case 2: data->fan_div[nr] = 1; break;
379 	case 4: data->fan_div[nr] = 2; break;
380 	case 8: data->fan_div[nr] = 3; break;
381 	default:
382 		dev_err(dev, "fan_div value %ld not "
383 			"supported. Choose one of 1, 2, 4 or 8!\n", val);
384 		mutex_unlock(&data->update_lock);
385 		return -EINVAL;
386 	}
387 
388 	reg = lm78_read_value(data, LM78_REG_VID_FANDIV);
389 	switch (nr) {
390 	case 0:
391 		reg = (reg & 0xcf) | (data->fan_div[nr] << 4);
392 		break;
393 	case 1:
394 		reg = (reg & 0x3f) | (data->fan_div[nr] << 6);
395 		break;
396 	}
397 	lm78_write_value(data, LM78_REG_VID_FANDIV, reg);
398 
399 	data->fan_min[nr] =
400 		FAN_TO_REG(min, DIV_FROM_REG(data->fan_div[nr]));
401 	lm78_write_value(data, LM78_REG_FAN_MIN(nr), data->fan_min[nr]);
402 	mutex_unlock(&data->update_lock);
403 
404 	return count;
405 }
406 
407 #define show_fan_offset(offset)				\
408 static SENSOR_DEVICE_ATTR(fan##offset##_input, S_IRUGO,		\
409 		show_fan, NULL, offset - 1);			\
410 static SENSOR_DEVICE_ATTR(fan##offset##_min, S_IRUGO | S_IWUSR,	\
411 		show_fan_min, set_fan_min, offset - 1);
412 
413 show_fan_offset(1);
414 show_fan_offset(2);
415 show_fan_offset(3);
416 
417 /* Fan 3 divisor is locked in H/W */
418 static SENSOR_DEVICE_ATTR(fan1_div, S_IRUGO | S_IWUSR,
419 		show_fan_div, set_fan_div, 0);
420 static SENSOR_DEVICE_ATTR(fan2_div, S_IRUGO | S_IWUSR,
421 		show_fan_div, set_fan_div, 1);
422 static SENSOR_DEVICE_ATTR(fan3_div, S_IRUGO, show_fan_div, NULL, 2);
423 
424 /* VID */
425 static ssize_t show_vid(struct device *dev, struct device_attribute *da,
426 			char *buf)
427 {
428 	struct lm78_data *data = lm78_update_device(dev);
429 	return sprintf(buf, "%d\n", vid_from_reg(data->vid, 82));
430 }
431 static DEVICE_ATTR(cpu0_vid, S_IRUGO, show_vid, NULL);
432 
433 /* Alarms */
434 static ssize_t show_alarms(struct device *dev, struct device_attribute *da,
435 			   char *buf)
436 {
437 	struct lm78_data *data = lm78_update_device(dev);
438 	return sprintf(buf, "%u\n", data->alarms);
439 }
440 static DEVICE_ATTR(alarms, S_IRUGO, show_alarms, NULL);
441 
442 static ssize_t show_alarm(struct device *dev, struct device_attribute *da,
443 			  char *buf)
444 {
445 	struct lm78_data *data = lm78_update_device(dev);
446 	int nr = to_sensor_dev_attr(da)->index;
447 	return sprintf(buf, "%u\n", (data->alarms >> nr) & 1);
448 }
449 static SENSOR_DEVICE_ATTR(in0_alarm, S_IRUGO, show_alarm, NULL, 0);
450 static SENSOR_DEVICE_ATTR(in1_alarm, S_IRUGO, show_alarm, NULL, 1);
451 static SENSOR_DEVICE_ATTR(in2_alarm, S_IRUGO, show_alarm, NULL, 2);
452 static SENSOR_DEVICE_ATTR(in3_alarm, S_IRUGO, show_alarm, NULL, 3);
453 static SENSOR_DEVICE_ATTR(in4_alarm, S_IRUGO, show_alarm, NULL, 8);
454 static SENSOR_DEVICE_ATTR(in5_alarm, S_IRUGO, show_alarm, NULL, 9);
455 static SENSOR_DEVICE_ATTR(in6_alarm, S_IRUGO, show_alarm, NULL, 10);
456 static SENSOR_DEVICE_ATTR(fan1_alarm, S_IRUGO, show_alarm, NULL, 6);
457 static SENSOR_DEVICE_ATTR(fan2_alarm, S_IRUGO, show_alarm, NULL, 7);
458 static SENSOR_DEVICE_ATTR(fan3_alarm, S_IRUGO, show_alarm, NULL, 11);
459 static SENSOR_DEVICE_ATTR(temp1_alarm, S_IRUGO, show_alarm, NULL, 4);
460 
461 static struct attribute *lm78_attributes[] = {
462 	&sensor_dev_attr_in0_input.dev_attr.attr,
463 	&sensor_dev_attr_in0_min.dev_attr.attr,
464 	&sensor_dev_attr_in0_max.dev_attr.attr,
465 	&sensor_dev_attr_in0_alarm.dev_attr.attr,
466 	&sensor_dev_attr_in1_input.dev_attr.attr,
467 	&sensor_dev_attr_in1_min.dev_attr.attr,
468 	&sensor_dev_attr_in1_max.dev_attr.attr,
469 	&sensor_dev_attr_in1_alarm.dev_attr.attr,
470 	&sensor_dev_attr_in2_input.dev_attr.attr,
471 	&sensor_dev_attr_in2_min.dev_attr.attr,
472 	&sensor_dev_attr_in2_max.dev_attr.attr,
473 	&sensor_dev_attr_in2_alarm.dev_attr.attr,
474 	&sensor_dev_attr_in3_input.dev_attr.attr,
475 	&sensor_dev_attr_in3_min.dev_attr.attr,
476 	&sensor_dev_attr_in3_max.dev_attr.attr,
477 	&sensor_dev_attr_in3_alarm.dev_attr.attr,
478 	&sensor_dev_attr_in4_input.dev_attr.attr,
479 	&sensor_dev_attr_in4_min.dev_attr.attr,
480 	&sensor_dev_attr_in4_max.dev_attr.attr,
481 	&sensor_dev_attr_in4_alarm.dev_attr.attr,
482 	&sensor_dev_attr_in5_input.dev_attr.attr,
483 	&sensor_dev_attr_in5_min.dev_attr.attr,
484 	&sensor_dev_attr_in5_max.dev_attr.attr,
485 	&sensor_dev_attr_in5_alarm.dev_attr.attr,
486 	&sensor_dev_attr_in6_input.dev_attr.attr,
487 	&sensor_dev_attr_in6_min.dev_attr.attr,
488 	&sensor_dev_attr_in6_max.dev_attr.attr,
489 	&sensor_dev_attr_in6_alarm.dev_attr.attr,
490 	&dev_attr_temp1_input.attr,
491 	&dev_attr_temp1_max.attr,
492 	&dev_attr_temp1_max_hyst.attr,
493 	&sensor_dev_attr_temp1_alarm.dev_attr.attr,
494 	&sensor_dev_attr_fan1_input.dev_attr.attr,
495 	&sensor_dev_attr_fan1_min.dev_attr.attr,
496 	&sensor_dev_attr_fan1_div.dev_attr.attr,
497 	&sensor_dev_attr_fan1_alarm.dev_attr.attr,
498 	&sensor_dev_attr_fan2_input.dev_attr.attr,
499 	&sensor_dev_attr_fan2_min.dev_attr.attr,
500 	&sensor_dev_attr_fan2_div.dev_attr.attr,
501 	&sensor_dev_attr_fan2_alarm.dev_attr.attr,
502 	&sensor_dev_attr_fan3_input.dev_attr.attr,
503 	&sensor_dev_attr_fan3_min.dev_attr.attr,
504 	&sensor_dev_attr_fan3_div.dev_attr.attr,
505 	&sensor_dev_attr_fan3_alarm.dev_attr.attr,
506 	&dev_attr_alarms.attr,
507 	&dev_attr_cpu0_vid.attr,
508 
509 	NULL
510 };
511 
512 static const struct attribute_group lm78_group = {
513 	.attrs = lm78_attributes,
514 };
515 
516 /* I2C devices get this name attribute automatically, but for ISA devices
517    we must create it by ourselves. */
518 static ssize_t show_name(struct device *dev, struct device_attribute
519 			 *devattr, char *buf)
520 {
521 	struct lm78_data *data = dev_get_drvdata(dev);
522 
523 	return sprintf(buf, "%s\n", data->name);
524 }
525 static DEVICE_ATTR(name, S_IRUGO, show_name, NULL);
526 
527 /* Returns 1 if the I2C chip appears to be an alias of the ISA chip */
528 static int lm78_alias_detect(struct i2c_client *client, u8 chipid)
529 {
530 	struct lm78_data *isa;
531 	int i;
532 
533 	if (!pdev)	/* No ISA chip */
534 		return 0;
535 	isa = platform_get_drvdata(pdev);
536 
537 	if (lm78_read_value(isa, LM78_REG_I2C_ADDR) != client->addr)
538 		return 0;	/* Address doesn't match */
539 	if ((lm78_read_value(isa, LM78_REG_CHIPID) & 0xfe) != (chipid & 0xfe))
540 		return 0;	/* Chip type doesn't match */
541 
542 	/* We compare all the limit registers, the config register and the
543 	 * interrupt mask registers */
544 	for (i = 0x2b; i <= 0x3d; i++) {
545 		if (lm78_read_value(isa, i) !=
546 		    i2c_smbus_read_byte_data(client, i))
547 			return 0;
548 	}
549 	if (lm78_read_value(isa, LM78_REG_CONFIG) !=
550 	    i2c_smbus_read_byte_data(client, LM78_REG_CONFIG))
551 		return 0;
552 	for (i = 0x43; i <= 0x46; i++) {
553 		if (lm78_read_value(isa, i) !=
554 		    i2c_smbus_read_byte_data(client, i))
555 			return 0;
556 	}
557 
558 	return 1;
559 }
560 
561 static int lm78_i2c_detect(struct i2c_client *client, int kind,
562 			   struct i2c_board_info *info)
563 {
564 	int i;
565 	struct lm78_data *isa = pdev ? platform_get_drvdata(pdev) : NULL;
566 	const char *client_name;
567 	struct i2c_adapter *adapter = client->adapter;
568 	int address = client->addr;
569 
570 	if (!i2c_check_functionality(adapter, I2C_FUNC_SMBUS_BYTE_DATA))
571 		return -ENODEV;
572 
573 	/* We block updates of the ISA device to minimize the risk of
574 	   concurrent access to the same LM78 chip through different
575 	   interfaces. */
576 	if (isa)
577 		mutex_lock(&isa->update_lock);
578 
579 	if (kind < 0) {
580 		if ((i2c_smbus_read_byte_data(client, LM78_REG_CONFIG) & 0x80)
581 		 || i2c_smbus_read_byte_data(client, LM78_REG_I2C_ADDR)
582 		    != address)
583 			goto err_nodev;
584 
585 		/* Explicitly prevent the misdetection of Winbond chips */
586 		i = i2c_smbus_read_byte_data(client, 0x4f);
587 		if (i == 0xa3 || i == 0x5c)
588 			goto err_nodev;
589 	}
590 
591 	/* Determine the chip type. */
592 	if (kind <= 0) {
593 		i = i2c_smbus_read_byte_data(client, LM78_REG_CHIPID);
594 		if (i == 0x00 || i == 0x20	/* LM78 */
595 		 || i == 0x40)			/* LM78-J */
596 			kind = lm78;
597 		else if ((i & 0xfe) == 0xc0)
598 			kind = lm79;
599 		else {
600 			if (kind == 0)
601 				dev_warn(&adapter->dev, "Ignoring 'force' "
602 					"parameter for unknown chip at "
603 					"adapter %d, address 0x%02x\n",
604 					i2c_adapter_id(adapter), address);
605 			goto err_nodev;
606 		}
607 
608 		if (lm78_alias_detect(client, i)) {
609 			dev_dbg(&adapter->dev, "Device at 0x%02x appears to "
610 				"be the same as ISA device\n", address);
611 			goto err_nodev;
612 		}
613 	}
614 
615 	if (isa)
616 		mutex_unlock(&isa->update_lock);
617 
618 	switch (kind) {
619 	case lm79:
620 		client_name = "lm79";
621 		break;
622 	default:
623 		client_name = "lm78";
624 	}
625 	strlcpy(info->type, client_name, I2C_NAME_SIZE);
626 
627 	return 0;
628 
629  err_nodev:
630 	if (isa)
631 		mutex_unlock(&isa->update_lock);
632 	return -ENODEV;
633 }
634 
635 static int lm78_i2c_probe(struct i2c_client *client,
636 			  const struct i2c_device_id *id)
637 {
638 	struct lm78_data *data;
639 	int err;
640 
641 	data = kzalloc(sizeof(struct lm78_data), GFP_KERNEL);
642 	if (!data)
643 		return -ENOMEM;
644 
645 	i2c_set_clientdata(client, data);
646 	data->client = client;
647 	data->type = id->driver_data;
648 
649 	/* Initialize the LM78 chip */
650 	lm78_init_device(data);
651 
652 	/* Register sysfs hooks */
653 	err = sysfs_create_group(&client->dev.kobj, &lm78_group);
654 	if (err)
655 		goto ERROR3;
656 
657 	data->hwmon_dev = hwmon_device_register(&client->dev);
658 	if (IS_ERR(data->hwmon_dev)) {
659 		err = PTR_ERR(data->hwmon_dev);
660 		goto ERROR4;
661 	}
662 
663 	return 0;
664 
665 ERROR4:
666 	sysfs_remove_group(&client->dev.kobj, &lm78_group);
667 ERROR3:
668 	kfree(data);
669 	return err;
670 }
671 
672 static int lm78_i2c_remove(struct i2c_client *client)
673 {
674 	struct lm78_data *data = i2c_get_clientdata(client);
675 
676 	hwmon_device_unregister(data->hwmon_dev);
677 	sysfs_remove_group(&client->dev.kobj, &lm78_group);
678 	kfree(data);
679 
680 	return 0;
681 }
682 
683 static int __devinit lm78_isa_probe(struct platform_device *pdev)
684 {
685 	int err;
686 	struct lm78_data *data;
687 	struct resource *res;
688 
689 	/* Reserve the ISA region */
690 	res = platform_get_resource(pdev, IORESOURCE_IO, 0);
691 	if (!request_region(res->start + LM78_ADDR_REG_OFFSET, 2, "lm78")) {
692 		err = -EBUSY;
693 		goto exit;
694 	}
695 
696 	if (!(data = kzalloc(sizeof(struct lm78_data), GFP_KERNEL))) {
697 		err = -ENOMEM;
698 		goto exit_release_region;
699 	}
700 	mutex_init(&data->lock);
701 	data->isa_addr = res->start;
702 	platform_set_drvdata(pdev, data);
703 
704 	if (lm78_read_value(data, LM78_REG_CHIPID) & 0x80) {
705 		data->type = lm79;
706 		data->name = "lm79";
707 	} else {
708 		data->type = lm78;
709 		data->name = "lm78";
710 	}
711 
712 	/* Initialize the LM78 chip */
713 	lm78_init_device(data);
714 
715 	/* Register sysfs hooks */
716 	if ((err = sysfs_create_group(&pdev->dev.kobj, &lm78_group))
717 	 || (err = device_create_file(&pdev->dev, &dev_attr_name)))
718 		goto exit_remove_files;
719 
720 	data->hwmon_dev = hwmon_device_register(&pdev->dev);
721 	if (IS_ERR(data->hwmon_dev)) {
722 		err = PTR_ERR(data->hwmon_dev);
723 		goto exit_remove_files;
724 	}
725 
726 	return 0;
727 
728  exit_remove_files:
729 	sysfs_remove_group(&pdev->dev.kobj, &lm78_group);
730 	device_remove_file(&pdev->dev, &dev_attr_name);
731 	kfree(data);
732  exit_release_region:
733 	release_region(res->start + LM78_ADDR_REG_OFFSET, 2);
734  exit:
735 	return err;
736 }
737 
738 static int __devexit lm78_isa_remove(struct platform_device *pdev)
739 {
740 	struct lm78_data *data = platform_get_drvdata(pdev);
741 	struct resource *res;
742 
743 	hwmon_device_unregister(data->hwmon_dev);
744 	sysfs_remove_group(&pdev->dev.kobj, &lm78_group);
745 	device_remove_file(&pdev->dev, &dev_attr_name);
746 	kfree(data);
747 
748 	res = platform_get_resource(pdev, IORESOURCE_IO, 0);
749 	release_region(res->start + LM78_ADDR_REG_OFFSET, 2);
750 
751 	return 0;
752 }
753 
754 /* The SMBus locks itself, but ISA access must be locked explicitly!
755    We don't want to lock the whole ISA bus, so we lock each client
756    separately.
757    We ignore the LM78 BUSY flag at this moment - it could lead to deadlocks,
758    would slow down the LM78 access and should not be necessary.  */
759 static int lm78_read_value(struct lm78_data *data, u8 reg)
760 {
761 	struct i2c_client *client = data->client;
762 
763 	if (!client) { /* ISA device */
764 		int res;
765 		mutex_lock(&data->lock);
766 		outb_p(reg, data->isa_addr + LM78_ADDR_REG_OFFSET);
767 		res = inb_p(data->isa_addr + LM78_DATA_REG_OFFSET);
768 		mutex_unlock(&data->lock);
769 		return res;
770 	} else
771 		return i2c_smbus_read_byte_data(client, reg);
772 }
773 
774 /* The SMBus locks itself, but ISA access muse be locked explicitly!
775    We don't want to lock the whole ISA bus, so we lock each client
776    separately.
777    We ignore the LM78 BUSY flag at this moment - it could lead to deadlocks,
778    would slow down the LM78 access and should not be necessary.
779    There are some ugly typecasts here, but the good new is - they should
780    nowhere else be necessary! */
781 static int lm78_write_value(struct lm78_data *data, u8 reg, u8 value)
782 {
783 	struct i2c_client *client = data->client;
784 
785 	if (!client) { /* ISA device */
786 		mutex_lock(&data->lock);
787 		outb_p(reg, data->isa_addr + LM78_ADDR_REG_OFFSET);
788 		outb_p(value, data->isa_addr + LM78_DATA_REG_OFFSET);
789 		mutex_unlock(&data->lock);
790 		return 0;
791 	} else
792 		return i2c_smbus_write_byte_data(client, reg, value);
793 }
794 
795 static void lm78_init_device(struct lm78_data *data)
796 {
797 	u8 config;
798 	int i;
799 
800 	/* Start monitoring */
801 	config = lm78_read_value(data, LM78_REG_CONFIG);
802 	if ((config & 0x09) != 0x01)
803 		lm78_write_value(data, LM78_REG_CONFIG,
804 				 (config & 0xf7) | 0x01);
805 
806 	/* A few vars need to be filled upon startup */
807 	for (i = 0; i < 3; i++) {
808 		data->fan_min[i] = lm78_read_value(data,
809 					LM78_REG_FAN_MIN(i));
810 	}
811 
812 	mutex_init(&data->update_lock);
813 }
814 
815 static struct lm78_data *lm78_update_device(struct device *dev)
816 {
817 	struct lm78_data *data = dev_get_drvdata(dev);
818 	int i;
819 
820 	mutex_lock(&data->update_lock);
821 
822 	if (time_after(jiffies, data->last_updated + HZ + HZ / 2)
823 	    || !data->valid) {
824 
825 		dev_dbg(dev, "Starting lm78 update\n");
826 
827 		for (i = 0; i <= 6; i++) {
828 			data->in[i] =
829 			    lm78_read_value(data, LM78_REG_IN(i));
830 			data->in_min[i] =
831 			    lm78_read_value(data, LM78_REG_IN_MIN(i));
832 			data->in_max[i] =
833 			    lm78_read_value(data, LM78_REG_IN_MAX(i));
834 		}
835 		for (i = 0; i < 3; i++) {
836 			data->fan[i] =
837 			    lm78_read_value(data, LM78_REG_FAN(i));
838 			data->fan_min[i] =
839 			    lm78_read_value(data, LM78_REG_FAN_MIN(i));
840 		}
841 		data->temp = lm78_read_value(data, LM78_REG_TEMP);
842 		data->temp_over =
843 		    lm78_read_value(data, LM78_REG_TEMP_OVER);
844 		data->temp_hyst =
845 		    lm78_read_value(data, LM78_REG_TEMP_HYST);
846 		i = lm78_read_value(data, LM78_REG_VID_FANDIV);
847 		data->vid = i & 0x0f;
848 		if (data->type == lm79)
849 			data->vid |=
850 			    (lm78_read_value(data, LM78_REG_CHIPID) &
851 			     0x01) << 4;
852 		else
853 			data->vid |= 0x10;
854 		data->fan_div[0] = (i >> 4) & 0x03;
855 		data->fan_div[1] = i >> 6;
856 		data->alarms = lm78_read_value(data, LM78_REG_ALARM1) +
857 		    (lm78_read_value(data, LM78_REG_ALARM2) << 8);
858 		data->last_updated = jiffies;
859 		data->valid = 1;
860 
861 		data->fan_div[2] = 1;
862 	}
863 
864 	mutex_unlock(&data->update_lock);
865 
866 	return data;
867 }
868 
869 /* return 1 if a supported chip is found, 0 otherwise */
870 static int __init lm78_isa_found(unsigned short address)
871 {
872 	int val, save, found = 0;
873 
874 	/* We have to request the region in two parts because some
875 	   boards declare base+4 to base+7 as a PNP device */
876 	if (!request_region(address, 4, "lm78")) {
877 		pr_debug("lm78: Failed to request low part of region\n");
878 		return 0;
879 	}
880 	if (!request_region(address + 4, 4, "lm78")) {
881 		pr_debug("lm78: Failed to request high part of region\n");
882 		release_region(address, 4);
883 		return 0;
884 	}
885 
886 #define REALLY_SLOW_IO
887 	/* We need the timeouts for at least some LM78-like
888 	   chips. But only if we read 'undefined' registers. */
889 	val = inb_p(address + 1);
890 	if (inb_p(address + 2) != val
891 	 || inb_p(address + 3) != val
892 	 || inb_p(address + 7) != val)
893 		goto release;
894 #undef REALLY_SLOW_IO
895 
896 	/* We should be able to change the 7 LSB of the address port. The
897 	   MSB (busy flag) should be clear initially, set after the write. */
898 	save = inb_p(address + LM78_ADDR_REG_OFFSET);
899 	if (save & 0x80)
900 		goto release;
901 	val = ~save & 0x7f;
902 	outb_p(val, address + LM78_ADDR_REG_OFFSET);
903 	if (inb_p(address + LM78_ADDR_REG_OFFSET) != (val | 0x80)) {
904 		outb_p(save, address + LM78_ADDR_REG_OFFSET);
905 		goto release;
906 	}
907 
908 	/* We found a device, now see if it could be an LM78 */
909 	outb_p(LM78_REG_CONFIG, address + LM78_ADDR_REG_OFFSET);
910 	val = inb_p(address + LM78_DATA_REG_OFFSET);
911 	if (val & 0x80)
912 		goto release;
913 	outb_p(LM78_REG_I2C_ADDR, address + LM78_ADDR_REG_OFFSET);
914 	val = inb_p(address + LM78_DATA_REG_OFFSET);
915 	if (val < 0x03 || val > 0x77)	/* Not a valid I2C address */
916 		goto release;
917 
918 	/* The busy flag should be clear again */
919 	if (inb_p(address + LM78_ADDR_REG_OFFSET) & 0x80)
920 		goto release;
921 
922 	/* Explicitly prevent the misdetection of Winbond chips */
923 	outb_p(0x4f, address + LM78_ADDR_REG_OFFSET);
924 	val = inb_p(address + LM78_DATA_REG_OFFSET);
925 	if (val == 0xa3 || val == 0x5c)
926 		goto release;
927 
928 	/* Explicitly prevent the misdetection of ITE chips */
929 	outb_p(0x58, address + LM78_ADDR_REG_OFFSET);
930 	val = inb_p(address + LM78_DATA_REG_OFFSET);
931 	if (val == 0x90)
932 		goto release;
933 
934 	/* Determine the chip type */
935 	outb_p(LM78_REG_CHIPID, address + LM78_ADDR_REG_OFFSET);
936 	val = inb_p(address + LM78_DATA_REG_OFFSET);
937 	if (val == 0x00 || val == 0x20	/* LM78 */
938 	 || val == 0x40			/* LM78-J */
939 	 || (val & 0xfe) == 0xc0)	/* LM79 */
940 		found = 1;
941 
942 	if (found)
943 		pr_info("lm78: Found an %s chip at %#x\n",
944 			val & 0x80 ? "LM79" : "LM78", (int)address);
945 
946  release:
947 	release_region(address + 4, 4);
948 	release_region(address, 4);
949 	return found;
950 }
951 
952 static int __init lm78_isa_device_add(unsigned short address)
953 {
954 	struct resource res = {
955 		.start	= address,
956 		.end	= address + LM78_EXTENT - 1,
957 		.name	= "lm78",
958 		.flags	= IORESOURCE_IO,
959 	};
960 	int err;
961 
962 	pdev = platform_device_alloc("lm78", address);
963 	if (!pdev) {
964 		err = -ENOMEM;
965 		printk(KERN_ERR "lm78: Device allocation failed\n");
966 		goto exit;
967 	}
968 
969 	err = platform_device_add_resources(pdev, &res, 1);
970 	if (err) {
971 		printk(KERN_ERR "lm78: Device resource addition failed "
972 		       "(%d)\n", err);
973 		goto exit_device_put;
974 	}
975 
976 	err = platform_device_add(pdev);
977 	if (err) {
978 		printk(KERN_ERR "lm78: Device addition failed (%d)\n",
979 		       err);
980 		goto exit_device_put;
981 	}
982 
983 	return 0;
984 
985  exit_device_put:
986 	platform_device_put(pdev);
987  exit:
988 	pdev = NULL;
989 	return err;
990 }
991 
992 static int __init sm_lm78_init(void)
993 {
994 	int res;
995 
996 	/* We register the ISA device first, so that we can skip the
997 	 * registration of an I2C interface to the same device. */
998 	if (lm78_isa_found(isa_address)) {
999 		res = platform_driver_register(&lm78_isa_driver);
1000 		if (res)
1001 			goto exit;
1002 
1003 		/* Sets global pdev as a side effect */
1004 		res = lm78_isa_device_add(isa_address);
1005 		if (res)
1006 			goto exit_unreg_isa_driver;
1007 	}
1008 
1009 	res = i2c_add_driver(&lm78_driver);
1010 	if (res)
1011 		goto exit_unreg_isa_device;
1012 
1013 	return 0;
1014 
1015  exit_unreg_isa_device:
1016 	platform_device_unregister(pdev);
1017  exit_unreg_isa_driver:
1018 	platform_driver_unregister(&lm78_isa_driver);
1019  exit:
1020 	return res;
1021 }
1022 
1023 static void __exit sm_lm78_exit(void)
1024 {
1025 	if (pdev) {
1026 		platform_device_unregister(pdev);
1027 		platform_driver_unregister(&lm78_isa_driver);
1028 	}
1029 	i2c_del_driver(&lm78_driver);
1030 }
1031 
1032 
1033 
1034 MODULE_AUTHOR("Frodo Looijaard <frodol@dds.nl>");
1035 MODULE_DESCRIPTION("LM78/LM79 driver");
1036 MODULE_LICENSE("GPL");
1037 
1038 module_init(sm_lm78_init);
1039 module_exit(sm_lm78_exit);
1040