• Home
  • History
  • Annotate
Name Date Size #Lines LOC

..--

aicasm/01-Feb-2010-4,8843,679

Config.inD01-Feb-20101.5 KiB3736

MakefileD01-Feb-20102.5 KiB9866

README.aic79xxD01-Feb-201023 KiB497443

README.aic7xxxD01-Feb-201019.9 KiB415382

aic7770.cD01-Feb-201010.1 KiB416294

aic7770_osm.cD01-Feb-20107.5 KiB280187

aic79xx.hD01-Feb-201048.1 KiB1,535905

aic79xx.regD01-Feb-201065.5 KiB3,9593,652

aic79xx.seqD01-Feb-201062.8 KiB2,0331,919

aic79xx_core.cD01-Feb-2010259 KiB9,5426,816

aic79xx_inline.hD01-Feb-201028 KiB959672

aic79xx_osm.cD01-Feb-2010139.1 KiB5,1303,722

aic79xx_osm.hD01-Feb-201034.1 KiB1,237849

aic79xx_osm_pci.cD01-Feb-201011.9 KiB453344

aic79xx_pci.cD01-Feb-201026.6 KiB1,009743

aic79xx_proc.cD01-Feb-20109.9 KiB363275

aic79xx_reg.hD01-Feb-2010101.3 KiB3,7773,094

aic79xx_reg_print.cD01-Feb-201089.6 KiB3,6363,132

aic79xx_seq.hD01-Feb-201027.4 KiB1,1401,083

aic7xxx.hD01-Feb-201043.4 KiB1,353720

aic7xxx.regD01-Feb-201033.5 KiB1,5951,472

aic7xxx.seqD01-Feb-201068.8 KiB2,3992,251

aic7xxx_93cx6.cD01-Feb-20108.9 KiB307166

aic7xxx_93cx6.hD01-Feb-20103.6 KiB10336

aic7xxx_core.cD01-Feb-2010196.9 KiB7,4535,244

aic7xxx_inline.hD01-Feb-201018.9 KiB650400

aic7xxx_osm.cD01-Feb-2010139.9 KiB5,1343,624

aic7xxx_osm.hD01-Feb-201033.1 KiB1,203807

aic7xxx_osm_pci.cD01-Feb-201011 KiB429321

aic7xxx_pci.cD01-Feb-201062.5 KiB2,4851,863

aic7xxx_proc.cD01-Feb-201010.1 KiB386296

aic7xxx_reg.hD01-Feb-201047.7 KiB1,7881,471

aic7xxx_reg_print.cD01-Feb-201041.2 KiB1,6821,454

aic7xxx_seq.hD01-Feb-201032.1 KiB1,3081,249

aiclib.cD01-Feb-201047.9 KiB1,4141,200

aiclib.hD01-Feb-201025.7 KiB1,047774

cam.hD01-Feb-20104.6 KiB11863

queue.hD01-Feb-201016.7 KiB502298

scsi_iu.hD01-Feb-20101 KiB4033

scsi_message.hD01-Feb-20102.7 KiB7156

README.aic79xx

