OSDN Git Service

broken bcexmm broken
[proj16/16.git] / src / exmmtest.c
index 02fafeb..a7d9410 100755 (executable)
@@ -1,5 +1,5 @@
 /* Project 16 Source Code~\r
- * Copyright (C) 2012-2016 sparky4 & pngwen & andrius4669 & joncampbell123 & yakui-lover\r
+ * Copyright (C) 2012-2017 sparky4 & pngwen & andrius4669 & joncampbell123 & yakui-lover\r
  *\r
  * This file is part of Project 16.\r
  *\r
        exmm test\r
 */\r
 #include "src/lib/16_head.h"\r
+#include "src/lib/16_tail.h"\r
+//#ifdef __WATCOMC__\r
+#include "src/lib/16_pm.h"\r
+//#endif\r
 #include "src/lib/16_ca.h"\r
 #include "src/lib/16_mm.h"\r
 #include "src/lib/16_hc.h"\r
-//#include "src/lib/modex16.h"\r
+//#include "src/lib/16_vl.h"\r
 #pragma hdrstop\r
 \r
 #pragma warn -pro\r
 #define FILEREAD\r
 //#define EXMMVERBOSE\r
 \r
-#define PRINTBB { printf("&main()=     %Fp\n", argv[0]);printf("bigbuffer=     %Fp\n", bigbuffer);printf("&bigbuffer=  %Fp\n", &bigbuffer);printf("bigbuffer=  %04x\n", bigbuffer);printf("&bigbuffer= %04x\n", &bigbuffer); }\r
+void VGAmodeX(sword vq, boolean cmem, global_game_variables_t *gv)\r
+{\r
+       printf("VGAmodeX dummy:\n       %Fp     %Fp     %Fp\n", &vq, &cmem, gv);\r
+}\r
+#define PRINTBB { printf("&main()=     %Fp\n", argv[0]);printf("gvar.ca.tinf[0]=       %Fp\n", gvar.ca.tinf[0]);printf("&gvar.ca.tinf[0]=      %Fp\n", &gvar.ca.tinf[0]);printf("gvar.ca.tinf[0]=      %04x\n", gvar.ca.tinf[0]);printf("&gvar.ca.tinf[0]=     %04x\n", &gvar.ca.tinf[0]); }\r
 \r
 #ifdef __WATCOMC__\r
 void segatesuto()\r
@@ -60,17 +68,16 @@ void segatesuto()
 //     getch();\r
 }\r
 #endif\r
