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

Last change on this file since 401 was 400, checked in by aitotat@…, 13 years ago

Changes to XTIDE Universal BIOS:

  • Moved 8-bit device support to MODULE_8BIT_IDE.
  • JR-IDE/ISA support requires a lot less bytes.
  • AT builds now always use full operating mode.
File size: 3.6 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
25LITE_MODE_RAMVARS_SEGMENT EQU 30h
26%endif
27
28
29; Variables for translating drive numbers.
30struc XLATEVARS
31%ifdef MODULE_SERIAL_FLOPPY
32 .bFlopCreateCnt:
33 .bFlopCntAndFirst resb 1 ; Normally, packed starting floppy drive number (high order 7 bits)
34 ; and number of drives (low order bit, max 2 drives supported).
35 ; During initialization, until the end of DetectDrives_FromAllIDEControllers,
36 ; this byte contains the raw number of floppy drives seen (using .bFlopCreateCnt)
37%else
38 resb 1 ; alignment
39%endif
40 .bXlatedDrv resb 1 ; Drive number after translation
41 .wFDandHDswap:
42 .bFDSwap resb 1 ; Floppy Drive to swap to 00h and vice versa
43 .bHDSwap resb 1 ; Hard Drive to swap to 80h and vice versa
44endstruc
45
46; RAM Variables.
47; Variables should be kept to minimum since they might be located
48; at the top of interrupt vectors.
49struc RAMVARS
50 .fpOldI13h resb 4 ; Far pointer to old INT 13h handler
51 .wSignature resb 2 ; Sign for finding stolen 1 kiB
52 .bTimeoutTicksLeft resb 1
53 .bLastTimeoutUpdate resb 1
54
55 .wDrvCntAndFirst:
56 .bFirstDrv resb 1 ; Number of first drive for this BIOS
57 .wDrvCntAndFlopCnt: ; Both the hard disk and floppy counts in one word
58 ; (yes, misaligned, but it is only used this way during initialization)
59 .bDrvCnt resb 1 ; Number of drives handled by this BIOS
60
61 ; Variables for drive number translation
62 .xlateVars resb XLATEVARS_size
63endstruc
64
65%ifdef MODULE_SERIAL_FLOPPY
66 %ifndef CHECK_FOR_UNUSED_ENTRYPOINTS
67 %if RAMVARS.xlateVars != RAMVARS.bDrvCnt+1 || XLATEVARS.bFlopCreateCnt != 0
68 %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"
69 %endif
70 %endif
71%endif
72
73RAMVARS_SIGNATURE EQU "Xu" ; RAMVARS signature for .wSignature
74
75;
76; IDEPACK NOTE: The first six bytes of this structure are directly put on the
77; wire for MODULE_SERIAL, please do not change the order or insert other members.
78;
79struc IDEPACK
80 .bFeatures resb 1
81 .bDrvAndHead resb 1 ; LBA28 27...24
82
83 .wSectorCountAndLbaLow:
84 .bSectorCount resb 1
85 .bSectorNumber:
86 .bLbaLow resb 1 ; LBA 7...0
87
88 .wCylinder:
89 .wLbaMiddleAndHigh:
90 .bLbaMiddle resb 1 ; LBA 15...8
91 .bLbaHigh resb 1 ; LBA 23...16
92
93 .bCommand resb 1
94 .bDeviceControl resb 1 ; Offset 7 shared with PIOVARS
95 resb 1
96
97 ; Parameters for 48-bit LBA
98 .bLbaLowExt resb 1 ; LBA48 31...24
99 .wLbaMiddleAndHighExt:
100 .bLbaMiddleExt resb 1 ; LBA48 39...32
101 .bLbaHighExt resb 1 ; LBA48 47...40
102
103 .intpack resb INTPACK_size
104endstruc
105
106EXTRA_BYTES_FOR_INTPACK EQU (IDEPACK_size - INTPACK_size)
107
108
109%endif ; RAMVARS_INC
Note: See TracBrowser for help on using the repository browser.