OSDN Git Service

FIXED farcoreleft() is a VERY important part of the farheap of MM. it is much larger...
[proj16/16.git] / src / exmmtest.c
1 /* Project 16 Source Code~\r
2  * Copyright (C) 2012-2017 sparky4 & pngwen & andrius4669 & joncampbell123 & yakui-lover\r
3  *\r
4  * This file is part of Project 16.\r
5  *\r
6  * Project 16 is free software; you can redistribute it and/or modify\r
7  * it under the terms of the GNU General Public License as published by\r
8  * the Free Software Foundation; either version 3 of the License, or\r
9  * (at your option) any later version.\r
10  *\r
11  * Project 16 is distributed in the hope that it will be useful,\r
12  * but WITHOUT ANY WARRANTY; without even the implied warranty of\r
13  * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the\r
14  * GNU General Public License for more details.\r
15  *\r
16  * You should have received a copy of the GNU General Public License\r
17  * along with this program.  If not, see <http://www.gnu.org/licenses/>, or\r
18  * write to the Free Software Foundation, Inc., 51 Franklin Street,\r
19  * Fifth Floor, Boston, MA 02110-1301 USA.\r
20  *\r
21  */\r
22 /*\r
23         exmm test\r
24 */\r
25 #include "src/lib/16_head.h"\r
26 #include "src/lib/16_tail.h"\r
27 #include "src/lib/16_pm.h"\r
28 #include "src/lib/16_ca.h"\r
29 #include "src/lib/16_mm.h"\r
30 #include "src/lib/16_hc.h"\r
31 #include "src/lib/16_dbg.h"\r
32 \r
33 #pragma hdrstop\r
34 \r
35 #pragma warn -pro\r
36 #pragma warn -use\r
37 \r
38 //file load or read definition\r
39 #define FILEREADLOAD\r
40 #define FILEREAD\r
41 //#define EXMMVERBOSE\r
42 //#define BUFFDUMPPAUSE\r
43 //#define EXMMVERBOSE__\r
44 //      #define PRINTBBDUMP\r
45 #define BUFFDUMP\r
46 \r
47 #ifdef __BORLANDC__\r
48 #define NOVID\r
49 #endif\r
50 #ifdef __WATCOMC__\r
51 #define NOVID\r
52 //#define                       SCROLLLOAD\r
53 #endif\r
54 \r
55 \r
56 #define KEYP IN_Shutdown(&gvar); printf("\n\npress any key to continue!\n"); getch(); IN_Startup(&gvar);\r
57 \r
58 #define BBUFNAME gvar.mm.bufferseg//bigbuffer\r
59 //#define INITBBUF static memptr BBUFNAME;\r
60 #define BBUFPTR MEMPTRCONV BBUFNAME\r
61 \r
62 #ifdef __BORLANDC__\r
63 #define BBUF            (memptr *)BBUFPTR\r
64 #define BBUFSTRING      (memptr *)BBUFNAME\r
65 #endif\r
66 #ifdef __WATCOMC__\r
67 #define BBUF            BBUFNAME\r
68 #define BBUFSTRING      BBUF\r
69 #endif\r
70 \r
71 ////////////////////////////////////////////////////////////////////////////\r
72 #ifdef __BORLANDC__\r
73 void VL_Startup (global_game_variables_t *gvar){ gvar=gvar; }\r
74 void VL_Shutdown (global_game_variables_t *gvar){ gvar=gvar; }\r
75 void VGAmodeX(sword vq, boolean cmem, global_game_variables_t *gv)\r
76 {\r
77         printf("VGAmodeX dummy:\n       %Fp     %Fp     %Fp\n", &vq, &cmem, gv);\r
78 }\r
79 \r
80 word modexPalOverscan(word col)\r
81 {\r
82         //modexWaitBorder();\r
83         outp(PAL_WRITE_REG, 0);  /* start at the beginning of palette */\r
84         outp(PAL_DATA_REG, col);\r
85         return col;\r
86 }\r
87 void    TL_VidInit(global_game_variables_t *gvar)\r
88 {\r
89         gvar->video.old_mode = 3;\r
90 }\r
91 #endif\r
92 \r
93 //printf("*     %Fp\t", *BBUF);\r
94 //printf("*          %04x\t", *BBUF);\r
95 #define PRINTBB {\\r
96         printf("-------------------------------------------------------------------------------\n");\\r
97         printf("&main()=        %Fp\n", argv[0]);\\r
98         printf("buffer:\n");\\r
99         printf("        %Fp\t", BBUF);\\r
100         printf("&%Fp\n", BBUFPTR);\\r
101         printf("             %04x\t", BBUF);\\r
102         printf("&     %04x\n", BBUFPTR);\\r
103         printf("-------------------------------------------------------------------------------\n");\\r
104 }\r
105         //printf("&main()=      %Fp\n", *argv[0]);\r
106         //printf("bigbuffer=    %Fp\n", bigbuffer);\r
107         //printf("&bigbuffer=   %Fp\n", &bigbuffer);\r
108         //printf("bigbuffer=    %04x\n", bigbuffer);\r
109         //printf("&bigbuffer=   %04x\n", &bigbuffer);\r
110 #ifdef __WATCOMC__\r
111 void segatesuto()\r
112 {\r
113         __segment screen;\r
114         char __based( void ) * scrptr;\r
115 \r
116         screen = 0xB800;\r
117         scrptr = 0;\r
118         printf( "Top left character is '%c'.\n", *(screen:>scrptr) );\r
119 //      printf("Next string is: [");\r
120 //      while(*scrptr<16)\r
121 //      {\r
122 //              printf("%c", *(screen:>scrptr));\r
123 //              //printf("\b");\r
124 //              scrptr++;\r
125 //\r
126 //      }\r
127 //      printf("]\n");\r
128 //      KEYP\r
129 }\r
130 #endif\r
131 \r
132 #ifdef SCROLLLOAD\r
133 #define FILENAME_1      "data/spri/chikyuu.vrs"\r
134 #define FILENAME_2      "data/test.map"\r
135 #else\r
136 #define FILENAME_1      "data/koishi~.pcx"\r
137 #define FILENAME_2      "data/test.map"\r
138 #endif\r
139 \r
140 //===========================================================================//\r
141 \r
142 //=======================================//\r
143 \r
144 //      main\r
145 \r
146 //=======================================//\r
147 void\r
148 main(int argc, char *argv[])\r
149 {\r
150         static global_game_variables_t gvar;\r
151                                                                 #ifdef INITBBUF\r
152         INITBBUF\r
153                                                                 #endif\r
154 \r
155         char bakapee1[64] = FILENAME_1;\r
156         char bakapee2[64] = FILENAME_2;\r
157 \r
158                 #ifdef __BORLANDC__\r
159                         argc=argc;\r
160                 #endif\r
161 \r
162                                                                 #ifdef PRINTBBDUMP\r
163                                                                 //0000PRINTBB; KEYP\r
164                                                                 #endif\r
165 #ifdef __16_PM__\r
166 #ifdef __DEBUG_PM__\r
167         dbg_debugpm=1;  //debug pm\r
168 #endif\r
169 #endif\r
170 #ifdef __DEBUG_CA__\r
171         dbg_debugca=1;\r
172 #endif\r
173 #ifdef __DEBUG_MM__\r
174         dbg_debugmm=1;\r
175 #endif\r
176 \r
177         if(argv[1]){ strcpy(bakapee1, argv[1]);//bakapee1[] = *argv[1];\r
178         if(argv[2]) strcpy(bakapee2, argv[2]); }//bakapee2[] = argv[2]; }\r
179 \r
180         printf("bakapee1[%s]\n", bakapee1);\r
181         printf("bakapee2[%s]\n", bakapee2);\r
182         KEYP\r
183 \r
184                                                                 #ifndef NOVID\r
185         Startup16(&gvar);\r
186         // save the palette\r
187         modexPalSave(&gvar.video.dpal); //modexFadeOff(4, &gvar.video.dpal); //modexPalBlack();\r
188                                                                 #else //NOVID\r
189         StartupCAMMPM(&gvar);\r
190                                                                 #endif //elsed NOVID\r
191                                                                 #ifdef PRINTBBDUMP\r
192                                                                 //0000\r
193 PRINTBB; KEYP\r
194                                                                 #endif\r
195 \r
196         IN_Default(0,&gvar.player[0],ctrl_Keyboard1, &gvar);\r
197         IN_SetControlType(&gvar.player[0],ctrl_Keyboard1);\r
198 \r
199         {\r
200         byte w; word baka;\r
201         w=0;\r
202                                                                 #ifdef FILEREADLOAD\r
203                                                                 #ifdef FILEREAD\r
204         for(;w<2;w++)\r
205         {\r
206         //      printf("size of big buffer~=%u\n", _bmsize(segu, BBUF));\r
207                 if(w>0)\r
208                 {\r
209                         printf("======================================read=====================================\n");\r
210                         if(CA_ReadFile(bakapee2, BBUFPTR, &gvar)) baka=1; else baka=0;\r
211                         printf("====================================read end===================================\n");\r
212                 }\r
213                                                                 #endif //FILEREAD\r
214                 if(w==0)\r
215                 {\r
216                         printf("======================================load=====================================\n");\r
217                         if(CA_LoadFile(bakapee1, BBUFPTR, &gvar)) baka=1; else baka=0;\r
218                         printf("====================================load end===================================\n");\r
219                 }\r
220                                                                 #ifdef BUFFDUMP\r
221                 printf("contents of the buffer\n[\n%s\n]\n", BBUFSTRING);\r
222                                                                 #endif\r
223                                                                 #ifdef PRINTBBDUMP\r
224                 PRINTBB;\r
225                                                                 #endif\r
226 \r
227                 //printf("dark purple = purgable\n");\r
228                 //printf("medium blue = non purgable\n");\r
229                 //printf("red = locked\n");\r
230         //      KEYP\r
231         //      DebugMemory_(&gvar, 1);\r
232                 if(baka) printf("\nyay!\n");\r
233                 else printf("\npoo!\n");\r
234                                                                 #ifdef BUFFDUMPPAUSE\r
235                 KEYP\r
236                                                                 #endif\r
237                                                                 #ifdef FILEREAD\r
238         }\r
239                                                                 #endif\r
240                                                                 #endif  //filereadload\r
241         }\r
242 \r
243                                                         #ifdef SCROLLLOAD\r
244 //                                                      #else           //scrollload\r
245         CA_loadmap(bakapee2, &gvar.map, &gvar);\r
246 //      newloadmap(bakapee2, &gvar.map);\r
247         VRS_LoadVRS(bakapee1, &gvar.player[0].enti, &gvar);\r
248         HC_heapdump(&gvar);\r
249         KEYP\r
250                                                         #endif  //scrollload\r
251 \r
252 #ifndef NOVID\r
253         VL_Startup(&gvar);//    VGAmodeX(8, 0, &gvar);\r
254         modexHiganbanaPageSetup(&gvar);\r
255 //      VL_modexPalScramble(&gvar.video.palette);\r
256         VL_LoadPalFileCore(&gvar.video.palette, &gvar);\r
257 //      ShapeTest_(&gvar);\r
258 #endif\r
259         MM_ShowMemory(&gvar);\r
260 #if 0\r
261         {\r
262         boolean                 done;\r
263         ScanCode                scan;\r
264         for (done = false;!done;)\r
265         {\r
266                 while (!(scan = gvar.in.inst->LastScan))\r
267                 {}\r
268         //                      SD_Poll();\r
269 \r
270                 IN_ClearKey(scan);\r
271                 switch (scan)\r
272                 {\r
273 //                      case sc_Space:\r
274 //                              MM_ShowMemory(&gvar);\r
275 //                      break;\r
276 //#ifdef __WATCOMC__\r
277                         case sc_O:\r
278                                 VL_modexPalScramble(&gvar.video.palette); modexpdump(&gvar.video.page);\r
279                         break;\r
280                         case sc_P:\r
281                                 modexpdump(&gvar.video.page[0]);\r
282                         break;\r
283                         case sc_V:\r
284                                 VL_PatternDraw(&gvar.video, 0, 1, 1);\r
285                         break;\r
286 //#endif\r
287                         default:\r
288                         case sc_Escape:\r
289                                 done = true;\r
290                         break;\r
291                 }\r
292         }\r
293 }\r
294 #endif\r
295 #ifndef NOVID\r
296         if(gvar.video.VL_Started)\r
297                 VL_Shutdown (&gvar);//VGAmodeX(0, 0, gvar);\r
298         modexFadeOn(4, gvar.video.dpal);\r
299 #endif\r
300         DebugMemory_(&gvar, 1);\r
301         MM_DumpData(&gvar);\r
302         MM_Report_(&gvar);\r
303         //printf("bakapee1=%s\n", bakapee1);\r
304         //printf("bakapee2=%s\n", bakapee2);\r
305         MM_FreePtr(BBUFPTR, &gvar);\r
306                                                                 #ifndef NOVID\r
307         Shutdown16(&gvar);\r
308                                                                 #else //novid\r
309         ShutdownCAMMPM(&gvar);\r
310                                                                 #endif //NOVID\r
311         IN_Shutdown(&gvar);\r
312         printf("========================================\n");\r
313         printf("near=   %Fp ",  gvar.mm.nearheap);\r
314         printf("far=    %Fp",                   gvar.mm.farheap);\r
315         printf("\n");\r
316         printf("&near=  %Fp ",  &(gvar.mm.nearheap));\r
317         printf("&far=   %Fp",           &(gvar.mm.farheap));\r
318         printf("\n");\r
319                                                                 #ifdef EXMMVERBOSE\r
320         printf("bigb=   %Fp ",  BBUF);\r
321         //printf("bigbr=        %04x",  BBUF);\r
322         //printf("\n");\r
323         printf("&bigb=%Fp ",            BBUFPTR);\r
324         //printf("&bigb=%04x",          BBUFPTR);\r
325         printf("\n");\r
326                                                                 #endif\r
327         printf("========================================\n");\r
328 \r
329                                                                 #ifdef EXMMVERBOSE__\r
330         printf("coreleft():                     %u\n", coreleft());\r
331         printf("farcoreleft():                  %ld\n", farcoreleft());\r
332                                                                 #endif\r
333 #ifdef __WATCOMC__\r
334 //this is far   printf("Total free:                     %lu\n", (dword)(HC_GetFreeSize()));\r
335 //super buggy   printf("HC_coreleft():                  %u\n", HC_coreleft());\r
336 //      printf("HC_farcoreleft():                       %lu\n", (dword)HC_farcoreleft());\r
337         //printf("HC_GetNearFreeSize():         %u\n", HC_GetNearFreeSize());\r
338         //printf("HC_GetFarFreeSize():                  %lu\n", (dword)HC_GetFarFreeSize());\r
339         HC_heapdump(&gvar);\r
340 //      segatesuto();\r
341 #endif\r
342 #ifdef __BORLANDC__\r
343 //      printf("HC_coreleft:                    %lu\n", (dword)HC_coreleft());\r
344 //      printf("HC_farcoreleft:                 %lu\n", (dword)HC_farcoreleft());\r
345 //      printf("HC_Newfarcoreleft():            %lu\n", (dword)HC_Newfarcoreleft());\r
346 #endif\r
347         printf("Project 16 ");\r
348 #ifdef __WATCOMC__\r
349         printf("exmmtest");\r
350 #endif\r
351 #ifdef __BORLANDC__\r
352         printf("bcexmm");\r
353 #endif\r
354         printf(".exe. This is just a test file!\n");\r
355         printf("version %s\n", VERSION);\r
356 \r
357 //end of program\r
358 \r
359 \r
360 #if defined(__DEBUG__) && ( defined(__DEBUG_PM__) || defined(__DEBUG_MM__) )\r
361 #ifdef __DEBUG_MM__\r
362         printf("debugmm: %u\t", dbg_debugmm);\r
363 #endif\r
364 #ifdef __DEBUG_PM__\r
365         printf("debugpm: %u", dbg_debugpm);\r
366 #endif\r
367         printf("\n");\r
368 #endif\r
369 //      printf("curr_mode=%u\n", gvar.video.curr_mode);\r
370 //      VL_PrintmodexmemInfo(&gvar.video);\r
371         //printf("old_mode=%u   VL_Started=%u", gvar.video.old_mode, gvar.video.VL_Started);\r
372         //printf("based core left:                      %lu\n", (dword)_basedcoreleft());\r
373         //printf("huge core left:                       %lu\n", (dword)_hugecoreleft());\r
374 }\r