hc
2024-03-22 619f0f87159c5dbd2755b1b0a0eb35784be84e7a
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
137
138
139
140
141
142
143
144
145
146
147
148
149
150
151
152
153
154
155
156
157
158
159
160
161
162
163
164
165
166
167
168
169
170
171
172
173
174
175
176
177
178
179
180
181
182
183
184
185
186
187
188
189
190
191
192
193
194
195
196
197
198
199
200
201
202
203
204
205
206
207
208
209
210
211
212
213
214
215
216
217
218
219
220
221
222
223
224
225
226
227
228
229
230
231
232
233
234
235
236
237
238
239
240
241
242
243
244
245
246
247
248
249
250
251
252
253
254
255
256
257
258
259
260
261
262
263
264
265
266
267
268
269
270
271
272
273
274
275
276
277
278
279
280
281
282
283
284
285
286
287
288
289
290
291
292
293
294
295
296
297
298
299
300
301
302
303
304
305
306
307
308
309
310
311
312
Kernel driver lm93
==================
 
Supported chips:
 
  * National Semiconductor LM93
 
    Prefix 'lm93'
 
    Addresses scanned: I2C 0x2c-0x2e
 
    Datasheet: http://www.national.com/ds.cgi/LM/LM93.pdf
 
  * National Semiconductor LM94
 
    Prefix 'lm94'
 
    Addresses scanned: I2C 0x2c-0x2e
 
    Datasheet: http://www.national.com/ds.cgi/LM/LM94.pdf
 
 
Authors:
   - Mark M. Hoffman <mhoffman@lightlink.com>
   - Ported to 2.6 by Eric J. Bowersox <ericb@aspsys.com>
   - Adapted to 2.6.20 by Carsten Emde <ce@osadl.org>
   - Modified for mainline integration by Hans J. Koch <hjk@hansjkoch.de>
 
Module Parameters
-----------------
 
* init: integer
  Set to non-zero to force some initializations (default is 0).
* disable_block: integer
  A "0" allows SMBus block data transactions if the host supports them.  A "1"
  disables SMBus block data transactions.  The default is 0.
* vccp_limit_type: integer array (2)
  Configures in7 and in8 limit type, where 0 means absolute and non-zero
  means relative.  "Relative" here refers to "Dynamic Vccp Monitoring using
  VID" from the datasheet.  It greatly simplifies the interface to allow
  only one set of limits (absolute or relative) to be in operation at a
  time (even though the hardware is capable of enabling both).  There's
  not a compelling use case for enabling both at once, anyway.  The default
  is "0,0".
* vid_agtl: integer
  A "0" configures the VID pins for V(ih) = 2.1V min, V(il) = 0.8V max.
  A "1" configures the VID pins for V(ih) = 0.8V min, V(il) = 0.4V max.
  (The latter setting is referred to as AGTL+ Compatible in the datasheet.)
  I.e. this parameter controls the VID pin input thresholds; if your VID
  inputs are not working, try changing this.  The default value is "0".
 
 
Hardware Description
--------------------
 
(from the datasheet)
 
The LM93 hardware monitor has a two wire digital interface compatible with
SMBus 2.0. Using an 8-bit ADC, the LM93 measures the temperature of two remote
diode connected transistors as well as its own die and 16 power supply
voltages. To set fan speed, the LM93 has two PWM outputs that are each
controlled by up to four temperature zones. The fancontrol algorithm is lookup
table based. The LM93 includes a digital filter that can be invoked to smooth
temperature readings for better control of fan speed. The LM93 has four
tachometer inputs to measure fan speed. Limit and status registers for all
measured values are included. The LM93 builds upon the functionality of
previous motherboard management ASICs and uses some of the LM85's features
(i.e. smart tachometer mode). It also adds measurement and control support
for dynamic Vccp monitoring and PROCHOT. It is designed to monitor a dual
processor Xeon class motherboard with a minimum of external components.
 
LM94 is also supported in LM93 compatible mode. Extra sensors and features of
LM94 are not supported.
 
 
User Interface
--------------
 
#PROCHOT
^^^^^^^^
 
The LM93 can monitor two #PROCHOT signals.  The results are found in the
sysfs files prochot1, prochot2, prochot1_avg, prochot2_avg, prochot1_max,
and prochot2_max.  prochot1_max and prochot2_max contain the user limits
for #PROCHOT1 and #PROCHOT2, respectively.  prochot1 and prochot2 contain
the current readings for the most recent complete time interval.  The
value of prochot1_avg and prochot2_avg is something like a 2 period
exponential moving average (but not quite - check the datasheet). Note
that this third value is calculated by the chip itself.  All values range
from 0-255 where 0 indicates no throttling, and 255 indicates > 99.6%.
 
The monitoring intervals for the two #PROCHOT signals is also configurable.
These intervals can be found in the sysfs files prochot1_interval and
prochot2_interval.  The values in these files specify the intervals for
#P1_PROCHOT and #P2_PROCHOT, respectively.  Selecting a value not in this
list will cause the driver to use the next largest interval.  The available
intervals are (in seconds):
 
