/* 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
/*\r
exmm test\r
*/\r
+#include <malloc.h> // for _memavl()\r
#include "src/lib/16_head.h"\r
+#include "src/lib/16_tail.h"\r
+#include "src/lib/16_pm.h"\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_dbg.h"\r
+\r
#pragma hdrstop\r
\r
#pragma warn -pro\r
#pragma warn -use\r
\r
//file load or read definition\r
+#define FILEREADLOAD\r
#define FILEREAD\r
//#define EXMMVERBOSE\r
+//#define BUFFDUMPPAUSE\r
+//#define EXMMVERBOSE__\r
+// #define PRINTBBDUMP\r
+#define BUFFDUMP\r
+\r
+#ifdef __BORLANDC__\r
+#define NOVID\r
+#endif\r
+#ifdef __WATCOMC__\r
+#define NOVID\r
+#endif\r
+\r
+\r
+#define KEYP IN_Shutdown(&gvar); printf("\n\npress any key to continue!\n"); getch(); IN_Startup(&gvar);\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
+#define BBUFNAME gvar.mm.bufferseg//bigbuffer\r
+//#define INITBBUF static memptr BBUFNAME;\r
+#define BBUFPTR MEMPTR BBUFNAME\r
\r
+#ifdef __BORLANDC__\r
+#define BBUF (memptr *)BBUFPTR\r
+#define BBUFSTRING (memptr *)BBUFNAME\r
+#endif\r
+#ifdef __WATCOMC__\r
+#define BBUF BBUFNAME\r
+#define BBUFSTRING BBUF\r
+#endif\r
+\r
+////////////////////////////////////////////////////////////////////////////\r
+//#ifdef NOVID\r
+#ifdef __BORLANDC__\r
+void VL_Startup (global_game_variables_t *gvar){ gvar=gvar; }\r
+void VL_Shutdown (global_game_variables_t *gvar){ gvar=gvar; }\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
+\r
+word modexPalOverscan(word col)\r
+{\r
+ //modexWaitBorder();\r
+ outp(PAL_WRITE_REG, 0); /* start at the beginning of palette */\r
+ outp(PAL_DATA_REG, col);\r
+ return col;\r
+}\r
+void TL_VidInit(global_game_variables_t *gvar)\r
+{\r
+ gvar->video.old_mode = 3;\r
+}\r
+#endif\r
+\r
+//printf("* %Fp\t", *BBUF);\r
+//printf("* %04x\t", *BBUF);\r
+#define PRINTBB {\\r
+ printf("-------------------------------------------------------------------------------\n");\\r
+ printf("&main()= %Fp\n", argv[0]);\\r
+ printf("buffer:\n");\\r
+ printf(" %Fp\t", BBUF);\\r
+ printf("&%Fp\n", BBUFPTR);\\r
+ printf(" %04x\t", BBUF);\\r
+ printf("& %04x\n", BBUFPTR);\\r
+ printf("-------------------------------------------------------------------------------\n");\\r
+}\r
+ //printf("&main()= %Fp\n", *argv[0]);\r
+ //printf("bigbuffer= %Fp\n", bigbuffer);\r
+ //printf("&bigbuffer= %Fp\n", &bigbuffer);\r
+ //printf("bigbuffer= %04x\n", bigbuffer);\r
+ //printf("&bigbuffer= %04x\n", &bigbuffer);\r
#ifdef __WATCOMC__\r
void segatesuto()\r
{\r
//\r
// }\r
// printf("]\n");\r
-// printf("press any key to continue!\n");\r
-// getch();\r
+// KEYP\r
}\r
#endif\r
\r
+//===========================================================================//\r
+\r
+//=======================================//\r
+\r
+// main\r
+\r
+//=======================================//\r
void\r
main(int argc, char *argv[])\r
{\r
- byte w=1;\r
- global_game_variables_t gvar;\r
-#ifdef __WATCOMC__\r
+ byte w;\r
+ static global_game_variables_t gvar;\r
+ #ifdef INITBBUF\r
+ INITBBUF\r
+ #endif\r
+#if 0\r
+//#ifdef __WATCOMC__\r
__segment sega;\r
#endif\r
- memptr bigbuffer;\r
-\r
- //static byte bakapee[64];\r
- char *bakapee1, *bakapee2;\r
+ char bakapee1[64] = "data/koishi~.pcx";\r
+ char bakapee2[64] = "data/test.map";\r
word baka;\r
\r
-#ifdef __BORLANDC__\r
- argc=argc;\r
-#endif\r
- //file name //\r
- bakapee1 = malloc(64);\r
- bakapee2 = malloc(64);\r
- //file name //\r
+ #ifdef __BORLANDC__\r
+ argc=argc;\r
+ #endif\r
\r
- gvar.mm.mmstarted=0;\r
+ #ifdef PRINTBBDUMP\r
+ //0000PRINTBB; KEYP\r
+ #endif\r
+#ifdef __16_PM__\r
+#ifdef __DEBUG_PM__\r
+ dbg_debugpm=1; //debug pm\r
+#endif\r
+#endif\r
+#ifdef __DEBUG_CA__\r
+ dbg_debugca=1;\r
+#endif\r
+#ifdef __DEBUG_MM__\r
+ dbg_debugmm=1;\r
+#endif\r
\r
- //PRINTBB\r
- if(argv[1]){ bakapee1 = argv[1];\r
- if(argv[2]) bakapee2 = argv[2]; }\r
+ if(argv[1]){ strcpy(bakapee1, argv[1]);//bakapee1[] = *argv[1];\r
+ if(argv[2]) strcpy(bakapee2, argv[2]); }//bakapee2[] = argv[2]; }\r
+#if 0\r
else{\r
//{ printf("filename!: "); scanf("%[^\n]", &bakapee); }\r
- 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
- CA_Startup(&gvar);\r
-// printf(" done!\n");\r
- PRINTBB;\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
- if(w>0)\r
- {\r
- printf(" read\n");\r
- if(CA_ReadFile(bakapee2, &bigbuffer, &gvar)) baka=1; else baka=0;\r
+ strcpy(bakapee1, "data/koishi~.pcx"); //bakapee1 = "data/koishi~.pcx";\r
+ strcpy(bakapee2, "data/test.map"); //bakapee2 = "data/test.map";\r
}\r
#endif\r
- if(w==0)\r
+ printf("bakapee1[%s]\n", bakapee1);\r
+ printf("bakapee2[%s]\n", bakapee2);\r
+ KEYP\r
+\r
+ #ifndef NOVID\r
+ Startup16(&gvar);\r
+ // save the palette\r
+ modexPalSave(&gvar.video.dpal); modexFadeOff(4, &gvar.video.dpal); //modexPalBlack();\r
+ #else //NOVID\r
+ StartupCAMMPM(&gvar);\r
+/* MM_Startup(&gvar);\r
+ #ifdef __16_PM__\r
+ #ifdef __DEBUG_PM__\r
+ if(dbg_debugpm>0)\r
+ {\r
+ #endif //__DEBUG_PM__\r
+ PM_Startup(&gvar); PM_CheckMainMem(&gvar); PM_UnlockMainMem(&gvar);\r
+ //0000printf("PM Started\n"); KEYP\r
+ #ifdef __DEBUG_PM__\r
+ }\r
+ #endif //__DEBUG_PM__\r
+ #endif //__16_PM__\r
+ CA_Startup(&gvar);*/\r
+ #endif //elsed NOVID\r
+ #ifdef PRINTBBDUMP\r
+ //0000\r
+PRINTBB; KEYP\r
+ #endif\r
+\r
+ w=0;\r
+ #ifdef FILEREADLOAD\r
+ #ifdef FILEREAD\r
+ for(;w<2;w++)\r
{\r
- printf(" load\n");\r
- if(CA_LoadFile(bakapee1, &bigbuffer, &gvar)) baka=1; else baka=0;\r
+ // printf("size of big buffer~=%u\n", _bmsize(segu, BBUF));\r
+ if(w>0)\r
+ {\r
+ printf("======================================read=====================================\n");\r
+ if(CA_ReadFile(bakapee2, BBUFPTR, &gvar)) baka=1; else baka=0;\r
+ printf("====================================read end===================================\n");\r
+ }\r
+ #endif //FILEREAD\r
+ if(w==0)\r
+ {\r
+ printf("======================================load=====================================\n");\r
+ if(CA_LoadFile(bakapee1, BBUFPTR, &gvar)) baka=1; else baka=0;\r
+ printf("====================================load end===================================\n");\r
+ }\r
+ //#ifdef __WATCOMC__\r
+ // printf("\nsize of big buffer~=%u\n", _bmsize(sega, BBUF));\r
+ //#endif\r
+ #ifdef BUFFDUMP\r
+ printf("contents of the buffer\n[\n%s\n]\n", BBUFSTRING);\r
+ #endif// #else\r
+ #ifdef PRINTBBDUMP\r
+ PRINTBB;\r
+ #endif\r
+\r
+ //endif // BUFFDUMP\r
+\r
+ //printf("dark purple = purgable\n");\r
+ //printf("medium blue = non purgable\n");\r
+ //printf("red = locked\n");\r
+ // KEYP\r
+ // DebugMemory_(&gvar, 1);\r
+ if(baka) printf("\nyay!\n");\r
+ else printf("\npoo!\n");\r
+ #ifdef BUFFDUMPPAUSE\r
+ KEYP\r
+ #endif\r
+ #ifdef FILEREAD\r
}\r
-// close(bakapeehandle);\r
- //hmm functions in cache system use the buffered stuff\r
+ #endif\r
+ #endif //filereadload\r
+\r
#ifdef __WATCOMC__\r
- printf("\nsize of big buffer~=%u\n", _bmsize(sega, bigbuffer));\r
-#endif\r
-\r
- printf("contents of the buffer\n[\n%s\n]\n", bigbuffer);\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
- if(baka) printf("\nyay!\n");\r
- else printf("\npoo!\n");\r
- printf("press any key to continue!\n");\r
- getch();\r
-#ifdef FILEREAD\r
+#ifndef NOVID\r
+ VGAmodeX(8, 0, &gvar);\r
+// modexPalUpdate0(&gvar.video.palette);\r
+// ShapeTest_(&gvar);\r
+ MM_ShowMemory(&gvar);\r
+#if 0\r
+ {\r
+ boolean done;\r
+ ScanCode scan;\r
+ for (done = false;!done;)\r
+ {\r
+ while (!(scan = gvar.in.inst->LastScan))\r
+ {}\r
+ // SD_Poll();\r
+\r
+ IN_ClearKey(scan);\r
+ switch (scan)\r
+ {\r
+// case sc_Space:\r
+// MM_ShowMemory(&gvar);\r
+// break;\r
+//#ifdef __WATCOMC__\r
+ case sc_O:\r
+ VL_modexPalScramble(&gvar.video.palette); modexpdump(&gvar.video.page);\r
+ break;\r
+ case sc_P:\r
+ modexpdump(&gvar.video.page[0]);\r
+ break;\r
+ case sc_V:\r
+ VL_PatternDraw(&gvar.video, 0, 1, 1);\r
+ break;\r
+//#endif\r
+ default:\r
+ case sc_Escape:\r
+ done = true;\r
+ break;\r
+ }\r
+ }\r
}\r
#endif\r
- MM_FreePtr(&bigbuffer, &gvar.mm);\r
- //PM_Shutdown();\r
+ VGAmodeX(0, 0, &gvar);\r
+#endif\r
+#endif\r
+ MM_ShowMemory(&gvar);\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(BBUFPTR, &gvar);\r
+ #ifndef NOVID\r
+ Shutdown16(&gvar);\r
+ #else //novid\r
+ ShutdownCAMMPM(&gvar);\r
+/* #ifdef __16_PM__\r
+ #ifdef __DEBUG_PM__\r
+ if(dbg_debugpm>0)\r
+ #endif //__DEBUG_PM__\r
+ PM_Shutdown(&gvar);\r
+ #endif //__16_PM__\r
CA_Shutdown(&gvar);\r
- MM_Shutdown(&gvar.mm);\r
- free(bakapee1); free(bakapee2);\r
+ MM_Shutdown(&gvar);*/\r
+ #endif //NOVID\r
+ IN_Shutdown(&gvar);\r
printf("========================================\n");\r
- printf("near= %Fp ", gvar.mm.nearheap);\r
- printf("far= %Fp", gvar.mm.farheap);\r
+ printf("near= %Fp ", gvar.mm.nearheap);\r
+ printf("far= %Fp", gvar.mm.farheap);\r
printf("\n");\r
- printf("&near= %Fp ", &(gvar.mm.nearheap));\r
- printf("&far= %Fp", &(gvar.mm.farheap));\r
+ printf("&near= %Fp ", &(gvar.mm.nearheap));\r
+ printf("&far= %Fp", &(gvar.mm.farheap));\r
printf("\n");\r
-#ifdef EXMMVERBOSE\r
- printf("bigb= %Fp ", bigbuffer);\r
- //printf("bigbr= %04x", bigbuffer);\r
+ #ifdef EXMMVERBOSE\r
+ printf("bigb= %Fp ", BBUF);\r
+ //printf("bigbr= %04x", BBUF);\r
//printf("\n");\r
- printf("&bigb=%Fp ", &bigbuffer);\r
- //printf("&bigb=%04x", &bigbuffer);\r
+ printf("&bigb=%Fp ", BBUFPTR);\r
+ //printf("&bigb=%04x", BBUFPTR);\r
printf("\n");\r
-#endif\r
+ #endif\r
printf("========================================\n");\r
+\r
+ #ifdef EXMMVERBOSE__\r
+ printf("coreleft(): %u\n", _memavl());\r
+ printf("farcoreleft(): %lu\n", (dword)HC_farcoreleft());\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
- heapdump(&gvar);\r
- segatesuto();\r
+//this is far printf("Total free: %lu\n", (dword)(HC_GetFreeSize()));\r
+//super buggy printf("HC_coreleft(): %u\n", HC_coreleft());\r
+// printf("HC_farcoreleft(): %lu\n", (dword)HC_farcoreleft());\r
+ //printf("HC_GetNearFreeSize(): %u\n", HC_GetNearFreeSize());\r
+ //printf("HC_GetFarFreeSize(): %lu\n", (dword)HC_GetFarFreeSize());\r
+ HC_heapdump(&gvar);\r
+// segatesuto();\r
+#endif\r
+/*#ifdef __BORLANDC__\r
+ //printf("core left: %lu\n", (dword)HC_coreleft());\r
+ //printf("far core left: %lu\n", (dword)HC_farcoreleft());\r
+// printf("\nfarcoreleft(): %lu\n", farcoreleft());\r
+#endif*/\r
+ printf("Project 16 ");\r
+#ifdef __WATCOMC__\r
+ printf("exmmtest");\r
+#endif\r
+#ifdef __BORLANDC__\r
+ printf("bcexmm");\r
#endif\r
- printf("Project 16 emmtest.exe. This is just a test file!\n");\r
+ printf(".exe. This is just a test file!\n");\r
printf("version %s\n", VERSION);\r
- //printf("core left: %lu\n", (dword)_coreleft());\r
- //printf("far core left: %lu\n", (dword)_farcoreleft());\r
+\r
+//end of program\r
+\r
+\r
+#if defined(__DEBUG__) && ( defined(__DEBUG_PM__) || defined(__DEBUG_MM__) )\r
+#ifdef __DEBUG_MM__\r
+ printf("debugmm: %u\t", dbg_debugmm);\r
+#endif\r
+#ifdef __DEBUG_PM__\r
+ printf("debugpm: %u", dbg_debugpm);\r
+#endif\r
+ printf("\n");\r
+#endif\r
+// printf("curr_mode=%u\n", gvar.video.curr_mode);\r
+// VL_PrintmodexmemInfo(&gvar.video);\r
+ //printf("old_mode=%u VL_Started=%u", gvar.video.old_mode, gvar.video.VL_Started);\r
//printf("based core left: %lu\n", (dword)_basedcoreleft());\r
//printf("huge core left: %lu\n", (dword)_hugecoreleft());\r
}\r