w83781d 15 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402
  1. Kernel driver w83781d
  2. =====================
  3. Supported chips:
  4. * Winbond W83781D
  5. Prefix: 'w83781d'
  6. Addresses scanned: I2C 0x20 - 0x2f, ISA 0x290 (8 I/O ports)
  7. Datasheet: http://www.winbond-usa.com/products/winbond_products/pdfs/PCIC/w83781d.pdf
  8. * Winbond W83782D
  9. Prefix: 'w83782d'
  10. Addresses scanned: I2C 0x20 - 0x2f, ISA 0x290 (8 I/O ports)
  11. Datasheet: http://www.winbond.com/PDF/sheet/w83782d.pdf
  12. * Winbond W83783S
  13. Prefix: 'w83783s'
  14. Addresses scanned: I2C 0x2d
  15. Datasheet: http://www.winbond-usa.com/products/winbond_products/pdfs/PCIC/w83783s.pdf
  16. * Winbond W83627HF
  17. Prefix: 'w83627hf'
  18. Addresses scanned: I2C 0x20 - 0x2f, ISA 0x290 (8 I/O ports)
  19. Datasheet: http://www.winbond.com/PDF/sheet/w83627hf.pdf
  20. * Asus AS99127F
  21. Prefix: 'as99127f'
  22. Addresses scanned: I2C 0x28 - 0x2f
  23. Datasheet: Unavailable from Asus
  24. Authors:
  25. Frodo Looijaard <frodol@dds.nl>,
  26. Philip Edelbrock <phil@netroedge.com>,
  27. Mark Studebaker <mdsxyz123@yahoo.com>
  28. Module parameters
  29. -----------------
  30. * init int
  31. (default 1)
  32. Use 'init=0' to bypass initializing the chip.
  33. Try this if your computer crashes when you load the module.
  34. force_subclients=bus,caddr,saddr,saddr
  35. This is used to force the i2c addresses for subclients of
  36. a certain chip. Typical usage is `force_subclients=0,0x2d,0x4a,0x4b'
  37. to force the subclients of chip 0x2d on bus 0 to i2c addresses
  38. 0x4a and 0x4b. This parameter is useful for certain Tyan boards.
  39. Description
  40. -----------
  41. This driver implements support for the Winbond W83781D, W83782D, W83783S,
  42. W83627HF chips, and the Asus AS99127F chips. We will refer to them
  43. collectively as W8378* chips.
  44. There is quite some difference between these chips, but they are similar
  45. enough that it was sensible to put them together in one driver.
  46. The W83627HF chip is assumed to be identical to the ISA W83782D.
  47. The Asus chips are similar to an I2C-only W83782D.
  48. Chip #vin #fanin #pwm #temp wchipid vendid i2c ISA
  49. as99127f 7 3 0 3 0x31 0x12c3 yes no
  50. as99127f rev.2 (type_name = as99127f) 0x31 0x5ca3 yes no
  51. w83781d 7 3 0 3 0x10-1 0x5ca3 yes yes
  52. w83627hf 9 3 2 3 0x21 0x5ca3 yes yes(LPC)
  53. w83782d 9 3 2-4 3 0x30 0x5ca3 yes yes
  54. w83783s 5-6 3 2 1-2 0x40 0x5ca3 yes no
  55. Detection of these chips can sometimes be foiled because they can be in
  56. an internal state that allows no clean access. If you know the address
  57. of the chip, use a 'force' parameter; this will put them into a more
  58. well-behaved state first.
  59. The W8378* implements temperature sensors (three on the W83781D and W83782D,
  60. two on the W83783S), three fan rotation speed sensors, voltage sensors
  61. (seven on the W83781D, nine on the W83782D and six on the W83783S), VID
  62. lines, alarms with beep warnings, and some miscellaneous stuff.
  63. Temperatures are measured in degrees Celsius. There is always one main
  64. temperature sensor, and one (W83783S) or two (W83781D and W83782D) other
  65. sensors. An alarm is triggered for the main sensor once when the
  66. Overtemperature Shutdown limit is crossed; it is triggered again as soon as
  67. it drops below the Hysteresis value. A more useful behavior
  68. can be found by setting the Hysteresis value to +127 degrees Celsius; in
  69. this case, alarms are issued during all the time when the actual temperature
  70. is above the Overtemperature Shutdown value. The driver sets the
  71. hysteresis value for temp1 to 127 at initialization.
  72. For the other temperature sensor(s), an alarm is triggered when the
  73. temperature gets higher then the Overtemperature Shutdown value; it stays
  74. on until the temperature falls below the Hysteresis value. But on the
  75. W83781D, there is only one alarm that functions for both other sensors!
  76. Temperatures are guaranteed within a range of -55 to +125 degrees. The
  77. main temperature sensors has a resolution of 1 degree; the other sensor(s)
  78. of 0.5 degree.
  79. Fan rotation speeds are reported in RPM (rotations per minute). An alarm is
  80. triggered if the rotation speed has dropped below a programmable limit. Fan
  81. readings can be divided by a programmable divider (1, 2, 4 or 8 for the
  82. W83781D; 1, 2, 4, 8, 16, 32, 64 or 128 for the others) to give
  83. the readings more range or accuracy. Not all RPM values can accurately
  84. be represented, so some rounding is done. With a divider of 2, the lowest
  85. representable value is around 2600 RPM.
  86. Voltage sensors (also known as IN sensors) report their values in volts.
  87. An alarm is triggered if the voltage has crossed a programmable minimum
  88. or maximum limit. Note that minimum in this case always means 'closest to
  89. zero'; this is important for negative voltage measurements. All voltage
  90. inputs can measure voltages between 0 and 4.08 volts, with a resolution
  91. of 0.016 volt.
  92. The VID lines encode the core voltage value: the voltage level your processor
  93. should work with. This is hardcoded by the mainboard and/or processor itself.
  94. It is a value in volts. When it is unconnected, you will often find the
  95. value 3.50 V here.
  96. The W83782D and W83783S temperature conversion machine understands about
  97. several kinds of temperature probes. You can program the so-called
  98. beta value in the sensor files. '1' is the PII/Celeron diode, '2' is the
  99. TN3904 transistor, and 3435 the default thermistor value. Other values
  100. are (not yet) supported.
  101. In addition to the alarms described above, there is a CHAS alarm on the
  102. chips which triggers if your computer case is open.
  103. When an alarm goes off, you can be warned by a beeping signal through
  104. your computer speaker. It is possible to enable all beeping globally,
  105. or only the beeping for some alarms.
  106. If an alarm triggers, it will remain triggered until the hardware register
  107. is read at least once. This means that the cause for the alarm may
  108. already have disappeared! Note that in the current implementation, all
  109. hardware registers are read whenever any data is read (unless it is less
  110. than 1.5 seconds since the last update). This means that you can easily
  111. miss once-only alarms.
  112. The chips only update values each 1.5 seconds; reading them more often
  113. will do no harm, but will return 'old' values.
  114. AS99127F PROBLEMS
  115. -----------------
  116. The as99127f support was developed without the benefit of a datasheet.
  117. In most cases it is treated as a w83781d (although revision 2 of the
  118. AS99127F looks more like a w83782d).
  119. This support will be BETA until a datasheet is released.
  120. One user has reported problems with fans stopping
  121. occasionally.
  122. Note that the individual beep bits are inverted from the other chips.
  123. The driver now takes care of this so that user-space applications
  124. don't have to know about it.
  125. Known problems:
  126. - Problems with diode/thermistor settings (supported?)
  127. - One user reports fans stopping under high server load.
  128. - Revision 2 seems to have 2 PWM registers but we don't know
  129. how to handle them. More details below.
  130. These will not be fixed unless we get a datasheet.
  131. If you have problems, please lobby Asus to release a datasheet.
  132. Unfortunately several others have without success.
  133. Please do not send mail to us asking for better as99127f support.
  134. We have done the best we can without a datasheet.
  135. Please do not send mail to the author or the sensors group asking for
  136. a datasheet or ideas on how to convince Asus. We can't help.
  137. NOTES:
  138. -----
  139. 783s has no in1 so that in[2-6] are compatible with the 781d/782d.
  140. 783s pin is programmable for -5V or temp1; defaults to -5V,
  141. no control in driver so temp1 doesn't work.
  142. 782d and 783s datasheets differ on which is pwm1 and which is pwm2.
  143. We chose to follow 782d.
  144. 782d and 783s pin is programmable for fan3 input or pwm2 output;
  145. defaults to fan3 input.
  146. If pwm2 is enabled (with echo 255 1 > pwm2), then
  147. fan3 will report 0.
  148. 782d has pwm1-2 for ISA, pwm1-4 for i2c. (pwm3-4 share pins with
  149. the ISA pins)
  150. Data sheet updates:
  151. ------------------
  152. - PWM clock registers:
  153. 000: master / 512
  154. 001: master / 1024
  155. 010: master / 2048
  156. 011: master / 4096
  157. 100: master / 8192
  158. Answers from Winbond tech support
  159. ---------------------------------
  160. >
  161. > 1) In the W83781D data sheet section 7.2 last paragraph, it talks about
  162. > reprogramming the R-T table if the Beta of the thermistor is not
  163. > 3435K. The R-T table is described briefly in section 8.20.
  164. > What formulas do I use to program a new R-T table for a given Beta?
  165. >
  166. We are sorry that the calculation for R-T table value is
  167. confidential. If you have another Beta value of thermistor, we can help
  168. to calculate the R-T table for you. But you should give us real R-T
  169. Table which can be gotten by thermistor vendor. Therefore we will calculate
  170. them and obtain 32-byte data, and you can fill the 32-byte data to the
  171. register in Bank0.CR51 of W83781D.
  172. > 2) In the W83782D data sheet, it mentions that pins 38, 39, and 40 are
  173. > programmable to be either thermistor or Pentium II diode inputs.
  174. > How do I program them for diode inputs? I can't find any register
  175. > to program these to be diode inputs.
  176. --> You may program Bank0 CR[5Dh] and CR[59h] registers.
  177. CR[5Dh] bit 1(VTIN1) bit 2(VTIN2) bit 3(VTIN3)
  178. thermistor 0 0 0
  179. diode 1 1 1
  180. (error) CR[59h] bit 4(VTIN1) bit 2(VTIN2) bit 3(VTIN3)
  181. (right) CR[59h] bit 4(VTIN1) bit 5(VTIN2) bit 6(VTIN3)
  182. PII thermal diode 1 1 1
  183. 2N3904 diode 0 0 0
  184. Asus Clones
  185. -----------
  186. We have no datasheets for the Asus clones (AS99127F and ASB100 Bach).
  187. Here are some very useful information that were given to us by Alex Van
  188. Kaam about how to detect these chips, and how to read their values. He
  189. also gives advice for another Asus chipset, the Mozart-2 (which we
  190. don't support yet). Thanks Alex!
  191. I reworded some parts and added personal comments.
  192. # Detection:
  193. AS99127F rev.1, AS99127F rev.2 and ASB100:
  194. - I2C address range: 0x29 - 0x2F
  195. - If register 0x58 holds 0x31 then we have an Asus (either ASB100 or
  196. AS99127F)
  197. - Which one depends on register 0x4F (manufacturer ID):
  198. 0x06 or 0x94: ASB100
  199. 0x12 or 0xC3: AS99127F rev.1
  200. 0x5C or 0xA3: AS99127F rev.2
  201. Note that 0x5CA3 is Winbond's ID (WEC), which let us think Asus get their
  202. AS99127F rev.2 direct from Winbond. The other codes mean ATT and DVC,
  203. respectively. ATT could stand for Asustek something (although it would be
  204. very badly chosen IMHO), I don't know what DVC could stand for. Maybe
  205. these codes simply aren't meant to be decoded that way.
  206. Mozart-2:
  207. - I2C address: 0x77
  208. - If register 0x58 holds 0x56 or 0x10 then we have a Mozart-2
  209. - Of the Mozart there are 3 types:
  210. 0x58=0x56, 0x4E=0x94, 0x4F=0x36: Asus ASM58 Mozart-2
  211. 0x58=0x56, 0x4E=0x94, 0x4F=0x06: Asus AS2K129R Mozart-2
  212. 0x58=0x10, 0x4E=0x5C, 0x4F=0xA3: Asus ??? Mozart-2
  213. You can handle all 3 the exact same way :)
  214. # Temperature sensors:
  215. ASB100:
  216. - sensor 1: register 0x27
  217. - sensor 2 & 3 are the 2 LM75's on the SMBus
  218. - sensor 4: register 0x17
  219. Remark: I noticed that on Intel boards sensor 2 is used for the CPU
  220. and 4 is ignored/stuck, on AMD boards sensor 4 is the CPU and sensor 2 is
  221. either ignored or a socket temperature.
  222. AS99127F (rev.1 and 2 alike):
  223. - sensor 1: register 0x27
  224. - sensor 2 & 3 are the 2 LM75's on the SMBus
  225. Remark: Register 0x5b is suspected to be temperature type selector. Bit 1
  226. would control temp1, bit 3 temp2 and bit 5 temp3.
  227. Mozart-2:
  228. - sensor 1: register 0x27
  229. - sensor 2: register 0x13
  230. # Fan sensors:
  231. ASB100, AS99127F (rev.1 and 2 alike):
  232. - 3 fans, identical to the W83781D
  233. Mozart-2:
  234. - 2 fans only, 1350000/RPM/div
  235. - fan 1: register 0x28, divisor on register 0xA1 (bits 4-5)
  236. - fan 2: register 0x29, divisor on register 0xA1 (bits 6-7)
  237. # Voltages:
  238. This is where there is a difference between AS99127F rev.1 and 2.
  239. Remark: The difference is similar to the difference between
  240. W83781D and W83782D.
  241. ASB100:
  242. in0=r(0x20)*0.016
  243. in1=r(0x21)*0.016
  244. in2=r(0x22)*0.016
  245. in3=r(0x23)*0.016*1.68
  246. in4=r(0x24)*0.016*3.8
  247. in5=r(0x25)*(-0.016)*3.97
  248. in6=r(0x26)*(-0.016)*1.666
  249. AS99127F rev.1:
  250. in0=r(0x20)*0.016
  251. in1=r(0x21)*0.016
  252. in2=r(0x22)*0.016
  253. in3=r(0x23)*0.016*1.68
  254. in4=r(0x24)*0.016*3.8
  255. in5=r(0x25)*(-0.016)*3.97
  256. in6=r(0x26)*(-0.016)*1.503
  257. AS99127F rev.2:
  258. in0=r(0x20)*0.016
  259. in1=r(0x21)*0.016
  260. in2=r(0x22)*0.016
  261. in3=r(0x23)*0.016*1.68
  262. in4=r(0x24)*0.016*3.8
  263. in5=(r(0x25)*0.016-3.6)*5.14+3.6
  264. in6=(r(0x26)*0.016-3.6)*3.14+3.6
  265. Mozart-2:
  266. in0=r(0x20)*0.016
  267. in1=255
  268. in2=r(0x22)*0.016
  269. in3=r(0x23)*0.016*1.68
  270. in4=r(0x24)*0.016*4
  271. in5=255
  272. in6=255
  273. # PWM
  274. Additional info about PWM on the AS99127F (may apply to other Asus
  275. chips as well) by Jean Delvare as of 2004-04-09:
  276. AS99127F revision 2 seems to have two PWM registers at 0x59 and 0x5A,
  277. and a temperature sensor type selector at 0x5B (which basically means
  278. that they swapped registers 0x59 and 0x5B when you compare with Winbond
  279. chips).
  280. Revision 1 of the chip also has the temperature sensor type selector at
  281. 0x5B, but PWM registers have no effect.
  282. We don't know exactly how the temperature sensor type selection works.
  283. Looks like bits 1-0 are for temp1, bits 3-2 for temp2 and bits 5-4 for
  284. temp3, although it is possible that only the most significant bit matters
  285. each time. So far, values other than 0 always broke the readings.
  286. PWM registers seem to be split in two parts: bit 7 is a mode selector,
  287. while the other bits seem to define a value or threshold.
  288. When bit 7 is clear, bits 6-0 seem to hold a threshold value. If the value
  289. is below a given limit, the fan runs at low speed. If the value is above
  290. the limit, the fan runs at full speed. We have no clue as to what the limit
  291. represents. Note that there seem to be some inertia in this mode, speed
  292. changes may need some time to trigger. Also, an hysteresis mechanism is
  293. suspected since walking through all the values increasingly and then
  294. decreasingly led to slightly different limits.
  295. When bit 7 is set, bits 3-0 seem to hold a threshold value, while bits 6-4
  296. would not be significant. If the value is below a given limit, the fan runs
  297. at full speed, while if it is above the limit it runs at low speed (so this
  298. is the contrary of the other mode, in a way). Here again, we don't know
  299. what the limit is supposed to represent.
  300. One remarkable thing is that the fans would only have two or three
  301. different speeds (transitional states left apart), not a whole range as
  302. you usually get with PWM.
  303. As a conclusion, you can write 0x00 or 0x8F to the PWM registers to make
  304. fans run at low speed, and 0x7F or 0x80 to make them run at full speed.
  305. Please contact us if you can figure out how it is supposed to work. As
  306. long as we don't know more, the w83781d driver doesn't handle PWM on
  307. AS99127F chips at all.
  308. Additional info about PWM on the AS99127F rev.1 by Hector Martin:
  309. I've been fiddling around with the (in)famous 0x59 register and
  310. found out the following values do work as a form of coarse pwm:
  311. 0x80 - seems to turn fans off after some time(1-2 minutes)... might be
  312. some form of auto-fan-control based on temp? hmm (Qfan? this mobo is an
  313. old ASUS, it isn't marketed as Qfan. Maybe some beta pre-attemp at Qfan
  314. that was dropped at the BIOS)
  315. 0x81 - off
  316. 0x82 - slightly "on-ner" than off, but my fans do not get to move. I can
  317. hear the high-pitched PWM sound that motors give off at too-low-pwm.
  318. 0x83 - now they do move. Estimate about 70% speed or so.
  319. 0x84-0x8f - full on
  320. Changing the high nibble doesn't seem to do much except the high bit
  321. (0x80) must be set for PWM to work, else the current pwm doesn't seem to
  322. change.
  323. My mobo is an ASUS A7V266-E. This behavior is similar to what I got
  324. with speedfan under Windows, where 0-15% would be off, 15-2x% (can't
  325. remember the exact value) would be 70% and higher would be full on.