]> 4ch.mooo.com Git - 16.git/blobdiff - src/lib/16_mm.h
fmemtest.exe hmmm
[16.git] / src / lib / 16_mm.h
index a18f0db7079dc966f4df354e63e55d870df8eba2..0b562da7eaf3908fe24dfba0d9564d5dbc19f8b5 100644 (file)
@@ -1,4 +1,4 @@
-/* Catacomb Armageddon Source Code
+/* Catacomb Apocalypse Source Code
  * Copyright (C) 1993-2014 Flat Rock Software
  *
  * This program is free software; you can redistribute it and/or modify
 
 #include <string.h>
 #include <malloc.h>
-#include "src/lib/lib_head.h"
+//#include <bios.h>
+#include "src/lib/16_head.h"
+#include "src/lib/modex16.h"
+//#include "src/lib/16_ca.h"
 //++++mh       #include "src/lib/16_in.h"
 
-//****#if 1            // 1 == Debug/Dev  ;  0 == Production/final
-#define OUT_OF_MEM_MSG "MM_GetPtr: Out of memory!\nYou were short :%ld bytes"
-//****#else
-//****#define OUT_OF_MEM_MSG   "\npee\n"
-//****#endif
+#ifdef __DEBUG__               // 1 == Debug/Dev  ;  0 == Production/final
+#define OUT_OF_MEM_MSG "MM_GetPtr: Out of memory!\nYou were short :%lu bytes"
+#else
+#define OUT_OF_MEM_MSG "\npee\n"
+#endif
 
 
-#define SAVENEARHEAP   0x400           // space to leave in data segment
-#define SAVEFARHEAP            0                       // space to leave in far heap
+#define SAVENEARHEAP   0//x200         // space to leave in data segment
+#define SAVEFARHEAP    0x400                   // space to leave in far heap
 
 #define        BUFFERSIZE              0x1000          // miscelanious, allways available buffer
 
-#define MAXBLOCKS              600
+#define MAXBLOCKS              720
+
 
 
 //--------
@@ -50,6 +54,7 @@
 #define        EMS_GETPAGES    0x42
 #define        EMS_ALLOCPAGES  0x43
 #define        EMS_MAPPAGE             0x44
+#define        EMS_MAPXPAGE            0x50
 #define        EMS_FREEPAGES   0x45
 #define        EMS_VERSION             0x46
 
 
 //==========================================================================
 
-typedef void /*__seg*/ * memptr;
-
 typedef struct
 {
-       long    nearheap,farheap,EMSmem,XMSmem,mainmem;
+       dword   nearheap,farheap,EMSmem,XMSmem,mainmem;
+       //__segment segu;
 } mminfotype;
 
 //==========================================================================
 
-/*extern       mminfotype      mminfo;
-extern memptr          bufferseg;
-extern boolean         mmerror;
-
 extern void            (* beforesort) (void);
-extern void            (* aftersort) (void);*/
+extern void            (* aftersort) (void);
+extern void            (* XMSaddr) (void);             // far pointer to XMS driver
 
 //==========================================================================
 
@@ -111,20 +112,32 @@ extern    void            (* aftersort) (void);*/
 #define PURGEMASK      0xfffc
 #define BASEATTRIBUTES 0       // unlocked, non purgable
 
-#define MAXUMBS                10
+#define MAXUMBS                12
+#define MAPPAGES               4//mm->EMSpagesmapped
 
 typedef struct mmblockstruct
 {
-       unsigned        start,length;
+       //word  start,length;
+       word    start;  dword length;
        unsigned        attributes;
        memptr          *useptr;        // pointer to the segment start
-       struct mmblockstruct far *next;
+       struct mmblockstruct huge *next;
 } mmblocktype;
 
 
-//#define GETNEWBLOCK {if(!(mmnew=mmfree))Quit("MM_GETNEWBLOCK: No free blocks!");mmfree=mmfree->next;}
-#define GETNEWBLOCK {if(!mmfree)MML_ClearBlock();mmnew=mmfree;mmfree=mmfree->next;}
-#define FREEBLOCK(x) {*x->useptr=NULL;x->next=mmfree;mmfree=x;}
+typedef struct
+{
+       memptr bufferseg;
+       boolean         mmstarted, bombonerror, mmerror;
+       void huge       *farheap;
+       void    *nearheap;
+       //byte          EMS_status;
+       unsigned        totalEMSpages,freeEMSpages,EMSpageframe,EMSpagesmapped,EMShandle;
+       unsigned int EMSVer;
+       word numUMBs,UMBbase[MAXUMBS];
+       //dword numUMBs,UMBbase[MAXUMBS];
+       mmblocktype     huge mmblocks[MAXBLOCKS],huge *mmhead,huge *mmfree,huge *mmrover,huge *mmnew;
+} mminfo_t;
 
 /*
 =============================================================================
@@ -134,12 +147,6 @@ typedef struct mmblockstruct
 =============================================================================
 */
 
