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

Last change on this file since 568 was 568, checked in by krille_n_@…, 9 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
RevLine 
[392]1; Project name  :   XTIDE Universal BIOS
2; Description   :   Functions for printing drive configuration
3;                   information on Boot Menu.
[399]4;
[392]5; Included by BootMenuPrint.asm, this routine is to be inserted into
6; BootMenuPrint_HardDiskRefreshInformation.
7;
8
9;
[399]10; XTIDE Universal BIOS and Associated Tools
[526]11; Copyright (C) 2009-2010 by Tomi Tilli, 2011-2013 by XTIDE Universal BIOS Team.
[392]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.
[399]17;
[392]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.
[399]22; Visit http://www.gnu.org/licenses/old-licenses/gpl-2.0.html
[392]23;
[399]24
[392]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
[421]45    ; Fall to .PushAddressingMode
[392]46
47;--------------------------------------------------------------------
[421]48; .PushAddressingMode
[392]49;   Parameters:
50;       DS:DI:  Ptr to DPT
51;       CS:BX:  Ptr to IDEVARS
52;   Returns:
[491]53;       Nothing (falls to next push below)
[392]54;   Corrupts registers:
[421]55;       AX, CX, DX
[392]56;--------------------------------------------------------------------
57.PushAddressingMode:
[568]58    mov     al, [di+DPT.bFlagsLow]
59    and     ax, BYTE MASKL_DPT_TRANSLATEMODE
[392]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    ;;
[422]65    mov     cx, g_szAddressingModes_Displacement << (8-TRANSLATEMODE_FIELD_POSITION)
[421]66    mul     cx
67    xchg    al, ah      ; AL = always zero after above multiplication
68    add     ax, g_szAddressingModes
[392]69    push    ax
[421]70    ; Fall to .PushBlockMode
[392]71
72;--------------------------------------------------------------------
[421]73; .PushBlockMode
[392]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
[550]84    test    BYTE [di+DPT.bFlagsHigh], FLGH_DPT_USE_BLOCK_MODE_COMMANDS
[392]85    jz      SHORT .PushBlockSizeFromAX
86    mov     al, [di+DPT_ATA.bBlockSize]
87.PushBlockSizeFromAX:
88    push    ax
[491]89    ; Fall to .PushDeviceType
[392]90
91;--------------------------------------------------------------------
[491]92; .PushDeviceType
[392]93;   Parameters:
94;       DS:DI:  Ptr to DPT
95;       CS:BX:  Ptr to IDEVARS
96;   Returns:
[491]97;       Nothing (falls to next push below)
[392]98;   Corrupts registers:
[491]99;       AX
[392]100;--------------------------------------------------------------------
[473]101.PushDeviceType:
[491]102%ifndef MODULE_SERIAL
103    mov     al, g_szDeviceTypeValues_Displacement
104    mul     BYTE [di+DPT_ATA.bDevice]
105%else
[473]106    mov     ah, [cs:bx+IDEVARS.bDevice]
[491]107    test    BYTE [di+DPT.bFlagsHigh], FLGH_DPT_SERIAL_DEVICE    ; Clears CF
[473]108    eCMOVZ  ah, [di+DPT_ATA.bDevice]    ; DPT_ATA contains up to date device information for IDE drives
[491]109%ifdef USE_UNDOC_INTEL
[568]110    salc    ; Clear AL using CF (from TEST above)
[491]111    eAAD    g_szDeviceTypeValues_Displacement
112%else
113    mov     al, g_szDeviceTypeValues_Displacement
[473]114    mul     ah
[491]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
[473]122%endif
[392]123
[491]124    shr     ax, 1   ; Divide by 2 since IDEVARS.bDevice is multiplied by 2
[473]125    add     ax, g_szDeviceTypeValues
[392]126    push    ax
[491]127    ; Fall to .PushIRQ
[392]128
129;--------------------------------------------------------------------
[491]130; .PushIRQ
[392]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:
[491]137;       AX
[392]138;--------------------------------------------------------------------
139.PushIRQ:
140    mov     al, [cs:bx+IDEVARS.bIRQ]
141    cbw
142    push    ax
[491]143    ; Fall to .PushResetStatus
[392]144
145;--------------------------------------------------------------------
[491]146; .PushResetStatus
[392]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:
[422]156    mov     al, [di+DPT.bInitError]
[392]157    push    ax
158
159;;; fall-out to BootMenuPrint_HardDiskRefreshInformation.
Note: See TracBrowser for help on using the repository browser.