source: xtideuniversalbios/trunk/XTIDE_Universal_BIOS/Inc/RamVars.inc @ 505

Last change on this file since 505 was 505, checked in by krille_n_@…, 11 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: 4.4 KB
Line 
1; Project name  :   XTIDE Universal BIOS
2; Description   :   RAMVARS struct containing BIOS variables stored in RAM.
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%ifndef RAMVARS_INC
21%define RAMVARS_INC
22
23; Segment when RAMVARS is stored to top of interrupt vectors.
24%ifndef USE_AT
25    LITE_MODE_RAMVARS_SEGMENT   EQU     30h
26%endif
27
28
29%ifdef MODULE_SERIAL_FLOPPY OR MODULE_DRIVEXLATE
30    %define NEED_XLATEVARS
31%endif
32
33
34; RAM Variables.
35; Variables should be kept to minimum since they might be located
36; at the top of interrupt vectors.
37struc RAMVARS
38%ifdef RELOCATE_INT13H_STACK
39    .fpInt13hEntryStack resb    4
40    .dwStackChangeDSDI:
41    .wStackChangeDI     resb    2
42    .wStackChangeDS     resb    2
43    .wNewStackOffset    resb    2
44%endif
45    .wDrvDetectSignature:           ; Signature when BIOS is in drive detection mode
46    .fpOldI13h          resb    4   ; Far pointer to old INT 13h handler
47    .wSignature         resb    2   ; Sign for finding stolen 1...64 kiB
48    .bTimeoutTicksLeft  resb    1
49    .bLastTimeoutUpdate resb    1
50
51    .wFirstDrvAndCount:
52    .bFirstDrv          resb    1   ; Number of first drive for this BIOS
53    .wDrvCntAndFlopCnt:             ; Both the hard disk and floppy counts in one word
54                                    ; (yes, misaligned, but it is only used this way during initialization)
55    .bDrvCnt            resb    1   ; Number of drives handled by this BIOS
56
57    ; Variables for drive number translation
58%ifdef NEED_XLATEVARS
59    .xlateVars          resb    XLATEVARS_size
60%endif
61endstruc
62
63; Note!!! .wDrvDetectSignature and .wSignature are intentionally in different locations.
64RAMVARS_RAM_SIGNATURE           EQU "Xu"    ; RAMVARS signature for .wSignature
65RAMVARS_DRV_DETECT_SIGNATURE    EQU 5A5Ah   ; Signature when BIOS is in drive detection mode
66
67
68%ifdef NEED_XLATEVARS
69; Variables for translating drive numbers.
70    struc XLATEVARS
71    %ifdef MODULE_SERIAL_FLOPPY
72        .bFlopCreateCnt:
73        .bFlopCntAndFirst   resb    1   ; Normally, packed starting floppy drive number (high order 7 bits)
74                                        ; and number of drives (low order bit, max 2 drives supported).
75                                        ; During initialization, until the end of DetectDrives_FromAllIDEControllers,
76                                        ; this byte contains the raw number of floppy drives seen
77                                        ; (using .bFlopCreateCnt)
78    %else
79                            resb    1   ; alignment
80    %endif
81
82    %ifdef MODULE_DRIVEXLATE
83        .bXlatedDrv         resb    1   ; Drive number after translation
84        .wFDandHDswap:
85        .bFDSwap            resb    1   ; Floppy Drive to swap to 00h and vice versa
86        .bHDSwap            resb    1   ; Hard Drive to swap to 80h and vice versa
87    %else
88                            resb    1   ; alignment
89    %endif
90    endstruc
91%endif
92
93%ifdef MODULE_SERIAL_FLOPPY
94  %ifndef CHECK_FOR_UNUSED_ENTRYPOINTS
95    %if RAMVARS.xlateVars != RAMVARS.bDrvCnt+1 || XLATEVARS.bFlopCreateCnt != 0
96        %error "bFlopCreateCnt needs to be the first thing in XLATEVARS, and .xlateVars needs to come immediately after .bDrvCnt.  In at least one place, we read .wDrvCntAndFlopCnt to get both counts in one fetch"
97    %endif
98  %endif
99%endif
100
101
102
103;
104; IDEPACK NOTE: The first six bytes of this structure are directly put on the
105; wire for MODULE_SERIAL, please do not change the order or insert other members.
106;
107struc IDEPACK   ; PIOVARS and MEMPIOVARS overwrite the first 7 bytes
108    .bFeatures              resb    1
109    .bDrvAndHead            resb    1   ; LBA28 27...24
110
111    .wSectorCountAndLbaLow:
112    .bSectorCount           resb    1
113    .bSectorNumber:
114    .bLbaLow                resb    1   ; LBA 7...0
115
116    .wCylinder:
117    .wLbaMiddleAndHigh:
118    .bLbaMiddle             resb    1   ; LBA 15...8
119    .bLbaHigh               resb    1   ; LBA 23...16
120
121    .bCommand               resb    1
122    .bDeviceControl         resb    1   ; Offset 7 shared with PIOVARS and MEMPIOVARS
123                            resb    1   ; Used by PIOVARS and MEMPIOVARS
124
125%ifdef MODULE_EBIOS
126    ; Parameters for 48-bit LBA
127    .bLbaLowExt             resb    1   ; LBA48 31...24
128    .wLbaMiddleAndHighExt:
129    .bLbaMiddleExt          resb    1   ; LBA48 39...32
130    .bLbaHighExt            resb    1   ; LBA48 47...40
131%endif
132
133    .intpack                resb    INTPACK_size
134endstruc
135
136SIZE_OF_IDEPACK_WITHOUT_INTPACK     EQU (IDEPACK_size - INTPACK_size)
137
138
139%endif ; RAMVARS_INC
Note: See TracBrowser for help on using the repository browser.