-static mminfotype      mminfo;
-static memptr          bufferseg;
-static boolean         mmerror;
-
-static void            (* beforesort) (void);
-static void            (* aftersort) (void);
 
 /*
 =============================================================================
@@ -149,63 +156,36 @@ static void               (* aftersort) (void);
 =============================================================================
 */
 
-static boolean         mmstarted;
-
-static void huge       *hugeheap;
-static void far        *farheap;
-static void            *nearheap;
-
-static mmblocktype     far mmblocks[MAXBLOCKS]
-                       ,far *mmhead,far *mmfree,far *mmrover,far *mmnew;
-
-static boolean         bombonerror;
-
-static unsigned        totalEMSpages,freeEMSpages,EMSpageframe,EMSpagesmapped,EMShandle;
-static unsigned int EMSVer;
-
-static void            (* XMSaddr) (void);             // far pointer to XMS driver
-
-static unsigned        numUMBs,UMBbase[MAXUMBS];
-
-static char *ParmStringsexmm[] = {"noems","noxms",""};
-
-//==========================================================================
-
-void MM_Startup (void);
-void MM_Shutdown (void);
-void MM_MapEMS (void);
-
-void MM_GetPtr (memptr *baseptr,dword size);
-void MM_FreePtr (memptr *baseptr);
-
-void MM_SetPurge (memptr *baseptr, int purge);
-void MM_SetLock (memptr *baseptr, boolean locked);
-void MM_SortMem (void);
-
-void MM_ShowMemory (void);
-
-dword MM_UnusedMemory (void);
-dword MM_TotalFree (void);
-void MM_Report(void);
-//int MM_EMSVer(void);
-
-void MM_BombOnError (boolean bomb);
-
 //==========================================================================
 
-//
-// local prototypes
-//
-
-boolean                MML_CheckForEMS (void);
-void           MML_ShutdownEMS (void);
-void           MM_MapEMS (void);
-boolean        MML_CheckForXMS (void);
-void           MML_ShutdownXMS (void);
-void           MML_UseSpace (unsigned segstart, unsigned seglength);
-void           MML_ClearBlock (void);
-
-int US_CheckParm(char *parm,char **strings);
+boolean MML_CheckForEMS(void);
+byte MML_SetupEMS(mminfo_t *mm);
+void MML_ShutdownEMS(mminfo_t *mm);
+byte MM_MapEMS(mminfo_t *mm, mminfotype *mmi);
+byte MM_MapXEMS(mminfo_t *mm, mminfotype *mmi);
+boolean MML_CheckForXMS(mminfo_t *mm);
+void MML_SetupXMS(mminfo_t *mm, mminfotype *mmi);
+void MML_ShutdownXMS(mminfo_t *mm);
+void MML_UseSpace(/*d*/word segstart, dword seglength, mminfo_t *mm);
+void MML_ClearBlock(mminfo_t *mm);
+
+void MM_Startup(mminfo_t *mm, mminfotype *mmi);
+void MM_Shutdown(mminfo_t *mm);
+
+void MM_GetPtr(memptr *baseptr,dword size, mminfo_t *mm, mminfotype *mmi);
+void MM_FreePtr(memptr *baseptr, mminfo_t *mm);
+void MM_SetPurge(memptr *baseptr, int purge, mminfo_t *mm);
+void MM_SetLock(memptr *baseptr, boolean locked, mminfo_t *mm);
+void MM_SortMem(mminfo_t *mm);
+void MM_ShowMemory(/*page_t *page, */mminfo_t *mm);
+void MM_DumpData(mminfo_t *mm);
+dword MM_UnusedMemory(mminfo_t *mm);
+dword MM_TotalFree(mminfo_t *mm);
+void MM_Report(/*page_t *page, */mminfo_t *mm, mminfotype *mmi);
+static void MM_EMSerr(byte *stri, byte err);
+void MM_BombOnError(boolean bomb, mminfo_t *mm);
+void MM_GetNewBlock(mminfo_t *mm);
+void MM_FreeBlock(mmblocktype *x, mminfo_t *mm);
 
 //==========================================================================