home *** CD-ROM | disk | FTP | other *** search
/ OS/2 Shareware BBS: 10 Tools / 10-Tools.zip / warphead.zip / H / VVD.H < prev    next >
C/C++ Source or Header  |  1997-04-10  |  45KB  |  1,061 lines

  1. /***    VVD.H
  2.  *
  3.  *
  4.  *      MVDM Virtual Video Exported Definitions
  5.  *      Copyright (c) 1993 IBM Corporation
  6.  *
  7.  *      For include file hierarchy, see MVDM.H
  8.  *
  9.  *      Options:
  10.  *          INCL_VIDEO      include all video definitions
  11.  *          INCL_VIDEOHW    include hardware-dependent definitions
  12.  *          INCL_VIDEOVDD   include VDD-support definitions
  13.  *
  14.  *
  15.  *
  16.  */
  17.  
  18. #pragma checkout( suspend )
  19.    #ifndef __CHKHDR__
  20.       #pragma checkout( suspend )
  21.    #endif
  22. #pragma checkout( resume )
  23.  
  24. #ifndef __VVD__
  25. #define __VVD__
  26.  
  27.  
  28. #ifndef INCL_NONE               /* include everything by default */
  29. #define INCL_VIDEO
  30. #endif
  31.  
  32. #ifdef  INCL_VIDEO
  33. #define INCL_VIDEOHW
  34. #define INCL_VIDEOPTR
  35. #define INCL_VIDEOSYSREQ
  36. #define INCL_VIDEODEVREQ
  37. #define INCL_VIDEOINTERFACES
  38. #endif
  39.  
  40. #ifdef  INCL_DBCSVDM
  41. #define ATLAS
  42. #define GALE
  43. #endif  //INCL_DBCSVDM
  44. #ifdef  GALE
  45. #define ATLAS_GALE
  46. #endif  //GALE
  47. #ifdef  ATLAS
  48. #define ATLAS_GALE
  49. #endif  //ATLAS
  50.  
  51. #ifdef INCL_VIDEOPTR
  52. #include <vmd.h>
  53. #endif
  54.  
  55.  
  56. #ifdef  INCL_VIDEOHW
  57.  
  58. /***EK+ Extended (non-BIOS) EGA INT 10h functions
  59.  */
  60.  
  61. #define INT10_EGAREADONE    0xF0        /* Read one EGA reg */
  62. #define INT10_EGAWRITEONE   0xF1        /* Write one EGA reg */
  63. #define INT10_EGAREADRANGE  0xF2        /* Read multiple EGA regs */
  64. #define INT10_EGAWRITERANGE 0xF3        /* Write multiple EGA regs */
  65. #define INT10_EGAREADSET    0xF4        /* Read set of EGA regs */
  66. #define INT10_EGAWRITESET   0xF5        /* Write set of EGA regs */
  67. #define INT10_EGAREVERTDEF  0xF6        /* Revert to default */
  68. #define INT10_EGADEFINEDEF  0xF7        /* Define default */
  69. #define INT10_EGAQUERYDEF   0xF8        /* Query default */
  70. #define INT10_EGACONTEXT    0xF9        /* Get context information */
  71. #define INT10_EGAINQUIRE    0xFA        /* Get EGA driver version */
  72.  
  73. #define INT10_EGAFIRST      INT10_EGAREADONE
  74. #define INT10_EGALAST       INT10_EGAINQUIRE
  75.  
  76.  
  77. /* Default physical memory locations
  78.  */
  79.  
  80. #define PLANE0              0
  81. #define PLANE1              1
  82. #define PLANE2              2
  83. #define PLANE3              3
  84.  
  85. #define MONOMEM_START       0xB0000
  86. #define MONOMEM_LEN         (4*1024)
  87. #ifdef  PAGESIZE
  88. #define MONOMEM_PAGES       (MONOMEM_LEN/PAGESIZE)
  89. #endif
  90.  
  91. #define CGAMEM_START        0xB8000
  92. #define CGAMEM_LEN          (16*1024)
  93. #ifdef  PAGESIZE
  94. #define CGAMEM_PAGES        (CGAMEM_LEN/PAGESIZE)
  95. #endif
  96.  
  97. #define EGAVGAMEM_START     0xA0000
  98. #define EGAVGAMEM_LEN       (128*1024)
  99. #ifdef  PAGESIZE
  100. #define EGAVGAMEM_PAGES     (EGAVGAMEM_LEN/PAGESIZE)
  101. #endif
  102.  
  103.  
  104. /*  Hardware ports
  105.  *
  106.  *  All are single-register ports unless otherwise specified;
  107.  *  All single-register ports are W/O unless VGA or otherwise specified
  108.  */
  109.  
  110. #define PORT_ATIVGA_INDX    0x1CE       /* used by ATI VGA Wonder */
  111. #define PORT_ATIVGA_DATA    0x1CF       /* used by ATI VGA Wonder */
  112. #define PORT_MONOCRTINDX    0x3B4
  113. #define PORT_MONOCRTDATA    0x3B5       /* multi-register port */
  114. #define PORT_MONOMODE       0x3B8       /* usually shadowed at uBiosVModeByte */
  115. #define PORT_MONOLPENSET    0x3B9
  116. #define PORT_MONOSTATUS1    0x3BA       /* (R/O) */
  117. #define PORT_MONOFEATURE    0x3BA       /* (W/O) */
  118. #define PORT_MONOLPENRESET  0x3BB
  119. #define PORT_ATC0           0x3C0
  120. #define PORT_ATC1           0x3C1       /* on VGA, distinct from ATC0 and R/O */
  121. #define PORT_STATUS0        0x3C2       /* (R/O) */
  122. #define PORT_MISCOUT        0x3C2       /* reset sequencer before writing */
  123. #define PORT_VGAENABLE      0x3C3
  124. #define PORT_SEQINDX        0x3C4
  125. #define PORT_SEQDATA        0x3C5       /* multi-register port */
  126. #define PORT_COMPAQ_CTRL    0x3C6
  127. #define PORT_VGADACMASK     0x3C6       /* initialized to 0FFh, leave alone */
  128. #define PORT_VGADACREAD     0x3C7       /* State (R), Index to read (W) */
  129. #define PORT_VGADACWRITE    0x3C8       /* Index to write (R/W) */
  130. #define PORT_VGADACDATA     0x3C9       /* multi-register port */
  131. #define PORT_GDCPOS2        0x3CA       /* on VGA, R/O (returns FEATURE) */
  132. #define PORT_ATIEGA_INDX    0x3CB       /* used by ATI EGA Wonder */
  133. #define PORT_GDCPOS1        0x3CC       /* on VGA, R/O (returns MISCOUT) */
  134. #define PORT_ATIEGA_DATA    0x3CD       /* used by ATI EGA Wonder */
  135. #define PORT_GDCINDX        0x3CE
  136. #define PORT_GDCDATA        0x3CF       /* multi-register port */
  137. #define PORT_COLRCRTINDX    0x3D4
  138. #define PORT_COLRCRTDATA    0x3D5       /* multi-register port */
  139. #define PORT_CGAMODE        0x3D8       /* usually shadowed at uBiosVModeByte */
  140. #define PORT_CGACOLOR       0x3D9       /* usually shadowed at uBiosVColorByte */
  141. #define PORT_COLRSTATUS1    0x3DA       /* (R/O) */
  142. #define PORT_COLRFEATURE    0x3DA       /* (W/O) */
  143. #define PORT_CGALPENRESET   0x3DB
  144. #define PORT_CGALPENSET     0x3DC
  145. #define PORT_COMPAQ_ENV     0x7C6       /* (R/O) */
  146. #define PORT_COMPAQ_DSP     0xBC6       /* (R/O) */
  147. #define PORT_IBMP70_INDX    0xD00       /* special port for plasma display? */
  148. #define PORT_IBMP70_DATA    0xD01       /* special port for plasma display? */
  149. #define PORT_COMPAQ_MODE    0xFC6       /* (R/O) */
  150.  
  151. /* 8514/A Display Controller registers (word registers unless noted otherwise)
  152.  */
  153. #define A8514_DSPSTAT       0x02E8      /* (R/O) */
  154. #define   DSPSTAT_PALSTAT       0x0001
  155. #define   DSPSTAT_VERTRTRC      0x0002
  156. #define   DSPSTAT_HORZRTRC      0x0004
  157. #define A8514_HORZTOTAL     0x02E8      /* (W/O) */
  158. #define A8514_DACMASK       0x02EA      /* pixel planes displayed   (R/W-byte) */
  159. #define A8514_DACREADINDEX  0x02EB      /* DAC data reg/mode select (R/W-byte) */
  160. #define A8514_DACWRITEINDEX 0x02EC      /* DAC data reg/mode select (R/W-byte) */
  161. #define A8514_DACDATA       0x02ED      /* DAC data register        (R/W-byte) */
  162. #define A8514_HORZDSP       0x06E8      /* (W/O) */
  163. #define A8514_HORZSSTART    0x0AE8      /* (W/O) */
  164. #define A8514_HORZSWIDTH    0x0EE8      /* (W/O) */
  165. #define A8514_VERTTOTAL     0x12E8      /* (W/O) */
  166. #define A8514_VERTDSP       0x16E8      /* (W/O) */
  167. #define A8514_VERTSSTART    0x1AE8      /* (W/O) */
  168. #define A8514_VERTSWIDTH    0x1EE8      /* (W/O) */
  169. #define A8514_DSPCTRL       0x22E8      /* (W/O) */
  170. #define   DSPCTRL_ODDEVEN       0x0001
  171. #define   DSPCTRL_CAS2          0x0000  /* this implies 4-plane setting */
  172. #define   DSPCTRL_CAS4          0x0002  /* this implies 8-plane setting */
  173. #define   DSPCTRL_CAS6          0x0004
  174. #define   DSPCTRL_CAS8          0x0006
  175. #define   DSPCTRL_CASMASK       0x0006
  176. #define   DSPCTRL_SCANDBL       0x0008
  177. #define   DSPCTRL_INTERLACE     0x0010
  178. #define   DSPCTRL_DSPENABLE     0x0020
  179. #define   DSPCTRL_DSPDISABLE    0x0040
  180. #define   DSPCTRL_DSPCTRLMASK   0x0060
  181.  
  182. /* 8514/A Configuration/Status registers (word registers unless noted otherwise)
  183.  */
  184. #define A8514_SUBSYSCTRL    0x42E8      /* (W/O) */
  185. #define   SUBCTRL_RESETVERTF    0x0001
  186. #define   SUBCTRL_RESETDTR      0x0002
  187. #define   SUBCTRL_RESETQFULL    0x0004
  188. #define   SUBCTRL_RESETGPIDLE   0x0008
  189. #define   SUBCTRL_INTONVERTF    0x0100
  190. #define   SUBCTRL_INTONDTR      0x0200
  191. #define   SUBCTRL_INTONQFULL    0x0400
  192. #define   SUBCTRL_INTONGPIDLE   0x0800
  193. #define   SUBCTRL_PIXENABLE     0x1000
  194. #define   SUBCTRL_PIXDISABLE    0x2000
  195. #define   SUBCTRL_PIXCTRLMASK   0x3000
  196. #define   SUBCTRL_SEQENABLE     0x4000
  197. #define   SUBCTRL_SEQDISABLE    0x8000
  198. #define   SUBCTRL_SEQCTRLMASK   0xC000
  199. #define A8514_SUBSYSSTATUS  0x42E8      /* (R/O) */
  200. #define   SUBSTATUS_VERTF       0x0001
  201. #define   SUBSTATUS_DTR         0x0002
  202. #define   SUBSTATUS_QFULL       0x0004
  203. #define   SUBSTATUS_GPIDLE      0x0008
  204. #define   SUBSTATUS_MONITORID   0x0070
  205. #define   SUBSTATUS_8503        0x0050
  206. #define   SUBSTATUS_8512_3      0x0060
  207. #define   SUBSTATUS_8514        0x0020
  208. #define   SUBSTATUS_MONOCHROME  0x0010
  209. #define   SUBSTATUS_NOT8514     0x0040
  210. #define   SUBSTATUS_MEMORYOPT   0x0080
  211. #define A8514_ROMPAGESELECT 0x46E8      /* (W/O) */
  212. #define A8514_ADVCTRL       0x4AE8      /* (W/O) */
  213. #define   ADVCTRL_VGADISABLE    0x0001
  214. #define   ADVCTRL_OUTPUTPIN     0x0002
  215. #define   ADVCTRL_DOTCLOCK      0x0004  /* 0 implies 640x480 mode */
  216.  
  217. /* 8514/A Graphics Processor registers (word registers unless noted otherwise)
  218.  */
  219. #define A8514_COMMAND       0x9AE8      /* (W/O) */
  220. #define   COMMAND_WRITE         0x0001  /* 0 implies read function */
  221. #define   COMMAND_PLANAR        0x0002  /* 0 implies pixel-access mode */
  222. #define   COMMAND_LASTPIXNULL   0x0004  /* 0 implies last pixel will be drawn */
  223. #define   COMMAND_STROKEALG     0x0008  /* 0 implies H/W line-drawing algorithm */
  224. #define   COMMAND_DRAW          0x0010  /* 0 implies move current position only */
  225. #define   COMMAND_INCX          0x0020  /* 0 implies decrement X */
  226. #define   COMMAND_MAJORY        0x0040  /* 0 implies X is major axis */
  227. #define   COMMAND_INCY          0x0080  /* 0 implies decrement Y */
  228. #define   COMMAND_PCDATAXFER    0x0100  /* 0 implies no PC intervention */
  229. #define   COMMAND_PCDATA16BIT   0x0200  /* 0 implies base pixel count per access */
  230. #define   COMMAND_PIXEL16BIT    0x0400  /* 0 implies 8-bit pixel transfers */
  231. #define   COMMAND_SWAPBYTES     0x1000  /* 0 implies even pixels from low bytes */
  232. #define   COMMAND_FUN_NONE      0x0000
  233. #define   COMMAND_FUN_LINE      0x2000
  234. #define   COMMAND_FUN_FILLX     0x4000
  235. #define   COMMAND_FUN_FILLY     0x6000
  236. #define   COMMAND_FUN_FILL      0x8000
  237. #define   COMMAND_FUN_AXIALLINE 0xA000
  238. #define   COMMAND_FUN_COPY      0xC000
  239. #define   COMMAND_FUNMASK       0xF000
  240. #define A8514_STATUS        0x9AE8      /* (R/O) */
  241. #define   STATUS_QUEUE1_INUSE   0x0001
  242. #define   STATUS_QUEUE2_INUSE   0x0002
  243. #define   STATUS_QUEUE3_INUSE   0x0004
  244. #define   STATUS_QUEUE4_INUSE   0x0008
  245. #define   STATUS_QUEUE5_INUSE   0x0010
  246. #define   STATUS_QUEUE6_INUSE   0x0020
  247. #define   STATUS_QUEUE7_INUSE   0x0040
  248. #define   STATUS_QUEUE8_INUSE   0x0080
  249. #define   STATUS_DATA_AVAILABLE 0x0100
  250. #define   STATUS_COMMAND_ACTIVE 0x0200
  251.  
  252. /* 8514/A Coordinate registers (word registers unless noted otherwise)
  253.  */
  254. #define A8514_CURRENTY      0x82E8      /* (R/W) */
  255. #define A8514_CURRENTX      0x86E8      /* (R/W) */
  256. #define A8514_DESTY_AXSTP   0x8AE8      /* (W/O) */
  257. #define A8514_DESTX_DIASTP  0x8EE8      /* (W/O) */
  258. #define A8514_ERRORTERM     0x92E8      /* suitable for presence test (R/W) */
  259. #define A8514_MAJORAXISCNT  0x96E8      /* (W/O) */
  260.  
  261. /* 8514/A Multi-function control registers (word registers unless noted otherwise)
  262.  */
  263. #define A8514_MULTIFUNCTION 0xBEE8      /* (W/O) */
  264. #define   MFINDX_MINORAXISCNT   0x0000
  265. #define   MFINDX_TOPSCISSORS    0x1000
  266. #define   MFINDX_LEFTSCISSORS   0x2000
  267. #define   MFINDX_BOTTOMSCISSORS 0x3000
  268. #define   MFINDX_RIGHTSCISSORS  0x4000
  269. #define   MFINDX_MEMORYCTRL     0x5000
  270. #define     MEMCTRL_WRITE4          0x0000
  271. #define     MEMCTRL_WRITE5          0x0001
  272. #define     MEMCTRL_WRITE8          0x0002
  273. #define     MEMCTRL_WRITE10         0x0003
  274. #define     MEMCTRL_WRITEMASK       0x0003
  275. #define     MEMCTRL_CAS2            0x0000  /* this implies 4-plane setting */
  276. #define     MEMCTRL_CAS4            0x0004  /* this implies 8-plane setting */
  277. #define     MEMCTRL_CAS6            0x0008
  278. #define     MEMCTRL_CAS8            0x000C
  279. #define     MEMCTRL_CASMASK         0x000C
  280. #define     MEMCTRL_CASSWAP         0x0010
  281. #define   MFINDX_PATTERNLOW     0x8000
  282. #define   MFINDX_PATTERNHIGH    0x9000
  283. #define   MFINDX_PIXELCTRL      0xA000
  284. #define     PIXELCTRL_5PIXELROTATE  0x0001
  285. #define     PIXELCTRL_MASKSELECT    0x0002
  286. #define     PIXELCTRL_PLANAR        0x0004
  287. #define     PIXELCTRL_COLORFALSE    0x0000
  288. #define     PIXELCTRL_COLORTRUE     0x0008
  289. #define     PIXELCTRL_COLORGE       0x0010
  290. #define     PIXELCTRL_COLORLT       0x0018
  291. #define     PIXELCTRL_COLORNE       0x0020
  292. #define     PIXELCTRL_COLOREQ       0x0028
  293. #define     PIXELCTRL_COLORLE       0x0030
  294. #define     PIXELCTRL_COLORGT       0x0038
  295. #define     PIXELCTRL_MIXFGND       0x0000
  296. #define     PIXELCTRL_FIXEDPATTERN  0x0040
  297. #define     PIXELCTRL_PLANARWRITE   0x0080
  298. #define     PIXELCTRL_SINGLEPLANE   0x00C0
  299. #define   MFINDX_INDXMASK       0xF000
  300. #define   MFINDX_DATAMASK       0x0FFF
  301. #define   MFINDX_INDXSHIFT      12
  302. #define   MFINDX_INDXTOTAL      16
  303.  
  304. /* 8514/A Pixel processing registers (word registers unless noted otherwise)
  305.  */
  306. #define A8514_SHORTSTROKE   0x9EE8      /* (W/O) */
  307. #define A8514_BGNDCOLOR     0xA2E8      /* (W/O) */
  308. #define A8514_FGNDCOLOR     0xA6E8      /* (W/O) */
  309. #define A8514_WRITEMASK     0xAAE8      /* (W/O) */
  310. #define A8514_READMASK      0xAEE8      /* (W/O) */
  311. #define A8514_COLORCOMPARE  0xB2E8      /* (W/O) */
  312. #define A8514_BGNDMIX       0xB6E8      /* (W/O) */
  313. #define A8514_FGNDMIX       0xBAE8      /* (W/O) */
  314. #define     FGNDMIX_SOURCE      0x0007
  315. #define     FGNDMIX_BGNDCLR     0x0000
  316. #define     FGNDMIX_FGNDCLR     0x0020
  317. #define     FGNDMIX_PIXELDATA   0x0040
  318. #define     FGNDMIX_PLANECOPY   0x0060
  319. #define A8514_PIXELTRANSFER 0xE2E8      /* (R/W) */
  320.  
  321. /* XGA I/O Registers (all byte registers) */
  322.  
  323. #define  AXGA_OPERATING_MODE              0  /* private indexes into */
  324. #define  AXGA_APERTURE_CONTROL            1  /*   awregXGAIOReg[].  See */
  325. #define  AXGA_RESERVED1                   2  /*   VVXGAREGS structure */
  326. #define  AXGA_RESERVED2                   3  /*   definition in VVXGAP.H */
  327. #define  AXGA_INTERRUPT_ENABLE            4  /*   for detail */
  328. #define  AXGA_INTERRUPT_STATUS            5
  329. #define  AXGA_VIRTUAL_MEMORY_CONTROLLER   6
  330. #define  AXGA_VIRTUAL_MEMORY_INT_STATUS   7
  331. #define  AXGA_APERTURE_INDEX              8
  332. #define  AXGA_MEMORY_ACCESS_MODE          9
  333. #define  AXGA_INDEX_SELECT                10
  334. #define  AXGA_INDEX_DATA_B                11
  335. #define  AXGA_INDEX_DATA_C                12
  336. #define  AXGA_INDEX_DATA_D                13
  337. #define  AXGA_INDEX_DATA_E                14
  338. #define  AXGA_INDEX_DATA_F                15
  339. #define  AXGA_TOTAL                       16
  340.  
  341. /* XGA Index Registers (all byte register) */
  342. #define  AINDX_RESERVED0               0x0000   /* (R/W) */
  343. #define  AINDX_RESERVED1               0x0001   /* (R/O) */
  344. #define  AINDX_RESERVED2               0x0002   /* (R/O) */
  345. #define  AINDX_RESERVED3               0x0003   /* (R/O) */
  346. #define  AINDX_AUTOCONFIG              0x0004   /* (R/O) */
  347. #define  AINDX_RESERVED5               0x0005   /* (R/O) */
  348. #define  AINDX_RESERVED6               0x0006   /* (R/O) */
  349. #define  AINDX_RESERVED7               0x0007   /* (R/O) */
  350. #define  AINDX_RESERVED8               0x0008   /* (R/O) */
  351. #define  AINDX_RESERVED9               0x0009   /* (R/O) */
  352. #define  AINDX_RESERVEDa               0x000a   /* (R/O) */
  353. #define  AINDX_RESERVEDb               0x000b   /* (R/O) */
  354. #define  AINDX_COPROCSAVERESTOREA      0x000c   /* (R/O) */
  355. #define  AINDX_COPROCSAVERESTOREB      0x000d   /* (R/O) */
  356. #define  AINDX_RESERVEDe               0x000e   /* (R/O) */
  357. #define  AINDX_RESERVEDf               0x000f   /* (R/O) */
  358. #define  AINDX_HORZTOTALLO             0x0010   /* (R/W) */
  359. #define  AINDX_HORZTOTALHI             0x0011   /* (R/W) */
  360. #define  AINDX_HORZDISPENDLO           0x0012   /* (R/W) */
  361. #define  AINDX_HORZDISPENDHI           0x0013   /* (R/W) */
  362. #define  AINDX_HORZBLANKINGSTARTLO     0x0014   /* (R/W) */
  363. #define  AINDX_HORZBLANKINGSTARTHI     0x0015   /* (R/W) */
  364. #define  AINDX_HORZBLANKINGENDLO       0x0016   /* (R/W) */
  365. #define  AINDX_HORZBLANKINGENDHI       0x0017   /* (R/W) */
  366. #define  AINDX_HORZSYNCPULSESTARTLO    0x0018   /* (R/W) */
  367. #define  AINDX_HORZSYNCPULSESTARTHI    0x0019   /* (R/W) */
  368. #define  AINDX_HORZSYNCPULSEENDLO      0x001a   /* (R/W)    132 Column Reg */
  369. #define  AINDX_HORZSYNCPULSEENDHI      0x001b   /* (R/W)    132 Column Reg */
  370. #define  AINDX_HORZSYNCPOSITION1       0x001c   /* (W/O) */
  371. #define  AINDX_RESERVED1d              0x001d   /* (R/O) */
  372. #define  AINDX_HORZSYNCPOSITION2       0x001e   /* (W/O) */
  373. #define  AINDX_RESERVED1f              0x001f   /* (R/O) */
  374. #define  AINDX_VERTTOTALLO             0x0020   /* (R/W) */
  375. #define  AINDX_VERTTOTALHI             0x0021   /* (R/W) */
  376. #define  AINDX_VERTDISPENDLO           0x0022   /* (R/W) */
  377. #define  AINDX_VERTDISPENDHI           0x0023   /* (R/W) */
  378. #define  AINDX_VERTBLANKINGSTARTLO     0x0024   /* (R/W) */
  379. #define  AINDX_VERTBLANKINGSTARTHI     0x0025   /* (R/W) */
  380. #define  AINDX_VERTBLANKINGENDLO       0x0026   /* (R/W) */
  381. #define  AINDX_VERTBLANKINGENDHI       0x0027   /* (R/W) */
  382. #define  AINDX_VERTSYNCPULSESTARTLO    0x0028   /* (R/W) */
  383. #define  AINDX_VERTSYNCPULSESTARTHI    0x0029   /* (R/W) */
  384. #define  AINDX_VERTSYNCPULSEEND        0x002a   /* (R/W)    132 Column Reg */
  385. #define  AINDX_RESERVED2b              0x002b   /* (R/O) */
  386. #define  AINDX_VERTLINECOMPLO          0x002c   /* (R/W) */
  387. #define  AINDX_VERTLINECOMPHI          0x002d   /* (R/W) */
  388. #define  AINDX_RESERVED2e              0x002e   /* (R/O) */
  389. #define  AINDX_RESERVED2f              0x002f   /* (R/O) */
  390. #define  AINDX_SPRITEHORZSTARTLO       0x0030   /* (R/W) */
  391. #define  AINDX_SPRITEHORZSTARTHI       0x0031   /* (R/W) */
  392. #define  AINDX_SPRITEHORZPRESET        0x0032   /* (R/W) */
  393. #define  AINDX_SPRITEVERTSTARTLO       0x0033   /* (R/W) */
  394. #define  AINDX_SPRITEVERTSTARTHI       0x0034   /* (R/W) */
  395. #define  AINDX_SPRITEVERTPRESET        0x0035   /* (R/W) */
  396. #define  AINDX_SPRITECONTROL           0x0036   /* (R/W) */
  397. #define  AINDX_RESERVED37              0x0037   /* (R/O) */
  398. #define  AINDX_SPRITECOLOR0RED         0x0038   /* (R/W) */
  399. #define  AINDX_SPRITECOLOR0GREEN       0x0039   /* (R/W) */
  400. #define  AINDX_SPRITECOLOR0BLUE        0x003a   /* (R/W) */
  401. #define  AINDX_SPRITECOLOR1RED         0x003b   /* (R/W) */
  402. #define  AINDX_SPRITECOLOR1GREEN       0x003c   /* (R/W) */
  403. #define  AINDX_SPRITECOLOR1BLUE        0x003d   /* (R/W) */
  404. #define  AINDX_RESERVED3e              0x003e   /* (R/O) */
  405. #define  AINDX_RESERVED3f              0x003f   /* (R/O) */
  406. #define  AINDX_DISPPIXELMAPOFFSETLO    0x0040   /* (R/W) */
  407. #define  AINDX_DISPPIXELMAPOFFSETMI    0x0041   /* (R/W) */
  408. #define  AINDX_DISPPIXELMAPOFFSETHI    0x0042   /* (R/W) */
  409. #define  AINDX_DISPPIXELMAPWIDTHLO     0x0043   /* (R/W) */
  410. #define  AINDX_DISPPIXELMAPWIDTHHI     0x0044   /* (R/W) */
  411. #define  AINDX_RESERVED45              0x0045   /* (R/O) */
  412. #define  AINDX_RESERVED46              0x0046   /* (R/O) */
  413. #define  AINDX_RESERVED47              0x0047   /* (R/O) */
  414. #define  AINDX_RESERVED48              0x0048   /* (R/O) */
  415. #define  AINDX_RESERVED49              0x0049   /* (R/O) */
  416. #define  AINDX_RESERVED4a              0x004a   /* (R/O) */
  417. #define  AINDX_RESERVED4b              0x004b   /* (R/O) */
  418. #define  AINDX_RESERVED4c              0x004c   /* (R/O) */
  419. #define  AINDX_RESERVED4d              0x004d   /* (R/O) */
  420. #define  AINDX_RESERVED4e              0x004e   /* (R/O) */
  421. #define  AINDX_RESERVED4f              0x004f   /* (R/O) */
  422. #define  AINDX_DISPCONTROL1            0x0050   /* (R/W)    132 Column Reg */
  423. #define  AINDX_DISPCONTROL2            0x0051   /* (R/W) */
  424. #define  AINDX_DISPIDCOMPARATOR        0x0052   /* (R/O) */
  425. #define  AINDX_MYSTERYREG              0x0053   /* (R/O)    Referenced by AFI */
  426. #define  AINDX_CLOCKFREQSELECT         0x0054   /* (R/W)    132 Column Reg */
  427. #define  AINDX_BORDERCOLOR             0x0055   /* (R/W) */
  428. #define  AINDX_RESERVED56              0x0056   /* (R/O) */
  429. #define  AINDX_RESERVED57              0x0057   /* (R/O) */
  430. #define  AINDX_RESERVED58              0x0058   /* (R/O) */
  431. #define  AINDX_RESERVED59              0x0059   /* (R/O) */
  432. #define  AINDX_RESERVED5a              0x005a   /* (R/O) */
  433. #define  AINDX_RESERVED5b              0x005b   /* (R/O) */
  434. #define  AINDX_RESERVED5c              0x005c   /* (R/O) */
  435. #define  AINDX_RESERVED5d              0x005d   /* (R/O) */
  436. #define  AINDX_RESERVED5e              0x005e   /* (R/O) */
  437. #define  AINDX_RESERVED5f              0x005f   /* (R/O) */
  438. #define  AINDX_SPRITEPALETTEIDXLO      0x0060   /* (R/W) */
  439. #define  AINDX_SPRITEIDXHI             0x0061   /* (R/W) */
  440. #define  AINDX_SPRITEPALETTEIDXLOPREF  0x0062   /* (R/W) */
  441. #define  AINDX_SPRITEIDXHIPREFETCH     0x0063   /* (R/W) */
  442. #define  AINDX_PALETTEMASK             0x0064   /* (R/W) */
  443. #define  AINDX_PALETTEDATA             0x0065   /* (R/W) */
  444. #define  AINDX_PALETTESEQUENCE         0x0066   /* (R/W) */
  445. #define  AINDX_PALETTEREDPREFETCH      0x0067   /* (R/W) */
  446. #define  AINDX_PALETTEGREENPREFETCH    0x0068   /* (R/W) */
  447. #define  AINDX_PALETTEBLUEPREFETCH     0x0069   /* (R/W) */
  448. #define  AINDX_SPRITEDATA              0x006a   /* (R/W) */
  449. #define  AINDX_SPRITEPREFETCH          0x006b   /* (R/W) */
  450. #define  AINDX_RESERVED6c              0x006c   /* (R/O) */
  451. #define  AINDX_RESERVED6d              0x006d   /* (R/O) */
  452. #define  AINDX_RESERVED6e              0x006e   /* (R/O) */
  453. #define  AINDX_RESERVED6f              0x006f   /* (R/O) */
  454. #define  AINDX_EXTCLOCKSELECT          0x0070   /* (R/W)    132 Column Reg */
  455.  
  456. #define  IRINDX_INDXTOTAL              0x0071
  457. #define  IRINDX_INDXMASK               0x00FF
  458. #define  IRINDX_DATAMASK               0xFF00
  459. #define  IRINDX_DATASHIFT              8
  460.  
  461.  
  462. /*  Registers indexed via multi-register ports
  463.  *
  464.  *  All are W/O unless VGA or otherwise specified
  465.  */
  466.  
  467. #define REG_ATCPALETTE      0x00        /* 00h-0Fh are palette registers */
  468. #define REG_ATCMODECTRL     0x10        /* Compaq VGA: wait for vert retrace */
  469. #define REG_ATCOVERSCAN     0x11
  470. #define REG_ATCPLANEENABLE  0x12
  471. #define REG_ATCPELPANNING   0x13
  472. #define REG_ATCVGAREG       0x14
  473. #define TOTAL_EGA_ATCREGS   0x14
  474. #define TOTAL_IBM_ATCREGS   0x15
  475. #define TOTAL_TSENG_ATCREGS 0x18
  476.  
  477. #define REG_SEQRESET        0x00
  478. #define REG_SEQCLKMODE      0x01        /* reset sequencer before writing */
  479. #define REG_SEQMAPMASK      0x02
  480. #define REG_SEQCHARMAPSEL   0x03
  481. #define REG_SEQMEMMODE      0x04        /* reset sequencer before writing */
  482. #define REG_SEQUNKNOWN_IBM1 0x07
  483. #define TOTAL_IBM_SEQREGS   0x05
  484. #define TOTAL_TSENG_SEQREGS 0x08
  485.  
  486. #define REG_GDCSR           0x00
  487. #define REG_GDCESR          0x01
  488. #define REG_GDCCLRCMP       0x02
  489. #define REG_GDCROTATE       0x03
  490. #define REG_GDCREADMAP      0x04
  491. #define REG_GDCMODE         0x05
  492. #define REG_GDCMISC         0x06        /* reset sequencer before writing */
  493. #define REG_GDCDONTCARE     0x07
  494. #define REG_GDCBITMASK      0x08
  495. #define TOTAL_IBM_GDCREGS   0x09
  496. #define TOTAL_TSENG_GDCREGS 0x0F
  497.  
  498. #define REG_CRTHORZTOTAL    0x00
  499. #define REG_CRTHORZDSPEND   0x01
  500. #define REG_CRTHORZSTBLNK   0x02
  501. #define REG_CRTHORZENDBLNK  0x03
  502. #define REG_CRTHORZSTRTRC   0x04
  503. #define REG_CRTHORZENDRTRC  0x05
  504. #define REG_CRTVERTTOTAL    0x06
  505. #define REG_CRTOVERFLOW     0x07
  506. #define REG_CRTPRESETROW    0x08
  507. #define REG_CRTMAXSCAN      0x09
  508. #define REG_CRTCURSTSCAN    0x0A
  509. #define REG_CRTCURENDSCAN   0x0B
  510. #define REG_CRTSTARTADDRHI  0x0C        /* R/W (W/O on CGA???) */
  511. #define REG_CRTSTARTADDRLO  0x0D        /* R/W (W/O on CGA???) */
  512. #define REG_CRTCURLOCHI     0x0E        /* R/W */
  513. #define REG_CRTCURLOCLO     0x0F        /* R/W */
  514. #define REG_CRTVERTSTRTRC   0x10
  515. #define REG_CRTLPENHI       0x10        /* R/O (dual-purpose register index) */
  516. #define REG_CRTVERTENDRTRC  0x11
  517. #define REG_CRTLPENLO       0x11        /* R/O (dual-purpose register index) */
  518. #define REG_CRTVERTDSPEND   0x12
  519. #define REG_TSENG_CRTLPEN2  0x12        /* R/O (dual-purpose register index) */
  520. #define REG_CRTOFFSET       0x13
  521. #define REG_CRTUNDLINELOC   0x14
  522. #define REG_CRTVERTSTBLNK   0x15
  523. #define REG_CRTVERTENDBLNK  0x16
  524. #define REG_CRTMODECTRL     0x17
  525. #define REG_CRTLINECMP      0x18
  526. #define REG_CRTUNKNOWN_IBM1 0x3F
  527. #define TOTAL_CGA_CRTREGS   0x13
  528. #define TOTAL_IBM_CRTREGS   0x19
  529. #define TOTAL_TSENG_CRTREGS 0x26
  530.  
  531. #define TOTAL_DACREGS       256         /* on VGA, there are 256 color registers */
  532.  
  533.  
  534. /* Individual bits for registers
  535.  */
  536.  
  537. #define ATCPAL_ADDRMASK     0x01F
  538. #define ATCPAL_ENABLE       0x020
  539.  
  540. #define SEQRESET_ASYNC      0x001
  541. #define SEQRESET_SYNC       0x002
  542.  
  543. #define SEQCLK_8DOTS        0x001       /* reset sequencer before writing */
  544. #define SEQCLK_CYCLES       0x002
  545. #define SEQCLK_SHIFTLOAD    0x004
  546. #define SEQCLK_DOTCLOCK     0x008       /* reset sequencer before writing */
  547. #define SEQCLK_VGASHIFT4    0x010
  548. #define SEQCLK_VGASCREENOFF 0x020
  549.  
  550. #define SEQMAP_PLANE0       0x001
  551. #define SEQMAP_PLANE1       0x002
  552. #define SEQMAP_PLANE2       0x004
  553. #define SEQMAP_PLANE3       0x008
  554. #define SEQMAP_ALL          (SEQMAP_PLANE0|SEQMAP_PLANE1| \
  555.                              SEQMAP_PLANE2|SEQMAP_PLANE3)
  556.  
  557. #define SEQMEM_ALPHA        0x001
  558. #define SEQMEM_EXTENDED     0x002
  559. #define SEQMEM_ODDEVENSAME  0x004       /* otherwise, even->0/2, odd->1/3 */
  560. #define SEQMEM_CHAIN4       0x008       /* low 2 bits select plane */
  561. #define SEQMEM_ALL          (SEQMEM_ALPHA|SEQMEM_EXTENDED|SEQMEM_ODDEVENSAME|SEQMEM_CHAIN4)
  562.  
  563. #define GDCSR_PLANE0        0x001
  564. #define GDCSR_PLANE1        0x002
  565. #define GDCSR_PLANE2        0x004
  566. #define GDCSR_PLANE3        0x008
  567. #define GDCSR_ALL           (GDCSR_PLANE0|GDCSR_PLANE1| \
  568.                              GDCSR_PLANE2|GDCSR_PLANE3)
  569. #define GDCESR_ALL          GDCSR_ALL
  570.  
  571. #define GDCCLRCMP_ALL       0x00F
  572.  
  573. #define GDCROTATE_COUNT     0x007
  574. #define GDCROTATE_AND       0x008
  575. #define GDCROTATE_OR        0x010
  576. #define GDCROTATE_XOR       0x018
  577. #define GDCROTATE_NOFUNC    0x000
  578. #define GDCROTATE_ALL       (GDCROTATE_COUNT|GDCROTATE_AND|GDCROTATE_OR| \
  579.                              GDCROTATE_XOR)
  580.  
  581. #define GDCREADMAP_ALL      (PLANE0|PLANE1|PLANE2|PLANE3)
  582.  
  583. #define GDCMODE_WRITE0      0x000
  584. #define GDCMODE_WRITE1      0x001
  585. #define GDCMODE_WRITE2      0x002
  586. #define GDCMODE_WRITE3      0x003       /* only on a VGA */
  587. #define GDCMODE_TEST        0x004
  588. #define GDCMODE_READ0       0x000
  589. #define GDCMODE_READ1       0x008
  590. #define GDCMODE_ODDEVENDIFF 0x010
  591. #define GDCMODE_ODDEVENBITS 0x020
  592. #define GDCMODE_256COLOR    0x040       /* only on a VGA */
  593. #define GDCMODE_ALL         (GDCMODE_WRITE3|GDCMODE_TEST|GDCMODE_READ1| \
  594.                              GDCMODE_ODDEVENDIFF|GDCMODE_ODDEVENBITS|GDCMODE_256COLOR)
  595.  
  596. #define GDCMISC_NOCHARGEN   0x001
  597. #define GDCMISC_ODDTOEVEN   0x002
  598. #define GDCMISC_64K_A0000   0x004
  599. #define GDCMISC_32K_B0000   0x008
  600. #define GDCMISC_32K_B8000   0x00C
  601. #define GDCMISC_128K_A0000  0x000
  602. #define GDCMISC_ADDRMASK    0x00C
  603. #define GDCMISC_ALL         (GDCMISC_NOCHARGEN|GDCMISC_ODDTOEVEN|GDCMISC_32K_B8000)
  604.  
  605. #define GDCDONTCARE_ALL     0x00F
  606.  
  607. #define GDCBITMASK_ALL      0x0FF
  608.  
  609. #define CRTOVFL_VERTTOTAL   0x001
  610. #define CRTOVFL_VERTDSPEND  0x002
  611. #define CRTOVFL_VERTSTRTRC  0x004
  612. #define CRTOVFL_VERTSTBLNK  0x008
  613. #define CRTOVFL_LINECMP     0x010
  614. #define CRTOVFL_CURLOC      0x020
  615.  
  616. #define CRTMAXSCAN_200CONV  0x080       /* VGA bit for 200->400 conversion */
  617.  
  618. #define CRTMCTRL_COMPAT     0x001       /* CRT compatibility mode (8K disp.) */
  619.  
  620.  
  621. #define MISCOUT_COLRPORTS   0x001       /* select 3Dx (or possibly 2Dx) ports */
  622. #define MISCOUT_ENABLERAM   0x002
  623. #define MISCOUT_CLKSELECT   0x00C       /* reset sequencer before writing */
  624. #define MISCOUT_DISABLEDRV  0x010
  625. #define MISCOUT_HIGHPAGE    0x020
  626. #define MISCOUT_NEGHORZRTRC 0x040
  627. #define MISCOUT_NEGVERTRTRC 0x080
  628.  
  629. #define STATUS1_HORZRTRC    0x001       /* very frequent, but very short */
  630. #define STATUS1_LPENSTROBE  0x002
  631. #define STATUS1_LPENSWITCH  0x004
  632. #define STATUS1_VERTRTRC    0x008       /* less frequent, but much longer */
  633. #define STATUS1_ATCOUTPUT1  0x010
  634. #define STATUS1_ATCOUTPUT2  0x020
  635.  
  636.  
  637. #define MONOMODE_HIRES      0x001       /* must always be set */
  638. #define MONOMODE_ENABLE     0x008
  639. #define MONOMODE_BLINK      0x020
  640.  
  641. #define CGAMODE_80X25       0x001
  642. #define CGAMODE_320X200     0x002
  643. #define CGAMODE_BW          0x004
  644. #define CGAMODE_ENABLE      0x008
  645. #define CGAMODE_640X200     0x010
  646. #define CGAMODE_BLINK       0x020
  647.  
  648. #define CGACOLOR_BORDER     0x00F       /* border in modes 0/1/2/3, bgnd in 4/5 */
  649. #define CGACOLOR_INTENSE    0x010
  650. #define CGACOLOR_SET        0x020
  651.  
  652. #endif  /* INCL_VIDEOHW */
  653.  
  654.  
  655. #ifdef INCL_VIDEOPTR
  656.  
  657. /* Define current pointer-draw limitations
  658.  */
  659.  
  660. #define PTRSAVWD            (MAX_PTRWIDTH+1)
  661. #define PTRSAVHT            (MAX_PTRHEIGHT)
  662. #define PTRSAVSIZE          (PTRSAVWD*PTRSAVHT)
  663.  
  664. #define BYTEPTRSAVWD        (PTRSAVWD*8)
  665. #define BYTEPTRSAVHT        (PTRSAVHT*1)
  666. #define BYTEPTRSAVSIZE      (BYTEPTRSAVWD*BYTEPTRSAVHT)
  667.  
  668. #define SCRSAVWD            (PTRSAVWD+2)
  669. #define SCRSAVHT            (PTRSAVHT+4)
  670. #define SCRSAVSIZE          (SCRSAVWD*SCRSAVHT)
  671.  
  672. #define BYTESCRSAVWD        (SCRSAVWD*8)
  673. #define BYTESCRSAVHT        (SCRSAVHT*1)
  674. #define BYTESCRSAVSIZE      (BYTESCRSAVWD*BYTESCRSAVHT)
  675.  
  676.  
  677. /* Define EGA/VGA off-screen memory usage
  678.  */
  679.  
  680. #define OFFSCREEN0D         ((320/8)*200)
  681. #define OFFSCREEN0E         ((640/8)*200)
  682. #define OFFSCREEN10         ((640/8)*350)
  683. #define OFFSCREEN12         ((640/8)*480)
  684. #define OFFSCREEN13         ((320/1)*200)
  685.  
  686. #define SIZBASIC            0x0004      /* reserved for BASIC */
  687. #define SIZEGASYS           0x0001      /* reserved for EGA.SYS */
  688. #define SIZMOUSE            0x0001      /* reserved for MOUSE drivers */
  689.  
  690.  
  691.  
  692. #define OFFBASIC            0x0000
  693. #define OFFEGASYS           (OFFBASIC  + SIZBASIC)
  694. #define OFFMOUSE            (OFFEGASYS + SIZEGASYS)
  695.  
  696.  
  697.  
  698.  
  699.  
  700.  
  701.  
  702. #define OFFPTRSAV0D         (OFFSCREEN0D + SIZRESERVED)
  703. #define OFFSCRSAV0D         (OFFPTRSAV0D + PTRSAVSIZE)
  704. /* c-begin */
  705. #if OFFSCRSAV0D+SCRSAVSIZE > 0x2000
  706. #error  PTRSAVSIZE and/or SCRSAVSIZE too large for mode 0Dh
  707. #endif
  708. /* c-end */
  709.  
  710. #define OFFPTRSAV0E         (OFFSCREEN0E + SIZRESERVED)
  711. #define OFFSCRSAV0E         (OFFPTRSAV0E + PTRSAVSIZE)
  712. /* c-begin */
  713. #if OFFSCRSAV0E+SCRSAVSIZE > 0x4000
  714. #error  PTRSAVSIZE and/or SCRSAVSIZE too large for mode 0Eh
  715. #endif
  716. /* c-end */
  717.  
  718. #define OFFPTRSAV10         (OFFSCREEN10 + SIZRESERVED)
  719. #define OFFSCRSAV10         (OFFPTRSAV10 + PTRSAVSIZE)
  720. /* c-begin */
  721. #if OFFSCRSAV10+SCRSAVSIZE > 0x7000
  722. #error  PTRSAVSIZE and/or SCRSAVSIZE too large for mode 10h
  723. #endif
  724. /* c-end */
  725.  
  726. #define OFFPTRSAV12         (OFFSCREEN12 + SIZRESERVED)
  727. #define OFFSCRSAV12         (OFFPTRSAV12 + PTRSAVSIZE)
  728. /* c-begin */
  729. #if OFFSCRSAV12+SCRSAVSIZE > 0x9800
  730. #error  PTRSAVSIZE and/or SCRSAVSIZE too large for mode 12h
  731. #endif
  732. /* c-end */
  733.  
  734. #define OFFPTRSAV13         (OFFSCREEN13 + SIZRESERVED)
  735. #define OFFSCRSAV13         (OFFPTRSAV13 + BYTEPTRSAVSIZE)
  736. /* c-begin */
  737. #if OFFSCRSAV13+SCRSAVSIZE > 0x10000
  738. #error  BYTEPTRSAVSIZE and/or BYTESCRSAVSIZE too large for mode 13h
  739. #endif
  740. /* c-end */
  741. /*end*/
  742.  
  743. #endif  /* INCL_VIDEOPTR */
  744.  
  745.  
  746. #define VVD_NAME1   "VVIDEO1$"  /* registered name of primary VVD */
  747. #define VVD_NAME2   "VVIDEO2$"  /* registered name of secondary VVD */
  748.  
  749.  
  750. #ifdef  INCL_VIDEOSYSREQ
  751.  
  752. /***EK+ VVD constants for system communication
  753.  */
  754. #ifndef CF_TEXT
  755. #define CF_TEXT     1           /* clipboard formats */
  756. #define CF_BITMAP   2           /* (see PMWIN.H) */
  757. #endif
  758.  
  759. #define ADAPTER_MONO    0       /* adapters supported */
  760. #define ADAPTER_CGA     1       /* (same as VioGetConfig constants) */
  761. #define ADAPTER_EGA     2
  762. #define ADAPTER_VGA     3
  763. #define ADAPTER_8514A   7
  764.  
  765. #ifndef MONITOR_8503            /* BUGBUG: avoid conflicts with bsesub.h */
  766. #define MONITOR_MONO    0       /* monitors supported */
  767. #define MONITOR_RGB     1       /* (typical for CGAs) */
  768. #define MONITOR_ECD     2       /* (typical for EGAs) */
  769. #define MONITOR_8503    3       /* (VGA or 8514/A monochrome) */
  770. #define MONITOR_8512_3  4       /* (VGA or 8514/A color) */
  771. #define MONITOR_8514    9       /* (VGA or 8514/A 1024x768 color, interlaced) */
  772. #endif
  773.  
  774. #define FORMAT_CGA      2       /* LVB formats supported */
  775. #define FORMAT_4BYTE    4
  776. #define FORMAT_BITMAP   0
  777.  
  778. #define DDFORMAT_4PLANE 1       /* display driver formats supported */
  779. #ifdef  ATLAS
  780. #define DDFORMAT_8PLANE 2       /* display driver 8 plane formats supported      */
  781. #define DDFORMAT_8PLANE_PALETTE 3
  782.                                 /* display driver 8 plane with palette supported */
  783. #endif  //ATLAS
  784.  
  785. #define MODE_MONO            0x0001 /* monochrome mode in effect */
  786. #define MODE_UNDERLINE       0x0002 /* underlining in effect */
  787. #define MODE_SUP_XSCALE2     0x1000 /* X scaling supported by factor of 2 */
  788. #define MODE_SUP_YSCALE2     0x2000 /* Y scaling supported by factor of 2 */
  789. #define MODE_SUP_PARTIALSCAN 0x4000 /* partial scanline copy requests supported */
  790.  
  791. #define SUSPEND_NONE              0 /* VDM running normally */
  792. #define SUSPEND_OUT_OF_MEMORY     1 /* VDM suspended due to low memory */
  793. #define SUSPEND_UNSUPPORTED_MODE  2 /* VDM suspended due to unsupported mode */
  794.  
  795. #define ACCESS_RELEASE            0 /* values for SETACCESS request */
  796. #define ACCESS_REQUEST            1
  797. #define ACCESS_PMREQUEST          2
  798.  
  799. #define CONTROL_RELEASE           0 /* Release event thread */
  800. #define CONTROL_VDMMINIMIZED      1 /* Disable video events for VDM */
  801. #define CONTROL_VDMUNMINIMIZED    2 /* Enable video events for VDM */
  802.  
  803.  
  804. /* VVD system functions
  805.  */
  806. #define VVDSYSREQ_SETACCESS     1   /* Obtain exclusive event access */
  807. #define VVDSYSREQ_SETFOCUS      2   /* Notify VDM gaining/losing focus */
  808. #define VVDSYSREQ_SETLOCK       3   /* Lock/unlock VDM's video state */
  809. #define VVDSYSREQ_QUERYMODE     4   /* Query VDM's current mode */
  810. #define VVDSYSREQ_QUERYCURSOR   5   /* Query VDM's current mode */
  811. #define VVDSYSREQ_QUERYPALETTE  6   /* Query VDM's palette settings */
  812. #define VVDSYSREQ_COPYLVB       7   /* Copy LVB data */
  813. #define VVDSYSREQ_COPYBITMAP    8   /* Copy bitmap data */
  814. #define VVDSYSREQ_WAITEVENT     9   /* Wait for VDM video update event */
  815. #define VVDSYSREQ_CONTROLEVENT  10  /* Perform event control operations */
  816.  
  817. #define VVDSYSREQ_SETDRQ        11  /* Set display requirements */
  818. #define VVDSYSREQ_REQMEM        12  /* Request off-screen video memory */
  819. #define VVDSYSREQ_FREEMEM       13  /* Free off-screen video memory */
  820. #define VVDSYSREQ_REQCTRL       14  /* Request video controller ownership */
  821. #define VVDSYSREQ_FREECTRL      15  /* Free video controller ownership */
  822.  
  823. #define VVDSYSREQ_QUERYVRAMSTATUS 16/* Return VRAM status since last call */
  824.  
  825. #define VVDSYSREQ_SETOEMFLAG    17  /* Set OEM Status Flag */
  826.  
  827. #define VVDSYSREQ_MAX           17
  828.  
  829.  
  830. /* VVD event IDs for VVDSYSREQ_WAITEVENT
  831.  */
  832. #define VVDEVENT_NONE           0   /* No change */
  833. #define VVDEVENT_MODE           1   /* Change in VDM's mode */
  834. #define VVDEVENT_PALETTE        2   /* Change in VDM's palette */
  835. #define VVDEVENT_LVB            3   /* Change in VDM's LVB */
  836. #define VVDEVENT_SCROLL         4   /* Scroll of VDM's LVB */
  837. #define VVDEVENT_STRING         5   /* String output */
  838. #define VVDEVENT_CURSOR         6   /* Cursor position/type change */
  839. #define VVDEVENT_INPUT          7   /* VDM is checking for input data */
  840. #define VVDEVENT_ENDPASTE       8   /* VDM has cancelled pasting */
  841. #define VVDEVENT_PASTE          9   /* VDM is ready for additional pasting */
  842. #define VVDEVENT_SWITCHERROR    10  /* VDM cannot be switched foreground */
  843. #define VVDEVENT_TITLECHANGE    11  /* VDM title has changed */
  844. #define VVDEVENT_DDE            12  /* Set/Clear DDE flag */
  845.  
  846. #define VVDEVENT_MAX            12
  847. /*end*/
  848.  
  849.  
  850. /***ET+ VVD DosRequestVDD communication structures
  851.  */
  852.  
  853. typedef struct vvm_s {          /* vvm (output for MODE event) */
  854.     ULONG  vvm_ulAdapter;       /* see the ADAPTER_* constants */
  855.     ULONG  vvm_ulFormat;        /* see the FORMAT_* constants */
  856.     ULONG  vvm_ulDDFormat;      /* see the DDFORMAT_* constants */
  857.     ULONG  vvm_flMode;          /* mode descriptors (see MODE_* constants) */
  858.     ULONG  vvm_nRows;           /* height of screen in rows (or y pixels) */
  859.     ULONG  vvm_nCols;           /* width of screen in columns (or x pixels) */
  860.     ULONG  vvm_nPlanes;         /* # of planes (must be 1 for Cruiser) */
  861.     ULONG  vvm_nBitCount;       /* if TEXT, zero;  if BITMAP, bits per pixel */
  862.     ULONG  vvm_ulCellWidth;     /* width of cells (normally 8;  1 for BITMAPs) */
  863.     ULONG  vvm_ulCellHeight;    /* height of cells (1 for BITMAPs) */
  864.     ULONG  vvm_fSuspended;      /* see the SUSPEND_* constants */
  865.     ULONG  vvm_cpID;            /* current code-page ID */
  866.     ULONG  vvm_FormatID;        /* current format ID */
  867. #ifdef ATLAS_GALE
  868.     ULONG  vvm_GridColor;       /* current grid color                     */
  869.     ULONG  vvm_AttrFlag;        /* current screen intensity               */
  870.     ULONG  vvm_nRows2;          /* height of screen in rows for superimpose text   */
  871.     ULONG  vvm_nCols2;          /* width of screen in columns for superimpose text */
  872.     ULONG  vvm_ulCellWidth2;    /* width of cells for superimpose text    */
  873.     ULONG  vvm_ulCellHeight2;   /* height of cells for superimpose text   */
  874.     ULONG  vvm_ulFormat2;       /* 4 for superimpose, otherwise 0         */
  875. #endif  //ATLAS_GALE
  876. } VVMODE;
  877. typedef VVMODE *NPVVMODE;
  878. typedef VVMODE FAR *PVVMODE;
  879.  
  880. #ifdef  ATLAS_GALE
  881. #define FORMATID_EPOCHColor     0x41
  882. #define FORMATID_EPOCHMono      0x81
  883. #define FORMATID_MckColor       0x20
  884. #define FORMATID_CommonFMT      0x70
  885. #endif  //ATLAS_GALE
  886.  
  887. typedef struct vvr_s {          /* vvr (input for COPYBITMAP request) */
  888.     ULONG  vvr_ulDDFormat;      /* display driver format (0 if DIB used) */
  889.     ULONG  vvr_cx;              /* target bitmap width */
  890.     ULONG  vvr_cy;              /* target bitmap height */
  891.     RECTL  vvr_rcl;             /* rectangle being requested */
  892.     PBYTE  vvr_pbColorXlate;    /* display driver color translation table */
  893. } VVRECT;
  894. typedef VVRECT *NPVVRECT;
  895. typedef VVRECT FAR *PVVRECT;
  896.  
  897. typedef struct vvl_s {          /* vvl (output for LVB event) */
  898.     RECTL  vvl_rcl;             /* rectangle being scrolled */
  899.     ULONG  vvl_fCertain;        /* TRUE if entire area changed, FALSE if unknown */
  900. #ifdef ATLAS_GALE
  901.     ULONG  vvl_pFlags;          /* LSB indicate which page (text or graphics) is */
  902.                                 /* updated. 0 means graphics, 1 does text.       */
  903. #endif  //ATLAS_GALE
  904. } VVLVB;
  905. typedef VVLVB *NPVVLVB;
  906. typedef VVLVB FAR *PVVLVB;
  907.  
  908. typedef struct vvs_s {          /* vvs (output for SCROLL event) */
  909.     RECTL  vvs_rcl;             /* rectangle being scrolled */
  910.     LONG   vvs_fill;            /* fill value */
  911.     LONG   vvs_nRows;           /* # rows (negative means reverse scroll) */
  912.     LONG   vvs_nCols;           /* # columns (0,0 means rectangle blankfilled) */
  913. } VVSCROLL;
  914. typedef VVSCROLL *NPVVSCROLL;
  915. typedef VVSCROLL FAR *PVVSCROLL;
  916.  
  917. typedef struct vva_s {          /* vva (output for STRING event) */
  918.     ULONG  vva_row;             /* beginning row of string */
  919.     ULONG  vva_col;             /* beginning column of string */
  920.     ULONG  vva_nChars;          /* # characters in string */
  921. } VVSTRING;
  922. typedef VVSTRING *NPVVSTRING;
  923. typedef VVSTRING FAR *PVVSTRING;
  924.  
  925. typedef struct vvc_s {          /* vvc (output for CURSOR event) */
  926.     ULONG  vvc_row;             /* row (y position) of VDM's cursor */
  927.     ULONG  vvc_col;             /* column (x position) of VDM's cursor */
  928.     ULONG  vvc_ulScanStart;     /* starting scan-line for VDM's cursor */
  929.     ULONG  vvc_ulScanEnd;       /* ending scan-line for VDM's cursor */
  930.     ULONG  vvc_fVisible;        /* TRUE if VDM cursor visible, FALSE if not */
  931. } VVCURSOR;
  932. typedef VVCURSOR *NPVVCURSOR;
  933. typedef VVCURSOR FAR *PVVCURSOR;
  934.  
  935. typedef struct vve_s {          /* vve (output for VVDSYSREQ_GET/WAITEVENT) */
  936.     LONG   vve_iEvent;          /* one of the VVDEVENT_* constants */
  937.     ULONG  vve_sgID;            /* screen group ID of VDM */
  938.     ULONG  vve_nData;           /* # of entries of information returned */
  939. } VVEVENT;
  940. typedef VVEVENT *NPVVEVENT;
  941. typedef VVEVENT FAR *PVVEVENT;
  942.  
  943. typedef struct vvreg_s {        /* vvreg (shadow entry for VVDSYSREQ_SETDRQ) */
  944.     USHORT vvreg_port;          /* port # */
  945.     CHAR   vvreg_indx;          /* register index # (-1 if index reg) */
  946.     BYTE   vvreg_value;         /* last value written to register by VDD */
  947. } VVREG;
  948. typedef VVREG *NPVVREG;
  949. typedef VVREG FAR *PVVREG;
  950.  
  951.  
  952. /*** In the DRQ structure, all pointers are 16:16, and as such, cannot be
  953.  *   dereferenced directly from C.  The selector portions are GDT aliases to
  954.  *   the PM display driver's resident data, and are valid in any context, even
  955.  *   interrupt-time.
  956.  */
  957. #define ALL_RESERVED 0xffffffff
  958.  
  959. #define DRQ_DIRTYREGS   0x01    /* video controller registers have been modified */
  960.  
  961. typedef struct vvdrq_s {        /* vvdrq (main structure for VVDSYSREQ_SETDRQ) */
  962.     PBYTE  vvd_pPhysVRAM;       /* physical address of VRAM */
  963.     ULONG  vvd_nbReserved;      /* # of reserved bytes */
  964.     ULONG  vvd_offLatchByte;    /* offset of available latch storage */
  965.     PBYTE  vvd_pfbDRQFlags;     /* pointer to flags (see DRQ_* constants) */
  966.     PBYTE  vvd_pfCtrlOwned;     /* address of display.dll's fCtrlOwned flag */
  967.     PBYTE  vvd_pfCtrlNotify;    /* address of display.dll's fCtrlNotify flag */
  968.     ULONG  vvd_nShadowRegs;     /* # of registers to shadow */
  969.     PVVREG vvd_pShadowData;     /* address of first entry in shadow list */
  970. } VVDRQ;
  971. typedef VVDRQ *NPVVDRQ;
  972. typedef VVDRQ FAR *PVVDRQ;
  973. /*end*/
  974.  
  975. #endif  /* INCL_VIDEOSYSREQ */
  976.  
  977.  
  978. #ifdef  INCL_VIDEODEVREQ
  979.  
  980. /***EK+ VVD constants for inter-VDD communication
  981.  */
  982.  
  983. #define VVDDEVREQ_POSTPEEK      1   /* VDM peeking for keyboard data */
  984. #define VVDDEVREQ_POSTREAD      2   /* VDM reading for keyboard data */
  985. #define VVDDEVREQ_POSTPASTE     3   /* VDM ready for more paste data */
  986. #define VVDDEVREQ_POSTMOUSE     4   /* VDM mouse activity notification */
  987. #define VVDDEVREQ_DEVACCEPT     5   /* request VVD to manage adapter */
  988. #define VVDDEVREQ_DEVRELEASE    6   /* request VVD to free adapter */
  989. #define VVDDEVREQ_DSPACCEPT     7   /* request VVD to manage display */
  990. #define VVDDEVREQ_DSPRELEASE    8   /* request VVD to free display */
  991. #define VVDDEVREQ_POSTEVENT     9   /* post a VDM event to the Shield */
  992. #define VVDDEVREQ_SAVERESTORE  10   /* enable/disable save/restore     XGA */
  993. #define VVDDEVREQ_REPAINT      11   /* keep VRAMISTOAST bit set        XGA */
  994. #define VVDDEVREQ_REQCTRL      12   /* Request controller ownership          */
  995. #define VVDDEVREQ_FREECTRL     13   /* Free video controller ownership       */
  996. #define VVDDEVREQ_PM_WINDOW    14   /* Set Windows on PM DeskTop state       */
  997. #define VVDDEVREQ_ENABLE_DDE   15   /* Set/Clear DDE flag                    */
  998. #define VVDDEVREQ_XGAPRESENT   16   /* VXGA installed                        */
  999. #define VVDDEVREQ_UNMAPVRAM    17   /* Unmap A0000 aperture                  */
  1000. #define VVDDEVREQ_8514PRESENT  18   /* V8514 installed                       */
  1001. #define VVDDEVREQ_VIDEOBUFFER  19
  1002. #define VVDDEVREQ_NOTIFYVTEXT  20
  1003.  
  1004. #define VVDDEVREQ_MAX          20
  1005.  
  1006. #define POSTEVENT_ADD      0x0001   /* add given event */
  1007. #define POSTEVENT_FLUSH    0x0002   /* flush given (or existing) event */
  1008. #define POSTEVENT_DELETE   0x0004   /* delete existing event */
  1009.  
  1010.  
  1011. /***ET+ VVD VDHRequestVDD communication structures
  1012.  */
  1013. typedef struct vvp_s {          /* vvp (input for POSTEVENT request) */
  1014.     LONG   vvp_iEvent;          /* see the VVDEVENT_* constants */
  1015.     PVOID  vvp_pEvent;          /* event data (varies from one event to another) */
  1016.     ULONG  vvp_flEvent;         /* event posting flags (see POSTEVENT_* constants) */
  1017. } VVPOST;
  1018. typedef VVPOST *NPVVPOST;
  1019. typedef VVPOST FAR *PVVPOST;
  1020. /*end*/
  1021.  
  1022. #endif  /* INCL_VIDEODEVREQ */
  1023.  
  1024. #ifdef INCL_VIDEOINTERFACES
  1025.  
  1026. typedef (*PASCAL PFNINT2FP)(HVDM, ULONG, PCRF);
  1027.  
  1028. /*** ULONG value sent to the registered INT 2F routine ***/
  1029. #define VDHVVD_INT2F_OFF      0
  1030. #define VDHVVD_INT2F_ON       1
  1031. #define VDHVVD_INT2F_FG_START 2
  1032. #define VDHVVD_INT2F_FG_END   3
  1033. #define VDHVVD_INT2F_BG_START 4
  1034. #define VDHVVD_INT2F_BG_END   5
  1035.  
  1036. #ifndef VDHENTRY
  1037. #define VDHENTRY PASCAL NEAR
  1038. #endif
  1039.  
  1040. VOID VDHENTRY VDHRegisterInt2FProc(FLAGS, PFNINT2FP);
  1041.  
  1042. /*** BOOL value indicates the type of notifications required ***/
  1043. #define VDHVVD_NOTIFY_ON_OFF  1
  1044. #define VDHVVD_NOTIFY_START   2
  1045. #define VDHVVD_NOTIFY_END     4
  1046.  
  1047. #endif   /* INCL_VIDEOINTERFACES */
  1048.  
  1049. /*** VVD exported function prototypes
  1050.  */
  1051.  
  1052. /* None */
  1053.  
  1054. #endif /* __VVD__ */
  1055.  
  1056. #pragma checkout( suspend )
  1057.    #ifndef __CHKHDR__
  1058.       #pragma checkout( resume )
  1059.    #endif
  1060. #pragma checkout( resume )
  1061.