💾 Archived View for spam.works › mirrors › textfiles › programming › biosdiag.man captured on 2023-06-16 at 20:08:51.

View Raw

More Information

-=-=-=-=-=-=-



1.0 Power on self test functions


On cold boot or hard reset AMI BIOS performs system diagnostics and
initialization operations which can be broadly classified into the following :-


        Processor register test
	
        ROM BIOS checksum check

        Keyboard controller test

        CMOS Shutdown register test

        Channel 2,1,0 timer test

        Memory refresh test

        Base 64KB RAM test

        CACHE memory test

        CMOS battery, options set, checksum check

        Display type verification

        Entering protected mode

        Address line test and memory size finding 

        Conventional and Extended memory test

        DMA controller test

        Keyboard test

        System configuration verification and setup




1.0.1 Processor register test..

Procedure..

All processor registers are loaded with values 05555h, 0aaaah, 0cccch,
0f0f0h and checked if they retain the values.

Possible errors..

error:  Registers do not retain the values
Action: 5 short beeps in an infinite loop. System does not
        proceed further.

1.0.2. ROM BIOS Checksum check..

Procedure..

Word addition of the BIOS ROM starting at F000:8000h till F000:FFFEh is
taken. The word addition (checksum)  should be 0.

Possible errors..

error:	Checksum is nonzero
action:	9 short beeps in an infinite loop. System does not
        proceed further.

1.0.3. Keyboard controller test..

A keyboard controller BAT command is issued(command 0AAH) and the
response is checked. Response should be 55H.

Possible errors..

error:	Return value <> 55H
action:	6 short beeps issued in an infinite loop. System does
        not proceed any further.

1.0.4. CMOS Shutdown register test..

Hex value 55h is written into and read back from CMOS shutdown register
8fh. The value read back should be 55h. The same test is then performed
with a hex value 0AAh.

Possible errors..

error:	Values read back not same as values written.
action:	Error "CMOS INOPERATIONAL" is registered and the system
        will stop after the display is initialized with the
        above error displayed on the screen.


1.0.5. Channel 2,1,0 timer test..

A. Channel 2 timer test..

Procedure..

Channel 2 timer gate and speaker is disabled and the gate bit is verified to
see if the gate is still disabled.

Channel 2 timer is programmed for 2 byte count. A test value of 55h is
written to high byte and AAh to low byte of channel 2 timer. Since the
timer gate is disabled it should retain these values.

Possible errors..

error:	channel 2 timer gate is still enabled
action:	Register "CH-2 timer error" to be displayed before
        system boot.

error:	The channel 2 timer does not retain the 55h,AAh written
        to it.
action:	Register "CH-2 timer error" to be displayed before
		system boot.

B. Channel 2, Channel 1 and Channel 0 delta count test..

Procedure..

Select channel 2 timer and load with count data 0ffh. Wait for a predefined
time. Read channel 2 timer value and check if the difference between the
data written and read is within the tolerance limit. If the operation is
successful, try the same with count data 0cch.

Do the same operations on channel 1 and channel 0 timer in the same
order.

Possible errors..

error:	Channel 2 timer is not counting at all
action:	Register "CH-2 timer error" to be displayed before
		system boot.

error:	Channel 2 timer in not counting properly. The delta
		diference is not within tolerence limit.
action:	Register "CH-2 timer error" to be displayed before
		system boot.

error:	Channel 1 timer is not counting at all.
action:	4 beeps and system halted.



error:	Channel 1 timer count is not within tolerence limit.
action:	4 beeps and system halted.

error:	Channel 0 timer is not counting at all.
action:	4 beeps and system halted.

error:	Channel 0 timer count is not within tolerence limit.
action:	4 beeps and system halted.


1.0.6. Refresh test...

Procedure..

Enable channel 1 (Refresh) timer and channel 0 (System timer). Test refresh
signal changing from low-to-high and high-to-low with time out count of
0ffffh.

Wait for refresh signal to be high. Use counter 1 to count till refresh
becomes low. Use counter 2 to count till refresh becomes high. The
difference between counter 1 and counter 2 should not be more than 6.

Possible errors...

error:	A time out has occured while testing refresh 
		low-to-high and high-to-low.
action:	1 beep in an infinite loop and system does not proceed
		further.

error:	The difference between counter 1 and counter 2 is more
		than 6.
action:	1 beep in an infinite loop and the system does not
		proceed further.


1.0.7.Base 64KB RAM test...

Procedure...

