w83792d 6.1 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181
  1. Kernel driver w83792d
  2. =====================
  3. Supported chips:
  4. * Winbond W83792D
  5. Prefix: 'w83792d'
  6. Addresses scanned: I2C 0x2c - 0x2f
  7. Datasheet: http://www.winbond.com.tw
  8. Author: Shane Huang (Winbond)
  9. Updated: Roger Lucas
  10. Module Parameters
  11. -----------------
  12. * init int
  13. (default 1)
  14. Use 'init=0' to bypass initializing the chip.
  15. Try this if your computer crashes when you load the module.
  16. * force_subclients=bus,caddr,saddr,saddr
  17. This is used to force the i2c addresses for subclients of
  18. a certain chip. Example usage is `force_subclients=0,0x2f,0x4a,0x4b'
  19. to force the subclients of chip 0x2f on bus 0 to i2c addresses
  20. 0x4a and 0x4b.
  21. Description
  22. -----------
  23. This driver implements support for the Winbond W83792AD/D.
  24. Detection of the chip can sometimes be foiled because it can be in an
  25. internal state that allows no clean access (Bank with ID register is not
  26. currently selected). If you know the address of the chip, use a 'force'
  27. parameter; this will put it into a more well-behaved state first.
  28. The driver implements three temperature sensors, seven fan rotation speed
  29. sensors, nine voltage sensors, and two automatic fan regulation
  30. strategies called: Smart Fan I (Thermal Cruise mode) and Smart Fan II.
  31. The driver also implements up to seven fan control outputs: pwm1-7. Pwm1-7
  32. can be configured to PWM output or Analogue DC output via their associated
  33. pwmX_mode. Outputs pwm4 through pwm7 may or may not be present depending on
  34. how the W83792AD/D was configured by the BIOS.
  35. Automatic fan control mode is possible only for fan1-fan3.
  36. For all pwmX outputs, a value of 0 means minimum fan speed and a value of
  37. 255 means maximum fan speed.
  38. Temperatures are measured in degrees Celsius and measurement resolution is 1
  39. degC for temp1 and 0.5 degC for temp2 and temp3. An alarm is triggered when
  40. the temperature gets higher than the Overtemperature Shutdown value; it stays
  41. on until the temperature falls below the Hysteresis value.
  42. Fan rotation speeds are reported in RPM (rotations per minute). An alarm is
  43. triggered if the rotation speed has dropped below a programmable limit. Fan
  44. readings can be divided by a programmable divider (1, 2, 4, 8, 16, 32, 64 or
  45. 128) to give the readings more range or accuracy.
  46. Voltage sensors (also known as IN sensors) report their values in millivolts.
  47. An alarm is triggered if the voltage has crossed a programmable minimum
  48. or maximum limit.
  49. Alarms are provided as output from "realtime status register". Following bits
  50. are defined:
  51. bit - alarm on:
  52. 0 - in0
  53. 1 - in1
  54. 2 - temp1
  55. 3 - temp2
  56. 4 - temp3
  57. 5 - fan1
  58. 6 - fan2
  59. 7 - fan3
  60. 8 - in2
  61. 9 - in3
  62. 10 - in4
  63. 11 - in5
  64. 12 - in6
  65. 13 - VID change
  66. 14 - chassis
  67. 15 - fan7
  68. 16 - tart1
  69. 17 - tart2
  70. 18 - tart3
  71. 19 - in7
  72. 20 - in8
  73. 21 - fan4
  74. 22 - fan5
  75. 23 - fan6
  76. Tart will be asserted while target temperature cannot be achieved after 3 minutes
  77. of full speed rotation of corresponding fan.
  78. In addition to the alarms described above, there is a CHAS alarm on the chips
  79. which triggers if your computer case is open (This one is latched, contrary
  80. to realtime alarms).
  81. The chips only update values each 3 seconds; reading them more often will
  82. do no harm, but will return 'old' values.
  83. W83792D PROBLEMS
  84. ----------------
  85. Known problems:
  86. - This driver is only for Winbond W83792D C version device, there
  87. are also some motherboards with B version W83792D device. The
  88. calculation method to in6-in7(measured value, limits) is a little
  89. different between C and B version. C or B version can be identified
  90. by CR[0x49h].
  91. - The function of vid and vrm has not been finished, because I'm NOT
  92. very familiar with them. Adding support is welcome.
  93.   - The function of chassis open detection needs more tests.
  94. - If you have ASUS server board and chip was not found: Then you will
  95. need to upgrade to latest (or beta) BIOS. If it does not help please
  96. contact us.
  97. Fan control
  98. -----------
  99. Manual mode
  100. -----------
  101. Works as expected. You just need to specify desired PWM/DC value (fan speed)
  102. in appropriate pwm# file.
  103. Thermal cruise
  104. --------------
  105. In this mode, W83792D provides the Smart Fan system to automatically control
  106. fan speed to keep the temperatures of CPU and the system within specific
  107. range. At first a wanted temperature and interval must be set. This is done
  108. via thermal_cruise# file. The tolerance# file serves to create T +- tolerance
  109. interval. The fan speed will be lowered as long as the current temperature
  110. remains below the thermal_cruise# +- tolerance# value. Once the temperature
  111. exceeds the high limit (T+tolerance), the fan will be turned on with a
  112. specific speed set by pwm# and automatically controlled its PWM duty cycle
  113. with the temperature varying. Three conditions may occur:
  114. (1) If the temperature still exceeds the high limit, PWM duty
  115. cycle will increase slowly.
  116. (2) If the temperature goes below the high limit, but still above the low
  117. limit (T-tolerance), the fan speed will be fixed at the current speed because
  118. the temperature is in the target range.
  119. (3) If the temperature goes below the low limit, PWM duty cycle will decrease
  120. slowly to 0 or a preset stop value until the temperature exceeds the low
  121. limit. (The preset stop value handling is not yet implemented in driver)
  122. Smart Fan II
  123. ------------
  124. W83792D also provides a special mode for fan. Four temperature points are
  125. available. When related temperature sensors detects the temperature in preset
  126. temperature region (sf2_point@_fan# +- tolerance#) it will cause fans to run
  127. on programmed value from sf2_level@_fan#. You need to set four temperatures
  128. for each fan.
  129. /sys files
  130. ----------
  131. pwm[1-7] - this file stores PWM duty cycle or DC value (fan speed) in range:
  132. 0 (stop) to 255 (full)
  133. pwm[1-3]_enable - this file controls mode of fan/temperature control:
  134. * 0 Disabled
  135. * 1 Manual mode
  136. * 2 Smart Fan II
  137. * 3 Thermal Cruise
  138. pwm[1-7]_mode - Select PWM or DC mode
  139. * 0 DC
  140. * 1 PWM
  141. thermal_cruise[1-3] - Selects the desired temperature for cruise (degC)
  142. tolerance[1-3] - Value in degrees of Celsius (degC) for +- T
  143. sf2_point[1-4]_fan[1-3] - four temperature points for each fan for Smart Fan II
  144. sf2_level[1-3]_fan[1-3] - three PWM/DC levels for each fan for Smart Fan II