]> 4ch.mooo.com Git - 16.git/blob - src/lib/16_mm.h
pcxtest0 for planar dump test
[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 "src/lib/16_head.h"
27 #include "src/lib/16_hc.h"
28 //#include "src/lib/modex16.h"
29 //++++mh        #include "src/lib/16_in.h"
30
31 #ifdef __DEBUG__                // 1 == Debug/Dev  ;  0 == Production/final
32 #define OUT_OF_MEM_MSG  "MM_GetPtr: Out of memory!\nYou were short :%lu bytes\n"
33 #else
34 #define OUT_OF_MEM_MSG  "\npee\n"
35 #endif
36
37 //#define GETNEWBLOCK {if(!(mmnew=mmfree))Quit("MM_GETNEWBLOCK: No free blocks!") ;mmfree=mmfree->next;}
38 #define GETNEWBLOCK {if(!mm->mmfree)MML_ClearBlock(mm);mm->mmnew=mm->mmfree;mm->mmfree=mm->mmfree->next;}
39
40 #define FREEBLOCK(x) {*x->useptr=NULL;x->next=mm->mmfree;mm->mmfree=x;}
41
42 #define SAVENEARHEAP    0x200           // space to leave in data segment
43 #define SAVEFARHEAP     0//x400                 // space to leave in far heap
44
45 #define BUFFERSIZE              0x1000          // miscelanious, allways available buffer
46
47 #define MAXBLOCKS               1024
48
49
50
51 //--------
52
53 #define EMS_INT                 0x67
54
55 #define EMS_STATUS              0x40
56 #define EMS_GETFRAME    0x41
57 #define EMS_GETPAGES    0x42
58 #define EMS_ALLOCPAGES  0x43
59 #define EMS_MAPPAGE             0x44
60 #define EMS_MAPXPAGE            0x50
61 #define EMS_FREEPAGES   0x45
62 #define EMS_VERSION             0x46
63
64 //--------
65
66 #define XMS_VERSION             0x00
67
68 #define XMS_ALLOCHMA    0x01
69 #define XMS_FREEHMA             0x02
70
71 #define XMS_GENABLEA20  0x03
72 #define XMS_GDISABLEA20 0x04
73 #define XMS_LENABLEA20  0x05
74 #define XMS_LDISABLEA20 0x06
75 #define XMS_QUERYA20    0x07
76
77 #define XMS_QUERYREE    0x08
78 #define XMS_ALLOC               0x09
79 #define XMS_FREE                0x0A
80 #define XMS_MOVE                0x0B
81 #define XMS_LOCK                0x0C
82 #define XMS_UNLOCK              0x0D
83 #define XMS_GETINFO             0x0E
84 #define XMS_RESIZE              0x0F
85
86 #define XMS_ALLOCUMB    0x10
87 #define XMS_FREEUMB             0x11
88
89 //==========================================================================
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                4//mm->EMSpagesmapped
119
120 typedef struct mmblockstruct
121 {
122         word    start,length;
123         //word  start;  dword length;
124         word    blob;   //for data larger than 64k
125         unsigned        attributes;
126         memptr          *useptr;        // pointer to the segment start
127         //huge struct mmblockstruct huge *next;
128         struct mmblockstruct far *next;
129 } mmblocktype;
130
131
132 typedef struct
133 {
134         memptr bufferseg;
135         boolean         mmstarted, bombonerror, mmerror;
136         //huge void huge        *farheap;
137         void far        *farheap;
138 #ifdef __BORLANDC__
139         void    *nearheap;
140 #endif
141 #ifdef __WATCOMC__
142         void __near     *nearheap;
143 #endif
144         //byte          EMS_status;
145         unsigned        totalEMSpages,freeEMSpages,EMSpageframe,EMSpagesmapped,EMShandle;
146         unsigned int EMSVer;
147         word numUMBs,UMBbase[MAXUMBS];
148         //dword numUMBs,UMBbase[MAXUMBS];
149         //huge mmblocktype      huge mmblocks[MAXBLOCKS],huge *mmhead,huge *mmfree,huge *mmrover,huge *mmnew;
150         mmblocktype     far mmblocks[MAXBLOCKS],far *mmhead,far *mmfree,far *mmrover,far *mmnew;
151 } mminfo_t;
152
153 /*
154 =============================================================================
155
156                                                  GLOBAL VARIABLES
157
158 =============================================================================
159 */
160
161
162 /*
163 =============================================================================
164
165                                                  LOCAL VARIABLES
166
167 =============================================================================
168 */
169
170 //==========================================================================
171
172 boolean MML_CheckForEMS(void);
173 byte MML_SetupEMS(mminfo_t *mm);
174 void MML_ShutdownEMS(mminfo_t *mm);
175 byte MM_MapEMS(mminfo_t *mm, mminfotype *mmi);
176 byte MM_MapXEMS(mminfo_t *mm, mminfotype *mmi);
177 boolean MML_CheckForXMS(mminfo_t *mm);
178 void MML_SetupXMS(mminfo_t *mm, mminfotype *mmi);
179 void MML_ShutdownXMS(mminfo_t *mm);
180 void MML_UseSpace(word segstart, dword seglength, mminfo_t *mm);
181 void MML_ClearBlock(mminfo_t *mm);
182
183 void MM_Startup(mminfo_t *mm, mminfotype *mmi);
184 void MM_Shutdown(mminfo_t *mm);
185
186 void MM_GetPtr(memptr *baseptr,dword size, mminfo_t *mm, mminfotype *mmi);
187 void MM_FreePtr(memptr *baseptr, mminfo_t *mm);
188 void MM_SetPurge(memptr *baseptr, int purge, mminfo_t *mm);
189 void MM_SetLock(memptr *baseptr, boolean locked, mminfo_t *mm);
190 void MM_SortMem(mminfo_t *mm);
191 void MM_ShowMemory(global_game_variables_t *gvar,/*page_t *page, */mminfo_t *mm);
192 void MM_DumpData(mminfo_t *mm);
193 dword MM_UnusedMemory(mminfo_t *mm);
194 dword MM_TotalFree(mminfo_t *mm);
195 void MM_Report(/*page_t *page, */mminfo_t *mm, mminfotype *mmi);
196 static void MM_EMSerr(byte *stri, byte err);
197 void MM_BombOnError(boolean bomb, mminfo_t *mm);
198 //void MM_GetNewBlock(mminfo_t *mm);
199 //void MM_FreeBlock(mmblocktype *x, mminfo_t *mm);
200
201 //==========================================================================
202
203 #endif