On first 64kb of memory do a Address test, Sequential data write & read
test, Random data write & read test. After all tests are over read the
parity port for any parity error which could have occured during the tests.

Possible errors...

error:	Error in address line test
action:	3 beeps in an infinite loop and system does not proceed
		further.

error::	Error in sequential data write & read test
action:	3 beeps in an infinite loop and system does not proceed
		further.


error:	Error in random data write & read test.
action:	3 beeps in an infinite loop and system does not proceed
		further.

error:	A parity error has occured during the tests.
action:	3 beeps in an infinite loop ands the system does not
		proceed further.


1.0.8. Cache memory test...


A. Check the presence of cache memory

Procedure..

Disable cache memory

Take timing to read 32kb memory 9 times and take the minimum value

Enable cache memory

Take timing to read 32kb memory 9 times and take the minimum value

If the minimum value of timing taken with cache on is greater than
minimum value of timing taken with cache memory off, then indicate in
global data area that cache memory is not present.

If cache memory is found present then with cache on test 32kb of memory.

Possible errors..

error:	Error in testing cache memory
action:	Register "CACHE MEMORY BAD, DO NOT ENABLE CACHE" error
		to be displayed on the screen.


B. Test 64kb cache memory

Test 1st 32kb cache memory

Test 2nd 32kb cache memory

Possible errors..

error:	Error in either 1st or 2nd 32kb cache memory test.
action:	Disable cache and register "CACHE MEMORY BAD, DO NOT
		ENABLE CACHE" error to be displayed on the screen.

1.0.9. CMOS battery, options and checksum check...

Read CMOS status register (8dh) and check if battery power is on.

Read CMOS diagnostic byte and check if CMOS options set.

If CMOS battery power is ok and options set then calculate CMOS
checksum for CMOS registers 10h thru 2dh by a byte addition to a word
result. Read the checksum word stored in registers 2eh and 2fh and
compare it with the calculated checksum.

Possible errors..

error:	CMOS battery state is low error.
action:	Register "CMOS battery state low" error to be displayed before
		system boot.

error:	CMOS system options not set error.
action:	Register "CMOS system option not set" error to be displayed
		before system boot.

error:	CMOS checksum mismatch
action:	Register "CMOS checksum error" to be displayed before system
		boot.


1.0.10. Display type verification...

A. finding out Display type

Procedure..

Get display switch setting.

If display switch mono then segment b000h else segment b800h.

Do a display memory sequential write and read test on 4kb of memory.

If display memory write and read test ok then do a horizontal and vertical
retrace test.

If memory test ok and all retrace test ok then leave the mode of display to
what ever is tested and go to check CMOS display type.

If memory test error or any retrace test fails then try the other mode. In
other words if you had color try mono and if you had mono try color.

Do a memory test with the new mode.

Do horizontal and vertical retrace with the new mode.

If memory test ok and all retrace tests ok then leave the mode of display
to whatever is tested and go to check CMOS display type.

if memory test error or retrace test error with the new mode then give one
long and 8 short beeps and continue after setting the final mode to mono.

Possible errors..

error:	memory test error with new mode set
action:	1 long beep and 8 short beeps

error:	retrace test failed with new mode
action:	1 long beep and 8 short beeps.

B. Check CMOS display type and display switch setting

Check the final mode set after finding out display type with the display
switch setting on the motherboard and the display type set in the CMOS by
the user.

Possible errors..

error:	Display switch setting on mother board is not same as what BIOS
		finds out.
action:	Register "Display switch setting not proper" error to be displayed
		before system boot.

error:	Display type set in CMOS is different from what BIOS has found
		out.
action:	Register "CMOS display type mismatch" error to be displayed
before
		system boot.


1.0.11. Entering protected mode...

Procedure..

Get into protected mode using BIOS interrupt 15h function 89h.

Possible errors..

error:	Processor not in protected mode
action:	Display "8042 GATE-A20 ERROR, SYSTEM HALTED"

error:	Virtual mode exception error
action:	7 beeps in an infinite loop. System does not proceed
		further.

1.0.12. Address line test and memory size finding..

Procedure..

Write a test pattern at 0:0h

Starting from bottom of the conventional memory space (640kb boundary) do
a address line test 64kb at a time and come down till there is a segment
where address line error is not found. That will be the bottom of the
conventional memory.

Now read back the test pattern at 0:0h. This should be same as the test
data written at 0:0h before the test was performed. If the test pattern at0:0h is overwritten then there is a address line error because while doing
address line test, the addresses are generated in such a way that only one
bit is set in the address line everytime. If there is a failure in that bit of
address line then the address generated will be 0. So the data written at
that address will actually be written at 0:0h.

