]> 4ch.mooo.com Git - 16.git/blob - src/emmtest.c
eefab9ea8cf7337f1a8740d6b0ba38818e92614e
[16.git] / src / emmtest.c
1 // Cut this out as emm.c\r
2 \r
3 /*      File:       emm.c\r
4  *      Module:     All Modules\r
5  *      Author(s):  Chris Somers\r
6  *      Date:       December 1, 1992\r
7  *      Version:    V.1.1w\r
8 \r
9         minor mods by Alex Russell to simplify\r
10 \r
11         Must use memory model with FAR code
12
13                 Open Watcom patch by sparky4~\r
14 \r
15  */\r
16 \r
17 #include <stdio.h>\r
18 #include <stdlib.h>\r
19 #include <mem.h>\r
20 #include <conio.h>
21 \r
22 #include "src/lib/exmm/memory.h"
23 #include "src/lib/types.h"
24
25 #define PEMMDATAPAGENUM 4\r
26 \r
27 void TransformData(char *pEmmData, unsigned int len)\r
28 {\r
29         while(len)\r
30         {\r
31                 (*pEmmData)++;\r
32                 pEmmData++;\r
33 \r
34                 len--;\r
35         }\r
36 }\r
37 \r
38 int main(int argc, char *argv[])\r
39 {\r
40         byte *pEmmData;
41         int hEData;
42         unsigned long advi;
43         unsigned long i=0;
44         char huge *p =(char huge *)(GetEMMSeg0()*0x10000);
45 \r
46         if(OpenEMM() != SUCCESS)\r
47         {               // make sure we got EMM\r
48                 printf("EMM unavailable.\n");\r
49                 exit(1);\r
50         }\r
51         else
52         {\r
53                 printf("Emm %x available\n", EMVer());
54                 printf("EMS pages available are %lu\n", EMMCoreLeft());
55                 //printf("EMM Hardware Information %lu\n", EMInfo());
56         }\r
57
58         printf("b4 EMS          pEmmData=%p\n", pEmmData);
59         //printf("b4 EMS        *pEmmData=%s\n", *pEmmData);
60         advi=EMMCoreLeft()*EMMPAGESIZE;
61         printf("advi=%lu\n", advi);
62
63         pEmmData = (byte *)EMMalloc(&hEData, EMMCoreLeft());  // get 6 * 16K bytes - 96K
64         if(pEmmData == NULL/* ||  pEmmData0 == NULL*/)\r
65         {\r
66                 printf("Not enough EMM or out of handles.\n");\r
67                 exit(2);\r
68         }\r
69         else\r
70                 printf("EMM allocate OK\n");\r
71
72         printf("EMS pages available are %lu\n", EMMCoreLeft());
73
74
75
76         printf("Map 1st 4 pages\n");\r
77         MapEMM(hEData, 0, PEMMDATAPAGENUM);   // load 1st 4 pages into page frame: 0-3\r
78         //memset(pEmmData, 0x0e, 64000u);
79 //0000  printf("(advi*EMMPAGESIZE)=%lu\n", advi);
80         memset(pEmmData, atoi(argv[1]), 0xffff);//sizeof(atoi(argv[1])));//((EMMCoreLeft())*EMMPAGESIZE));
81 //qqqq  memset(pEmmData+0x10000, atoi(argv[1]), 0xffff);//sizeof(atoi(argv[1])));//((EMMCoreLeft())*EMMPAGESIZE));
82 //----  UnmapEMM(hEData, 0, 4);          // not absolutely necessary
83         printf("%p= %c %c %c %c %c %c %c %c\n", pEmmData,
84 *pEmmData, *(pEmmData+1), *(pEmmData+2), *(pEmmData+3), *(pEmmData+4), *(pEmmData+5), *(pEmmData+6), *(pEmmData+7));
85 \r
86         /*printf("Map next 2 pages\n");\r
87         MapEMM(hEData, 4, 2);            // map last 2 pages: 4-5\r
88         memset(pEmmData, 0x04, 32768u);
89 //      memset(pEmmData, atoi(argv[0]), 32768u);
90         printf("*pEmmData=%c\n", *pEmmData);
91         printf(" pEmmData=%p\n", pEmmData);*/
92 \r
93    /*MapEMM(hEData, 0, 4);\r
94    // do some stuff with the first 64K of file data.\r
95    printf("Transform data\n");\r
96    TransformData(pEmmData, 64000UL);
97         printf("*pEmmData=%lu\n", *pEmmData);\r
98    MapEMM(hEData, 4, 2);  // only unmaps 1st two pages of prior 64k mapping\r
99    // do stuff with remaining 32K of data\r
100    TransformData(pEmmData, 32768UL);
101         printf("*pEmmData=%lu\n", *pEmmData);*/
102         if(atoi(argv[2]))
103         {
104                 while(p<(char huge *)((GetEMMSeg0()*0x10000)+0xffff) && !kbhit())
105                 {
106                         if((i%16)==0) printf("%p= %c %c %c %c %c %c %c %c %c %c %c %c %c %c %c %c\n", p,
107 *p, *(p+1), *(p+2), *(p+3), *(p+4), *(p+5), *(p+6), *(p+7),
108 *(p+8), *(p+9), *(p+10), *(p+11), *(p+12), *(p+13), *(p+14), *(p+15));
109         //              (*p)++;
110                         i++;
111                         p++;
112                 }
113         }
114         /*if(atoi(argv[3]))
115                 p =(char huge *)(GetEMMSeg0()*0x20000);
116                 while(p<(char huge *)((GetEMMSeg0()*0x20000)+0xffff) && !kbhit())
117                 {
118                         if((i%16)==0) printf("%p= %c %c %c %c %c %c %c %c %c %c %c %c %c %c %c %c\n", p,
119 *p, *(p+1), *(p+2), *(p+3), *(p+4), *(p+5), *(p+6), *(p+7),
120 *(p+8), *(p+9), *(p+10), *(p+11), *(p+12), *(p+13), *(p+14), *(p+15));
121         //              (*p)++;
122                         i++;
123                         p++;
124                 }
125                 //free(p);
126         }*/
127         if(!atoi(argv[3]))
128         {\r
129                 UnmapEMM(hEData, 0, PEMMDATAPAGENUM);  // should unmap before freeing
130                 //printf("after EMS     *pEmmData=%c\n", *pEmmData);\r
131                 printf("Close emm\n");\r
132                 EMMFree(hEData);     // finished with the file data\r
133                 CloseEMM();
134         }
135         printf("after EMS       pEmmData=%p\n", pEmmData);
136         printf("EMS pages available are %lu\n", EMMCoreLeft());
137         printf("GetEMMSeg0=%p\n", GetEMMSeg0()*0x10000);
138         //printf("EMMPAGESIZE=%d\n", EMMPAGESIZE);
139         return 0;
140 }\r