home *** CD-ROM | disk | FTP | other *** search
/ OS/2 Shareware BBS: 10 Tools / 10-Tools.zip / ddkx86v1.zip / DDKX86 / H / VVD.H < prev   
C/C++ Source or Header  |  1995-04-14  |  46KB  |  1,038 lines

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