Write a test pattern at 0:0h.

Starting from the bottom of the Extended memory (16MB boundary) do a
address line test till there is a segment where address line error is not
found. That will be the bottom of extended memory.

Now read back the data at 0:0h. This should be same as the test data
written at 0:0h before the test is peformed

Possible errors..

error:	Test data at 0:0h is destroyed while trying to find out
		the conventional memory size.
action:	3 beeps in a loop and system does not proceed any
		further.

error:	Test data at 0:0h is destroyed while trying to find out
		the extended memory size.
action:	3 beeps in an infinite loop and the system does not
		proceed further.


1.0.13. Conventional and Extended memory test..

Procedure..

Clear all the conventional memory 64kb at a time by filling it with 0.

Clear all Extended memory 64kb at a time by filling if with 0.


Starting from 2nd 64kb in conventional memory space do the following 64kb
at a time for the size of conventional memory found in step 13:-
		
IF <ESC> is pressed

	skip all test 

	Fill the 64kb memory with 0.

	Go back to real mode

	Display memory size tested so far

	Go back to protected mode

ELSE

	Do a Sequential Write and Read test

	Do a Random Write and Read test


	Check if Parity error is registered during any of the above
	2 tests.

	Fill memory tested with 0

	Go back to real mode

	Display memory size tested so far 

	Go back to protected mode

Starting from 1st 64kb in Extended memory space do the following 64kb at
a time for the size of extended memory found in step 13:-

IF <ESC> is pressed

	Skip all test 

	Fill the memory with 0.

	Go back to real mode

	Display memory size tested so far

	Go back to protected mode


ELSE

	Do a Sequential Write and Read test

	Do a Random Write and Read test

	Check if parity error is registered during any of the above
	2 tests.

	Fill memory tested with 0

	Get into real mode

	Display memory size tested so far 

	Go back to protected mode

Possible errors...

error:	Memory Write and Read test error
action:	1 long beep and 3 short beeps produced in the speaker.
		The memory size is trimmed to what ever was found good.


error:	Parity error registered during Sequential and Random
		test on any 64kb segment.
action:	1 long beep and 3 short beeps produced in the speaker.
		The memory size is trimmed to what ever was found good.

error:	Virtual mode exception error has occured
action:	7 beeps in an infinite loop and system does not proceed
		further.


1.0.14. DMA Controller test

4 different patterns are written into and read back from DMA page
registers 80h thru 8fh. The data read back should be same as the data
written. The data patterns used are aa55h,55aah,cc0fh,0000h.

The same patterns are then written into, read back from DMA unit 1
registers 00 thru 07. The data read back should be same as the data
written.

The same patterns are them written into, read back from DMA unit 2
registers C0h thru C7h. The data read back should be same as the data
written.

Possible errors...

error:	Any one of the DMA page registers did not retain the
		data.
action:	"DMA ERROR, SYSTEM HALTED"

error:	Any one of the DMA unit 1 registers did not retain the
		data.
action:	"DMA #1 ERROR, SYSTEM HALTED"

error:	Any one of the DMA unit 2 registers did not ratain the
		data.
action:	"DMA #2 ERROR, SYSTEM HALTED"


1.0.15. Keyboard test

Procedure..

Output keyboard self test command 0ffh. The keyboard should return 0fah
and 0aah.

If the data returned is 0fah and 0aah then check if any key is stuck on
the keyboard. This is done by enabling keyboard enable bit, inhibit bit, sys
bit, output buffer full bit and then checking for output buffer full bit going
low.



If any error occured during the above two tests, keyboard interface test is
performed. This is done by writing command 0abh to keyboard controller
and reading the response. The response should be 00h.

Possible errors..

error:	Keyboard self test command failed but the keyboard
		interface test command was successful.
action:	Register soft error "Keyboard error" to be displayed
		before system boot.

error:	Keyboard self test command passed, keyboard was found
		to be stuck and keyboard interface command passed.
action:	Register soft error "Keyboard error" to be displayed
		before system boot.

error:	Keyboard self test command failed or keyboard was found
		stuck and the keyboard interface command failed.
action:	Register "KB/Interface error" to be displayed before
		system boot.

1.0.16. System configuration verification and setup

A. Floppy disk setup..

Procedure..

Initialize floppy global data area.

reset floppy controller.

