X-Git-Url: http://4ch.mooo.com/gitweb/?a=blobdiff_plain;f=src%2Fexmmtest.c;h=d036b8387bf4f594f3192e200c1f426560cef2a8;hb=96ceb7d08dd300c94570f4d58f0e10d47bf9a4fd;hp=8cd440f558bc2a19146c380cd7f806983c662aac;hpb=9ffe77d9a59bd77df9ab71eb98e82c97a1fa6076;p=16.git diff --git a/src/exmmtest.c b/src/exmmtest.c index 8cd440f5..d036b838 100644 --- a/src/exmmtest.c +++ b/src/exmmtest.c @@ -20,58 +20,127 @@ * */ /* - input test + exmm test */ +#include +#include + +#include "src/lib/16_head.h" #include "src/lib/16_ca.h" #include "src/lib/16_mm.h" -#include "src/lib/modex16.h" +//#include "src/lib/modex16.h" +#pragma hdrstop + +#pragma warn -pro +#pragma warn -use + +//file load or read definition +//#define FILERL +//#define FILEREAD void main(int argc, char *argv[]) { mminfo_t mm; mminfotype mmi; - memptr bigbuffer; - __segment segu; + memptr bigbuffer; +#ifdef FILERL char *bakapee; +// int bakapeehandle; word baka; - page_t screen; +#endif + //static page_t screen; + + //mmi.segu=FP_SEG(segu); + + 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); +#ifdef FILERL bakapee = malloc(64); // memset(bakapee, 0, 64); +#endif mm.mmstarted=0; +#ifdef FILERL if(argv[1]) bakapee = argv[1]; else bakapee = "data/koishi~~.pcx"; +#endif textInit(); - /* setup camera and screen~ */ - screen = modexDefaultPage(); - screen.width += (16*2); - screen.height += (16*2); + /* setup camera and screen~ */ + //bug!!! + //screen = modexDefaultPage(); + /*screen.width += (16*2); + screen.height += (16*2);*/ - printf("start!\n"); + printf("main()=%Fp start MM\n", *argv[0]); MM_Startup(&mm, &mmi); - printf("done!\n"); - printf("&main()=%Fp\n", *argv[0]); - if(CA_LoadFile(bakapee, &bigbuffer, &mm, &mmi)) baka=1; + //PM_Startup(); + //PM_UnlockMainMem(); + CA_Startup(); + printf(" done!\n"); + /*if(FP_SEG(*argv[0])==0) + { + MM_Report(&screen, &mm, &mmi); + MM_Shutdown(&mm); + printf("&main()=%Fp\n", *argv[0]); + printf("&main() == %u\n", FP_SEG(*argv[0])); + exit(-5); + }*/ + 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); +#ifdef FILERL +// bakapeehandle = open(bakapee,O_RDONLY | O_BINARY, S_IREAD); +// printf("size of big buffer~=%u\n", _bmsize(segu, bigbuffer)); +// if(CA_FarRead(bakapeehandle,(void far *)&bigbuffer,sizeof(bigbuffer),&mm)) +#ifdef FILEREAD + printf(" read\n"); + if(CA_ReadFile(bakapee, &bigbuffer, &mm)) +#else + printf(" load\n"); + if(CA_LoadFile(bakapee, &bigbuffer, &mm, &mmi)) +#endif + baka=1; else baka=0; - //MM_GetPtr(&bigbuffer, mmi.nearheap, &mm, &mmi); +// close(bakapeehandle); //hmm functions in cache system use the buffered stuff - printf("size of big buffer~=%u\n", _bmsize(segu, bigbuffer)); +// printf("size of big buffer~=%u\n", _bmsize(segu, bigbuffer)); +#endif + printf("dark purple = purgable\n"); + printf("medium blue = non purgable\n"); + printf("red = locked\n"); getch(); - modexEnter(); - MM_ShowMemory(&screen, &mm); - getch(); - MM_Report(&screen, &mm, &mmi); - modexLeave(); - printf("stop!\n"); + //++++modexEnter(); + //++++modexShowPage(&screen); + MM_ShowMemory(/*&screen, */&mm); + //getch(); + MM_DumpData(&mm); + //++++modexLeave(); + MM_Report(&mm, &mmi); + printf(" stop!\n"); +#ifdef FILERL MM_FreePtr(&bigbuffer, &mm); +#endif + //PM_Shutdown(); + CA_Shutdown(); MM_Shutdown(&mm); - printf("done!\n"); + printf(" done!\n"); +#ifdef FILERL free(bakapee); - //printf("_bios_memsize=%u\n", _bios_memsize()); if(baka) printf("\nyay!\n"); else printf("\npoo!\n"); +#endif + //printf("_bios_memsize=%u\n", _bios_memsize()); + printf("bigbuffer= %Fp\n", bigbuffer); + printf("&bigbuffer= %Fp\n", &bigbuffer); + printf("bigbuffer= %04x\n", bigbuffer); + printf("&bigbuffer= %04x\n", &bigbuffer); }