source: xtideuniversalbios/wiki/Manual_v2_0_0.wiki@ 341

Last change on this file since 341 was 331, checked in by aitotat@…, 13 years ago

Edited wiki page Manual_v2_0_0 through web user interface.

File size: 24.4 KB
Line 
1#summary Instructions for XTIDE Universal BIOS v2.0.0
2*Table of Contents*
3<wiki:toc max_depth="3" />
4----
5
6= Introduction =
7
8XTIDE Universal BIOS makes possible to use modern large ATA hard disks or Compact Flash cards on old PC's. You can then enjoy quiet or noiseless drives with more capacity than you'll ever need for old computers.
9
10XTIDE Universal BIOS can be used on any IBM PC, XT, AT and 100% compatible system. On AT systems you can use any 16-ISA or VLB IDE or Multi I/O controller. For XT systems you can use XTIDE rev1 (not available anymore), [http://www.vintage-computer.com/vcforum/showwiki.php?title=XTIDE+Rev2 XTIDE rev2] or [http://www.retrotronics.org/tiki/tiki-index.php JR-IDE/ISA].
11
12
13== Features ==
14
15Some of the features included in XTIDE Universal BIOS are...
16 * Supports up to 4 IDE controllers
17 * Support for virtual drives using serial port, [SerialDrives more information]
18 * Supports drives with any capacity (MS-DOS 7.x or FreeDOS is required to access more than 8.4 GB)
19 * PIO transfers with block mode support
20 * Hard disk autodetection
21 * Autodetected capacity, both CHS and LBA, can be overridden to make drive appear smaller than it is
22 * Boot menu for selecting any floppy drive or hard disk to boot from, including hard disks that are not handled by XTIDE Universal BIOS
23 * Compact Flash and Microdrive support
24 * Support for most 8-, 16-, and 32-bit IDE controllers
25...and many more.
26
27
28== Different builds ==
29
30At the moment there are different builds included in the XTIDE Universal BIOS zip file. 15 kiB builds (xxxL.BIN) include support for JR-IDE/ISA but are otherwise the same as 8 kiB builds.
31 * IDE_XT.BIN, IDE_JR8K.BIN and IDE_XTL.BIN (XT build)
32 XT build uses only instructions supported by 8086/8088 making it the only build that can be used on any PC, including the original IBM PC model 5150. IDE_JR8K.BIN has JR-IDE/ISA support but serial port features are removed to reduce the size to 8 kiB.
33 * IDE_XTP.BIN and IDE_XTPL.BIN (XT+ build)
34 XT+ build has the same features as the XT build but XT+ build uses instructions introduced in 80186/80188. Those instructions are supported by all later x86 CPUs, including NEC V20/V30. 8-bit transfers rates will be better thanks to INS and OUTS instructions.
35 * IDE_AT.BIN and IDE_ATL.BIN (AT build)
36 AT build is meant for all AT class machines (16-bit or 32-bit bus). AT build supports OS hooks to allow operating system to do some processing while drive seeks the requested data (if interrupts are enabled).
37
38All XT builds (including XT+) can be used on AT systems but XT builds have few differences to make them better suited for XT systems:
39 * XT builds prevent CGA snow on boot menu but this slows down drawing the menu.
40 * XT builds have much simpler method for detecting is INT 40h Floppy Drive handler installed.
41 * Jump targets are not aligned on XT builds.
42 * XT builds have different default settings (see below).
43
44XT builds are preconfigured for XTIDE rev1 at port 300h and IDE_JR8K.BIN is preconfigured for JR-IDE/ISA. AT builds are configured to search standard Primary and Secondary IDE drives, XTIDE rev1 at port 300h and 4th stardard IDE controller at port 168h (found on many sound cards). Interrupts are disabled by default on all builds.
45
46----
47= Installing XTIDE Universal BIOS =
48
49== Important if you are upgrading from XTIDE Universal BIOS v1.x.x. ==
50
51There is a bug related to generating L-CHS parameters for LBA drives. Generated parameters can be different than what should be based on Phoenix Enhanced Disk Drive Specification. That specification is what most BIOSes follow. If you want to swap drives between systems, both of them must use the same L-CHS parameters. XTIDE Universal BIOS v2 now uses the Phoenix specification (will be verified during beta testing) so the parameters can be different than those from XTIDE Universal BIOS v1.
52
53IMPORTANT! That means you need to create new partitions and format the drives after upgrading to XTIDE Universal BIOS v2.x.x.
54
55
56== Hardware supporting XTIDE Universal BIOS ROM ==
57
58The most convenient way to use XTIDE Universal BIOS is to use [http://www.vintage-computer.com/vcforum/showwiki.php?title=XTIDE+Rev2 XTIDE card]. It can be used on any PC with free 8-bit ISA slot. You might not want to connect any drives to it in 16- or 32-bit systems since 8-bit transfer will be very slow. Using XTIDE card allows EEPROM flashing so it is really easy to update XTIDE Universal BIOS.
59
60Another option is to use any card with free ROM socket for 8 kiB or larger ROMs. Official XTIDE builds are meant for 8 kiB and 16 kiB ROMs but you can burn it on larger ROM if you append enough zeroes to the end (only append zeroes so checksum does not change). Many network cards have unused ROM sockets but there are also few multi I/O cards and IDE controllers with ROM sockets. The network card remains fully usable even if you place XTIDE Universal BIOS ROM on it.
61
62You don't need EPROM/EEPROM programmer if you already have XTIDE card. XTIDE card can be used to flash additional EEPROMs (8 kiB 2864) that can be moved to EPROM (8 kiB 2764) sockets.
63
64
65== Configuring and flashing ==
66
67XTIDE Universal BIOS comes with DOS utility called XTIDECFG.COM. It configures XTIDE Universal BIOS and also works as a generic EEPROM flasher supporting EEPROM sizes up to 32 kiB. XTIDECFG.COM allows saving changes to BIOS images so that they can be programmed with other programming software or device.
68
69
70== Other things to know ==
71
72CTRL can be held down to skip XTIDE Universal BIOS initialization. Right time to press CTRL down is when POST OK beep is heard or just before all memory is tested.
73
74----
75= Using XTIDECFG.COM (XTIDE Universal BIOS configuration and flashing program) =
76
77XTIDECFG.COM is intended to be user friendly. At the bottom of the screen appears quick information for each menu item. Pressing F1 displays more detailed help for menu item (some menu items do not have detailed help available). Up, Down, PgUp, PgDn, Home and End keys are used for menu navigation. Enter selects menuitem and Esc resumes to previous menu.
78
79Some menu items appear only when needed to make configuring easier.
80
81
82== Menuitems on "Main Menu" ==
83 * Exit to DOS
84 Exits to DOS. If any changes are made, then dialog is displayed about saving the changes. You can also exit to DOS by pressing Esc at the main menu.
85 * Load BIOS from file
86 Loads any (not just XTIDE Universal BIOS) file to be flashed.
87 * Load BIOS from EEPROM
88 Loads XTIDE Universal BIOS from EEPROM to be reconfigured if supported version of XTIDE Universal BIOS is found in system.
89 * Load old settings from EEPROM
90 Loads current settings from EEPROM if supported version of XTIDE Universal BIOS is found in system.
91 * Configure XTIDE Universal BIOS
92 This menuitem appears only when supported version of XTIDE Universal BIOS is loaded to be configured.
93 * Flash EEPROM
94 This menuitem appears when file is loaded.
95
96== Menuitems on "Flash EEPROM" submenu ==
97 * Start flashing
98 * EEPROM type [default=2864]
99 Selects EEPROM type. XTIDE rev1 uses 2864 (8 kiB) EEPROM. Select 2864mod if you have done the A0-A3 address line swap mod to your XTIDE.
100 * SDP command [default=Enable]
101 Selects Software Data Protect command to be written before every page. You should set it to Enable if the EEPROM supports SDP.
102 * Page size [default=1]
103 Large page makes flashing faster. You'll probably want to select largest that your EEPROM supports. Slow XT systems might not be fast enough for large page sizes.
104 * EEPROM address [default=D000h]
105 Segment address where the EEPROM locates. Supported versions of XTIDE Universal BIOS will be detected automatically.
106 * Generate checksum byte [default=Yes]
107 You'll want to enable this if you have done any changes to XTIDE Universal BIOS settings. This option will generate checksum byte to the end of EEPROM.
108
109== Menuitems on "Configure XTIDE Universal BIOS" submenu ==
110 * Back to Main Menu
111 * Primary IDE Controller
112 * Secondary IDE Controller
113 * Tertiary IDE Controller
114 * Quaternary IDE Controller
115 Each "xxx IDE Controller" submenu displays IDE controller specific settings. "IDE controllers" menuitem specifies the visible "xxx IDE Controller" submenus.
116 * Boot settings
117 Opens submenu for boot related settings such as should boot menu be enabled etc.
118 * Full operating mode [default=No for XT builds, Yes for AT builds]
119 "Full operating mode" reserves a bit of Conventional memory for XTIDE Universal BIOS variables. Disabling this will reduce maximum number of IDE controllers to 2 and place the variables to memory area reserved for IBM ROM Basic (30:0h). You should always enable this unless:
120 # You don't need to use IBM ROM Basic or any BIOS or software that requires that memory area.
121 # You have any Tandy 1000 model with 640k or less RAM (see "kiB to steal from RAM" for a way around this problem).
122 # You really need the 1k of Conventional memory that "Full operating mode" requires.
123 * kiB to steal from RAM [default=1]
124 This menuitem will appear only when "Full operating mode" is enabled. Leave this to 1 unless you really need to enable "Full operating mode" on any Tandy 1000 model with 640k or less RAM. Setting this to 33 (almost always enough) or 65 (always enough) in such case will reserve the top of RAM to Tandy video circuitry thus disabling sharing of conventional memory with video circuitry.
125 * IDE controllers
126 Number of IDE controllers to be searched by XTIDE Universal BIOS. The maximum is 4 if Full operation mode" is enabled. Otherwise the maximum is 2.
127
128=== Menuitems on "Boot settings" submenu ===
129 * Display Mode [default=Default]
130 This setting allows you to force display mode change before boot menu is displayed. This setting will work even if boot menu is disabled and will leave the specified display mode set when booting to OS. Forcing display mode can be handy if you have composite monitor (use 40 column modes for better readability) or black&white VGA monitor (use 80 column black&white mode for better readability).
131 * Number of Floppy Drives [default=Auto]
132 In some systems number of floppy drives cannot be properly auto detected. This settings allows you to specify it manually so all drives can be displayed on boot menu.
133 * Scan for Serial Devices [default=No]
134 When enabled, the BIOS will scan COM1-7 for a Serial Drive server at the end of standard drive detection. Even without this option enabled, holding down the ALT key at the end of drive detection will do the same thing (useful for bootstrapping scenarios). The BIOS will display "Serial Master on COM Detect:" while it is scanning. See the [SerialDrives Serial Drive] documentation for more information.
135 * Boot Menu [default=Yes]
136 You can disable boot menu if you don't like it for some reason. Normal Drive A, then C, then INT 18h (ROM Basic, ROM DOS or boot error) boot order is used when boot menu is disabled.
137 * Default boot drive [default=80h]
138 Specifies what drive is highlighted on boot menu by default. Default of 80h means first hard drive in the system.
139 * Selection timeout [default=540]
140 Specifies the duration before auto selecting default boot drive from boot menu. 1 tick = 54.9 ms so default duration of 540 is about 30 seconds.
141 * Swap boot drive numbers [default=yes]
142 MS-DOS and old operating systems can only boot from first floppy or hard disk drive. Swapping boot drive numbers allows booting from all drives in the system.
143
144
145=== Menuitems on "xxx IDE Controller" submenus ===
146 * Back to Configuration Menu
147 Moves back to "Configure XTIDE Universal BIOS" submenu.
148 * Master Drive
149 * Slave Drive
150 Opens submenu for Master/Slave Drive specific settings for this IDE Controller.
151 * Device Type [default=XTIDE for XT builds, 16-bit for AT builds]
152 Type of device. 16-bit will support all standard IDE controllers, including VLB controllers. 32-bit will use 32-bit transfers on VLB controllers but those controllers usually require native support for full speed. Other devices include XTIDE rev1 (and rev2 slow mode), XTIDE mod with swapped A0 and A3 address lines (XTIDE rev2 fast mode), JR-IDE/ISA (IDE_JR8K.BIN and 15 kiB builds only) and [SerialDrives support for virtual devices through serial port]. Note that a serial port controller must be the last configured IDE controller. Xtidecfg will move any serial ports to the end of the list if this is not already done. This is done so that serial floppy disks, if any are present, will be last on the list of drives detected.
153 * Base (cmd block) address [default=300h for XT builds, 1F0h for AT builds (Primary IDE)]
154 Command block (base port) address where the IDE Controller is located. JR-IDE/ISA does not use this setting.
155 * Control block address [default=308h for XT builds, 3F0h for AT builds (Primary IDE)]
156 Set to base port + 8h for XTIDE rev1 and rev2. Set to base port + 200h for standard IDE controllers. JR-IDE/ISA does not use this setting.
157 * Enable interrupt [default=no]
158 Enables interrupt but it does not offer any benefit for MS-DOS. Do not enable unless you know you need it.
159 * IRQ [default=14 for Primary IDE, 15 for Secondary IDE]
160 IRQ channel to use for IDE controllers.
161 * COM Port [default=COM1]
162 * Baud Rate [default=9600]
163
164=== Menuitems for "Master/Slave Drive" submenus ===
165 * Back to IDE Controller Menu
166 * Block Mode Transfers [default=Yes]
167 Block Mode Transfers will speed up the transfer rates. This should be leaved enabled but there is at least one old hard drive with buggy block mode support when interrupts are enabled (Quantum, maybe 100MB).
168 * Internal Write Cache [default=Disabled]
169 Leave to disabled unless you know what you are doing! Improper use of write cache can cause data corruption.
170 * User specified CHS [default=no]
171 Specify CHS parameters manually. This will force the drive to CHS addressing and EBIOS functions will be disabled.
172 * User specified LBA [default=no]
173 Specify drive capacity manually (starting from 8.4 GB). All versions of MS-DOS 7.x (Windows 9x) seem to have compatibility problems with very large drives so you might need to reduce drive capacity. Use FreeDOS if you want to use full capacity of the drive.
174 * Cylinders, Heads and Sectors per track
175 These will appear when "User specified CHS" is enabled. Maximum values of 16383 Cylinders, 16 Heads and 63 Sectors per track will provide capacity of 7.8 GiB/8.4 GB that is the maximum that MS-DOS 3.31 to 6.22 supports. Note that this will force CHS addressing so once formatted, there will be data corruption if you try to access the drive with system using LBA addressing.
176 * Millions of sectors
177 This will appear when "User specified LBA" is enabled. You can specify the drive capacity in millions of sectors. Note that MS-DOS 7.x (Windows 9x) or FreeDOS is required to access more than 7.8 GiB/8.4 GB.
178
179----
180= Boot menu =
181
182Using boot menu is optional. Boot menu allows to boot from any floppy or hard disk drive. Drive can be selected with Up and Down arrows. Home, End, PgUp and PgDn keys can speed up selection if there are many drives in the boot menu. Press Enter to boot from selected drive.
183
184
185== Drive swapping ==
186
187DOS requires that it is loaded from first floppy drive (00h) or first hard disk (80h) in the system. XTIDE Universal BIOS can translate drive numbers to make booting possible from any floppy drive or hard disk. Drive number translation is implemented with simple swapping method: selected drive will be swapped with first drive and vice versa. For example drive 82h on boot menu would be translated to 80h and 80h would be translated to 82h. Drive swapping for floppy drives and hard disks are handled separately so it is possible to install DOS from any floppy drive to any hard disk. Drive number translation can be disabled with XTIDECFG.COM (see "Swap boot drive numbers" on Menuitems on "Boot settings" submenu).
188
189
190== Boot menu hotkeys ==
191
192Keys A to Z work as a hotkeys for boot menu drives. Hotkeys have another benefit: they allow to install DOS from any floppy drive to any hard disk. Select hard disk from menu but do not press Enter. Press any floppy drive hotkey instead to boot from floppy while maintaining selected hard disk translation.
193
194F8 calls software interrupt 18h. This starts IBM ROM Basic, ROM DOS or most usually error message from motherboard BIOS when there is no ROM to boot from.
195
196
197== Boot menu drive information ==
198
199Boot menu can display a little bit information about the drive.
200
201 * Capacity
202 This shows the drive capacity. This is the same as reported by the drive unless you have specified CHS or LBA manually. Capacity is read from INT 13h AH=08h for drives not handled by XTIDE Universal BIOS.
203 * Addr.
204 This shows the current addressing mode:
205 * L-CHS is used for drives with 1024 or less cylinders (504 MiB / 528 MB and smaller drives). L-CHS is the fastest mode since no address translations are required.
206 * P-CHS addressing is used for drives without LBA support and 1025 or more cylinders. It is unlikely such drives exists so P-CHS addressing is used if you manually specify CHS parameters with 1025 or more heads. P-CHS addressing is only a bit slower than L-CHS addressing.
207 * LBA28 is used when drive supports LBA and has capacity at most 128 GiB / 137 GB.
208 * LBA48 is used for drives larger than 128 GiB / 137 GB.
209 LBA modes are the slowest but the difference cannot be noticed on any AT system. There is no performance differences between LBA28 and LBA48. EBIOS functions (support for drives larger than 7.8 GiB / 8.4 GB) is available only when LBA addressing is used.
210 * Block
211 Shows the size of block in sectors. The larger the better. 1 means that block mode is disabled or not supported. CF cards usually support block mode commands but do not allow blocks larger than 1 sector.
212 * Bus
213 Shows the bus/device type configured in "Device Type" menuitem on "xxx IDE Controller" submenu.
214 * IRQ
215 Shows the IRQ channel if enabled.
216 * Reset
217 Shows the status from drive initialization. This should always be zero. If it is something else, then something has gone wrong.
218
219----
220= Performance problems =
221
222== MS-DOS DIR command takes very long time ==
223This is completely normal on systems with slow CPUs and large partitions. Calculating free space first time is simply very slow process in such case.
224
225It was very rare to have partitions larger than 32 MiB on XT systems so there weren't long delays then. Now XTIDE and JR-IDE/ISA makes possible to use very large modern drives on such slow systems. MS-DOS 3.31 allows partitions up to 512 MiB and MS-DOS 4.00 to 6.22 allows partitions up to 2 GiB. Those are enormous for XT systems and the slow 8088 or even the V20 take some time to calculate free space with FAT file system.
226
227It might be a good idea to use small partition for OS and frequently used utilities and large partition(s) for games and less needed data. You should experiment what feels the best size for the small partition. Please do let me know the results if you do some testing.
228
229It is very likely that this same problem will occur if you decide to use MS-DOS 7.x (Windows 9x) of FreeDOS and a large FAT-32 partition on a slow 386 or even 486.
230
231== XTIDE Universal BIOS v2.x.x has worse transfer rates than v1.1.5! ==
232There are three reasons for this:
233 * Virtual device support, XTIDE A0-A3 address line swap mod and memory mapping support for JR-IDE/ISA require some generalizations in code that results in more comparisons, jumps and function calls than before. These slow down the execution especially on slow CPUs.
234 * v2 has some improvements in error handling that also makes the CPU to do more work.
235 * v2 disable Drive Internal Cache by default. MS-DOS does not access hard drives directly and there are no BIOS function to flush cache so data corruption is likely when using modern drives with large internal caches unless the write cache is disabled. Disabling the write cache has much less hit on performance that you might think so it it not good idea to enable the write cache.
236
237If you are happy with v1.1.5 then go ahead and use it. I think most people will find that v2 is worth the upgrade even though the transfer rates are a bit slower.
238
239Here are some transfer rate comparisons between v1.1.5 and v2.0.0β1. Results are from [http://www.brutman.com/iotest.zip IOTEST by Michael B. Brutman].
240
241Test system is 486DX4 100 MHz with VLB Multi I/O card and 6 GB Hitachi Microdrive. XTIDE Universal BIOSes are configured for 16-transfers.
242||Internal Cache||Shadow RAM||v1.1.5||v2.0.0β1||
243||Enabled||Disabled||1399.22 KB/s||1185.50 KB/s||
244||Enabled||Enabled||1931.79 KB/s||1911.37 KB/s||
245||Disabled||Disabled||1358.26 KB/s||1145.48 KB/s||
246||Disabled||Enabled||1873.80 KB/s||1851.30 KB/s||
247
248
249== Importance of Shadow RAM ==
250Always enable Shadow RAM and ROM area caching if your systems supports them! They might speed up much more than you think. This is especially true on Pentium systems.
251
252Pentium will fetch at least 8 bytes (since it has 64-bit wide bus) before it can start to execute the instructions. Even if you have placed the ROM on a 16-bit ISA or 32-bit VLB or PCI card the ROM itself is only 8-bits wide. So the ROM must be read 8 times before CPU can start executing instructions. And if those 8 times are read from 8 MHz ISA with wait states... Believe it or not, this can slow the transfer rates on a mighty Pentium to the level of fast XT system.
253
254So always enable Shadow RAM to copy the ROM to RAM to get full bus width and you might also want to enable cache for ROM areas to compensate for RAM latencies and slower clock rate. The Shadow RAM is the more important of the two.
255
256You should be aware that you most likely need to disable Shadow RAM when you flash the EEPROM. Another thing to note is that JR-IDE/ISA does not work if Shadow RAM or ROM area caching is enabled. You wouldn't want to connect drives to 8-bit bus on a 32-bit system anyway. You can use the JR-IDE/ISA if you just need the 512 kiB FLASH.
257
258== Configuring hints ==
259CHS addressing modes are a bit faster than LBA addressing modes so you might want to manually specify CHS parameters for XT systems.
260
261----
262= IDE controllers on VLB and PCI bus =
263
26416-bit ISA IDE controllers are basically very simple ISA to PATA adapters so they all perform alike. ISA is not fast enough for anything above PIO-0 transfer method (with theoretical maximum of 3.3 MB/s).
265
266VLB and PCI IDE controllers are more complex since they have an actual controller between bus and IDE drive. This controller can buffer the data so CPU can read 32-bits at a time. Early VLB controller are limited to PIO-2 but later VLB controllers and (all?) PCI controllers also support PIO modes 3 and 4. These later VLB multi I/O cards have two IDE connectors so you should use one of those even if you don't need the other IDE connector.
267
268Unfortunately many of the controllers work only at PIO-0 by default. Some VLB multi I/O cards have jumpers to set transfer rates but most require controller specific programming to enable higher PIO modes. It is possible that your VLB multi I/O card don't offer any advantages over ISA multi I/O cards if your BIOS does not support the IDE controller on the VLB card. There are DOS drivers for many VLB IDE controllers so BIOS support isn't necessity.
269
270XTIDE Universal BIOS does not support any specific VLB controllers at the moment. I'm planning to add native support for Vision QD6580 controller soon (for real this time).
271
272----
273= Known problems =
274
275== Known bugs in XTIDE Universal BIOS v2.0.0 beta 1==
276 * User Defined LBA seems to have problems in FreeDOS (format does not work).
277
278
279== Problems with Compact Flash cards and microdrives ==
280
281CF cards and microdrives are IDE devices and should work as any hard disk. Unfortunately there are many CF cards and microdrives with limitations. Some of them only work as a master drive and not as a slave drive. Some of them requires MBR to be re-created before they can be booted.
282
283MBR can be re-created with FDISK /MBR switch. You can also use any low-level data wipe utility to clear non-bootable MBR. MBR will then be created automatically when partitioning the drive.
284
285----
286= Contact information =
287
288[http://www.vintage-computer.com/vcforum/showthread.php?17986-XTIDE-Universal-BIOS XTIDE Universal BIOS thread can be found at Vintage Computer Forums]. I recommend to post there but you can also send email to aitotat (at) gmail.com.
289
290When reporting bugs or other problems, please post the following information:
291 * Computer specs (at least CPU and RAM but details about expansion cards and how they are configured might be useful)
292 * Operating system and version (for example MS-DOS 6.22)
293 * Hard disk(s) you are using with XTIDE Universal BIOS
294 * Hard disk(s) not handled by XTIDE Universal BIOS (if any)
295 * Reset status that boot menu shows if problem is related to specific drive
Note: See TracBrowser for help on using the repository browser.