For floppy drive 0 and 1 try to find out the presence of the drive and then
sense the drive type in the following manner:-

	Seek to track 48

	Seek backwards till track 0

	If seek to track 0 is not successful then it is a 40 track
	drive which is 360kb. So set global as 360kb disk type.

	If seek to track 0 is successful, it is a 80 track drive so
	check CMOS for type of drive selected through the SETUP
	program.

	For 720kb drive set 720kb disk type in global.

	If 1.2mb or 1.44mb in CMOS, then set 2 or 7 respectively in
	the global which means that media has to be established for
	these drives every time a new disk is put in. This is
	necessary because a 1.2mb drive can take 1.2mb or 360kb disk
	and a 1.44mb drive can take either 720kb or 1.44mb disk.



Possible errors...

error:	Reset floppy controller failure
action:	Register "FDD controller failure" error to be displayed
		before system boot.

B. Hard disk Setup

Procedure..

Reset hard disk controller.

If CMOS bad or no drive type set, skip hard disk check otherwise do hard
disk tests in following manner:-

Redirect Int 13h to Int 40h for floppy and point Int 13h to hard disk
routines.

Depending upon the CMOS Drive type value, point Int 41h and Int 46h
vectors to ROM drive type parameters for drive C and D respectively.

Initialize the global data area for hard disks.

Issue controller diagnostics command for the hard disk controller.

Set parameters from drive type table for drive 0 and recalibrate on drive 0
if CMOS type is set for drive 0.

Set parameters from drive type table for drive 1 and recalibrate on drive 1
if CMOS type is set for for drive 1. 

For drive 0, if CMOS type is set, do verify on each sector in the last
track. At least one of the sectors in the last track should verify ok.

For drive 1, if CMOS isset, do verify on each sector in the last track. At
least one of the sectors in the last track should verify ok.

Possible errors..

error:	Hard disk controller diagnostics failed
action:	Register "HDD controller error" to be displayed before
		system boot.

error:	Recalibrate on drive 0 failed.
action:	Register "C:Drive failure" error to be displayed before
		system boot.

error::	Recalibrate on drive 1 failed.
action:	Register "D:Drive failure" error to be displayed before
		system boot.



error:	None of the sectors in last track on drive 0 verified
		ok.
action:	Register "C:Drive error" error to be displayed before
		system boot.

error:	None of the sectors in last track on drive 1 verified
		ok.
action:	Register "D:Drive error" error to be displayed before
		system boot.


C. Memory size verification

Procedure...

If CMOS battery state is ok and CMOS checksum is ok then do the
following:-

Check Conventional memory size in CMOS with actual memory size found
out by BIOS.

Check Extended memory size in CMOS with actual extended memory size
found by BIOS.

Possible errors..

error::	Actual conventional memory size found by BIOS is not
		same as memory size stored in CMOS.
action:	Register "CMOS memory size mismatch" error to be
		displayed before system boot.

error:	Actual extended memory size found by BIOS is different
		from memory size stored in CMOS.
action:	Register "CMOS memory size mismatch" error to be
		displayed before system boot.


D. Optional ROM control

Procedure..

Start from segment C800h segment and continue with an increment of 80h
till E000h segment with the following operation:-

Check if word at offset 0 is 0aa55h.

If word at offset 0 is 0aa55h then do the following:-

Take the size of the ROM from offset 2. The size should be # of 512 bytes
in the optional ROM. Now calculate the checksum of the ROM by adding all
the bytes. The checksum should be 0. If the checksum is 0 then give
control to the optional ROM at offset 3 
by a FAR CALL.

E. Initialize Timer data area

Procedure..

Check if CMOS battery state ok and CMOS checksum ok. If both of them
are ok then do the following:-

Read real time clock through BIOS interrupt routine 1Ah. Compare the
hour, minute and second BCD values to find if they are within limit. Hour
should be <=24, Minute<=60 and second<=60. If they are within limit then
change them from BCD to Binary value and in terms 1/18th of a second.
Save them in timer data area which is 2 words and is used by the timer
routine to update the count in every 1/18th of a second.

Possible errors..

error:	Error returned by int 1Ah function.
action:	Register "CMOS time & date not set" to be displayed
		before system boot.

error:	Hour, minute and seconds not within limit.
action:	Register "CMOS time & date not set" error to be
		displayed before system boot.


E. Setup Printer and RS232 Ports

Procedure..

Check for presence of printer ports 03bch, 0378h, 0278h by a port pattern
test. In the port pattern test write values 0aa55h, 55aah, cc00h,0000h to
these ports in these order and read them back after writing to check if
they retain the values. For the ports that retain the values, add them to
the system data area starting at 40h:8.

