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