1====================================================================
2=             Adaptec Ultra320 Family Manager Set v1.3.0           =
3=                                                                  =
4=                            README for                            =
5=                    The Linux Operating System                    =
6====================================================================
7
8The following information is available in this file:
9
10  1. Supported Hardware
11  2. Version History
12  3. Command Line Options
13  4. Additional Notes
14  5. Contacting Adaptec
15
16
171. Supported Hardware
18
19   The following Adaptec SCSI Host Adapters are supported by this
20   driver set.
21
22   Ultra320 Adapters         Description
23   ----------------------------------------------------------------
24   Adaptec SCSI Card 39320   Dual Channel 64-bit PCI-X 133MHz to
25                             Ultra320 SCSI Card (one external
26                             68-pin, two internal 68-pin)
27   Adaptec SCSI Card 39320D  Dual Channel 64-bit PCI-X 133MHz to
28                             Ultra320 SCSI Card (two external VHDC
29                             and one internal 68-pin)
30   Adaptec SCSI Card 39320D  Dual Channel 64-bit PCI-X 133MHz to
31                             Ultra320 SCSI Card (two external VHDC
32                             and one internal 68-pin) based on the
33                             AIC-7902B ASIC
34   Adaptec SCSI Card 29320   Single Channel 64-bit PCI-X 133MHz to
35                             Ultra320 SCSI Card (one external
36                             68-pin, two internal 68-pin, one
37                             internal 50-pin)
38   Adaptec SCSI Card 29320LP Single Channel 64-bit Low Profile
39                             PCI-X 133MHz to Ultra320 SCSI Card
40                             (One external VHDC, one internal
41                             68-pin)
42   AIC-7901A                 Single Channel 64-bit PCI-X 133MHz to
43                             Ultra320 SCSI ASIC
44   AIC-7902A4                Dual Channel 64-bit PCI-X 133MHz to
45                             Ultra320 SCSI ASIC
46   AIC-7902B                 Dual Channel 64-bit PCI-X 133MHz to
47                             Ultra320 SCSI ASIC
48
492. Version History
50   1.3.10 (June 3rd, 2003)
51        - Align the SCB_TAG field on a 16byte boundary.  This avoids
52          SCB corruption on some PCI-33 busses.
53        - Correct non-zero luns on Rev B. hardware.
54        - Update for change in 2.5.X SCSI proc FS interface.
55        - When negotiation async via an 8bit WDTR message, send
56          an SDTR with an offset of 0 to be sure the target
57          knows we are async.  This works around a firmware defect
58          in the Quantum Atlas 10K.
59        - Implement controller susupend and resume.
60        - Clear PCI error state during driver attach so that we
61          don't disable memory mapped I/O due to a stray write
62          by some other driver probe that occurred before we
63          claimed the controller.
64
65   1.3.9 (May 22nd, 2003)
66        - Fix compiler errors.
67        - Remove S/G splitting for segments that cross a 4GB boundary.
68          This is guaranteed not to happen in Linux.
69        - Add support for scsi_report_device_reset() found in
70          2.5.X kernels.
71        - Add 7901B support.
72        - Simplify handling of the packtized lun Rev A workaround.
73        - Correct and simplify handling of the ignore wide residue
74          message.  The previous code would fail to report a residual
75          if the transaction data length was even and we received
76          an IWR message.
77
78   1.3.8 (April 29th, 2003)
79        - Fix types accessed via the command line interface code.
80        - Perform a few firmware optimizations.
81        - Fix "Unexpected PKT busfree" errors.
82        - Use a sequencer interrupt to notify the host of
83          commands with bad status.  We defer the notification
84          until there are no outstanding selections to ensure
85          that the host is interrupted for as short a time as
86          possible.
87        - Remove pre-2.2.X support.
88        - Add support for new 2.5.X interrupt API.
89        - Correct big-endian architecture support.
90
91   1.3.7 (April 16th, 2003)
92        - Use del_timer_sync() to ensure that no timeouts
93          are pending during controller shutdown.
94        - For pre-2.5.X kernels, carefully adjust our segment
95          list size to avoid SCSI malloc pool fragmentation.
96        - Cleanup channel display in our /proc output.
97        - Workaround duplicate device entries in the mid-layer
98          devlice list during add-single-device.
99
100   1.3.6 (March 28th, 2003)
101        - Correct a double free in the Domain Validation code.
102        - Correct a reference to free'ed memory during controller
103          shutdown.
104        - Reset the bus on an SE->LVD change.  This is required
105          to reset our transcievers.
106
107   1.3.5 (March 24th, 2003)
108        - Fix a few register window mode bugs.
109        - Include read streaming in the PPR flags we display in
110          diagnostics as well as /proc.
111        - Add PCI hot plug support for 2.5.X kernels.
112        - Correct default precompensation value for RevA hardware.
113        - Fix Domain Validation thread shutdown.
114        - Add a firmware workaround to make the LED blink
115          brighter during packetized operations on the H2A4.
116        - Correct /proc display of user read streaming settings.
117        - Simplify driver locking by releasing the io_request_lock
118          upon driver entry from the mid-layer.
119        - Cleanup command line parsing and move much of this code
120          to aiclib.
121
122   1.3.4 (February 28th, 2003)
123        - Correct a race condition in our error recovery handler.
124        - Allow Test Unit Ready commands to take a full 5 seconds
125          during Domain Validation.
126
127   1.3.2 (February 19th, 2003)
128        - Correct a Rev B. regression due to the GEM318
129          compatibility fix included in 1.3.1.
130
131   1.3.1 (February 11th, 2003)
132        - Add support for the 39320A.
133        - Improve recovery for certain PCI-X errors.
134        - Fix handling of LQ/DATA/LQ/DATA for the
135          same write transaction that can occur without
136          interveining training.
137        - Correct compatibility issues with the GEM318
138          enclosure services device.
139        - Correct data corruption issue that occurred under
140          high tag depth write loads.
141        - Adapt to a change in the 2.5.X daemonize() API.
142        - Correct a "Missing case in ahd_handle_scsiint" panic.
143
144   1.3.0 (January 21st, 2003)
145        - Full regression testing for all U320 products completed.
146        - Added abort and target/lun reset error recovery handler and
147          interrupt coalessing.
148
149   1.2.0 (November 14th, 2002)
150        - Added support for Domain Validation
151        - Add support for the Hewlett-Packard version of the 39320D
152          and AIC-7902 adapters.
153        Support for previous adapters has not been fully tested and should
154        only be used at the customer's own risk.
155
156   1.1.1 (September 24th, 2002)
157        - Added support for the Linux 2.5.X kernel series
158
159   1.1.0 (September 17th, 2002)
160        - Added support for four additional SCSI products:
161          ASC-39320, ASC-29320, ASC-29320LP, AIC-7901.
162
163   1.0.0 (May 30th, 2002)
164        - Initial driver release.
165
166   2.1. Software/Hardware Features
167        - Support for the SPI-4 "Ultra320" standard:
168          - 320MB/s transfer rates
169          - Packetized SCSI Protocol at 160MB/s and 320MB/s
170          - Quick Arbitration Selection (QAS)
171          - Retained Training Information (Rev B. ASIC only)
172        - Interrupt Coalessing
173        - Initiator Mode (target mode not currently
174          supported)
175        - Support for the PCI-X standard up to 133MHz
176        - Support for the PCI v2.2 standard
177	- Domain Validation
178
179   2.2. Operating System Support:
180        - Redhat Linux 7.2, 7.3, 8.0, Advanced Server 2.1
181        - SuSE Linux 7.3, 8.0, 8.1, Enterprise Server 7
182        - only Intel and AMD x86 supported at this time
183        - >4GB memory configurations supported.
184
185     Refer to the User's Guide for more details on this.
186
1873. Command Line Options
188
189        WARNING: ALTERING OR ADDING THESE DRIVER PARAMETERS
190                 INCORRECTLY CAN RENDER YOUR SYSTEM INOPERABLE.
191                 USE THEM WITH CAUTION.
192
193   Edit the file "modules.conf" in the directory /etc and add/edit a
194   line containing 'options aic79xx aic79xx=[command[,command...]]' where
195   'command' is one or more of the following:
196   -----------------------------------------------------------------
197              Option: verbose
198          Definition: enable additional informative messages during
199                      driver operation.
200     Possible Values: This option is a flag
201       Default Value: disabled
202   -----------------------------------------------------------------
203              Option: debug:[value]
204          Definition: Enables various levels of debugging information
205                      The bit definitions for the debugging mask can
206                      be found in drivers/scsi/aic7xxx/aic79xx.h under
207                      the "Debug" heading.
208     Possible Values: 0x0000 = no debugging, 0xffff = full debugging
209       Default Value: 0x0000
210   -----------------------------------------------------------------
211              Option: no_reset
212          Definition: Do not reset the bus during the initial probe
213                      phase
214     Possible Values: This option is a flag
215       Default Value: disabled
216   -----------------------------------------------------------------
217              Option: extended
218          Definition: Force extended translation on the controller
219     Possible Values: This option is a flag
220       Default Value: disabled
221   -----------------------------------------------------------------
222              Option: periodic_otag
223          Definition: Send an ordered tag periodically to prevent
224                      tag starvation.  Needed for some older devices
225     Possible Values: This option is a flag
226       Default Value: disabled
227   -----------------------------------------------------------------
228              Option: reverse_scan
229          Definition: Probe the scsi bus in reverse order, starting
230                      with target 15
231     Possible Values: This option is a flag
232       Default Value: disabled
233   -----------------------------------------------------------------
234              Option: global_tag_depth
235          Definition: Global tag depth for all targets on all busses.
236                      This option sets the default tag depth which
237                      may be selectively overridden vi the tag_info
238                      option.
239     Possible Values: 1 - 253
240       Default Value: 32
241   -----------------------------------------------------------------
242              Option: tag_info:{{value[,value...]}[,{value[,value...]}...]}
243          Definition: Set the per-target tagged queue depth on a
244                      per controller basis.  Both controllers and targets
245                      may be ommitted indicating that they should retain
246                      the default tag depth.
247            Examples: tag_info:{{16,32,32,64,8,8,,32,32,32,32,32,32,32,32,32}
248                        On Controller 0
249                          specifies a tag depth of 16 for target 0
250                          specifies a tag depth of 64 for target 3
251                          specifies a tag depth of 8 for targets 4 and 5
252                          leaves target 6 at the default
253                          specifies a tag depth of 32 for targets 1,2,7-15
254                        All other targets retain the default depth.
255
256                      tag_info:{{},{32,,32}}
257                        On Controller 1
258                          specifies a tag depth of 32 for targets 0 and 2
259                        All other targets retain the default depth.
260
261     Possible Values: 1 - 253
262       Default Value: 32
263   -----------------------------------------------------------------
264              Option: rd_strm: {rd_strm_bitmask[,rd_strm_bitmask...]}
265          Definition: Enable read streaming on a per target basis.
266                      The rd_strm_bitmask is a 16 bit hex value in which
267                      each bit represents a target.  Setting the target's
268                      bit to '1' enables read streaming for that
269                      target.  Controllers may be ommitted indicating that
270                      they should retain the default read streaming setting.
271             Example: rd_strm:{0x0041}
272                        On Controller 0
273                          enables read streaming for targets 0 and 6.
274                          disables read streaming for targets 1-5,7-15.
275                        All other targets retain the default read
276                        streaming setting.
277             Example: rd_strm:{0x0023,,0xFFFF}
278                        On Controller 0
279                          enables read streaming for targets 1,2, and 5.
280                          disables read streaming for targets 3,4,6-15.
281                        On Controller 2
282                          enables read streaming for all targets.
283                        All other targets retain the default read
284                        streaming setting.
285
286     Possible Values: 0x0000 - 0xffff
287       Default Value: 0x0000
288   -----------------------------------------------------------------
289              Option: dv: {value[,value...]}
290          Definition: Set Domain Validation Policy on a per-controller basis.
291                      Controllers may be ommitted indicating that
292                      they should retain the default read streaming setting.
293             Example: dv:{-1,0,,1,1,0}
294                        On Controller 0 leave DV at its default setting.
295                        On Controller 1 disable DV.
296                        Skip configuration on Controller 2.
297                        On Controllers 3 and 4 enable DV.
298                        On Controller 5 disable DV.
299
300     Possible Values: < 0 Use setting from serial EEPROM.
301                      0 Disable DV
302                      > 0 Enable DV
303       Default Value: DV Serial EEPROM configuration setting.
304   -----------------------------------------------------------------
305              Option: seltime:[value]
306          Definition: Specifies the selection timeout value
307     Possible Values: 0 = 256ms, 1 = 128ms, 2 = 64ms, 3 = 32ms
308       Default Value: 0
309   -----------------------------------------------------------------
310
311   *** The following three options should only be changed at ***
312   *** the direction of a technical support representative.  ***
313
314   -----------------------------------------------------------------
315              Option: precomp: {value[,value...]}
316          Definition: Set IO Cell precompensation value on a per-controller
317                      basis.
318                      Controllers may be ommitted indicating that
319                      they should retain the default precompensation setting.
320             Example: precomp:{0x1}
321                        On Controller 0 set precompensation to 1.
322             Example: precomp:{1,,7}
323                        On Controller 0 set precompensation to 1.
324                        On Controller 2 set precompensation to 8.
325
326     Possible Values: 0 - 7
327       Default Value: Varies based on chip revision
328   -----------------------------------------------------------------
329              Option: slewrate: {value[,value...]}
330          Definition: Set IO Cell slew rate on a per-controller basis.
331                      Controllers may be ommitted indicating that
332                      they should retain the default slew rate setting.
333             Example: slewrate:{0x1}
334                        On Controller 0 set slew rate to 1.
335             Example: slewrate :{1,,8}
336                        On Controller 0 set slew rate to 1.
337                        On Controller 2 set slew rate to 8.
338
339     Possible Values: 0 - 15
340       Default Value: Varies based on chip revision
341   -----------------------------------------------------------------
342              Option: amplitude: {value[,value...]}
343          Definition: Set IO Cell signal amplitude on a per-controller basis.
344                      Controllers may be ommitted indicating that
345                      they should retain the default read streaming setting.
346             Example: amplitude:{0x1}
347                        On Controller 0 set amplitude to 1.
348             Example: amplitude :{1,,7}
349                        On Controller 0 set amplitude to 1.
350                        On Controller 2 set amplitude to 7.
351
352     Possible Values: 1 - 7
353       Default Value: Varies based on chip revision
354   -----------------------------------------------------------------
355
356   Example: 'options aic79xx aic79xx=verbose,rd_strm:{{0x0041}}'
357        enables verbose output in the driver and turns read streaming on
358        for targets 0 and 6 of Controller 0.
359
3604. Additional Notes
361
362   4.1. Known/Unresolved or FYI Issues
363
364        * Under SuSE Linux Enterprise 7, the driver may fail to operate
365          correctly due to a problem with PCI interrupt routing in the
366          Linux kernel.  Please contact SuSE for an updated Linux
367          kernel.
368
369   4.2. Third-Party Compatibility Issues
370
371        * Adaptec only supports Ultra320 hard drives running
372          the latest firmware available. Please check with
373          your hard drive manufacturer to ensure you have the
374          latest version.
375
376   4.3. Operating System or Technology Limitations
377
378        * PCI Hot Plug is untested and may cause the operating system
379          to stop responding.
380        * Luns that are not numbered contiguously starting with 0 might not
381          be automatically probed during system startup.  This is a limitation
382          of the OS.  Please contact your Linux vendor for instructions on
383          manually probing non-contiguous luns.
384        * Using the Driver Update Disk version of this package during OS
385          installation under RedHat might result in two versions of this
386          driver being installed into the system module directory.  This
387          might cause problems with the /sbin/mkinitrd program and/or
388          other RPM packages that try to install system modules.  The best
389          way to correct this once the system is running is to install
390          the latest RPM package version of this driver, available from
391          http://www.adaptec.com.
392
393
3945. Contacting Adaptec
395
396   A Technical Support Identification (TSID) Number is required for
397   Adaptec technical support.
398    - The 12-digit TSID can be found on the white barcode-type label
399      included inside the box with your product. The TSID helps us
400      provide more efficient service by accurately identifying your
401      product and support status.
402   Support Options
403    - Search the Adaptec Support Knowledgebase (ASK) at
404      http://ask.adaptec.com for articles, troubleshooting tips, and
405      frequently asked questions for your product.
406    - For support via Email, submit your question to Adaptec's
407      Technical Support Specialists at http://ask.adaptec.com.
408
409   North America
410    - Visit our Web site at http://www.adaptec.com.
411    - To speak with a Fibre Channel/RAID/External Storage Technical
412      Support Specialist, call 1-321-207-2000,
413      Hours: Monday-Friday, 3:00 A.M. to 5:00 P.M., PST.
414      (Not open on holidays)
415    - For Technical Support in all other technologies including
416      SCSI, call 1-408-934-7274,
417      Hours: Monday-Friday, 6:00 A.M. to 5:00 P.M., PST.
418      (Not open on holidays)
419    - For after hours support, call 1-800-416-8066 ($99/call,
420      $149/call on holidays)
421    - To order Adaptec products including software and cables, call
422      1-800-442-7274 or 1-408-957-7274. You can also visit our
423      online store at http://www.adaptecstore.com
424
425   Europe
426    - Visit our Web site at http://www.adaptec-europe.com.
427    - English and French: To speak with a Technical Support
428      Specialist, call one of the following numbers:
429        - English: +32-2-352-3470
430        - French:  +32-2-352-3460
431      Hours: Monday-Thursday, 10:00 to 12:30, 13:30 to 17:30 CET
432             Friday, 10:00 to 12:30, 13:30 to 16:30 CET
433    - German: To speak with a Technical Support Specialist,
434      call +49-89-456-40660
435      Hours: Monday-Thursday, 09:30 to 12:30, 13:30 to 16:30 CET
436             Friday, 09:30 to 12:30, 13:30 to 15:00 CET
437    - To order Adaptec products, including accessories and cables:
438        - UK: +0800-96-65-26 or fax +0800-731-02-95
439        - Other European countries: +32-11-300-379
440
441   Australia and New Zealand
442    - Visit our Web site at http://www.adaptec.com.au.
443    - To speak with a Technical Support Specialist, call
444      +612-9416-0698
445      Hours: Monday-Friday, 10:00 A.M. to 4:30 P.M., EAT
446      (Not open on holidays)
447
448   Japan
449    - To speak with a Technical Support Specialist, call
450      +81-3-5308-6120
451      Hours: Monday-Friday, 9:00 a.m. to 12:00 p.m., 1:00 p.m. to
452      6:00 p.m. TSC
453
454   Hong Kong and China
455    - To speak with a Technical Support Specialist, call
456      +852-2869-7200
457      Hours: Monday-Friday, 10:00 to 17:00.
458    - Fax Technical Support at +852-2869-7100.
459
460   Singapore
461    - To speak with a Technical Support Specialist, call
462      +65-245-7470
463      Hours: Monday-Friday, 10:00 to 17:00.
464    - Fax Technical Support at +852-2869-7100
465
466-------------------------------------------------------------------
467/*
468 * Copyright (c) 2003 Adaptec Inc. 691 S. Milpitas Blvd., Milpitas CA 95035 USA.
469 * All rights reserved.
470 *
471 * You are permitted to redistribute, use and modify this README file in whole
472 * or in part in conjunction with redistribution of software governed by the
473 * General Public License, provided that the following conditions are met:
474 * 1. Redistributions of README file must retain the above copyright
475 *    notice, this list of conditions, and the following disclaimer,
476 *    without modification.
477 * 2. The name of the author may not be used to endorse or promote products
478 *    derived from this software without specific prior written permission.
479 * 3. Modifications or new contributions must be attributed in a copyright
480 *    notice identifying the author ("Contributor") and added below the
481 *    original copyright notice. The copyright notice is for purposes of
482 *    identifying contributors and should not be deemed as permission to alter
483 *    the permissions given by Adaptec.
484 *
485 * THIS README FILE IS PROVIDED BY ADAPTEC AND CONTRIBUTORS ``AS IS'' AND
486 * ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, ANY
487 * WARRANTIES OF NON-INFRINGEMENT OR THE IMPLIED WARRANTIES OF MERCHANTABILITY
488 * AND FITNESS FOR A PARTICULAR PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL
489 * ADAPTEC OR CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL,
490 * SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT LIMITED
491 * TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, DATA, OR
492 * PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY THEORY OF
493 * LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT (INCLUDING
494 * NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE OF THIS README
495 * FILE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
496 */
497

README.aic7xxx

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