#PROCHOT intervals:
   0.73, 1.46, 2.9, 5.8, 11.7, 23.3, 46.6, 93.2, 186, 372
 
It is possible to configure the LM93 to logically short the two #PROCHOT
signals.  I.e. when #P1_PROCHOT is asserted, the LM93 will automatically
assert #P2_PROCHOT, and vice-versa.  This mode is enabled by writing a
non-zero integer to the sysfs file prochot_short.
 
The LM93 can also override the #PROCHOT pins by driving a PWM signal onto
one or both of them.  When overridden, the signal has a period of 3.56 ms,
a minimum pulse width of 5 clocks (at 22.5kHz => 6.25% duty cycle), and
a maximum pulse width of 80 clocks (at 22.5kHz => 99.88% duty cycle).
 
The sysfs files prochot1_override and prochot2_override contain boolean
integers which enable or disable the override function for #P1_PROCHOT and
#P2_PROCHOT, respectively.  The sysfs file prochot_override_duty_cycle
contains a value controlling the duty cycle for the PWM signal used when
the override function is enabled.  This value ranges from 0 to 15, with 0
indicating minimum duty cycle and 15 indicating maximum.
 
#VRD_HOT
^^^^^^^^
 
The LM93 can monitor two #VRD_HOT signals. The results are found in the
sysfs files vrdhot1 and vrdhot2. There is one value per file: a boolean for
which 1 indicates #VRD_HOT is asserted and 0 indicates it is negated. These
files are read-only.
 
Smart Tach Mode (from the datasheet)::
 
   If a fan is driven using a low-side drive PWM, the tachometer
   output of the fan is corrupted. The LM93 includes smart tachometer
   circuitry that allows an accurate tachometer reading to be
   achieved despite the signal corruption.  In smart tach mode all
   four signals are measured within 4 seconds.
 
Smart tach mode is enabled by the driver by writing 1 or 2 (associating the
fan tachometer with a pwm) to the sysfs file fan<n>_smart_tach.  A zero
will disable the function for that fan.  Note that Smart tach mode cannot be
enabled if the PWM output frequency is 22500 Hz (see below).
 
Manual PWM
^^^^^^^^^^
 
The LM93 has a fixed or override mode for the two PWM outputs (although, there
are still some conditions that will override even this mode - see section
15.10.6 of the datasheet for details.)  The sysfs files pwm1_override
and pwm2_override are used to enable this mode; each is a boolean integer
where 0 disables and 1 enables the manual control mode.  The sysfs files pwm1
and pwm2 are used to set the manual duty cycle; each is an integer (0-255)
where 0 is 0% duty cycle, and 255 is 100%.  Note that the duty cycle values
are constrained by the hardware. Selecting a value which is not available
will cause the driver to use the next largest value.  Also note: when manual
PWM mode is disabled, the value of pwm1 and pwm2 indicates the current duty
cycle chosen by the h/w.
 
PWM Output Frequency
^^^^^^^^^^^^^^^^^^^^
 
The LM93 supports several different frequencies for the PWM output channels.
The sysfs files pwm1_freq and pwm2_freq are used to select the frequency. The
frequency values are constrained by the hardware.  Selecting a value which is
not available will cause the driver to use the next largest value.  Also note
that this parameter has implications for the Smart Tach Mode (see above).
 
PWM Output Frequencies (in Hz):
   12, 36, 48, 60, 72, 84, 96, 22500 (default)
 
Automatic PWM
^^^^^^^^^^^^^
 
The LM93 is capable of complex automatic fan control, with many different
points of configuration.  To start, each PWM output can be bound to any
combination of eight control sources.  The final PWM is the largest of all
individual control sources to which the PWM output is bound.
 
The eight control sources are: temp1-temp4 (aka "zones" in the datasheet),
#PROCHOT 1 & 2, and #VRDHOT 1 & 2.  The bindings are expressed as a bitmask
in the sysfs files pwm<n>_auto_channels, where a "1" enables the binding, and
a "0" disables it. The h/w default is 0x0f (all temperatures bound).
 
   ====== ===========
   0x01   Temp 1
   0x02   Temp 2
   0x04   Temp 3
   0x08   Temp 4
   0x10   #PROCHOT 1
   0x20   #PROCHOT 2
   0x40   #VRDHOT 1
   0x80   #VRDHOT 2
   ====== ===========
 
The function y = f(x) takes a source temperature x to a PWM output y.  This
function of the LM93 is derived from a base temperature and a table of 12
temperature offsets.  The base temperature is expressed in degrees C in the
sysfs files temp<n>_auto_base.  The offsets are expressed in cumulative
degrees C, with the value of offset <i> for temperature value <n> being
contained in the file temp<n>_auto_offset<i>.  E.g. if the base temperature
is 40C:
 
     ========== ======================= =============== =======
     offset #    temp<n>_auto_offset<i>    range        pwm
     ========== ======================= =============== =======
    1        0        -         25.00%
    2        0        -         28.57%
    3        1        40C - 41C     32.14%
    4        1        41C - 42C     35.71%
    5        2        42C - 44C     39.29%
    6        2        44C - 46C     42.86%
    7        2        48C - 50C     46.43%
    8        2        50C - 52C     50.00%
    9        2        52C - 54C     53.57%
   10        2        54C - 56C     57.14%
   11        2        56C - 58C     71.43%
   12        2        58C - 60C     85.71%
   -        -        > 60C        100.00%
     ========== ======================= =============== =======
 
