aic7xxx.txt 19 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395
  1. ====================================================================
  2. = Adaptec Aic7xxx Fast -> Ultra160 Family Manager Set v7.0 =
  3. = README for =
  4. = The Linux Operating System =
  5. ====================================================================
  6. The following information is available in this file:
  7. 1. Supported Hardware
  8. 2. Version History
  9. 3. Command Line Options
  10. 4. Contacting Adaptec
  11. 1. Supported Hardware
  12. The following Adaptec SCSI Chips and Host Adapters are supported by
  13. the aic7xxx driver.
  14. Chip MIPS Host Bus MaxSync MaxWidth SCBs Notes
  15. ---------------------------------------------------------------
  16. aic7770 10 EISA/VL 10MHz 16Bit 4 1
  17. aic7850 10 PCI/32 10MHz 8Bit 3
  18. aic7855 10 PCI/32 10MHz 8Bit 3
  19. aic7856 10 PCI/32 10MHz 8Bit 3
  20. aic7859 10 PCI/32 20MHz 8Bit 3
  21. aic7860 10 PCI/32 20MHz 8Bit 3
  22. aic7870 10 PCI/32 10MHz 16Bit 16
  23. aic7880 10 PCI/32 20MHz 16Bit 16
  24. aic7890 20 PCI/32 40MHz 16Bit 16 3 4 5 6 7 8
  25. aic7891 20 PCI/64 40MHz 16Bit 16 3 4 5 6 7 8
  26. aic7892 20 PCI/64-66 80MHz 16Bit 16 3 4 5 6 7 8
  27. aic7895 15 PCI/32 20MHz 16Bit 16 2 3 4 5
  28. aic7895C 15 PCI/32 20MHz 16Bit 16 2 3 4 5 8
  29. aic7896 20 PCI/32 40MHz 16Bit 16 2 3 4 5 6 7 8
  30. aic7897 20 PCI/64 40MHz 16Bit 16 2 3 4 5 6 7 8
  31. aic7899 20 PCI/64-66 80MHz 16Bit 16 2 3 4 5 6 7 8
  32. 1. Multiplexed Twin Channel Device - One controller servicing two
  33. busses.
  34. 2. Multi-function Twin Channel Device - Two controllers on one chip.
  35. 3. Command Channel Secondary DMA Engine - Allows scatter gather list
  36. and SCB prefetch.
  37. 4. 64 Byte SCB Support - Allows disconnected, untagged request table
  38. for all possible target/lun combinations.
  39. 5. Block Move Instruction Support - Doubles the speed of certain
  40. sequencer operations.
  41. 6. `Bayonet' style Scatter Gather Engine - Improves S/G prefetch
  42. performance.
  43. 7. Queuing Registers - Allows queuing of new transactions without
  44. pausing the sequencer.
  45. 8. Multiple Target IDs - Allows the controller to respond to selection
  46. as a target on multiple SCSI IDs.
  47. Controller Chip Host-Bus Int-Connectors Ext-Connectors Notes
  48. --------------------------------------------------------------------------
  49. AHA-274X[A] aic7770 EISA SE-50M SE-HD50F
  50. AHA-274X[A]W aic7770 EISA SE-HD68F SE-HD68F
  51. SE-50M
  52. AHA-274X[A]T aic7770 EISA 2 X SE-50M SE-HD50F
  53. AHA-2842 aic7770 VL SE-50M SE-HD50F
  54. AHA-2940AU aic7860 PCI/32 SE-50M SE-HD50F
  55. AVA-2902I aic7860 PCI/32 SE-50M
  56. AVA-2902E aic7860 PCI/32 SE-50M
  57. AVA-2906 aic7856 PCI/32 SE-50M SE-DB25F
  58. APC-7850 aic7850 PCI/32 SE-50M 1
  59. AVA-2940 aic7860 PCI/32 SE-50M
  60. AHA-2920B aic7860 PCI/32 SE-50M
  61. AHA-2930B aic7860 PCI/32 SE-50M
  62. AHA-2920C aic7856 PCI/32 SE-50M SE-HD50F
  63. AHA-2930C aic7860 PCI/32 SE-50M
  64. AHA-2930C aic7860 PCI/32 SE-50M
  65. AHA-2910C aic7860 PCI/32 SE-50M
  66. AHA-2915C aic7860 PCI/32 SE-50M
  67. AHA-2940AU/CN aic7860 PCI/32 SE-50M SE-HD50F
  68. AHA-2944W aic7870 PCI/32 HVD-HD68F HVD-HD68F
  69. HVD-50M
  70. AHA-3940W aic7870 PCI/32 2 X SE-HD68F SE-HD68F 2
  71. AHA-2940UW aic7880 PCI/32 SE-HD68F
  72. SE-50M SE-HD68F
  73. AHA-2940U aic7880 PCI/32 SE-50M SE-HD50F
  74. AHA-2940D aic7880 PCI/32
  75. aHA-2940 A/T aic7880 PCI/32
  76. AHA-2940D A/T aic7880 PCI/32
  77. AHA-3940UW aic7880 PCI/32 2 X SE-HD68F SE-HD68F 3
  78. AHA-3940UWD aic7880 PCI/32 2 X SE-HD68F 2 X SE-VHD68F 3
  79. AHA-3940U aic7880 PCI/32 2 X SE-50M SE-HD50F 3
  80. AHA-2944UW aic7880 PCI/32 HVD-HD68F HVD-HD68F
  81. HVD-50M
  82. AHA-3944UWD aic7880 PCI/32 2 X HVD-HD68F 2 X HVD-VHD68F 3
  83. AHA-4944UW aic7880 PCI/32
  84. AHA-2930UW aic7880 PCI/32
  85. AHA-2940UW Pro aic7880 PCI/32 SE-HD68F SE-HD68F 4
  86. SE-50M
  87. AHA-2940UW/CN aic7880 PCI/32
  88. AHA-2940UDual aic7895 PCI/32
  89. AHA-2940UWDual aic7895 PCI/32
  90. AHA-3940UWD aic7895 PCI/32
  91. AHA-3940AUW aic7895 PCI/32
  92. AHA-3940AUWD aic7895 PCI/32
  93. AHA-3940AU aic7895 PCI/32
  94. AHA-3944AUWD aic7895 PCI/32 2 X HVD-HD68F 2 X HVD-VHD68F
  95. AHA-2940U2B aic7890 PCI/32 LVD-HD68F LVD-HD68F
  96. AHA-2940U2 OEM aic7891 PCI/64
  97. AHA-2940U2W aic7890 PCI/32 LVD-HD68F LVD-HD68F
  98. SE-HD68F
  99. SE-50M
  100. AHA-2950U2B aic7891 PCI/64 LVD-HD68F LVD-HD68F
  101. AHA-2930U2 aic7890 PCI/32 LVD-HD68F SE-HD50F
  102. SE-50M
  103. AHA-3950U2B aic7897 PCI/64
  104. AHA-3950U2D aic7897 PCI/64
  105. AHA-29160 aic7892 PCI/64-66
  106. AHA-29160 CPQ aic7892 PCI/64-66
  107. AHA-29160N aic7892 PCI/32 LVD-HD68F SE-HD50F
  108. SE-50M
  109. AHA-29160LP aic7892 PCI/64-66
  110. AHA-19160 aic7892 PCI/64-66
  111. AHA-29150LP aic7892 PCI/64-66
  112. AHA-29130LP aic7892 PCI/64-66
  113. AHA-3960D aic7899 PCI/64-66 2 X LVD-HD68F 2 X LVD-VHD68F
  114. LVD-50M
  115. AHA-3960D CPQ aic7899 PCI/64-66 2 X LVD-HD68F 2 X LVD-VHD68F
  116. LVD-50M
  117. AHA-39160 aic7899 PCI/64-66 2 X LVD-HD68F 2 X LVD-VHD68F
  118. LVD-50M
  119. 1. No BIOS support
  120. 2. DEC21050 PCI-PCI bridge with multiple controller chips on secondary bus
  121. 3. DEC2115X PCI-PCI bridge with multiple controller chips on secondary bus
  122. 4. All three SCSI connectors may be used simultaneously without
  123. SCSI "stub" effects.
  124. 2. Version History
  125. 7.0 (4th August, 2005)
  126. - Updated driver to use SCSI transport class infrastructure
  127. - Upported sequencer and core fixes from last adaptec released
  128. version of the driver.
  129. 6.2.36 (June 3rd, 2003)
  130. - Correct code that disables PCI parity error checking.
  131. - Correct and simplify handling of the ignore wide residue
  132. message. The previous code would fail to report a residual
  133. if the transaction data length was even and we received
  134. an IWR message.
  135. - Add support for the 2.5.X EISA framework.
  136. - Update for change in 2.5.X SCSI proc FS interface.
  137. - Correct Domain Validation command-line option parsing.
  138. - When negotiation async via an 8bit WDTR message, send
  139. an SDTR with an offset of 0 to be sure the target
  140. knows we are async. This works around a firmware defect
  141. in the Quantum Atlas 10K.
  142. - Clear PCI error state during driver attach so that we
  143. don't disable memory mapped I/O due to a stray write
  144. by some other driver probe that occurred before we
  145. claimed the controller.
  146. 6.2.35 (May 14th, 2003)
  147. - Fix a few GCC 3.3 compiler warnings.
  148. - Correct operation on EISA Twin Channel controller.
  149. - Add support for 2.5.X's scsi_report_device_reset().
  150. 6.2.34 (May 5th, 2003)
  151. - Fix locking regression introduced in 6.2.29 that
  152. could cause a lock order reversal between the io_request_lock
  153. and our per-softc lock. This was only possible on RH9,
  154. SuSE, and kernel.org 2.4.X kernels.
  155. 6.2.33 (April 30th, 2003)
  156. - Dynamically disable PCI parity error reporting after
  157. 10 errors are reported to the user. These errors are
  158. the result of some other device issuing PCI transactions
  159. with bad parity. Once the user has been informed of the
  160. problem, continuing to report the errors just degrades
  161. our performance.
  162. 6.2.32 (March 28th, 2003)
  163. - Dynamically sized S/G lists to avoid SCSI malloc
  164. pool fragmentation and SCSI mid-layer deadlock.
  165. 6.2.28 (January 20th, 2003)
  166. - Domain Validation Fixes
  167. - Add ability to disable PCI parity error checking.
  168. - Enhanced Memory Mapped I/O probe
  169. 6.2.20 (November 7th, 2002)
  170. - Added Domain Validation.
  171. 3. Command Line Options
  172. WARNING: ALTERING OR ADDING THESE DRIVER PARAMETERS
  173. INCORRECTLY CAN RENDER YOUR SYSTEM INOPERABLE.
  174. USE THEM WITH CAUTION.
  175. Put a .conf file in the /etc/modprobe.d directory and add/edit a
  176. line containing 'options aic7xxx aic7xxx=[command[,command...]]' where
  177. 'command' is one or more of the following:
  178. -----------------------------------------------------------------
  179. Option: verbose
  180. Definition: enable additional informative messages during
  181. driver operation.
  182. Possible Values: This option is a flag
  183. Default Value: disabled
  184. -----------------------------------------------------------------
  185. Option: debug:[value]
  186. Definition: Enables various levels of debugging information
  187. Possible Values: 0x0000 = no debugging, 0xffff = full debugging
  188. Default Value: 0x0000
  189. -----------------------------------------------------------------
  190. Option: no_probe
  191. Option: probe_eisa_vl
  192. Definition: Do not probe for EISA/VLB controllers.
  193. This is a toggle. If the driver is compiled
  194. to not probe EISA/VLB controllers by default,
  195. specifying "no_probe" will enable this probing.
  196. If the driver is compiled to probe EISA/VLB
  197. controllers by default, specifying "no_probe"
  198. will disable this probing.
  199. Possible Values: This option is a toggle
  200. Default Value: EISA/VLB probing is disabled by default.
  201. -----------------------------------------------------------------
  202. Option: pci_parity
  203. Definition: Toggles the detection of PCI parity errors.
  204. On many motherboards with VIA chipsets,
  205. PCI parity is not generated correctly on the
  206. PCI bus. It is impossible for the hardware to
  207. differentiate between these "spurious" parity
  208. errors and real parity errors. The symptom of
  209. this problem is a stream of the message:
  210. "scsi0: Data Parity Error Detected during address or write data phase"
  211. output by the driver.
  212. Possible Values: This option is a toggle
  213. Default Value: PCI Parity Error reporting is disabled
  214. -----------------------------------------------------------------
  215. Option: no_reset
  216. Definition: Do not reset the bus during the initial probe
  217. phase
  218. Possible Values: This option is a flag
  219. Default Value: disabled
  220. -----------------------------------------------------------------
  221. Option: extended
  222. Definition: Force extended translation on the controller
  223. Possible Values: This option is a flag
  224. Default Value: disabled
  225. -----------------------------------------------------------------
  226. Option: periodic_otag
  227. Definition: Send an ordered tag periodically to prevent
  228. tag starvation. Needed for some older devices
  229. Possible Values: This option is a flag
  230. Default Value: disabled
  231. -----------------------------------------------------------------
  232. Option: reverse_scan
  233. Definition: Probe the scsi bus in reverse order, starting
  234. with target 15
  235. Possible Values: This option is a flag
  236. Default Value: disabled
  237. -----------------------------------------------------------------
  238. Option: global_tag_depth:[value]
  239. Definition: Global tag depth for all targets on all busses.
  240. This option sets the default tag depth which
  241. may be selectively overridden vi the tag_info
  242. option.
  243. Possible Values: 1 - 253
  244. Default Value: 32
  245. -----------------------------------------------------------------
  246. Option: tag_info:{{value[,value...]}[,{value[,value...]}...]}
  247. Definition: Set the per-target tagged queue depth on a
  248. per controller basis. Both controllers and targets
  249. may be omitted indicating that they should retain
  250. the default tag depth.
  251. Examples: tag_info:{{16,32,32,64,8,8,,32,32,32,32,32,32,32,32,32}
  252. On Controller 0
  253. specifies a tag depth of 16 for target 0
  254. specifies a tag depth of 64 for target 3
  255. specifies a tag depth of 8 for targets 4 and 5
  256. leaves target 6 at the default
  257. specifies a tag depth of 32 for targets 1,2,7-15
  258. All other targets retain the default depth.
  259. tag_info:{{},{32,,32}}
  260. On Controller 1
  261. specifies a tag depth of 32 for targets 0 and 2
  262. All other targets retain the default depth.
  263. Possible Values: 1 - 253
  264. Default Value: 32
  265. -----------------------------------------------------------------
  266. Option: seltime:[value]
  267. Definition: Specifies the selection timeout value
  268. Possible Values: 0 = 256ms, 1 = 128ms, 2 = 64ms, 3 = 32ms
  269. Default Value: 0
  270. -----------------------------------------------------------------
  271. Option: dv: {value[,value...]}
  272. Definition: Set Domain Validation Policy on a per-controller basis.
  273. Controllers may be omitted indicating that
  274. they should retain the default read streaming setting.
  275. Example: dv:{-1,0,,1,1,0}
  276. On Controller 0 leave DV at its default setting.
  277. On Controller 1 disable DV.
  278. Skip configuration on Controller 2.
  279. On Controllers 3 and 4 enable DV.
  280. On Controller 5 disable DV.
  281. Possible Values: < 0 Use setting from serial EEPROM.
  282. 0 Disable DV
  283. > 0 Enable DV
  284. Default Value: SCSI-Select setting on controllers with a SCSI Select
  285. option for DV. Otherwise, on for controllers supporting
  286. U160 speeds and off for all other controller types.
  287. -----------------------------------------------------------------
  288. Example:
  289. 'options aic7xxx aic7xxx=verbose,no_probe,tag_info:{{},{,,10}},seltime:1'
  290. enables verbose logging, Disable EISA/VLB probing,
  291. and set tag depth on Controller 1/Target 2 to 10 tags.
  292. 4. Adaptec Customer Support
  293. A Technical Support Identification (TSID) Number is required for
  294. Adaptec technical support.
  295. - The 12-digit TSID can be found on the white barcode-type label
  296. included inside the box with your product. The TSID helps us
  297. provide more efficient service by accurately identifying your
  298. product and support status.
  299. Support Options
  300. - Search the Adaptec Support Knowledgebase (ASK) at
  301. http://ask.adaptec.com for articles, troubleshooting tips, and
  302. frequently asked questions about your product.
  303. - For support via Email, submit your question to Adaptec's
  304. Technical Support Specialists at http://ask.adaptec.com/.
  305. North America
  306. - Visit our Web site at http://www.adaptec.com/.
  307. - For information about Adaptec's support options, call
  308. 408-957-2550, 24 hours a day, 7 days a week.
  309. - To speak with a Technical Support Specialist,
  310. * For hardware products, call 408-934-7274,
  311. Monday to Friday, 3:00 am to 5:00 pm, PDT.
  312. * For RAID and Fibre Channel products, call 321-207-2000,
  313. Monday to Friday, 3:00 am to 5:00 pm, PDT.
  314. To expedite your service, have your computer with you.
  315. - To order Adaptec products, including accessories and cables,
  316. call 408-957-7274. To order cables online go to
  317. http://www.adaptec.com/buy-cables/.
  318. Europe
  319. - Visit our Web site at http://www.adaptec.com/en-US/_common/world_index.
  320. - To speak with a Technical Support Specialist, call, or email,
  321. * German: +49 89 4366 5522, Monday-Friday, 9:00-17:00 CET,
  322. http://ask-de.adaptec.com/.
  323. * French: +49 89 4366 5533, Monday-Friday, 9:00-17:00 CET,
  324. http://ask-fr.adaptec.com/.
  325. * English: +49 89 4366 5544, Monday-Friday, 9:00-17:00 GMT,
  326. http://ask.adaptec.com/.
  327. - You can order Adaptec cables online at
  328. http://www.adaptec.com/buy-cables/.
  329. Japan
  330. - Visit our web site at http://www.adaptec.co.jp/.
  331. - To speak with a Technical Support Specialist, call
  332. +81 3 5308 6120, Monday-Friday, 9:00 a.m. to 12:00 p.m.,
  333. 1:00 p.m. to 6:00 p.m.
  334. -------------------------------------------------------------------
  335. /*
  336. * Copyright (c) 2003 Adaptec Inc. 691 S. Milpitas Blvd., Milpitas CA 95035 USA.
  337. * All rights reserved.
  338. *
  339. * You are permitted to redistribute, use and modify this README file in whole
  340. * or in part in conjunction with redistribution of software governed by the
  341. * General Public License, provided that the following conditions are met:
  342. * 1. Redistributions of README file must retain the above copyright
  343. * notice, this list of conditions, and the following disclaimer,
  344. * without modification.
  345. * 2. The name of the author may not be used to endorse or promote products
  346. * derived from this software without specific prior written permission.
  347. * 3. Modifications or new contributions must be attributed in a copyright
  348. * notice identifying the author ("Contributor") and added below the
  349. * original copyright notice. The copyright notice is for purposes of
  350. * identifying contributors and should not be deemed as permission to alter
  351. * the permissions given by Adaptec.
  352. *
  353. * THIS README FILE IS PROVIDED BY ADAPTEC AND CONTRIBUTORS ``AS IS'' AND
  354. * ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, ANY
  355. * WARRANTIES OF NON-INFRINGEMENT OR THE IMPLIED WARRANTIES OF MERCHANTABILITY
  356. * AND FITNESS FOR A PARTICULAR PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL
  357. * ADAPTEC OR CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL,
  358. * SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT LIMITED
  359. * TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, DATA, OR
  360. * PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY THEORY OF
  361. * LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT (INCLUDING
  362. * NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE OF THIS README
  363. * FILE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
  364. */