blob: 7012b5c46d5df7cd669d2cad5fcecc1c2fc04e22 [file] [log] [blame]
Mauro Carvalho Chehab94b55302020-03-02 09:15:39 +01001.. SPDX-License-Identifier: GPL-2.0
2.. include:: <isonum.txt>
Linus Torvalds1da177e2005-04-16 15:20:36 -07003
Mauro Carvalho Chehab94b55302020-03-02 09:15:39 +01004=====================================================
5Adaptec AHA-1520/1522 SCSI driver for Linux (aha152x)
6=====================================================
7
8Copyright |copy| 1993-1999 Jürgen Fischer <fischer@norbit.de>
9
Linus Torvalds1da177e2005-04-16 15:20:36 -070010TC1550 patches by Luuk van Dijk (ldz@xs4all.nl)
11
12
13In Revision 2 the driver was modified a lot (especially the
14bottom-half handler complete()).
15
16The driver is much cleaner now, has support for the new
17error handling code in 2.3, produced less cpu load (much
18less polling loops), has slightly higher throughput (at
19least on my ancient test box; a i486/33Mhz/20MB).
20
21
Mauro Carvalho Chehab94b55302020-03-02 09:15:39 +010022Configuration Arguments
23=======================
Linus Torvalds1da177e2005-04-16 15:20:36 -070024
Mauro Carvalho Chehab94b55302020-03-02 09:15:39 +010025============ ======================================== ======================
Linus Torvalds1da177e2005-04-16 15:20:36 -070026IOPORT base io address (0x340/0x140)
27IRQ interrupt level (9-12; default 11)
28SCSI_ID scsi id of controller (0-7; default 7)
29RECONNECT allow targets to disconnect from the bus (0/1; default 1 [on])
30PARITY enable parity checking (0/1; default 1 [on])
31SYNCHRONOUS enable synchronous transfers (0/1; default 1 [on])
32DELAY: bus reset delay (default 100)
33EXT_TRANS: enable extended translation (0/1: default 0 [off])
34 (see NOTES)
Mauro Carvalho Chehab94b55302020-03-02 09:15:39 +010035============ ======================================== ======================
Linus Torvalds1da177e2005-04-16 15:20:36 -070036
Mauro Carvalho Chehab94b55302020-03-02 09:15:39 +010037Compile Time Configuration
38==========================
Linus Torvalds1da177e2005-04-16 15:20:36 -070039
Mauro Carvalho Chehab94b55302020-03-02 09:15:39 +010040(go into AHA152X in drivers/scsi/Makefile):
Linus Torvalds1da177e2005-04-16 15:20:36 -070041
Mauro Carvalho Chehab94b55302020-03-02 09:15:39 +010042- DAUTOCONF
43 use configuration the controller reports (AHA-152x only)
Linus Torvalds1da177e2005-04-16 15:20:36 -070044
Mauro Carvalho Chehab94b55302020-03-02 09:15:39 +010045- DSKIP_BIOSTEST
46 Don't test for BIOS signature (AHA-1510 or disabled BIOS)
Linus Torvalds1da177e2005-04-16 15:20:36 -070047
Mauro Carvalho Chehab94b55302020-03-02 09:15:39 +010048- DSETUP0="{ IOPORT, IRQ, SCSI_ID, RECONNECT, PARITY, SYNCHRONOUS, DELAY, EXT_TRANS }"
49 override for the first controller
Linus Torvalds1da177e2005-04-16 15:20:36 -070050
Mauro Carvalho Chehab94b55302020-03-02 09:15:39 +010051- DSETUP1="{ IOPORT, IRQ, SCSI_ID, RECONNECT, PARITY, SYNCHRONOUS, DELAY, EXT_TRANS }"
52 override for the second controller
Linus Torvalds1da177e2005-04-16 15:20:36 -070053
Mauro Carvalho Chehab94b55302020-03-02 09:15:39 +010054- DAHA152X_DEBUG
55 enable debugging output
56
57- DAHA152X_STAT
58 enable some statistics
Linus Torvalds1da177e2005-04-16 15:20:36 -070059
60
Mauro Carvalho Chehab94b55302020-03-02 09:15:39 +010061LILO Command Line Options
62=========================
Linus Torvalds1da177e2005-04-16 15:20:36 -070063
Mauro Carvalho Chehab94b55302020-03-02 09:15:39 +010064 ::
65
66 aha152x=<IOPORT>[,<IRQ>[,<SCSI-ID>[,<RECONNECT>[,<PARITY>[,<SYNCHRONOUS>[,<DELAY> [,<EXT_TRANS]]]]]]]
Linus Torvalds1da177e2005-04-16 15:20:36 -070067
68 The normal configuration can be overridden by specifying a command line.
69 When you do this, the BIOS test is skipped. Entered values have to be
70 valid (known). Don't use values that aren't supported under normal
71 operation. If you think that you need other values: contact me.
72 For two controllers use the aha152x statement twice.
73
74
Mauro Carvalho Chehab94b55302020-03-02 09:15:39 +010075Symbols for Module Configuration
76================================
Linus Torvalds1da177e2005-04-16 15:20:36 -070077
78Choose from 2 alternatives:
79
Mauro Carvalho Chehab94b55302020-03-02 09:15:39 +0100801. specify everything (old)::
Linus Torvalds1da177e2005-04-16 15:20:36 -070081
Mauro Carvalho Chehab94b55302020-03-02 09:15:39 +010082 aha152x=IOPORT,IRQ,SCSI_ID,RECONNECT,PARITY,SYNCHRONOUS,DELAY,EXT_TRANS
83
Linus Torvalds1da177e2005-04-16 15:20:36 -070084 configuration override for first controller
85
Mauro Carvalho Chehab94b55302020-03-02 09:15:39 +010086 ::
Linus Torvalds1da177e2005-04-16 15:20:36 -070087
Mauro Carvalho Chehab94b55302020-03-02 09:15:39 +010088 aha152x1=IOPORT,IRQ,SCSI_ID,RECONNECT,PARITY,SYNCHRONOUS,DELAY,EXT_TRANS
89
Linus Torvalds1da177e2005-04-16 15:20:36 -070090 configuration override for second controller
91
922. specify only what you need to (irq or io is required; new)
93
94io=IOPORT0[,IOPORT1]
95 IOPORT for first and second controller
96
97irq=IRQ0[,IRQ1]
98 IRQ for first and second controller
99
100scsiid=SCSIID0[,SCSIID1]
101 SCSIID for first and second controller
102
103reconnect=RECONNECT0[,RECONNECT1]
104 allow targets to disconnect for first and second controller
105
106parity=PAR0[PAR1]
107 use parity for first and second controller
108
109sync=SYNCHRONOUS0[,SYNCHRONOUS1]
110 enable synchronous transfers for first and second controller
111
112delay=DELAY0[,DELAY1]
113 reset DELAY for first and second controller
114
115exttrans=EXTTRANS0[,EXTTRANS1]
116 enable extended translation for first and second controller
117
118
119If you use both alternatives the first will be taken.
120
121
Mauro Carvalho Chehab94b55302020-03-02 09:15:39 +0100122Notes on EXT_TRANS
123==================
Linus Torvalds1da177e2005-04-16 15:20:36 -0700124
125SCSI uses block numbers to address blocks/sectors on a device.
126The BIOS uses a cylinder/head/sector addressing scheme (C/H/S)
127scheme instead. DOS expects a BIOS or driver that understands this
128C/H/S addressing.
129
130The number of cylinders/heads/sectors is called geometry and is required
131as base for requests in C/H/S addressing. SCSI only knows about the
132total capacity of disks in blocks (sectors).
133
134Therefore the SCSI BIOS/DOS driver has to calculate a logical/virtual
135geometry just to be able to support that addressing scheme. The geometry
136returned by the SCSI BIOS is a pure calculation and has nothing to
137do with the real/physical geometry of the disk (which is usually
138irrelevant anyway).
139
140Basically this has no impact at all on Linux, because it also uses block
141instead of C/H/S addressing. Unfortunately C/H/S addressing is also used
142in the partition table and therefore every operating system has to know
143the right geometry to be able to interpret it.
144
145Moreover there are certain limitations to the C/H/S addressing scheme,
Lucas De Marchi25985ed2011-03-30 22:57:33 -0300146namely the address space is limited to up to 255 heads, up to 63 sectors
Linus Torvalds1da177e2005-04-16 15:20:36 -0700147and a maximum of 1023 cylinders.
148
149The AHA-1522 BIOS calculates the geometry by fixing the number of heads
150to 64, the number of sectors to 32 and by calculating the number of
151cylinders by dividing the capacity reported by the disk by 64*32 (1 MB).
152This is considered to be the default translation.
153
154With respect to the limit of 1023 cylinders using C/H/S you can only
155address the first GB of your disk in the partition table. Therefore
156BIOSes of some newer controllers based on the AIC-6260/6360 support
157extended translation. This means that the BIOS uses 255 for heads,
15863 for sectors and then divides the capacity of the disk by 255*63
159(about 8 MB), as soon it sees a disk greater than 1 GB. That results
160in a maximum of about 8 GB addressable diskspace in the partition table
161(but there are already bigger disks out there today).
162
163To make it even more complicated the translation mode might/might
164not be configurable in certain BIOS setups.
165
166This driver does some more or less failsafe guessing to get the
167geometry right in most cases:
168
169- for disks<1GB: use default translation (C/32/64)
170
171- for disks>1GB:
Mauro Carvalho Chehab94b55302020-03-02 09:15:39 +0100172
Linus Torvalds1da177e2005-04-16 15:20:36 -0700173 - take current geometry from the partition table
Mauro Carvalho Chehab94b55302020-03-02 09:15:39 +0100174 (using scsicam_bios_param and accept only 'valid' geometries,
Linus Torvalds1da177e2005-04-16 15:20:36 -0700175 ie. either (C/32/64) or (C/63/255)). This can be extended translation
176 even if it's not enabled in the driver.
177
178 - if that fails, take extended translation if enabled by override,
179 kernel or module parameter, otherwise take default translation and
180 ask the user for verification. This might on not yet partitioned
181 disks.
182
183
Mauro Carvalho Chehab94b55302020-03-02 09:15:39 +0100184References Used
185===============
Linus Torvalds1da177e2005-04-16 15:20:36 -0700186
187 "AIC-6260 SCSI Chip Specification", Adaptec Corporation.
188
189 "SCSI COMPUTER SYSTEM INTERFACE - 2 (SCSI-2)", X3T9.2/86-109 rev. 10h
190
191 "Writing a SCSI device driver for Linux", Rik Faith (faith@cs.unc.edu)
192
193 "Kernel Hacker's Guide", Michael K. Johnson (johnsonm@sunsite.unc.edu)
194
195 "Adaptec 1520/1522 User's Guide", Adaptec Corporation.
196
197 Michael K. Johnson (johnsonm@sunsite.unc.edu)
198
199 Drew Eckhardt (drew@cs.colorado.edu)
200
Mauro Carvalho Chehab94b55302020-03-02 09:15:39 +0100201 Eric Youngdale (eric@andante.org)
Linus Torvalds1da177e2005-04-16 15:20:36 -0700202
203 special thanks to Eric Youngdale for the free(!) supplying the
204 documentation on the chip.