]> 4ch.mooo.com Git - 16.git/blob - src/exmmtest.c
16_ca needs huge amounts of work and I should remember what needs to be done soon...
[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 <malloc.h>             // for _memavl()\r
26 #include "src/lib/16_head.h"\r
27 #include "src/lib/16_tail.h"\r
28 #include "src/lib/16_pm.h"\r
29 #include "src/lib/16_ca.h"\r
30 #include "src/lib/16_mm.h"\r
31 #include "src/lib/16_hc.h"\r
32 #include "src/lib/16_dbg.h"\r
33 \r
34 #pragma hdrstop\r
35 \r
36 #pragma warn -pro\r
37 #pragma warn -use\r
38 \r
39 //file load or read definition\r
40 #define FILEREADLOAD\r
41 #define FILEREAD\r
42 //#define EXMMVERBOSE\r
43 //#define BUFFDUMPPAUSE\r
44 //#define EXMMVERBOSE__\r
45 //      #define PRINTBBDUMP\r
46 #define BUFFDUMP\r
47 \r
48 #ifdef __BORLANDC__\r
49 #define NOVID\r
50 #endif\r
51 #ifdef __WATCOMC__\r
52 #define NOVID\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 NOVID\r
73 #ifdef __BORLANDC__\r
74 void VL_Startup (global_game_variables_t *gvar){ gvar=gvar; }\r
75 void VL_Shutdown (global_game_variables_t *gvar){ gvar=gvar; }\r
76 void VGAmodeX(sword vq, boolean cmem, global_game_variables_t *gv)\r
77 {\r
78         printf("VGAmodeX dummy:\n       %Fp     %Fp     %Fp\n", &vq, &cmem, gv);\r
79 }\r
80 \r
81 word modexPalOverscan(word col)\r
82 {\r
83         //modexWaitBorder();\r
84         outp(PAL_WRITE_REG, 0);  /* start at the beginning of palette */\r
85         outp(PAL_DATA_REG, col);\r
86         return col;\r
87 }\r
88 void    TL_VidInit(global_game_variables_t *gvar)\r
89 {\r
90         gvar->video.old_mode = 3;\r
91 }\r
92 #endif\r
93 \r
94 //printf("*     %Fp\t", *BBUF);\r
95 //printf("*          %04x\t", *BBUF);\r
96 #define PRINTBB {\\r
97         printf("-------------------------------------------------------------------------------\n");\\r
98         printf("&main()=        %Fp\n", argv[0]);\\r
99         printf("buffer:\n");\\r
100         printf("        %Fp\t", BBUF);\\r
101         printf("&%Fp\n", BBUFPTR);\\r
102         printf("             %04x\t", BBUF);\\r
103         printf("&     %04x\n", BBUFPTR);\\r
104         printf("-------------------------------------------------------------------------------\n");\\r
105 }\r
106         //printf("&main()=      %Fp\n", *argv[0]);\r
107         //printf("bigbuffer=    %Fp\n", bigbuffer);\r
108         //printf("&bigbuffer=   %Fp\n", &bigbuffer);\r
109         //printf("bigbuffer=    %04x\n", bigbuffer);\r
110         //printf("&bigbuffer=   %04x\n", &bigbuffer);\r
111 #ifdef __WATCOMC__\r
112 void segatesuto()\r
113 {\r
114         __segment screen;\r
115         char __based( void ) * scrptr;\r
116 \r
117         screen = 0xB800;\r
118         scrptr = 0;\r
119         printf( "Top left character is '%c'.\n", *(screen:>scrptr) );\r
120 //      printf("Next string is: [");\r
121 //      while(*scrptr<16)\r
122 //      {\r
123 //              printf("%c", *(screen:>scrptr));\r
124 //              //printf("\b");\r
125 //              scrptr++;\r
126 //\r
127 //      }\r
128 //      printf("]\n");\r
129 //      KEYP\r
130 }\r
131 #endif\r
132 \r
133 //===========================================================================//\r
134 \r
135 //=======================================//\r
136 \r
137 //      main\r
138 \r
139 //=======================================//\r
140 void\r
141 main(int argc, char *argv[])\r
142 {\r
143         byte w;\r
144         static global_game_variables_t gvar;\r
145                                                                 #ifdef INITBBUF\r
146         INITBBUF\r
147                                                                 #endif\r
148 #if 0\r
149 //#ifdef __WATCOMC__\r
150         __segment sega;\r
151 #endif\r
152         char bakapee1[64] = "data/koishi~.pcx";\r
153         char bakapee2[64] = "data/test.map";\r
154         word baka;\r
155 \r
156                 #ifdef __BORLANDC__\r
157                         argc=argc;\r
158                 #endif\r
159 \r
160                                                                 #ifdef PRINTBBDUMP\r
161                                                                 //0000PRINTBB; KEYP\r
162                                                                 #endif\r
163 #ifdef __16_PM__\r
164 #ifdef __DEBUG_PM__\r
165         dbg_debugpm=1;  //debug pm\r
166 #endif\r
167 #endif\r
168 #ifdef __DEBUG_CA__\r
169         dbg_debugca=1;\r
170 #endif\r
171 #ifdef __DEBUG_MM__\r
172         dbg_debugmm=1;\r
173 #endif\r
174 \r
175         if(argv[1]){ strcpy(bakapee1, argv[1]);//bakapee1[] = *argv[1];\r
176         if(argv[2]) strcpy(bakapee2, argv[2]); }//bakapee2[] = argv[2]; }\r
177 #if 0\r
178         else{\r
179         //{ printf("filename!: "); scanf("%[^\n]", &bakapee); }\r
180                 strcpy(bakapee1, "data/koishi~.pcx"); //bakapee1 = "data/koishi~.pcx";\r
181                 strcpy(bakapee2, "data/test.map"); //bakapee2 = "data/test.map";\r
182         }\r
183 #endif\r
184         printf("bakapee1[%s]\n", bakapee1);\r
185         printf("bakapee2[%s]\n", bakapee2);\r
186         KEYP\r
187 \r
188                                                                 #ifndef NOVID\r
189         Startup16(&gvar);\r
190         // save the palette\r
191         modexPalSave(&gvar.video.dpal); modexFadeOff(4, &gvar.video.dpal); //modexPalBlack();\r
192                                                                 #else //NOVID\r
193         StartupCAMMPM(&gvar);\r
194 /*      MM_Startup(&gvar);\r
195                                                                 #ifdef __16_PM__\r
196                                                                 #ifdef __DEBUG_PM__\r
197                                                                         if(dbg_debugpm>0)\r
198                                                                         {\r
199                                                                 #endif //__DEBUG_PM__\r
200         PM_Startup(&gvar); PM_CheckMainMem(&gvar); PM_UnlockMainMem(&gvar);\r
201                                                                 //0000printf("PM Started\n"); KEYP\r
202                                                                 #ifdef __DEBUG_PM__\r
203                                                                         }\r
204                                                                 #endif //__DEBUG_PM__\r
205                                                                 #endif //__16_PM__\r
206         CA_Startup(&gvar);*/\r
207                                                                 #endif //elsed NOVID\r
208                                                                 #ifdef PRINTBBDUMP\r
209                                                                 //0000\r
210 PRINTBB; KEYP\r
211                                                                 #endif\r
212 \r
213         w=0;\r
214                                                                 #ifdef FILEREADLOAD\r
215                                                                 #ifdef FILEREAD\r
216         for(;w<2;w++)\r
217         {\r
218         //      printf("size of big buffer~=%u\n", _bmsize(segu, BBUF));\r
219                 if(w>0)\r
220                 {\r
221                         printf("======================================read=====================================\n");\r
222                         if(CA_ReadFile(bakapee2, BBUFPTR, &gvar)) baka=1; else baka=0;\r
223                         printf("====================================read end===================================\n");\r
224                 }\r
225                                                                 #endif //FILEREAD\r
226                 if(w==0)\r
227                 {\r
228                         printf("======================================load=====================================\n");\r
229                         if(CA_LoadFile(bakapee1, BBUFPTR, &gvar)) baka=1; else baka=0;\r
230                         printf("====================================load end===================================\n");\r
231                 }\r
232                                                                 //#ifdef __WATCOMC__\r
233                                                                 //      printf("\nsize of big buffer~=%u\n", _bmsize(sega, BBUF));\r
234                                                                 //#endif\r
235                                                                 #ifdef BUFFDUMP\r
236                 printf("contents of the buffer\n[\n%s\n]\n", BBUFSTRING);\r
237                                                                 #endif// #else\r
238                                                                 #ifdef PRINTBBDUMP\r
239                 PRINTBB;\r
240                                                                 #endif\r
241 \r
242                                                                 //endif // BUFFDUMP\r
243 \r
244                 //printf("dark purple = purgable\n");\r
245                 //printf("medium blue = non purgable\n");\r
246                 //printf("red = locked\n");\r
247         //      KEYP\r
248         //      DebugMemory_(&gvar, 1);\r
249                 if(baka) printf("\nyay!\n");\r
250                 else printf("\npoo!\n");\r
251                                                                 #ifdef BUFFDUMPPAUSE\r
252                 KEYP\r
253                                                                 #endif\r
254                                                                 #ifdef FILEREAD\r
255         }\r
256                                                                 #endif\r
257                                                                 #endif  //filereadload\r
258 \r
259 #ifdef __WATCOMC__\r
260 #ifndef NOVID\r
261         VGAmodeX(8, 0, &gvar);\r
262 //      modexPalUpdate0(&gvar.video.palette);\r
263 //      ShapeTest_(&gvar);\r
264         MM_ShowMemory(&gvar);\r
265 #if 0\r
266         {\r
267         boolean                 done;\r
268         ScanCode                scan;\r
269         for (done = false;!done;)\r
270         {\r
271                 while (!(scan = gvar.in.inst->LastScan))\r
272                 {}\r
273         //                      SD_Poll();\r
274 \r
275                 IN_ClearKey(scan);\r
276                 switch (scan)\r
277                 {\r
278 //                      case sc_Space:\r
279 //                              MM_ShowMemory(&gvar);\r
280 //                      break;\r
281 //#ifdef __WATCOMC__\r
282                         case sc_O:\r
283                                 VL_modexPalScramble(&gvar.video.palette); modexpdump(&gvar.video.page);\r
284                         break;\r
285                         case sc_P:\r
286                                 modexpdump(&gvar.video.page[0]);\r
287                         break;\r
288                         case sc_V:\r
289                                 VL_PatternDraw(&gvar.video, 0, 1, 1);\r
290                         break;\r
291 //#endif\r
292                         default:\r
293                         case sc_Escape:\r
294                                 done = true;\r
295                         break;\r
296                 }\r
297         }\r
298 }\r
299 #endif\r
300         VGAmodeX(0, 0, &gvar);\r
301 #endif\r
302 #endif\r
303         MM_ShowMemory(&gvar);\r
304         DebugMemory_(&gvar, 1);\r
305         MM_DumpData(&gvar);\r
306         MM_Report_(&gvar);\r
307         //printf("bakapee1=%s\n", bakapee1);\r
308         //printf("bakapee2=%s\n", bakapee2);\r
309         MM_FreePtr(BBUFPTR, &gvar);\r
310                                                                 #ifndef NOVID\r
311         Shutdown16(&gvar);\r
312                                                                 #else //novid\r
313         ShutdownCAMMPM(&gvar);\r
314 /*                                                              #ifdef __16_PM__\r
315                                                                 #ifdef __DEBUG_PM__\r
316                                                                         if(dbg_debugpm>0)\r
317                                                                 #endif //__DEBUG_PM__\r
318         PM_Shutdown(&gvar);\r
319                                                                 #endif //__16_PM__\r
320         CA_Shutdown(&gvar);\r
321         MM_Shutdown(&gvar);*/\r
322                                                                 #endif //NOVID\r
323         IN_Shutdown(&gvar);\r
324         printf("========================================\n");\r
325         printf("near=   %Fp ",  gvar.mm.nearheap);\r
326         printf("far=    %Fp",                   gvar.mm.farheap);\r
327         printf("\n");\r
328         printf("&near=  %Fp ",  &(gvar.mm.nearheap));\r
329         printf("&far=   %Fp",           &(gvar.mm.farheap));\r
330         printf("\n");\r
331                                                                 #ifdef EXMMVERBOSE\r
332         printf("bigb=   %Fp ",  BBUF);\r
333         //printf("bigbr=        %04x",  BBUF);\r
334         //printf("\n");\r
335         printf("&bigb=%Fp ",            BBUFPTR);\r
336         //printf("&bigb=%04x",          BBUFPTR);\r
337         printf("\n");\r
338                                                                 #endif\r
339         printf("========================================\n");\r
340 \r
341                                                                 #ifdef EXMMVERBOSE__\r
342         printf("coreleft():                     %u\n", _memavl());\r
343         printf("farcoreleft():                  %lu\n", (dword)HC_farcoreleft());\r
344                                                                 #endif\r
345 #ifdef __WATCOMC__\r
346 //this is far   printf("Total free:                     %lu\n", (dword)(HC_GetFreeSize()));\r
347 //super buggy   printf("HC_coreleft():                  %u\n", HC_coreleft());\r
348 //      printf("HC_farcoreleft():                       %lu\n", (dword)HC_farcoreleft());\r
349         //printf("HC_GetNearFreeSize():         %u\n", HC_GetNearFreeSize());\r
350         //printf("HC_GetFarFreeSize():                  %lu\n", (dword)HC_GetFarFreeSize());\r
351         HC_heapdump(&gvar);\r
352 //      segatesuto();\r
353 #endif\r
354 /*#ifdef __BORLANDC__\r
355         //printf("core left:                    %lu\n", (dword)HC_coreleft());\r
356         //printf("far core left:                        %lu\n", (dword)HC_farcoreleft());\r
357 //      printf("\nfarcoreleft():                        %lu\n", farcoreleft());\r
358 #endif*/\r
359         printf("Project 16 ");\r
360 #ifdef __WATCOMC__\r
361         printf("exmmtest");\r
362 #endif\r
363 #ifdef __BORLANDC__\r
364         printf("bcexmm");\r
365 #endif\r
366         printf(".exe. This is just a test file!\n");\r
367         printf("version %s\n", VERSION);\r
368 \r
369 //end of program\r
370 \r
371 \r
372 #if defined(__DEBUG__) && ( defined(__DEBUG_PM__) || defined(__DEBUG_MM__) )\r
373 #ifdef __DEBUG_MM__\r
374         printf("debugmm: %u\t", dbg_debugmm);\r
375 #endif\r
376 #ifdef __DEBUG_PM__\r
377         printf("debugpm: %u", dbg_debugpm);\r
378 #endif\r
379         printf("\n");\r
380 #endif\r
381 //      printf("curr_mode=%u\n", gvar.video.curr_mode);\r
382 //      VL_PrintmodexmemInfo(&gvar.video);\r
383         //printf("old_mode=%u   VL_Started=%u", gvar.video.old_mode, gvar.video.VL_Started);\r
384         //printf("based core left:                      %lu\n", (dword)_basedcoreleft());\r
385         //printf("huge core left:                       %lu\n", (dword)_hugecoreleft());\r
386 }\r