*/
#include "src/lib/16_mm.h"
+#pragma hdrstop\r
+\r
+#pragma warn -pro\r
+#pragma warn -use
/*
=============================================================================
void MM_Startup(mminfo_t *mm, mminfotype *mmi)
{
int i;
- dword length;
+ dword length,seglength;
+ //dword length; word seglength;
void huge *start;
- unsigned segstart,seglength,endfree;
+ word segstart;//,endfree;
if(mm->mmstarted)
MM_Shutdown(mm);
mm->mmstarted = true;
mm->bombonerror = true;
+
//
// set up the linked list (everything in the free list;
//
- printf(" linked list making!\n");
+ //printf(" linked list making!\n");
mm->mmhead = NULL;
mm->mmfree = &(mm->mmblocks[0]);
for(i=0;i<MAXBLOCKS-1;i++)
//
// locked block of all memory until we punch out free space
//
- printf(" newblock making!\n");
+ //printf(" newblock making!\n");
MM_GetNewBlock(mm);
mm->mmhead = mm->mmnew; // this will allways be the first node
mm->mmnew->start = 0;
//
printf(" nearheap making!\n");
//---- length=coreleft();
- //_nheapgrow();
+ _nheapgrow();
length=_memmax();
- start = (void huge *)(mm->nearheap = _nmalloc(length));
+ start = (void huge *)(mm->nearheap = malloc(length));
length -= 16-(FP_OFF(start)&15);
length -= SAVENEARHEAP;
seglength = length / 16; // now in paragraphs
segstart = FP_SEG(start)+(FP_OFF(start)+15)/16;
MML_UseSpace(segstart,seglength, mm);
mmi->nearheap = length;
+ printf("start=%Fp segstart=%x seglen=%lu len=%lu\n", start, segstart, seglength, length);
/*switch( _nheapchk() ) {
case _HEAPOK:
printf( "OK - nearheap is good\n" );
printf( "ERROR - bad node in nearheap\n" );
break;
}*/
-// printf(" near heap ok!\n");
+ printf(" near heap ok!\n");
//
// get all available far conventional memory segments
//---- length=farcoreleft();
printf(" farheap making!\n");
_fheapgrow();
- length=0xffffUL*4UL;//_memavl();
+ length=0xffffUL*4UL;
start = mm->farheap = halloc(length, sizeof(byte));
//start = mm->farheap = _fmalloc(length);
length -= 16-(FP_OFF(start)&15);
MML_UseSpace(segstart,seglength, mm);
mmi->farheap = length;
mmi->mainmem = mmi->nearheap + mmi->farheap;
+ printf("start=%Fp segstart=%x seglen=%lu len=%lu\n", start, segstart, seglength, length);
/*switch( _fheapchk() ) {
case _HEAPOK:
printf( "OK - farheap is good\n" );
printf( "ERROR - bad node in farheap\n" );
break;
}*/
- //printf(" far heap ok!\n");
+ printf(" far heap ok!\n");
//
// detect EMS and allocate up to 64K at page frame
//
-printf(" EMS1\n");
+/*printf(" EMS1\n");
printf("\0\0\0\0\0\0\0\0\0\0\0\0\0\0\0\0\0\0\0\0\0\0\0\0\0\0\0\0\0\0\0\0\0\0\0\0\0\0\0\0"); //bug!
mmi->EMSmem = 0;
for(i = 1;i < __argc;i++)
MML_UseSpace(mm->EMSpageframe,(MAPPAGES)*0x4000lu, mm);
printf("\0\0\0\0\0\0\0\0\0\0\0\0\0\0\0\0\0\0\0\0\0\0\0\0\0\0\0\0\0\0\0\0\0\0\0\0\0\0\0\0"); //bug!
printf(" EMS4\n");
- if(mm->EMSVer<0x40)
+ //if(mm->EMSVer<0x40)
MM_MapEMS(mm, mmi); // map in used pages
- else
- MM_MapXEMS(mm, mmi); // map in used pages
+ //else
+ //MM_MapXEMS(mm, mmi); // map in used pages
}
//
//
// allocate the misc buffer
//
-xmsskip:
+xmsskip:*/
+/*mmi->nearheap = 0;
+mmi->farheap = 0;*/
+mmi->EMSmem = 0;
+mmi->XMSmem = 0;
mm->mmrover = mm->mmhead; // start looking for space after low block
MM_GetPtr(&(mm->bufferseg),BUFFERSIZE, mm, mmi);
=====================
*/
-void MM_ShowMemory(page_t *page, mminfo_t *mm)
+void MM_ShowMemory(/*page_t *page, */mminfo_t *mm)
{
mmblocktype huge *scan;
word color,temp;
//modexhlin(page, scan->start, (unsigned)end, chy, color);
//for(chx=scan->start;chx+4>=(word)end;chx+=4)
//{
- modexClearRegion(page, chx, chy, 4, 4, color);
+//++++ modexClearRegion(page, chx, chy, 4, 4, color);
//}
//++++ VW_Hlin(scan->start,(unsigned)end,0,color);
//++++ VW_Plot(scan->start,0,15);
- modexClearRegion(page, chx, chy, 4, 4, 15);
+//++++ modexClearRegion(page, chx, chy, 4, 4, 15);
if(scan->next->start > end+1)
//++++ VW_Hlin(end+1,scan->next->start,0,0); // black = free
//for(chx=scan->next->start;chx+4>=(word)end+1;chx+=4)
//{
- chx+=scan->next->start;
- modexClearRegion(page, chx, chy, 4, 4, 2);
+//++++ chx+=scan->next->start;
+//++++ modexClearRegion(page, chx, chy, 4, 4, 2);
//}
//modexhlin(page, end+1,scan->next->start, chy, 0);
strcat (scratch,"\n");
write(debughandle,scratch,strlen(scratch));
//modexprint(page, chx, chy, 1, 0, 24, &scratch);
-chy+=4;
+//++++chy+=4;
//fprintf(stdout, "%s", scratch);
//****#endif
FILE *dumpfile;
- free (mm->nearheap);
+ //++++free(mm->nearheap);
dumpfile = fopen ("mmdump.txt","w");
if (!dumpfile){
printf("MM_DumpData: Couldn't open MMDUMP.TXT!\n");
} while (lowest != 0xffff);
- fclose (dumpfile);
+ fclose(dumpfile);
printf("MMDUMP.TXT created.\n");
}
=====================
*/
-void MM_Report(page_t *page, mminfo_t *mm, mminfotype *mmi)
+void MM_Report(/*page_t *page, */mminfo_t *mm, mminfotype *mmi)
{
if(MML_CheckForEMS())
{