source: xtideuniversalbios/trunk/XTIDE_Universal_BIOS/Src/VariablesAndDPTs/RamVars.asm@ 506

Last change on this file since 506 was 505, checked in by krille_n_@…, 12 years ago

Changes:

  • Reverted the changes to MenuEvents.inc done in r492 since they broke the F1 key function in XTIDECFG.
  • Added a tail-call optimized variant of the CALL_DISPLAY_LIBRARY macro (JMP_DISPLAY_LIBRARY).
  • Put a block size limit in AH1Eh_ChangeXTCFmodeBasedOnControlRegisterInAL. I think it's needed but if not, it's easy to remove.
  • Other optimizations and fixes.
File size: 6.7 KB
Line 
1; Project name : XTIDE Universal BIOS
2; Description : Functions for accessings RAMVARS.
3
4;
5; XTIDE Universal BIOS and Associated Tools
6; Copyright (C) 2009-2010 by Tomi Tilli, 2011-2012 by XTIDE Universal BIOS Team.
7;
8; This program is free software; you can redistribute it and/or modify
9; it under the terms of the GNU General Public License as published by
10; the Free Software Foundation; either version 2 of the License, or
11; (at your option) any later version.
12;
13; This program is distributed in the hope that it will be useful,
14; but WITHOUT ANY WARRANTY; without even the implied warranty of
15; MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
16; GNU General Public License for more details.
17; Visit http://www.gnu.org/licenses/old-licenses/gpl-2.0.html
18;
19
20; Section containing code
21SECTION .text
22
23;--------------------------------------------------------------------
24; Initializes RAMVARS.
25; Drive detection can be started after this function returns.
26;
27; RamVars_Initialize
28; Parameters:
29; Nothing
30; Returns:
31; DS: RAMVARS segment
32; Corrupts registers:
33; AX, CX, DI
34;--------------------------------------------------------------------
35RamVars_Initialize:
36 push es
37 ; Fall to .StealMemoryForRAMVARS
38
39;--------------------------------------------------------------------
40; .StealMemoryForRAMVARS
41; Parameters:
42; Nothing
43; Returns:
44; DS: RAMVARS segment
45; Corrupts registers:
46; AX
47;--------------------------------------------------------------------
48.StealMemoryForRAMVARS:
49%ifndef USE_AT
50 mov ax, LITE_MODE_RAMVARS_SEGMENT
51 test BYTE [cs:ROMVARS.wFlags], FLG_ROMVARS_FULLMODE
52 jz SHORT .InitializeRamvars ; No need to steal RAM
53%endif
54
55 LOAD_BDA_SEGMENT_TO ds, ax, ! ; Zero AX
56 mov al, [cs:ROMVARS.bStealSize]
57 sub [BDA.wBaseMem], ax
58 mov ax, [BDA.wBaseMem]
59 eSHL_IM ax, 6 ; Segment to first stolen kB (*=40h)
60 ; Fall to .InitializeRamvars
61
62;--------------------------------------------------------------------
63; .InitializeRamvars
64; Parameters:
65; AX: RAMVARS segment
66; Returns:
67; DS: RAMVARS segment
68; Corrupts registers:
69; AX, CX, DI, ES
70;--------------------------------------------------------------------
71.InitializeRamvars:
72 mov ds, ax
73 mov es, ax
74 mov cx, RAMVARS_size
75 xor di, di
76 call Memory_ZeroESDIwithSizeInCX
77 mov WORD [RAMVARS.wDrvDetectSignature], RAMVARS_DRV_DETECT_SIGNATURE
78 mov WORD [RAMVARS.wSignature], RAMVARS_RAM_SIGNATURE
79 ; Fall to .InitializeInt13hStackChangeVariables
80
81;--------------------------------------------------------------------
82; .InitializeInt13hStackChangeVariables
83; Parameters:
84; DS: RAMVARS segment
85; Returns:
86; Nothing
87; Corrupts registers:
88; AX
89;--------------------------------------------------------------------
90%ifdef RELOCATE_INT13H_STACK
91.InitializeInt13hStackChangeVariables:
92 eMOVZX ax, BYTE [cs:ROMVARS.bStealSize]
93 eSHL_IM ax, 10 ; kiB to Bytes = Top of stack offset
94 mov [RAMVARS.wNewStackOffset], ax
95%endif
96
97;; There used to be a DriveXlate_Reset call here. It isn't necessary, as we reset
98;; when entering the boot menu and also before transferring control at boot time and
99;; for ROM boots (in int19h.asm).
100
101 pop es
102 ret
103
104;--------------------------------------------------------------------
105; Returns segment to RAMVARS.
106; RAMVARS might be located at the top of interrupt vectors (0030:0000h)
107; or at the top of system base RAM.
108;
109; RamVars_GetSegmentToDS
110; Parameters:
111; Nothing
112; Returns:
113; DS: RAMVARS segment
114; Corrupts registers:
115; DI
116;--------------------------------------------------------------------
117ALIGN JUMP_ALIGN
118RamVars_GetSegmentToDS:
119
120%ifndef USE_AT ; Always in Full Mode for AT builds
121 test BYTE [cs:ROMVARS.wFlags], FLG_ROMVARS_FULLMODE
122 jnz SHORT .GetStolenSegmentToDS
123 %ifndef USE_186
124 mov di, LITE_MODE_RAMVARS_SEGMENT
125 mov ds, di
126 %else
127 push LITE_MODE_RAMVARS_SEGMENT
128 pop ds
129 %endif
130 ret
131%endif
132
133ALIGN JUMP_ALIGN
134.GetStolenSegmentToDS:
135 LOAD_BDA_SEGMENT_TO ds, di
136 mov di, [BDA.wBaseMem] ; Load available base memory size in kB
137 eSHL_IM di, 6 ; Segment to first stolen kB (*=40h)
138ALIGN JUMP_ALIGN
139.LoopStolenKBs:
140 mov ds, di ; EBDA segment to DS
141 add di, BYTE 64 ; DI to next stolen kB
142 cmp WORD [RAMVARS.wSignature], RAMVARS_RAM_SIGNATURE
143 jne SHORT .LoopStolenKBs ; Loop until sign found (always found eventually)
144 ret
145
146
147;--------------------------------------------------------------------
148; RamVars_GetHardDiskCountFromBDAtoAX
149; Parameters:
150; DS: RAMVARS segment
151; Returns:
152; AX: Total hard disk count
153; Corrupts registers:
154; BX
155;--------------------------------------------------------------------
156%ifdef MODULE_BOOT_MENU
157RamVars_GetHardDiskCountFromBDAtoAX:
158 call RamVars_GetCountOfKnownDrivesToAX
159 push ds
160 LOAD_BDA_SEGMENT_TO ds, bx
161 mov bl, [BDA.bHDCount]
162 MAX_U al, bl
163 pop ds
164 ret
165%endif
166
167
168;--------------------------------------------------------------------
169; RamVars_GetCountOfKnownDrivesToAX
170; Parameters:
171; DS: RAMVARS segment
172; Returns:
173; AX: Total hard disk count
174; Corrupts registers:
175; None
176;--------------------------------------------------------------------
177ALIGN JUMP_ALIGN
178RamVars_GetCountOfKnownDrivesToAX:
179 mov ax, [RAMVARS.wFirstDrvAndCount]
180 add al, ah
181 and ax, BYTE 7fh
182 ret
183
184;--------------------------------------------------------------------
185; RamVars_GetIdeControllerCountToCX
186; Parameters:
187; Nothing
188; Returns:
189; CX: Number of IDE controllers to handle
190; Corrupts registers:
191; Nothing
192;--------------------------------------------------------------------
193ALIGN JUMP_ALIGN
194RamVars_GetIdeControllerCountToCX:
195 eMOVZX cx, [cs:ROMVARS.bIdeCnt]
196 ret
197
198
199%ifdef MODULE_SERIAL_FLOPPY
200;--------------------------------------------------------------------
201; RamVars_UnpackFlopCntAndFirstToAL
202; Parameters:
203; DS: RAMVARS segment
204; Returns:
205; AL: First floppy drive number supported
206; CF: Number of floppy drives supported (clear = 1, set = 2)
207; SF: Emulating drives (clear = yes, set = no)
208; Corrupts registers:
209; Nothing
210;--------------------------------------------------------------------
211ALIGN JUMP_ALIGN
212RamVars_UnpackFlopCntAndFirstToAL:
213 mov al, [RAMVARS.xlateVars+XLATEVARS.bFlopCntAndFirst]
214 sar al, 1
215 ret
216%endif
217
218
219%if 0 ; unused...
220;--------------------------------------------------------------------
221; RamVars_IsDriveDetectionInProgress
222; Parameters:
223; DS: RAMVARS segment
224; Returns:
225; ZF: Set if drive detection is in progress (ROM initialization)
226; Corrupts registers:
227; None
228;--------------------------------------------------------------------
229RamVars_IsDriveDetectionInProgress:
230 cmp WORD [RAMVARS.wSignature], RAMVARS_DRV_DETECT_SIGNATURE
231 ret
232%endif
Note: See TracBrowser for help on using the repository browser.