source: xtideuniversalbios/wiki/Manual.wiki@ 606

Last change on this file since 606 was 454, checked in by aitotat@…, 12 years ago

Old v1.x.x manual is no longer listed on project home page.

File size: 20.0 KB
Line 
1#summary Instructions for XTIDE Universal BIOS v1.1.0
2#labels Phase-Deploy
3*Table of Contents*
4<wiki:toc max_depth="3" />
5----
6= Introduction =
7
8XTIDE 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.
9
10
11== Features ==
12
13Some of the features included in XTIDE Universal BIOS are...
14 * Supports up to 5 IDE controllers (10 drives)
15 * Accesses up to 8.4 GB hard disk space (BIOS CHS limit)
16 * Block mode transfers
17 * Hard disk autodetection
18 * Autodetected CHS parameteres can be overridden to make drive appear smaller than it is
19 * Boot menu for selecting any floppy drive or hard disk to boot from, including hard disks that are not handled by XTIDE Universal BIOS
20 * Compact Flash and Microdrive support
21 * Support for most 8-, 16-, and 32-bit IDE controllers
22 * IRQ and polling operation modes
23...and many more.
24
25
26== Different builds ==
27
28At the moment there are three different builds included in the XTIDE Universal BIOS zip file:
29 * IDE_XT.BIN (XT build)
30 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.
31 * IDE_XTP.BIN (XT+ build)
32 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.
33 * IDE_AT.BIN (AT build)
34 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.
35
36----
37
38= Installing XTIDE Universal BIOS =
39
40== Hardware supporting XTIDE Universal BIOS ROM ==
41
42The 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.
43
44Another 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.
45
46You 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.
47
48
49== Configuring and flashing BIOS ==
50
51XTIDE 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.
52
53
54== Other things to know ==
55
56CTRL can be held down to skip XTIDE Universal BIOS initialization. Only drive detection will be skipped when late initialization is used.
57
58----
59
60= Using IDECFG.COM (XTIDE Universal BIOS configuration and flashing program) =
61
62Idecfg.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.
63
64Some menu items appear only when needed to make configuring easier.
65
66
67== Menuitems on main menu ==
68 * Exit to DOS
69 This menu item exits to DOS but allows user to save any unsaved changes.
70 * Load BIOS from file
71 Loads any file with .BIN extension to be flashed.
72 * Load BIOS from EEPROM
73 This menu item appears only when supported version of XTIDE Universal BIOS is detected. It loads the BIOS from EEPROM to be reconfigured.
74 * Load old settings from EEPROM
75 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.
76 * Configure XTIDE Universal BIOS
77 All XTIDE Universal BIOS settings can be found and configured from this sub menu.
78 * Flash EEPROM
79 Settings for EEPROM flashing.
80
81
82== Menuitems on Configure XTIDE Universal BIOS submenu ==
83 * Back to previous menu
84 Resumes back to main menu.
85 * Primary IDE Controller
86 * Secondary IDE Controller
87 * Tertiary IDE Controller
88 * Quaternary IDE Controller
89 * Quinary IDE Controller
90 IDE Controller menu items appear based on selected number of IDE controllers.
91 * Boot menu settings
92 Opens sub menu for configuring boot menu. This menu item appears only when Boot loader type is set to Menu.
93 * Late initialization
94 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.
95 * Maximize disk size
96 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.
97 * Full operating mode
98 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.
99 * kiB to steal from RAM
100 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.
101 * Number of IDE controllers
102 Number of IDE controllers handled by XTIDE Universal BIOS. This menu item appears only when full operating mode is enabled.
103
104
105== Menuitems on IDE Controller submenus ==
106 * Back to previous menu
107 Resumes back to Configure XTIDE Universal BIOS submenu.
108 * Master drive
109 * Slave drive
110 Drive specific settings for master and slave drives.
111 * Bus type
112 * 8-bit dual port (XTIDE)
113 8-bit ISA controllers with two data ports. This is what the XTIDE card uses.
114 * 8-bit single port
115 8-bit ISA controllers with one data port.
116 * 16-bit
117 ISA (16-bit) but it also works on VLB and PCI controllers.
118 * 32-bit generic
119 Generic 32-bit I/O for VLB and PCI controllers.
120 * Base (cmd block) address
121 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.
122 * Control block address
123 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.
124 * Enable interrupt
125 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.
126 * IRQ
127 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.
128
129
130== Menuitems on Master and Slave drive submenus ==
131 * Block mode transfers
132 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.
133 * User specified CHS
134 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.
135 * Cylinders
136 * Heads
137 * Sectors per track
138 Number of user specified P-CHS cylinders, heads and sectors per track. These menu items appear only when user specified CHS is enabled.
139
140
141== Menuitems on Boot menu settings submenu ==
142 * Back to previous menu
143 Resumes back to XTIDE Universal BIOS configuration menu.
144 * Default boot drive
145 Drive to be set selected by default when Boot Menu is displayed.
146 * Display drive info
147 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.
148 * Display ROM boot
149 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.
150 * Maximum height
151 Boot Menu maximum height in characters.
152 * Min floppy drive count
153 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.
154 * Selection timeout
155 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.
156 * Swap boot drive numbers
157 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.
158 * Boot loader type
159 * Boot menu
160 Boot menu where user can select drive to boot from.
161 * Simple boot loader
162 Typical A, C, INT 18h boot order.
163 * System boot loader
164 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.
165
166
167== Settings for Flash EEPROM submenu ==
168 * Back to previous menu
169 Resumes to main menu.
170 * Start flashing
171 Writes (configured) BIOS to EEPROM.
172 * SDP command
173 * None
174 Do not use Software Data Protection. Meant for EEPROMs that do not support SDP.
175 * Enable
176 Write protects the EEPROM after flashing. Software Data Protection should always be enabled if EEPROM supports it.
177 * Disable
178 Disables Software Data Protection after flashing.
179 * EEPROM address
180 Address (segment) where EEPROM is located.
181 * Page size
182 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.
183 * Generate checksum byte
184 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.
185
186----
187
188= Boot menu =
189
190Using 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.
191
192
193== Drive swapping ==
194
195DOS 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.
196
197
198== Boot menu hotkeys ==
199
200Keys 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.
201
202
203== Boot menu drive information ==
204
205Boot menu can display a little bit information about the drive. Drive information can be disabled with idecfg.com.
206
207 * Drive capacity
208 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.
209 * Drive configuration information is displayed for XTIDE Universal BIOS controlled drives. Information includes:
210 * Addressing (Addr.)
211 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.
212 * 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.
213 * 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.
214 * 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.
215 * 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.
216 * Block mode (Block)
217 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.
218 * Bus type (Bus)
219 Displays the bus type that has been selected with idecfg.com.
220 * IRQ
221 Displays IRQ channel if IRQ has been enabled.
222 * Reset
223 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.
224
225----
226
227= IDE controllers on VLB and PCI bus =
228
22916-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).
230
231VLB 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.
232
233Unfortunately 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.
234
235XTIDE Universal BIOS does not support any specific VLB controllers at the moment. I'm planning to add support for Vision QD6580 controller soon.
236
237----
238
239= Known problems =
240
241== Known bugs in XTIDE Universal BIOS ==
242 * There are some compatibility problems with SCSI BIOSes.
243
244
245== Problems with Compact Flash cards and microdrives ==
246
247CF 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.
248
249MBR 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.
250
251[http://code.google.com/p/xtideuniversalbios/wiki/DriveCompatibility Drive compatibility list can be found here].
252
253
254= Contact information =
255
256[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.
257
258When reporting bugs or other problems, please post the following information:
259 * Computer specs (at least CPU and RAM but details about expansion cards and how they are configured might be useful)
260 * Operating system and version (for example MS-DOS 6.22)
261 * Hard disk(s) you are using with XTIDE Universal BIOS
262 * Hard disk(s) not handled by XTIDE Universal BIOS (if any)
263 * Reset status that boot menu shows if problem is related to specific drive
Note: See TracBrowser for help on using the repository browser.