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

Last change on this file since 594 was 594, checked in by aitotat, 6 years ago

Previosly committed flash fix for configurator was incomplete. Now fixed properly.
Added MODULE_MFM_COMPATIBILITY.

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