Valid offsets are in the range 0C <= x <= 7.5C in 0.5C increments.
 
There is an independent base temperature for each temperature channel. Note,
however, there are only two tables of offsets: one each for temp[12] and
temp[34].  Therefore, any change to e.g. temp1_auto_offset<i> will also
affect temp2_auto_offset<i>.
 
The LM93 can also apply hysteresis to the offset table, to prevent unwanted
oscillation between two steps in the offsets table.  These values are found in
the sysfs files temp<n>_auto_offset_hyst.  The value in this file has the
same representation as in temp<n>_auto_offset<i>.
 
If a temperature reading falls below the base value for that channel, the LM93
will use the minimum PWM value.  These values are found in the sysfs files
temp<n>_auto_pwm_min.  Note, there are only two minimums: one each for temp[12]
and temp[34].  Therefore, any change to e.g. temp1_auto_pwm_min will also
affect temp2_auto_pwm_min.
 
PWM Spin-Up Cycle
^^^^^^^^^^^^^^^^^
 
A spin-up cycle occurs when a PWM output is commanded from 0% duty cycle to
some value > 0%.  The LM93 supports a minimum duty cycle during spin-up.  These
values are found in the sysfs files pwm<n>_auto_spinup_min. The value in this
file has the same representation as other PWM duty cycle values. The
duration of the spin-up cycle is also configurable.  These values are found in
the sysfs files pwm<n>_auto_spinup_time. The value in this file is
the spin-up time in seconds.  The available spin-up times are constrained by
the hardware.  Selecting a value which is not available will cause the driver
to use the next largest value.
 
Spin-up Durations:
   0 (disabled, h/w default), 0.1, 0.25, 0.4, 0.7, 1.0, 2.0, 4.0
 
#PROCHOT and #VRDHOT PWM Ramping
^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^
 
If the #PROCHOT or #VRDHOT signals are asserted while bound to a PWM output
channel, the LM93 will ramp the PWM output up to 100% duty cycle in discrete
steps. The duration of each step is configurable. There are two files, with
one value each in seconds: pwm_auto_prochot_ramp and pwm_auto_vrdhot_ramp.
The available ramp times are constrained by the hardware.  Selecting a value
which is not available will cause the driver to use the next largest value.
 
Ramp Times:
   0 (disabled, h/w default) to 0.75 in 0.05 second intervals
 
Fan Boost
^^^^^^^^^
 
For each temperature channel, there is a boost temperature: if the channel
exceeds this limit, the LM93 will immediately drive both PWM outputs to 100%.
This limit is expressed in degrees C in the sysfs files temp<n>_auto_boost.
There is also a hysteresis temperature for this function: after the boost
limit is reached, the temperature channel must drop below this value before
the boost function is disabled.  This temperature is also expressed in degrees
C in the sysfs files temp<n>_auto_boost_hyst.
 
GPIO Pins
^^^^^^^^^
 
The LM93 can monitor the logic level of four dedicated GPIO pins as well as the
four tach input pins.  GPIO0-GPIO3 correspond to (fan) tach 1-4, respectively.
All eight GPIOs are read by reading the bitmask in the sysfs file gpio.  The
LSB is GPIO0, and the MSB is GPIO7.
 
 
LM93 Unique sysfs Files
-----------------------
 
=========================== ===============================================
file                description
=========================== ===============================================
prochot<n>            current #PROCHOT %
prochot<n>_avg            moving average #PROCHOT %
prochot<n>_max            limit #PROCHOT %
prochot_short            enable or disable logical #PROCHOT pin short
prochot<n>_override        force #PROCHOT assertion as PWM
prochot_override_duty_cycle duty cycle for the PWM signal used when
               #PROCHOT is overridden
prochot<n>_interval        #PROCHOT PWM sampling interval
vrdhot<n>            0 means negated, 1 means asserted
fan<n>_smart_tach        enable or disable smart tach mode
pwm<n>_auto_channels        select control sources for PWM outputs
pwm<n>_auto_spinup_min        minimum duty cycle during spin-up
pwm<n>_auto_spinup_time        duration of spin-up
pwm_auto_prochot_ramp        ramp time per step when #PROCHOT asserted
pwm_auto_vrdhot_ramp        ramp time per step when #VRDHOT asserted
temp<n>_auto_base        temperature channel base
temp<n>_auto_offset[1-12]   temperature channel offsets
temp<n>_auto_offset_hyst    temperature channel offset hysteresis
temp<n>_auto_boost        temperature channel boost (PWMs to 100%)
               limit
temp<n>_auto_boost_hyst     temperature channel boost hysteresis
gpio                input state of 8 GPIO pins; read-only
=========================== ===============================================