diff options
author | Ingo Molnar <mingo@elte.hu> | 2008-11-18 10:48:49 -0500 |
---|---|---|
committer | Ingo Molnar <mingo@elte.hu> | 2008-11-18 10:48:49 -0500 |
commit | 73f56c0d35e6427081a4eabd620d8b8d8a35bd09 (patch) | |
tree | 9fe1a2577baea03f3a6ec4a5e79f3ff26c4ee0ae /Documentation/blockdev/paride.txt | |
parent | 0af40a4b1050c050e62eb1dc30b82d5ab22bf221 (diff) | |
parent | 8501c45cc32c311ae755a2d5ac8c4a5f04908d42 (diff) |
Merge branch 'iommu-fixes-2.6.28' of git://git.kernel.org/pub/scm/linux/kernel/git/joro/linux-2.6-iommu into x86/urgent
Diffstat (limited to 'Documentation/blockdev/paride.txt')
-rw-r--r-- | Documentation/blockdev/paride.txt | 417 |
1 files changed, 417 insertions, 0 deletions
diff --git a/Documentation/blockdev/paride.txt b/Documentation/blockdev/paride.txt new file mode 100644 index 000000000000..e4312676bdda --- /dev/null +++ b/Documentation/blockdev/paride.txt | |||
@@ -0,0 +1,417 @@ | |||
1 | |||
2 | Linux and parallel port IDE devices | ||
3 | |||
4 | PARIDE v1.03 (c) 1997-8 Grant Guenther <grant@torque.net> | ||
5 | |||
6 | 1. Introduction | ||
7 | |||
8 | Owing to the simplicity and near universality of the parallel port interface | ||
9 | to personal computers, many external devices such as portable hard-disk, | ||
10 | CD-ROM, LS-120 and tape drives use the parallel port to connect to their | ||
11 | host computer. While some devices (notably scanners) use ad-hoc methods | ||
12 | to pass commands and data through the parallel port interface, most | ||
13 | external devices are actually identical to an internal model, but with | ||
14 | a parallel-port adapter chip added in. Some of the original parallel port | ||
15 | adapters were little more than mechanisms for multiplexing a SCSI bus. | ||
16 | (The Iomega PPA-3 adapter used in the ZIP drives is an example of this | ||
17 | approach). Most current designs, however, take a different approach. | ||
18 | The adapter chip reproduces a small ISA or IDE bus in the external device | ||
19 | and the communication protocol provides operations for reading and writing | ||
20 | device registers, as well as data block transfer functions. Sometimes, | ||
21 | the device being addressed via the parallel cable is a standard SCSI | ||
22 | controller like an NCR 5380. The "ditto" family of external tape | ||
23 | drives use the ISA replicator to interface a floppy disk controller, | ||
24 | which is then connected to a floppy-tape mechanism. The vast majority | ||
25 | of external parallel port devices, however, are now based on standard | ||
26 | IDE type devices, which require no intermediate controller. If one | ||
27 | were to open up a parallel port CD-ROM drive, for instance, one would | ||
28 | find a standard ATAPI CD-ROM drive, a power supply, and a single adapter | ||
29 | that interconnected a standard PC parallel port cable and a standard | ||
30 | IDE cable. It is usually possible to exchange the CD-ROM device with | ||
31 | any other device using the IDE interface. | ||
32 | |||
33 | The document describes the support in Linux for parallel port IDE | ||
34 | devices. It does not cover parallel port SCSI devices, "ditto" tape | ||
35 | drives or scanners. Many different devices are supported by the | ||
36 | parallel port IDE subsystem, including: | ||
37 | |||
38 | MicroSolutions backpack CD-ROM | ||
39 | MicroSolutions backpack PD/CD | ||
40 | MicroSolutions backpack hard-drives | ||
41 | MicroSolutions backpack 8000t tape drive | ||
42 | SyQuest EZ-135, EZ-230 & SparQ drives | ||
43 | Avatar Shark | ||
44 | Imation Superdisk LS-120 | ||
45 | Maxell Superdisk LS-120 | ||
46 | FreeCom Power CD | ||
47 | Hewlett-Packard 5GB and 8GB tape drives | ||
48 | Hewlett-Packard 7100 and 7200 CD-RW drives | ||
49 | |||
50 | as well as most of the clone and no-name products on the market. | ||
51 | |||
52 | To support such a wide range of devices, PARIDE, the parallel port IDE | ||
53 | subsystem, is actually structured in three parts. There is a base | ||
54 | paride module which provides a registry and some common methods for | ||
55 | accessing the parallel ports. The second component is a set of | ||
56 | high-level drivers for each of the different types of supported devices: | ||
57 | |||
58 | pd IDE disk | ||
59 | pcd ATAPI CD-ROM | ||
60 | pf ATAPI disk | ||
61 | pt ATAPI tape | ||
62 | pg ATAPI generic | ||
63 | |||
64 | (Currently, the pg driver is only used with CD-R drives). | ||
65 | |||
66 | The high-level drivers function according to the relevant standards. | ||
67 | The third component of PARIDE is a set of low-level protocol drivers | ||
68 | for each of the parallel port IDE adapter chips. Thanks to the interest | ||
69 | and encouragement of Linux users from many parts of the world, | ||
70 | support is available for almost all known adapter protocols: | ||
71 | |||
72 | aten ATEN EH-100 (HK) | ||
73 | bpck Microsolutions backpack (US) | ||
74 | comm DataStor (old-type) "commuter" adapter (TW) | ||
75 | dstr DataStor EP-2000 (TW) | ||
76 | epat Shuttle EPAT (UK) | ||
77 | epia Shuttle EPIA (UK) | ||
78 | fit2 FIT TD-2000 (US) | ||
79 | fit3 FIT TD-3000 (US) | ||
80 | friq Freecom IQ cable (DE) | ||
81 | frpw Freecom Power (DE) | ||
82 | kbic KingByte KBIC-951A and KBIC-971A (TW) | ||
83 | ktti KT Technology PHd adapter (SG) | ||
84 | on20 OnSpec 90c20 (US) | ||
85 | on26 OnSpec 90c26 (US) | ||
86 | |||
87 | |||
88 | 2. Using the PARIDE subsystem | ||
89 | |||
90 | While configuring the Linux kernel, you may choose either to build | ||
91 | the PARIDE drivers into your kernel, or to build them as modules. | ||
92 | |||
93 | In either case, you will need to select "Parallel port IDE device support" | ||
94 | as well as at least one of the high-level drivers and at least one | ||
95 | of the parallel port communication protocols. If you do not know | ||
96 | what kind of parallel port adapter is used in your drive, you could | ||
97 | begin by checking the file names and any text files on your DOS | ||
98 | installation floppy. Alternatively, you can look at the markings on | ||
99 | the adapter chip itself. That's usually sufficient to identify the | ||
100 | correct device. | ||
101 | |||
102 | You can actually select all the protocol modules, and allow the PARIDE | ||
103 | subsystem to try them all for you. | ||
104 | |||
105 | For the "brand-name" products listed above, here are the protocol | ||
106 | and high-level drivers that you would use: | ||
107 | |||
108 | Manufacturer Model Driver Protocol | ||
109 | |||
110 | MicroSolutions CD-ROM pcd bpck | ||
111 | MicroSolutions PD drive pf bpck | ||
112 | MicroSolutions hard-drive pd bpck | ||
113 | MicroSolutions 8000t tape pt bpck | ||
114 | SyQuest EZ, SparQ pd epat | ||
115 | Imation Superdisk pf epat | ||
116 | Maxell Superdisk pf friq | ||
117 | Avatar Shark pd epat | ||
118 | FreeCom CD-ROM pcd frpw | ||
119 | Hewlett-Packard 5GB Tape pt epat | ||
120 | Hewlett-Packard 7200e (CD) pcd epat | ||
121 | Hewlett-Packard 7200e (CD-R) pg epat | ||
122 | |||
123 | 2.1 Configuring built-in drivers | ||
124 | |||
125 | We recommend that you get to know how the drivers work and how to | ||
126 | configure them as loadable modules, before attempting to compile a | ||
127 | kernel with the drivers built-in. | ||
128 | |||
129 | If you built all of your PARIDE support directly into your kernel, | ||
130 | and you have just a single parallel port IDE device, your kernel should | ||
131 | locate it automatically for you. If you have more than one device, | ||
132 | you may need to give some command line options to your bootloader | ||
133 | (eg: LILO), how to do that is beyond the scope of this document. | ||
134 | |||
135 | The high-level drivers accept a number of command line parameters, all | ||
136 | of which are documented in the source files in linux/drivers/block/paride. | ||
137 | By default, each driver will automatically try all parallel ports it | ||
138 | can find, and all protocol types that have been installed, until it finds | ||
139 | a parallel port IDE adapter. Once it finds one, the probe stops. So, | ||
140 | if you have more than one device, you will need to tell the drivers | ||
141 | how to identify them. This requires specifying the port address, the | ||
142 | protocol identification number and, for some devices, the drive's | ||
143 | chain ID. While your system is booting, a number of messages are | ||
144 | displayed on the console. Like all such messages, they can be | ||
145 | reviewed with the 'dmesg' command. Among those messages will be | ||
146 | some lines like: | ||
147 | |||
148 | paride: bpck registered as protocol 0 | ||
149 | paride: epat registered as protocol 1 | ||
150 | |||
151 | The numbers will always be the same until you build a new kernel with | ||
152 | different protocol selections. You should note these numbers as you | ||
153 | will need them to identify the devices. | ||
154 | |||
155 | If you happen to be using a MicroSolutions backpack device, you will | ||
156 | also need to know the unit ID number for each drive. This is usually | ||
157 | the last two digits of the drive's serial number (but read MicroSolutions' | ||
158 | documentation about this). | ||
159 | |||
160 | As an example, let's assume that you have a MicroSolutions PD/CD drive | ||
161 | with unit ID number 36 connected to the parallel port at 0x378, a SyQuest | ||
162 | EZ-135 connected to the chained port on the PD/CD drive and also an | ||
163 | Imation Superdisk connected to port 0x278. You could give the following | ||
164 | options on your boot command: | ||
165 | |||
166 | pd.drive0=0x378,1 pf.drive0=0x278,1 pf.drive1=0x378,0,36 | ||
167 | |||
168 | In the last option, pf.drive1 configures device /dev/pf1, the 0x378 | ||
169 | is the parallel port base address, the 0 is the protocol registration | ||
170 | number and 36 is the chain ID. | ||
171 | |||
172 | Please note: while PARIDE will work both with and without the | ||
173 | PARPORT parallel port sharing system that is included by the | ||
174 | "Parallel port support" option, PARPORT must be included and enabled | ||
175 | if you want to use chains of devices on the same parallel port. | ||
176 | |||
177 | 2.2 Loading and configuring PARIDE as modules | ||
178 | |||
179 | It is much faster and simpler to get to understand the PARIDE drivers | ||
180 | if you use them as loadable kernel modules. | ||
181 | |||
182 | Note 1: using these drivers with the "kerneld" automatic module loading | ||
183 | system is not recommended for beginners, and is not documented here. | ||
184 | |||
185 | Note 2: if you build PARPORT support as a loadable module, PARIDE must | ||
186 | also be built as loadable modules, and PARPORT must be loaded before the | ||
187 | PARIDE modules. | ||
188 | |||
189 | To use PARIDE, you must begin by | ||
190 | |||
191 | insmod paride | ||
192 | |||
193 | this loads a base module which provides a registry for the protocols, | ||
194 | among other tasks. | ||
195 | |||
196 | Then, load as many of the protocol modules as you think you might need. | ||
197 | As you load each module, it will register the protocols that it supports, | ||
198 | and print a log message to your kernel log file and your console. For | ||
199 | example: | ||
200 | |||
201 | # insmod epat | ||
202 | paride: epat registered as protocol 0 | ||
203 | # insmod kbic | ||
204 | paride: k951 registered as protocol 1 | ||
205 | paride: k971 registered as protocol 2 | ||
206 | |||
207 | Finally, you can load high-level drivers for each kind of device that | ||
208 | you have connected. By default, each driver will autoprobe for a single | ||
209 | device, but you can support up to four similar devices by giving their | ||
210 | individual co-ordinates when you load the driver. | ||
211 | |||
212 | For example, if you had two no-name CD-ROM drives both using the | ||
213 | KingByte KBIC-951A adapter, one on port 0x378 and the other on 0x3bc | ||
214 | you could give the following command: | ||
215 | |||
216 | # insmod pcd drive0=0x378,1 drive1=0x3bc,1 | ||
217 | |||
218 | For most adapters, giving a port address and protocol number is sufficient, | ||
219 | but check the source files in linux/drivers/block/paride for more | ||
220 | information. (Hopefully someone will write some man pages one day !). | ||
221 | |||
222 | As another example, here's what happens when PARPORT is installed, and | ||
223 | a SyQuest EZ-135 is attached to port 0x378: | ||
224 | |||
225 | # insmod paride | ||
226 | paride: version 1.0 installed | ||
227 | # insmod epat | ||
228 | paride: epat registered as protocol 0 | ||
229 | # insmod pd | ||
230 | pd: pd version 1.0, major 45, cluster 64, nice 0 | ||
231 | pda: Sharing parport1 at 0x378 | ||
232 | pda: epat 1.0, Shuttle EPAT chip c3 at 0x378, mode 5 (EPP-32), delay 1 | ||
233 | pda: SyQuest EZ135A, 262144 blocks [128M], (512/16/32), removable media | ||
234 | pda: pda1 | ||
235 | |||
236 | Note that the last line is the output from the generic partition table | ||
237 | scanner - in this case it reports that it has found a disk with one partition. | ||
238 | |||
239 | 2.3 Using a PARIDE device | ||
240 | |||
241 | Once the drivers have been loaded, you can access PARIDE devices in the | ||
242 | same way as their traditional counterparts. You will probably need to | ||
243 | create the device "special files". Here is a simple script that you can | ||
244 | cut to a file and execute: | ||
245 | |||
246 | #!/bin/bash | ||
247 | # | ||
248 | # mkd -- a script to create the device special files for the PARIDE subsystem | ||
249 | # | ||
250 | function mkdev { | ||
251 | mknod $1 $2 $3 $4 ; chmod 0660 $1 ; chown root:disk $1 | ||
252 | } | ||
253 | # | ||
254 | function pd { | ||
255 | D=$( printf \\$( printf "x%03x" $[ $1 + 97 ] ) ) | ||
256 | mkdev pd$D b 45 $[ $1 * 16 ] | ||
257 | for P in 1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 | ||
258 | do mkdev pd$D$P b 45 $[ $1 * 16 + $P ] | ||
259 | done | ||
260 | } | ||
261 | # | ||
262 | cd /dev | ||
263 | # | ||
264 | for u in 0 1 2 3 ; do pd $u ; done | ||
265 | for u in 0 1 2 3 ; do mkdev pcd$u b 46 $u ; done | ||
266 | for u in 0 1 2 3 ; do mkdev pf$u b 47 $u ; done | ||
267 | for u in 0 1 2 3 ; do mkdev pt$u c 96 $u ; done | ||
268 | for u in 0 1 2 3 ; do mkdev npt$u c 96 $[ $u + 128 ] ; done | ||
269 | for u in 0 1 2 3 ; do mkdev pg$u c 97 $u ; done | ||
270 | # | ||
271 | # end of mkd | ||
272 | |||
273 | With the device files and drivers in place, you can access PARIDE devices | ||
274 | like any other Linux device. For example, to mount a CD-ROM in pcd0, use: | ||
275 | |||
276 | mount /dev/pcd0 /cdrom | ||
277 | |||
278 | If you have a fresh Avatar Shark cartridge, and the drive is pda, you | ||
279 | might do something like: | ||
280 | |||
281 | fdisk /dev/pda -- make a new partition table with | ||
282 | partition 1 of type 83 | ||
283 | |||
284 | mke2fs /dev/pda1 -- to build the file system | ||
285 | |||
286 | mkdir /shark -- make a place to mount the disk | ||
287 | |||
288 | mount /dev/pda1 /shark | ||
289 | |||
290 | Devices like the Imation superdisk work in the same way, except that | ||
291 | they do not have a partition table. For example to make a 120MB | ||
292 | floppy that you could share with a DOS system: | ||
293 | |||
294 | mkdosfs /dev/pf0 | ||
295 | mount /dev/pf0 /mnt | ||
296 | |||
297 | |||
298 | 2.4 The pf driver | ||
299 | |||
300 | The pf driver is intended for use with parallel port ATAPI disk | ||
301 | devices. The most common devices in this category are PD drives | ||
302 | and LS-120 drives. Traditionally, media for these devices are not | ||
303 | partitioned. Consequently, the pf driver does not support partitioned | ||
304 | media. This may be changed in a future version of the driver. | ||
305 | |||
306 | 2.5 Using the pt driver | ||
307 | |||
308 | The pt driver for parallel port ATAPI tape drives is a minimal driver. | ||
309 | It does not yet support many of the standard tape ioctl operations. | ||
310 | For best performance, a block size of 32KB should be used. You will | ||
311 | probably want to set the parallel port delay to 0, if you can. | ||
312 | |||
313 | 2.6 Using the pg driver | ||
314 | |||
315 | The pg driver can be used in conjunction with the cdrecord program | ||
316 | to create CD-ROMs. Please get cdrecord version 1.6.1 or later | ||
317 | from ftp://ftp.fokus.gmd.de/pub/unix/cdrecord/ . To record CD-R media | ||
318 | your parallel port should ideally be set to EPP mode, and the "port delay" | ||
319 | should be set to 0. With those settings it is possible to record at 2x | ||
320 | speed without any buffer underruns. If you cannot get the driver to work | ||
321 | in EPP mode, try to use "bidirectional" or "PS/2" mode and 1x speeds only. | ||
322 | |||
323 | |||
324 | 3. Troubleshooting | ||
325 | |||
326 | 3.1 Use EPP mode if you can | ||
327 | |||
328 | The most common problems that people report with the PARIDE drivers | ||
329 | concern the parallel port CMOS settings. At this time, none of the | ||
330 | PARIDE protocol modules support ECP mode, or any ECP combination modes. | ||
331 | If you are able to do so, please set your parallel port into EPP mode | ||
332 | using your CMOS setup procedure. | ||
333 | |||
334 | 3.2 Check the port delay | ||
335 | |||
336 | Some parallel ports cannot reliably transfer data at full speed. To | ||
337 | offset the errors, the PARIDE protocol modules introduce a "port | ||
338 | delay" between each access to the i/o ports. Each protocol sets | ||
339 | a default value for this delay. In most cases, the user can override | ||
340 | the default and set it to 0 - resulting in somewhat higher transfer | ||
341 | rates. In some rare cases (especially with older 486 systems) the | ||
342 | default delays are not long enough. if you experience corrupt data | ||
343 | transfers, or unexpected failures, you may wish to increase the | ||
344 | port delay. The delay can be programmed using the "driveN" parameters | ||
345 | to each of the high-level drivers. Please see the notes above, or | ||
346 | read the comments at the beginning of the driver source files in | ||
347 | linux/drivers/block/paride. | ||
348 | |||
349 | 3.3 Some drives need a printer reset | ||
350 | |||
351 | There appear to be a number of "noname" external drives on the market | ||
352 | that do not always power up correctly. We have noticed this with some | ||
353 | drives based on OnSpec and older Freecom adapters. In these rare cases, | ||
354 | the adapter can often be reinitialised by issuing a "printer reset" on | ||
355 | the parallel port. As the reset operation is potentially disruptive in | ||
356 | multiple device environments, the PARIDE drivers will not do it | ||
357 | automatically. You can however, force a printer reset by doing: | ||
358 | |||
359 | insmod lp reset=1 | ||
360 | rmmod lp | ||
361 | |||
362 | If you have one of these marginal cases, you should probably build | ||
363 | your paride drivers as modules, and arrange to do the printer reset | ||
364 | before loading the PARIDE drivers. | ||
365 | |||
366 | 3.4 Use the verbose option and dmesg if you need help | ||
367 | |||
368 | While a lot of testing has gone into these drivers to make them work | ||
369 | as smoothly as possible, problems will arise. If you do have problems, | ||
370 | please check all the obvious things first: does the drive work in | ||
371 | DOS with the manufacturer's drivers ? If that doesn't yield any useful | ||
372 | clues, then please make sure that only one drive is hooked to your system, | ||
373 | and that either (a) PARPORT is enabled or (b) no other device driver | ||
374 | is using your parallel port (check in /proc/ioports). Then, load the | ||
375 | appropriate drivers (you can load several protocol modules if you want) | ||
376 | as in: | ||
377 | |||
378 | # insmod paride | ||
379 | # insmod epat | ||
380 | # insmod bpck | ||
381 | # insmod kbic | ||
382 | ... | ||
383 | # insmod pd verbose=1 | ||
384 | |||
385 | (using the correct driver for the type of device you have, of course). | ||
386 | The verbose=1 parameter will cause the drivers to log a trace of their | ||
387 | activity as they attempt to locate your drive. | ||
388 | |||
389 | Use 'dmesg' to capture a log of all the PARIDE messages (any messages | ||
390 | beginning with paride:, a protocol module's name or a driver's name) and | ||
391 | include that with your bug report. You can submit a bug report in one | ||
392 | of two ways. Either send it directly to the author of the PARIDE suite, | ||
393 | by e-mail to grant@torque.net, or join the linux-parport mailing list | ||
394 | and post your report there. | ||
395 | |||
396 | 3.5 For more information or help | ||
397 | |||
398 | You can join the linux-parport mailing list by sending a mail message | ||
399 | to | ||
400 | linux-parport-request@torque.net | ||
401 | |||
402 | with the single word | ||
403 | |||
404 | subscribe | ||
405 | |||
406 | in the body of the mail message (not in the subject line). Please be | ||
407 | sure that your mail program is correctly set up when you do this, as | ||
408 | the list manager is a robot that will subscribe you using the reply | ||
409 | address in your mail headers. REMOVE any anti-spam gimmicks you may | ||
410 | have in your mail headers, when sending mail to the list server. | ||
411 | |||
412 | You might also find some useful information on the linux-parport | ||
413 | web pages (although they are not always up to date) at | ||
414 | |||
415 | http://www.torque.net/parport/ | ||
416 | |||
417 | |||