sysfs-interface 10.9 KB
Newer Older
L
Linus Torvalds 已提交
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
Naming and data format standards for sysfs files
------------------------------------------------

The libsensors library offers an interface to the raw sensors data
through the sysfs interface. See libsensors documentation and source for
more further information. As of writing this document, libsensors
(from lm_sensors 2.8.3) is heavily chip-dependant. Adding or updating
support for any given chip requires modifying the library's code.
This is because libsensors was written for the procfs interface
older kernel modules were using, which wasn't standardized enough.
Recent versions of libsensors (from lm_sensors 2.8.2 and later) have
support for the sysfs interface, though.

The new sysfs interface was designed to be as chip-independant as
possible.

Note that motherboards vary widely in the connections to sensor chips.
There is no standard that ensures, for example, that the second
temperature sensor is connected to the CPU, or that the second fan is on
the CPU. Also, some values reported by the chips need some computation
before they make full sense. For example, most chips can only measure
voltages between 0 and +4V. Other voltages are scaled back into that
range using external resistors. Since the values of these resistors
can change from motherboard to motherboard, the conversions cannot be
hard coded into the driver and have to be done in user space.

For this reason, even if we aim at a chip-independant libsensors, it will
still require a configuration file (e.g. /etc/sensors.conf) for proper
values conversion, labeling of inputs and hiding of unused inputs.

An alternative method that some programs use is to access the sysfs
files directly. This document briefly describes the standards that the
drivers follow, so that an application program can scan for entries and
access this data in a simple and consistent way. That said, such programs
will have to implement conversion, labeling and hiding of inputs. For
this reason, it is still not recommended to bypass the library.

If you are developing a userspace application please send us feedback on
this standard.

Note that this standard isn't completely established yet, so it is subject
to changes, even important ones. One more reason to use the library instead
of accessing sysfs files directly.

Each chip gets its own directory in the sysfs /sys/devices tree.  To
find all sensor chips, it is easier to follow the symlinks from
/sys/i2c/devices/

All sysfs values are fixed point numbers.  To get the true value of some
of the values, you should divide by the specified value.

