]> 4ch.mooo.com Git - 16.git/blobdiff - src/lib/16_mm.h
==== HOLY MOTHER FUCKER ==== I FIXED THIS SHIT!!!!!! NOW TO MAXIMIZE IT'S DONG!!...
[16.git] / src / lib / 16_mm.h
index 7425fc93b89c9affa2a8b5a9e0df79ae3493283c..7e43b271031a7f98b14952c5a7efe0984ad643ae 100644 (file)
@@ -23,7 +23,6 @@
 
 #include <string.h>
 #include <malloc.h>
-//#include <bios.h>
 #include "src/lib/16_head.h"
 #include "src/lib/16_hc.h"
 //#include "src/lib/modex16.h"
@@ -37,9 +36,9 @@
 #endif
 
 //#define GETNEWBLOCK {if(!(mmnew=mmfree))Quit("MM_GETNEWBLOCK: No free blocks!") ;mmfree=mmfree->next;}
-#define GETNEWBLOCK {if(!mm->mmfree)MML_ClearBlock(mm);mm->mmnew=mm->mmfree;mm->mmfree=mm->mmfree->next;}
+#define GETNEWBLOCK {if(!mm->mmfree)MML_ClearBlock(mm);mm->mmnew=mm->mmfree;mm->mmfree=mm->mmfree->next;mm->endid++;}
 
-#define FREEBLOCK(x) {*x->useptr=NULL;x->next=mm->mmfree;mm->mmfree=x;}
+#define FREEBLOCK(x) {*x->useptr=NULL;x->next=mm->mmfree;mm->mmfree=x;mm->endid--;}
 
 
 #define SAVENEARHEAP   0//_memavl()/4          // space to leave in data segment
@@ -94,7 +93,6 @@
 typedef struct
 {
        dword   nearheap,farheap,EMSmem,XMSmem,mainmem;
-       //__segment segu;
 } mminfotype;
 
 //==========================================================================
@@ -136,7 +134,12 @@ typedef struct
        memptr bufferseg;
        boolean         mmstarted, bombonerror, mmerror;
        void huge       *farheap;
+#ifdef __BORLANDC__
+       void    *nearheap;
+#endif
+#ifdef __WATCOMC__
        void __near     *nearheap;
+#endif
        //byte          EMS_status;
        unsigned        totalEMSpages,freeEMSpages,EMSpageframe,EMSpagesmapped,EMShandle;
        unsigned int EMSVer;