root/lm-sensors/trunk/kernel/chips/lm85.c @ 2933

Revision 2933, 64.3 KB (checked in by khali, 10 years ago)

Change the ADT7463 identification rules. Patch by Philip Pokorny.

  • Property svn:eol-style set to native
  • Property svn:keywords set to Author Date Id Revision
Line 
1/*
2    lm85.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) 2002, 2003  Philip Pokorny <ppokorny@penguincomputing.com>
6    Copyright (c) 2003        Margit Schubert-While <margitsw@t-online.de>
7
8    This program is free software; you can redistribute it and/or modify
9    it under the terms of the GNU General Public License as published by
10    the Free Software Foundation; either version 2 of the License, or
11    (at your option) any later version.
12
13    This program is distributed in the hope that it will be useful,
14    but WITHOUT ANY WARRANTY; without even the implied warranty of
15    MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
16    GNU General Public License for more details.
17
18    You should have received a copy of the GNU General Public License
19    along with this program; if not, write to the Free Software
20    Foundation, Inc., 675 Mass Ave, Cambridge, MA 02139, USA.
21
22    CHANGELOG
23
24    2002-11-13   First patch for LM85 functionality
25    2002-11-18   LM85 functionality mostly done
26    2002-12-02   Adding ADM1027 functionality
27    2002-12-06   Adding ADT7463 functionality
28    2003-01-09   Code cleanup.
29                 Save reserved bits in case they are implemented
30                    in a future chip.  (Solve problem with lockups
31                    on ADM1027 due to chip initialization)
32                 Added chip initialization bypass option
33    2003-02-12   Add THERM asserted counts for ADT7463
34                 Added #ifdef so we can compile against 2.6.5
35                    without updating i2c-ids.h
36    2003-02-17   Prepare for switch to 2.7.0 development
37                 Implement tmin_control for ADT7463
38                 Expose THERM asserted counts to /proc
39                 Code cleanup
40    2003-02-19   Working with Margit and LM_SENSORS developers
41    2003-02-23   Removed chip initialization entirely
42                 Scale voltages in driver at Margit's request
43                 Change PWM from 0-100% to 0-255 per LM sensors standard
44    2003-02-27   Documentation and code cleanups
45                 Added this CHANGELOG
46                 Print additional precision for temperatures and voltages
47                 Many thanks to Margit Schubert-While and Brandt xxxxxx
48                    for help testing this version
49    2003-02-28   More diagnostic messages regarding BIOS setup
50    2003-03-01   Added Interrupt mask register support.
51    2003-03-08   Fixed problem with pseudo 16-bit registers
52                 Cleaned up some compiler warnings.
53                 Fixed problem with Operating Point and THERM counting
54    2003-03-21   Initial support for EMC6D100 and EMC6D101 chips
55    2003-06-30   Add support for EMC6D100 extra voltage inputs.
56*/
57
58#include <linux/module.h>
59#include <linux/slab.h>
60#include <linux/i2c.h>
61#include <linux/i2c-proc.h>
62#include <linux/init.h>
63#include "version.h"
64#include "sensors_vid.h"
65
66#ifndef I2C_DRIVERID_LM85
67#define I2C_DRIVERID_LM85  1039
68#endif
69
70/* Addresses to scan */
71static unsigned short normal_i2c[] = { 0x2c, 0x2d, 0x2e, SENSORS_I2C_END };
72static unsigned short normal_i2c_range[] = { SENSORS_I2C_END };
73static unsigned int normal_isa[] = { SENSORS_ISA_END };
74static unsigned int normal_isa_range[] = { SENSORS_ISA_END };
75
76/* Insmod parameters */
77SENSORS_INSMOD_5(lm85b, lm85c, adm1027, adt7463, emc6d100);
78
79/* Many LM85 constants specified below */
80
81/* The LM85 registers */
82#define LM85_REG_IN(nr) (0x20 + (nr))
83#define LM85_REG_IN_MIN(nr) (0x44 + (nr) * 2)
84#define LM85_REG_IN_MAX(nr) (0x45 + (nr) * 2)
85
86#define LM85_REG_TEMP(nr) (0x25 + (nr))
87#define LM85_REG_TEMP_MIN(nr) (0x4e + (nr) * 2)
88#define LM85_REG_TEMP_MAX(nr) (0x4f + (nr) * 2)
89
90/* Fan speeds are LSB, MSB (2 bytes) */
91#define LM85_REG_FAN(nr) (0x28 + (nr) *2)
92#define LM85_REG_FAN_MIN(nr) (0x54 + (nr) *2)
93
94#define LM85_REG_PWM(nr) (0x30 + (nr))
95
96#define ADT7463_REG_OPPOINT(nr) (0x33 + (nr))
97
98#define ADT7463_REG_TMIN_CTL1 0x36
99#define ADT7463_REG_TMIN_CTL2 0x37
100#define ADT7463_REG_TMIN_CTL  0x0136
101
102#define LM85_REG_DEVICE 0x3d
103#define LM85_REG_COMPANY 0x3e
104#define LM85_REG_VERSTEP 0x3f
105/* These are the recognized values for the above regs */
106#define LM85_DEVICE_ADX 0x27
107#define LM85_COMPANY_NATIONAL 0x01
108#define LM85_COMPANY_ANALOG_DEV 0x41
109#define LM85_COMPANY_SMSC 0x5c
110#define LM85_VERSTEP_VMASK 0xf0
111#define LM85_VERSTEP_SMASK 0x0f
112#define LM85_VERSTEP_GENERIC 0x60
113#define LM85_VERSTEP_LM85C 0x60
114#define LM85_VERSTEP_LM85B 0x62
115#define LM85_VERSTEP_ADM1027 0x60
116#define LM85_VERSTEP_ADT7463 0x62
117#define LM85_VERSTEP_ADT7463C 0x6A
118#define LM85_VERSTEP_EMC6D100_A0 0x60
119#define LM85_VERSTEP_EMC6D100_A1 0x61
120
121#define LM85_REG_CONFIG 0x40
122
123#define LM85_REG_ALARM1 0x41
124#define LM85_REG_ALARM2 0x42
125#define LM85_REG_ALARM  0x0141
126
127#define LM85_REG_VID 0x43
128
129/* Automated FAN control */
130#define LM85_REG_AFAN_CONFIG(nr) (0x5c + (nr))
131#define LM85_REG_AFAN_RANGE(nr) (0x5f + (nr))
132#define LM85_REG_AFAN_SPIKE1 0x62
133#define LM85_REG_AFAN_SPIKE2 0x63
134#define LM85_REG_AFAN_MINPWM(nr) (0x64 + (nr))
135#define LM85_REG_AFAN_LIMIT(nr) (0x67 + (nr))
136#define LM85_REG_AFAN_CRITICAL(nr) (0x6a + (nr))
137#define LM85_REG_AFAN_HYST1 0x6d
138#define LM85_REG_AFAN_HYST2 0x6e
139
140#define LM85_REG_TACH_MODE 0x74
141#define LM85_REG_SPINUP_CTL 0x75
142
143#define ADM1027_REG_TEMP_OFFSET(nr) (0x70 + (nr))
144#define ADM1027_REG_CONFIG2 0x73
145#define ADM1027_REG_INTMASK1 0x74
146#define ADM1027_REG_INTMASK2 0x75
147#define ADM1027_REG_INTMASK  0x0174
148#define ADM1027_REG_EXTEND_ADC1 0x76
149#define ADM1027_REG_EXTEND_ADC2 0x77
150#define ADM1027_REG_EXTEND_ADC  0x0176
151#define ADM1027_REG_CONFIG3 0x78
152#define ADM1027_REG_FAN_PPR 0x7b
153
154#define ADT7463_REG_THERM 0x79
155#define ADT7463_REG_THERM_LIMIT 0x7A
156#define ADT7463_REG_CONFIG4 0x7D
157
158#define EMC6D100_REG_SFR  0x7c
159#define EMC6D100_REG_ALARM3  0x7d
160#define EMC6D100_REG_CONF  0x7f
161#define EMC6D100_REG_INT_EN  0x80
162/* IN5, IN6 and IN7 */
163#define EMC6D100_REG_IN(nr)  (0x70 + ((nr)-5))
164#define EMC6D100_REG_IN_MIN(nr) (0x73 + ((nr)-5) * 2)
165#define EMC6D100_REG_IN_MAX(nr) (0x74 + ((nr)-5) * 2)
166
167/* Conversions. Rounding and limit checking is only done on the TO_REG
168   variants. Note that you should be a bit careful with which arguments
169   these macros are called: arguments may be evaluated more than once.
170 */
171
172/* IN are scaled 1.000 == 0xc0, mag = 3 */
173#define IN_TO_REG(val)  (SENSORS_LIMIT((((val)*0xc0+500)/1000),0,255))
174#define INEXT_FROM_REG(val,ext) (((val)*1000 + (ext)*250 + 96)/0xc0)
175#define IN_FROM_REG(val) (INEXT_FROM_REG(val,0))
176
177/* IN are scaled acording to built-in resistors */
178static int lm85_scaling[] = {  /* .001 Volts */
179                2500, 2250, 3300, 5000, 12000,
180                3300, 1500, 1800,       /* EMC6D100 */
181        };
182#define SCALE(val,from,to) (((val)*(to) + ((from)/2))/(from))
183#define INS_TO_REG(n,val)  (SENSORS_LIMIT(SCALE(val,lm85_scaling[n],192),0,255))
184#define INSEXT_FROM_REG(n,val,ext) (SCALE((val)*4 + (ext),192*4,lm85_scaling[n]))
185#define INS_FROM_REG(n,val) (INSEXT_FROM_REG(n,val,0))
186
187/* FAN speed is measured using 90kHz clock */
188#define FAN_TO_REG(val)  (SENSORS_LIMIT( (val)<=0?0: 5400000/(val),0,65534))
189#define FAN_FROM_REG(val) ((val)==0?-1:(val)==0xffff?0:5400000/(val))
190
191/* Temperature is reported in .01 degC increments */
192#define TEMP_TO_REG(val) (SENSORS_LIMIT(((val)+50)/100,-127,127))
193#define TEMPEXT_FROM_REG(val,ext) ((val)*100 + (ext)*25)
194#define TEMP_FROM_REG(val) (TEMPEXT_FROM_REG(val,0))
195#define EXTTEMP_TO_REG(val) (SENSORS_LIMIT((val)/25,-127,127))
196#define OPPOINT_TO_REG(val) (SENSORS_LIMIT(val,-127,127))
197#define OPPOINT_FROM_REG(val) (val)
198
199#define PWM_TO_REG(val) (SENSORS_LIMIT(val,0,255))
200#define PWM_FROM_REG(val) (val)
201
202#define EXT_FROM_REG(val,sensor) (((val)>>(sensor * 2))&0x03)
203
204/* ZONEs have the following parameters:
205 *    Limit (low) temp,           1. degC
206 *    Hysteresis (below limit),   1. degC (0-15)
207 *    Range of speed control,     .1 degC (2-80)
208 *    Critical (high) temp,       1. degC
209 *
210 * FAN PWMs have the following parameters:
211 *    Reference Zone,                 1, 2, 3, etc.
212 *    Spinup time,                    .05 sec
213 *    PWM value at limit/low temp,    1 count
214 *    PWM Frequency,                  1. Hz
215 *    PWM is Min or OFF below limit,  flag
216 *    Invert PWM output,              flag
217 *
218 * Some chips filter the temp, others the fan.
219 *    Filter constant (or disabled)   .1 seconds
220 */
221
222/* These are the zone temperature range encodings */
223static int lm85_range_map[] = {   /* .1 degC */
224                 20,  25,  33,  40,  50,  66,
225                 80, 100, 133, 160, 200, 266,
226                320, 400, 533, 800
227        };
228static int RANGE_TO_REG( int range )
229{
230        int i;
231
232        if( range >= lm85_range_map[15] ) { return 15 ; }
233        for( i = 0 ; i < 15 ; ++i )
234                if( range <= lm85_range_map[i] )
235                        break ;
236        return( i & 0x0f );
237}
238#define RANGE_FROM_REG(val) (lm85_range_map[(val)&0x0f])
239
240/* These are the Acoustic Enhancement, or Temperature smoothing encodings
241 * NOTE: The enable/disable bit is INCLUDED in these encodings as the
242 *       MSB (bit 3, value 8).  If the enable bit is 0, the encoded value
243 *       is ignored, or set to 0.
244 */
245static int lm85_smooth_map[] = {  /* .1 sec */
246                350, 176, 118,  70,  44,   30,   16,    8
247/*    35.4 *    1/1, 1/2, 1/3, 1/5, 1/8, 1/12, 1/24, 1/48  */
248        };
249static int SMOOTH_TO_REG( int smooth )
250{
251        int i;
252
253        if( smooth <= 0 ) { return 0 ; }  /* Disabled */
254        for( i = 0 ; i < 7 ; ++i )
255                if( smooth >= lm85_smooth_map[i] )
256                        break ;
257        return( (i & 0x07) | 0x08 );
258}
259#define SMOOTH_FROM_REG(val) ((val)&0x08?lm85_smooth_map[(val)&0x07]:0)
260
261/* These are the fan spinup delay time encodings */
262static int lm85_spinup_map[] = {  /* .1 sec */
263                0, 1, 2, 4, 7, 10, 20, 40
264        };
265static int SPINUP_TO_REG( int spinup )
266{
267        int i;
268
269        if( spinup >= lm85_spinup_map[7] ) { return 7 ; }
270        for( i = 0 ; i < 7 ; ++i )
271                if( spinup <= lm85_spinup_map[i] )
272                        break ;
273        return( i & 0x07 );
274}
275#define SPINUP_FROM_REG(val) (lm85_spinup_map[(val)&0x07])
276
277/* These are the PWM frequency encodings */
278static int lm85_freq_map[] = { /* .1 Hz */
279                100, 150, 230, 300, 380, 470, 620, 980
280        };
281static int FREQ_TO_REG( int freq )
282{
283        int i;
284
285        if( freq >= lm85_freq_map[7] ) { return 7 ; }
286        for( i = 0 ; i < 7 ; ++i )
287                if( freq <= lm85_freq_map[i] )
288                        break ;
289        return( i & 0x07 );
290}
291#define FREQ_FROM_REG(val) (lm85_freq_map[(val)&0x07])
292
293/* Since we can't use strings, I'm abusing these numbers
294 *   to stand in for the following meanings:
295 *      1 -- PWM responds to Zone 1
296 *      2 -- PWM responds to Zone 2
297 *      3 -- PWM responds to Zone 3
298 *     23 -- PWM responds to the higher temp of Zone 2 or 3
299 *    123 -- PWM responds to highest of Zone 1, 2, or 3
300 *      0 -- PWM is always at 0% (ie, off)
301 *     -1 -- PWM is always at 100%
302 *     -2 -- PWM responds to manual control
303 */
304static int lm85_zone_map[] = { 1, 2, 3, -1, 0, 23, 123, -2 };
305static int ZONE_TO_REG( int zone )
306{
307        int i;
308
309        for( i = 0 ; i <= 7 ; ++i )
310                if( zone == lm85_zone_map[i] )
311                        break ;
312        if( i > 7 )   /* Not found. */
313                i = 3;  /* Always 100% */
314        return( (i & 0x07)<<5 );
315}
316#define ZONE_FROM_REG(val) (lm85_zone_map[((val)>>5)&0x07])
317
318#define HYST_TO_REG(val) (SENSORS_LIMIT((-(val)+5)/10,0,15))
319#define HYST_FROM_REG(val) (-(val)*10)
320
321#define OFFSET_TO_REG(val) (SENSORS_LIMIT((val)/25,-127,127))
322#define OFFSET_FROM_REG(val) ((val)*25)
323
324#define PPR_MASK(fan) (0x03<<(fan *2))
325#define PPR_TO_REG(val,fan) (SENSORS_LIMIT((val)-1,0,3)<<(fan *2))
326#define PPR_FROM_REG(val,fan) ((((val)>>(fan * 2))&0x03)+1)
327
328/* sensors_vid.h defines vid_from_reg() */
329#define VID_FROM_REG(val,vrm) (vid_from_reg((val),(vrm)))
330
331#define ALARMS_FROM_REG(val) (val)
332
333/* When converting to REG, we need to fixup the carry-over bit */
334#define INTMASK_FROM_REG(val) (val)
335#define INTMASK_TO_REG(val) (SENSORS_LIMIT((val)|((val)&0xff00?0x80:0),0,65535))
336
337/* Unlike some other drivers we DO NOT set initial limits.  Use
338 * the config file to set limits.  Some users have reported
339 * motherboards shutting down when we set limits in a previous
340 * version of this driver.  This may be caused by APM/ACPI
341 * detecting an out-of-limit condition when we had the wrong
342 * limits set.
343 */
344
345/* Typically used with Pentium 4 systems v9.1 VRM spec */
346#define LM85_INIT_VRM  91
347
348/* Chip sampling rates
349 *
350 * Some sensors are not updated more frequently than once per second
351 *    so it doesn't make sense to read them more often than that.
352 *    We cache the results and return the saved data if the driver
353 *    is called again before a second has elapsed.
354 *
355 * Also, there is significant configuration data for this chip
356 *    given the automatic PWM fan control that is possible.  There
357 *    are about 47 bytes of config data to only 22 bytes of actual
358 *    readings.  So, we keep the config data up to date in the cache
359 *    when it is written and only sample it once every 5 *minutes*
360 */
361#define LM85_DATA_INTERVAL  (1 * HZ)
362#define LM85_CONFIG_INTERVAL  (5 * 60 * HZ)
363
364/* For each registered LM85, we need to keep some data in memory. That
365   data is pointed to by client->data. The structure itself is
366   dynamically allocated, when a new lm85 client is allocated. */
367
368/* LM85 can automatically adjust fan speeds based on temperature
369 * This structure encapsulates an entire Zone config.  There are
370 * three zones (one for each temperature input) on the lm85
371 */
372struct lm85_zone {
373        s8 limit;       /* Low temp limit */
374        u8 hyst;        /* Low limit hysteresis. (0-15) */
375        u8 range;       /* Temp range, encoded */
376        s8 critical;    /* "All fans ON" temp limit */
377};
378
379struct lm85_autofan {
380        u8 config;      /* Register value */
381        u8 freq;        /* PWM frequency, encoded */
382        u8 min_pwm;     /* Minimum PWM value, encoded */
383        u8 min_off;     /* Min PWM or OFF below "limit", flag */
384};
385
386struct lm85_data {
387        struct i2c_client client;
388        struct semaphore lock;
389        int sysctl_id;
390        enum chips type;
391
392        struct semaphore update_lock;
393        int valid;              /* !=0 if following fields are valid */
394        unsigned long last_reading;     /* In jiffies */
395        unsigned long last_config;      /* In jiffies */
396
397        u8 in[8];               /* Register value */
398        u8 in_max[8];           /* Register value */
399        u8 in_min[8];           /* Register value */
400        s8 temp[3];             /* Register value */
401        s8 temp_min[3];         /* Register value */
402        s8 temp_max[3];         /* Register value */
403        s8 temp_offset[3];      /* Register value */
404        u16 fan[4];             /* Register value */
405        u16 fan_min[4];         /* Register value */
406        u8 pwm[3];              /* Register value */
407        u8 spinup_ctl;          /* Register encoding, combined */
408        u8 tach_mode;           /* Register encoding, combined */
409        u16 extend_adc;         /* Register value */
410        u8 fan_ppr;             /* Register value */
411        u8 smooth[3];           /* Register encoding */
412        u8 vid;                 /* Register value */
413        u8 vrm;                 /* VRM version */
414        u8 syncpwm3;            /* Saved PWM3 for TACH 2,3,4 config */
415        s8 oppoint[3];          /* Register value */
416        u16 tmin_ctl;           /* Register value */
417        long therm_total;       /* Cummulative therm count */
418        long therm_ovfl;        /* Count of therm overflows */
419        u8 therm_limit;         /* Register value */
420        u32 alarms;             /* Register encoding, combined */
421        u32 alarm_mask;         /* Register encoding, combined */
422        struct lm85_autofan autofan[3];
423        struct lm85_zone zone[3];
424};
425
426static int lm85_attach_adapter(struct i2c_adapter *adapter);
427static int lm85_detect(struct i2c_adapter *adapter, int address,
428                        unsigned short flags, int kind);
429static int lm85_detach_client(struct i2c_client *client);
430static int lm85_read_value(struct i2c_client *client, u16 register);
431static int lm85_write_value(struct i2c_client *client, u16 register, int value);
432static void lm85_update_client(struct i2c_client *client);
433static void lm85_init_client(struct i2c_client *client);
434
435
436static void lm85_in(struct i2c_client *client, int operation, int ctl_name,
437                        int *nrels_mag, long *results);
438static void lm85_fan(struct i2c_client *client, int operation,
439                        int ctl_name, int *nrels_mag, long *results);
440static void lm85_temp(struct i2c_client *client, int operation,
441                        int ctl_name, int *nrels_mag, long *results);
442static void lm85_vid(struct i2c_client *client, int operation,
443                        int ctl_name, int *nrels_mag, long *results);
444static void lm85_vrm(struct i2c_client *client, int operation,
445                        int ctl_name, int *nrels_mag, long *results);
446static void lm85_alarms(struct i2c_client *client, int operation,
447                        int ctl_name, int *nrels_mag, long *results);
448static void lm85_pwm(struct i2c_client *client, int operation,
449                        int ctl_name, int *nrels_mag, long *results);
450static void lm85_zone(struct i2c_client *client, int operation,
451                        int ctl_name, int *nrels_mag, long *results);
452static void lm85_pwm_config(struct i2c_client *client, int operation,
453                        int ctl_name, int *nrels_mag, long *results);
454static void lm85_pwm_zone(struct i2c_client *client, int operation,
455                        int ctl_name, int *nrels_mag, long *results);
456static void lm85_smooth(struct i2c_client *client, int operation,
457                        int ctl_name, int *nrels_mag, long *results);
458
459static void lm85_spinup_ctl(struct i2c_client *client, int operation,
460                        int ctl_name, int *nrels_mag, long *results);
461static void lm85_tach_mode(struct i2c_client *client, int operation,
462                        int ctl_name, int *nrels_mag, long *results);
463
464static void adm1027_tach_mode(struct i2c_client *client, int operation,
465                        int ctl_name, int *nrels_mag, long *results);
466static void adm1027_temp_offset(struct i2c_client *client, int operation,
467                        int ctl_name, int *nrels_mag, long *results);
468static void adm1027_fan_ppr(struct i2c_client *client, int operation,
469                        int ctl_name, int *nrels_mag, long *results);
470static void adm1027_alarm_mask(struct i2c_client *client, int operation,
471                        int ctl_name, int *nrels_mag, long *results);
472
473static void adt7463_tmin_ctl(struct i2c_client *client, int operation,
474                        int ctl_name, int *nrels_mag, long *results);
475static void adt7463_therm_signal(struct i2c_client *client, int operation,
476                        int ctl_name, int *nrels_mag, long *results);
477
478static void emc6d100_in(struct i2c_client *client, int operation,
479                        int ctl_name, int *nrels_mag, long *results);
480
481static struct i2c_driver lm85_driver = {
482        .name           =  "LM85 compatible sensor driver",
483        .id             = I2C_DRIVERID_LM85,
484        .flags          = I2C_DF_NOTIFY,
485        .attach_adapter = &lm85_attach_adapter,
486        .detach_client  = &lm85_detach_client,
487};
488
489/* Unique ID assigned to each LM85 detected */
490static int lm85_id = 0;
491
492/* -- SENSORS SYSCTL START -- */
493/* Common parameters */
494#define LM85_SYSCTL_IN0                1000
495#define LM85_SYSCTL_IN1                1001
496#define LM85_SYSCTL_IN2                1002
497#define LM85_SYSCTL_IN3                1003
498#define LM85_SYSCTL_IN4                1004
499#define LM85_SYSCTL_FAN1               1005
500#define LM85_SYSCTL_FAN2               1006
501#define LM85_SYSCTL_FAN3               1007
502#define LM85_SYSCTL_FAN4               1008
503#define LM85_SYSCTL_TEMP1              1009
504#define LM85_SYSCTL_TEMP2              1010
505#define LM85_SYSCTL_TEMP3              1011
506#define LM85_SYSCTL_VID                1012
507#define LM85_SYSCTL_ALARMS             1013
508#define LM85_SYSCTL_PWM1               1014
509#define LM85_SYSCTL_PWM2               1015
510#define LM85_SYSCTL_PWM3               1016
511#define LM85_SYSCTL_VRM                1017
512#define LM85_SYSCTL_PWM_CFG1           1019
513#define LM85_SYSCTL_PWM_CFG2           1020
514#define LM85_SYSCTL_PWM_CFG3           1021
515#define LM85_SYSCTL_PWM_ZONE1          1022
516#define LM85_SYSCTL_PWM_ZONE2          1023
517#define LM85_SYSCTL_PWM_ZONE3          1024
518#define LM85_SYSCTL_ZONE1              1025
519#define LM85_SYSCTL_ZONE2              1026
520#define LM85_SYSCTL_ZONE3              1027
521#define LM85_SYSCTL_SMOOTH1            1028
522#define LM85_SYSCTL_SMOOTH2            1029
523#define LM85_SYSCTL_SMOOTH3            1030
524
525/* Vendor specific values */
526#define LM85_SYSCTL_SPINUP_CTL         1100
527#define LM85_SYSCTL_TACH_MODE          1101
528
529/* Analog Devices variant of the LM85 */
530#define ADM1027_SYSCTL_TACH_MODE       1200
531#define ADM1027_SYSCTL_TEMP_OFFSET1    1201
532#define ADM1027_SYSCTL_TEMP_OFFSET2    1202
533#define ADM1027_SYSCTL_TEMP_OFFSET3    1203
534#define ADM1027_SYSCTL_FAN_PPR         1204
535#define ADM1027_SYSCTL_ALARM_MASK      1205
536
537/* Analog Devices variant of the LM85/ADM1027 */
538#define ADT7463_SYSCTL_TMIN_CTL1       1300
539#define ADT7463_SYSCTL_TMIN_CTL2       1301
540#define ADT7463_SYSCTL_TMIN_CTL3       1302
541#define ADT7463_SYSCTL_THERM_SIGNAL    1303
542
543/* SMSC variant of the LM85 */
544#define EMC6D100_SYSCTL_IN5            1400
545#define EMC6D100_SYSCTL_IN6            1401
546#define EMC6D100_SYSCTL_IN7            1402
547
548#define LM85_ALARM_IN0          0x0001
549#define LM85_ALARM_IN1          0x0002
550#define LM85_ALARM_IN2          0x0004
551#define LM85_ALARM_IN3          0x0008
552#define LM85_ALARM_TEMP1        0x0010
553#define LM85_ALARM_TEMP2        0x0020
554#define LM85_ALARM_TEMP3        0x0040
555#define LM85_ALARM_ALARM2       0x0080
556#define LM85_ALARM_IN4          0x0100
557#define LM85_ALARM_RESERVED     0x0200
558#define LM85_ALARM_FAN1         0x0400
559#define LM85_ALARM_FAN2         0x0800
560#define LM85_ALARM_FAN3         0x1000
561#define LM85_ALARM_FAN4         0x2000
562#define LM85_ALARM_TEMP1_FAULT  0x4000
563#define LM85_ALARM_TEMP3_FAULT 0x08000
564#define LM85_ALARM_IN6         0x10000
565#define LM85_ALARM_IN7         0x20000
566#define LM85_ALARM_IN5         0x40000
567/* -- SENSORS SYSCTL END -- */
568
569/* The /proc/sys entries */
570/* These files are created for each detected LM85. This is just a template;
571 *    The actual list is built from this and additional per-chip
572 *    custom lists below.  Note the XXX_LEN macros.  These must be
573 *    compile time constants because they will be used to allocate
574 *    space for the final template passed to i2c_register_entry.
575 *    We depend on the ability of GCC to evaluate expressions at
576 *    compile time to turn these expressions into compile time
577 *    constants, but this can generate a warning.
578 */
579static ctl_table lm85_common[] = {
580        {LM85_SYSCTL_IN0, "in0", NULL, 0, 0644, NULL, &i2c_proc_real,
581                &i2c_sysctl_real, NULL, &lm85_in},
582        {LM85_SYSCTL_IN1, "in1", NULL, 0, 0644, NULL, &i2c_proc_real,
583                &i2c_sysctl_real, NULL, &lm85_in},
584        {LM85_SYSCTL_IN2, "in2", NULL, 0, 0644, NULL, &i2c_proc_real,
585                &i2c_sysctl_real, NULL, &lm85_in},
586        {LM85_SYSCTL_IN3, "in3", NULL, 0, 0644, NULL, &i2c_proc_real,
587                &i2c_sysctl_real, NULL, &lm85_in},
588        {LM85_SYSCTL_IN4, "in4", NULL, 0, 0644, NULL, &i2c_proc_real,
589                &i2c_sysctl_real, NULL, &lm85_in},
590        {LM85_SYSCTL_FAN1, "fan1", NULL, 0, 0644, NULL, &i2c_proc_real,
591                &i2c_sysctl_real, NULL, &lm85_fan},
592        {LM85_SYSCTL_FAN2, "fan2", NULL, 0, 0644, NULL, &i2c_proc_real,
593                &i2c_sysctl_real, NULL, &lm85_fan},
594        {LM85_SYSCTL_FAN3, "fan3", NULL, 0, 0644, NULL, &i2c_proc_real,
595                &i2c_sysctl_real, NULL, &lm85_fan},
596        {LM85_SYSCTL_FAN4, "fan4", NULL, 0, 0644, NULL, &i2c_proc_real,
597                &i2c_sysctl_real, NULL, &lm85_fan},
598        {LM85_SYSCTL_TEMP1, "temp1", NULL, 0, 0644, NULL, &i2c_proc_real,
599                &i2c_sysctl_real, NULL, &lm85_temp},
600        {LM85_SYSCTL_TEMP2, "temp2", NULL, 0, 0644, NULL, &i2c_proc_real,
601                &i2c_sysctl_real, NULL, &lm85_temp},
602        {LM85_SYSCTL_TEMP3, "temp3", NULL, 0, 0644, NULL, &i2c_proc_real,
603                &i2c_sysctl_real, NULL, &lm85_temp},
604        {LM85_SYSCTL_VID, "vid", NULL, 0, 0444, NULL, &i2c_proc_real,
605                &i2c_sysctl_real, NULL, &lm85_vid},
606        {LM85_SYSCTL_VRM, "vrm", NULL, 0, 0644, NULL, &i2c_proc_real,
607                &i2c_sysctl_real, NULL, &lm85_vrm},
608        {LM85_SYSCTL_ALARMS, "alarms", NULL, 0, 0444, NULL, &i2c_proc_real,
609                &i2c_sysctl_real, NULL, &lm85_alarms},
610        {LM85_SYSCTL_PWM1, "pwm1", NULL, 0, 0644, NULL, &i2c_proc_real,
611                &i2c_sysctl_real, NULL, &lm85_pwm},
612        {LM85_SYSCTL_PWM2, "pwm2", NULL, 0, 0644, NULL, &i2c_proc_real,
613                &i2c_sysctl_real, NULL, &lm85_pwm},
614        {LM85_SYSCTL_PWM3, "pwm3", NULL, 0, 0644, NULL, &i2c_proc_real,
615                &i2c_sysctl_real, NULL, &lm85_pwm},
616        {LM85_SYSCTL_PWM_CFG1, "pwm1_cfg", NULL, 0, 0644, NULL, &i2c_proc_real,
617                &i2c_sysctl_real, NULL, &lm85_pwm_config},
618        {LM85_SYSCTL_PWM_CFG2, "pwm2_cfg", NULL, 0, 0644, NULL, &i2c_proc_real,
619                &i2c_sysctl_real, NULL, &lm85_pwm_config},
620        {LM85_SYSCTL_PWM_CFG3, "pwm3_cfg", NULL, 0, 0644, NULL, &i2c_proc_real,
621                &i2c_sysctl_real, NULL, &lm85_pwm_config},
622        {LM85_SYSCTL_PWM_ZONE1, "pwm1_zone", NULL, 0, 0644, NULL,
623                &i2c_proc_real, &i2c_sysctl_real, NULL, &lm85_pwm_zone},
624        {LM85_SYSCTL_PWM_ZONE2, "pwm2_zone", NULL, 0, 0644, NULL,
625                &i2c_proc_real, &i2c_sysctl_real, NULL, &lm85_pwm_zone},
626        {LM85_SYSCTL_PWM_ZONE3, "pwm3_zone", NULL, 0, 0644, NULL,
627                &i2c_proc_real, &i2c_sysctl_real, NULL, &lm85_pwm_zone},
628        {LM85_SYSCTL_ZONE1, "zone1", NULL, 0, 0644, NULL, &i2c_proc_real,
629                &i2c_sysctl_real, NULL, &lm85_zone},
630        {LM85_SYSCTL_ZONE2, "zone2", NULL, 0, 0644, NULL, &i2c_proc_real,
631                &i2c_sysctl_real, NULL, &lm85_zone},
632        {LM85_SYSCTL_ZONE3, "zone3", NULL, 0, 0644, NULL, &i2c_proc_real,
633                &i2c_sysctl_real, NULL, &lm85_zone},
634        {LM85_SYSCTL_SMOOTH1, "smooth1", NULL, 0, 0644, NULL, &i2c_proc_real,
635                &i2c_sysctl_real, NULL, &lm85_smooth},
636        {LM85_SYSCTL_SMOOTH2, "smooth2", NULL, 0, 0644, NULL, &i2c_proc_real,
637                &i2c_sysctl_real, NULL, &lm85_smooth},
638        {LM85_SYSCTL_SMOOTH3, "smooth3", NULL, 0, 0644, NULL, &i2c_proc_real,
639                &i2c_sysctl_real, NULL, &lm85_smooth},
640        {0}
641};
642#define CTLTBL_COMMON (sizeof(lm85_common)/sizeof(lm85_common[0]))
643
644/* NOTE: tach_mode is a shared name, but implemented with
645 *   different functions
646 */
647static ctl_table lm85_specific[] = {
648        {LM85_SYSCTL_SPINUP_CTL, "spinup_ctl", NULL, 0, 0644, NULL,
649                &i2c_proc_real, &i2c_sysctl_real, NULL, &lm85_spinup_ctl},
650        {LM85_SYSCTL_TACH_MODE, "tach_mode", NULL, 0, 0644, NULL,
651                &i2c_proc_real, &i2c_sysctl_real, NULL, &lm85_tach_mode},
652/*      {0} The doc generator needs this. */
653};
654#define CTLTBL_LM85 (sizeof(lm85_specific)/sizeof(lm85_specific[0]))
655
656static ctl_table adm1027_specific[] = {
657        {ADM1027_SYSCTL_TACH_MODE, "tach_mode", NULL, 0, 0644, NULL,
658                &i2c_proc_real, &i2c_sysctl_real, NULL, &adm1027_tach_mode},
659        {ADM1027_SYSCTL_TEMP_OFFSET1, "temp1_offset", NULL, 0, 0644, NULL,
660                &i2c_proc_real, &i2c_sysctl_real, NULL, &adm1027_temp_offset},
661        {ADM1027_SYSCTL_TEMP_OFFSET2, "temp2_offset", NULL, 0, 0644, NULL,
662                &i2c_proc_real, &i2c_sysctl_real, NULL, &adm1027_temp_offset},
663        {ADM1027_SYSCTL_TEMP_OFFSET3, "temp3_offset", NULL, 0, 0644, NULL,
664                &i2c_proc_real, &i2c_sysctl_real, NULL, &adm1027_temp_offset},
665        {ADM1027_SYSCTL_FAN_PPR, "fan_ppr", NULL, 0, 0644, NULL,
666                &i2c_proc_real, &i2c_sysctl_real, NULL, &adm1027_fan_ppr},
667        {ADM1027_SYSCTL_ALARM_MASK, "alarm_mask", NULL, 0, 0644, NULL,
668                &i2c_proc_real, &i2c_sysctl_real, NULL, &adm1027_alarm_mask},
669/*      {0} The doc generator needs this. */
670};
671#define CTLTBL_ADM1027 (sizeof(adm1027_specific)/sizeof(adm1027_specific[0]))
672
673static ctl_table adt7463_specific[] = {
674        {ADT7463_SYSCTL_TMIN_CTL1, "tmin_ctl1", NULL, 0, 0644, NULL,
675                &i2c_proc_real, &i2c_sysctl_real, NULL, &adt7463_tmin_ctl},
676        {ADT7463_SYSCTL_TMIN_CTL2, "tmin_ctl2", NULL, 0, 0644, NULL,
677                &i2c_proc_real, &i2c_sysctl_real, NULL, &adt7463_tmin_ctl},
678        {ADT7463_SYSCTL_TMIN_CTL3, "tmin_ctl3", NULL, 0, 0644, NULL,
679                &i2c_proc_real, &i2c_sysctl_real, NULL, &adt7463_tmin_ctl},
680        {ADT7463_SYSCTL_THERM_SIGNAL, "therm_signal", NULL, 0, 0644, NULL,
681                &i2c_proc_real, &i2c_sysctl_real, NULL, &adt7463_therm_signal},
682/*      {0} The doc generator needs this. */
683};
684#define CTLTBL_ADT7463 (sizeof(adt7463_specific)/sizeof(adt7463_specific[0]))
685
686static ctl_table emc6d100_specific[] = {
687        {EMC6D100_SYSCTL_IN5, "in5", NULL, 0, 0644, NULL, &i2c_proc_real,
688                &i2c_sysctl_real, NULL, &emc6d100_in},
689        {EMC6D100_SYSCTL_IN6, "in6", NULL, 0, 0644, NULL, &i2c_proc_real,
690                &i2c_sysctl_real, NULL, &emc6d100_in},
691        {EMC6D100_SYSCTL_IN7, "in7", NULL, 0, 0644, NULL, &i2c_proc_real,
692                &i2c_sysctl_real, NULL, &emc6d100_in},
693/*      {0} The doc generator needs this. */
694};
695#define CTLTBL_EMC6D100 (sizeof(emc6d100_specific)/sizeof(emc6d100_specific[0]))
696
697
698#define MAX2(a,b) ((a)>(b)?(a):(b))
699#define MAX3(a,b,c) ((a)>(b)?MAX2((a),(c)):MAX2((b),(c)))
700#define MAX4(a,b,c,d) ((a)>(b)?MAX3((a),(c),(d)):MAX3((b),(c),(d)))
701
702#define CTLTBL_MAX (CTLTBL_COMMON + MAX3(CTLTBL_LM85, CTLTBL_ADM1027+CTLTBL_ADT7463, CTLTBL_EMC6D100))
703
704/* This function is called when:
705     * lm85_driver is inserted (when this module is loaded), for each
706       available adapter
707     * when a new adapter is inserted (and lm85_driver is still present) */
708int lm85_attach_adapter(struct i2c_adapter *adapter)
709{
710        return i2c_detect(adapter, &addr_data, lm85_detect);
711}
712
713/* This function is called by i2c_detect */
714int lm85_detect(struct i2c_adapter *adapter, int address,
715                unsigned short flags, int kind)
716{
717        int i;
718        int company, verstep ;
719        struct i2c_client *new_client;
720        struct lm85_data *data;
721        int err = 0;
722        const char *type_name = "";
723        struct ctl_table template[CTLTBL_MAX] ;
724        int template_used ;
725
726        if (i2c_is_isa_adapter(adapter)) {
727                /* This chip has no ISA interface */
728                goto ERROR0 ;
729        };
730
731        if (!i2c_check_functionality(adapter,
732                                        I2C_FUNC_SMBUS_BYTE_DATA)) {
733                /* We need to be able to do byte I/O */
734                goto ERROR0 ;
735        };
736
737        /* OK. For now, we presume we have a valid client. We now create the
738           client structure, even though we cannot fill it completely yet.
739           But it allows us to access lm85_{read,write}_value. */
740
741        if (!(data = kmalloc(sizeof(struct lm85_data), GFP_KERNEL))) {
742                err = -ENOMEM;
743                goto ERROR0;
744        }
745
746        new_client = &data->client;
747        new_client->addr = address;
748        new_client->data = data;
749        new_client->adapter = adapter;
750        new_client->driver = &lm85_driver;
751        new_client->flags = 0;
752
753        /* Now, we do the remaining detection. */
754
755        company = lm85_read_value(new_client, LM85_REG_COMPANY);
756        verstep = lm85_read_value(new_client, LM85_REG_VERSTEP);
757
758#ifdef DEBUG
759        printk("lm85: Detecting device at %d,0x%02x with"
760                " COMPANY: 0x%02x and VERSTEP: 0x%02x\n",
761                i2c_adapter_id(new_client->adapter), new_client->addr,
762                company, verstep
763            );
764#endif
765
766        /* If auto-detecting, Determine the chip type. */
767        if (kind <= 0) {
768#ifdef DEBUG
769                printk("lm85: Autodetecting device at %d,0x%02x ...\n",
770                        i2c_adapter_id(adapter), address );
771#endif
772                if( company == LM85_COMPANY_NATIONAL
773                    && verstep == LM85_VERSTEP_LM85C ) {
774                        kind = lm85c ;
775                } else if( company == LM85_COMPANY_NATIONAL
776                    && verstep == LM85_VERSTEP_LM85B ) {
777                        kind = lm85b ;
778                } else if( company == LM85_COMPANY_NATIONAL
779                    && (verstep & LM85_VERSTEP_VMASK) == LM85_VERSTEP_GENERIC) {
780                        printk("lm85: Detected National Semiconductor chip\n");
781                        printk("lm85: Unrecgonized version/stepping 0x%02x"
782                            " Defaulting to Generic LM85.\n", verstep );
783                        kind = any_chip ;
784                } else if( company == LM85_COMPANY_ANALOG_DEV
785                    && verstep == LM85_VERSTEP_ADM1027 ) {
786                        kind = adm1027 ;
787                } else if( company == LM85_COMPANY_ANALOG_DEV
788                    && (verstep == LM85_VERSTEP_ADT7463
789                         || verstep == LM85_VERSTEP_ADT7463C) ) {
790                        kind = adt7463 ;
791                } else if( company == LM85_COMPANY_ANALOG_DEV
792                    && (verstep & LM85_VERSTEP_VMASK) == LM85_VERSTEP_GENERIC) {
793                        printk("lm85: Detected Analog Devices chip\n");
794                        printk("lm85: Unrecgonized version/stepping 0x%02x"
795                            " Defaulting to Generic LM85.\n", verstep );
796                        kind = any_chip ;
797                } else if( company == LM85_COMPANY_SMSC
798                    && (verstep == LM85_VERSTEP_EMC6D100_A0
799                         || verstep == LM85_VERSTEP_EMC6D100_A1) ) {
800                        /* Unfortunately, we can't tell a '100 from a '101
801                         *   from the registers.  Since a '101 is a '100
802                         *   in a package with fewer pins and therefore no
803                         *   3.3V, 1.5V or 1.8V inputs, perhaps if those
804                         *   inputs read 0, then it's a '101.
805                         */
806                        kind = emc6d100 ;
807                } else if( company == LM85_COMPANY_SMSC
808                    && (verstep & LM85_VERSTEP_VMASK) == LM85_VERSTEP_GENERIC) {
809                        printk("lm85: Detected SMSC chip\n");
810                        printk("lm85: Unrecognized version/stepping 0x%02x"
811                            " Defaulting to Generic LM85.\n", verstep );
812                        kind = any_chip ;
813                } else if( kind == any_chip
814                    && (verstep & LM85_VERSTEP_VMASK) == LM85_VERSTEP_GENERIC) {
815                        printk("lm85: Generic LM85 Version 6 detected\n");
816                        /* Leave kind as "any_chip" */
817                } else {
818#ifdef DEBUG
819                        printk("lm85: Autodetection failed\n");
820#endif
821                        /* Not an LM85 ... */
822                        if( kind == any_chip ) {  /* User used force=x,y */
823                            printk("lm85: Generic LM85 Version 6 not"
824                                " found at %d,0x%02x. Try force_lm85c.\n",
825                                i2c_adapter_id(adapter), address );
826                        }
827                        goto ERROR1;
828                }
829        }
830
831        /* Fill in the chip specific driver values */
832        switch (kind) {
833        case any_chip :
834                type_name = "lm85";
835                strcpy(new_client->name, "Generic LM85");
836                template_used = 0 ;
837                break ;
838        case lm85b :
839                type_name = "lm85b";
840                strcpy(new_client->name, "National LM85-B");
841                memcpy( template, lm85_specific, sizeof(lm85_specific) );
842                template_used = CTLTBL_LM85 ;
843                break ;
844        case lm85c :
845                type_name = "lm85c";
846                strcpy(new_client->name, "National LM85-C");
847                memcpy( template, lm85_specific, sizeof(lm85_specific) );
848                template_used = CTLTBL_LM85 ;
849                break ;
850        case adm1027 :
851                type_name = "adm1027";
852                strcpy(new_client->name, "Analog Devices ADM1027");
853                memcpy( template, adm1027_specific, sizeof(adm1027_specific) );
854                template_used = CTLTBL_ADM1027 ;
855                break ;
856        case adt7463 :
857                type_name = "adt7463";
858                strcpy(new_client->name, "Analog Devices ADT7463");
859                memcpy( template, adt7463_specific, sizeof(adt7463_specific) );
860                template_used = CTLTBL_ADT7463 ;
861                memcpy( template+template_used, adm1027_specific, sizeof(adm1027_specific) );
862                template_used += CTLTBL_ADM1027 ;
863                break ;
864        case emc6d100 :
865                type_name = "emc6d100";
866                strcpy(new_client->name, "SMSC EMC6D100");
867                memcpy(template, emc6d100_specific, sizeof(emc6d100_specific));
868                template_used = CTLTBL_EMC6D100 ;
869                break ;
870        default :
871                printk("lm85: Internal error, invalid kind (%d)!", kind);
872                err = -EFAULT ;
873                goto ERROR1;
874        }
875
876        /* Fill in the remaining client fields */
877        new_client->id = lm85_id++;
878        printk("lm85: Assigning ID %d to %s at %d,0x%02x\n",
879                new_client->id, new_client->name,
880                i2c_adapter_id(new_client->adapter),
881                new_client->addr
882            );
883
884        /* Housekeeping values */
885        data->type = kind;
886        data->valid = 0;
887
888        /* Set the VRM version */
889        data->vrm = LM85_INIT_VRM ;
890
891        /* Zero the accumulators */
892        data->therm_total = 0;
893        data->therm_ovfl = 0;
894
895        init_MUTEX(&data->update_lock);
896
897        /* Initialize the LM85 chip */
898        lm85_init_client(new_client);
899
900        /* Tell the I2C layer a new client has arrived */
901        if ((err = i2c_attach_client(new_client)))
902                goto ERROR1;
903
904        /* Finish out the template */
905        memcpy( template + template_used, lm85_common, sizeof(lm85_common) );
906
907        /* Register a new directory entry with module sensors */
908        if ((i = i2c_register_entry(new_client,
909                                        type_name,
910                                        template,
911                                        THIS_MODULE)) < 0) {
912                err = i;
913                goto ERROR2;
914        }
915        data->sysctl_id = i;
916
917        return 0;
918
919        /* Error out and cleanup code */
920    ERROR2:
921        i2c_detach_client(new_client);
922    ERROR1:
923        kfree(data);
924    ERROR0:
925        return err;
926}
927
928int lm85_detach_client(struct i2c_client *client)
929{
930        int err;
931        int id ;
932
933        id = client->id;
934        i2c_deregister_entry(((struct lm85_data *)(client->data))->sysctl_id);
935
936        if ((err = i2c_detach_client(client))) {
937                printk("lm85(%d): Client deregistration failed,"
938                        " client not detached.\n", id );
939                return err;
940        }
941
942        kfree(client->data);
943
944        return 0;
945}
946
947int lm85_read_value(struct i2c_client *client, u16 reg)
948{
949        int res;
950
951        /* What size location is it? */
952        switch( reg ) {
953        case LM85_REG_FAN(0) :  /* Read WORD data */
954        case LM85_REG_FAN(1) :
955        case LM85_REG_FAN(2) :
956        case LM85_REG_FAN(3) :
957        case LM85_REG_FAN_MIN(0) :
958        case LM85_REG_FAN_MIN(1) :
959        case LM85_REG_FAN_MIN(2) :
960        case LM85_REG_FAN_MIN(3) :
961        case LM85_REG_ALARM :  /* Read ALARM1 and ALARM2 */
962        case ADM1027_REG_INTMASK :  /* Read MASK1 and MASK2 */
963        case ADM1027_REG_EXTEND_ADC :  /* Read ADC1 and ADC2 */
964                reg &= 0xff ;  /* Pseudo words have address + 0x0100 */
965                res = i2c_smbus_read_byte_data(client, reg) & 0xff ;
966                res |= (i2c_smbus_read_byte_data(client, reg+1) & 0xff) << 8 ;
967                break ;
968        case ADT7463_REG_TMIN_CTL :  /* Read WORD MSB, LSB */
969                reg &= 0xff ;  /* Pseudo words have address + 0x0100 */
970                res = (i2c_smbus_read_byte_data(client, reg) & 0xff) << 8 ;
971                res |= i2c_smbus_read_byte_data(client, reg+1) & 0xff ;
972                break ;
973        default:        /* Read BYTE data */
974                res = i2c_smbus_read_byte_data(client, reg & 0xff) & 0xff ;
975                break ;
976        }
977
978        return res ;
979}
980
981int lm85_write_value(struct i2c_client *client, u16 reg, int value)
982{
983        int res ;
984
985        switch( reg ) {
986        case LM85_REG_FAN(0) :  /* Write WORD data */
987        case LM85_REG_FAN(1) :
988        case LM85_REG_FAN(2) :
989        case LM85_REG_FAN(3) :
990        case LM85_REG_FAN_MIN(0) :
991        case LM85_REG_FAN_MIN(1) :
992        case LM85_REG_FAN_MIN(2) :
993        case LM85_REG_FAN_MIN(3) :
994        case ADM1027_REG_INTMASK :
995        /* NOTE: ALARM and ADC are read only, so not included here */
996                reg &= 0xff ;  /* Pseudo words have address + 0x0100 */
997                res = i2c_smbus_write_byte_data(client, reg, value & 0xff) ;
998                res |= i2c_smbus_write_byte_data(client, reg+1, (value>>8) & 0xff) ;
999                break ;
1000        case ADT7463_REG_TMIN_CTL :  /* Write WORD MSB, LSB */
1001                reg &= 0xff ;  /* Pseudo words have address + 0x0100 */
1002                res = i2c_smbus_write_byte_data(client, reg, (value>>8) & 0xff);
1003                res |= i2c_smbus_write_byte_data(client, reg+1, value & 0xff) ;
1004                break ;
1005        default:        /* Write BYTE data */
1006                res = i2c_smbus_write_byte_data(client, reg & 0xff, value);
1007                break ;
1008        }
1009
1010        return res ;
1011}
1012
1013/* Called when we have found a new LM85. It should set limits, etc. */
1014void lm85_init_client(struct i2c_client *client)
1015{
1016        int value;
1017        struct lm85_data *data = client->data;
1018
1019#ifdef DEBUG
1020        printk("lm85(%d): Initializing device\n", client->id);
1021#endif
1022
1023        /* Warn if part was not "READY" */
1024        value = lm85_read_value(client, LM85_REG_CONFIG);
1025#ifdef DEBUG
1026        printk("lm85(%d): LM85_REG_CONFIG is: 0x%02x\n", client->id, value );
1027#endif
1028        if( value & 0x02 ) {
1029                printk("lm85(%d): Client (%d,0x%02x) config is locked.\n",
1030                            client->id,
1031                            i2c_adapter_id(client->adapter), client->addr );
1032        };
1033        if( ! (value & 0x04) ) {
1034                printk("lm85(%d): Client (%d,0x%02x) is not ready.\n",
1035                            client->id,
1036                            i2c_adapter_id(client->adapter), client->addr );
1037        };
1038        if( (data->type == adm1027 || data->type == adt7463)
1039            && (value & 0x10)
1040        ) {
1041                printk("lm85(%d): Client (%d,0x%02x) VxI mode is set.  "
1042                        "Please report this to the lm85 maintainer.\n",
1043                            client->id,
1044                            i2c_adapter_id(client->adapter), client->addr );
1045        };
1046
1047        /* See if SYNC to PWM3 is set */
1048        if( data->type == adt7463
1049            && (lm85_read_value(client, LM85_REG_AFAN_SPIKE1) & 0x10)
1050        ) {
1051                printk("lm85(%d): Sync to PWM3 is set.  Expect PWM3 "
1052                        "to control fans 2, 3, and 4\n",
1053                        client->id );
1054        };
1055
1056        /* See if PWM2 is #SMBALERT */
1057        if( (data->type == adm1027 || data->type == adt7463)
1058            && (lm85_read_value(client, ADM1027_REG_CONFIG3) & 0x01)
1059        ) {
1060                printk("lm85(%d): PWM2 is SMBALERT.  PWM2 not available.\n",
1061                        client->id );
1062        };
1063
1064        /* Check if 2.5V and 5V inputs are reconfigured */
1065        if( data->type == adt7463 ) {
1066                value = lm85_read_value(client, ADT7463_REG_CONFIG4);
1067                if( value & 0x01 ) {
1068                        printk("lm85(%d): 2.5V input (in0) is SMBALERT.  "
1069                                "in0 not available.\n", client->id );
1070                };
1071                if( value & 0x02 ) {
1072                        printk("lm85(%d): 5V input (in3) is THERM.  "
1073                                "in3 not available.\n", client->id );
1074                }
1075        };
1076
1077        /* FIXME?  Display EMC6D100 config info? */
1078
1079        /* WE INTENTIONALLY make no changes to the limits,
1080         *   offsets, pwms, fans and zones.  If they were
1081         *   configured, we don't want to mess with them.
1082         *   If they weren't, the default is 100% PWM, no
1083         *   control and will suffice until 'sensors -s'
1084         *   can be run by the user.
1085         */
1086
1087        /* Start monitoring */
1088        value = lm85_read_value(client, LM85_REG_CONFIG);
1089        /* Try to clear LOCK, Set START, save everything else */
1090        value = ((value & ~ 0x02) | 0x01) & 0xff ;
1091#ifdef DEBUG
1092        printk("lm85(%d): Setting CONFIG to: 0x%02x\n", client->id, value );
1093#endif
1094        lm85_write_value(client, LM85_REG_CONFIG, value);
1095
1096}
1097
1098void lm85_update_client(struct i2c_client *client)
1099{
1100        struct lm85_data *data = client->data;
1101        int i;
1102
1103        down(&data->update_lock);
1104
1105        if (!data->valid
1106            || (jiffies - data->last_reading > LM85_DATA_INTERVAL )) {
1107                /* Things that change quickly */
1108
1109#ifdef DEBUG
1110                printk("lm85(%d): Reading sensor values\n", client->id);
1111#endif
1112                /* Have to read extended bits first to "freeze" the
1113                 * more significant bits that are read later.
1114                 */
1115                switch( data->type ) {
1116                case adm1027 :
1117                case adt7463 :
1118                        data->extend_adc =
1119                            lm85_read_value(client, ADM1027_REG_EXTEND_ADC);
1120                        break ;
1121                default :
1122                        data->extend_adc = 0 ;
1123                        break ;
1124                }
1125
1126                for (i = 0; i <= 4; ++i) {
1127                        data->in[i] =
1128                            lm85_read_value(client, LM85_REG_IN(i));
1129                }
1130
1131                for (i = 0; i <= 3; ++i) {
1132                        data->fan[i] =
1133                            lm85_read_value(client, LM85_REG_FAN(i));
1134                }
1135
1136                for (i = 0; i <= 2; ++i) {
1137                        data->temp[i] =
1138                            lm85_read_value(client, LM85_REG_TEMP(i));
1139                }
1140
1141                for (i = 0; i <= 2; ++i) {
1142                        data->pwm[i] =
1143                            lm85_read_value(client, LM85_REG_PWM(i));
1144                }
1145
1146                data->alarms = lm85_read_value(client, LM85_REG_ALARM);
1147
1148                switch( ((struct lm85_data *)(client->data))->type ) {
1149                case adt7463 :
1150                        /* REG_THERM code duplicated in therm_signal() */
1151                        i = lm85_read_value(client, ADT7463_REG_THERM);
1152                        if( data->therm_total < LONG_MAX - 256 ) {
1153                            data->therm_total += i ;
1154                        }
1155                        if( i >= 255 ) {
1156                                ++data->therm_ovfl ;
1157                        }
1158                        break ;
1159                case emc6d100 :
1160                        /* Three more voltage sensors */
1161                        for (i = 5; i <= 7; ++i) {
1162                            data->in[i] =
1163                                lm85_read_value(client, EMC6D100_REG_IN(i));
1164                        }
1165                        /* More alarm bits */
1166                        data->alarms |=
1167                            lm85_read_value(client, EMC6D100_REG_ALARM3) << 16;
1168
1169                        break ;
1170                default : break ; /* no warnings */
1171                }
1172
1173                data->last_reading = jiffies ;
1174        };  /* last_reading */
1175
1176        if (!data->valid
1177            || (jiffies - data->last_config > LM85_CONFIG_INTERVAL) ) {
1178                /* Things that don't change often */
1179
1180#ifdef DEBUG
1181                printk("lm85(%d): Reading config values\n", client->id);
1182#endif
1183                for (i = 0; i <= 4; ++i) {
1184                        data->in_min[i] =
1185                            lm85_read_value(client, LM85_REG_IN_MIN(i));
1186                        data->in_max[i] =
1187                            lm85_read_value(client, LM85_REG_IN_MAX(i));
1188                }
1189
1190                for (i = 0; i <= 3; ++i) {
1191                        data->fan_min[i] =
1192                            lm85_read_value(client, LM85_REG_FAN_MIN(i));
1193                }
1194
1195                for (i = 0; i <= 2; ++i) {
1196                        data->temp_min[i] =
1197                            lm85_read_value(client, LM85_REG_TEMP_MIN(i));
1198                        data->temp_max[i] =
1199                            lm85_read_value(client, LM85_REG_TEMP_MAX(i));
1200                }
1201
1202                data->vid = lm85_read_value(client, LM85_REG_VID);
1203
1204                for (i = 0; i <= 2; ++i) {
1205                        int val ;
1206                        data->autofan[i].config =
1207                            lm85_read_value(client, LM85_REG_AFAN_CONFIG(i));
1208                        val = lm85_read_value(client, LM85_REG_AFAN_RANGE(i));
1209                        data->autofan[i].freq = val & 0x07 ;
1210                        data->zone[i].range = (val >> 4) & 0x0f ;
1211                        data->autofan[i].min_pwm =
1212                            lm85_read_value(client, LM85_REG_AFAN_MINPWM(i));
1213                        data->zone[i].limit =
1214                            lm85_read_value(client, LM85_REG_AFAN_LIMIT(i));
1215                        data->zone[i].critical =
1216                            lm85_read_value(client, LM85_REG_AFAN_CRITICAL(i));
1217                }
1218
1219                i = lm85_read_value(client, LM85_REG_AFAN_SPIKE1);
1220                data->smooth[0] = i & 0x0f ;
1221                data->syncpwm3 = i & 0x10 ;  /* Save PWM3 config */
1222                data->autofan[0].min_off = i & 0x20 ;
1223                data->autofan[1].min_off = i & 0x40 ;
1224                data->autofan[2].min_off = i & 0x80 ;
1225                i = lm85_read_value(client, LM85_REG_AFAN_SPIKE2);
1226                data->smooth[1] = (i>>4) & 0x0f ;
1227                data->smooth[2] = i & 0x0f ;
1228
1229                i = lm85_read_value(client, LM85_REG_AFAN_HYST1);
1230                data->zone[0].hyst = (i>>4) & 0x0f ;
1231                data->zone[1].hyst = i & 0x0f ;
1232
1233                i = lm85_read_value(client, LM85_REG_AFAN_HYST2);
1234                data->zone[2].hyst = (i>>4) & 0x0f ;
1235
1236                switch( ((struct lm85_data *)(client->data))->type ) {
1237                case lm85b :
1238                case lm85c :
1239                        data->tach_mode = lm85_read_value(client,
1240                                LM85_REG_TACH_MODE );
1241                        data->spinup_ctl = lm85_read_value(client,
1242                                LM85_REG_SPINUP_CTL );
1243                        break ;
1244                case adt7463 :
1245                        for (i = 0; i <= 2; ++i) {
1246                            data->oppoint[i] = lm85_read_value(client,
1247                                ADT7463_REG_OPPOINT(i) );
1248                        }
1249                        data->tmin_ctl = lm85_read_value(client,
1250                                ADT7463_REG_TMIN_CTL );
1251                        data->therm_limit = lm85_read_value(client,
1252                                ADT7463_REG_THERM_LIMIT );
1253                /* FALL THROUGH */
1254                case adm1027 :
1255                        for (i = 0; i <= 2; ++i) {
1256                            data->temp_offset[i] = lm85_read_value(client,
1257                                ADM1027_REG_TEMP_OFFSET(i) );
1258                        }
1259                        data->tach_mode = lm85_read_value(client,
1260                                ADM1027_REG_CONFIG3 );
1261                        data->fan_ppr = lm85_read_value(client,
1262                                ADM1027_REG_FAN_PPR );
1263                        data->alarm_mask = lm85_read_value(client,
1264                                ADM1027_REG_INTMASK );
1265                        break ;
1266                case emc6d100 :
1267                        for (i = 5; i <= 7; ++i) {
1268                            data->in_min[i] =
1269                                lm85_read_value(client, EMC6D100_REG_IN_MIN(i));
1270                            data->in_max[i] =
1271                                lm85_read_value(client, EMC6D100_REG_IN_MAX(i));
1272                        }
1273                        break ;
1274                default : break ; /* no warnings */
1275                }
1276       
1277                data->last_config = jiffies;
1278        };  /* last_config */
1279
1280        data->valid = 1;
1281
1282        up(&data->update_lock);
1283}
1284
1285
1286/* The next functions are the call-back functions of the /proc/sys and
1287   sysctl files. Which function is used is defined in the ctl_table in
1288   the extra1 field.
1289   Each function must return the magnitude (power of 10 to divide the data
1290   with) if it is called with operation==SENSORS_PROC_REAL_INFO.  It must
1291   put a maximum of *nrels elements in results reflecting the data of this
1292   file, and set *nrels to the number it actually put in it, if operation==
1293   SENSORS_PROC_REAL_READ.  Finally, it must get upto *nrels elements from
1294   results and write them to the chip, if operations==SENSORS_PROC_REAL_WRITE.
1295 */
1296void lm85_in(struct i2c_client *client, int operation, int ctl_name,
1297             int *nrels_mag, long *results)
1298{
1299        struct lm85_data *data = client->data;
1300        int nr = ctl_name - LM85_SYSCTL_IN0;
1301
1302        if (nr < 0 || nr > 4)
1303                return ;  /* ERROR */
1304
1305        if (operation == SENSORS_PROC_REAL_INFO)
1306                *nrels_mag = 3;  /* 1.000 */
1307        else if (operation == SENSORS_PROC_REAL_READ) {
1308                int  ext = 0 ;
1309                lm85_update_client(client);
1310                ext = EXT_FROM_REG(data->extend_adc, nr);
1311                results[0] = INS_FROM_REG(nr,data->in_min[nr]);
1312                results[1] = INS_FROM_REG(nr,data->in_max[nr]);
1313                results[2] = INSEXT_FROM_REG(nr,data->in[nr],ext);
1314                *nrels_mag = 3;
1315        } else if (operation == SENSORS_PROC_REAL_WRITE) {
1316                down(&data->update_lock);
1317                if (*nrels_mag > 1) {
1318                        data->in_max[nr] = INS_TO_REG(nr,results[1]);
1319                        lm85_write_value(client, LM85_REG_IN_MAX(nr),
1320                                         data->in_max[nr]);
1321                }
1322                if (*nrels_mag > 0) {
1323                        data->in_min[nr] = INS_TO_REG(nr,results[0]);
1324                        lm85_write_value(client, LM85_REG_IN_MIN(nr),
1325                                         data->in_min[nr]);
1326                }
1327                up(&data->update_lock);
1328        }
1329}
1330
1331void lm85_fan(struct i2c_client *client, int operation, int ctl_name,
1332              int *nrels_mag, long *results)
1333{
1334        struct lm85_data *data = client->data;
1335        int nr = ctl_name - LM85_SYSCTL_FAN1 ;
1336
1337        if (nr < 0 || nr > 3)
1338                return ;  /* ERROR */
1339
1340        if (operation == SENSORS_PROC_REAL_INFO)
1341                *nrels_mag = 0;
1342        else if (operation == SENSORS_PROC_REAL_READ) {
1343                lm85_update_client(client);
1344                results[0] = FAN_FROM_REG(data->fan_min[nr]);
1345                results[1] = FAN_FROM_REG(data->fan[nr]);
1346                *nrels_mag = 2;
1347        } else if (operation == SENSORS_PROC_REAL_WRITE) {
1348                down(&data->update_lock);
1349                if (*nrels_mag > 0) {
1350                        data->fan_min[nr] = FAN_TO_REG(results[0]);
1351                        lm85_write_value(client, LM85_REG_FAN_MIN(nr),
1352                                         data->fan_min[nr]);
1353                }
1354                up(&data->update_lock);
1355        }
1356}
1357
1358
1359void lm85_temp(struct i2c_client *client, int operation, int ctl_name,
1360               int *nrels_mag, long *results)
1361{
1362        struct lm85_data *data = client->data;
1363        int nr = ctl_name - LM85_SYSCTL_TEMP1 ;
1364
1365        if (nr < 0 || nr > 2)
1366                return ;  /* ERROR */
1367
1368        if (operation == SENSORS_PROC_REAL_INFO)
1369                *nrels_mag = 2;
1370        else if (operation == SENSORS_PROC_REAL_READ) {
1371                int  ext = 0 ;
1372                lm85_update_client(client);
1373
1374                /* +5 for offset of temp data in ext reg */
1375                ext = EXT_FROM_REG(data->extend_adc, nr+5);
1376
1377                results[0] = TEMP_FROM_REG(data->temp_min[nr]);
1378                results[1] = TEMP_FROM_REG(data->temp_max[nr]);
1379                results[2] = TEMPEXT_FROM_REG(data->temp[nr],ext);
1380                *nrels_mag = 3;
1381        } else if (operation == SENSORS_PROC_REAL_WRITE) {
1382                down(&data->update_lock);
1383                if (*nrels_mag > 1) {
1384                        data->temp_max[nr] = TEMP_TO_REG(results[1]);
1385                        lm85_write_value(client, LM85_REG_TEMP_MAX(nr),
1386                                         data->temp_max[nr]);
1387                }
1388                if (*nrels_mag > 0) {
1389                        data->temp_min[nr] = TEMP_TO_REG(results[0]);
1390                        lm85_write_value(client, LM85_REG_TEMP_MIN(nr),
1391                                         data->temp_min[nr]);
1392                }
1393                up(&data->update_lock);
1394        }
1395}
1396
1397void lm85_pwm(struct i2c_client *client, int operation, int ctl_name,
1398              int *nrels_mag, long *results)
1399{
1400        struct lm85_data *data = client->data;
1401        int nr = ctl_name - LM85_SYSCTL_PWM1 ;
1402        int pwm_zone ;
1403
1404        if (nr < 0 || nr > 2)
1405                return ;  /* ERROR */
1406
1407        if (operation == SENSORS_PROC_REAL_INFO)
1408                *nrels_mag = 0;
1409        else if (operation == SENSORS_PROC_REAL_READ) {
1410                lm85_update_client(client);
1411                results[0] = PWM_FROM_REG(data->pwm[nr]);
1412                pwm_zone = ZONE_FROM_REG(data->autofan[nr].config);
1413                /* PWM "enabled" if not off (0) nor on (-1) */
1414                results[1] = pwm_zone != 0 && pwm_zone != -1 ;
1415                *nrels_mag = 2;
1416        } else if (operation == SENSORS_PROC_REAL_WRITE) {
1417                down(&data->update_lock);
1418                /* PWM enable is read-only */
1419                if (*nrels_mag > 0) {
1420                        data->pwm[nr] = PWM_TO_REG(results[0]);
1421                        lm85_write_value(client, LM85_REG_PWM(nr),
1422                                         data->pwm[nr]);
1423                }
1424                up(&data->update_lock);
1425        }
1426}
1427
1428void lm85_vid(struct i2c_client *client, int operation, int ctl_name,
1429              int *nrels_mag, long *results)
1430{
1431        struct lm85_data *data = client->data;
1432
1433        if( ctl_name != LM85_SYSCTL_VID )
1434                return ;  /* ERROR */
1435
1436        if (operation == SENSORS_PROC_REAL_INFO)
1437                *nrels_mag = 3;
1438        else if (operation == SENSORS_PROC_REAL_READ) {
1439                lm85_update_client(client);
1440                results[0] = VID_FROM_REG((data->vid)&0x3f,data->vrm);
1441                *nrels_mag = 1;
1442        }
1443}
1444
1445void lm85_vrm(struct i2c_client *client, int operation, int ctl_name,
1446              int *nrels_mag, long *results)
1447{
1448        struct lm85_data *data = client->data;
1449
1450        if( ctl_name != LM85_SYSCTL_VRM )
1451                return ;  /* ERROR */
1452
1453        if (operation == SENSORS_PROC_REAL_INFO)
1454                *nrels_mag = 1;
1455        else if (operation == SENSORS_PROC_REAL_READ) {
1456                results[0] = data->vrm ;
1457                *nrels_mag = 1;
1458        } else if (operation == SENSORS_PROC_REAL_WRITE) {
1459                down(&data->update_lock);
1460                if (*nrels_mag > 0) {
1461                        data->vrm = results[0] ;
1462                }
1463                up(&data->update_lock);
1464        }
1465}
1466
1467void lm85_alarms(struct i2c_client *client, int operation, int ctl_name,
1468                int *nrels_mag, long *results)
1469{
1470        struct lm85_data *data = client->data;
1471
1472        if( ctl_name != LM85_SYSCTL_ALARMS )
1473                return ;  /* ERROR */
1474
1475        if (operation == SENSORS_PROC_REAL_INFO)
1476                *nrels_mag = 0;
1477        else if (operation == SENSORS_PROC_REAL_READ) {
1478                lm85_update_client(client);
1479                results[0] = ALARMS_FROM_REG(data->alarms);
1480                *nrels_mag = 1;
1481        }
1482}
1483
1484void lm85_spinup_ctl(struct i2c_client *client, int operation, int ctl_name,
1485                  int *nrels_mag, long *results)
1486{
1487        struct lm85_data *data = client->data;
1488        int old;
1489
1490        if( ctl_name != LM85_SYSCTL_SPINUP_CTL )
1491                return ;  /* ERROR */
1492
1493        if (operation == SENSORS_PROC_REAL_INFO)
1494                *nrels_mag = 0;
1495        else if (operation == SENSORS_PROC_REAL_READ) {
1496                lm85_update_client(client);
1497                results[0] = (data->spinup_ctl & 1) != 0 ;
1498                results[1] = (data->spinup_ctl & 2) != 0 ;
1499                results[2] = (data->spinup_ctl & 4) != 0 ;
1500                *nrels_mag = 3;
1501        } else if (operation == SENSORS_PROC_REAL_WRITE) {
1502                down(&data->update_lock);
1503                old = data->spinup_ctl ;
1504                if (*nrels_mag > 2) {
1505                        old = (old & (~4)) | (results[2]?4:0) ;
1506                }
1507                if (*nrels_mag > 1) {
1508                        old = (old & (~2)) | (results[1]?2:0) ;
1509                }
1510                if (*nrels_mag > 0) {
1511                        old = (old & (~1)) | (results[0]?1:0) ;
1512                        lm85_write_value(client, LM85_REG_SPINUP_CTL, old);
1513                        data->spinup_ctl = old ;
1514                }
1515                up(&data->update_lock);
1516        }
1517}
1518
1519void lm85_tach_mode(struct i2c_client *client, int operation, int ctl_name,
1520                  int *nrels_mag, long *results)
1521{
1522        struct lm85_data *data = client->data;
1523        int old;
1524
1525        /* Tach Mode 1, Tach Mode 2, Tach Mode 3 & 4 */
1526
1527        if( ctl_name != LM85_SYSCTL_TACH_MODE )
1528                return ;  /* ERROR */
1529
1530        if (operation == SENSORS_PROC_REAL_INFO)
1531                *nrels_mag = 0;
1532        else if (operation == SENSORS_PROC_REAL_READ) {
1533                lm85_update_client(client);
1534                results[0] = (data->tach_mode & 0x03) ;
1535                results[1] = (data->tach_mode & 0x0c) >> 2 ;
1536                results[2] = (data->tach_mode & 0x30) >> 4 ;
1537                *nrels_mag = 3;
1538        } else if (operation == SENSORS_PROC_REAL_WRITE) {
1539                down(&data->update_lock);
1540                old = data->tach_mode ;
1541                if (*nrels_mag > 2) {
1542                        old = (old & (~0x30)) | ((results[2]&3) << 4) ;
1543                }
1544                if (*nrels_mag > 1) {
1545                        old = (old & (~0x0c)) | ((results[1]&3) << 2) ;
1546                }
1547                if (*nrels_mag > 0) {
1548                        old = (old & (~0x03)) |  (results[0]&3) ;
1549                        lm85_write_value(client, LM85_REG_TACH_MODE, old);
1550                        data->tach_mode = old ;
1551                }
1552                up(&data->update_lock);
1553        }
1554}
1555
1556void adm1027_tach_mode(struct i2c_client *client, int operation, int ctl_name,
1557                  int *nrels_mag, long *results)
1558{
1559        struct lm85_data *data = client->data;
1560        int old;
1561
1562        /* Tach/DC 1, Tach/DC 2, Tach/DC 3, Tach/DC 4 */
1563
1564        if( ctl_name != ADM1027_SYSCTL_TACH_MODE )
1565                return ;  /* ERROR */
1566
1567        if (operation == SENSORS_PROC_REAL_INFO)
1568                *nrels_mag = 0;
1569        else if (operation == SENSORS_PROC_REAL_READ) {
1570                lm85_update_client(client);
1571                results[0] = (data->tach_mode & 0x10) != 0 ;
1572                results[1] = (data->tach_mode & 0x20) != 0 ;
1573                results[2] = (data->tach_mode & 0x40) != 0 ;
1574                results[3] = (data->tach_mode & 0x80) != 0 ;
1575                *nrels_mag = 4;
1576        } else if (operation == SENSORS_PROC_REAL_WRITE) {
1577                down(&data->update_lock);
1578                old = data->tach_mode ;
1579                if (*nrels_mag > 3) {
1580                        old = (old & (~0x80)) | (results[3] ? 0x80 : 0) ;
1581                }
1582                if (*nrels_mag > 2) {
1583                        old = (old & (~0x40)) | (results[2] ? 0x40 : 0) ;
1584                }
1585                if (*nrels_mag > 1) {
1586                        old = (old & (~0x20)) | (results[1] ? 0x20 : 0) ;
1587                }
1588                if (*nrels_mag > 0) {
1589                        old = (old & (~0x10)) | (results[0] ? 0x10 : 0) ;
1590
1591                        /* Enable fast measurements if any TACH's are DC */
1592                        old = (old & (~0x08)) | ((old&0xf0) ? 0x08 : 0) ;
1593
1594                        lm85_write_value(client, ADM1027_REG_CONFIG3, old);
1595                        data->tach_mode = old ;
1596                }
1597                up(&data->update_lock);
1598        }
1599}
1600
1601void lm85_pwm_config(struct i2c_client *client, int operation, int ctl_name,
1602                  int *nrels_mag, long *results)
1603{
1604        struct lm85_data *data = client->data;
1605        int nr = ctl_name - LM85_SYSCTL_PWM_CFG1 ;
1606
1607        /* Spinup, min PWM, PWM Frequency, min below limit, Invert */
1608
1609        if (nr < 0 || nr > 2)
1610                return ;  /* ERROR */
1611
1612        if (operation == SENSORS_PROC_REAL_INFO)
1613                *nrels_mag = 1;
1614        else if (operation == SENSORS_PROC_REAL_READ) {
1615                lm85_update_client(client);
1616
1617                results[0] = SPINUP_FROM_REG(data->autofan[nr].config);
1618                results[1] = PWM_FROM_REG(data->autofan[nr].min_pwm)*10;
1619                results[2] = FREQ_FROM_REG(data->autofan[nr].freq);
1620                results[3] = data->autofan[nr].min_off ? 10 : 0 ;
1621                results[4] = (data->autofan[nr].config & 0x10) ? 10 : 0 ;
1622                *nrels_mag = 5;
1623        } else if (operation == SENSORS_PROC_REAL_WRITE) {
1624                int  old_config ;
1625
1626                down(&data->update_lock);
1627                old_config = data->autofan[nr].config ;
1628                if (*nrels_mag > 4) {
1629                        old_config = (old_config & (~0x10)) | (results[4]?0x10:0) ;
1630                }
1631                if (*nrels_mag > 3) {
1632                        data->autofan[nr].min_off = results[3] != 0 ;
1633                        lm85_write_value(client, LM85_REG_AFAN_SPIKE1,
1634                                data->smooth[0]
1635                                | data->syncpwm3
1636                                | (data->autofan[0].min_off ? 0x20 : 0)
1637                                | (data->autofan[1].min_off ? 0x40 : 0)
1638                                | (data->autofan[2].min_off ? 0x80 : 0)
1639                        );
1640                }
1641                if (*nrels_mag > 2) {
1642                        data->autofan[nr].freq = FREQ_TO_REG(results[2]) ;
1643                        lm85_write_value(client, LM85_REG_AFAN_RANGE(nr),
1644                            (data->zone[nr].range << 4)
1645                            | data->autofan[nr].freq
1646                        );
1647                }
1648                if (*nrels_mag > 1) {
1649                        data->autofan[nr].min_pwm = PWM_TO_REG((results[1]+5)/10);
1650                        lm85_write_value(client, LM85_REG_AFAN_MINPWM(nr),
1651                                        data->autofan[nr].min_pwm
1652                        );
1653                }
1654                if (*nrels_mag > 0) {
1655                        old_config = (old_config & (~0x07)) | SPINUP_TO_REG(results[0]) ;
1656                        lm85_write_value(client, LM85_REG_AFAN_CONFIG(nr), old_config);
1657                        data->autofan[nr].config = old_config ;
1658                }
1659                up(&data->update_lock);
1660        }
1661}
1662
1663void lm85_smooth(struct i2c_client *client, int operation, int ctl_name,
1664                  int *nrels_mag, long *results)
1665{
1666        struct lm85_data *data = client->data;
1667        int nr = ctl_name - LM85_SYSCTL_SMOOTH1 ;
1668
1669        if (nr < 0 || nr > 2)
1670                return ;  /* ERROR */
1671
1672        if (operation == SENSORS_PROC_REAL_INFO)
1673                *nrels_mag = 1;
1674        else if (operation == SENSORS_PROC_REAL_READ) {
1675                lm85_update_client(client);
1676                results[0] = SMOOTH_FROM_REG(data->smooth[nr]);
1677                *nrels_mag = 1;
1678
1679        } else if (operation == SENSORS_PROC_REAL_WRITE) {
1680                down(&data->update_lock);
1681                if( *nrels_mag > 0 ) {
1682                        data->smooth[nr] = SMOOTH_TO_REG(results[0]);
1683                }
1684                if( nr == 0 ) {
1685                    lm85_write_value(client, LM85_REG_AFAN_SPIKE1,
1686                        data->smooth[0]
1687                        | data->syncpwm3
1688                        | (data->autofan[0].min_off ? 0x20 : 0)
1689                        | (data->autofan[1].min_off ? 0x40 : 0)
1690                        | (data->autofan[2].min_off ? 0x80 : 0)
1691                    );
1692                } else {
1693                    lm85_write_value(client, LM85_REG_AFAN_SPIKE2,
1694                        (data->smooth[1] << 4) | data->smooth[2]);
1695                }
1696                up(&data->update_lock);
1697        }
1698}
1699
1700void lm85_zone(struct i2c_client *client, int operation, int ctl_name,
1701                  int *nrels_mag, long *results)
1702{
1703        struct lm85_data *data = client->data;
1704        int nr = ctl_name - LM85_SYSCTL_ZONE1 ;
1705
1706        /* Limit, Hysteresis (neg), Range, Critical */
1707
1708        if (nr < 0 || nr > 2)
1709                return ;  /* ERROR */
1710
1711        if (operation == SENSORS_PROC_REAL_INFO)
1712                *nrels_mag = 1;
1713        else if (operation == SENSORS_PROC_REAL_READ) {
1714                lm85_update_client(client);
1715
1716                results[0] = TEMP_FROM_REG(data->zone[nr].limit) / 10;
1717                results[1] = HYST_FROM_REG(data->zone[nr].hyst);
1718                results[2] = RANGE_FROM_REG(data->zone[nr].range);
1719                results[3] = TEMP_FROM_REG(data->zone[nr].critical) / 10;
1720                *nrels_mag = 4;
1721
1722        } else if (operation == SENSORS_PROC_REAL_WRITE) {
1723                down(&data->update_lock);
1724                if (*nrels_mag > 3) {
1725                        data->zone[nr].critical = TEMP_TO_REG(results[3]*10);
1726                        lm85_write_value(client, LM85_REG_AFAN_CRITICAL(nr),
1727                                data->zone[nr].critical );
1728                }
1729                if (*nrels_mag > 2) {
1730                        data->zone[nr].range = RANGE_TO_REG(results[2]);
1731                        lm85_write_value(client, LM85_REG_AFAN_RANGE(nr),
1732                            (data->zone[nr].range << 4)
1733                            | data->autofan[nr].freq
1734                        );
1735                }
1736                if (*nrels_mag > 1) {
1737                        data->zone[nr].hyst = HYST_TO_REG(results[1]);
1738                        if( nr == 0 || nr == 1 ) {
1739                            lm85_write_value(client, LM85_REG_AFAN_HYST1,
1740                                (data->zone[0].hyst << 4)
1741                                | data->zone[1].hyst
1742                            );
1743                        } else {
1744                            lm85_write_value(client, LM85_REG_AFAN_HYST2,
1745                                (data->zone[2].hyst << 4)
1746                            );
1747                        }
1748                }
1749                if (*nrels_mag > 0) {
1750                        data->zone[nr].limit = TEMP_TO_REG(results[0]*10);
1751                        lm85_write_value(client, LM85_REG_AFAN_LIMIT(nr),
1752                            data->zone[nr].limit
1753                        );
1754                }
1755                up(&data->update_lock);
1756        }
1757}
1758
1759void lm85_pwm_zone(struct i2c_client *client, int operation, int ctl_name,
1760                int *nrels_mag, long *results)
1761{
1762        struct lm85_data *data = client->data;
1763        int nr = ctl_name - LM85_SYSCTL_PWM_ZONE1 ;
1764
1765        if (nr < 0 || nr > 2)
1766                return ;  /* ERROR */
1767
1768        if (operation == SENSORS_PROC_REAL_INFO)
1769                *nrels_mag = 0;
1770        else if (operation == SENSORS_PROC_REAL_READ) {
1771                lm85_update_client(client);
1772                results[0] = ZONE_FROM_REG(data->autofan[nr].config);
1773                *nrels_mag = 1;
1774        } else if (operation == SENSORS_PROC_REAL_WRITE) {
1775                down(&data->update_lock);
1776                if (*nrels_mag > 0) {
1777                        data->autofan[nr].config =
1778                            (data->autofan[nr].config & (~0xe0))
1779                            | ZONE_TO_REG(results[0]) ;
1780                        lm85_write_value(client, LM85_REG_AFAN_CONFIG(nr),
1781                            data->autofan[nr].config);
1782                }
1783                up(&data->update_lock);
1784        }
1785}
1786
1787void adm1027_temp_offset(struct i2c_client *client, int operation, int ctl_name,
1788                int *nrels_mag, long *results)
1789{
1790        struct lm85_data *data = client->data;
1791        int nr = ctl_name - ADM1027_SYSCTL_TEMP_OFFSET1 ;
1792
1793        if (nr < 0 || nr > 2)
1794                return ;  /* ERROR */
1795
1796        if (operation == SENSORS_PROC_REAL_INFO)
1797                *nrels_mag = 2;
1798        else if (operation == SENSORS_PROC_REAL_READ) {
1799                lm85_update_client(client);
1800                switch( data->type ) {
1801                case adm1027 :
1802                default :
1803                        results[0] = TEMP_FROM_REG(data->temp_offset[nr]);
1804                        break ;
1805                case adt7463 :
1806                        results[0] = TEMPEXT_FROM_REG(0,data->temp_offset[nr]);
1807                        break ;
1808                }
1809                *nrels_mag = 1;
1810        } else if (operation == SENSORS_PROC_REAL_WRITE) {
1811                down(&data->update_lock);
1812                if (*nrels_mag > 0) {
1813                        switch( data->type ) {
1814                        case adm1027 :
1815                        default :
1816                            data->temp_offset[nr] = TEMP_TO_REG(results[0]);
1817                            break ;
1818                        case adt7463 :
1819                            data->temp_offset[nr] = EXTTEMP_TO_REG(results[0]);
1820                            break ;
1821                        };
1822                        lm85_write_value(client, ADM1027_REG_TEMP_OFFSET(nr),
1823                            data->temp_offset[nr]);
1824                }
1825                up(&data->update_lock);
1826        }
1827}
1828
1829void adm1027_fan_ppr(struct i2c_client *client, int operation, int ctl_name,
1830                int *nrels_mag, long *results)
1831{
1832        struct lm85_data *data = client->data;
1833        int old ;
1834
1835        if (ctl_name != ADM1027_SYSCTL_FAN_PPR)
1836                return ;  /* ERROR */
1837
1838        if (operation == SENSORS_PROC_REAL_INFO)
1839                *nrels_mag = 0;
1840        else if (operation == SENSORS_PROC_REAL_READ) {
1841                lm85_update_client(client);
1842                results[0] = PPR_FROM_REG(data->fan_ppr,0);
1843                results[1] = PPR_FROM_REG(data->fan_ppr,1);
1844                results[2] = PPR_FROM_REG(data->fan_ppr,2);
1845                results[3] = PPR_FROM_REG(data->fan_ppr,3);
1846                *nrels_mag = 4;
1847        } else if (operation == SENSORS_PROC_REAL_WRITE) {
1848                down(&data->update_lock);
1849                old = data->fan_ppr ;
1850                if (*nrels_mag > 3) {
1851                        old = (old & ~PPR_MASK(3)) | PPR_TO_REG(results[3],3);
1852                };
1853                if (*nrels_mag > 2) {
1854                        old = (old & ~PPR_MASK(2)) | PPR_TO_REG(results[2],2);
1855                };
1856                if (*nrels_mag > 1) {
1857                        old = (old & ~PPR_MASK(1)) | PPR_TO_REG(results[1],1);
1858                };
1859                if (*nrels_mag > 0) {
1860                        old = (old & ~PPR_MASK(0)) | PPR_TO_REG(results[0],0);
1861                        lm85_write_value(client, ADM1027_REG_FAN_PPR, old);
1862                        data->fan_ppr = old ;
1863                }
1864                up(&data->update_lock);
1865        }
1866}
1867
1868void adm1027_alarm_mask(struct i2c_client *client, int operation,
1869                int ctl_name, int *nrels_mag, long *results)
1870{
1871        struct lm85_data *data = client->data;
1872
1873        if( ctl_name != ADM1027_SYSCTL_ALARM_MASK )
1874                return ;  /* ERROR */
1875
1876        if (operation == SENSORS_PROC_REAL_INFO)
1877                *nrels_mag = 0;
1878        else if (operation == SENSORS_PROC_REAL_READ) {
1879                lm85_update_client(client);
1880                results[0] = INTMASK_FROM_REG(data->alarm_mask);
1881                *nrels_mag = 1;
1882        } else if (operation == SENSORS_PROC_REAL_WRITE) {
1883                down(&data->update_lock);
1884                if (*nrels_mag > 0) {
1885                        data->alarm_mask = INTMASK_TO_REG(results[0]);
1886                        lm85_write_value(client, ADM1027_REG_INTMASK,
1887                            data->alarm_mask);
1888                }
1889                up(&data->update_lock);
1890        }
1891}
1892
1893void adt7463_tmin_ctl(struct i2c_client *client, int operation, int ctl_name,
1894                int *nrels_mag, long *results)
1895{
1896        struct lm85_data *data = client->data;
1897        int nr = ctl_name - ADT7463_SYSCTL_TMIN_CTL1 ;
1898        u16 old ;
1899
1900        if (nr < 0 || nr > 2)
1901                return ;  /* ERROR */
1902
1903        if (operation == SENSORS_PROC_REAL_INFO)
1904                *nrels_mag = 0;
1905        else if (operation == SENSORS_PROC_REAL_READ) {
1906                old = data->tmin_ctl ;
1907                results[0] = (old & ( 0x2000 << nr )) != 0 ;
1908                results[1] = (old >> (nr*3)) & 0x07  ;
1909                results[2] = (old & ( 0x0400 << nr )) != 0 ;
1910                results[3] = OPPOINT_FROM_REG(data->oppoint[nr]);
1911                *nrels_mag = 4;
1912        } else if (operation == SENSORS_PROC_REAL_WRITE) {
1913                down(&data->update_lock);
1914                old = data->tmin_ctl ;
1915                if (*nrels_mag > 3) {
1916                        data->oppoint[nr] = OPPOINT_TO_REG(results[3]);
1917                        lm85_write_value(client, ADT7463_REG_OPPOINT(nr),
1918                            data->oppoint[nr]);
1919                };
1920                if (*nrels_mag > 2) {
1921                        if( results[2] ) {
1922                                old |= (0x0400 << nr) ;
1923                        } else {
1924                                old &= ~(0x0400 << nr) ;
1925                        }
1926                };
1927                if (*nrels_mag > 1) {
1928                        old &= ~(0x07 << (nr*3)) ;
1929                        old |= (results[1] & 0x07) << (nr*3) ;
1930                };
1931                if (*nrels_mag > 0) {
1932                        if( results[0] ) {
1933                                old |= 0x2000 << nr ;
1934                        } else {
1935                                old &= ~(0x2000 << nr) ;
1936                        }
1937                        lm85_write_value(client, ADT7463_REG_TMIN_CTL, old);
1938                        data->tmin_ctl = old ;
1939                }
1940                up(&data->update_lock);
1941        }
1942}
1943
1944void adt7463_therm_signal(struct i2c_client *client, int operation,
1945                int ctl_name, int *nrels_mag, long *results)
1946{
1947        struct lm85_data *data = client->data;
1948        int counts ;
1949
1950        if (ctl_name != ADT7463_SYSCTL_THERM_SIGNAL)
1951                return ;  /* ERROR */
1952
1953        if (operation == SENSORS_PROC_REAL_INFO)
1954                *nrels_mag = 0;
1955        else if (operation == SENSORS_PROC_REAL_READ) {
1956                /* Don't call update_client here because
1957                 *   ADT7463_REG_THERM has to be read every
1958                 *   5 seconds to prevent lost counts
1959                 */
1960                down(&data->update_lock);
1961                counts = lm85_read_value(client, ADT7463_REG_THERM) & 0xff;
1962                if( data->therm_total < LONG_MAX - 256 ) {
1963                    data->therm_total += counts ;
1964                }
1965                if( counts >= 255 ) {
1966                    ++data->therm_ovfl ;
1967                }
1968                up(&data->update_lock);
1969
1970                results[0] = data->therm_limit ;
1971                results[1] = data->therm_total ;
1972                results[2] = data->therm_ovfl ;
1973                *nrels_mag = 3;
1974        } else if (operation == SENSORS_PROC_REAL_WRITE) {
1975                down(&data->update_lock);
1976                /* therm_total and therm_ovfl are read only */
1977                if (*nrels_mag > 0) {
1978                        data->therm_limit = SENSORS_LIMIT(results[0],0,255);
1979                        lm85_write_value(client, ADT7463_REG_THERM_LIMIT,
1980                            data->therm_limit);
1981                };
1982                up(&data->update_lock);
1983        }
1984}
1985
1986
1987void emc6d100_in(struct i2c_client *client, int operation, int ctl_name,
1988             int *nrels_mag, long *results)
1989{
1990        struct lm85_data *data = client->data;
1991        int nr = ctl_name - EMC6D100_SYSCTL_IN5 +5;
1992
1993        if (nr < 5 || nr > 7)
1994                return ;  /* ERROR */
1995
1996        if (operation == SENSORS_PROC_REAL_INFO)
1997                *nrels_mag = 3;  /* 1.000 */
1998        else if (operation == SENSORS_PROC_REAL_READ) {
1999                lm85_update_client(client);
2000                results[0] = INS_FROM_REG(nr,data->in_min[nr]);
2001                results[1] = INS_FROM_REG(nr,data->in_max[nr]);
2002                results[2] = INS_FROM_REG(nr,data->in[nr]);
2003                *nrels_mag = 3;
2004        } else if (operation == SENSORS_PROC_REAL_WRITE) {
2005                down(&data->update_lock);
2006                if (*nrels_mag > 1) {
2007                        data->in_max[nr] = INS_TO_REG(nr,results[1]);
2008                        lm85_write_value(client, EMC6D100_REG_IN_MAX(nr),
2009                                         data->in_max[nr]);
2010                }
2011                if (*nrels_mag > 0) {
2012                        data->in_min[nr] = INS_TO_REG(nr,results[0]);
2013                        lm85_write_value(client, EMC6D100_REG_IN_MIN(nr),
2014                                         data->in_min[nr]);
2015                }
2016                up(&data->update_lock);
2017        }
2018}
2019
2020
2021static int __init sm_lm85_init(void)
2022{
2023        printk("lm85: Version %s (%s)\n", LM_VERSION, LM_DATE);
2024        printk("lm85: See http://www.penguincomputing.com/lm_sensors for more info.\n" );
2025        return i2c_add_driver(&lm85_driver);
2026}
2027
2028static void __exit sm_lm85_exit(void)
2029{
2030        i2c_del_driver(&lm85_driver);
2031}
2032
2033/* Thanks to Richard Barrington for adding the LM85 to sensors-detect.
2034 * Thanks to Margit Schubert-While <margitsw@t-online.de> for help with
2035 *     post 2.7.0 CVS changes
2036 */
2037MODULE_LICENSE("GPL");
2038MODULE_AUTHOR("Philip Pokorny <ppokorny@penguincomputing.com");
2039MODULE_DESCRIPTION("LM85-B, LM85-C driver");
2040
2041module_init(sm_lm85_init);
2042module_exit(sm_lm85_exit);
Note: See TracBrowser for help on using the browser.