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