* Module: All Modules\r
* Author(s): Chris Somers\r
* Date: December 1, 1992\r
- * Version: V.1.1\r
+ * Version: V.1.1w\r
\r
minor mods by Alex Russell to simplify\r
\r
- Must use memory model with FAR code\r
+ Must use memory model with FAR code
+
+ Open Watcom patch by sparky4~\r
\r
*/\r
\r
-\r
#include <stdio.h>\r
#include <stdlib.h>\r
#include <mem.h>\r
+#include <conio.h>
\r
-#include "memory.h"\r
+#include "memory.h"
+
+#define PEMMDATAPAGENUM 4\r
\r
void TransformData(char *pEmmData, unsigned int len)\r
{\r
- while ( len )\r
- {\r
- (*pEmmData)++;\r
- pEmmData++;\r
+ while(len)\r
+ {\r
+ (*pEmmData)++;\r
+ pEmmData++;\r
\r
- len--;\r
- }\r
+ len--;\r
+ }\r
}\r
\r
-void main(void)\r
+int main(int argc, char *argv[])\r
{\r
- char *pEmmData;\r
- int hEData;\r
-\r
- if ( OpenEMM() != SUCCESS )\r
- { // make sure we got EMM\r
- printf("EMM unavailable.\n");\r
- exit(1);\r
- }\r
- else\r
- printf("Emm available\n");\r
-\r
- pEmmData = (char *)EMMalloc(&hEData, 6); // get 6 * 16K bytes - 96K\r
- if ( pEmmData == NULL )\r
- {\r
- printf("Not enough EMM or out of handles.\n");\r
- exit(2);\r
- }\r
- else\r
- printf("emm alloced OK\n");\r
-\r
-\r
- printf("Map 1st 4 pages\n");\r
- MapEMM(hEData, 0, 4); // load 1st 4 pages into page frame: 0-3\r
-\r
- memset(pEmmData, 0x0e, 64000u);\r
- UnmapEMM(hEData, 0, 4); // not absolutely necessary\r
- \r
- printf("Map next 2 pages\n");\r
- MapEMM(hEData, 4, 2); // map last 2 pages: 4-5\r
- memset(pEmmData, 0x0e, 32768u);\r
-\r
- MapEMM(hEData, 0, 4);\r
+ byte *pEmmData;
+ int hEData;
+ unsigned long advi;
+ unsigned long i=0;
+ char huge *p =(char huge *)(GetEMMSeg0()*0x10000);
+\r
+ if(OpenEMM() != SUCCESS)\r
+ { // make sure we got EMM\r
+ printf("EMM unavailable.\n");\r
+ exit(1);\r
+ }\r
+ else
+ {\r
+ printf("Emm %x available\n", EMVer());
+ printf("EMS pages available are %lu\n", EMMCoreLeft());
+ //printf("EMM Hardware Information %lu\n", EMInfo());
+ }\r
+
+ printf("b4 EMS pEmmData=%p\n", pEmmData);
+ //printf("b4 EMS *pEmmData=%s\n", *pEmmData);
+ advi=EMMCoreLeft()*EMMPAGESIZE;
+ printf("advi=%lu\n", advi);
+
+ pEmmData = (byte *)EMMalloc(&hEData, EMMCoreLeft()); // get 6 * 16K bytes - 96K
+ if(pEmmData == NULL/* || pEmmData0 == NULL*/)\r
+ {\r
+ printf("Not enough EMM or out of handles.\n");\r
+ exit(2);\r
+ }\r
+ else\r
+ printf("EMM allocate OK\n");\r
+
+ printf("EMS pages available are %lu\n", EMMCoreLeft());
+
+
+
+ printf("Map 1st 4 pages\n");\r
+ MapEMM(hEData, 0, PEMMDATAPAGENUM); // load 1st 4 pages into page frame: 0-3\r
+ //memset(pEmmData, 0x0e, 64000u);
+//0000 printf("(advi*EMMPAGESIZE)=%lu\n", advi);
+ memset(pEmmData, atoi(argv[1]), 0xffff);//sizeof(atoi(argv[1])));//((EMMCoreLeft())*EMMPAGESIZE));
+//qqqq memset(pEmmData+0x10000, atoi(argv[1]), 0xffff);//sizeof(atoi(argv[1])));//((EMMCoreLeft())*EMMPAGESIZE));
+//---- UnmapEMM(hEData, 0, 4); // not absolutely necessary
+ printf("%p= %c %c %c %c %c %c %c %c\n", pEmmData,
+*pEmmData, *(pEmmData+1), *(pEmmData+2), *(pEmmData+3), *(pEmmData+4), *(pEmmData+5), *(pEmmData+6), *(pEmmData+7));
+\r
+ /*printf("Map next 2 pages\n");\r
+ MapEMM(hEData, 4, 2); // map last 2 pages: 4-5\r
+ memset(pEmmData, 0x04, 32768u);
+// memset(pEmmData, atoi(argv[0]), 32768u);
+ printf("*pEmmData=%c\n", *pEmmData);
+ printf(" pEmmData=%p\n", pEmmData);*/
+\r
+ /*MapEMM(hEData, 0, 4);\r
// do some stuff with the first 64K of file data.\r
printf("Transform data\n");\r
- TransformData(pEmmData, 64000UL);\r
+ TransformData(pEmmData, 64000UL);
+ printf("*pEmmData=%lu\n", *pEmmData);\r
MapEMM(hEData, 4, 2); // only unmaps 1st two pages of prior 64k mapping\r
// do stuff with remaining 32K of data\r
- TransformData(pEmmData, 32768UL);\r
- UnmapEMM(hEData, 0, 4); // should unmap before freeing\r
-\r
- printf("Close emm\n");\r
- EMMFree(hEData); // finished with the file data\r
- CloseEMM();\r
+ TransformData(pEmmData, 32768UL);
+ printf("*pEmmData=%lu\n", *pEmmData);*/
+ if(atoi(argv[2]))
+ {
+ while(p<(char huge *)((GetEMMSeg0()*0x10000)+0xffff) && !kbhit())
+ {
+ if((i%16)==0) printf("%p= %c %c %c %c %c %c %c %c %c %c %c %c %c %c %c %c\n", p,
+*p, *(p+1), *(p+2), *(p+3), *(p+4), *(p+5), *(p+6), *(p+7),
+*(p+8), *(p+9), *(p+10), *(p+11), *(p+12), *(p+13), *(p+14), *(p+15));
+ // (*p)++;
+ i++;
+ p++;
+ }
+ }
+ /*if(atoi(argv[3]))
+ p =(char huge *)(GetEMMSeg0()*0x20000);
+ while(p<(char huge *)((GetEMMSeg0()*0x20000)+0xffff) && !kbhit())
+ {
+ if((i%16)==0) printf("%p= %c %c %c %c %c %c %c %c %c %c %c %c %c %c %c %c\n", p,
+*p, *(p+1), *(p+2), *(p+3), *(p+4), *(p+5), *(p+6), *(p+7),
+*(p+8), *(p+9), *(p+10), *(p+11), *(p+12), *(p+13), *(p+14), *(p+15));
+ // (*p)++;
+ i++;
+ p++;
+ }
+ //free(p);
+ }*/
+ if(!atoi(argv[3]))
+ {\r
+ UnmapEMM(hEData, 0, PEMMDATAPAGENUM); // should unmap before freeing
+ //printf("after EMS *pEmmData=%c\n", *pEmmData);\r
+ printf("Close emm\n");\r
+ EMMFree(hEData); // finished with the file data\r
+ CloseEMM();
+ }
+ printf("after EMS pEmmData=%p\n", pEmmData);
+ printf("EMS pages available are %lu\n", EMMCoreLeft());
+ printf("GetEMMSeg0=%p\n", GetEMMSeg0()*0x10000);
+ //printf("EMMPAGESIZE=%d\n", EMMPAGESIZE);
+ return 0;
}\r