Check for presence of RS232 ports 03f8h, 02f8h, 03e8h, 02e8h in the same
way as above and add them to the system data area at 40h:0.

F. Check for Keyboard lock

Procedure..

Read keyboard status port and check the keyboard lock bit.

Possible errors..

error:	Keyboard is locked
action:	Register "Keyboard is locked" error to be displayed
		before system boot.

G. Display all error messages

H. System ROM control

Procedure..

Check for System ROM at segment e000h in following manner:-

Check if at offset 0 the word value is 0aa55h. If the value is 0aa55h then
calculate a byte checksum for 64kb by adding all bytes. The checksum
should be 0. If the checksum is zero then give control to the optional ROM
at offset 3.




2.0 Classification of error messages..

The error messages can be classified into 4 diferent categories

		Fatal errors through beeps
	
		Fatal errors through display

		Non fatal errors through beeps

		Non fatal errors through display

2.1 Fatal errors through beeps..

The fatal errors through beeps are conveyed through a number of beeps in
an infinite process and there is enough time gap between tow subsequent
sets of error beeps to calculate the number in each set.

2.1.1 One beep (DRAM Refresh failure)

Occurrence..

	Refresh test

2.1.2 Three beeps (Base 64kb RAM failure)

Occurrence..

	Base 64kb RAM test

	Address test and memory size finding

2.1.3 Four beeps (System timer failure)

Occurrence..

	Channel 1 timer test

	Channel 0 timer test

2.1.4 Five beeps (Processor failure)

Occurrence..

	Processor register test

2.1.5 Six beeps (Keyboard controller Gate A20 error)

Occurrence..

	Keyboard controller test


2.1.6 Seven beeps (Virtual mode exception error)

Occurrence..

	Getting into protected mode

	Conventional and Extended memory test


2.1.7 Nine beeps (ROM BIOS Checksum failure)

Occurrence..

	ROM BIOS Checksum check


2.2 Fatal errors through display..

When these errors are displayed the screen is cleared and after the error
message display is also followed by a line saying "SYSTEM HALTED"

2.2.1 CMOS INOPERATIONAL

Occurrence..

	CMOS Shutdown register test

2.2.2 8042 GATE-A20 ERROR

Occurrence..

	Getting into protected mode

2.2.3 INVALID SWITCH MEMORY FAILURE

2.2.4 DMA ERROR

Occurrence.. 

	DMA Controller page register test

2.2.5 DMA #1 ERROR

Occurrence..
	
	DMA Unit 1 register test

2.2.6 DMA #2 ERROR

Occurrence..

	DMA Unit 2 register test


2.3 Non fatal errors through beeps..

These errors are displayed as one long beep following by a number of short
beeps and the system proceeds normally.

2.3.1 One long and 3 short beeps

Occurrence..

	Conventional and Extended memory test

2.3.2 One long and eight short beeps

Occurrence..

	Display RAM test and display vertical and horizontal retrace test.

2.4 Non fatal errors through display..

These types of errors are classified into 2 categories.

	Ones that wait for F1 key and give the option to run SETUP

	Ones that wait for F1 key but do not give option to run SETUP

2.4.1 Errors waiting fot F1 key and giving option to run SETUP

2.4.1.1 CMOS battery state low

Ouucrrence..

	CMOS battery, options set and checksum test

2.4.1.2 CMOS system options not set

Occurrence..

	CMOS battery, options set and checksum test

2.4.1.3 CMOS ckecksum failure

Occurrence..

	CMOS battery, options set and checksum test

2.4.1.4 CMOS display type mismatch

Occurrence..

	Display type verification

2.4.1.5 CMOS memory size mismatch

Occurrence..

	System Configuration verification and setup (Memory size verification)

2.4.1.6 CMOS time & date not set

Occurrence..

	System configuration verification and setup (Init timer data)


2.4.1.7 C:Drive failure

Occurrence..

	System configuration verification and setup (Hard disk setup)

2.4.2 Errors waiting for F1 key and not giving the option to run SETUP

2.4.2.1 CH-2 timer error

Occurrence..

	Channel 2,1,0 timer test

2.4.2.2 Keyboard error

Occurrence..

	Keyboard test

2.4.2.3 KB/Interface error

Occurrence..

	Keyboard test

2.4.2.4 Display switch setting not proper

Occurrence..

	Display type verification


2.4.2.5 Keyboard is locked ... Unlock it