+//static global_game_variables_t gvar;\r
 \r
 void\r
 main(int argc, char *argv[])\r
 {\r
        byte w=1;\r
-       global_game_variables_t gvar;\r
-#ifdef __WATCOMC__\r
-       __segment sega;\r
-#endif\r
-       memptr bigbuffer;\r
-\r
+       static global_game_variables_t gvar;\r
+//#ifdef __WATCOMC__\r
+//     __segment sega;\r
+//#endif\r
        //static byte bakapee[64];\r
        char *bakapee1, *bakapee2;\r
        word baka;\r
@@ -83,7 +90,11 @@ main(int argc, char *argv[])
        bakapee2 = malloc(64);\r
        //file name //\r
 \r
-       gvar.mm.mmstarted=0;\r
+//#ifdef __WATCOMC__\r
+#ifdef __DEBUG_PM__\r
+       dbg_debugpm=1;  //debug pm\r
+#endif\r
+//#endif\r
 \r
        //PRINTBB\r
        if(argv[1]){ bakapee1 = argv[1];\r
@@ -93,47 +104,53 @@ main(int argc, char *argv[])
                bakapee1 = "data/koishi~.pcx";\r
                bakapee2 = "data/test.map";\r
        }\r
-//     printf("main()=%Fp      start MM\n", *argv[0]);\r
-       MM_Startup(&gvar.mm, &gvar.mmi);\r
-       //PM_Startup();\r
-       //PM_UnlockMainMem();\r
+       //printf("main()=%Fp    start MM\n", *argv[0]);\r
+       MM_Startup(&gvar);\r
+       //printf("ok\n");\r
+//#ifdef __WATCOMC__\r
+#ifdef __DEBUG_PM__\r
+       if(dbg_debugpm>0)\r
+       {\r
+#endif\r
+               PM_Startup(&gvar); PM_CheckMainMem(&gvar); PM_UnlockMainMem(&gvar);\r
+#ifdef __DEBUG_PM__\r
+       }\r
+#endif\r
+//#endif\r
        CA_Startup(&gvar);\r
 //     printf("                done!\n");\r
-       PRINTBB;\r
+       //0000PRINTBB;\r
 //     printf("press any key to continue!\n");\r
 //     getch();\r
 #ifdef FILEREAD\r
 for(w=0;w<2;w++)\r
 {\r
 //     bakapeehandle = open(bakapee,O_RDONLY | O_BINARY, S_IREAD);\r
-//     printf("size of big buffer~=%u\n", _bmsize(segu, bigbuffer));\r
-//     if(CA_FarRead(bakapeehandle,(void far *)&bigbuffer,sizeof(bigbuffer),&gvar.mm))\r
+//     printf("size of big buffer~=%u\n", _bmsize(segu, gvar.ca.tinf[0]));\r
+//     if(CA_FarRead(bakapeehandle,(void far *)&gvar.ca.tinf[0],sizeof(gvar.ca.tinf[0]),&gvar.mm))\r
        if(w>0)\r
        {\r
                printf("                read\n");\r
-               if(CA_ReadFile(bakapee2, &bigbuffer, &gvar)) baka=1; else baka=0;\r
+               if(CA_ReadFile(bakapee2, &gvar.ca.tinf[0], &gvar)) baka=1; else baka=0;\r
        }\r
 #endif\r
        if(w==0)\r
        {\r
-       printf("                load\n");\r
-       if(CA_LoadFile(bakapee1, &bigbuffer, &gvar)) baka=1; else baka=0;\r
+               printf("                load\n");\r
+               if(CA_LoadFile(bakapee1, &gvar.ca.tinf[0], &gvar)) baka=1; else baka=0;\r
        }\r
 //     close(bakapeehandle);\r
        //hmm functions in cache system use the buffered stuff\r
-#ifdef __WATCOMC__\r
-       printf("\nsize of big buffer~=%u\n", _bmsize(sega, bigbuffer));\r
-#endif\r
+//#ifdef __WATCOMC__\r
+//     printf("\nsize of big buffer~=%u\n", _bmsize(sega, gvar.ca.tinf[0]));\r
+//#endif\r
 \r
-       printf("contents of the buffer\n[\n%s\n]\n", bigbuffer);\r
+       printf("contents of the buffer\n[\n%s\n]\n", gvar.ca.tinf[0]);\r
        //printf("dark purple = purgable\n");\r
        //printf("medium blue = non purgable\n");\r
        //printf("red = locked\n");\r
-       printf("press any key to continue!\n");\r
-       getch();\r
-       MM_ShowMemory(&gvar, &gvar.mm);\r
-       MM_DumpData(&gvar.mm);\r
-       MM_Report(&gvar);\r
+//     printf("press any key to continue!\n");\r
+       DebugMemory_(&gvar, 1);\r
        if(baka) printf("\nyay!\n");\r
        else printf("\npoo!\n");\r
        printf("press any key to continue!\n");\r
@@ -141,10 +158,20 @@ for(w=0;w<2;w++)
 #ifdef FILEREAD\r
 }\r
 #endif\r
-       MM_FreePtr(&bigbuffer, &gvar.mm);\r
-       //PM_Shutdown();\r
+       DebugMemory_(&gvar, 1);\r
+       MM_DumpData(&gvar);\r
+       MM_Report_(&gvar);\r
+       //printf("bakapee1=%s\n", bakapee1);\r
+       //printf("bakapee2=%s\n", bakapee2);\r
+       MM_FreePtr(&gvar.ca.tinf[0], &gvar);\r
+//#ifdef __WATCOMC__\r
+#ifdef __DEBUG_PM__\r
+       if(dbg_debugpm>0)\r
+#endif\r
+               PM_Shutdown(&gvar);\r
+//#endif\r
        CA_Shutdown(&gvar);\r
-       MM_Shutdown(&gvar.mm);\r
+       MM_Shutdown(&gvar);\r
        free(bakapee1); free(bakapee2);\r
        printf("========================================\n");\r
        printf("near=   %Fp ", gvar.mm.nearheap);\r
@@ -154,23 +181,24 @@ for(w=0;w<2;w++)
        printf("&far=   %Fp", &(gvar.mm.farheap));\r
        printf("\n");\r
 #ifdef EXMMVERBOSE\r
-       printf("bigb=   %Fp ", bigbuffer);\r
-       //printf("bigbr=        %04x", bigbuffer);\r
+       printf("bigb=   %Fp ", gvar.ca.tinf[0]);\r
+       //printf("bigbr=        %04x", gvar.ca.tinf[0]);\r
        //printf("\n");\r
-       printf("&bigb=%Fp ", &bigbuffer);\r
-       //printf("&bigb=%04x", &bigbuffer);\r
+       printf("&bigb=%Fp ", &gvar.ca.tinf[0]);\r
+       //printf("&bigb=%04x", &gvar.ca.tinf[0]);\r
        printf("\n");\r
-#endif\r
        printf("========================================\n");\r
+#endif\r
 #ifdef __WATCOMC__\r
 //this is far  printf("Total free:                     %lu\n", (dword)(GetFreeSize()));\r
-       printf("Total near free:                %lu\n", (dword)(GetNearFreeSize()));\r
-       printf("Total far free:                 %lu\n", (dword)(GetFarFreeSize()));\r
+       printf("Total near free:                %lub\n", (dword)(GetNearFreeSize()));\r
+       printf("Total far free:                 %lub\n", (dword)(GetFarFreeSize()));\r
        heapdump(&gvar);\r
        segatesuto();\r
 #endif\r
-       printf("Project 16 emmtest.exe. This is just a test file!\n");\r
+       printf("Project 16 exmmtest.exe. This is just a test file!\n");\r
        printf("version %s\n", VERSION);\r
+       //printf("\n");\r
        //printf("core left:                    %lu\n", (dword)_coreleft());\r
        //printf("far core left:                        %lu\n", (dword)_farcoreleft());\r
        //printf("based core left:                      %lu\n", (dword)_basedcoreleft());\r