source: xtideuniversalbios/trunk/XTIDE_Universal_BIOS/Src/Menus/BootMenu/BootMenuPrintCfg.asm@ 590

Last change on this file since 590 was 568, checked in by krille_n_@…, 10 years ago

Changes:

  • SerDrive: Using named pipe mode (serdrive -p) now works under Windows XP/2000/Server 2003.
  • checksum.pl: Added a compatibility fix for 3Com 3C503 cards.
  • XTIDECFG will now scan every possible segment address to find and load the BIOS and/or its settings from EEPROM. This should simplify things for people using combined option ROMs.
  • Fixed a bug from r521 in BootSector.asm where the BIOS would not display a timeout error if it failed to load the boot sector from harddrive.
  • Fixed a bug from r541 in CompatibleDPT.asm where CompatibleDPT_CreateDeviceParameterTableExtensionToESBXfromDPTinDSSI would generate an invalid checksum in the DPTE.
  • Optimizations and other fixes.
File size: 5.0 KB
Line 
1; Project name : XTIDE Universal BIOS
2; Description : Functions for printing drive configuration
3; information on Boot Menu.
4;
5; Included by BootMenuPrint.asm, this routine is to be inserted into
6; BootMenuPrint_HardDiskRefreshInformation.
7;
8
9;
10; XTIDE Universal BIOS and Associated Tools
11; Copyright (C) 2009-2010 by Tomi Tilli, 2011-2013 by XTIDE Universal BIOS Team.
12;
13; This program is free software; you can redistribute it and/or modify
14; it under the terms of the GNU General Public License as published by
15; the Free Software Foundation; either version 2 of the License, or
16; (at your option) any later version.
17;
18; This program is distributed in the hope that it will be useful,
19; but WITHOUT ANY WARRANTY; without even the implied warranty of
20; MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
21; GNU General Public License for more details.
22; Visit http://www.gnu.org/licenses/old-licenses/gpl-2.0.html
23;
24
25; Section containing code
26SECTION .text
27
28;;; fall-into from BootMenuPrint_HardDiskRefreshInformation.
29
30;--------------------------------------------------------------------
31; Prints Hard Disk configuration for drive handled by our BIOS.
32; Cursor is set to configuration header string position.
33;
34; BootMenuPrintCfg_ForOurDrive
35; Parameters:
36; DS:DI: Pointer to DPT
37; Returns:
38; Nothing
39; Corrupts registers:
40; AX, BX, CX, DX
41;--------------------------------------------------------------------
42.BootMenuPrintCfg_ForOurDrive:
43 eMOVZX ax, [di+DPT.bIdevarsOffset]
44 xchg bx, ax ; CS:BX now points to IDEVARS
45 ; Fall to .PushAddressingMode
46
47;--------------------------------------------------------------------
48; .PushAddressingMode
49; Parameters:
50; DS:DI: Ptr to DPT
51; CS:BX: Ptr to IDEVARS
52; Returns:
53; Nothing (falls to next push below)
54; Corrupts registers:
55; AX, CX, DX
56;--------------------------------------------------------------------
57.PushAddressingMode:
58 mov al, [di+DPT.bFlagsLow]
59 and ax, BYTE MASKL_DPT_TRANSLATEMODE
60 ;;
61 ;; This multiply both shifts the addressing mode bits down to low order bits, and
62 ;; at the same time multiplies by the size of the string displacement. The result is in AH,
63 ;; with AL clear, and so we exchange AL and AH after the multiply for the final result.
64 ;;
65 mov cx, g_szAddressingModes_Displacement << (8-TRANSLATEMODE_FIELD_POSITION)
66 mul cx
67 xchg al, ah ; AL = always zero after above multiplication
68 add ax, g_szAddressingModes
69 push ax
70 ; Fall to .PushBlockMode
71
72;--------------------------------------------------------------------
73; .PushBlockMode
74; Parameters:
75; DS:DI: Ptr to DPT
76; CS:BX: Ptr to IDEVARS
77; Returns:
78; Nothing (falls to next push below)
79; Corrupts registers:
80; AX
81;--------------------------------------------------------------------
82.PushBlockMode:
83 mov ax, 1
84 test BYTE [di+DPT.bFlagsHigh], FLGH_DPT_USE_BLOCK_MODE_COMMANDS
85 jz SHORT .PushBlockSizeFromAX
86 mov al, [di+DPT_ATA.bBlockSize]
87.PushBlockSizeFromAX:
88 push ax
89 ; Fall to .PushDeviceType
90
91;--------------------------------------------------------------------
92; .PushDeviceType
93; Parameters:
94; DS:DI: Ptr to DPT
95; CS:BX: Ptr to IDEVARS
96; Returns:
97; Nothing (falls to next push below)
98; Corrupts registers:
99; AX
100;--------------------------------------------------------------------
101.PushDeviceType:
102%ifndef MODULE_SERIAL
103 mov al, g_szDeviceTypeValues_Displacement
104 mul BYTE [di+DPT_ATA.bDevice]
105%else
106 mov ah, [cs:bx+IDEVARS.bDevice]
107 test BYTE [di+DPT.bFlagsHigh], FLGH_DPT_SERIAL_DEVICE ; Clears CF
108 eCMOVZ ah, [di+DPT_ATA.bDevice] ; DPT_ATA contains up to date device information for IDE drives
109%ifdef USE_UNDOC_INTEL
110 salc ; Clear AL using CF (from TEST above)
111 eAAD g_szDeviceTypeValues_Displacement
112%else
113 mov al, g_szDeviceTypeValues_Displacement
114 mul ah
115%endif ; USE_UNDOC_INTEL
116%endif ; MODULE_SERIAL
117
118%ifndef CHECK_FOR_UNUSED_ENTRYPOINTS
119 %if (COUNT_OF_ALL_IDE_DEVICES * 2 * g_szDeviceTypeValues_Displacement) > 255
120 %error "The USE_UNDOC_INTEL block in .PushDeviceType needs to be removed (would cause an overflow)!"
121 %endif
122%endif
123
124 shr ax, 1 ; Divide by 2 since IDEVARS.bDevice is multiplied by 2
125 add ax, g_szDeviceTypeValues
126 push ax
127 ; Fall to .PushIRQ
128
129;--------------------------------------------------------------------
130; .PushIRQ
131; Parameters:
132; DS:DI: Ptr to DPT
133; CS:BX: Ptr to IDEVARS
134; Returns:
135; Nothing (falls to next push below)
136; Corrupts registers:
137; AX
138;--------------------------------------------------------------------
139.PushIRQ:
140 mov al, [cs:bx+IDEVARS.bIRQ]
141 cbw
142 push ax
143 ; Fall to .PushResetStatus
144
145;--------------------------------------------------------------------
146; .PushResetStatus
147; Parameters:
148; DS:DI: Ptr to DPT
149; CS:BX: Ptr to IDEVARS
150; Returns:
151; Nothing (falls to next push below)
152; Corrupts registers:
153; AX, BX, DX, ES
154;--------------------------------------------------------------------
155.PushResetStatus:
156 mov al, [di+DPT.bInitError]
157 push ax
158
159;;; fall-out to BootMenuPrint_HardDiskRefreshInformation.
Note: See TracBrowser for help on using the repository browser.