]> 4ch.mooo.com Git - 16.git/blobdiff - src/lib/16_mm.h
Merge remote-tracking branch 'upstream/master'
[16.git] / src / lib / 16_mm.h
index e816d8854558d240e3bf93fca2611b6615ff1183..b68eea9c472ba0055b8484bff1f45c5e78dddbb3 100755 (executable)
@@ -53,6 +53,7 @@ extern boolean dbg_debugpm;
 //--------\r
 \r
 #define        EMS_INT                 0x67\r
+#define        EMM_INT                 0x21\r
 \r
 #define        EMS_STATUS              0x40\r
 #define        EMS_GETFRAME    0x41\r
@@ -67,7 +68,7 @@ extern boolean dbg_debugpm;
 \r
 #define        XMS_INT                 0x2f\r
 #define        XMS_CALL(v)             _AH = (v);\\r
-                                               __asm call [WORD PTR XMSDriver]\r
+                                               __asm call [DWORD PTR XMSDriver]\r
 /*__asm { mov ah,[v]\*///}\r
 \r
 #define        XMS_VERSION             0x00\r
@@ -79,7 +80,7 @@ extern boolean dbg_debugpm;
 #define        XMS_GDISABLEA20 0x04\r
 #define        XMS_LENABLEA20  0x05\r
 #define        XMS_LDISABLEA20 0x06\r
-#define        XMS_QUERYA20    0x07\r
+#define        XMS_QUERYA20            0x07\r
 \r
 #define        XMS_QUERYFREE   0x08\r
 #define        XMS_ALLOC               0x09\r
@@ -106,6 +107,8 @@ extern boolean dbg_debugpm;
 extern void            (* beforesort) (void);\r
 extern void            (* aftersort) (void);\r
 extern void            (* XMSaddr) (void);             // far pointer to XMS driver\r
+extern dword   XMSDriver;\r
+extern word            XMSVer;\r
 \r
 //==========================================================================\r
 \r
@@ -183,8 +186,8 @@ boolean MML_CheckForEMS(void);
 //byte MML_SetupEMS(mminfo_t *mm);\r
 //void MML_ShutdownEMS(mminfo_t *mm);\r
 byte MM_MapEMS(global_game_variables_t *gvar);\r
-byte MM_MapXEMS(global_game_variables_t *gvar);\r
-//boolean MML_CheckForXMS(mminfo_t *mm);\r
+//byte MM_MapXEMS(global_game_variables_t *gvar);\r
+boolean MML_CheckForXMS(void);\r
 //void MML_SetupXMS(mminfo_t *mm, mminfotype *mmi);\r
 //void MML_ShutdownXMS(mminfo_t *mm);\r
 void MML_UseSpace(word segstart, dword seglength, global_game_variables_t *gvar);\r
@@ -207,6 +210,7 @@ void MM_Report_(global_game_variables_t *gvar);
 void MM_BombOnError(boolean bomb, global_game_variables_t *gvar);\r
 //void MM_GetNewBlock(mminfo_t *mm);\r
 //void MM_FreeBlock(mmblocktype *x, mminfo_t *mm);\r
+void xms_call(byte v, global_game_variables_t *gvar);\r
 \r
 //==========================================================================\r
 \r