167 lines
		
	
	
	
		
			6.5 KiB
			
		
	
	
	
		
			Text
		
	
	
	
	
	
			
		
		
	
	
			167 lines
		
	
	
	
		
			6.5 KiB
			
		
	
	
	
		
			Text
		
	
	
	
	
	
Kernel driver f71805f
 | 
						|
=====================
 | 
						|
 | 
						|
Supported chips:
 | 
						|
  * Fintek F71805F/FG
 | 
						|
    Prefix: 'f71805f'
 | 
						|
    Addresses scanned: none, address read from Super I/O config space
 | 
						|
    Datasheet: Available from the Fintek website
 | 
						|
  * Fintek F71806F/FG
 | 
						|
    Prefix: 'f71872f'
 | 
						|
    Addresses scanned: none, address read from Super I/O config space
 | 
						|
    Datasheet: Available from the Fintek website
 | 
						|
  * Fintek F71872F/FG
 | 
						|
    Prefix: 'f71872f'
 | 
						|
    Addresses scanned: none, address read from Super I/O config space
 | 
						|
    Datasheet: Available from the Fintek website
 | 
						|
 | 
						|
Author: Jean Delvare <jdelvare@suse.de>
 | 
						|
 | 
						|
Thanks to Denis Kieft from Barracuda Networks for the donation of a
 | 
						|
test system (custom Jetway K8M8MS motherboard, with CPU and RAM) and
 | 
						|
for providing initial documentation.
 | 
						|
 | 
						|
Thanks to Kris Chen and Aaron Huang from Fintek for answering technical
 | 
						|
questions and providing additional documentation.
 | 
						|
 | 
						|
Thanks to Chris Lin from Jetway for providing wiring schematics and
 | 
						|
answering technical questions.
 | 
						|
 | 
						|
 | 
						|
Description
 | 
						|
-----------
 | 
						|
 | 
						|
The Fintek F71805F/FG Super I/O chip includes complete hardware monitoring
 | 
						|
capabilities. It can monitor up to 9 voltages (counting its own power
 | 
						|
source), 3 fans and 3 temperature sensors.
 | 
						|
 | 
						|
This chip also has fan controlling features, using either DC or PWM, in
 | 
						|
three different modes (one manual, two automatic).
 | 
						|
 | 
						|
The Fintek F71872F/FG Super I/O chip is almost the same, with two
 | 
						|
additional internal voltages monitored (VSB and battery). It also features
 | 
						|
6 VID inputs. The VID inputs are not yet supported by this driver.
 | 
						|
 | 
						|
The Fintek F71806F/FG Super-I/O chip is essentially the same as the
 | 
						|
F71872F/FG, and is undistinguishable therefrom.
 | 
						|
 | 
						|
The driver assumes that no more than one chip is present, which seems
 | 
						|
reasonable.
 | 
						|
 | 
						|
 | 
						|
Voltage Monitoring
 | 
						|
------------------
 | 
						|
 | 
						|
Voltages are sampled by an 8-bit ADC with a LSB of 8 mV. The supported
 | 
						|
range is thus from 0 to 2.040 V. Voltage values outside of this range
 | 
						|
need external resistors. An exception is in0, which is used to monitor
 | 
						|
the chip's own power source (+3.3V), and is divided internally by a
 | 
						|
factor 2. For the F71872F/FG, in9 (VSB) and in10 (battery) are also
 | 
						|
divided internally by a factor 2.
 | 
						|
 | 
						|
The two LSB of the voltage limit registers are not used (always 0), so
 | 
						|
you can only set the limits in steps of 32 mV (before scaling).
 | 
						|
 | 
						|
The wirings and resistor values suggested by Fintek are as follow:
 | 
						|
 | 
						|
        pin                                           expected
 | 
						|
        name    use           R1      R2     divider  raw val.
 | 
						|
 | 
						|
in0     VCC     VCC3.3V     int.    int.        2.00    1.65 V
 | 
						|
in1     VIN1    VTT1.2V      10K       -        1.00    1.20 V
 | 
						|
in2     VIN2    VRAM        100K    100K        2.00   ~1.25 V (1)
 | 
						|
in3     VIN3    VCHIPSET     47K    100K        1.47    2.24 V (2)
 | 
						|
in4     VIN4    VCC5V       200K     47K        5.25    0.95 V
 | 
						|
in5     VIN5    +12V        200K     20K       11.00    1.05 V
 | 
						|
in6     VIN6    VCC1.5V      10K       -        1.00    1.50 V
 | 
						|
in7     VIN7    VCORE        10K       -        1.00   ~1.40 V (1)
 | 
						|
in8     VIN8    VSB5V       200K     47K        1.00    0.95 V
 | 
						|
