]> 4ch.mooo.com Git - 16.git/blob - src/lib/16_mm.h
==major fixing?==
[16.git] / src / lib / 16_mm.h
1 /* Catacomb Apocalypse Source Code
2  * Copyright (C) 1993-2014 Flat Rock Software
3  *
4  * This program is free software; you can redistribute it and/or modify
5  * it under the terms of the GNU General Public License as published by
6  * the Free Software Foundation; either version 2 of the License, or
7  * (at your option) any later version.
8  *
9  * This program is distributed in the hope that it will be useful,
10  * but WITHOUT ANY WARRANTY; without even the implied warranty of
11  * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
12  * GNU General Public License for more details.
13  *
14  * You should have received a copy of the GNU General Public License along
15  * with this program; if not, write to the Free Software Foundation, Inc.,
16  * 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301 USA.
17  */
18
19 // ID_MM.H
20
21 #ifndef __16_EXMM__
22 #define __16_EXMM__
23
24 #include <string.h>
25 #include <malloc.h>
26 //#include <bios.h>
27 #include "src/lib/16_head.h"
28 #include "src/lib/modex16.h"
29 //#include "src/lib/16_ca.h"
30 //++++mh        #include "src/lib/16_in.h"
31
32 #ifdef __DEBUG__                // 1 == Debug/Dev  ;  0 == Production/final
33 #define OUT_OF_MEM_MSG  "MM_GetPtr: Out of memory!\nYou were short :%ld bytes"
34 #else
35 #define OUT_OF_MEM_MSG  "\npee\n"
36 #endif
37
38
39 #define SAVENEARHEAP    0x4000          // space to leave in data segment
40 #define SAVEFARHEAP             0                       // space to leave in far heap
41
42 #define BUFFERSIZE              0x8000          // miscelanious, allways available buffer
43
44 #define MAXBLOCKS               720
45
46
47
48 //--------
49
50 #define EMS_INT                 0x67
51
52 #define EMS_STATUS              0x40
53 #define EMS_GETFRAME    0x41
54 #define EMS_GETPAGES    0x42
55 #define EMS_ALLOCPAGES  0x43
56 #define EMS_MAPPAGE             0x44
57 #define EMS_MAPXPAGE            0x50
58 #define EMS_FREEPAGES   0x45
59 #define EMS_VERSION             0x46
60
61 //--------
62
63 #define XMS_VERSION             0x00
64
65 #define XMS_ALLOCHMA    0x01
66 #define XMS_FREEHMA             0x02
67
68 #define XMS_GENABLEA20  0x03
69 #define XMS_GDISABLEA20 0x04
70 #define XMS_LENABLEA20  0x05
71 #define XMS_LDISABLEA20 0x06
72 #define XMS_QUERYA20    0x07
73
74 #define XMS_QUERYREE    0x08
75 #define XMS_ALLOC               0x09
76 #define XMS_FREE                0x0A
77 #define XMS_MOVE                0x0B
78 #define XMS_LOCK                0x0C
79 #define XMS_UNLOCK              0x0D
80 #define XMS_GETINFO             0x0E
81 #define XMS_RESIZE              0x0F
82
83 #define XMS_ALLOCUMB    0x10
84 #define XMS_FREEUMB             0x11
85
86 //==========================================================================
87 //I hope this is correct!
88 //__segment                seg;
89 typedef void __based(__self) * memptr; //__based(seg) * memptr;
90
91 typedef struct
92 {
93         dword   nearheap,farheap,EMSmem,XMSmem,mainmem;
94 } mminfotype;
95
96 //==========================================================================
97
98 extern  void            (* beforesort) (void);
99 extern  void            (* aftersort) (void);
100 extern void             (* XMSaddr) (void);             // far pointer to XMS driver
101
102 //==========================================================================
103
104 /*
105 =============================================================================
106
107                                                         LOCAL INFO
108
109 =============================================================================
110 */
111
112 #define LOCKBIT         0x80    // if set in attributes, block cannot be moved
113 #define PURGEBITS       3               // 0-3 level, 0= unpurgable, 3= purge first
114 #define PURGEMASK       0xfffc
115 #define BASEATTRIBUTES  0       // unlocked, non purgable
116
117 #define MAXUMBS         12
118 #define MAPPAGES                mm->EMSpagesmapped
119
120 typedef struct mmblockstruct
121 {
122         word    start,length;
123         //dword start,length;
124         //word  start;
125         //dword length;
126         //byte segm;                            //how many 64kb segment blocks it takes up if there is many data!
127         unsigned        attributes;
128         memptr          *useptr;        // pointer to the segment start
129         struct mmblockstruct huge *next;
130 } mmblocktype;
131
132
133 typedef struct
134 {
135         memptr bufferseg;
136         boolean         mmstarted, bombonerror, mmerror;
137         void huge       *farheap;
138         void            *nearheap;
139         //byte          EMS_status;
140         unsigned        totalEMSpages,freeEMSpages,EMSpageframe,EMSpagesmapped,EMShandle;
141         unsigned int EMSVer;
142         word numUMBs,UMBbase[MAXUMBS];
143         //dword numUMBs,UMBbase[MAXUMBS];
144         mmblocktype     huge mmblocks[MAXBLOCKS],huge *mmhead,huge *mmfree,huge *mmrover,huge *mmnew;
145 } mminfo_t;
146
147 /*
148 =============================================================================
149
150                                                  GLOBAL VARIABLES
151
152 =============================================================================
153 */
154
155
156 /*
157 =============================================================================
158
159                                                  LOCAL VARIABLES
160
161 =============================================================================
162 */
163
164 //==========================================================================
165
166 boolean MML_CheckForEMS(void);
167 byte MML_SetupEMS(mminfo_t *mm);
168 void MML_ShutdownEMS(mminfo_t *mm);
169 byte MM_MapEMS(mminfo_t *mm, mminfotype *mmi);
170 byte MM_MapXEMS(mminfo_t *mm, mminfotype *mmi);
171 boolean MML_CheckForXMS(mminfo_t *mm);
172 void MML_SetupXMS(mminfo_t *mm, mminfotype *mmi);
173 void MML_ShutdownXMS(mminfo_t *mm);
174 void MML_UseSpace(/*d*/word segstart, dword seglength, mminfo_t *mm);
175 void MML_ClearBlock(mminfo_t *mm);
176
177 void MM_Startup(mminfo_t *mm, mminfotype *mmi);
178 void MM_Shutdown(mminfo_t *mm);
179
180 void MM_GetPtr(memptr *baseptr,dword size, mminfo_t *mm, mminfotype *mmi);
181 void MM_FreePtr(memptr *baseptr, mminfo_t *mm);
182 void MM_SetPurge(memptr *baseptr, int purge, mminfo_t *mm);
183 void MM_SetLock(memptr *baseptr, boolean locked, mminfo_t *mm);
184 void MM_SortMem(mminfo_t *mm);
185 void MM_ShowMemory(page_t *page, mminfo_t *mm);
186 void MM_DumpData(mminfo_t *mm);
187 dword MM_UnusedMemory(mminfo_t *mm);
188 dword MM_TotalFree(mminfo_t *mm);
189 void MM_Report(page_t *page, mminfo_t *mm, mminfotype *mmi);
190 static void MM_EMSerr(byte *stri, byte err);
191 void MM_BombOnError(boolean bomb, mminfo_t *mm);
192 void MM_GetNewBlock(mminfo_t *mm);
193 void MM_FreeBlock(mmblocktype *x, mminfo_t *mm);
194
195 //==========================================================================
196
197 #endif