blob: 20e4014139911dc8b9d788981c10534ca3838db6 [file] [log] [blame]
Mauro Carvalho Chehab6d6486a2019-07-26 09:51:22 -03001=====================================
2Amiga Buddha and Catweasel IDE Driver
3=====================================
Linus Torvalds1da177e2005-04-16 15:20:36 -07004
5The Amiga Buddha and Catweasel IDE Driver (part of ide.c) was written by
6Geert Uytterhoeven based on the following specifications:
7
8------------------------------------------------------------------------
9
10Register map of the Buddha IDE controller and the
11Buddha-part of the Catweasel Zorro-II version
12
13The Autoconfiguration has been implemented just as Commodore
14described in their manuals, no tricks have been used (for
15example leaving some address lines out of the equations...).
16If you want to configure the board yourself (for example let
17a Linux kernel configure the card), look at the Commodore
Mauro Carvalho Chehab6d6486a2019-07-26 09:51:22 -030018Docs. Reading the nibbles should give this information::
Linus Torvalds1da177e2005-04-16 15:20:36 -070019
Mauro Carvalho Chehab6d6486a2019-07-26 09:51:22 -030020 Vendor number: 4626 ($1212)
21 product number: 0 (42 for Catweasel Z-II)
22 Serial number: 0
23 Rom-vector: $1000
Linus Torvalds1da177e2005-04-16 15:20:36 -070024
25The card should be a Z-II board, size 64K, not for freemem
26list, Rom-Vektor is valid, no second Autoconfig-board on the
27same card, no space preference, supports "Shutup_forever".
28
29Setting the base address should be done in two steps, just
30as the Amiga Kickstart does: The lower nibble of the 8-Bit
31address is written to $4a, then the whole Byte is written to
32$48, while it doesn't matter how often you're writing to $4a
33as long as $48 is not touched. After $48 has been written,
34the whole card disappears from $e8 and is mapped to the new
Alexey Dobriyan7f927fc2006-03-28 01:56:53 -080035address just written. Make sure $4a is written before $48,
Linus Torvalds1da177e2005-04-16 15:20:36 -070036otherwise your chance is only 1:16 to find the board :-).
37
38The local memory-map is even active when mapped to $e8:
39
Mauro Carvalho Chehab6d6486a2019-07-26 09:51:22 -030040============== ===========================================
Linus Torvalds1da177e2005-04-16 15:20:36 -070041$0-$7e Autokonfig-space, see Z-II docs.
42
43$80-$7fd reserved
44
45$7fe Speed-select Register: Read & Write
46 (description see further down)
47
48$800-$8ff IDE-Select 0 (Port 0, Register set 0)
49
50$900-$9ff IDE-Select 1 (Port 0, Register set 1)
51
52$a00-$aff IDE-Select 2 (Port 1, Register set 0)
53
54$b00-$bff IDE-Select 3 (Port 1, Register set 1)
55
56$c00-$cff IDE-Select 4 (Port 2, Register set 0,
Mauro Carvalho Chehab6d6486a2019-07-26 09:51:22 -030057 Catweasel only!)
Linus Torvalds1da177e2005-04-16 15:20:36 -070058
59$d00-$dff IDE-Select 5 (Port 3, Register set 1,
Mauro Carvalho Chehab6d6486a2019-07-26 09:51:22 -030060 Catweasel only!)
Linus Torvalds1da177e2005-04-16 15:20:36 -070061
Mauro Carvalho Chehab6d6486a2019-07-26 09:51:22 -030062$e00-$eff local expansion port, on Catweasel Z-II the
Linus Torvalds1da177e2005-04-16 15:20:36 -070063 Catweasel registers are also mapped here.
64 Never touch, use multidisk.device!
Mauro Carvalho Chehab6d6486a2019-07-26 09:51:22 -030065
66$f00 read only, Byte-access: Bit 7 shows the
67 level of the IRQ-line of IDE port 0.
Linus Torvalds1da177e2005-04-16 15:20:36 -070068
69$f01-$f3f mirror of $f00
70
Mauro Carvalho Chehab6d6486a2019-07-26 09:51:22 -030071$f40 read only, Byte-access: Bit 7 shows the
72 level of the IRQ-line of IDE port 1.
Linus Torvalds1da177e2005-04-16 15:20:36 -070073
74$f41-$f7f mirror of $f40
75
Mauro Carvalho Chehab6d6486a2019-07-26 09:51:22 -030076$f80 read only, Byte-access: Bit 7 shows the
77 level of the IRQ-line of IDE port 2.
Linus Torvalds1da177e2005-04-16 15:20:36 -070078 (Catweasel only!)
79
80$f81-$fbf mirror of $f80
81
82$fc0 write-only: Writing any value to this
Mauro Carvalho Chehab6d6486a2019-07-26 09:51:22 -030083 register enables IRQs to be passed from the
84 IDE ports to the Zorro bus. This mechanism
85 has been implemented to be compatible with
Linus Torvalds1da177e2005-04-16 15:20:36 -070086 harddisks that are either defective or have
Mauro Carvalho Chehab6d6486a2019-07-26 09:51:22 -030087 a buggy firmware and pull the IRQ line up
88 while starting up. If interrupts would
89 always be passed to the bus, the computer
90 might not start up. Once enabled, this flag
91 can not be disabled again. The level of the
92 flag can not be determined by software
Linus Torvalds1da177e2005-04-16 15:20:36 -070093 (what for? Write to me if it's necessary!).
94
95$fc1-$fff mirror of $fc0
96
97$1000-$ffff Buddha-Rom with offset $1000 in the rom
Mauro Carvalho Chehab6d6486a2019-07-26 09:51:22 -030098 chip. The addresses $0 to $fff of the rom
Linus Torvalds1da177e2005-04-16 15:20:36 -070099 chip cannot be read. Rom is Byte-wide and
100 mapped to even addresses.
Mauro Carvalho Chehab6d6486a2019-07-26 09:51:22 -0300101============== ===========================================
Linus Torvalds1da177e2005-04-16 15:20:36 -0700102
103The IDE ports issue an INT2. You can read the level of the
104IRQ-lines of the IDE-ports by reading from the three (two
105for Buddha-only) registers $f00, $f40 and $f80. This way
106more than one I/O request can be handled and you can easily
107determine what driver has to serve the INT2. Buddha and
108Catweasel expansion boards can issue an INT6. A separate
109memory map is available for the I/O module and the sysop's
110I/O module.
111
112The IDE ports are fed by the address lines A2 to A4, just as
113the Amiga 1200 and Amiga 4000 IDE ports are. This way
114existing drivers can be easily ported to Buddha. A move.l
115polls two words out of the same address of IDE port since
116every word is mirrored once. movem is not possible, but
117it's not necessary either, because you can only speedup
11868000 systems with this technique. A 68020 system with
119fastmem is faster with move.l.
120
121If you're using the mirrored registers of the IDE-ports with
122A6=1, the Buddha doesn't care about the speed that you have
123selected in the speed register (see further down). With
124A6=1 (for example $840 for port 0, register set 0), a 780ns
125access is being made. These registers should be used for a
126command access to the harddisk/CD-Rom, since command
127accesses are Byte-wide and have to be made slower according
128to the ATA-X3T9 manual.
129
130Now for the speed-register: The register is byte-wide, and
131only the upper three bits are used (Bits 7 to 5). Bit 4
132must always be set to 1 to be compatible with later Buddha
133versions (if I'll ever update this one). I presume that
134I'll never use the lower four bits, but they have to be set
135to 1 by definition.
Mauro Carvalho Chehab6d6486a2019-07-26 09:51:22 -0300136
137The values in this table have to be shifted 5 bits to the
Linus Torvalds1da177e2005-04-16 15:20:36 -0700138left and or'd with $1f (this sets the lower 5 bits).
139
140All the timings have in common: Select and IOR/IOW rise at
141the same time. IOR and IOW have a propagation delay of
142about 30ns to the clocks on the Zorro bus, that's why the
143values are no multiple of 71. One clock-cycle is 71ns long
144(exactly 70,5 at 14,18 Mhz on PAL systems).
145
146value 0 (Default after reset)
Mauro Carvalho Chehab6d6486a2019-07-26 09:51:22 -0300147 497ns Select (7 clock cycles) , IOR/IOW after 172ns (2 clock cycles)
148 (same timing as the Amiga 1200 does on it's IDE port without
149 accelerator card)
Linus Torvalds1da177e2005-04-16 15:20:36 -0700150
151value 1
Mauro Carvalho Chehab6d6486a2019-07-26 09:51:22 -0300152 639ns Select (9 clock cycles), IOR/IOW after 243ns (3 clock cycles)
Linus Torvalds1da177e2005-04-16 15:20:36 -0700153
154value 2
Mauro Carvalho Chehab6d6486a2019-07-26 09:51:22 -0300155 781ns Select (11 clock cycles), IOR/IOW after 314ns (4 clock cycles)
Linus Torvalds1da177e2005-04-16 15:20:36 -0700156
157value 3
Mauro Carvalho Chehab6d6486a2019-07-26 09:51:22 -0300158 355ns Select (5 clock cycles), IOR/IOW after 101ns (1 clock cycle)
Linus Torvalds1da177e2005-04-16 15:20:36 -0700159
160value 4
Mauro Carvalho Chehab6d6486a2019-07-26 09:51:22 -0300161 355ns Select (5 clock cycles), IOR/IOW after 172ns (2 clock cycles)
Linus Torvalds1da177e2005-04-16 15:20:36 -0700162
163value 5
Mauro Carvalho Chehab6d6486a2019-07-26 09:51:22 -0300164 355ns Select (5 clock cycles), IOR/IOW after 243ns (3 clock cycles)
Linus Torvalds1da177e2005-04-16 15:20:36 -0700165
166value 6
Mauro Carvalho Chehab6d6486a2019-07-26 09:51:22 -0300167 1065ns Select (15 clock cycles), IOR/IOW after 314ns (4 clock cycles)
Linus Torvalds1da177e2005-04-16 15:20:36 -0700168
169value 7
Mauro Carvalho Chehab6d6486a2019-07-26 09:51:22 -0300170 355ns Select, (5 clock cycles), IOR/IOW after 101ns (1 clock cycle)
Linus Torvalds1da177e2005-04-16 15:20:36 -0700171
172When accessing IDE registers with A6=1 (for example $84x),
173the timing will always be mode 0 8-bit compatible, no matter
174what you have selected in the speed register:
175
Mauro Carvalho Chehab6d6486a2019-07-26 09:51:22 -0300176781ns select, IOR/IOW after 4 clock cycles (=314ns) aktive.
Linus Torvalds1da177e2005-04-16 15:20:36 -0700177
178All the timings with a very short select-signal (the 355ns
179fast accesses) depend on the accelerator card used in the
180system: Sometimes two more clock cycles are inserted by the
181bus interface, making the whole access 497ns long. This
182doesn't affect the reliability of the controller nor the
183performance of the card, since this doesn't happen very
184often.
185
186All the timings are calculated and only confirmed by
187measurements that allowed me to count the clock cycles. If
188the system is clocked by an oscillator other than 28,37516
189Mhz (for example the NTSC-frequency 28,63636 Mhz), each
190clock cycle is shortened to a bit less than 70ns (not worth
191mentioning). You could think of a small performance boost
192by overclocking the system, but you would either need a
193multisync monitor, or a graphics card, and your internal
194diskdrive would go crazy, that's why you shouldn't tune your
195Amiga this way.
196
197Giving you the possibility to write software that is
198compatible with both the Buddha and the Catweasel Z-II, The
199Buddha acts just like a Catweasel Z-II with no device
200connected to the third IDE-port. The IRQ-register $f80
201always shows a "no IRQ here" on the Buddha, and accesses to
202the third IDE port are going into data's Nirwana on the
203Buddha.
204
Mauro Carvalho Chehab6d6486a2019-07-26 09:51:22 -0300205Jens Schönfeld february 19th, 1997
Linus Torvalds1da177e2005-04-16 15:20:36 -0700206
Mauro Carvalho Chehab6d6486a2019-07-26 09:51:22 -0300207updated may 27th, 1997
208
209eMail: sysop@nostlgic.tng.oche.de