X-Git-Url: http://4ch.mooo.com/gitweb/?a=blobdiff_plain;f=src%2Fexmmtest.c;h=afbc9d042000e39255208fa1aab0fb7bca977f0b;hb=4d803a69429c22aeeb410c987c3199b1b4de4462;hp=bdc799915c4cdd4e36c9a03783868b117956ae48;hpb=8e02b48e481611a3c25091a3d88fbf2da7000478;p=16.git diff --git a/src/exmmtest.c b/src/exmmtest.c index bdc79991..afbc9d04 100644 --- a/src/exmmtest.c +++ b/src/exmmtest.c @@ -20,63 +20,120 @@ * */ /* - 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; +#ifdef FILERL + memptr bigbuffer; 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("&segu=%p\n", (segu)); + //printf("mmi.segu=%p\n", (mmi.segu)); + +#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"); + //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]); - if(CA_LoadFile(bakapee, &bigbuffer, &mm, &mmi)) baka=1; + printf("&segu=%p\n", (segu)); + //printf("mmi.segu=%p\n", (mmi.segu)); +#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)); +#endif printf("dark purple = purgable\n"); printf("medium blue = non purgable\n"); printf("red = locked\n"); getch(); - modexEnter(); - modexShowPage(&screen); - MM_ShowMemory(&screen, &mm); - getch(); + //++++modexEnter(); + //++++modexShowPage(&screen); + MM_ShowMemory(/*&screen, */&mm); + //getch(); MM_DumpData(&mm); - modexLeave(); - MM_Report(&screen, &mm, &mmi); - printf("stop!\n"); + //++++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()); }