xref: /openbmc/linux/drivers/hwmon/vt1211.c (revision a1e58bbd)
1 /*
2  * vt1211.c - driver for the VIA VT1211 Super-I/O chip integrated hardware
3  *            monitoring features
4  * Copyright (C) 2006 Juerg Haefliger <juergh@gmail.com>
5  *
6  * This driver is based on the driver for kernel 2.4 by Mark D. Studebaker
7  * and its port to kernel 2.6 by Lars Ekman.
8  *
9  * This program is free software; you can redistribute it and/or modify
10  * it under the terms of the GNU General Public License as published by
11  * the Free Software Foundation; either version 2 of the License, or
12  * (at your option) any later version.
13  *
14  * This program is distributed in the hope that it will be useful,
15  * but WITHOUT ANY WARRANTY; without even the implied warranty of
16  * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
17  * GNU General Public License for more details.
18  *
19  * You should have received a copy of the GNU General Public License
20  * along with this program; if not, write to the Free Software
21  * Foundation, Inc., 675 Mass Ave, Cambridge, MA 02139, USA.
22  */
23 
24 #include <linux/module.h>
25 #include <linux/init.h>
26 #include <linux/slab.h>
27 #include <linux/jiffies.h>
28 #include <linux/platform_device.h>
29 #include <linux/hwmon.h>
30 #include <linux/hwmon-sysfs.h>
31 #include <linux/hwmon-vid.h>
32 #include <linux/err.h>
33 #include <linux/mutex.h>
34 #include <linux/ioport.h>
35 #include <asm/io.h>
36 
37 static int uch_config = -1;
38 module_param(uch_config, int, 0);
39 MODULE_PARM_DESC(uch_config, "Initialize the universal channel configuration");
40 
41 static int int_mode = -1;
42 module_param(int_mode, int, 0);
43 MODULE_PARM_DESC(int_mode, "Force the temperature interrupt mode");
44 
45 static unsigned short force_id;
46 module_param(force_id, ushort, 0);
47 MODULE_PARM_DESC(force_id, "Override the detected device ID");
48 
49 static struct platform_device *pdev;
50 
51 #define DRVNAME "vt1211"
52 
53 /* ---------------------------------------------------------------------
54  * Registers
55  *
56  * The sensors are defined as follows.
57  *
58  * Sensor          Voltage Mode   Temp Mode   Notes (from the datasheet)
59  * --------        ------------   ---------   --------------------------
60  * Reading 1                      temp1       Intel thermal diode
61  * Reading 3                      temp2       Internal thermal diode
62  * UCH1/Reading2   in0            temp3       NTC type thermistor
63  * UCH2            in1            temp4       +2.5V
64  * UCH3            in2            temp5       VccP
65  * UCH4            in3            temp6       +5V
66  * UCH5            in4            temp7       +12V
67  * 3.3V            in5                        Internal VDD (+3.3V)
68  *
69  * --------------------------------------------------------------------- */
70 
71 /* Voltages (in) numbered 0-5 (ix) */
72 #define VT1211_REG_IN(ix)		(0x21 + (ix))
73 #define VT1211_REG_IN_MIN(ix)		((ix) == 0 ? 0x3e : 0x2a + 2 * (ix))
74 #define VT1211_REG_IN_MAX(ix)		((ix) == 0 ? 0x3d : 0x29 + 2 * (ix))
75 
76 /* Temperatures (temp) numbered 0-6 (ix) */
77 static u8 regtemp[]	= {0x1f, 0x20, 0x21, 0x22, 0x23, 0x24, 0x25};
78 static u8 regtempmax[]	= {0x39, 0x1d, 0x3d, 0x2b, 0x2d, 0x2f, 0x31};
79 static u8 regtemphyst[]	= {0x3a, 0x1e, 0x3e, 0x2c, 0x2e, 0x30, 0x32};
80 
81 /* Fans numbered 0-1 (ix) */
82 #define VT1211_REG_FAN(ix)		(0x29 + (ix))
83 #define VT1211_REG_FAN_MIN(ix)		(0x3b + (ix))
84 #define VT1211_REG_FAN_DIV		 0x47
85 
86 /* PWMs numbered 0-1 (ix) */
87 /* Auto points numbered 0-3 (ap) */
88 #define VT1211_REG_PWM(ix)		(0x60 + (ix))
89 #define VT1211_REG_PWM_CLK		 0x50
90 #define VT1211_REG_PWM_CTL		 0x51
91 #define VT1211_REG_PWM_AUTO_TEMP(ap)	(0x55 - (ap))
92 #define VT1211_REG_PWM_AUTO_PWM(ix, ap)	(0x58 + 2 * (ix) - (ap))
93 
94 /* Miscellaneous registers */
95 #define VT1211_REG_CONFIG		0x40
96 #define VT1211_REG_ALARM1		0x41
97 #define VT1211_REG_ALARM2		0x42
98 #define VT1211_REG_VID			0x45
99 #define VT1211_REG_UCH_CONFIG		0x4a
100 #define VT1211_REG_TEMP1_CONFIG		0x4b
101 #define VT1211_REG_TEMP2_CONFIG		0x4c
102 
103 /* In, temp & fan alarm bits */
104 static const u8 bitalarmin[]	= {11, 0, 1, 3, 8, 2, 9};
105 static const u8 bitalarmtemp[]	= {4, 15, 11, 0, 1, 3, 8};
106 static const u8 bitalarmfan[]	= {6, 7};
107 
108 /* ---------------------------------------------------------------------
109  * Data structures and manipulation thereof
110  * --------------------------------------------------------------------- */
111 
112 struct vt1211_data {
113 	unsigned short addr;
114 	const char *name;
115 	struct device *hwmon_dev;
116 
117 	struct mutex update_lock;
118 	char valid;			/* !=0 if following fields are valid */
119 	unsigned long last_updated;	/* In jiffies */
120 
121 	/* Register values */
122 	u8  in[6];
123 	u8  in_max[6];
124 	u8  in_min[6];
125 	u8  temp[7];
126 	u8  temp_max[7];
127 	u8  temp_hyst[7];
128 	u8  fan[2];
129 	u8  fan_min[2];
130 	u8  fan_div[2];
131 	u8  fan_ctl;
132 	u8  pwm[2];
133 	u8  pwm_ctl[2];
134 	u8  pwm_clk;
135 	u8  pwm_auto_temp[4];
136 	u8  pwm_auto_pwm[2][4];
137 	u8  vid;		/* Read once at init time */
138 	u8  vrm;
139 	u8  uch_config;		/* Read once at init time */
140 	u16 alarms;
141 };
142 
143 /* ix = [0-5] */
144 #define ISVOLT(ix, uch_config)	((ix) > 4 ? 1 : \
145 				 !(((uch_config) >> ((ix) + 2)) & 1))
146 
147 /* ix = [0-6] */
148 #define ISTEMP(ix, uch_config)	((ix) < 2 ? 1 : \
149 				 ((uch_config) >> (ix)) & 1)
150 
151 /* in5 (ix = 5) is special. It's the internal 3.3V so it's scaled in the
152    driver according to the VT1211 BIOS porting guide */
153 #define IN_FROM_REG(ix, reg)	((reg) < 3 ? 0 : (ix) == 5 ? \
154 				 (((reg) - 3) * 15882 + 479) / 958 : \
155 				 (((reg) - 3) * 10000 + 479) / 958)
156 #define IN_TO_REG(ix, val)	(SENSORS_LIMIT((ix) == 5 ? \
157 				 ((val) * 958 + 7941) / 15882 + 3 : \
158 				 ((val) * 958 + 5000) / 10000 + 3, 0, 255))
159 
160 /* temp1 (ix = 0) is an intel thermal diode which is scaled in user space.
161    temp2 (ix = 1) is the internal temp diode so it's scaled in the driver
162    according to some measurements that I took on an EPIA M10000.
163    temp3-7 are thermistor based so the driver returns the voltage measured at
164    the pin (range 0V - 2.2V). */
165 #define TEMP_FROM_REG(ix, reg)	((ix) == 0 ? (reg) * 1000 : \
166 				 (ix) == 1 ? (reg) < 51 ? 0 : \
167 				 ((reg) - 51) * 1000 : \
168 				 ((253 - (reg)) * 2200 + 105) / 210)
169 #define TEMP_TO_REG(ix, val)	SENSORS_LIMIT( \
170 				 ((ix) == 0 ? ((val) + 500) / 1000 : \
171 				  (ix) == 1 ? ((val) + 500) / 1000 + 51 : \
172 				  253 - ((val) * 210 + 1100) / 2200), 0, 255)
173 
174 #define DIV_FROM_REG(reg)	(1 << (reg))
175 
176 #define RPM_FROM_REG(reg, div)	(((reg) == 0) || ((reg) == 255) ? 0 : \
177 				 1310720 / (reg) / DIV_FROM_REG(div))
178 #define RPM_TO_REG(val, div)	((val) == 0 ? 255 : \
179 				 SENSORS_LIMIT((1310720 / (val) / \
180 				 DIV_FROM_REG(div)), 1, 254))
181 
182 /* ---------------------------------------------------------------------
183  * Super-I/O constants and functions
184  * --------------------------------------------------------------------- */
185 
186 /* Configuration index port registers
187  * The vt1211 can live at 2 different addresses so we need to probe both */
188 #define SIO_REG_CIP1		0x2e
189 #define SIO_REG_CIP2		0x4e
190 
191 /* Configuration registers */
192 #define SIO_VT1211_LDN		0x07	/* logical device number */
193 #define SIO_VT1211_DEVID	0x20	/* device ID */
194 #define SIO_VT1211_DEVREV	0x21	/* device revision */
195 #define SIO_VT1211_ACTIVE	0x30	/* HW monitor active */
196 #define SIO_VT1211_BADDR	0x60	/* base I/O address */
197 #define SIO_VT1211_ID		0x3c	/* VT1211 device ID */
198 
199 /* VT1211 logical device numbers */
200 #define SIO_VT1211_LDN_HWMON	0x0b	/* HW monitor */
201 
202 static inline void superio_outb(int sio_cip, int reg, int val)
203 {
204 	outb(reg, sio_cip);
205 	outb(val, sio_cip + 1);
206 }
207 
208 static inline int superio_inb(int sio_cip, int reg)
209 {
210 	outb(reg, sio_cip);
211 	return inb(sio_cip + 1);
212 }
213 
214 static inline void superio_select(int sio_cip, int ldn)
215 {
216 	outb(SIO_VT1211_LDN, sio_cip);
217 	outb(ldn, sio_cip + 1);
218 }
219 
220 static inline void superio_enter(int sio_cip)
221 {
222 	outb(0x87, sio_cip);
223 	outb(0x87, sio_cip);
224 }
225 
226 static inline void superio_exit(int sio_cip)
227 {
228 	outb(0xaa, sio_cip);
229 }
230 
231 /* ---------------------------------------------------------------------
232  * Device I/O access
233  * --------------------------------------------------------------------- */
234 
235 static inline u8 vt1211_read8(struct vt1211_data *data, u8 reg)
236 {
237 	return inb(data->addr + reg);
238 }
239 
240 static inline void vt1211_write8(struct vt1211_data *data, u8 reg, u8 val)
241 {
242 	outb(val, data->addr + reg);
243 }
244 
245 static struct vt1211_data *vt1211_update_device(struct device *dev)
246 {
247 	struct vt1211_data *data = dev_get_drvdata(dev);
248 	int ix, val;
249 
250 	mutex_lock(&data->update_lock);
251 
252 	/* registers cache is refreshed after 1 second */
253 	if (time_after(jiffies, data->last_updated + HZ) || !data->valid) {
254 		/* read VID */
255 		data->vid = vt1211_read8(data, VT1211_REG_VID) & 0x1f;
256 
257 		/* voltage (in) registers */
258 		for (ix = 0; ix < ARRAY_SIZE(data->in); ix++) {
259 			if (ISVOLT(ix, data->uch_config)) {
260 				data->in[ix] = vt1211_read8(data,
261 						VT1211_REG_IN(ix));
262 				data->in_min[ix] = vt1211_read8(data,
263 						VT1211_REG_IN_MIN(ix));
264 				data->in_max[ix] = vt1211_read8(data,
265 						VT1211_REG_IN_MAX(ix));
266 			}
267 		}
268 
269 		/* temp registers */
270 		for (ix = 0; ix < ARRAY_SIZE(data->temp); ix++) {
271 			if (ISTEMP(ix, data->uch_config)) {
272 				data->temp[ix] = vt1211_read8(data,
273 						regtemp[ix]);
274 				data->temp_max[ix] = vt1211_read8(data,
275 						regtempmax[ix]);
276 				data->temp_hyst[ix] = vt1211_read8(data,
277 						regtemphyst[ix]);
278 			}
279 		}
280 
281 		/* fan & pwm registers */
282 		for (ix = 0; ix < ARRAY_SIZE(data->fan); ix++) {
283 			data->fan[ix] = vt1211_read8(data,
284 						VT1211_REG_FAN(ix));
285 			data->fan_min[ix] = vt1211_read8(data,
286 						VT1211_REG_FAN_MIN(ix));
287 			data->pwm[ix] = vt1211_read8(data,
288 						VT1211_REG_PWM(ix));
289 		}
290 		val = vt1211_read8(data, VT1211_REG_FAN_DIV);
291 		data->fan_div[0] = (val >> 4) & 3;
292 		data->fan_div[1] = (val >> 6) & 3;
293 		data->fan_ctl = val & 0xf;
294 
295 		val = vt1211_read8(data, VT1211_REG_PWM_CTL);
296 		data->pwm_ctl[0] = val & 0xf;
297 		data->pwm_ctl[1] = (val >> 4) & 0xf;
298 
299 		data->pwm_clk = vt1211_read8(data, VT1211_REG_PWM_CLK);
300 
301 		/* pwm & temp auto point registers */
302 		data->pwm_auto_pwm[0][1] = vt1211_read8(data,
303 						VT1211_REG_PWM_AUTO_PWM(0, 1));
304 		data->pwm_auto_pwm[0][2] = vt1211_read8(data,
305 						VT1211_REG_PWM_AUTO_PWM(0, 2));
306 		data->pwm_auto_pwm[1][1] = vt1211_read8(data,
307 						VT1211_REG_PWM_AUTO_PWM(1, 1));
308 		data->pwm_auto_pwm[1][2] = vt1211_read8(data,
309 						VT1211_REG_PWM_AUTO_PWM(1, 2));
310 		for (ix = 0; ix < ARRAY_SIZE(data->pwm_auto_temp); ix++) {
311 			data->pwm_auto_temp[ix] = vt1211_read8(data,
312 						VT1211_REG_PWM_AUTO_TEMP(ix));
313 		}
314 
315 		/* alarm registers */
316 		data->alarms = (vt1211_read8(data, VT1211_REG_ALARM2) << 8) |
317 				vt1211_read8(data, VT1211_REG_ALARM1);
318 
319 		data->last_updated = jiffies;
320 		data->valid = 1;
321 	}
322 
323 	mutex_unlock(&data->update_lock);
324 
325 	return data;
326 }
327 
328 /* ---------------------------------------------------------------------
329  * Voltage sysfs interfaces
330  * ix = [0-5]
331  * --------------------------------------------------------------------- */
332 
333 #define SHOW_IN_INPUT	0
334 #define SHOW_SET_IN_MIN	1
335 #define SHOW_SET_IN_MAX	2
336 #define SHOW_IN_ALARM	3
337 
338 static ssize_t show_in(struct device *dev, struct device_attribute *attr,
339 		       char *buf)
340 {
341 	struct vt1211_data *data = vt1211_update_device(dev);
342 	struct sensor_device_attribute_2 *sensor_attr_2 =
343 						to_sensor_dev_attr_2(attr);
344 	int ix = sensor_attr_2->index;
345 	int fn = sensor_attr_2->nr;
346 	int res;
347 
348 	switch (fn) {
349 	case SHOW_IN_INPUT:
350 		res = IN_FROM_REG(ix, data->in[ix]);
351 		break;
352 	case SHOW_SET_IN_MIN:
353 		res = IN_FROM_REG(ix, data->in_min[ix]);
354 		break;
355 	case SHOW_SET_IN_MAX:
356 		res = IN_FROM_REG(ix, data->in_max[ix]);
357 		break;
358 	case SHOW_IN_ALARM:
359 		res = (data->alarms >> bitalarmin[ix]) & 1;
360 		break;
361 	default:
362 		res = 0;
363 		dev_dbg(dev, "Unknown attr fetch (%d)\n", fn);
364 	}
365 
366 	return sprintf(buf, "%d\n", res);
367 }
368 
369 static ssize_t set_in(struct device *dev, struct device_attribute *attr,
370 		      const char *buf, size_t count)
371 {
372 	struct vt1211_data *data = dev_get_drvdata(dev);
373 	struct sensor_device_attribute_2 *sensor_attr_2 =
374 						to_sensor_dev_attr_2(attr);
375 	int ix = sensor_attr_2->index;
376 	int fn = sensor_attr_2->nr;
377 	long val = simple_strtol(buf, NULL, 10);
378 
379 	mutex_lock(&data->update_lock);
380 	switch (fn) {
381 	case SHOW_SET_IN_MIN:
382 		data->in_min[ix] = IN_TO_REG(ix, val);
383 		vt1211_write8(data, VT1211_REG_IN_MIN(ix), data->in_min[ix]);
384 		break;
385 	case SHOW_SET_IN_MAX:
386 		data->in_max[ix] = IN_TO_REG(ix, val);
387 		vt1211_write8(data, VT1211_REG_IN_MAX(ix), data->in_max[ix]);
388 		break;
389 	default:
390 		dev_dbg(dev, "Unknown attr fetch (%d)\n", fn);
391 	}
392 	mutex_unlock(&data->update_lock);
393 
394 	return count;
395 }
396 
397 /* ---------------------------------------------------------------------
398  * Temperature sysfs interfaces
399  * ix = [0-6]
400  * --------------------------------------------------------------------- */
401 
402 #define SHOW_TEMP_INPUT		0
403 #define SHOW_SET_TEMP_MAX	1
404 #define SHOW_SET_TEMP_MAX_HYST	2
405 #define SHOW_TEMP_ALARM		3
406 
407 static ssize_t show_temp(struct device *dev, struct device_attribute *attr,
408 			 char *buf)
409 {
410 	struct vt1211_data *data = vt1211_update_device(dev);
411 	struct sensor_device_attribute_2 *sensor_attr_2 =
412 						to_sensor_dev_attr_2(attr);
413 	int ix = sensor_attr_2->index;
414 	int fn = sensor_attr_2->nr;
415 	int res;
416 
417 	switch (fn) {
418 	case SHOW_TEMP_INPUT:
419 		res = TEMP_FROM_REG(ix, data->temp[ix]);
420 		break;
421 	case SHOW_SET_TEMP_MAX:
422 		res = TEMP_FROM_REG(ix, data->temp_max[ix]);
423 		break;
424 	case SHOW_SET_TEMP_MAX_HYST:
425 		res = TEMP_FROM_REG(ix, data->temp_hyst[ix]);
426 		break;
427 	case SHOW_TEMP_ALARM:
428 		res = (data->alarms >> bitalarmtemp[ix]) & 1;
429 		break;
430 	default:
431 		res = 0;
432 		dev_dbg(dev, "Unknown attr fetch (%d)\n", fn);
433 	}
434 
435 	return sprintf(buf, "%d\n", res);
436 }
437 
438 static ssize_t set_temp(struct device *dev, struct device_attribute *attr,
439 			const char *buf, size_t count)
440 {
441 	struct vt1211_data *data = dev_get_drvdata(dev);
442 	struct sensor_device_attribute_2 *sensor_attr_2 =
443 						to_sensor_dev_attr_2(attr);
444 	int ix = sensor_attr_2->index;
445 	int fn = sensor_attr_2->nr;
446 	long val = simple_strtol(buf, NULL, 10);
447 
448 	mutex_lock(&data->update_lock);
449 	switch (fn) {
450 	case SHOW_SET_TEMP_MAX:
451 		data->temp_max[ix] = TEMP_TO_REG(ix, val);
452 		vt1211_write8(data, regtempmax[ix],
453 			      data->temp_max[ix]);
454 		break;
455 	case SHOW_SET_TEMP_MAX_HYST:
456 		data->temp_hyst[ix] = TEMP_TO_REG(ix, val);
457 		vt1211_write8(data, regtemphyst[ix],
458 			      data->temp_hyst[ix]);
459 		break;
460 	default:
461 		dev_dbg(dev, "Unknown attr fetch (%d)\n", fn);
462 	}
463 	mutex_unlock(&data->update_lock);
464 
465 	return count;
466 }
467 
468 /* ---------------------------------------------------------------------
469  * Fan sysfs interfaces
470  * ix = [0-1]
471  * --------------------------------------------------------------------- */
472 
473 #define SHOW_FAN_INPUT		0
474 #define SHOW_SET_FAN_MIN	1
475 #define SHOW_SET_FAN_DIV	2
476 #define SHOW_FAN_ALARM		3
477 
478 static ssize_t show_fan(struct device *dev, struct device_attribute *attr,
479 			char *buf)
480 {
481 	struct vt1211_data *data = vt1211_update_device(dev);
482 	struct sensor_device_attribute_2 *sensor_attr_2 =
483 						to_sensor_dev_attr_2(attr);
484 	int ix = sensor_attr_2->index;
485 	int fn = sensor_attr_2->nr;
486 	int res;
487 
488 	switch (fn) {
489 	case SHOW_FAN_INPUT:
490 		res = RPM_FROM_REG(data->fan[ix], data->fan_div[ix]);
491 		break;
492 	case SHOW_SET_FAN_MIN:
493 		res = RPM_FROM_REG(data->fan_min[ix], data->fan_div[ix]);
494 		break;
495 	case SHOW_SET_FAN_DIV:
496 		res = DIV_FROM_REG(data->fan_div[ix]);
497 		break;
498 	case SHOW_FAN_ALARM:
499 		res = (data->alarms >> bitalarmfan[ix]) & 1;
500 		break;
501 	default:
502 		res = 0;
503 		dev_dbg(dev, "Unknown attr fetch (%d)\n", fn);
504 	}
505 
506 	return sprintf(buf, "%d\n", res);
507 }
508 
509 static ssize_t set_fan(struct device *dev, struct device_attribute *attr,
510 		       const char *buf, size_t count)
511 {
512 	struct vt1211_data *data = dev_get_drvdata(dev);
513 	struct sensor_device_attribute_2 *sensor_attr_2 =
514 						to_sensor_dev_attr_2(attr);
515 	int ix = sensor_attr_2->index;
516 	int fn = sensor_attr_2->nr;
517 	long val = simple_strtol(buf, NULL, 10);
518 	int reg;
519 
520 	mutex_lock(&data->update_lock);
521 
522 	/* sync the data cache */
523 	reg = vt1211_read8(data, VT1211_REG_FAN_DIV);
524 	data->fan_div[0] = (reg >> 4) & 3;
525 	data->fan_div[1] = (reg >> 6) & 3;
526 	data->fan_ctl = reg & 0xf;
527 
528 	switch (fn) {
529 	case SHOW_SET_FAN_MIN:
530 		data->fan_min[ix] = RPM_TO_REG(val, data->fan_div[ix]);
531 		vt1211_write8(data, VT1211_REG_FAN_MIN(ix),
532 			      data->fan_min[ix]);
533 		break;
534 	case SHOW_SET_FAN_DIV:
535 		switch (val) {
536 			case 1: data->fan_div[ix] = 0; break;
537 			case 2: data->fan_div[ix] = 1; break;
538 			case 4: data->fan_div[ix] = 2; break;
539 			case 8: data->fan_div[ix] = 3; break;
540 			default:
541 				count = -EINVAL;
542 				dev_warn(dev, "fan div value %ld not "
543 					 "supported. Choose one of 1, 2, "
544 					 "4, or 8.\n", val);
545 				goto EXIT;
546 		}
547 		vt1211_write8(data, VT1211_REG_FAN_DIV,
548 			      ((data->fan_div[1] << 6) |
549 			       (data->fan_div[0] << 4) |
550 				data->fan_ctl));
551 		break;
552 	default:
553 		dev_dbg(dev, "Unknown attr fetch (%d)\n", fn);
554 	}
555 
556 EXIT:
557 	mutex_unlock(&data->update_lock);
558 	return count;
559 }
560 
561 /* ---------------------------------------------------------------------
562  * PWM sysfs interfaces
563  * ix = [0-1]
564  * --------------------------------------------------------------------- */
565 
566 #define SHOW_PWM			0
567 #define SHOW_SET_PWM_ENABLE		1
568 #define SHOW_SET_PWM_FREQ		2
569 #define SHOW_SET_PWM_AUTO_CHANNELS_TEMP	3
570 
571 static ssize_t show_pwm(struct device *dev, struct device_attribute *attr,
572 			char *buf)
573 {
574 	struct vt1211_data *data = vt1211_update_device(dev);
575 	struct sensor_device_attribute_2 *sensor_attr_2 =
576 						to_sensor_dev_attr_2(attr);
577 	int ix = sensor_attr_2->index;
578 	int fn = sensor_attr_2->nr;
579 	int res;
580 
581 	switch (fn) {
582 	case SHOW_PWM:
583 		res = data->pwm[ix];
584 		break;
585 	case SHOW_SET_PWM_ENABLE:
586 		res = ((data->pwm_ctl[ix] >> 3) & 1) ? 2 : 0;
587 		break;
588 	case SHOW_SET_PWM_FREQ:
589 		res = 90000 >> (data->pwm_clk & 7);
590 		break;
591 	case SHOW_SET_PWM_AUTO_CHANNELS_TEMP:
592 		res = (data->pwm_ctl[ix] & 7) + 1;
593 		break;
594 	default:
595 		res = 0;
596 		dev_dbg(dev, "Unknown attr fetch (%d)\n", fn);
597 	}
598 
599 	return sprintf(buf, "%d\n", res);
600 }
601 
602 static ssize_t set_pwm(struct device *dev, struct device_attribute *attr,
603 		       const char *buf, size_t count)
604 {
605 	struct vt1211_data *data = dev_get_drvdata(dev);
606 	struct sensor_device_attribute_2 *sensor_attr_2 =
607 						to_sensor_dev_attr_2(attr);
608 	int ix = sensor_attr_2->index;
609 	int fn = sensor_attr_2->nr;
610 	long val = simple_strtol(buf, NULL, 10);
611 	int tmp, reg;
612 
613 	mutex_lock(&data->update_lock);
614 
615 	switch (fn) {
616 	case SHOW_SET_PWM_ENABLE:
617 		/* sync the data cache */
618 		reg = vt1211_read8(data, VT1211_REG_FAN_DIV);
619 		data->fan_div[0] = (reg >> 4) & 3;
620 		data->fan_div[1] = (reg >> 6) & 3;
621 		data->fan_ctl = reg & 0xf;
622 		reg = vt1211_read8(data, VT1211_REG_PWM_CTL);
623 		data->pwm_ctl[0] = reg & 0xf;
624 		data->pwm_ctl[1] = (reg >> 4) & 0xf;
625 		switch (val) {
626 		case 0:
627 			data->pwm_ctl[ix] &= 7;
628 			/* disable SmartGuardian if both PWM outputs are
629 			 * disabled */
630 			if ((data->pwm_ctl[ix ^ 1] & 1) == 0) {
631 				data->fan_ctl &= 0xe;
632 			}
633 			break;
634 		case 2:
635 			data->pwm_ctl[ix] |= 8;
636 			data->fan_ctl |= 1;
637 			break;
638 		default:
639 			count = -EINVAL;
640 			dev_warn(dev, "pwm mode %ld not supported. "
641 				 "Choose one of 0 or 2.\n", val);
642 			goto EXIT;
643 		}
644 		vt1211_write8(data, VT1211_REG_PWM_CTL,
645 			      ((data->pwm_ctl[1] << 4) |
646 				data->pwm_ctl[0]));
647 		vt1211_write8(data, VT1211_REG_FAN_DIV,
648 			      ((data->fan_div[1] << 6) |
649 			       (data->fan_div[0] << 4) |
650 				data->fan_ctl));
651 		break;
652 	case SHOW_SET_PWM_FREQ:
653 		val = 135000 / SENSORS_LIMIT(val, 135000 >> 7, 135000);
654 		/* calculate tmp = log2(val) */
655 		tmp = 0;
656 		for (val >>= 1; val > 0; val >>= 1) {
657 			tmp++;
658 		}
659 		/* sync the data cache */
660 		reg = vt1211_read8(data, VT1211_REG_PWM_CLK);
661 		data->pwm_clk = (reg & 0xf8) | tmp;
662 		vt1211_write8(data, VT1211_REG_PWM_CLK, data->pwm_clk);
663 		break;
664 	case SHOW_SET_PWM_AUTO_CHANNELS_TEMP:
665 		if ((val < 1) || (val > 7)) {
666 			count = -EINVAL;
667 			dev_warn(dev, "temp channel %ld not supported. "
668 				 "Choose a value between 1 and 7.\n", val);
669 			goto EXIT;
670 		}
671 		if (!ISTEMP(val - 1, data->uch_config)) {
672 			count = -EINVAL;
673 			dev_warn(dev, "temp channel %ld is not available.\n",
674 				 val);
675 			goto EXIT;
676 		}
677 		/* sync the data cache */
678 		reg = vt1211_read8(data, VT1211_REG_PWM_CTL);
679 		data->pwm_ctl[0] = reg & 0xf;
680 		data->pwm_ctl[1] = (reg >> 4) & 0xf;
681 		data->pwm_ctl[ix] = (data->pwm_ctl[ix] & 8) | (val - 1);
682 		vt1211_write8(data, VT1211_REG_PWM_CTL,
683 			      ((data->pwm_ctl[1] << 4) | data->pwm_ctl[0]));
684 		break;
685 	default:
686 		dev_dbg(dev, "Unknown attr fetch (%d)\n", fn);
687 	}
688 
689 EXIT:
690 	mutex_unlock(&data->update_lock);
691 	return count;
692 }
693 
694 /* ---------------------------------------------------------------------
695  * PWM auto point definitions
696  * ix = [0-1]
697  * ap = [0-3]
698  * --------------------------------------------------------------------- */
699 
700 /*
701  * pwm[ix+1]_auto_point[ap+1]_temp mapping table:
702  * Note that there is only a single set of temp auto points that controls both
703  * PWM controllers. We still create 2 sets of sysfs files to make it look
704  * more consistent even though they map to the same registers.
705  *
706  * ix ap : description
707  * -------------------
708  * 0  0  : pwm1/2 off temperature        (pwm_auto_temp[0])
709  * 0  1  : pwm1/2 low speed temperature  (pwm_auto_temp[1])
710  * 0  2  : pwm1/2 high speed temperature (pwm_auto_temp[2])
711  * 0  3  : pwm1/2 full speed temperature (pwm_auto_temp[3])
712  * 1  0  : pwm1/2 off temperature        (pwm_auto_temp[0])
713  * 1  1  : pwm1/2 low speed temperature  (pwm_auto_temp[1])
714  * 1  2  : pwm1/2 high speed temperature (pwm_auto_temp[2])
715  * 1  3  : pwm1/2 full speed temperature (pwm_auto_temp[3])
716  */
717 
718 static ssize_t show_pwm_auto_point_temp(struct device *dev,
719 					struct device_attribute *attr,
720 					char *buf)
721 {
722 	struct vt1211_data *data = vt1211_update_device(dev);
723 	struct sensor_device_attribute_2 *sensor_attr_2 =
724 						to_sensor_dev_attr_2(attr);
725 	int ix = sensor_attr_2->index;
726 	int ap = sensor_attr_2->nr;
727 
728 	return sprintf(buf, "%d\n", TEMP_FROM_REG(data->pwm_ctl[ix] & 7,
729 		       data->pwm_auto_temp[ap]));
730 }
731 
732 static ssize_t set_pwm_auto_point_temp(struct device *dev,
733 				       struct device_attribute *attr,
734 				       const char *buf, size_t count)
735 {
736 	struct vt1211_data *data = dev_get_drvdata(dev);
737 	struct sensor_device_attribute_2 *sensor_attr_2 =
738 						to_sensor_dev_attr_2(attr);
739 	int ix = sensor_attr_2->index;
740 	int ap = sensor_attr_2->nr;
741 	long val = simple_strtol(buf, NULL, 10);
742 	int reg;
743 
744 	mutex_lock(&data->update_lock);
745 
746 	/* sync the data cache */
747 	reg = vt1211_read8(data, VT1211_REG_PWM_CTL);
748 	data->pwm_ctl[0] = reg & 0xf;
749 	data->pwm_ctl[1] = (reg >> 4) & 0xf;
750 
751 	data->pwm_auto_temp[ap] = TEMP_TO_REG(data->pwm_ctl[ix] & 7, val);
752 	vt1211_write8(data, VT1211_REG_PWM_AUTO_TEMP(ap),
753 		      data->pwm_auto_temp[ap]);
754 	mutex_unlock(&data->update_lock);
755 
756 	return count;
757 }
758 
759 /*
760  * pwm[ix+1]_auto_point[ap+1]_pwm mapping table:
761  * Note that the PWM auto points 0 & 3 are hard-wired in the VT1211 and can't
762  * be changed.
763  *
764  * ix ap : description
765  * -------------------
766  * 0  0  : pwm1 off                   (pwm_auto_pwm[0][0], hard-wired to 0)
767  * 0  1  : pwm1 low speed duty cycle  (pwm_auto_pwm[0][1])
768  * 0  2  : pwm1 high speed duty cycle (pwm_auto_pwm[0][2])
769  * 0  3  : pwm1 full speed            (pwm_auto_pwm[0][3], hard-wired to 255)
770  * 1  0  : pwm2 off                   (pwm_auto_pwm[1][0], hard-wired to 0)
771  * 1  1  : pwm2 low speed duty cycle  (pwm_auto_pwm[1][1])
772  * 1  2  : pwm2 high speed duty cycle (pwm_auto_pwm[1][2])
773  * 1  3  : pwm2 full speed            (pwm_auto_pwm[1][3], hard-wired to 255)
774 */
775 
776 static ssize_t show_pwm_auto_point_pwm(struct device *dev,
777 				       struct device_attribute *attr,
778 				       char *buf)
779 {
780 	struct vt1211_data *data = vt1211_update_device(dev);
781 	struct sensor_device_attribute_2 *sensor_attr_2 =
782 						to_sensor_dev_attr_2(attr);
783 	int ix = sensor_attr_2->index;
784 	int ap = sensor_attr_2->nr;
785 
786 	return sprintf(buf, "%d\n", data->pwm_auto_pwm[ix][ap]);
787 }
788 
789 static ssize_t set_pwm_auto_point_pwm(struct device *dev,
790 				      struct device_attribute *attr,
791 				      const char *buf, size_t count)
792 {
793 	struct vt1211_data *data = dev_get_drvdata(dev);
794 	struct sensor_device_attribute_2 *sensor_attr_2 =
795 						to_sensor_dev_attr_2(attr);
796 	int ix = sensor_attr_2->index;
797 	int ap = sensor_attr_2->nr;
798 	long val = simple_strtol(buf, NULL, 10);
799 
800 	if ((val < 0) || (val > 255)) {
801 		dev_err(dev, "pwm value %ld is out of range. "
802 			"Choose a value between 0 and 255.\n" , val);
803 		return -EINVAL;
804 	}
805 
806 	mutex_lock(&data->update_lock);
807 	data->pwm_auto_pwm[ix][ap] = val;
808 	vt1211_write8(data, VT1211_REG_PWM_AUTO_PWM(ix, ap),
809 		      data->pwm_auto_pwm[ix][ap]);
810 	mutex_unlock(&data->update_lock);
811 
812 	return count;
813 }
814 
815 /* ---------------------------------------------------------------------
816  * Miscellaneous sysfs interfaces (VRM, VID, name, and (legacy) alarms)
817  * --------------------------------------------------------------------- */
818 
819 static ssize_t show_vrm(struct device *dev, struct device_attribute *attr,
820 			char *buf)
821 {
822 	struct vt1211_data *data = dev_get_drvdata(dev);
823 
824 	return sprintf(buf, "%d\n", data->vrm);
825 }
826 
827 static ssize_t set_vrm(struct device *dev, struct device_attribute *attr,
828 		       const char *buf, size_t count)
829 {
830 	struct vt1211_data *data = dev_get_drvdata(dev);
831 	long val = simple_strtol(buf, NULL, 10);
832 
833 	data->vrm = val;
834 
835 	return count;
836 }
837 
838 static ssize_t show_vid(struct device *dev, struct device_attribute *attr,
839 			char *buf)
840 {
841 	struct vt1211_data *data = dev_get_drvdata(dev);
842 
843 	return sprintf(buf, "%d\n", vid_from_reg(data->vid, data->vrm));
844 }
845 
846 static ssize_t show_name(struct device *dev,
847 			 struct device_attribute *attr, char *buf)
848 {
849 	struct vt1211_data *data = dev_get_drvdata(dev);
850 
851 	return sprintf(buf, "%s\n", data->name);
852 }
853 
854 static ssize_t show_alarms(struct device *dev,
855 			   struct device_attribute *attr, char *buf)
856 {
857 	struct vt1211_data *data = vt1211_update_device(dev);
858 
859 	return sprintf(buf, "%d\n", data->alarms);
860 }
861 
862 /* ---------------------------------------------------------------------
863  * Device attribute structs
864  * --------------------------------------------------------------------- */
865 
866 #define SENSOR_ATTR_IN_INPUT(ix) \
867 	SENSOR_ATTR_2(in##ix##_input, S_IRUGO, \
868 		show_in, NULL, SHOW_IN_INPUT, ix)
869 
870 static struct sensor_device_attribute_2 vt1211_sysfs_in_input[] = {
871 	SENSOR_ATTR_IN_INPUT(0),
872 	SENSOR_ATTR_IN_INPUT(1),
873 	SENSOR_ATTR_IN_INPUT(2),
874 	SENSOR_ATTR_IN_INPUT(3),
875 	SENSOR_ATTR_IN_INPUT(4),
876 	SENSOR_ATTR_IN_INPUT(5),
877 };
878 
879 #define SENSOR_ATTR_IN_MIN(ix) \
880 	SENSOR_ATTR_2(in##ix##_min, S_IRUGO | S_IWUSR, \
881 		show_in, set_in, SHOW_SET_IN_MIN, ix)
882 
883 static struct sensor_device_attribute_2 vt1211_sysfs_in_min[] = {
884 	SENSOR_ATTR_IN_MIN(0),
885 	SENSOR_ATTR_IN_MIN(1),
886 	SENSOR_ATTR_IN_MIN(2),
887 	SENSOR_ATTR_IN_MIN(3),
888 	SENSOR_ATTR_IN_MIN(4),
889 	SENSOR_ATTR_IN_MIN(5),
890 };
891 
892 #define SENSOR_ATTR_IN_MAX(ix) \
893 	SENSOR_ATTR_2(in##ix##_max, S_IRUGO | S_IWUSR, \
894 		show_in, set_in, SHOW_SET_IN_MAX, ix)
895 
896 static struct sensor_device_attribute_2 vt1211_sysfs_in_max[] = {
897 	SENSOR_ATTR_IN_MAX(0),
898 	SENSOR_ATTR_IN_MAX(1),
899 	SENSOR_ATTR_IN_MAX(2),
900 	SENSOR_ATTR_IN_MAX(3),
901 	SENSOR_ATTR_IN_MAX(4),
902 	SENSOR_ATTR_IN_MAX(5),
903 };
904 
905 #define SENSOR_ATTR_IN_ALARM(ix) \
906 	SENSOR_ATTR_2(in##ix##_alarm, S_IRUGO, \
907 		show_in, NULL, SHOW_IN_ALARM, ix)
908 
909 static struct sensor_device_attribute_2 vt1211_sysfs_in_alarm[] = {
910 	SENSOR_ATTR_IN_ALARM(0),
911 	SENSOR_ATTR_IN_ALARM(1),
912 	SENSOR_ATTR_IN_ALARM(2),
913 	SENSOR_ATTR_IN_ALARM(3),
914 	SENSOR_ATTR_IN_ALARM(4),
915 	SENSOR_ATTR_IN_ALARM(5),
916 };
917 
918 #define SENSOR_ATTR_TEMP_INPUT(ix) \
919 	SENSOR_ATTR_2(temp##ix##_input, S_IRUGO, \
920 		show_temp, NULL, SHOW_TEMP_INPUT, ix-1)
921 
922 static struct sensor_device_attribute_2 vt1211_sysfs_temp_input[] = {
923 	SENSOR_ATTR_TEMP_INPUT(1),
924 	SENSOR_ATTR_TEMP_INPUT(2),
925 	SENSOR_ATTR_TEMP_INPUT(3),
926 	SENSOR_ATTR_TEMP_INPUT(4),
927 	SENSOR_ATTR_TEMP_INPUT(5),
928 	SENSOR_ATTR_TEMP_INPUT(6),
929 	SENSOR_ATTR_TEMP_INPUT(7),
930 };
931 
932 #define SENSOR_ATTR_TEMP_MAX(ix) \
933 	SENSOR_ATTR_2(temp##ix##_max, S_IRUGO | S_IWUSR, \
934 		show_temp, set_temp, SHOW_SET_TEMP_MAX, ix-1)
935 
936 static struct sensor_device_attribute_2 vt1211_sysfs_temp_max[] = {
937 	SENSOR_ATTR_TEMP_MAX(1),
938 	SENSOR_ATTR_TEMP_MAX(2),
939 	SENSOR_ATTR_TEMP_MAX(3),
940 	SENSOR_ATTR_TEMP_MAX(4),
941 	SENSOR_ATTR_TEMP_MAX(5),
942 	SENSOR_ATTR_TEMP_MAX(6),
943 	SENSOR_ATTR_TEMP_MAX(7),
944 };
945 
946 #define SENSOR_ATTR_TEMP_MAX_HYST(ix) \
947 	SENSOR_ATTR_2(temp##ix##_max_hyst, S_IRUGO | S_IWUSR, \
948 		show_temp, set_temp, SHOW_SET_TEMP_MAX_HYST, ix-1)
949 
950 static struct sensor_device_attribute_2 vt1211_sysfs_temp_max_hyst[] = {
951 	SENSOR_ATTR_TEMP_MAX_HYST(1),
952 	SENSOR_ATTR_TEMP_MAX_HYST(2),
953 	SENSOR_ATTR_TEMP_MAX_HYST(3),
954 	SENSOR_ATTR_TEMP_MAX_HYST(4),
955 	SENSOR_ATTR_TEMP_MAX_HYST(5),
956 	SENSOR_ATTR_TEMP_MAX_HYST(6),
957 	SENSOR_ATTR_TEMP_MAX_HYST(7),
958 };
959 
960 #define SENSOR_ATTR_TEMP_ALARM(ix) \
961 	SENSOR_ATTR_2(temp##ix##_alarm, S_IRUGO, \
962 		show_temp, NULL, SHOW_TEMP_ALARM, ix-1)
963 
964 static struct sensor_device_attribute_2 vt1211_sysfs_temp_alarm[] = {
965 	SENSOR_ATTR_TEMP_ALARM(1),
966 	SENSOR_ATTR_TEMP_ALARM(2),
967 	SENSOR_ATTR_TEMP_ALARM(3),
968 	SENSOR_ATTR_TEMP_ALARM(4),
969 	SENSOR_ATTR_TEMP_ALARM(5),
970 	SENSOR_ATTR_TEMP_ALARM(6),
971 	SENSOR_ATTR_TEMP_ALARM(7),
972 };
973 
974 #define SENSOR_ATTR_FAN(ix) \
975 	SENSOR_ATTR_2(fan##ix##_input, S_IRUGO, \
976 		show_fan, NULL, SHOW_FAN_INPUT, ix-1), \
977 	SENSOR_ATTR_2(fan##ix##_min, S_IRUGO | S_IWUSR, \
978 		show_fan, set_fan, SHOW_SET_FAN_MIN, ix-1), \
979 	SENSOR_ATTR_2(fan##ix##_div, S_IRUGO | S_IWUSR, \
980 		show_fan, set_fan, SHOW_SET_FAN_DIV, ix-1), \
981 	SENSOR_ATTR_2(fan##ix##_alarm, S_IRUGO, \
982 		show_fan, NULL, SHOW_FAN_ALARM, ix-1)
983 
984 #define SENSOR_ATTR_PWM(ix) \
985 	SENSOR_ATTR_2(pwm##ix, S_IRUGO, \
986 		show_pwm, NULL, SHOW_PWM, ix-1), \
987 	SENSOR_ATTR_2(pwm##ix##_enable, S_IRUGO | S_IWUSR, \
988 		show_pwm, set_pwm, SHOW_SET_PWM_ENABLE, ix-1), \
989 	SENSOR_ATTR_2(pwm##ix##_auto_channels_temp, S_IRUGO | S_IWUSR, \
990 		show_pwm, set_pwm, SHOW_SET_PWM_AUTO_CHANNELS_TEMP, ix-1)
991 
992 #define SENSOR_ATTR_PWM_FREQ(ix) \
993 	SENSOR_ATTR_2(pwm##ix##_freq, S_IRUGO | S_IWUSR, \
994 		show_pwm, set_pwm, SHOW_SET_PWM_FREQ, ix-1)
995 
996 #define SENSOR_ATTR_PWM_FREQ_RO(ix) \
997 	SENSOR_ATTR_2(pwm##ix##_freq, S_IRUGO, \
998 		show_pwm, NULL, SHOW_SET_PWM_FREQ, ix-1)
999 
1000 #define SENSOR_ATTR_PWM_AUTO_POINT_TEMP(ix, ap) \
1001 	SENSOR_ATTR_2(pwm##ix##_auto_point##ap##_temp, S_IRUGO | S_IWUSR, \
1002 		show_pwm_auto_point_temp, set_pwm_auto_point_temp, \
1003 		ap-1, ix-1)
1004 
1005 #define SENSOR_ATTR_PWM_AUTO_POINT_TEMP_RO(ix, ap) \
1006 	SENSOR_ATTR_2(pwm##ix##_auto_point##ap##_temp, S_IRUGO, \
1007 		show_pwm_auto_point_temp, NULL, \
1008 		ap-1, ix-1)
1009 
1010 #define SENSOR_ATTR_PWM_AUTO_POINT_PWM(ix, ap) \
1011 	SENSOR_ATTR_2(pwm##ix##_auto_point##ap##_pwm, S_IRUGO | S_IWUSR, \
1012 		show_pwm_auto_point_pwm, set_pwm_auto_point_pwm, \
1013 		ap-1, ix-1)
1014 
1015 #define SENSOR_ATTR_PWM_AUTO_POINT_PWM_RO(ix, ap) \
1016 	SENSOR_ATTR_2(pwm##ix##_auto_point##ap##_pwm, S_IRUGO, \
1017 		show_pwm_auto_point_pwm, NULL, \
1018 		ap-1, ix-1)
1019 
1020 static struct sensor_device_attribute_2 vt1211_sysfs_fan_pwm[] = {
1021 	SENSOR_ATTR_FAN(1),
1022 	SENSOR_ATTR_FAN(2),
1023 	SENSOR_ATTR_PWM(1),
1024 	SENSOR_ATTR_PWM(2),
1025 	SENSOR_ATTR_PWM_FREQ(1),
1026 	SENSOR_ATTR_PWM_FREQ_RO(2),
1027 	SENSOR_ATTR_PWM_AUTO_POINT_TEMP(1, 1),
1028 	SENSOR_ATTR_PWM_AUTO_POINT_TEMP(1, 2),
1029 	SENSOR_ATTR_PWM_AUTO_POINT_TEMP(1, 3),
1030 	SENSOR_ATTR_PWM_AUTO_POINT_TEMP(1, 4),
1031 	SENSOR_ATTR_PWM_AUTO_POINT_TEMP_RO(2, 1),
1032 	SENSOR_ATTR_PWM_AUTO_POINT_TEMP_RO(2, 2),
1033 	SENSOR_ATTR_PWM_AUTO_POINT_TEMP_RO(2, 3),
1034 	SENSOR_ATTR_PWM_AUTO_POINT_TEMP_RO(2, 4),
1035 	SENSOR_ATTR_PWM_AUTO_POINT_PWM_RO(1, 1),
1036 	SENSOR_ATTR_PWM_AUTO_POINT_PWM(1, 2),
1037 	SENSOR_ATTR_PWM_AUTO_POINT_PWM(1, 3),
1038 	SENSOR_ATTR_PWM_AUTO_POINT_PWM_RO(1, 4),
1039 	SENSOR_ATTR_PWM_AUTO_POINT_PWM_RO(2, 1),
1040 	SENSOR_ATTR_PWM_AUTO_POINT_PWM(2, 2),
1041 	SENSOR_ATTR_PWM_AUTO_POINT_PWM(2, 3),
1042 	SENSOR_ATTR_PWM_AUTO_POINT_PWM_RO(2, 4),
1043 };
1044 
1045 static struct device_attribute vt1211_sysfs_misc[] = {
1046 	__ATTR(vrm, S_IRUGO | S_IWUSR, show_vrm, set_vrm),
1047 	__ATTR(cpu0_vid, S_IRUGO, show_vid, NULL),
1048 	__ATTR(name, S_IRUGO, show_name, NULL),
1049 	__ATTR(alarms, S_IRUGO, show_alarms, NULL),
1050 };
1051 
1052 /* ---------------------------------------------------------------------
1053  * Device registration and initialization
1054  * --------------------------------------------------------------------- */
1055 
1056 static void __devinit vt1211_init_device(struct vt1211_data *data)
1057 {
1058 	/* set VRM */
1059 	data->vrm = vid_which_vrm();
1060 
1061 	/* Read (and initialize) UCH config */
1062 	data->uch_config = vt1211_read8(data, VT1211_REG_UCH_CONFIG);
1063 	if (uch_config > -1) {
1064 		data->uch_config = (data->uch_config & 0x83) |
1065 				   (uch_config << 2);
1066 		vt1211_write8(data, VT1211_REG_UCH_CONFIG, data->uch_config);
1067 	}
1068 
1069 	/* Initialize the interrupt mode (if request at module load time).
1070 	 * The VT1211 implements 3 different modes for clearing interrupts:
1071 	 * 0: Clear INT when status register is read. Regenerate INT as long
1072 	 *    as temp stays above hysteresis limit.
1073 	 * 1: Clear INT when status register is read. DON'T regenerate INT
1074 	 *    until temp falls below hysteresis limit and exceeds hot limit
1075 	 *    again.
1076 	 * 2: Clear INT when temp falls below max limit.
1077 	 *
1078 	 * The driver only allows to force mode 0 since that's the only one
1079 	 * that makes sense for 'sensors' */
1080 	if (int_mode == 0) {
1081 		vt1211_write8(data, VT1211_REG_TEMP1_CONFIG, 0);
1082 		vt1211_write8(data, VT1211_REG_TEMP2_CONFIG, 0);
1083 	}
1084 
1085 	/* Fill in some hard wired values into our data struct */
1086 	data->pwm_auto_pwm[0][3] = 255;
1087 	data->pwm_auto_pwm[1][3] = 255;
1088 }
1089 
1090 static void vt1211_remove_sysfs(struct platform_device *pdev)
1091 {
1092 	struct device *dev = &pdev->dev;
1093 	int i;
1094 
1095 	for (i = 0; i < ARRAY_SIZE(vt1211_sysfs_in_input); i++) {
1096 		device_remove_file(dev,
1097 			&vt1211_sysfs_in_input[i].dev_attr);
1098 		device_remove_file(dev,
1099 			&vt1211_sysfs_in_min[i].dev_attr);
1100 		device_remove_file(dev,
1101 			&vt1211_sysfs_in_max[i].dev_attr);
1102 		device_remove_file(dev,
1103 			&vt1211_sysfs_in_alarm[i].dev_attr);
1104 	}
1105 	for (i = 0; i < ARRAY_SIZE(vt1211_sysfs_temp_input); i++) {
1106 		device_remove_file(dev,
1107 			&vt1211_sysfs_temp_input[i].dev_attr);
1108 		device_remove_file(dev,
1109 			&vt1211_sysfs_temp_max[i].dev_attr);
1110 		device_remove_file(dev,
1111 			&vt1211_sysfs_temp_max_hyst[i].dev_attr);
1112 		device_remove_file(dev,
1113 			&vt1211_sysfs_temp_alarm[i].dev_attr);
1114 	}
1115 	for (i = 0; i < ARRAY_SIZE(vt1211_sysfs_fan_pwm); i++) {
1116 		device_remove_file(dev,
1117 			&vt1211_sysfs_fan_pwm[i].dev_attr);
1118 	}
1119 	for (i = 0; i < ARRAY_SIZE(vt1211_sysfs_misc); i++) {
1120 		device_remove_file(dev, &vt1211_sysfs_misc[i]);
1121 	}
1122 }
1123 
1124 static int __devinit vt1211_probe(struct platform_device *pdev)
1125 {
1126 	struct device *dev = &pdev->dev;
1127 	struct vt1211_data *data;
1128 	struct resource *res;
1129 	int i, err;
1130 
1131 	if (!(data = kzalloc(sizeof(struct vt1211_data), GFP_KERNEL))) {
1132 		err = -ENOMEM;
1133 		dev_err(dev, "Out of memory\n");
1134 		goto EXIT;
1135 	}
1136 
1137 	res = platform_get_resource(pdev, IORESOURCE_IO, 0);
1138 	if (!request_region(res->start, res->end - res->start + 1, DRVNAME)) {
1139 		err = -EBUSY;
1140 		dev_err(dev, "Failed to request region 0x%lx-0x%lx\n",
1141 			(unsigned long)res->start, (unsigned long)res->end);
1142 		goto EXIT_KFREE;
1143 	}
1144 	data->addr = res->start;
1145 	data->name = DRVNAME;
1146 	mutex_init(&data->update_lock);
1147 
1148 	platform_set_drvdata(pdev, data);
1149 
1150 	/* Initialize the VT1211 chip */
1151 	vt1211_init_device(data);
1152 
1153 	/* Create sysfs interface files */
1154 	for (i = 0; i < ARRAY_SIZE(vt1211_sysfs_in_input); i++) {
1155 		if (ISVOLT(i, data->uch_config)) {
1156 			if ((err = device_create_file(dev,
1157 				&vt1211_sysfs_in_input[i].dev_attr)) ||
1158 			    (err = device_create_file(dev,
1159 				&vt1211_sysfs_in_min[i].dev_attr)) ||
1160 			    (err = device_create_file(dev,
1161 				&vt1211_sysfs_in_max[i].dev_attr)) ||
1162 			    (err = device_create_file(dev,
1163 				&vt1211_sysfs_in_alarm[i].dev_attr))) {
1164 				goto EXIT_DEV_REMOVE;
1165 			}
1166 		}
1167 	}
1168 	for (i = 0; i < ARRAY_SIZE(vt1211_sysfs_temp_input); i++) {
1169 		if (ISTEMP(i, data->uch_config)) {
1170 			if ((err = device_create_file(dev,
1171 				&vt1211_sysfs_temp_input[i].dev_attr)) ||
1172 			    (err = device_create_file(dev,
1173 				&vt1211_sysfs_temp_max[i].dev_attr)) ||
1174 			    (err = device_create_file(dev,
1175 				&vt1211_sysfs_temp_max_hyst[i].dev_attr)) ||
1176 			    (err = device_create_file(dev,
1177 				&vt1211_sysfs_temp_alarm[i].dev_attr))) {
1178 				goto EXIT_DEV_REMOVE;
1179 			}
1180 		}
1181 	}
1182 	for (i = 0; i < ARRAY_SIZE(vt1211_sysfs_fan_pwm); i++) {
1183 		err = device_create_file(dev,
1184 			&vt1211_sysfs_fan_pwm[i].dev_attr);
1185 		if (err) {
1186 			goto EXIT_DEV_REMOVE;
1187 		}
1188 	}
1189 	for (i = 0; i < ARRAY_SIZE(vt1211_sysfs_misc); i++) {
1190 		err = device_create_file(dev,
1191 		       &vt1211_sysfs_misc[i]);
1192 		if (err) {
1193 			goto EXIT_DEV_REMOVE;
1194 		}
1195 	}
1196 
1197 	/* Register device */
1198 	data->hwmon_dev = hwmon_device_register(dev);
1199 	if (IS_ERR(data->hwmon_dev)) {
1200 		err = PTR_ERR(data->hwmon_dev);
1201 		dev_err(dev, "Class registration failed (%d)\n", err);
1202 		goto EXIT_DEV_REMOVE_SILENT;
1203 	}
1204 
1205 	return 0;
1206 
1207 EXIT_DEV_REMOVE:
1208 	dev_err(dev, "Sysfs interface creation failed (%d)\n", err);
1209 EXIT_DEV_REMOVE_SILENT:
1210 	vt1211_remove_sysfs(pdev);
1211 	release_region(res->start, res->end - res->start + 1);
1212 EXIT_KFREE:
1213 	platform_set_drvdata(pdev, NULL);
1214 	kfree(data);
1215 EXIT:
1216 	return err;
1217 }
1218 
1219 static int __devexit vt1211_remove(struct platform_device *pdev)
1220 {
1221 	struct vt1211_data *data = platform_get_drvdata(pdev);
1222 	struct resource *res;
1223 
1224 	hwmon_device_unregister(data->hwmon_dev);
1225 	vt1211_remove_sysfs(pdev);
1226 	platform_set_drvdata(pdev, NULL);
1227 	kfree(data);
1228 
1229 	res = platform_get_resource(pdev, IORESOURCE_IO, 0);
1230 	release_region(res->start, res->end - res->start + 1);
1231 
1232 	return 0;
1233 }
1234 
1235 static struct platform_driver vt1211_driver = {
1236 	.driver = {
1237 		.owner = THIS_MODULE,
1238 		.name  = DRVNAME,
1239 	},
1240 	.probe  = vt1211_probe,
1241 	.remove = __devexit_p(vt1211_remove),
1242 };
1243 
1244 static int __init vt1211_device_add(unsigned short address)
1245 {
1246 	struct resource res = {
1247 		.start	= address,
1248 		.end	= address + 0x7f,
1249 		.flags	= IORESOURCE_IO,
1250 	};
1251 	int err;
1252 
1253 	pdev = platform_device_alloc(DRVNAME, address);
1254 	if (!pdev) {
1255 		err = -ENOMEM;
1256 		printk(KERN_ERR DRVNAME ": Device allocation failed (%d)\n",
1257 		       err);
1258 		goto EXIT;
1259 	}
1260 
1261 	res.name = pdev->name;
1262 	err = platform_device_add_resources(pdev, &res, 1);
1263 	if (err) {
1264 		printk(KERN_ERR DRVNAME ": Device resource addition failed "
1265 		       "(%d)\n", err);
1266 		goto EXIT_DEV_PUT;
1267 	}
1268 
1269 	err = platform_device_add(pdev);
1270 	if (err) {
1271 		printk(KERN_ERR DRVNAME ": Device addition failed (%d)\n",
1272 		       err);
1273 		goto EXIT_DEV_PUT;
1274 	}
1275 
1276 	return 0;
1277 
1278 EXIT_DEV_PUT:
1279 	platform_device_put(pdev);
1280 EXIT:
1281 	return err;
1282 }
1283 
1284 static int __init vt1211_find(int sio_cip, unsigned short *address)
1285 {
1286 	int err = -ENODEV;
1287 	int devid;
1288 
1289 	superio_enter(sio_cip);
1290 
1291 	devid = force_id ? force_id : superio_inb(sio_cip, SIO_VT1211_DEVID);
1292 	if (devid != SIO_VT1211_ID) {
1293 		goto EXIT;
1294 	}
1295 
1296 	superio_select(sio_cip, SIO_VT1211_LDN_HWMON);
1297 
1298 	if ((superio_inb(sio_cip, SIO_VT1211_ACTIVE) & 1) == 0) {
1299 		printk(KERN_WARNING DRVNAME ": HW monitor is disabled, "
1300 		       "skipping\n");
1301 		goto EXIT;
1302 	}
1303 
1304 	*address = ((superio_inb(sio_cip, SIO_VT1211_BADDR) << 8) |
1305 		    (superio_inb(sio_cip, SIO_VT1211_BADDR + 1))) & 0xff00;
1306 	if (*address == 0) {
1307 		printk(KERN_WARNING DRVNAME ": Base address is not set, "
1308 		       "skipping\n");
1309 		goto EXIT;
1310 	}
1311 
1312 	err = 0;
1313 	printk(KERN_INFO DRVNAME ": Found VT1211 chip at 0x%04x, "
1314 	       "revision %u\n", *address,
1315 	       superio_inb(sio_cip, SIO_VT1211_DEVREV));
1316 
1317 EXIT:
1318 	superio_exit(sio_cip);
1319 	return err;
1320 }
1321 
1322 static int __init vt1211_init(void)
1323 {
1324 	int err;
1325 	unsigned short address = 0;
1326 
1327 	if ((err = vt1211_find(SIO_REG_CIP1, &address)) &&
1328 	    (err = vt1211_find(SIO_REG_CIP2, &address))) {
1329 		goto EXIT;
1330 	}
1331 
1332 	if ((uch_config < -1) || (uch_config > 31)) {
1333 		err = -EINVAL;
1334 		printk(KERN_WARNING DRVNAME ": Invalid UCH configuration %d. "
1335 		       "Choose a value between 0 and 31.\n", uch_config);
1336 	  goto EXIT;
1337 	}
1338 
1339 	if ((int_mode < -1) || (int_mode > 0)) {
1340 		err = -EINVAL;
1341 		printk(KERN_WARNING DRVNAME ": Invalid interrupt mode %d. "
1342 		       "Only mode 0 is supported.\n", int_mode);
1343 	  goto EXIT;
1344 	}
1345 
1346 	err = platform_driver_register(&vt1211_driver);
1347 	if (err) {
1348 		goto EXIT;
1349 	}
1350 
1351 	/* Sets global pdev as a side effect */
1352 	err = vt1211_device_add(address);
1353 	if (err) {
1354 		goto EXIT_DRV_UNREGISTER;
1355 	}
1356 
1357 	return 0;
1358 
1359 EXIT_DRV_UNREGISTER:
1360 	platform_driver_unregister(&vt1211_driver);
1361 EXIT:
1362 	return err;
1363 }
1364 
1365 static void __exit vt1211_exit(void)
1366 {
1367 	platform_device_unregister(pdev);
1368 	platform_driver_unregister(&vt1211_driver);
1369 }
1370 
1371 MODULE_AUTHOR("Juerg Haefliger <juergh@gmail.com>");
1372 MODULE_DESCRIPTION("VT1211 sensors");
1373 MODULE_LICENSE("GPL");
1374 
1375 module_init(vt1211_init);
1376 module_exit(vt1211_exit);
1377