in10    VSB     VSB3.3V     int.    int.        2.00    1.65 V (3)
 | 
						|
in9     VBAT    VBATTERY    int.    int.        2.00    1.50 V (3)
 | 
						|
 | 
						|
(1) Depends on your hardware setup.
 | 
						|
(2) Obviously not correct, swapping R1 and R2 would make more sense.
 | 
						|
(3) F71872F/FG only.
 | 
						|
 | 
						|
These values can be used as hints at best, as motherboard manufacturers
 | 
						|
are free to use a completely different setup. As a matter of fact, the
 | 
						|
Jetway K8M8MS uses a significantly different setup. You will have to
 | 
						|
find out documentation about your own motherboard, and edit sensors.conf
 | 
						|
accordingly.
 | 
						|
 | 
						|
Each voltage measured has associated low and high limits, each of which
 | 
						|
triggers an alarm when crossed.
 | 
						|
 | 
						|
 | 
						|
Fan Monitoring
 | 
						|
--------------
 | 
						|
 | 
						|
Fan rotation speeds are reported as 12-bit values from a gated clock
 | 
						|
signal. Speeds down to 366 RPM can be measured. There is no theoretical
 | 
						|
high limit, but values over 6000 RPM seem to cause problem. The effective
 | 
						|
resolution is much lower than you would expect, the step between different
 | 
						|
register values being 10 rather than 1.
 | 
						|
 | 
						|
The chip assumes 2 pulse-per-revolution fans.
 | 
						|
 | 
						|
An alarm is triggered if the rotation speed drops below a programmable
 | 
						|
limit or is too low to be measured.
 | 
						|
 | 
						|
 | 
						|
Temperature Monitoring
 | 
						|
----------------------
 | 
						|
 | 
						|
Temperatures are reported in degrees Celsius. Each temperature measured
 | 
						|
has a high limit, those crossing triggers an alarm. There is an associated
 | 
						|
hysteresis value, below which the temperature has to drop before the
 | 
						|
alarm is cleared.
 | 
						|
 | 
						|
All temperature channels are external, there is no embedded temperature
 | 
						|
sensor. Each channel can be used for connecting either a thermal diode
 | 
						|
or a thermistor. The driver reports the currently selected mode, but
 | 
						|
doesn't allow changing it. In theory, the BIOS should have configured
 | 
						|
everything properly.
 | 
						|
 | 
						|
 | 
						|
Fan Control
 | 
						|
-----------
 | 
						|
 | 
						|
Both PWM (pulse-width modulation) and DC fan speed control methods are
 | 
						|
supported. The right one to use depends on external circuitry on the
 | 
						|
motherboard, so the driver assumes that the BIOS set the method
 | 
						|
properly. The driver will report the method, but won't let you change
 | 
						|
it.
 | 
						|
 | 
						|
When the PWM method is used, you can select the operating frequency,
 | 
						|
from 187.5 kHz (default) to 31 Hz. The best frequency depends on the
 | 
						|
fan model. As a rule of thumb, lower frequencies seem to give better
 | 
						|
control, but may generate annoying high-pitch noise. So a frequency just
 | 
						|
above the audible range, such as 25 kHz, may be a good choice; if this
 | 
						|
doesn't give you good linear control, try reducing it. Fintek recommends
 | 
						|
not going below 1 kHz, as the fan tachometers get confused by lower
 | 
						|
frequencies as well.
 | 
						|
 | 
						|
When the DC method is used, Fintek recommends not going below 5 V, which
 | 
						|
corresponds to a pwm value of 106 for the driver. The driver doesn't
 | 
						|
enforce this limit though.
 | 
						|
 | 
						|
Three different fan control modes are supported; the mode number is written
 | 
						|
to the pwm<n>_enable file.
 | 
						|
 | 
						|
* 1: Manual mode
 | 
						|
  You ask for a specific PWM duty cycle or DC voltage by writing to the
 | 
						|
  pwm<n> file.
 | 
						|
 | 
						|
* 2: Temperature mode
 | 
						|
  You define 3 temperature/fan speed trip points using the
 | 
						|
  pwm<n>_auto_point<m>_temp and _fan files. These define a staircase
 | 
						|
  relationship between temperature and fan speed with two additional points
 | 
						|
  interpolated between the values that you define. When the temperature
 | 
						|
  is below auto_point1_temp the fan is switched off.
 | 
						|
 | 
						|
* 3: Fan speed mode
 | 
						|
  You ask for a specific fan speed by writing to the fan<n>_target file.
 | 
						|
 | 
						|
Both of the automatic modes require that pwm1 corresponds to fan1, pwm2 to
 | 
						|
fan2 and pwm3 to fan3. Temperature mode also requires that temp1 corresponds
 | 
						|
to pwm1 and fan1, etc.
 |