There is only one value per file, unlike the older /proc specification.
The common scheme for files naming is: <type><number>_<item>. Usual
types for sensor chips are "in" (voltage), "temp" (temperature) and
"fan" (fan). Usual items are "input" (measured value), "max" (high
threshold, "min" (low threshold). Numbering usually starts from 1,
except for voltages which start from 0 (because most data sheets use
this). A number is always used for elements that can be present more
than once, even if there is a single element of the given type on the
specific chip. Other files do not refer to a specific element, so
they have a simple name, and no number.

Alarms are direct indications read from the chips. The drivers do NOT
make comparisons of readings to thresholds. This allows violations
between readings to be caught and alarmed. The exact definition of an
alarm (for example, whether a threshold must be met or must be exceeded
to cause an alarm) is chip-dependent.


-------------------------------------------------------------------------

72 73 74 75 76 77 78 79
[0-*]	denotes any positive number starting from 0
[1-*]	denotes any positive number starting from 1
RO	read only value
RW	read/write value

Read/write values may be read-only for some chips, depending on the
hardware implementation.

L
Linus Torvalds 已提交
80 81 82 83
************
* Voltages *
************

84
in[0-*]_min	Voltage min value.
L
Linus Torvalds 已提交
85
		Unit: millivolt
86
		RW
L
Linus Torvalds 已提交
87
		
88
in[0-*]_max	Voltage max value.
L
Linus Torvalds 已提交
89
		Unit: millivolt
90
		RW
L
Linus Torvalds 已提交
91
		
92
in[0-*]_input	Voltage input value.
L
Linus Torvalds 已提交
93
		Unit: millivolt
94 95
		RO
		Voltage measured on the chip pin.
L
Linus Torvalds 已提交
96 97 98 99 100 101
		Actual voltage depends on the scaling resistors on the
		motherboard, as recommended in the chip datasheet.
		This varies by chip and by motherboard.
		Because of this variation, values are generally NOT scaled
		by the chip driver, and must be done by the application.
		However, some drivers (notably lm87 and via686a)
102
		do scale, because of internal resistors built into a chip.
L
Linus Torvalds 已提交
103 104 105 106 107 108 109 110 111 112 113 114 115
		These drivers will output the actual voltage.

		Typical usage:
			in0_*	CPU #1 voltage (not scaled)
			in1_*	CPU #2 voltage (not scaled)
			in2_*	3.3V nominal (not scaled)
			in3_*	5.0V nominal (scaled)
			in4_*	12.0V nominal (scaled)
			in5_*	-12.0V nominal (scaled)
			in6_*	-5.0V nominal (scaled)
			in7_*	varies
			in8_*	varies

116
cpu[0-*]_vid	CPU core reference voltage.
L
Linus Torvalds 已提交
117
		Unit: millivolt
118
		RO
L
Linus Torvalds 已提交
119 120 121
		Not always correct.

vrm		Voltage Regulator Module version number. 
122 123 124 125
		RW (but changing it should no more be necessary)
		Originally the VRM standard version multiplied by 10, but now
		an arbitrary number, as not all standards have a version
		number.
L
Linus Torvalds 已提交
126 127 128
		Affects the way the driver calculates the CPU core reference
		voltage from the vid pins.

129 130
Also see the Alarms section for status flags associated with voltages.

L
Linus Torvalds 已提交
131 132 133 134 135

********
* Fans *
********

136
fan[1-*]_min	Fan minimum value
L
Linus Torvalds 已提交
137
		Unit: revolution/min (RPM)
138
		RW
L
Linus Torvalds 已提交
139

140
fan[1-*]_input	Fan input value.
L
Linus Torvalds 已提交
141
		Unit: revolution/min (RPM)
142
		RO
L
Linus Torvalds 已提交
143

144
fan[1-*]_div	Fan divisor.
L
Linus Torvalds 已提交
145
		Integer value in powers of two (1, 2, 4, 8, 16, 32, 64, 128).
146
		RW
L
Linus Torvalds 已提交
147 148 149 150
		Some chips only support values 1, 2, 4 and 8.
		Note that this is actually an internal clock divisor, which
		affects the measurable speed range, not the read value.

151 152 153
Also see the Alarms section for status flags associated with fans.


L
Linus Torvalds 已提交
154 155 156 157
*******
* PWM *
*******

158
pwm[1-*]	Pulse width modulation fan control.
L
Linus Torvalds 已提交
159
		Integer value in the range 0 to 255
160
		RW
L
Linus Torvalds 已提交
161 162
		255 is max or 100%.

163
pwm[1-*]_enable
L
Linus Torvalds 已提交
164 165
		Switch PWM on and off.
		Not always present even if fan*_pwm is.
166 167 168 169 170 171 172 173 174 175
		0: turn off
		1: turn on in manual mode
		2+: turn on in automatic mode
		Check individual chip documentation files for automatic mode details.
		RW

pwm[1-*]_mode
		0: DC mode
		1: PWM mode
		RW
L
Linus Torvalds 已提交
176 177 178 179 180

pwm[1-*]_auto_channels_temp
		Select which temperature channels affect this PWM output in
		auto mode. Bitfield, 1 is temp1, 2 is temp2, 4 is temp3 etc...
		Which values are possible depend on the chip used.
181
		RW
L
Linus Torvalds 已提交
182 183 184 185 186 187 188

pwm[1-*]_auto_point[1-*]_pwm
pwm[1-*]_auto_point[1-*]_temp
pwm[1-*]_auto_point[1-*]_temp_hyst
		Define the PWM vs temperature curve. Number of trip points is
		chip-dependent. Use this for chips which associate trip points
		to PWM output channels.
189
		RW
L
Linus Torvalds 已提交
190 191 192 193 194 195 196 197 198

OR

temp[1-*]_auto_point[1-*]_pwm
temp[1-*]_auto_point[1-*]_temp
temp[1-*]_auto_point[1-*]_temp_hyst
		Define the PWM vs temperature curve. Number of trip points is
		chip-dependent. Use this for chips which associate trip points
		to temperature channels.
199
		RW
L
Linus Torvalds 已提交
200 201 202 203 204 205


****************
* Temperatures *
****************

206
temp[1-*]_type	Sensor type selection.
J
Jean Delvare 已提交
207
		Integers 1 to 4 or thermistor Beta value (typically 3435)
208
		RW
L
Linus Torvalds 已提交
209 210 211
		1: PII/Celeron Diode
		2: 3904 transistor
		3: thermal diode
J
Jean Delvare 已提交
212
		4: thermistor (default/unknown Beta)
L
Linus Torvalds 已提交
213 214
		Not all types are supported by all chips

215
temp[1-*]_max	Temperature max value.
L
Linus Torvalds 已提交
216
		Unit: millidegree Celcius
217
		RW
L
Linus Torvalds 已提交
218

219
temp[1-*]_min	Temperature min value.
L
Linus Torvalds 已提交
220
		Unit: millidegree Celcius
221
		RW
L
Linus Torvalds 已提交
222

223
temp[1-*]_max_hyst
L
Linus Torvalds 已提交
224 225 226 227
		Temperature hysteresis value for max limit.
		Unit: millidegree Celcius
		Must be reported as an absolute temperature, NOT a delta
		from the max value.
228
		RW
L
Linus Torvalds 已提交
229

230
temp[1-*]_input Temperature input value.
L
Linus Torvalds 已提交
231
		Unit: millidegree Celcius
232
		RO
L
Linus Torvalds 已提交
233

234
temp[1-*]_crit	Temperature critical value, typically greater than
L
Linus Torvalds 已提交
235 236
		corresponding temp_max values.
		Unit: millidegree Celcius
237
		RW
L
Linus Torvalds 已提交
238

239
temp[1-*]_crit_hyst
L
Linus Torvalds 已提交
240 241 242 243
		Temperature hysteresis value for critical limit.
		Unit: millidegree Celcius
		Must be reported as an absolute temperature, NOT a delta
		from the critical value.
244
		RW
L
Linus Torvalds 已提交
245

246 247 248 249 250 251
temp[1-4]_offset
		Temperature offset which is added to the temperature reading
		by the chip.
		Unit: millidegree Celsius
		Read/Write value.

L
Linus Torvalds 已提交
252 253 254 255 256 257 258
		If there are multiple temperature sensors, temp1_* is
		generally the sensor inside the chip itself,
		reported as "motherboard temperature".  temp2_* to
		temp4_* are generally sensors external to the chip
		itself, for example the thermal diode inside the CPU or
		a thermistor nearby.

259 260
Also see the Alarms section for status flags associated with temperatures.

L
Linus Torvalds 已提交
261 262 263 264 265 266 267 268

************
* Currents *
************

Note that no known chip provides current measurements as of writing,
so this part is theoretical, so to say.

269
curr[1-*]_max	Current max value
L
Linus Torvalds 已提交
270
		Unit: milliampere
271
		RW
L
Linus Torvalds 已提交
272

273
curr[1-*]_min	Current min value.
L
Linus Torvalds 已提交
274
		Unit: milliampere
275
		RW
L
Linus Torvalds 已提交
276

277
curr[1-*]_input	Current input value
L
Linus Torvalds 已提交
278
		Unit: milliampere
279
		RO
L
Linus Torvalds 已提交
280 281


282 283 284 285 286 287 288 289 290 291 292
**********
* Alarms *
**********

Each channel or limit may have an associated alarm file, containing a
boolean value. 1 means than an alarm condition exists, 0 means no alarm.

Usually a given chip will either use channel-related alarms, or
limit-related alarms, not both. The driver should just reflect the hardware
implementation.

293 294 295
in[0-*]_alarm
fan[1-*]_alarm
temp[1-*]_alarm
296
		Channel alarm
297 298 299
		0: no alarm
		1: alarm
		RO
300 301 302

OR

303 304 305 306 307 308
in[0-*]_min_alarm
in[0-*]_max_alarm
fan[1-*]_min_alarm
temp[1-*]_min_alarm
temp[1-*]_max_alarm
temp[1-*]_crit_alarm
309
		Limit alarm
310 311 312
		0: no alarm
		1: alarm
		RO
313 314 315 316 317 318

Each input channel may have an associated fault file. This can be used
to notify open diodes, unconnected fans etc. where the hardware
supports it. When this boolean has value 1, the measurement for that
channel should not be trusted.

319 320 321
in[0-*]_input_fault
fan[1-*]_input_fault
temp[1-*]_input_fault
322
		Input fault condition
323 324 325
		0: no fault occured
		1: fault condition
		RO
326 327 328 329

Some chips also offer the possibility to get beeped when an alarm occurs:

beep_enable	Master beep enable
330 331 332
		0: no beeps
		1: beeps
		RW
333

334 335 336
in[0-*]_beep
fan[1-*]_beep
temp[1-*]_beep
337
		Channel beep
338 339 340
		0: disable
		1: enable
		RW
341 342 343 344 345 346 347

In theory, a chip could provide per-limit beep masking, but no such chip
was seen so far.

Old drivers provided a different, non-standard interface to alarms and
beeps. These interface files are deprecated, but will be kept around
for compatibility reasons:
L
Linus Torvalds 已提交
348 349

alarms		Alarm bitmask.
350
		RO
L
Linus Torvalds 已提交
351 352 353 354 355 356 357
		Integer representation of one to four bytes.
		A '1' bit means an alarm.
		Chips should be programmed for 'comparator' mode so that
		the alarm will 'come back' after you read the register
		if it is still valid.
		Generally a direct representation of a chip's internal
		alarm registers; there is no standard for the position
358 359 360
		of individual bits. For this reason, the use of this
		interface file for new drivers is discouraged. Use
		individual *_alarm and *_fault files instead.
L
Linus Torvalds 已提交
361 362 363
		Bits are defined in kernel/include/sensors.h.

beep_mask	Bitmask for beep.
364 365 366
		Same format as 'alarms' with the same bit locations,
		use discouraged for the same reason. Use individual
		*_beep files instead.
367
		RW
L
Linus Torvalds 已提交
368

369 370 371 372 373

*********
* Other *
*********

L
Linus Torvalds 已提交
374
eeprom		Raw EEPROM data in binary form.
375
		RO
376 377

pec		Enable or disable PEC (SMBus only)
378 379 380
		0: disable
		1: enable
		RW