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

Last change on this file since 630 was 625, checked in by Krister Nordvall, 23 months ago

Changes:

  • Added a configuration option to let the BIOS store RamVars to an UMB when Full operating mode is enabled. This is primarily for XT class machines with RAM in the UMA (which apparently is a common thing these days).
  • Added two new builds specifically for IBM PS/2 machines. This is for support of the new McIDE adapter from the guys at zzxio.com. Note that the additional hardware specific code (under the USE_PS2 define) is for the PS/2 machines themselves and not for the McIDE adapters, so any controller in an IBM PS/2 machine can be used with the USE_PS2 define.
  • Moved pColorTheme out of the range of ROMVARS being copied over when doing "Load old settings from EEPROM" in XTIDECFG. This fixed a serious bug from r592 where loading a BIOS from file and then loading the old settings from ROM would corrupt 7 bytes of code somewhere in the loaded BIOS.
  • Optimizations (speed and size) to the library. Browsing the menus in XTIDECFG should now feel a little less sluggish.
  • Hopefully fixed a problem with the PostCommitHook script where it sometimes wouldn't find the CommitInProgress file. I say hopefully because testing this is a nightmare.
File size: 4.5 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-2023 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
24%ifdef MODULE_SERIAL_FLOPPY OR MODULE_DRIVEXLATE
25 %define NEED_XLATEVARS
26%endif
27
28
29%ifdef NEED_XLATEVARS
30; Variables for translating drive numbers.
31 struc XLATEVARS
32 %ifdef MODULE_SERIAL_FLOPPY
33 .bFlopCreateCnt:
34 .bFlopCntAndFirst resb 1 ; Normally, packed starting floppy drive number (high order 7 bits)
35 ; and number of drives (low order bit, max 2 drives supported).
36 ; During initialization, until the end of DetectDrives_FromAllIDEControllers,
37 ; this byte contains the raw number of floppy drives seen
38 ; (using .bFlopCreateCnt)
39 %else
40 resb 1 ; alignment
41 %endif
42
43 %ifdef MODULE_DRIVEXLATE
44 .bXlatedDrv resb 1 ; Drive number after translation
45 .wFDandHDswap:
46 .bFDSwap resb 1 ; Floppy Drive to swap to 00h and vice versa
47 .bHDSwap resb 1 ; Hard Drive to swap to 80h and vice versa
48 %else
49 resb 1 ; alignment
50 %endif
51 endstruc
52%endif
53
54
55; RAM Variables.
56; Variables should be kept to minimum since they might be located
57; at the top of interrupt vectors.
58struc RAMVARS
59%ifdef RELOCATE_INT13H_STACK
60 resb 252
61 .dwStackChangeDSDI:
62 .wStackChangeDI resb 2 ; Used during stack
63 .wStackChangeDS resb 2 ; switching only
64 .rgbTopOfStack: ; 256 bytes of stack
65 .fpInt13hEntryStack resb 4
66%endif
67%ifdef MODULE_MFM_COMPATIBILITY
68 .fpMFMint13h resb 4
69%endif
70 .fpOldI13h resb 4 ; Far pointer to old INT 13h handler
71 .wDrvDetectSignature resb 2 ; Signature when BIOS is in drive detection mode
72 .wSignature resb 2 ; Sign for finding stolen 1...64 kiB
73 .bTimeoutTicksLeft resb 1
74 .bLastTimeoutUpdate resb 1
75
76 .wFirstDrvAndCount:
77 .bFirstDrv resb 1 ; Number of first drive for this BIOS
78 .wDrvCntAndFlopCnt: ; Both the hard disk and floppy counts in one word
79 ; (yes, misaligned, but it is only used this way during initialization)
80 .bDrvCnt resb 1 ; Number of drives handled by this BIOS
81
82 ; Variables for drive number translation
83%ifdef NEED_XLATEVARS
84 .xlateVars resb XLATEVARS_size
85%endif
86endstruc
87
88; Note!!! .wDrvDetectSignature and .wSignature are intentionally in different locations.
89RAMVARS_RAM_SIGNATURE EQU "Xu" ; RAMVARS signature for .wSignature
90RAMVARS_DRV_DETECT_SIGNATURE EQU 5A5Ah ; Signature when BIOS is in drive detection mode
91
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 alignb 2 ; Keep the INTPACK structure and stack pointer WORD aligned
134
135 .intpack resb INTPACK_size
136endstruc
137
138SIZE_OF_IDEPACK_WITHOUT_INTPACK EQU (IDEPACK_size - INTPACK_size)
139
140
141%endif ; RAMVARS_INC
Note: See TracBrowser for help on using the repository browser.