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

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

Changes to XTIDE Universal BIOS:

  • Large changes to prepare full XT-CF support (DMA not yet implemented and memory mapped transfers are not working).
File size: 4.5 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
[392]11; Copyright (C) 2009-2010 by Tomi Tilli, 2011-2012 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.
[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:
53; Nothing (jumps to next push below)
54; Corrupts registers:
[421]55; AX, CX, DX
[392]56;--------------------------------------------------------------------
57.PushAddressingMode:
[422]58 ACCESSDPT__GET_UNSHIFTED_TRANSLATE_MODE_TO_AXZF
[392]59 ;;
60 ;; This multiply both shifts the addressing mode bits down to low order bits, and
61 ;; at the same time multiplies by the size of the string displacement. The result is in AH,
62 ;; with AL clear, and so we exchange AL and AH after the multiply for the final result.
63 ;;
[422]64 mov cx, g_szAddressingModes_Displacement << (8-TRANSLATEMODE_FIELD_POSITION)
[421]65 mul cx
66 xchg al, ah ; AL = always zero after above multiplication
67 add ax, g_szAddressingModes
[392]68 push ax
[421]69 ; Fall to .PushBlockMode
[392]70
71;--------------------------------------------------------------------
[421]72; .PushBlockMode
[392]73; Parameters:
74; DS:DI: Ptr to DPT
75; CS:BX: Ptr to IDEVARS
76; Returns:
77; Nothing (falls to next push below)
78; Corrupts registers:
79; AX
80;--------------------------------------------------------------------
81.PushBlockMode:
82 mov ax, 1
83 test BYTE [di+DPT.bFlagsHigh], FLGH_DPT_BLOCK_MODE_SUPPORTED
84 jz SHORT .PushBlockSizeFromAX
85 mov al, [di+DPT_ATA.bBlockSize]
86.PushBlockSizeFromAX:
87 push ax
88
89;--------------------------------------------------------------------
[473]90; PushDeviceType
[392]91; Parameters:
92; DS:DI: Ptr to DPT
93; CS:BX: Ptr to IDEVARS
94; Returns:
95; Nothing (jumps to next push below)
96; Corrupts registers:
97; AX, DX
98;--------------------------------------------------------------------
[473]99.PushDeviceType:
100 mov al,g_szDeviceTypeValues_Displacement
101%ifdef MODULE_SERIAL
102 mov ah, [cs:bx+IDEVARS.bDevice]
103 test BYTE [di+DPT.bFlagsHigh], FLGH_DPT_SERIAL_DEVICE
104 eCMOVZ ah, [di+DPT_ATA.bDevice] ; DPT_ATA contains up to date device information for IDE drives
105 mul ah
106%else
107 mul BYTE [di+DPT_ATA.bDevice]
108%endif
[392]109
110 shr ax,1 ; divide by 2 since IDEVARS.bDevice is multiplied by 2
111
[473]112 add ax, g_szDeviceTypeValues
[392]113 push ax
114
115;--------------------------------------------------------------------
116; PushIRQ
117; Parameters:
118; DS:DI: Ptr to DPT
119; CS:BX: Ptr to IDEVARS
120; Returns:
121; Nothing (falls to next push below)
122; Corrupts registers:
123; AX, DX
124;--------------------------------------------------------------------
125.PushIRQ:
126 mov al, [cs:bx+IDEVARS.bIRQ]
127 cbw
128 push ax
129
130;--------------------------------------------------------------------
131; PushResetStatus
132; Parameters:
133; DS:DI: Ptr to DPT
134; CS:BX: Ptr to IDEVARS
135; Returns:
136; Nothing (falls to next push below)
137; Corrupts registers:
138; AX, BX, DX, ES
139;--------------------------------------------------------------------
140.PushResetStatus:
[422]141 mov al, [di+DPT.bInitError]
[392]142 push ax
143
144;;; fall-out to BootMenuPrint_HardDiskRefreshInformation.
Note: See TracBrowser for help on using the repository browser.