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

Last change on this file since 601 was 601, checked in by krille_n_, 5 years ago

Changes:

  • Building the BIOS now works again.
  • Added a new IDE device type/transfer mode for use only with XT-IDE rev 2+ (or Chuck(G)-modded rev 1) cards installed in any of the following machines: Olivetti M24, AT&T PC6300, Xerox 6060 and Logabax Persona 1600. This new transfer mode is slightly faster than the regular XT-IDE rev 1 device type and requires that the card is configured for High Speed mode (or, in case of the card being a rev 1 card, has the Chuck(G) mod done). The new device type is called "XTIDE rev 2 (Olivetti M24)" in XTIDECFG.
  • Made some minor improvements to the library code that handles 'Drive Not Ready' errors in XTIDECFG.
  • Optimizations.
File size: 4.9 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_RefreshInformation.
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_RefreshInformation.
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, DX
41;--------------------------------------------------------------------
42.BootMenuPrintCfg_ForOurDrive:
43    ; Fall to .PushAddressingMode
44
45;--------------------------------------------------------------------
46; .PushAddressingMode
47;   Parameters:
48;       DS:DI:  Ptr to DPT
49;   Returns:
50;       Nothing (falls to next push below)
51;   Corrupts registers:
52;       AX, BX, DX
53;--------------------------------------------------------------------
54.PushAddressingMode:
55    mov     al, [di+DPT.bFlagsLow]
56    and     ax, BYTE MASKL_DPT_TRANSLATEMODE
57    ;;
58    ;; This multiply both shifts the addressing mode bits down to low order bits, and
59    ;; at the same time multiplies by the size of the string displacement.  The result is in AH,
60    ;; with AL clear, and so we exchange AL and AH after the multiply for the final result.
61    ;;
62%ifdef USE_186
63    imul    ax, g_szAddressingModes_Displacement << (8-TRANSLATEMODE_FIELD_POSITION)
64%else
65    mov     bx, g_szAddressingModes_Displacement << (8-TRANSLATEMODE_FIELD_POSITION)
66    mul     bx
67%endif
68    xchg    al, ah      ; AL = always zero after above multiplication
69    add     ax, g_szAddressingModes
70    push    ax
71    ; Fall to .PushBlockMode
72
73;--------------------------------------------------------------------
74; .PushBlockMode
75;   Parameters:
76;       DS:DI:  Ptr to DPT
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;   Returns:
96;       Nothing (falls to next push below)
97;   Corrupts registers:
98;       AX, BX
99;--------------------------------------------------------------------
100.PushDeviceType:
101    call    AccessDPT_GetIdevarsToCSBX
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;       AL
154;--------------------------------------------------------------------
155.PushResetStatus:
156    mov     al, [di+DPT.bInitError]
157    push    ax
158
159;;; fall-out to BootMenuPrint_RefreshInformation.
Note: See TracBrowser for help on using the repository browser.