source: xtideuniversalbios/wiki/Manual.wiki @ 20

Last change on this file since 20 was 20, checked in by aitotat, 14 years ago

Edited wiki page through web user interface.

File size: 20.0 KB
Line 
1#summary Instructions for XTIDE Universal BIOS v1.1.0
2*Table of Contents*
3<wiki:toc max_depth="3" />
4----
5= Introduction =
6
7XTIDE Universal BIOS is mainly used with [http://wiki.vintage-computer.com/index.php/XTIDE_project XTIDE controller] to use modern IDE drives on PC/XT systems. XTIDE Universal BIOS supports 16- and 32-bit IDE controllers found in later ISA, VLB and PCI systems. Thus XTIDE Universal BIOS can be used to overcome 504 MiB hard disk size limit that many old BIOSes have.
8
9
10== Features ==
11
12Some of the features included in XTIDE Universal BIOS are...
13  * Supports up to 5 IDE controllers (10 drives)
14  * Accesses up to 8.4 GB hard disk space (BIOS CHS limit)
15  * Block mode transfers
16  * Hard disk autodetection
17  * Autodetected CHS parameteres can be overridden to make drive appear smaller than it is
18  * Boot menu for selecting any floppy drive or hard disk to boot from, including hard disks that are not handled by XTIDE Universal BIOS
19  * Compact Flash and Microdrive support
20  * Support for most 8-, 16-, and 32-bit IDE controllers
21  * IRQ and polling operation modes
22...and many more.
23
24
25== Different builds ==
26
27At the moment there are three different builds included in the XTIDE Universal BIOS zip file:
28  * IDE_XT.BIN (XT build)
29   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.
30  * IDE_XTP.BIN (XT+ build)
31   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.
32  * IDE_AT.BIN (AT build)
33   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. By default, the AT build is configured to full mode to take advantage of all the features the XTIDE Universal BIOS offers.
34
35----
36
37= Installing XTIDE Universal BIOS =
38
39== Hardware supporting XTIDE Universal BIOS ROM ==
40
41The most convenient way to use XTIDE Universal BIOS is to use [http://wiki.vintage-computer.com/index.php/XTIDE_project 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.
42
43Another option is to use any card with free ROM socket for 8 kiB or larger ROMs. Official XTIDE builds are meant for 8 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.
44
45You don't need EPROM/EEPROM programmer if you already have XTIDE card. XTIDE card can be used to flash additional EEPROMs (2864) that can be moved to EPROM (2764) sockets.
46
47
48== Configuring and flashing BIOS ==
49
50XTIDE Universal BIOS comes with DOS utility called idecfg.com. It configures XTIDE Universal BIOS and also works as a generic EEPROM flasher supporting EEPROM sizes up to 16 kiB. Idecfg.com allows saving changes to BIOS images so that they can be programmed with other programming software or device.
51
52
53== Other things to know ==
54
55CTRL can be held down to skip XTIDE Universal BIOS initialization. Only drive detection will be skipped when late initialization is used.
56
57----
58
59= Using IDECFG.COM (XTIDE Universal BIOS configuration and flashing program) =
60
61Idecfg.com is intended to be user friendly. At the bottom of the screen appears quick information for each menu item. It can be hidden with F2 to make menu navigation faster on XT systems. Pressing F1 displays more detailed help for menu item. Sometimes the help is the same as the quick information but not always. Up, Down, PgUp, PgDn, Home and End keys are used for menu navigation. Enter selects menuitem and Esc resumes to previous menu.
62
63Some menu items appear only when needed to make configuring easier.
64
65
66== Menuitems on main menu ==
67  * Exit to DOS
68   This menu item exits to DOS but allows user to save any unsaved changes.
69  * Load BIOS from file
70   Loads any file with .BIN extension to be flashed.
71  * Load BIOS from EEPROM
72   This menu item appears only when supported version of XTIDE Universal BIOS is detected. It loads the BIOS from EEPROM to be reconfigured.
73  * Load old settings from EEPROM
74   This menu item appears only when supported version of XTIDE Universal BIOS is detected and same or another supported version is loaded to be configured. It loads the old settings so that the new version does not need to be reconfigured when updating XTIDE Universal BIOS to new version.
75  * Configure XTIDE Universal BIOS
76   All XTIDE Universal BIOS settings can be found and configured from this sub menu.
77  * Flash EEPROM
78   Settings for EEPROM flashing.
79
80
81== Menuitems on Configure XTIDE Universal BIOS submenu ==
82  * Back to previous menu
83   Resumes back to main menu.
84  * Primary IDE Controller
85  * Secondary IDE Controller
86  * Tertiary IDE Controller
87  * Quaternary IDE Controller
88  * Quinary IDE Controller
89   IDE Controller menu items appear based on selected number of IDE controllers.
90  * Boot menu settings
91   Opens sub menu for configuring boot menu. This menu item appears only when Boot loader type is set to Menu.
92  * Late initialization
93   Normally expansion card BIOSes are initialized before POST completes. Some (older) systems initialize expansion card BIOSes before they have initialized themselves. This might cause problems since XTIDE Universal BIOS requires some main BIOS functions for drive detection. This problem can be fixed by using late initialization to detect drives on boot loader. Late initialization requires that XTIDE Universal BIOS is the last BIOS that installs INT 19h handler. Make sure that XTIDE ROM is configured to highest address if you have other storage device controllers present.
94  * Maximize disk size
95   Old BIOSes reserve diagnostic cylinder (landing zone cylinder for MFM drives) that is not used. Later BIOSes do not reserve it to allow more data to be stored. Do not maximize disk size if you need to move the drive between XTIDE Universal BIOS controlled systems and systems with cylinder reserving BIOSes.
96  * Full operating mode
97   Full mode supports up to 5 IDE controllers (10 drives). Full mode reserves a bit of RAM from top of base memory. This makes possible to use ROM Basic and software that requires top of interrupt vectors where XTIDE Universal BIOS parameters would be stored in lite mode. Lite mode supports only one IDE controller (2 drives) and stores parameters to top of interrupt vectors (30:0h) so no base RAM needs to be reserved. Lite mode cannot be used if some software requires top of interrupt vectors. Usually this is not a problem since only IBM ROM Basic uses them. Tandy 1000 models with 640 kiB or less memory need to use lite mode since top of base RAM gets dynamically reserved by video hardware. This happens only with Tandy integrated video controller, not with expansion graphics cards. It is possible to use full mode if reserving RAM for video memory + what is required for XTIDE Universal BIOS. This would mean 129 kiB but most software should work with 65 kiB reserved.
98  * kiB to steal from RAM
99   Parameters for detected hard disks must be stored somewhere. In full mode they are stored to top of base RAM. At the moment 1 kiB is always enough but you might want to steal more if you want to use full mode with Tandy 1000. This menu item appears only when full operating mode is enabled.
100  * Number of IDE controllers
101   Number of IDE controllers handled by XTIDE Universal BIOS. This menu item appears only when full operating mode is enabled.
102
103
104== Menuitems on IDE Controller submenus ==
105  * Back to previous menu
106   Resumes back to Configure XTIDE Universal BIOS submenu.
107  * Master drive
108  * Slave drive
109   Drive specific settings for master and slave drives.
110  * Bus type
111    * 8-bit dual port (XTIDE)
112     8-bit ISA controllers with two data ports. This is what the XTIDE card uses.
113    * 8-bit single port
114     8-bit ISA controllers with one data port.
115    * 16-bit
116     ISA (16-bit) but it also works on VLB and PCI controllers.
117    * 32-bit generic
118     Generic 32-bit I/O for VLB and PCI controllers.
119  * Base (cmd block) address
120   IDE controller command block address is the usual address mentioned for IDE controllers. By default the primary IDE controller uses port 1F0h and secondary controller uses port 170h. XTIDE card uses port 300h by default.
121  * Control block address
122   IDE controller control block address is normally command block address + 200h. For XTIDE card the control block registers are mapped right after command block registers so use command block address + 8h for XTIDE card.
123  * Enable interrupt
124   IDE controller can use interrupts to signal when it is ready to transfer data. This makes possible to do other tasks while waiting drive to be ready. That is not useful in MS-DOS but using interrupts frees the bus for any DMA transfers. Polling mode is used when interrupts are disabled. Polling usually gives a little better access times since interrupt handling requires extra processing. There can be some compatibility issues with some old drives when polling is used with block mode transfers.
125  * IRQ
126   IRQ channel to use. All controllers managed by XTIDE Universal BIOS can use the same IRQ when MS-DOS is used. Other operating systems are likely to require different interrupts for each controller. This menu item appears only when interrupts are enabled.
127
128
129== Menuitems on Master and Slave drive submenus ==
130  * Block mode transfers
131   Block mode will speed up transfers since multiple sectors can be transferred before waiting next data request. Normally block mode should always be kept enabled but there is at least one drive with buggy block mode implementation.
132  * User specified CHS
133   Specify (P-)CHS parameters manually instead of autodetecting them. This can be used to limit drive size for old operating systems that do not support large hard disks. Limiting cylinders will work for all drives but drives may not accept all values for heads and sectors per track.
134  * Cylinders
135  * Heads
136  * Sectors per track
137   Number of user specified P-CHS cylinders, heads and sectors per track. These menu items appear only when user specified CHS is enabled.
138
139
140== Menuitems on Boot menu settings submenu ==
141  * Back to previous menu
142   Resumes back to XTIDE Universal BIOS configuration menu.
143  * Default boot drive
144   Drive to be set selected by default when Boot Menu is displayed.
145  * Display drive info 
146   Boot Menu can display some details about the drives in system. Reading this data might be slow on XTs so you might want to hide drive information.
147  * Display ROM boot
148   Some old systems have Basic or DOS in ROM. Since most systems don't have either, ROM Boot setting is disabled by default. Enable it if you have use for it.
149  * Maximum height
150   Boot Menu maximum height in characters.
151  * Min floppy drive count
152   Detecting correct number of floppy drives might fail when using floppy controller with it's own BIOS. Minimum number of floppy drives can be specified to force non-detected drives to appear on boot menu.
153  * Selection timeout
154   Boot Menu selection timeout in seconds. When time goes to zero, currently selected drive will be booted automatically. Timeout can be disabled by setting this to 0.
155  * Swap boot drive numbers
156   Some old operating systems (DOS) can only boot from Floppy Drive A (00h) or first Hard Disk (80h, usually drive C). Drive Translation can be used to modify drive numbers so that selected drive will be mapped to 00h or 80h so that it can be booted.
157  * Boot loader type
158   * Boot menu
159    Boot menu where user can select drive to boot from.
160   * Simple boot loader
161    Typical A, C, INT 18h boot order.
162   * System boot loader
163    Uses main BIOS boot loader or boot loader provided by some other BIOS. System boot loader works only when late initialization is disabled since late initialization is done on a boot loader.
164
165
166== Settings for Flash EEPROM submenu ==
167  * Back to previous menu
168   Resumes to main menu.
169  * Start flashing
170   Writes (configured) BIOS to EEPROM.
171  * SDP command
172   * None
173    Do not use Software Data Protection. Meant for EEPROMs that do not support SDP.
174   * Enable
175    Write protects the EEPROM after flashing. Software Data Protection should always be enabled if EEPROM supports it.
176   * Disable
177    Disables Software Data Protection after flashing.
178  * EEPROM address
179   Address (segment) where EEPROM is located.
180  * Page size
181   Larger page size will improve write performance but not all EEPROMs support large pages or page writing at all. Byte writing mode will be used when page size is set to 1. Byte writing mode is supported by every EEPROM. Large pages cannot be flashed with slow CPUs.
182  * Generate checksum byte
183   PC BIOSes require checksum byte to the end of expansion card BIOS ROMs. Checksum generation can be disabled so any type of binaries can be flashed.
184
185----
186
187= Boot menu =
188
189Using 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.
190
191
192== Drive swapping ==
193
194DOS 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 idecfg.com.
195
196
197== Boot menu hotkeys ==
198
199Keys 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.
200
201
202== Boot menu drive information ==
203
204Boot menu can display a little bit information about the drive. Drive information can be disabled with idecfg.com.
205
206  * Drive capacity
207   Boot menu displays drive type for floppy drives. The type is read from BIOS and it is the same you usually set in CMOS setup. XT systems do not support the BIOS function to return drive type so 5.25" or 3.5" DD is displayed. For foreign hard disks (hard disks not handled by XTIDE Universal BIOS) the boot menu displays capacity calculated from CHS-parameters returned by BIOS function INT 13h, AH=8h. It is the same capacity that MS-DOS 6.xx and older versions see. Same CHS-capacity is displayed for hard disks handled by XTIDE Universal BIOS. In addition to the CHS capacity, the boot menu will display another size that is the full size of the hard disk.
208  * Drive configuration information is displayed for XTIDE Universal BIOS controlled drives. Information includes:
209   * Addressing (Addr.)
210    This can be L-CHS, P-CHS, LBA28 or LBA48. CHS addressing is the old type of addressing method where cylinder, head and sector numbers will be handled separately. Original PC BIOS functions are designed for CHS addressing with maximum  hard disk size being 7.8 GiB (8.4 GB). LBA addressing is modern addressing method where every sector has its own address. There are no cylinders or heads anymore. Enhanced BIOS functions were introduced for LBA drives but they are not supported before Windows 95 (DOS 7). These EBIOS function are not yet supported by XTIDE Universal BIOS. CHS address must be translated to LBA address when using old CHS BIOS functions with LBA addressing.
211    * L-CHS (known as NORMAL on many old BIOSes) is used for drives <= 504 MiB that can accept the CHS parameters without translation. That makes L-CHS the fastest addressing method.
212    * P-CHS (known as LARGE on many old BIOSes) is used for drives from 504 MiB up to 7.8 GiB. This is a bit slower than L-CHS since simple translation is required to make BIOS L-CHS parameters compatible with IDE P-CHS parameters.
213    * LBA28 (28-bit address) allows drive sizes up to 128 GiB (137 GB) but maximum accessible size is 7.8 GiB when old BIOS functions are used. L-CHS to LBA translation is more complex and slower than L-CHS to P-CHS conversion.
214    * LBA48 (48-bit address) work just like LBA28 but with 20 more address bits. This makes possible to use drives with over 128 GiB capacity.
215   * Block mode (Block)
216    Block size in sectors for block mode transfers. XTIDE Universal BIOS always uses largest supported block size. Block mode is disabled or not supported if this is 1.
217   * Bus type (Bus)
218    Displays the bus type that has been selected with idecfg.com.
219   * IRQ
220    Displays IRQ channel if IRQ has been enabled.
221   * Reset
222    Displays status information from drive reset and initialization. This should always be 00h. Anything else would indicate some sort of error. Let me know if you see something other than 00h.
223
224----
225
226= IDE controllers on VLB and PCI bus =
227
22816-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).
229
230VLB and PCI IDE controllers are much more complex since they have an actual controller between bus and IDE drive. This controller can buffer words so CPU can read 32-bits at a time. Later VLB and (all?) PCI controller also offer flow control so they can support PIO modes 3 and 4. Early VLB controller are limited to PIO-2. 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.
231
232Unfortunately 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.
233
234XTIDE Universal BIOS does not support any specific VLB controllers at the moment. I'm planning to add support for Vision QD6580 controller soon.
235
236----
237
238= Known problems =
239
240== Known bugs in XTIDE Universal BIOS ==
241  * There are some compatibility problems with SCSI BIOSes.
242
243
244== Problems with Compact Flash cards and microdrives ==
245
246CF 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. Avoid CF cards without speed ratings. They are too slow to be used as a hard disks.
247
248MBR 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.
249
250[http://code.google.com/p/xtideuniversalbios/wiki/DriveCompatibility Drive compatibility list can be found here].
251
252
253= Contact information =
254
255[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.
256
257When reporting bugs or other problems, please post the following information:
258  * Computer specs (at least CPU and RAM but details about expansion cards and how they are configured might be useful)
259  * Operating system and version (for example MS-DOS 6.22)
260  * Hard disk(s) you are using with XTIDE Universal BIOS
261  * Hard disk(s) not handled by XTIDE Universal BIOS (if any)
262  * Reset status that boot menu shows if problem is related to specific drive
Note: See TracBrowser for help on using the repository browser.