sphinx.addnodesdocument)}( rawsourcechildren]( translations LanguagesNode)}(hhh](h pending_xref)}(hhh]docutils.nodesTextChinese (Simplified)}parenthsba attributes}(ids]classes]names]dupnames]backrefs] refdomainstdreftypedoc reftarget!/translations/zh_CN/hwmon/w83781dmodnameN classnameN refexplicitutagnamehhh ubh)}(hhh]hChinese (Traditional)}hh2sbah}(h]h ]h"]h$]h&] refdomainh)reftypeh+ reftarget!/translations/zh_TW/hwmon/w83781dmodnameN classnameN refexplicituh1hhh ubh)}(hhh]hItalian}hhFsbah}(h]h ]h"]h$]h&] refdomainh)reftypeh+ reftarget!/translations/it_IT/hwmon/w83781dmodnameN classnameN refexplicituh1hhh ubh)}(hhh]hJapanese}hhZsbah}(h]h ]h"]h$]h&] refdomainh)reftypeh+ reftarget!/translations/ja_JP/hwmon/w83781dmodnameN classnameN refexplicituh1hhh ubh)}(hhh]hKorean}hhnsbah}(h]h ]h"]h$]h&] refdomainh)reftypeh+ reftarget!/translations/ko_KR/hwmon/w83781dmodnameN classnameN refexplicituh1hhh ubh)}(hhh]hSpanish}hhsbah}(h]h ]h"]h$]h&] refdomainh)reftypeh+ reftarget!/translations/sp_SP/hwmon/w83781dmodnameN classnameN refexplicituh1hhh ubeh}(h]h ]h"]h$]h&]current_languageEnglishuh1h hh _documenthsourceNlineNubhsection)}(hhh](htitle)}(hKernel driver w83781dh]hKernel driver w83781d}(hhhhhNhNubah}(h]h ]h"]h$]h&]uh1hhhhhh;/var/lib/git/docbuild/linux/Documentation/hwmon/w83781d.rsthKubh paragraph)}(hSupported chips:h]hSupported chips:}(hhhhhNhNubah}(h]h ]h"]h$]h&]uh1hhhhKhhhhubh block_quote)}(hX_* Winbond W83781D Prefix: 'w83781d' Addresses scanned: I2C 0x28 - 0x2f, ISA 0x290 (8 I/O ports) Datasheet: http://www.winbond-usa.com/products/winbond_products/pdfs/PCIC/w83781d.pdf * Winbond W83782D Prefix: 'w83782d' Addresses scanned: I2C 0x28 - 0x2f, ISA 0x290 (8 I/O ports) Datasheet: https://www.winbond.com * Winbond W83783S Prefix: 'w83783s' Addresses scanned: I2C 0x2d Datasheet: http://www.winbond-usa.com/products/winbond_products/pdfs/PCIC/w83783s.pdf * Asus AS99127F Prefix: 'as99127f' Addresses scanned: I2C 0x28 - 0x2f Datasheet: Unavailable from Asus h]h bullet_list)}(hhh](h list_item)}(hWinbond W83781D Prefix: 'w83781d' Addresses scanned: I2C 0x28 - 0x2f, ISA 0x290 (8 I/O ports) Datasheet: http://www.winbond-usa.com/products/winbond_products/pdfs/PCIC/w83781d.pdf h](h)}(hWinbond W83781Dh]hWinbond W83781D}(hhhhhNhNubah}(h]h ]h"]h$]h&]uh1hhhhKhhubh)}(hPrefix: 'w83781d'h]hPrefix: ‘w83781d’}(hhhhhNhNubah}(h]h ]h"]h$]h&]uh1hhhhKhhubh)}(h;Addresses scanned: I2C 0x28 - 0x2f, ISA 0x290 (8 I/O ports)h]h;Addresses scanned: I2C 0x28 - 0x2f, ISA 0x290 (8 I/O ports)}(hhhhhNhNubah}(h]h ]h"]h$]h&]uh1hhhhK hhubh)}(hUDatasheet: http://www.winbond-usa.com/products/winbond_products/pdfs/PCIC/w83781d.pdfh](h Datasheet: }(hjhhhNhNubh reference)}(hJhttp://www.winbond-usa.com/products/winbond_products/pdfs/PCIC/w83781d.pdfh]hJhttp://www.winbond-usa.com/products/winbond_products/pdfs/PCIC/w83781d.pdf}(hj hhhNhNubah}(h]h ]h"]h$]h&]refurijuh1j hjubeh}(h]h ]h"]h$]h&]uh1hhhhK hhubeh}(h]h ]h"]h$]h&]uh1hhhubh)}(hWinbond W83782D Prefix: 'w83782d' Addresses scanned: I2C 0x28 - 0x2f, ISA 0x290 (8 I/O ports) Datasheet: https://www.winbond.com h](h)}(hWinbond W83782Dh]hWinbond W83782D}(hj+hhhNhNubah}(h]h ]h"]h$]h&]uh1hhhhKhj'ubh)}(hPrefix: 'w83782d'h]hPrefix: ‘w83782d’}(hj9hhhNhNubah}(h]h ]h"]h$]h&]uh1hhhhKhj'ubh)}(h;Addresses scanned: I2C 0x28 - 0x2f, ISA 0x290 (8 I/O ports)h]h;Addresses scanned: I2C 0x28 - 0x2f, ISA 0x290 (8 I/O ports)}(hjGhhhNhNubah}(h]h ]h"]h$]h&]uh1hhhhKhj'ubh)}(h"Datasheet: https://www.winbond.comh](h Datasheet: }(hjUhhhNhNubj )}(hhttps://www.winbond.comh]hhttps://www.winbond.com}(hj]hhhNhNubah}(h]h ]h"]h$]h&]refurij_uh1j hjUubeh}(h]h ]h"]h$]h&]uh1hhhhKhj'ubeh}(h]h ]h"]h$]h&]uh1hhhubh)}(hWinbond W83783S Prefix: 'w83783s' Addresses scanned: I2C 0x2d Datasheet: http://www.winbond-usa.com/products/winbond_products/pdfs/PCIC/w83783s.pdf h](h)}(hWinbond W83783Sh]hWinbond W83783S}(hj|hhhNhNubah}(h]h ]h"]h$]h&]uh1hhhhKhjxubh)}(hPrefix: 'w83783s'h]hPrefix: ‘w83783s’}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1hhhhKhjxubh)}(hAddresses scanned: I2C 0x2dh]hAddresses scanned: I2C 0x2d}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1hhhhKhjxubh)}(hUDatasheet: http://www.winbond-usa.com/products/winbond_products/pdfs/PCIC/w83783s.pdfh](h Datasheet: }(hjhhhNhNubj )}(hJhttp://www.winbond-usa.com/products/winbond_products/pdfs/PCIC/w83783s.pdfh]hJhttp://www.winbond-usa.com/products/winbond_products/pdfs/PCIC/w83783s.pdf}(hjhhhNhNubah}(h]h ]h"]h$]h&]refurijuh1j hjubeh}(h]h ]h"]h$]h&]uh1hhhhKhjxubeh}(h]h ]h"]h$]h&]uh1hhhubh)}(hjAsus AS99127F Prefix: 'as99127f' Addresses scanned: I2C 0x28 - 0x2f Datasheet: Unavailable from Asus h](h)}(h Asus AS99127Fh]h Asus AS99127F}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1hhhhKhjubh)}(hPrefix: 'as99127f'h]hPrefix: ‘as99127f’}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1hhhhK hjubh)}(h"Addresses scanned: I2C 0x28 - 0x2fh]h"Addresses scanned: I2C 0x28 - 0x2f}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1hhhhK"hjubh)}(h Datasheet: Unavailable from Asush]h Datasheet: Unavailable from Asus}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1hhhhK$hjubeh}(h]h ]h"]h$]h&]uh1hhhubeh}(h]h ]h"]h$]h&]bullet*uh1hhhhKhhubah}(h]h ]h"]h$]h&]uh1hhhhKhhhhubh)}(hAuthors:h]hAuthors:}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1hhhhK(hhhhubh)}(ht- Frodo Looijaard , - Philip Edelbrock , - Mark Studebaker h]h)}(hhh](h)}(h Frodo Looijaard ,h]h)}(hj0h](hFrodo Looijaard <}(hj2hhhNhNubj )}(h frodol@dds.nlh]h frodol@dds.nl}(hj9hhhNhNubah}(h]h ]h"]h$]h&]refurimailto:frodol@dds.nluh1j hj2ubh>,}(hj2hhhNhNubeh}(h]h ]h"]h$]h&]uh1hhhhK*hj.ubah}(h]h ]h"]h$]h&]uh1hhj+ubh)}(h&Philip Edelbrock ,h]h)}(hj[h](hPhilip Edelbrock <}(hj]hhhNhNubj )}(hphil@netroedge.comh]hphil@netroedge.com}(hjdhhhNhNubah}(h]h ]h"]h$]h&]refurimailto:phil@netroedge.comuh1j hj]ubh>,}(hj]hhhNhNubeh}(h]h ]h"]h$]h&]uh1hhhhK+hjYubah}(h]h ]h"]h$]h&]uh1hhj+ubh)}(h&Mark Studebaker h]h)}(h%Mark Studebaker h](hMark Studebaker <}(hjhhhNhNubj )}(hmdsxyz123@yahoo.comh]hmdsxyz123@yahoo.com}(hjhhhNhNubah}(h]h ]h"]h$]h&]refurimailto:mdsxyz123@yahoo.comuh1j hjubh>}(hjhhhNhNubeh}(h]h ]h"]h$]h&]uh1hhhhK,hjubah}(h]h ]h"]h$]h&]uh1hhj+ubeh}(h]h ]h"]h$]h&]j-uh1hhhhK*hj'ubah}(h]h ]h"]h$]h&]uh1hhhhK*hhhhubh)}(hhh](h)}(hModule parametersh]hModule parameters}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1hhjhhhhhK/ubh)}(hhh](h)}(hinit int (default 1) Use 'init=0' to bypass initializing the chip. Try this if your computer crashes when you load the module. h]hdefinition_list)}(hhh]hdefinition_list_item)}(hinit int (default 1) Use 'init=0' to bypass initializing the chip. Try this if your computer crashes when you load the module. h](hterm)}(hinit inth]hinit int}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1jhhhK5hjubh definition)}(hhh](h)}(h (default 1)h]h (default 1)}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1hhhhK2hjubh)}(hiUse 'init=0' to bypass initializing the chip. Try this if your computer crashes when you load the module.h]hmUse ‘init=0’ to bypass initializing the chip. Try this if your computer crashes when you load the module.}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1hhhhK4hjubeh}(h]h ]h"]h$]h&]uh1jhjubeh}(h]h ]h"]h$]h&]uh1jhhhK5hjubah}(h]h ]h"]h$]h&]uh1jhjubah}(h]h ]h"]h$]h&]uh1hhjhhhNhNubh)}(hreset int (default 0) The driver used to reset the chip on load, but does no more. Use 'reset=1' to restore the old behavior. Report if you need to do this. h]j)}(hhh]j)}(hreset int (default 0) The driver used to reset the chip on load, but does no more. Use 'reset=1' to restore the old behavior. Report if you need to do this. h](j)}(h reset inth]h reset int}(hj4hhhNhNubah}(h]h ]h"]h$]h&]uh1jhhhK:hj0ubj)}(hhh]h)}(h(default 0) The driver used to reset the chip on load, but does no more. Use 'reset=1' to restore the old behavior. Report if you need to do this.h]h(default 0) The driver used to reset the chip on load, but does no more. Use ‘reset=1’ to restore the old behavior. Report if you need to do this.}(hjEhhhNhNubah}(h]h ]h"]h$]h&]uh1hhhhK8hjBubah}(h]h ]h"]h$]h&]uh1jhj0ubeh}(h]h ]h"]h$]h&]uh1jhhhK:hj-ubah}(h]h ]h"]h$]h&]uh1jhj)ubah}(h]h ]h"]h$]h&]uh1hhjhhhNhNubeh}(h]h ]h"]h$]h&]jjuh1hhhhK1hjhhubj)}(hhh]j)}(hX&force_subclients=bus,caddr,saddr,saddr This is used to force the i2c addresses for subclients of a certain chip. Typical usage is `force_subclients=0,0x2d,0x4a,0x4b` to force the subclients of chip 0x2d on bus 0 to i2c addresses 0x4a and 0x4b. This parameter is useful for certain Tyan boards. h](j)}(h&force_subclients=bus,caddr,saddr,saddrh]h&force_subclients=bus,caddr,saddr,saddr}(hjxhhhNhNubah}(h]h ]h"]h$]h&]uh1jhhhK@hjtubj)}(hhh]h)}(hThis is used to force the i2c addresses for subclients of a certain chip. Typical usage is `force_subclients=0,0x2d,0x4a,0x4b` to force the subclients of chip 0x2d on bus 0 to i2c addresses 0x4a and 0x4b. This parameter is useful for certain Tyan boards.h](h[This is used to force the i2c addresses for subclients of a certain chip. Typical usage is }(hjhhhNhNubhtitle_reference)}(h#`force_subclients=0,0x2d,0x4a,0x4b`h]h!force_subclients=0,0x2d,0x4a,0x4b}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1jhjubh to force the subclients of chip 0x2d on bus 0 to i2c addresses 0x4a and 0x4b. This parameter is useful for certain Tyan boards.}(hjhhhNhNubeh}(h]h ]h"]h$]h&]uh1hhhhK=hjubah}(h]h ]h"]h$]h&]uh1jhjtubeh}(h]h ]h"]h$]h&]uh1jhhhK@hjqubah}(h]h ]h"]h$]h&]uh1jhjhhhhhNubeh}(h]module-parametersah ]h"]module parametersah$]h&]uh1hhhhhhhhK/ubh)}(hhh](h)}(h Descriptionh]h Description}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1hhjhhhhhKCubh)}(hThis driver implements support for the Winbond W83781D, W83782D, W83783S chips, and the Asus AS99127F chips. We will refer to them collectively as W8378* chips.h]hThis driver implements support for the Winbond W83781D, W83782D, W83783S chips, and the Asus AS99127F chips. We will refer to them collectively as W8378* chips.}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1hhhhKEhjhhubh)}(hThere is quite some difference between these chips, but they are similar enough that it was sensible to put them together in one driver. The Asus chips are similar to an I2C-only W83782D.h]hThere is quite some difference between these chips, but they are similar enough that it was sensible to put them together in one driver. The Asus chips are similar to an I2C-only W83782D.}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1hhhhKIhjhhubhtable)}(hhh]htgroup)}(hhh](hcolspec)}(hhh]h}(h]h ]h"]h$]h&]colwidthK uh1jhjubj)}(hhh]h}(h]h ]h"]h$]h&]colwidthK uh1jhjubj)}(hhh]h}(h]h ]h"]h$]h&]colwidthKuh1jhjubj)}(hhh]h}(h]h ]h"]h$]h&]colwidthKuh1jhjubj)}(hhh]h}(h]h ]h"]h$]h&]colwidthKuh1jhjubj)}(hhh]h}(h]h ]h"]h$]h&]colwidthK uh1jhjubj)}(hhh]h}(h]h ]h"]h$]h&]colwidthKuh1jhjubj)}(hhh]h}(h]h ]h"]h$]h&]colwidthKuh1jhjubj)}(hhh]h}(h]h ]h"]h$]h&]colwidthKuh1jhjubhtbody)}(hhh](hrow)}(hhh](hentry)}(hhh]h)}(hChiph]hChip}(hjghhhNhNubah}(h]h ]h"]h$]h&]uh1hhhhKNhjdubah}(h]h ]h"]h$]h&]uh1jbhj_ubjc)}(hhh]h)}(h#vinh]h#vin}(hj~hhhNhNubah}(h]h ]h"]h$]h&]uh1hhhhKNhj{ubah}(h]h ]h"]h$]h&]uh1jbhj_ubjc)}(hhh]h)}(h#faninh]h#fanin}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1hhhhKNhjubah}(h]h ]h"]h$]h&]uh1jbhj_ubjc)}(hhh]h)}(h#pwmh]h#pwm}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1hhhhKNhjubah}(h]h ]h"]h$]h&]uh1jbhj_ubjc)}(hhh]h)}(h#temph]h#temp}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1hhhhKNhjubah}(h]h ]h"]h$]h&]uh1jbhj_ubjc)}(hhh]h)}(hwchipidh]hwchipid}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1hhhhKNhjubah}(h]h ]h"]h$]h&]uh1jbhj_ubjc)}(hhh]h)}(hvendidh]hvendid}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1hhhhKNhjubah}(h]h ]h"]h$]h&]uh1jbhj_ubjc)}(hhh]h)}(hi2ch]hi2c}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1hhhhKNhjubah}(h]h ]h"]h$]h&]uh1jbhj_ubjc)}(hhh]h)}(hISAh]hISA}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1hhhhKNhjubah}(h]h ]h"]h$]h&]uh1jbhj_ubeh}(h]h ]h"]h$]h&]uh1j]hjZubj^)}(hhh](jc)}(hhh]h)}(has99127fh]has99127f}(hj?hhhNhNubah}(h]h ]h"]h$]h&]uh1hhhhKPhj<ubah}(h]h ]h"]h$]h&]uh1jbhj9ubjc)}(hhh]h)}(h7h]h7}(hjVhhhNhNubah}(h]h ]h"]h$]h&]uh1hhhhKPhjSubah}(h]h ]h"]h$]h&]uh1jbhj9ubjc)}(hhh]h)}(h3h]h3}(hjmhhhNhNubah}(h]h ]h"]h$]h&]uh1hhhhKPhjjubah}(h]h ]h"]h$]h&]uh1jbhj9ubjc)}(hhh]h)}(h0h]h0}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1hhhhKPhjubah}(h]h ]h"]h$]h&]uh1jbhj9ubjc)}(hhh]h)}(hjoh]h3}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1hhhhKPhjubah}(h]h ]h"]h$]h&]uh1jbhj9ubjc)}(hhh]h)}(h0x31h]h0x31}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1hhhhKPhjubah}(h]h ]h"]h$]h&]uh1jbhj9ubjc)}(hhh]h)}(h0x12c3h]h0x12c3}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1hhhhKPhjubah}(h]h ]h"]h$]h&]uh1jbhj9ubjc)}(hhh]h)}(hyesh]hyes}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1hhhhKPhjubah}(h]h ]h"]h$]h&]uh1jbhj9ubjc)}(hhh]h)}(hnoh]hno}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1hhhhKPhjubah}(h]h ]h"]h$]h&]uh1jbhj9ubeh}(h]h ]h"]h$]h&]uh1j]hjZubj^)}(hhh](jc)}(hhh]h)}(h%as99127f rev.2 (type_name = as99127f)h]h%as99127f rev.2 (type_name = as99127f)}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1hhhhKRhjubah}(h]h ]h"]h$]h&]morecolsKuh1jbhjubjc)}(hhh]h)}(h0x31h]h0x31}(hj.hhhNhNubah}(h]h ]h"]h$]h&]uh1hhhhKRhj+ubah}(h]h ]h"]h$]h&]uh1jbhjubjc)}(hhh]h)}(h0x5ca3h]h0x5ca3}(hjEhhhNhNubah}(h]h ]h"]h$]h&]uh1hhhhKRhjBubah}(h]h ]h"]h$]h&]uh1jbhjubjc)}(hhh]h)}(hyesh]hyes}(hj\hhhNhNubah}(h]h ]h"]h$]h&]uh1hhhhKRhjYubah}(h]h ]h"]h$]h&]uh1jbhjubjc)}(hhh]h)}(hnoh]hno}(hjshhhNhNubah}(h]h ]h"]h$]h&]uh1hhhhKRhjpubah}(h]h ]h"]h$]h&]uh1jbhjubeh}(h]h ]h"]h$]h&]uh1j]hjZubj^)}(hhh](jc)}(hhh]h)}(hw83781dh]hw83781d}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1hhhhKThjubah}(h]h ]h"]h$]h&]uh1jbhjubjc)}(hhh]h)}(hjXh]h7}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1hhhhKThjubah}(h]h ]h"]h$]h&]uh1jbhjubjc)}(hhh]h)}(hjoh]h3}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1hhhhKThjubah}(h]h ]h"]h$]h&]uh1jbhjubjc)}(hhh]h)}(hjh]h0}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1hhhhKThjubah}(h]h ]h"]h$]h&]uh1jbhjubjc)}(hhh]h)}(hjoh]h3}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1hhhhKThjubah}(h]h ]h"]h$]h&]uh1jbhjubjc)}(hhh]h)}(h0x10-1h]h0x10-1}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1hhhhKThjubah}(h]h ]h"]h$]h&]uh1jbhjubjc)}(hhh]h)}(h0x5ca3h]h0x5ca3}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1hhhhKThjubah}(h]h ]h"]h$]h&]uh1jbhjubjc)}(hhh]h)}(hyesh]hyes}(hj0hhhNhNubah}(h]h ]h"]h$]h&]uh1hhhhKThj-ubah}(h]h ]h"]h$]h&]uh1jbhjubjc)}(hhh]h)}(hyesh]hyes}(hjGhhhNhNubah}(h]h ]h"]h$]h&]uh1hhhhKThjDubah}(h]h ]h"]h$]h&]uh1jbhjubeh}(h]h ]h"]h$]h&]uh1j]hjZubj^)}(hhh](jc)}(hhh]h)}(hw83782dh]hw83782d}(hjghhhNhNubah}(h]h ]h"]h$]h&]uh1hhhhKVhjdubah}(h]h ]h"]h$]h&]uh1jbhjaubjc)}(hhh]h)}(h9h]h9}(hj~hhhNhNubah}(h]h ]h"]h$]h&]uh1hhhhKVhj{ubah}(h]h ]h"]h$]h&]uh1jbhjaubjc)}(hhh]h)}(hjoh]h3}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1hhhhKVhjubah}(h]h ]h"]h$]h&]uh1jbhjaubjc)}(hhh]h)}(h2-4h]h2-4}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1hhhhKVhjubah}(h]h ]h"]h$]h&]uh1jbhjaubjc)}(hhh]h)}(hjoh]h3}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1hhhhKVhjubah}(h]h ]h"]h$]h&]uh1jbhjaubjc)}(hhh]h)}(h0x30h]h0x30}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1hhhhKVhjubah}(h]h ]h"]h$]h&]uh1jbhjaubjc)}(hhh]h)}(h0x5ca3h]h0x5ca3}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1hhhhKVhjubah}(h]h ]h"]h$]h&]uh1jbhjaubjc)}(hhh]h)}(hyesh]hyes}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1hhhhKVhjubah}(h]h ]h"]h$]h&]uh1jbhjaubjc)}(hhh]h)}(hyesh]hyes}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1hhhhKVhjubah}(h]h ]h"]h$]h&]uh1jbhjaubeh}(h]h ]h"]h$]h&]uh1j]hjZubj^)}(hhh](jc)}(hhh]h)}(hw83783sh]hw83783s}(hj=hhhNhNubah}(h]h ]h"]h$]h&]uh1hhhhKXhj:ubah}(h]h ]h"]h$]h&]uh1jbhj7ubjc)}(hhh]h)}(h5-6h]h5-6}(hjThhhNhNubah}(h]h ]h"]h$]h&]uh1hhhhKXhjQubah}(h]h ]h"]h$]h&]uh1jbhj7ubjc)}(hhh]h)}(hjoh]h3}(hjkhhhNhNubah}(h]h ]h"]h$]h&]uh1hhhhKXhjhubah}(h]h ]h"]h$]h&]uh1jbhj7ubjc)}(hhh]h)}(h2h]h2}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1hhhhKXhj~ubah}(h]h ]h"]h$]h&]uh1jbhj7ubjc)}(hhh]h)}(h1-2h]h1-2}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1hhhhKXhjubah}(h]h ]h"]h$]h&]uh1jbhj7ubjc)}(hhh]h)}(h0x40h]h0x40}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1hhhhKXhjubah}(h]h ]h"]h$]h&]uh1jbhj7ubjc)}(hhh]h)}(h0x5ca3h]h0x5ca3}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1hhhhKXhjubah}(h]h ]h"]h$]h&]uh1jbhj7ubjc)}(hhh]h)}(hyesh]hyes}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1hhhhKXhjubah}(h]h ]h"]h$]h&]uh1jbhj7ubjc)}(hhh]h)}(hnoh]hno}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1hhhhKXhjubah}(h]h ]h"]h$]h&]uh1jbhj7ubeh}(h]h ]h"]h$]h&]uh1j]hjZubeh}(h]h ]h"]h$]h&]uh1jXhjubeh}(h]h ]h"]h$]h&]colsK uh1jhjubah}(h]h ]h"]h$]h&]uh1jhjhhhhhNubh)}(hDetection of these chips can sometimes be foiled because they can be in an internal state that allows no clean access. If you know the address of the chip, use a 'force' parameter; this will put them into a more well-behaved state first.h]hDetection of these chips can sometimes be foiled because they can be in an internal state that allows no clean access. If you know the address of the chip, use a ‘force’ parameter; this will put them into a more well-behaved state first.}(hj! hhhNhNubah}(h]h ]h"]h$]h&]uh1hhhhK[hjhhubh)}(hXThe W8378* implements temperature sensors (three on the W83781D and W83782D, two on the W83783S), three fan rotation speed sensors, voltage sensors (seven on the W83781D, nine on the W83782D and six on the W83783S), VID lines, alarms with beep warnings, and some miscellaneous stuff.h]hXThe W8378* implements temperature sensors (three on the W83781D and W83782D, two on the W83783S), three fan rotation speed sensors, voltage sensors (seven on the W83781D, nine on the W83782D and six on the W83783S), VID lines, alarms with beep warnings, and some miscellaneous stuff.}(hj/ hhhNhNubah}(h]h ]h"]h$]h&]uh1hhhhK`hjhhubh)}(hXdTemperatures are measured in degrees Celsius. There is always one main temperature sensor, and one (W83783S) or two (W83781D and W83782D) other sensors. An alarm is triggered for the main sensor once when the Overtemperature Shutdown limit is crossed; it is triggered again as soon as it drops below the Hysteresis value. A more useful behavior can be found by setting the Hysteresis value to +127 degrees Celsius; in this case, alarms are issued during all the time when the actual temperature is above the Overtemperature Shutdown value. The driver sets the hysteresis value for temp1 to 127 at initialization.h]hXdTemperatures are measured in degrees Celsius. There is always one main temperature sensor, and one (W83783S) or two (W83781D and W83782D) other sensors. An alarm is triggered for the main sensor once when the Overtemperature Shutdown limit is crossed; it is triggered again as soon as it drops below the Hysteresis value. A more useful behavior can be found by setting the Hysteresis value to +127 degrees Celsius; in this case, alarms are issued during all the time when the actual temperature is above the Overtemperature Shutdown value. The driver sets the hysteresis value for temp1 to 127 at initialization.}(hj= hhhNhNubah}(h]h ]h"]h$]h&]uh1hhhhKehjhhubh)}(hXFor the other temperature sensor(s), an alarm is triggered when the temperature gets higher then the Overtemperature Shutdown value; it stays on until the temperature falls below the Hysteresis value. But on the W83781D, there is only one alarm that functions for both other sensors! Temperatures are guaranteed within a range of -55 to +125 degrees. The main temperature sensors has a resolution of 1 degree; the other sensor(s) of 0.5 degree.h]hXFor the other temperature sensor(s), an alarm is triggered when the temperature gets higher then the Overtemperature Shutdown value; it stays on until the temperature falls below the Hysteresis value. But on the W83781D, there is only one alarm that functions for both other sensors! Temperatures are guaranteed within a range of -55 to +125 degrees. The main temperature sensors has a resolution of 1 degree; the other sensor(s) of 0.5 degree.}(hjK hhhNhNubah}(h]h ]h"]h$]h&]uh1hhhhKohjhhubh)}(hXFan rotation speeds are reported in RPM (rotations per minute). An alarm is triggered if the rotation speed has dropped below a programmable limit. Fan readings can be divided by a programmable divider (1, 2, 4 or 8 for the W83781D; 1, 2, 4, 8, 16, 32, 64 or 128 for the others) to give the readings more range or accuracy. Not all RPM values can accurately be represented, so some rounding is done. With a divider of 2, the lowest representable value is around 2600 RPM.h]hXFan rotation speeds are reported in RPM (rotations per minute). An alarm is triggered if the rotation speed has dropped below a programmable limit. Fan readings can be divided by a programmable divider (1, 2, 4 or 8 for the W83781D; 1, 2, 4, 8, 16, 32, 64 or 128 for the others) to give the readings more range or accuracy. Not all RPM values can accurately be represented, so some rounding is done. With a divider of 2, the lowest representable value is around 2600 RPM.}(hjY hhhNhNubah}(h]h ]h"]h$]h&]uh1hhhhKwhjhhubh)}(hXyVoltage sensors (also known as IN sensors) report their values in volts. An alarm is triggered if the voltage has crossed a programmable minimum or maximum limit. Note that minimum in this case always means 'closest to zero'; this is important for negative voltage measurements. All voltage inputs can measure voltages between 0 and 4.08 volts, with a resolution of 0.016 volt.h]hX}Voltage sensors (also known as IN sensors) report their values in volts. An alarm is triggered if the voltage has crossed a programmable minimum or maximum limit. Note that minimum in this case always means ‘closest to zero’; this is important for negative voltage measurements. All voltage inputs can measure voltages between 0 and 4.08 volts, with a resolution of 0.016 volt.}(hjg hhhNhNubah}(h]h ]h"]h$]h&]uh1hhhhKhjhhubh)}(hThe VID lines encode the core voltage value: the voltage level your processor should work with. This is hardcoded by the mainboard and/or processor itself. It is a value in volts. When it is unconnected, you will often find the value 3.50 V here.h]hThe VID lines encode the core voltage value: the voltage level your processor should work with. This is hardcoded by the mainboard and/or processor itself. It is a value in volts. When it is unconnected, you will often find the value 3.50 V here.}(hju hhhNhNubah}(h]h ]h"]h$]h&]uh1hhhhKhjhhubh)}(hX4The W83782D and W83783S temperature conversion machine understands about several kinds of temperature probes. You can program the so-called beta value in the sensor files. '1' is the PII/Celeron diode, '2' is the TN3904 transistor, and 3435 the default thermistor value. Other values are (not yet) supported.h]hX<The W83782D and W83783S temperature conversion machine understands about several kinds of temperature probes. You can program the so-called beta value in the sensor files. ‘1’ is the PII/Celeron diode, ‘2’ is the TN3904 transistor, and 3435 the default thermistor value. Other values are (not yet) supported.}(hj hhhNhNubah}(h]h ]h"]h$]h&]uh1hhhhKhjhhubh)}(h{In addition to the alarms described above, there is a CHAS alarm on the chips which triggers if your computer case is open.h]h{In addition to the alarms described above, there is a CHAS alarm on the chips which triggers if your computer case is open.}(hj hhhNhNubah}(h]h ]h"]h$]h&]uh1hhhhKhjhhubh)}(hWhen an alarm goes off, you can be warned by a beeping signal through your computer speaker. It is possible to enable all beeping globally, or only the beeping for some alarms.h]hWhen an alarm goes off, you can be warned by a beeping signal through your computer speaker. It is possible to enable all beeping globally, or only the beeping for some alarms.}(hj hhhNhNubah}(h]h ]h"]h$]h&]uh1hhhhKhjhhubh)}(hIndividual alarm and beep bits:h]hIndividual alarm and beep bits:}(hj hhhNhNubah}(h]h ]h"]h$]h&]uh1hhhhKhjhhubj)}(hhh]j)}(hhh](j)}(hhh]h}(h]h ]h"]h$]h&]colwidthKuh1jhj ubj)}(hhh]h}(h]h ]h"]h$]h&]colwidthKuh1jhj ubjY)}(hhh](j^)}(hhh](jc)}(hhh]h)}(h0x000001h]h0x000001}(hj hhhNhNubah}(h]h ]h"]h$]h&]uh1hhhhKhj ubah}(h]h ]h"]h$]h&]uh1jbhj ubjc)}(hhh]h)}(hin0h]hin0}(hj hhhNhNubah}(h]h ]h"]h$]h&]uh1hhhhKhj ubah}(h]h ]h"]h$]h&]uh1jbhj ubeh}(h]h ]h"]h$]h&]uh1j]hj ubj^)}(hhh](jc)}(hhh]h)}(h0x000002h]h0x000002}(hj hhhNhNubah}(h]h ]h"]h$]h&]uh1hhhhKhj ubah}(h]h ]h"]h$]h&]uh1jbhj ubjc)}(hhh]h)}(hin1h]hin1}(hj, hhhNhNubah}(h]h ]h"]h$]h&]uh1hhhhKhj) ubah}(h]h ]h"]h$]h&]uh1jbhj ubeh}(h]h ]h"]h$]h&]uh1j]hj ubj^)}(hhh](jc)}(hhh]h)}(h0x000004h]h0x000004}(hjL hhhNhNubah}(h]h ]h"]h$]h&]uh1hhhhKhjI ubah}(h]h ]h"]h$]h&]uh1jbhjF ubjc)}(hhh]h)}(hin2h]hin2}(hjc hhhNhNubah}(h]h ]h"]h$]h&]uh1hhhhKhj` ubah}(h]h ]h"]h$]h&]uh1jbhjF ubeh}(h]h ]h"]h$]h&]uh1j]hj ubj^)}(hhh](jc)}(hhh]h)}(h0x000008h]h0x000008}(hj hhhNhNubah}(h]h ]h"]h$]h&]uh1hhhhKhj ubah}(h]h ]h"]h$]h&]uh1jbhj} ubjc)}(hhh]h)}(hin3h]hin3}(hj hhhNhNubah}(h]h ]h"]h$]h&]uh1hhhhKhj ubah}(h]h ]h"]h$]h&]uh1jbhj} ubeh}(h]h ]h"]h$]h&]uh1j]hj ubj^)}(hhh](jc)}(hhh]h)}(h0x000010h]h0x000010}(hj hhhNhNubah}(h]h ]h"]h$]h&]uh1hhhhKhj ubah}(h]h ]h"]h$]h&]uh1jbhj ubjc)}(hhh]h)}(htemp1h]htemp1}(hj hhhNhNubah}(h]h ]h"]h$]h&]uh1hhhhKhj ubah}(h]h ]h"]h$]h&]uh1jbhj ubeh}(h]h ]h"]h$]h&]uh1j]hj ubj^)}(hhh](jc)}(hhh]h)}(h0x000020h]h0x000020}(hj hhhNhNubah}(h]h ]h"]h$]h&]uh1hhhhKhj ubah}(h]h ]h"]h$]h&]uh1jbhj ubjc)}(hhh]h)}(htemp2 (+temp3 on W83781D)h]htemp2 (+temp3 on W83781D)}(hj hhhNhNubah}(h]h ]h"]h$]h&]uh1hhhhKhj ubah}(h]h ]h"]h$]h&]uh1jbhj ubeh}(h]h ]h"]h$]h&]uh1j]hj ubj^)}(hhh](jc)}(hhh]h)}(h0x000040h]h0x000040}(hj( hhhNhNubah}(h]h ]h"]h$]h&]uh1hhhhKhj% ubah}(h]h ]h"]h$]h&]uh1jbhj" ubjc)}(hhh]h)}(hfan1h]hfan1}(hj? hhhNhNubah}(h]h ]h"]h$]h&]uh1hhhhKhj< ubah}(h]h ]h"]h$]h&]uh1jbhj" ubeh}(h]h ]h"]h$]h&]uh1j]hj ubj^)}(hhh](jc)}(hhh]h)}(h0x000080h]h0x000080}(hj_ hhhNhNubah}(h]h ]h"]h$]h&]uh1hhhhKhj\ ubah}(h]h ]h"]h$]h&]uh1jbhjY ubjc)}(hhh]h)}(hfan2h]hfan2}(hjv hhhNhNubah}(h]h ]h"]h$]h&]uh1hhhhKhjs ubah}(h]h ]h"]h$]h&]uh1jbhjY ubeh}(h]h ]h"]h$]h&]uh1j]hj ubj^)}(hhh](jc)}(hhh]h)}(h0x000100h]h0x000100}(hj hhhNhNubah}(h]h ]h"]h$]h&]uh1hhhhKhj ubah}(h]h ]h"]h$]h&]uh1jbhj ubjc)}(hhh]h)}(hin4h]hin4}(hj hhhNhNubah}(h]h ]h"]h$]h&]uh1hhhhKhj ubah}(h]h ]h"]h$]h&]uh1jbhj ubeh}(h]h ]h"]h$]h&]uh1j]hj ubj^)}(hhh](jc)}(hhh]h)}(h0x000200h]h0x000200}(hj hhhNhNubah}(h]h ]h"]h$]h&]uh1hhhhKhj ubah}(h]h ]h"]h$]h&]uh1jbhj ubjc)}(hhh]h)}(hin5h]hin5}(hj hhhNhNubah}(h]h ]h"]h$]h&]uh1hhhhKhj ubah}(h]h ]h"]h$]h&]uh1jbhj ubeh}(h]h ]h"]h$]h&]uh1j]hj ubj^)}(hhh](jc)}(hhh]h)}(h0x000400h]h0x000400}(hj hhhNhNubah}(h]h ]h"]h$]h&]uh1hhhhKhj ubah}(h]h ]h"]h$]h&]uh1jbhj ubjc)}(hhh]h)}(hin6h]hin6}(hj hhhNhNubah}(h]h ]h"]h$]h&]uh1hhhhKhj ubah}(h]h ]h"]h$]h&]uh1jbhj ubeh}(h]h ]h"]h$]h&]uh1j]hj ubj^)}(hhh](jc)}(hhh]h)}(h0x000800h]h0x000800}(hj; hhhNhNubah}(h]h ]h"]h$]h&]uh1hhhhKhj8 ubah}(h]h ]h"]h$]h&]uh1jbhj5 ubjc)}(hhh]h)}(hfan3h]hfan3}(hjR hhhNhNubah}(h]h ]h"]h$]h&]uh1hhhhKhjO ubah}(h]h ]h"]h$]h&]uh1jbhj5 ubeh}(h]h ]h"]h$]h&]uh1j]hj ubj^)}(hhh](jc)}(hhh]h)}(h0x001000h]h0x001000}(hjr hhhNhNubah}(h]h ]h"]h$]h&]uh1hhhhKhjo ubah}(h]h ]h"]h$]h&]uh1jbhjl ubjc)}(hhh]h)}(hchassish]hchassis}(hj hhhNhNubah}(h]h ]h"]h$]h&]uh1hhhhKhj ubah}(h]h ]h"]h$]h&]uh1jbhjl ubeh}(h]h ]h"]h$]h&]uh1j]hj ubj^)}(hhh](jc)}(hhh]h)}(h0x002000h]h0x002000}(hj hhhNhNubah}(h]h ]h"]h$]h&]uh1hhhhKhj ubah}(h]h ]h"]h$]h&]uh1jbhj ubjc)}(hhh]h)}(htemp3 (W83782D only)h]htemp3 (W83782D only)}(hj hhhNhNubah}(h]h ]h"]h$]h&]uh1hhhhKhj ubah}(h]h ]h"]h$]h&]uh1jbhj ubeh}(h]h ]h"]h$]h&]uh1j]hj ubj^)}(hhh](jc)}(hhh]h)}(h0x010000h]h0x010000}(hj hhhNhNubah}(h]h ]h"]h$]h&]uh1hhhhKhj ubah}(h]h ]h"]h$]h&]uh1jbhj ubjc)}(hhh]h)}(hin7 (W83782D only)h]hin7 (W83782D only)}(hj hhhNhNubah}(h]h ]h"]h$]h&]uh1hhhhKhj ubah}(h]h ]h"]h$]h&]uh1jbhj ubeh}(h]h ]h"]h$]h&]uh1j]hj ubj^)}(hhh](jc)}(hhh]h)}(h0x020000h]h0x020000}(hj hhhNhNubah}(h]h ]h"]h$]h&]uh1hhhhKhj ubah}(h]h ]h"]h$]h&]uh1jbhj ubjc)}(hhh]h)}(hin8 (W83782D only)h]hin8 (W83782D only)}(hj. hhhNhNubah}(h]h ]h"]h$]h&]uh1hhhhKhj+ ubah}(h]h ]h"]h$]h&]uh1jbhj ubeh}(h]h ]h"]h$]h&]uh1j]hj ubeh}(h]h ]h"]h$]h&]uh1jXhj ubeh}(h]h ]h"]h$]h&]colsKuh1jhj ubah}(h]h ]h"]h$]h&]uh1jhjhhhhhNubh)}(hX|If an alarm triggers, it will remain triggered until the hardware register is read at least once. This means that the cause for the alarm may already have disappeared! Note that in the current implementation, all hardware registers are read whenever any data is read (unless it is less than 1.5 seconds since the last update). This means that you can easily miss once-only alarms.h]hX|If an alarm triggers, it will remain triggered until the hardware register is read at least once. This means that the cause for the alarm may already have disappeared! Note that in the current implementation, all hardware registers are read whenever any data is read (unless it is less than 1.5 seconds since the last update). This means that you can easily miss once-only alarms.}(hj[ hhhNhNubah}(h]h ]h"]h$]h&]uh1hhhhKhjhhubh)}(huThe chips only update values each 1.5 seconds; reading them more often will do no harm, but will return 'old' values.h]hyThe chips only update values each 1.5 seconds; reading them more often will do no harm, but will return ‘old’ values.}(hji hhhNhNubah}(h]h ]h"]h$]h&]uh1hhhhKhjhhubeh}(h] descriptionah ]h"] descriptionah$]h&]uh1hhhhhhhhKCubh)}(hhh](h)}(hAS99127F PROBLEMSh]hAS99127F PROBLEMS}(hj hhhNhNubah}(h]h ]h"]h$]h&]uh1hhj hhhhhKubh)}(hX)The as99127f support was developed without the benefit of a datasheet. In most cases it is treated as a w83781d (although revision 2 of the AS99127F looks more like a w83782d). This support will be BETA until a datasheet is released. One user has reported problems with fans stopping occasionally.h]hX)The as99127f support was developed without the benefit of a datasheet. In most cases it is treated as a w83781d (although revision 2 of the AS99127F looks more like a w83782d). This support will be BETA until a datasheet is released. One user has reported problems with fans stopping occasionally.}(hj hhhNhNubah}(h]h ]h"]h$]h&]uh1hhhhKhj hhubh)}(hNote that the individual beep bits are inverted from the other chips. The driver now takes care of this so that user-space applications don't have to know about it.h]hNote that the individual beep bits are inverted from the other chips. The driver now takes care of this so that user-space applications don’t have to know about it.}(hj hhhNhNubah}(h]h ]h"]h$]h&]uh1hhhhKhj hhubj)}(hhh]j)}(hKnown problems: - Problems with diode/thermistor settings (supported?) - One user reports fans stopping under high server load. - Revision 2 seems to have 2 PWM registers but we don't know how to handle them. More details below. h](j)}(hKnown problems:h]hKnown problems:}(hj hhhNhNubah}(h]h ]h"]h$]h&]uh1jhhhKhj ubj)}(hhh]h)}(hhh](h)}(h4Problems with diode/thermistor settings (supported?)h]h)}(hj h]h4Problems with diode/thermistor settings (supported?)}(hj hhhNhNubah}(h]h ]h"]h$]h&]uh1hhhhKhj ubah}(h]h ]h"]h$]h&]uh1hhj ubh)}(h6One user reports fans stopping under high server load.h]h)}(hj h]h6One user reports fans stopping under high server load.}(hj hhhNhNubah}(h]h ]h"]h$]h&]uh1hhhhKhj ubah}(h]h ]h"]h$]h&]uh1hhj ubh)}(hcRevision 2 seems to have 2 PWM registers but we don't know how to handle them. More details below. h]h)}(hbRevision 2 seems to have 2 PWM registers but we don't know how to handle them. More details below.h]hdRevision 2 seems to have 2 PWM registers but we don’t know how to handle them. More details below.}(hj hhhNhNubah}(h]h ]h"]h$]h&]uh1hhhhKhj ubah}(h]h ]h"]h$]h&]uh1hhj ubeh}(h]h ]h"]h$]h&]jjuh1hhhhKhj ubah}(h]h ]h"]h$]h&]uh1jhj ubeh}(h]h ]h"]h$]h&]uh1jhhhKhj ubah}(h]h ]h"]h$]h&]uh1jhj hhhNhNubh)}(hXThese will not be fixed unless we get a datasheet. If you have problems, please lobby Asus to release a datasheet. Unfortunately several others have without success. Please do not send mail to us asking for better as99127f support. We have done the best we can without a datasheet. Please do not send mail to the author or the sensors group asking for a datasheet or ideas on how to convince Asus. We can't help.h]hXThese will not be fixed unless we get a datasheet. If you have problems, please lobby Asus to release a datasheet. Unfortunately several others have without success. Please do not send mail to us asking for better as99127f support. We have done the best we can without a datasheet. Please do not send mail to the author or the sensors group asking for a datasheet or ideas on how to convince Asus. We can’t help.}(hj%hhhNhNubah}(h]h ]h"]h$]h&]uh1hhhhKhj hhubeh}(h]as99127f-problemsah ]h"]as99127f problemsah$]h&]uh1hhhhhhhhKubh)}(hhh](h)}(hNOTESh]hNOTES}(hj>hhhNhNubah}(h]h ]h"]h$]h&]uh1hhj;hhhhhKubh)}(hX783s has no in1 so that in[2-6] are compatible with the 781d/782d. 783s pin is programmable for -5V or temp1; defaults to -5V, no control in driver so temp1 doesn't work. 782d and 783s datasheets differ on which is pwm1 and which is pwm2. We chose to follow 782d. 782d and 783s pin is programmable for fan3 input or pwm2 output; defaults to fan3 input. If pwm2 is enabled (with echo 255 1 > pwm2), then fan3 will report 0. 782d has pwm1-2 for ISA, pwm1-4 for i2c. (pwm3-4 share pins with the ISA pins) h](h)}(hB783s has no in1 so that in[2-6] are compatible with the 781d/782d.h]hB783s has no in1 so that in[2-6] are compatible with the 781d/782d.}(hjPhhhNhNubah}(h]h ]h"]h$]h&]uh1hhhhKhjLubh)}(hg783s pin is programmable for -5V or temp1; defaults to -5V, no control in driver so temp1 doesn't work.h]hi783s pin is programmable for -5V or temp1; defaults to -5V, no control in driver so temp1 doesn’t work.}(hj^hhhNhNubah}(h]h ]h"]h$]h&]uh1hhhhKhjLubh)}(h\782d and 783s datasheets differ on which is pwm1 and which is pwm2. We chose to follow 782d.h]h\782d and 783s datasheets differ on which is pwm1 and which is pwm2. We chose to follow 782d.}(hjlhhhNhNubah}(h]h ]h"]h$]h&]uh1hhhhKhjLubh)}(h782d and 783s pin is programmable for fan3 input or pwm2 output; defaults to fan3 input. If pwm2 is enabled (with echo 255 1 > pwm2), then fan3 will report 0.h]h782d and 783s pin is programmable for fan3 input or pwm2 output; defaults to fan3 input. If pwm2 is enabled (with echo 255 1 > pwm2), then fan3 will report 0.}(hjzhhhNhNubah}(h]h ]h"]h$]h&]uh1hhhhKhjLubh)}(hN782d has pwm1-2 for ISA, pwm1-4 for i2c. (pwm3-4 share pins with the ISA pins)h]hN782d has pwm1-2 for ISA, pwm1-4 for i2c. (pwm3-4 share pins with the ISA pins)}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1hhhhKhjLubeh}(h]h ]h"]h$]h&]uh1hhhhKhj;hhubeh}(h]notesah ]h"]notesah$]h&]uh1hhhhhhhhKubh)}(hhh](h)}(hData sheet updatesh]hData sheet updates}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1hhjhhhhhKubh)}(h- PWM clock registers: * 000: master / 512 * 001: master / 1024 * 010: master / 2048 * 011: master / 4096 * 100: master / 8192 h]h)}(hhh]h)}(hPWM clock registers: * 000: master / 512 * 001: master / 1024 * 010: master / 2048 * 011: master / 4096 * 100: master / 8192 h]j)}(hhh]j)}(hPWM clock registers: * 000: master / 512 * 001: master / 1024 * 010: master / 2048 * 011: master / 4096 * 100: master / 8192 h](j)}(hPWM clock registers:h]hPWM clock registers:}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1jhhhKhjubj)}(hhh]h)}(hhh](h)}(h000: master / 512h]h)}(hjh]h000: master / 512}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1hhhhKhjubah}(h]h ]h"]h$]h&]uh1hhjubh)}(h001: master / 1024h]h)}(hjh]h001: master / 1024}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1hhhhKhjubah}(h]h ]h"]h$]h&]uh1hhjubh)}(h010: master / 2048h]h)}(hj h]h010: master / 2048}(hj hhhNhNubah}(h]h ]h"]h$]h&]uh1hhhhKhj ubah}(h]h ]h"]h$]h&]uh1hhjubh)}(h011: master / 4096h]h)}(hj"h]h011: master / 4096}(hj$hhhNhNubah}(h]h ]h"]h$]h&]uh1hhhhKhj ubah}(h]h ]h"]h$]h&]uh1hhjubh)}(h100: master / 8192 h]h)}(h100: master / 8192h]h100: master / 8192}(hj;hhhNhNubah}(h]h ]h"]h$]h&]uh1hhhhKhj7ubah}(h]h ]h"]h$]h&]uh1hhjubeh}(h]h ]h"]h$]h&]jjuh1hhhhKhjubah}(h]h ]h"]h$]h&]uh1jhjubeh}(h]h ]h"]h$]h&]uh1jhhhKhjubah}(h]h ]h"]h$]h&]uh1jhjubah}(h]h ]h"]h$]h&]uh1hhjubah}(h]h ]h"]h$]h&]jjuh1hhhhKhjubah}(h]h ]h"]h$]h&]uh1hhhhKhjhhubeh}(h]data-sheet-updatesah ]h"]data sheet updatesah$]h&]uh1hhhhhhhhKubh)}(hhh](h)}(h!Answers from Winbond tech supporth]h!Answers from Winbond tech support}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1hhjhhhhhKubh literal_block)}(hXS> > 1) In the W83781D data sheet section 7.2 last paragraph, it talks about > reprogramming the R-T table if the Beta of the thermistor is not > 3435K. The R-T table is described briefly in section 8.20. > What formulas do I use to program a new R-T table for a given Beta? > We are sorry that the calculation for R-T table value is confidential. If you have another Beta value of thermistor, we can help to calculate the R-T table for you. But you should give us real R-T Table which can be gotten by thermistor vendor. Therefore we will calculate them and obtain 32-byte data, and you can fill the 32-byte data to the register in Bank0.CR51 of W83781D. > 2) In the W83782D data sheet, it mentions that pins 38, 39, and 40 are > programmable to be either thermistor or Pentium II diode inputs. > How do I program them for diode inputs? I can't find any register > to program these to be diode inputs. You may program Bank0 CR[5Dh] and CR[59h] registers. =============================== =============== ============== ============ CR[5Dh] bit 1(VTIN1) bit 2(VTIN2) bit 3(VTIN3) thermistor 0 0 0 diode 1 1 1 (error) CR[59h] bit 4(VTIN1) bit 2(VTIN2) bit 3(VTIN3) (right) CR[59h] bit 4(VTIN1) bit 5(VTIN2) bit 6(VTIN3) PII thermal diode 1 1 1 2N3904 diode 0 0 0 =============================== =============== ============== ============h]hXS> > 1) In the W83781D data sheet section 7.2 last paragraph, it talks about > reprogramming the R-T table if the Beta of the thermistor is not > 3435K. The R-T table is described briefly in section 8.20. > What formulas do I use to program a new R-T table for a given Beta? > We are sorry that the calculation for R-T table value is confidential. If you have another Beta value of thermistor, we can help to calculate the R-T table for you. But you should give us real R-T Table which can be gotten by thermistor vendor. Therefore we will calculate them and obtain 32-byte data, and you can fill the 32-byte data to the register in Bank0.CR51 of W83781D. > 2) In the W83782D data sheet, it mentions that pins 38, 39, and 40 are > programmable to be either thermistor or Pentium II diode inputs. > How do I program them for diode inputs? I can't find any register > to program these to be diode inputs. You may program Bank0 CR[5Dh] and CR[59h] registers. =============================== =============== ============== ============ CR[5Dh] bit 1(VTIN1) bit 2(VTIN2) bit 3(VTIN3) thermistor 0 0 0 diode 1 1 1 (error) CR[59h] bit 4(VTIN1) bit 2(VTIN2) bit 3(VTIN3) (right) CR[59h] bit 4(VTIN1) bit 5(VTIN2) bit 6(VTIN3) PII thermal diode 1 1 1 2N3904 diode 0 0 0 =============================== =============== ============== ============}hjsbah}(h]h ]h"]h$]h&] xml:spacepreserveuh1jhhhKhjhhubeh}(h]!answers-from-winbond-tech-supportah ]h"]!answers from winbond tech supportah$]h&]uh1hhhhhhhhKubh)}(hhh](h)}(h Asus Clonesh]h Asus Clones}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1hhjhhhhhMubh)}(hX8We have no datasheets for the Asus clones (AS99127F and ASB100 Bach). Here are some very useful information that were given to us by Alex Van Kaam about how to detect these chips, and how to read their values. He also gives advice for another Asus chipset, the Mozart-2 (which we don't support yet). Thanks Alex!h]hX:We have no datasheets for the Asus clones (AS99127F and ASB100 Bach). Here are some very useful information that were given to us by Alex Van Kaam about how to detect these chips, and how to read their values. He also gives advice for another Asus chipset, the Mozart-2 (which we don’t support yet). Thanks Alex!}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1hhhhMhjhhubh)}(h2I reworded some parts and added personal comments.h]h2I reworded some parts and added personal comments.}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1hhhhM"hjhhubh)}(hhh](h)}(h Detectionh]h Detection}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1hhjhhhhhM%ubh)}(hAS99127F rev.1, AS99127F rev.2 and ASB100: - I2C address range: 0x29 - 0x2F - If register 0x58 holds 0x31 then we have an Asus (either ASB100 or AS99127F) - Which one depends on register 0x4F (manufacturer ID):h]hAS99127F rev.1, AS99127F rev.2 and ASB100: - I2C address range: 0x29 - 0x2F - If register 0x58 holds 0x31 then we have an Asus (either ASB100 or AS99127F) - Which one depends on register 0x4F (manufacturer ID):}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1hhhhM'hjhhubh)}(hX- 0x06 or 0x94: ASB100 - 0x12 or 0xC3: AS99127F rev.1 - 0x5C or 0xA3: AS99127F rev.2 Note that 0x5CA3 is Winbond's ID (WEC), which let us think Asus get their AS99127F rev.2 direct from Winbond. The other codes mean ATT and DVC, respectively. ATT could stand for Asustek something (although it would be very badly chosen IMHO), I don't know what DVC could stand for. Maybe these codes simply aren't meant to be decoded that way. h](h)}(hhh](h)}(h0x06 or 0x94: ASB100h]h)}(hjh]h0x06 or 0x94: ASB100}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1hhhhM,hjubah}(h]h ]h"]h$]h&]uh1hhjubh)}(h0x12 or 0xC3: AS99127F rev.1h]h)}(hjh]h0x12 or 0xC3: AS99127F rev.1}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1hhhhM-hjubah}(h]h ]h"]h$]h&]uh1hhjubh)}(h0x5C or 0xA3: AS99127F rev.2 h]h)}(h0x5C or 0xA3: AS99127F rev.2h]h0x5C or 0xA3: AS99127F rev.2}(hj1hhhNhNubah}(h]h ]h"]h$]h&]uh1hhhhM.hj-ubah}(h]h ]h"]h$]h&]uh1hhjubeh}(h]h ]h"]h$]h&]jjuh1hhhhM,hjubh)}(hXWNote that 0x5CA3 is Winbond's ID (WEC), which let us think Asus get their AS99127F rev.2 direct from Winbond. The other codes mean ATT and DVC, respectively. ATT could stand for Asustek something (although it would be very badly chosen IMHO), I don't know what DVC could stand for. Maybe these codes simply aren't meant to be decoded that way.h]hX]Note that 0x5CA3 is Winbond’s ID (WEC), which let us think Asus get their AS99127F rev.2 direct from Winbond. The other codes mean ATT and DVC, respectively. ATT could stand for Asustek something (although it would be very badly chosen IMHO), I don’t know what DVC could stand for. Maybe these codes simply aren’t meant to be decoded that way.}(hjKhhhNhNubah}(h]h ]h"]h$]h&]uh1hhhhM0hjubeh}(h]h ]h"]h$]h&]uh1hhhhM,hjhhubh)}(h~Mozart-2: - I2C address: 0x77 - If register 0x58 holds 0x56 or 0x10 then we have a Mozart-2 - Of the Mozart there are 3 types:h]h~Mozart-2: - I2C address: 0x77 - If register 0x58 holds 0x56 or 0x10 then we have a Mozart-2 - Of the Mozart there are 3 types:}(hj_hhhNhNubah}(h]h ]h"]h$]h&]uh1hhhhM6hjhhubh)}(h- 0x58=0x56, 0x4E=0x94, 0x4F=0x36: Asus ASM58 Mozart-2 - 0x58=0x56, 0x4E=0x94, 0x4F=0x06: Asus AS2K129R Mozart-2 - 0x58=0x10, 0x4E=0x5C, 0x4F=0xA3: Asus ??? Mozart-2 You can handle all 3 the exact same way :) h](h)}(hhh](h)}(h40x58=0x56, 0x4E=0x94, 0x4F=0x36: Asus ASM58 Mozart-2h]h)}(hjvh]h40x58=0x56, 0x4E=0x94, 0x4F=0x36: Asus ASM58 Mozart-2}(hjxhhhNhNubah}(h]h ]h"]h$]h&]uh1hhhhM;hjtubah}(h]h ]h"]h$]h&]uh1hhjqubh)}(h70x58=0x56, 0x4E=0x94, 0x4F=0x06: Asus AS2K129R Mozart-2h]h)}(hjh]h70x58=0x56, 0x4E=0x94, 0x4F=0x06: Asus AS2K129R Mozart-2}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1hhhhM<hjubah}(h]h ]h"]h$]h&]uh1hhjqubh)}(h30x58=0x10, 0x4E=0x5C, 0x4F=0xA3: Asus ??? Mozart-2 h]h)}(h20x58=0x10, 0x4E=0x5C, 0x4F=0xA3: Asus ??? Mozart-2h]h20x58=0x10, 0x4E=0x5C, 0x4F=0xA3: Asus ??? Mozart-2}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1hhhhM=hjubah}(h]h ]h"]h$]h&]uh1hhjqubeh}(h]h ]h"]h$]h&]jjuh1hhhhM;hjmubh)}(h*You can handle all 3 the exact same way :)h]h*You can handle all 3 the exact same way :)}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1hhhhM?hjmubeh}(h]h ]h"]h$]h&]uh1hhhhM;hjhhubeh}(h] detectionah ]h"] detectionah$]h&]uh1hhjhhhhhM%ubh)}(hhh](h)}(hTemperature sensorsh]hTemperature sensors}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1hhjhhhhhMBubj)}(hhh]j)}(hiASB100: - sensor 1: register 0x27 - sensor 2 & 3 are the 2 LM75's on the SMBus - sensor 4: register 0x17 h](j)}(hASB100:h]hASB100:}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1jhhhMGhjubj)}(hhh]h)}(hhh](h)}(hsensor 1: register 0x27h]h)}(hj h]hsensor 1: register 0x27}(hj hhhNhNubah}(h]h ]h"]h$]h&]uh1hhhhMEhjubah}(h]h ]h"]h$]h&]uh1hhjubh)}(h*sensor 2 & 3 are the 2 LM75's on the SMBush]h)}(hj!h]h,sensor 2 & 3 are the 2 LM75’s on the SMBus}(hj#hhhNhNubah}(h]h ]h"]h$]h&]uh1hhhhMFhjubah}(h]h ]h"]h$]h&]uh1hhjubh)}(hsensor 4: register 0x17 h]h)}(hsensor 4: register 0x17h]hsensor 4: register 0x17}(hj:hhhNhNubah}(h]h ]h"]h$]h&]uh1hhhhMGhj6ubah}(h]h ]h"]h$]h&]uh1hhjubeh}(h]h ]h"]h$]h&]jjuh1hhhhMEhjubah}(h]h ]h"]h$]h&]uh1jhjubeh}(h]h ]h"]h$]h&]uh1jhhhMGhjubah}(h]h ]h"]h$]h&]uh1jhjhhhNhNubh)}(hRemark:h]hRemark:}(hjfhhhNhNubah}(h]h ]h"]h$]h&]uh1hhhhMIhjhhubh)}(hI noticed that on Intel boards sensor 2 is used for the CPU and 4 is ignored/stuck, on AMD boards sensor 4 is the CPU and sensor 2 is either ignored or a socket temperature. h]h)}(hI noticed that on Intel boards sensor 2 is used for the CPU and 4 is ignored/stuck, on AMD boards sensor 4 is the CPU and sensor 2 is either ignored or a socket temperature.h]hI noticed that on Intel boards sensor 2 is used for the CPU and 4 is ignored/stuck, on AMD boards sensor 4 is the CPU and sensor 2 is either ignored or a socket temperature.}(hjxhhhNhNubah}(h]h ]h"]h$]h&]uh1hhhhMKhjtubah}(h]h ]h"]h$]h&]uh1hhhhMKhjhhubj)}(hhh]j)}(heAS99127F (rev.1 and 2 alike): - sensor 1: register 0x27 - sensor 2 & 3 are the 2 LM75's on the SMBus h](j)}(hAS99127F (rev.1 and 2 alike):h]hAS99127F (rev.1 and 2 alike):}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1jhhhMQhjubj)}(hhh]h)}(hhh](h)}(hsensor 1: register 0x27h]h)}(hjh]hsensor 1: register 0x27}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1hhhhMPhjubah}(h]h ]h"]h$]h&]uh1hhjubh)}(h+sensor 2 & 3 are the 2 LM75's on the SMBus h]h)}(h*sensor 2 & 3 are the 2 LM75's on the SMBush]h,sensor 2 & 3 are the 2 LM75’s on the SMBus}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1hhhhMQhjubah}(h]h ]h"]h$]h&]uh1hhjubeh}(h]h ]h"]h$]h&]jjuh1hhhhMPhjubah}(h]h ]h"]h$]h&]uh1jhjubeh}(h]h ]h"]h$]h&]uh1jhhhMQhjubah}(h]h ]h"]h$]h&]uh1jhjhhhNhNubh)}(hRemark:h]hRemark:}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1hhhhMShjhhubh)}(htRegister 0x5b is suspected to be temperature type selector. Bit 1 would control temp1, bit 3 temp2 and bit 5 temp3. h]h)}(hsRegister 0x5b is suspected to be temperature type selector. Bit 1 would control temp1, bit 3 temp2 and bit 5 temp3.h]hsRegister 0x5b is suspected to be temperature type selector. Bit 1 would control temp1, bit 3 temp2 and bit 5 temp3.}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1hhhhMUhjubah}(h]h ]h"]h$]h&]uh1hhhhMUhjhhubj)}(hhh]j)}(h>Mozart-2: - sensor 1: register 0x27 - sensor 2: register 0x13 h](j)}(h Mozart-2:h]h Mozart-2:}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1jhhhMZhjubj)}(hhh]h)}(hhh](h)}(hsensor 1: register 0x27h]h)}(hj1h]hsensor 1: register 0x27}(hj3hhhNhNubah}(h]h ]h"]h$]h&]uh1hhhhMYhj/ubah}(h]h ]h"]h$]h&]uh1hhj,ubh)}(hsensor 2: register 0x13 h]h)}(hsensor 2: register 0x13h]hsensor 2: register 0x13}(hjJhhhNhNubah}(h]h ]h"]h$]h&]uh1hhhhMZhjFubah}(h]h ]h"]h$]h&]uh1hhj,ubeh}(h]h ]h"]h$]h&]jjuh1hhhhMYhj)ubah}(h]h ]h"]h$]h&]uh1jhjubeh}(h]h ]h"]h$]h&]uh1jhhhMZhjubah}(h]h ]h"]h$]h&]uh1jhjhhhNhNubeh}(h]temperature-sensorsah ]h"]temperature sensorsah$]h&]uh1hhjhhhhhMBubh)}(hhh](h)}(h Fan sensorsh]h Fan sensors}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1hhj~hhhhhM]ubj)}(hhh](j)}(hIASB100, AS99127F (rev.1 and 2 alike): - 3 fans, identical to the W83781D h](j)}(h%ASB100, AS99127F (rev.1 and 2 alike):h]h%ASB100, AS99127F (rev.1 and 2 alike):}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1jhhhM`hjubj)}(hhh]h)}(hhh]h)}(h!3 fans, identical to the W83781D h]h)}(h 3 fans, identical to the W83781Dh]h 3 fans, identical to the W83781D}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1hhhhM`hjubah}(h]h ]h"]h$]h&]uh1hhjubah}(h]h ]h"]h$]h&]jjuh1hhhhM`hjubah}(h]h ]h"]h$]h&]uh1jhjubeh}(h]h ]h"]h$]h&]uh1jhhhM`hjubj)}(hMozart-2: - 2 fans only, 1350000/RPM/div - fan 1: register 0x28, divisor on register 0xA1 (bits 4-5) - fan 2: register 0x29, divisor on register 0xA1 (bits 6-7) h](j)}(h Mozart-2:h]h Mozart-2:}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1jhhhMehjubj)}(hhh]h)}(hhh](h)}(h2 fans only, 1350000/RPM/divh]h)}(hjh]h2 fans only, 1350000/RPM/div}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1hhhhMchjubah}(h]h ]h"]h$]h&]uh1hhjubh)}(h:fan 1: register 0x28, divisor on register 0xA1 (bits 4-5)h]h)}(hjh]h:fan 1: register 0x28, divisor on register 0xA1 (bits 4-5)}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1hhhhMdhjubah}(h]h ]h"]h$]h&]uh1hhjubh)}(h;fan 2: register 0x29, divisor on register 0xA1 (bits 6-7) h]h)}(h:fan 2: register 0x29, divisor on register 0xA1 (bits 6-7)h]h:fan 2: register 0x29, divisor on register 0xA1 (bits 6-7)}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1hhhhMehjubah}(h]h ]h"]h$]h&]uh1hhjubeh}(h]h ]h"]h$]h&]jjuh1hhhhMchjubah}(h]h ]h"]h$]h&]uh1jhjubeh}(h]h ]h"]h$]h&]uh1jhhhMehjhhubeh}(h]h ]h"]h$]h&]uh1jhj~hhhNhNubeh}(h] fan-sensorsah ]h"] fan sensorsah$]h&]uh1hhjhhhhhM]ubh)}(hhh](h)}(hVoltagesh]hVoltages}(hjUhhhNhNubah}(h]h ]h"]h$]h&]uh1hhjRhhhhhMhubh)}(hAThis is where there is a difference between AS99127F rev.1 and 2.h]hAThis is where there is a difference between AS99127F rev.1 and 2.}(hjchhhNhNubah}(h]h ]h"]h$]h&]uh1hhhhMjhjRhhubh)}(hRemark:h]hRemark:}(hjqhhhNhNubah}(h]h ]h"]h$]h&]uh1hhhhMlhjRhhubh)}(hIThe difference is similar to the difference between W83781D and W83782D. h]h)}(hHThe difference is similar to the difference between W83781D and W83782D.h]hHThe difference is similar to the difference between W83781D and W83782D.}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1hhhhMnhjubah}(h]h ]h"]h$]h&]uh1hhhhMnhjRhhubj)}(hhh](j)}(hASB100: - in0=r(0x20)*0.016 - in1=r(0x21)*0.016 - in2=r(0x22)*0.016 - in3=r(0x23)*0.016*1.68 - in4=r(0x24)*0.016*3.8 - in5=r(0x25)*(-0.016)*3.97 - in6=r(0x26)*(-0.016)*1.666 h](j)}(hASB100:h]hASB100:}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1jhhhMxhjubj)}(hhh]h)}(hhh](h)}(hin0=r(0x20)*0.016h]h)}(hjh]hin0=r(0x20)*0.016}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1hhhhMrhjubah}(h]h ]h"]h$]h&]uh1hhjubh)}(hin1=r(0x21)*0.016h]h)}(hjh]hin1=r(0x21)*0.016}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1hhhhMshjubah}(h]h ]h"]h$]h&]uh1hhjubh)}(hin2=r(0x22)*0.016h]h)}(hjh]hin2=r(0x22)*0.016}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1hhhhMthjubah}(h]h ]h"]h$]h&]uh1hhjubh)}(hin3=r(0x23)*0.016*1.68h]h)}(hjh]hin3=r(0x23)*0.016*1.68}(hrjhhhNhNubah}(h]h ]h"]h$]h&]uh1hhhhMuhjubah}(h]h ]h"]h$]h&]uh1hhjubh)}(hin4=r(0x24)*0.016*3.8h]h)}(hjh]hin4=r(0x24)*0.016*3.8}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1hhhhMvhjubah}(h]h ]h"]h$]h&]uh1hhjubh)}(hin5=r(0x25)*(-0.016)*3.97h]h)}(hj'h]hin5=r(0x25)*(-0.016)*3.97}(hj)hhhNhNubah}(h]h ]h"]h$]h&]uh1hhhhMwhj%ubah}(h]h ]h"]h$]h&]uh1hhjubh)}(hin6=r(0x26)*(-0.016)*1.666 h]h)}(hin6=r(0x26)*(-0.016)*1.666h]hin6=r(0x26)*(-0.016)*1.666}(hj@hhhNhNubah}(h]h ]h"]h$]h&]uh1hhhhMxhj<ubah}(h]h ]h"]h$]h&]uh1hhjubeh}(h]h ]h"]h$]h&]jjuh1hhhhMrhjubah}(h]h ]h"]h$]h&]uh1jhjubeh}(h]h ]h"]h$]h&]uh1jhhhMxhjubj)}(hAS99127F rev.1: - in0=r(0x20)*0.016 - in1=r(0x21)*0.016 - in2=r(0x22)*0.016 - in3=r(0x23)*0.016*1.68 - in4=r(0x24)*0.016*3.8 - in5=r(0x25)*(-0.016)*3.97 - in6=r(0x26)*(-0.016)*1.503 h](j)}(hAS99127F rev.1:h]hAS99127F rev.1:}(hjjhhhNhNubah}(h]h ]h"]h$]h&]uh1jhhhMhjfubj)}(hhh]h)}(hhh](h)}(hin0=r(0x20)*0.016h]h)}(hjh]hin0=r(0x20)*0.016}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1hhhhM{hj~ubah}(h]h ]h"]h$]h&]uh1hhj{ubh)}(hin1=r(0x21)*0.016h]h)}(hjh]hin1=r(0x21)*0.016}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1hhhhM|hjubah}(h]h ]h"]h$]h&]uh1hhj{ubh)}(hin2=r(0x22)*0.016h]h)}(hjh]hin2=r(0x22)*0.016}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1hhhhM}hjubah}(h]h ]h"]h$]h&]uh1hhj{ubh)}(hin3=r(0x23)*0.016*1.68h]h)}(hjh]hin3=r(0x23)*0.016*1.68}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1hhhhM~hjubah}(h]h ]h"]h$]h&]uh1hhj{ubh)}(hin4=r(0x24)*0.016*3.8h]h)}(hjh]hin4=r(0x24)*0.016*3.8}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1hhhhMhjubah}(h]h ]h"]h$]h&]uh1hhj{ubh)}(hin5=r(0x25)*(-0.016)*3.97h]h)}(hjh]hin5=r(0x25)*(-0.016)*3.97}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1hhhhMhjubah}(h]h ]h"]h$]h&]uh1hhj{ubh)}(hin6=r(0x26)*(-0.016)*1.503 h]h)}(hin6=r(0x26)*(-0.016)*1.503h]hin6=r(0x26)*(-0.016)*1.503}(hj hhhNhNubah}(h]h ]h"]h$]h&]uh1hhhhMhjubah}(h]h ]h"]h$]h&]uh1hhj{ubeh}(h]h ]h"]h$]h&]jjuh1hhhhM{hjxubah}(h]h ]h"]h$]h&]uh1jhjfubeh}(h]h ]h"]h$]h&]uh1jhhhMhjhhubj)}(hAS99127F rev.2: - in0=r(0x20)*0.016 - in1=r(0x21)*0.016 - in2=r(0x22)*0.016 - in3=r(0x23)*0.016*1.68 - in4=r(0x24)*0.016*3.8 - in5=(r(0x25)*0.016-3.6)*5.14+3.6 - in6=(r(0x26)*0.016-3.6)*3.14+3.6 h](j)}(hAS99127F rev.2:h]hAS99127F rev.2:}(hj6hhhNhNubah}(h]h ]h"]h$]h&]uh1jhhhMhj2ubj)}(hhh]h)}(hhh](h)}(hin0=r(0x20)*0.016h]h)}(hjLh]hin0=r(0x20)*0.016}(hjNhhhNhNubah}(h]h ]h"]h$]h&]uh1hhhhMhjJubah}(h]h ]h"]h$]h&]uh1hhjGubh)}(hin1=r(0x21)*0.016h]h)}(hjch]hin1=r(0x21)*0.016}(hjehhhNhNubah}(h]h ]h"]h$]h&]uh1hhhhMhjaubah}(h]h ]h"]h$]h&]uh1hhjGubh)}(hin2=r(0x22)*0.016h]h)}(hjzh]hin2=r(0x22)*0.016}(hj|hhhNhNubah}(h]h ]h"]h$]h&]uh1hhhhMhjxubah}(h]h ]h"]h$]h&]uh1hhjGubh)}(hin3=r(0x23)*0.016*1.68h]h)}(hjh]hin3=r(0x23)*0.016*1.68}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1hhhhMhjubah}(h]h ]h"]h$]h&]uh1hhjGubh)}(hin4=r(0x24)*0.016*3.8h]h)}(hjh]hin4=r(0x24)*0.016*3.8}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1hhhhMhjubah}(h]h ]h"]h$]h&]uh1hhjGubh)}(h in5=(r(0x25)*0.016-3.6)*5.14+3.6h]h)}(hjh]h in5=(r(0x25)*0.016-3.6)*5.14+3.6}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1hhhhMhjubah}(h]h ]h"]h$]h&]uh1hhjGubh)}(h!in6=(r(0x26)*0.016-3.6)*3.14+3.6 h]h)}(h in6=(r(0x26)*0.016-3.6)*3.14+3.6h]h in6=(r(0x26)*0.016-3.6)*3.14+3.6}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1hhhhMhjubah}(h]h ]h"]h$]h&]uh1hhjGubeh}(h]h ]h"]h$]h&]jjuh1hhhhMhjDubah}(h]h ]h"]h$]h&]uh1jhj2ubeh}(h]h ]h"]h$]h&]uh1jhhhMhjhhubj)}(hMozart-2: - in0=r(0x20)*0.016 - in1=255 - in2=r(0x22)*0.016 - in3=r(0x23)*0.016*1.68 - in4=r(0x24)*0.016*4 - in5=255 - in6=255 h](j)}(h Mozart-2:h]h Mozart-2:}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1jhhhMhjubj)}(hhh]h)}(hhh](h)}(hin0=r(0x20)*0.016h]h)}(hjh]hin0=r(0x20)*0.016}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1hhhhMhjubah}(h]h ]h"]h$]h&]uh1hhjubh)}(hin1=255h]h)}(hj/h]hin1=255}(hj1hhhNhNubah}(h]h ]h"]h$]h&]uh1hhhhMhj-ubah}(h]h ]h"]h$]h&]uh1hhjubh)}(hin2=r(0x22)*0.016h]h)}(hjFh]hin2=r(0x22)*0.016}(hjHhhhNhNubah}(h]h ]h"]h$]h&]uh1hhhhMhjDubah}(h]h ]h"]h$]h&]uh1hhjubh)}(hin3=r(0x23)*0.016*1.68h]h)}(hj]h]hin3=r(0x23)*0.016*1.68}(hj_hhhNhNubah}(h]h ]h"]h$]h&]uh1hhhhMhj[ubah}(h]h ]h"]h$]h&]uh1hhjubh)}(hin4=r(0x24)*0.016*4h]h)}(hjth]hin4=r(0x24)*0.016*4}(hjvhhhNhNubah}(h]h ]h"]h$]h&]uh1hhhhMhjrubah}(h]h ]h"]h$]h&]uh1hhjubh)}(hin5=255h]h)}(hjh]hin5=255}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1hhhhMhjubah}(h]h ]h"]h$]h&]uh1hhjubh)}(h in6=255 h]h)}(hin6=255h]hin6=255}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1hhhhMhjubah}(h]h ]h"]h$]h&]uh1hhjubeh}(h]h ]h"]h$]h&]jjuh1hhhhMhjubah}(h]h ]h"]h$]h&]uh1jhjubeh}(h]h ]h"]h$]h&]uh1jhhhMhjhhubeh}(h]h ]h"]h$]h&]uh1jhjRhhhNhNubeh}(h]voltagesah ]h"]voltagesah$]h&]uh1hhjhhhhhMhubh)}(hhh](h)}(hPWMh]hPWM}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1hhjhhhhhMubh)}(hhh]h)}(htAdditional info about PWM on the AS99127F (may apply to other Asus chips as well) by Jean Delvare as of 2004-04-09: h]h)}(hsAdditional info about PWM on the AS99127F (may apply to other Asus chips as well) by Jean Delvare as of 2004-04-09:h]hsAdditional info about PWM on the AS99127F (may apply to other Asus chips as well) by Jean Delvare as of 2004-04-09:}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1hhhhMhjubah}(h]h ]h"]h$]h&]uh1hhjhhhhhNubah}(h]h ]h"]h$]h&]jjuh1hhhhMhjhhubh)}(hXKAS99127F revision 2 seems to have two PWM registers at 0x59 and 0x5A, and a temperature sensor type selector at 0x5B (which basically means that they swapped registers 0x59 and 0x5B when you compare with Winbond chips). Revision 1 of the chip also has the temperature sensor type selector at 0x5B, but PWM registers have no effect.h]hXKAS99127F revision 2 seems to have two PWM registers at 0x59 and 0x5A, and a temperature sensor type selector at 0x5B (which basically means that they swapped registers 0x59 and 0x5B when you compare with Winbond chips). Revision 1 of the chip also has the temperature sensor type selector at 0x5B, but PWM registers have no effect.}(hj hhhNhNubah}(h]h ]h"]h$]h&]uh1hhhhMhjhhubh)}(hXWe don't know exactly how the temperature sensor type selection works. Looks like bits 1-0 are for temp1, bits 3-2 for temp2 and bits 5-4 for temp3, although it is possible that only the most significant bit matters each time. So far, values other than 0 always broke the readings.h]hXWe don’t know exactly how the temperature sensor type selection works. Looks like bits 1-0 are for temp1, bits 3-2 for temp2 and bits 5-4 for temp3, although it is possible that only the most significant bit matters each time. So far, values other than 0 always broke the readings.}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1hhhhMhjhhubh)}(hPWM registers seem to be split in two parts: bit 7 is a mode selector, while the other bits seem to define a value or threshold.h]hPWM registers seem to be split in two parts: bit 7 is a mode selector, while the other bits seem to define a value or threshold.}(hj&hhhNhNubah}(h]h ]h"]h$]h&]uh1hhhhMhjhhubh)}(hXWhen bit 7 is clear, bits 6-0 seem to hold a threshold value. If the value is below a given limit, the fan runs at low speed. If the value is above the limit, the fan runs at full speed. We have no clue as to what the limit represents. Note that there seem to be some inertia in this mode, speed changes may need some time to trigger. Also, an hysteresis mechanism is suspected since walking through all the values increasingly and then decreasingly led to slightly different limits.h]hXWhen bit 7 is clear, bits 6-0 seem to hold a threshold value. If the value is below a given limit, the fan runs at low speed. If the value is above the limit, the fan runs at full speed. We have no clue as to what the limit represents. Note that there seem to be some inertia in this mode, speed changes may need some time to trigger. Also, an hysteresis mechanism is suspected since walking through all the values increasingly and then decreasingly led to slightly different limits.}(hj4hhhNhNubah}(h]h ]h"]h$]h&]uh1hhhhMhjhhubh)}(hXSWhen bit 7 is set, bits 3-0 seem to hold a threshold value, while bits 6-4 would not be significant. If the value is below a given limit, the fan runs at full speed, while if it is above the limit it runs at low speed (so this is the contrary of the other mode, in a way). Here again, we don't know what the limit is supposed to represent.h]hXUWhen bit 7 is set, bits 3-0 seem to hold a threshold value, while bits 6-4 would not be significant. If the value is below a given limit, the fan runs at full speed, while if it is above the limit it runs at low speed (so this is the contrary of the other mode, in a way). Here again, we don’t know what the limit is supposed to represent.}(hjBhhhNhNubah}(h]h ]h"]h$]h&]uh1hhhhMhjhhubh)}(hOne remarkable thing is that the fans would only have two or three different speeds (transitional states left apart), not a whole range as you usually get with PWM.h]hOne remarkable thing is that the fans would only have two or three different speeds (transitional states left apart), not a whole range as you usually get with PWM.}(hjPhhhNhNubah}(h]h ]h"]h$]h&]uh1hhhhMhjhhubh)}(hAs a conclusion, you can write 0x00 or 0x8F to the PWM registers to make fans run at low speed, and 0x7F or 0x80 to make them run at full speed.h]hAs a conclusion, you can write 0x00 or 0x8F to the PWM registers to make fans run at low speed, and 0x7F or 0x80 to make them run at full speed.}(hj^hhhNhNubah}(h]h ]h"]h$]h&]uh1hhhhMhjhhubh)}(hPlease contact us if you can figure out how it is supposed to work. As long as we don't know more, the w83781d driver doesn't handle PWM on AS99127F chips at all.h]hPlease contact us if you can figure out how it is supposed to work. As long as we don’t know more, the w83781d driver doesn’t handle PWM on AS99127F chips at all.}(hjlhhhNhNubah}(h]h ]h"]h$]h&]uh1hhhhMhjhhubh)}(hhh]h)}(hBAdditional info about PWM on the AS99127F rev.1 by Hector Martin: h]h)}(hAAdditional info about PWM on the AS99127F rev.1 by Hector Martin:h]hAAdditional info about PWM on the AS99127F rev.1 by Hector Martin:}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1hhhhMhj}ubah}(h]h ]h"]h$]h&]uh1hhjzhhhhhNubah}(h]h ]h"]h$]h&]jjuh1hhhhMhjhhubh)}(hI've been fiddling around with the (in)famous 0x59 register and found out the following values do work as a form of coarse pwm:h]hI’ve been fiddling around with the (in)famous 0x59 register and found out the following values do work as a form of coarse pwm:}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1hhhhMhjhhubj)}(hhh](j)}(h0x80 - seems to turn fans off after some time(1-2 minutes)... might be some form of auto-fan-control based on temp? hmm (Qfan? this mobo is an old ASUS, it isn't marketed as Qfan. Maybe some beta pre-attempt at Qfan that was dropped at the BIOS)h](j)}(h0x80h]h0x80}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1jhhhMhjubj)}(hhh]h)}(hhh]h)}(hseems to turn fans off after some time(1-2 minutes)... might be some form of auto-fan-control based on temp? hmm (Qfan? this mobo is an old ASUS, it isn't marketed as Qfan. Maybe some beta pre-attempt at Qfan that was dropped at the BIOS)h]h)}(hseems to turn fans off after some time(1-2 minutes)... might be some form of auto-fan-control based on temp? hmm (Qfan? this mobo is an old ASUS, it isn't marketed as Qfan. Maybe some beta pre-attempt at Qfan that was dropped at the BIOS)h]hseems to turn fans off after some time(1-2 minutes)... might be some form of auto-fan-control based on temp? hmm (Qfan? this mobo is an old ASUS, it isn’t marketed as Qfan. Maybe some beta pre-attempt at Qfan that was dropped at the BIOS)}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1hhhhMhjubah}(h]h ]h"]h$]h&]uh1hhjubah}(h]h ]h"]h$]h&]jjuh1hhhhMhjubah}(h]h ]h"]h$]h&]uh1jhjubeh}(h]h ]h"]h$]h&]uh1jhhhMhjubj)}(h 0x81 - offh](j)}(h0x81h]h0x81}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1jhhhMhjubj)}(hhh]h)}(hhh]h)}(hoffh]h)}(hjh]hoff}(hj hhhNhNubah}(h]h ]h"]h$]h&]uh1hhhhMhjubah}(h]h ]h"]h$]h&]uh1hhjubah}(h]h ]h"]h$]h&]jjuh1hhhhMhjubah}(h]h ]h"]h$]h&]uh1jhjubeh}(h]h ]h"]h$]h&]uh1jhhhMhjhhubj)}(h0x82 - slightly "on-ner" than off, but my fans do not get to move. I can hear the high-pitched PWM sound that motors give off at too-low-pwm.h](j)}(h0x82h]h0x82}(hj3hhhNhNubah}(h]h ]h"]h$]h&]uh1jhhhMhj/ubj)}(hhh]h)}(hhh]h)}(hslightly "on-ner" than off, but my fans do not get to move. I can hear the high-pitched PWM sound that motors give off at too-low-pwm.h]h)}(hslightly "on-ner" than off, but my fans do not get to move. I can hear the high-pitched PWM sound that motors give off at too-low-pwm.h]hslightly “on-ner” than off, but my fans do not get to move. I can hear the high-pitched PWM sound that motors give off at too-low-pwm.}(hjKhhhNhNubah}(h]h ]h"]h$]h&]uh1hhhhMhjGubah}(h]h ]h"]h$]h&]uh1hhjDubah}(h]h ]h"]h$]h&]jjuh1hhhhMhjAubah}(h]h ]h"]h$]h&]uh1jhj/ubeh}(h]h ]h"]h$]h&]uh1jhhhMhjhhubj)}(h80x83 - now they do move. Estimate about 70% speed or so.h](j)}(h0x83h]h0x83}(hjuhhhNhNubah}(h]h ]h"]h$]h&]uh1jhhhMhjqubj)}(hhh]h)}(hhh]h)}(h1now they do move. Estimate about 70% speed or so.h]h)}(hjh]h1now they do move. Estimate about 70% speed or so.}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1hhhhMhjubah}(h]h ]h"]h$]h&]uh1hhjubah}(h]h ]h"]h$]h&]jjuh1hhhhMhjubah}(h]h ]h"]h$]h&]uh1jhjqubeh}(h]h ]h"]h$]h&]uh1jhhhMhjhhubj)}(h0x84-0x8f - full on h](j)}(h 0x84-0x8fh]h 0x84-0x8f}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1jhhhMhjubj)}(hhh]h)}(hhh]h)}(hfull on h]h)}(hfull onh]hfull on}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1hhhhMhjubah}(h]h ]h"]h$]h&]uh1hhjubah}(h]h ]h"]h$]h&]jjuh1hhhhMhjubah}(h]h ]h"]h$]h&]uh1jhjubeh}(h]h ]h"]h$]h&]uh1jhhhMhjhhubeh}(h]h ]h"]h$]h&]uh1jhjhhhNhNubh)}(hChanging the high nibble doesn't seem to do much except the high bit (0x80) must be set for PWM to work, else the current pwm doesn't seem to change.h]hChanging the high nibble doesn’t seem to do much except the high bit (0x80) must be set for PWM to work, else the current pwm doesn’t seem to change.}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1hhhhMhjhhubh)}(hMy mobo is an ASUS A7V266-E. This behavior is similar to what I got with speedfan under Windows, where 0-15% would be off, 15-2x% (can't remember the exact value) would be 70% and higher would be full on.h]hMy mobo is an ASUS A7V266-E. This behavior is similar to what I got with speedfan under Windows, where 0-15% would be off, 15-2x% (can’t remember the exact value) would be 70% and higher would be full on.}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1hhhhMhjhhubh)}(hhh]h)}(hNAdditional info about PWM on the AS99127F rev.1 from lm-sensors ticket #2350: h]h)}(hMAdditional info about PWM on the AS99127F rev.1 from lm-sensors ticket #2350:h]hMAdditional info about PWM on the AS99127F rev.1 from lm-sensors ticket #2350:}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1hhhhMhjubah}(h]h ]h"]h$]h&]uh1hhjhhhhhNubah}(h]h ]h"]h$]h&]jjuh1hhhhMhjhhubh)}(hMI conducted some experiment on Asus P3B-F motherboard with AS99127F (Ver. 1).h]hMI conducted some experiment on Asus P3B-F motherboard with AS99127F (Ver. 1).}(hj7hhhNhNubah}(h]h ]h"]h$]h&]uh1hhhhMhjhhubh)}(hoI confirm that 0x59 register control the CPU_Fan Header on this motherboard, and 0x5a register control PWR_Fan.h]hoI confirm that 0x59 register control the CPU_Fan Header on this motherboard, and 0x5a register control PWR_Fan.}(hjEhhhNhNubah}(h]h ]h"]h$]h&]uh1hhhhMhjhhubh)}(hXIn order to reduce the dependency of specific fan, the measurement is conducted with a digital scope without fan connected. I found out that P3B-F actually output variable DC voltage on fan header center pin, looks like PWM is filtered on this motherboard.h]hXIn order to reduce the dependency of specific fan, the measurement is conducted with a digital scope without fan connected. I found out that P3B-F actually output variable DC voltage on fan header center pin, looks like PWM is filtered on this motherboard.}(hjShhhNhNubah}(h]h ]h"]h$]h&]uh1hhhhMhjhhubh)}(hHere are some of measurements:h]hHere are some of measurements:}(hjahhhNhNubah}(h]h ]h"]h$]h&]uh1hhhhMhjhhubj)}(hhh]j)}(hhh](j)}(hhh]h}(h]h ]h"]h$]h&]colwidthKuh1jhjrubj)}(hhh]h}(h]h ]h"]h$]h&]colwidthK uh1jhjrubjY)}(hhh](j^)}(hhh](jc)}(hhh]h)}(h0x80h]h0x80}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1hhhhMhjubah}(h]h ]h"]h$]h&]uh1jbhjubjc)}(hhh]h)}(h20 mVh]h20 mV}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1hhhhMhjubah}(h]h ]h"]h$]h&]uh1jbhjubeh}(h]h ]h"]h$]h&]uh1j]hjubj^)}(hhh](jc)}(hhh]h)}(h0x81h]h0x81}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1hhhhMhjubah}(h]h ]h"]h$]h&]uh1jbhjubjc)}(hhh]h)}(h20 mVh]h20 mV}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1hhhhMhjubah}(h]h ]h"]h$]h&]uh1jbhjubeh}(h]h ]h"]h$]h&]uh1j]hjubj^)}(hhh](jc)}(hhh]h)}(h0x82h]h0x82}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1hhhhMhjubah}(h]h ]h"]h$]h&]uh1jbhjubjc)}(hhh]h)}(h232 mVh]h232 mV}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1hhhhMhjubah}(h]h ]h"]h$]h&]uh1jbhjubeh}(h]h ]h"]h$]h&]uh1j]hjubj^)}(hhh](jc)}(hhh]h)}(h0x83h]h0x83}(hj7hhhNhNubah}(h]h ]h"]h$]h&]uh1hhhhMhj4ubah}(h]h ]h"]h$]h&]uh1jbhj1ubjc)}(hhh]h)}(h1.2 Vh]h1.2 V}(hjNhhhNhNubah}(h]h ]h"]h$]h&]uh1hhhhMhjKubah}(h]h ]h"]h$]h&]uh1jbhj1ubeh}(h]h ]h"]h$]h&]uh1j]hjubj^)}(hhh](jc)}(hhh]h)}(h0x84h]h0x84}(hjnhhhNhNubah}(h]h ]h"]h$]h&]uh1hhhhMhjkubah}(h]h ]h"]h$]h&]uh1jbhjhubjc)}(hhh]h)}(h2.31 Vh]h2.31 V}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1hhhhMhjubah}(h]h ]h"]h$]h&]uh1jbhjhubeh}(h]h ]h"]h$]h&]uh1j]hjubj^)}(hhh](jc)}(hhh]h)}(h0x85h]h0x85}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1hhhhMhjubah}(h]h ]h"]h$]h&]uh1jbhjubjc)}(hhh]h)}(h3.44 Vh]h3.44 V}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1hhhhMhjubah}(h]h ]h"]h$]h&]uh1jbhjubeh}(h]h ]h"]h$]h&]uh1j]hjubj^)}(hhh](jc)}(hhh]h)}(h0x86h]h0x86}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1hhhhMhjubah}(h]h ]h"]h$]h&]uh1jbhjubjc)}(hhh]h)}(h4.62 Vh]h4.62 V}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1hhhhMhjubah}(h]h ]h"]h$]h&]uh1jbhjubeh}(h]h ]h"]h$]h&]uh1j]hjubj^)}(hhh](jc)}(hhh]h)}(h0x87h]h0x87}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1hhhhMhjubah}(h]h ]h"]h$]h&]uh1jbhj ubjc)}(hhh]h)}(h5.81 Vh]h5.81 V}(hj*hhhNhNubah}(h]h ]h"]h$]h&]uh1hhhhMhj'ubah}(h]h ]h"]h$]h&]uh1jbhj ubeh}(h]h ]h"]h$]h&]uh1j]hjubj^)}(hhh](jc)}(hhh]h)}(h0x88h]h0x88}(hjJhhhNhNubah}(h]h ]h"]h$]h&]uh1hhhhMhjGubah}(h]h ]h"]h$]h&]uh1jbhjDubjc)}(hhh]h)}(h7.01 Vh]h7.01 V}(hjahhhNhNubah}(h]h ]h"]h$]h&]uh1hhhhMhj^ubah}(h]h ]h"]h$]h&]uh1jbhjDubeh}(h]h ]h"]h$]h&]uh1j]hjubj^)}(hhh](jc)}(hhh]h)}(h9x89h]h9x89}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1hhhhMhj~ubah}(h]h ]h"]h$]h&]uh1jbhj{ubjc)}(hhh]h)}(h8.22 Vh]h8.22 V}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1hhhhMhjubah}(h]h ]h"]h$]h&]uh1jbhj{ubeh}(h]h ]h"]h$]h&]uh1j]hjubj^)}(hhh](jc)}(hhh]h)}(h0x8ah]h0x8a}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1hhhhMhjubah}(h]h ]h"]h$]h&]uh1jbhjubjc)}(hhh]h)}(h9.42 Vh]h9.42 V}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1hhhhMhjubah}(h]h ]h"]h$]h&]uh1jbhjubeh}(h]h ]h"]h$]h&]uh1j]hjubj^)}(hhh](jc)}(hhh]h)}(h0x8bh]h0x8b}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1hhhhMhjubah}(h]h ]h"]h$]h&]uh1jbhjubjc)}(hhh]h)}(h10.6 Vh]h10.6 V}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1hhhhMhjubah}(h]h ]h"]h$]h&]uh1jbhjubeh}(h]h ]h"]h$]h&]uh1j]hjubj^)}(hhh](jc)}(hhh]h)}(h0x8ch]h0x8c}(hj&hhhNhNubah}(h]h ]h"]h$]h&]uh1hhhhMhj#ubah}(h]h ]h"]h$]h&]uh1jbhj ubjc)}(hhh]h)}(h11.9 Vh]h11.9 V}(hj=hhhNhNubah}(h]h ]h"]h$]h&]uh1hhhhMhj:ubah}(h]h ]h"]h$]h&]uh1jbhj ubeh}(h]h ]h"]h$]h&]uh1j]hjubj^)}(hhh](jc)}(hhh]h)}(h0x8dh]h0x8d}(hj]hhhNhNubah}(h]h ]h"]h$]h&]uh1hhhhMhjZubah}(h]h ]h"]h$]h&]uh1jbhjWubjc)}(hhh]h)}(h12.4 Vh]h12.4 V}(hjthhhNhNubah}(h]h ]h"]h$]h&]uh1hhhhMhjqubah}(h]h ]h"]h$]h&]uh1jbhjWubeh}(h]h ]h"]h$]h&]uh1j]hjubj^)}(hhh](jc)}(hhh]h)}(h0x8eh]h0x8e}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1hhhhMhjubah}(h]h ]h"]h$]h&]uh1jbhjubjc)}(hhh]h)}(h12.4 Vh]h12.4 V}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1hhhhMhjubah}(h]h ]h"]h$]h&]uh1jbhjubeh}(h]h ]h"]h$]h&]uh1j]hjubj^)}(hhh](jc)}(hhh]h)}(h0x8fh]h0x8f}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1hhhhMhjubah}(h]h ]h"]h$]h&]uh1jbhjubjc)}(hhh]h)}(h12.4 Vh]h12.4 V}(hjhhhNhNubah}(h]h ]h"]h$]h&]uh1hhhhMhjubah}(h]h ]h"]h$]h&]uh1jbhjubeh}(h]h ]h"]h$]h&]uh1j]hjubeh}(h]h ]h"]h$]h&]uh1jXhjrubeh}(h]h ]h"]h$]h&]colsKuh1jhjoubah}(h]h ]h"]h$]h&]uh1jhjhhhhhNubeh}(h]pwmah ]h"]pwmah$]h&]uh1hhjhhhhhMubeh}(h] asus-clonesah ]h"] asus clonesah$]h&]uh1hhhhhhhhMubeh}(h]kernel-driver-w83781dah ]h"]kernel driver w83781dah$]h&]uh1hhhhhhhhKubeh}(h]h ]h"]h$]h&]sourcehuh1hcurrent_sourceN current_lineNsettingsdocutils.frontendValues)}(hN generatorN datestampN source_linkN source_urlN toc_backlinksjbfootnote_backlinksK sectnum_xformKstrip_commentsNstrip_elements_with_classesN strip_classesN report_levelK halt_levelKexit_status_levelKdebugNwarning_streamN tracebackinput_encoding utf-8-siginput_encoding_error_handlerstrictoutput_encodingutf-8output_encoding_error_handlerjIerror_encodingutf-8error_encoding_error_handlerbackslashreplace language_codeenrecord_dependenciesNconfigN id_prefixhauto_id_prefixid dump_settingsNdump_internalsNdump_transformsNdump_pseudo_xmlNexpose_internalsNstrict_visitorN_disable_configN_sourceh _destinationN _config_files]7/var/lib/git/docbuild/linux/Documentation/docutils.confafile_insertion_enabled raw_enabledKline_length_limitM'pep_referencesN pep_base_urlhttps://peps.python.org/pep_file_url_templatepep-%04drfc_referencesN rfc_base_url&https://datatracker.ietf.org/doc/html/ tab_widthKtrim_footnote_reference_spacesyntax_highlightlong smart_quotessmartquotes_locales]character_level_inline_markupdoctitle_xform docinfo_xformKsectsubtitle_xform image_loadinglinkembed_stylesheetcloak_email_addressessection_self_linkenvNubreporterNindirect_targets]substitution_defs}substitution_names}refnames}refids}nameids}(j$j!jjj| jy j8j5jjj~j{jjjjjjj{jxjOjLjjjju nametypes}(j$jj| j8jj~jjjj{jOjjuh}(j!hjjjy jj5j jj;j{jjjjjjjjxjjLj~jjRjju footnote_refs} citation_refs} autofootnotes]autofootnote_refs]symbol_footnotes]symbol_footnote_refs] footnotes] citations]autofootnote_startKsymbol_footnote_startK id_counter collectionsCounter}Rparse_messages]transform_messages] transformerN include_log] decorationNhhub.