Occurrence..

	System configuration verification and setup (Keyboard lock check)

2.4.2.6 FDD controller error

Occurrence..

	System configuration verification and setup (floppy disk setup)

2.4.2.7 HDD controller failure

Occurrence..

	System configuration verification and setup (Hard disk setup)

2.4.2.8 C:Drive error

Occurrence..

	System configuration verification and setup (Hard disk setup)


2.4.2.9 D:Drive error

Occurrence..

	System configuration verification and setup (Hard disk setup)


2.4.2.10 D:Drive failure

Occurrence..

	System configuration verification and setup (Hard disk setup)


Appendix A


Address line test procedure


For the 64kb of memory on test, write and then read data patterns 0ffh
and 00h at addresses 1, 2, 4, 8, 16, 32, 64, 128, 256, 512, 1024, 2048, 4096,
8192, 16384, 32768. The data read back should be same as that written.

Sequential memory Write and Read test

For the 64kb of memory on test, use test patterns 8080h, 5555h, 3333h,
0f0fh in the same order.

Take one pattern and write it on the entire 64kb space one word at a time.
Then compare the 64k space one word at a time with the value written. If
any word does not retain the value then return error.


Random memory Write and Read test

Use a random number generator which generates 16k of random numbers as
memory addresses and returns a seed between 0 to ffh associated with each
random addresses generated.

Use the random number generator again and read the data from the random
address.  The data read back should be same as the seed returned by the
random number generator. In short, the BIOS checks wheather the data
written in 16k random addresses are retained in those memory locations.

The random number generator procedure is written in such a way that it
generates the same sequence of random numbers in the same order every
time it is called and it also returns a unique seed associated with each
random number.



Appendix B

CMOS RAM USAGE IN AMI MARK II AT BIOS

-------------------------------------------------------------------------
Address		Description

-------------------------------------------------------------------------
00-0D	*Real-time clock information
0E		*Diagnostics status byte
0F		*Shutdown status byte
10		Diskett drive type byte - drives A and B
11		Reserved
12		Fixed disk type byte - drives C and D (1 - 14)
13		Reserved
14		Equipment byte
15		Base memory byte LOW
16		Base memory byte HIGH
17		Expansion memory byte LOW
18		Expansion memory byte HIGH
19		Extended fixed disk type - drive C (16 - 255)
1A		Extended fixed disk type - drive D (16 - 255)
1B-2C!!	User defined drive type 
2D		Reserved
2E-2F	2 - byte CMOS Checksum
30		*Expansion memory size LOW
31		*Expansion memory size HIGH
32		*Date century byte
33		*Information flags (set during power on)
34-36	Reserved
37 !!	Video and Keyboard installation information
38 !!	Video shadow and memory information
39-3A!!	Segment value for scratch memory used by BIOS for Load all
		translation.
3B-3F	Reserved
------------------------------------------------------------------------


of the configuration record.

!! These are extra bytes used by AMI BIOS.

Bytes 1B - 2C (Is used by AMI BIOS released after March 1989)
_____________________________________________

These bytes will store user defined drive types in following format.

Drive C User defined type

1B,1C		Number of cylinders
1D			Number of heads

1E,1F		Write precom

20			Control byte
21,22		Landing zone
23			Number of sectors

Drive D User defined type

24,25		Number of cylinders
26			Number of heads
27,28		Write precom
29			Control byte
2A,2B		Landing zone
2C			Number of sectors


Byte 37 
_____


Bit 0		This bit has meaning only in BIOS released after March
1989.
			1=Test keyboard
			0=Do not test keyboard

Bit 1		This bit has meaning only in BIOS released after March
1989.
			1=Test Video
			0=Don not test Video

Bit 2		Current status of keyboard controller pin 23.

Bit 3		Current Status of Keyboard controller pin 24.

Bit 4-7		Not used

Byte 38
_____

Bit 0-2		Not used

Bit 3		1="INS" key has been pressed
			0="INS" key not pressed

Bit 4		1=Weitek co-processor present
			0=Weitek co-processor absent

Bit 5		1=Enable Video shadow
			0=Disable video shadow

Bit 6		1=Relocate 256k memory
			0=Do not relocate 256k memory

Bit 7		1=32-bit memory card installed
			0=32-bit memory card not installed
			
			

Byte 39-3A 
________

These bytes are used to save the segment value of the memory BIOS is
going to use for Load all function translation. For MARK II AT Board this
actually points to BIOS area because BIOS Shadow RAM is enabled.