home *** CD-ROM | disk | FTP | other *** search
/ OS/2 Shareware BBS: 10 Tools / 10-Tools.zip / warptlk3.zip / TOOLKIT / H / CDAUDOS2.H < prev    next >
C/C++ Source or Header  |  1995-08-24  |  12KB  |  228 lines

  1. /****************************************************************************/
  2. /*                                                                          */
  3. /* Module Name:  CDAUDOS2.H                                                 */
  4. /*                                                                          */
  5. /* FUNCTION:  This file contains the macro definition and common record     */
  6. /*            structures used between the CD Audio MCI Driver, its VSDs     */
  7. /*            (Vendor Specific Drivers), and the CD look-up table,          */
  8. /*            MMPMCD.INI.                                                   */
  9. /*                                                                          */
  10. /* Copyright (c) International Business Machines Corporation 1991 - 1993    */
  11. /*                        All Rights Reserved                               */
  12. /*                                                                          */
  13. /****************************************************************************/
  14.  
  15. /*******************************************************************/
  16. /* CD MCD and VSD values and inter-modual communications           */
  17. /*******************************************************************/
  18.  
  19.  
  20. /**********************************/
  21. /* Macro Definitions              */
  22. /**********************************/
  23.  
  24. #define UPC_SIZE              7     /* UPC code size, CD serial number */
  25. #define CDMCD_CUEPOINT_MAX   20     /* maximum number of cuepoints */
  26. #define CDROM_SPEC_START   6000     /* 2 seconds, greatest min start address */
  27.  
  28.  
  29. /*************************************************************************/
  30. /* Internal messages between the MCI Driver and the VSD.                 */
  31. /*************************************************************************/
  32.  
  33. #define MCIDRV_REGISTER_DISC    MCI_INTERNAL_MESSAGES_START + 1
  34. #define MCIDRV_REGISTER_DRIVE   MCI_INTERNAL_MESSAGES_START + 2
  35. #define MCIDRV_REGISTER_TRACKS  MCI_INTERNAL_MESSAGES_START + 3
  36. #define MCIDRV_CD_READ_LONG     MCI_INTERNAL_MESSAGES_START + 4
  37. #define MCIDRV_CD_SET_VERIFY    MCI_INTERNAL_MESSAGES_START + 5
  38. #define MCIDRV_CD_STATUS_CVOL   MCI_INTERNAL_MESSAGES_START + 6
  39.  
  40.  
  41. /*************************************************************************/
  42. /* Internal callback routine to the VSD from the MCI Driver.             */
  43. /*************************************************************************/
  44.  
  45. typedef ULONG (APIENTRY FNCDVSD) (PVOID, USHORT, ULONG *, PVOID, USHORT);
  46. typedef FNCDVSD *PFNCDVSD;
  47.  
  48.  
  49. /*************************************************************************/
  50. /* Internal callback routine from the VSD to the MCI Driver.             */
  51. /*************************************************************************/
  52.  
  53. typedef VOID (*PFNCDMCD) (ULONG, ULONG, ULONG);
  54.  
  55.  
  56. /***********************************/
  57. /* CDAudRegister record structures */
  58. /***********************************/
  59. #pragma pack(1)
  60.  
  61. /*** ID a disc, used to verify a disc change ***/
  62. typedef struct _MCI_CD_ID
  63. {                              /* must stay at 8 bytes to equal size of UPC */
  64.    BYTE   Mode;                           /* mode, 0=UPC, 1=ID              */
  65.    USHORT usTrack1;                       /* address of track one in MMTIME */
  66.    BYTE   NumTracks;                      /* number of tracks               */
  67.    ULONG  ulLeadOut;                      /* address of lead out track      */
  68. } MCI_CD_ID;
  69.  
  70. /*** CD-ROM Drive information, determines capabilities ***/
  71. typedef struct _MCI_CD_REGDRIVE_PARMS
  72. {
  73.    USHORT usCaps;                         /* capabilities                   */
  74.    ULONG  ulPrerollType;                  /* preroll type                   */
  75.    ULONG  ulPrerollTime;                  /* preroll time                   */
  76.    ULONG  ulMinStartTime;                 /* minimum starting time          */
  77.    ULONG  ulCDMCDID;                      /* CD MCD ID for instance         */
  78.    PFNCDMCD pCDMCDReturn;                 /* addr of CD MCD Return function */
  79. } MCI_CD_REGDRIVE_PARMS;
  80.  
  81. /*************************************************/
  82. /* These flags are valid for the usCaps Field    */
  83. /*************************************************/
  84. #define CDVSD_CAP_CAN_RECORD  0x0001    /* Can record audio               */
  85. #define CDVSD_CAP_HAS_AUDIO   0x0002    /* Can play audio                 */
  86. #define CDVSD_CAP_HAS_VIDEO   0x0004    /* Can play video                 */
  87. #define CDVSD_CAP_CAN_EJECT   0x0010    /* Can eject disc                 */
  88. #define CDVSD_CAP_CAN_STREAM  0x0020    /* Can stream                     */
  89. #define CDVSD_CAP_HAS_DAC     0x0040    /* Can process internal           */
  90. #define CDVSD_CAP_CAN_LOCK    0x0080    /* Can disable manual eject       */
  91. #define CDVSD_CAP_CAN_VOLUME  0x0100    /* Can manipulate volume settings */
  92. #define CDVSD_CAP_CAN_REVERSE 0x0200    /* Can play in reverse            */
  93. #define CDVSD_CAP_CAN_V_SPEED 0x0400    /* Can vary play speed            */
  94. #define CDVSD_CAP_CAN_CUE     0x0800    /* Can read sequent. after break  */
  95.                                         /* Used for Cue, Pause, and Seek  */
  96.  
  97.  
  98. /*** Information about the disc ***/
  99. typedef struct _MCI_CD_REGDISC_PARMS
  100. {
  101.    BYTE   LowestTrackNum;                 /* lowest track number  */
  102.    BYTE   HighestTrackNum;                /* highest track number */
  103.    BYTE   UPC[UPC_SIZE];                  /* upc, 13 BCD + 4bit 0 */
  104.    MCI_CD_ID DiscID;                      /* Disc ID              */
  105. } MCI_CD_REGDISC_PARMS;
  106.  
  107. /*** Information about each track ***/
  108. typedef struct _MCI_CD_REGTRACK_REC
  109. {
  110.    BYTE   TrackNum;                       /* track number               */
  111.    ULONG  ulStartAddr;                    /* starting address in MMTIME */
  112.    ULONG  ulEndAddr;                      /* ending address             */
  113.    BYTE   TrackControl;                   /* track control information  */
  114. } MCI_CD_REGTRACK_REC;
  115.  
  116. /*** Track information, used to verify address ***/
  117. typedef struct _MCI_CD_REGTRACKS_PARMS
  118. {
  119.    MCI_CD_REGTRACK_REC *TrackRecArr;      /* ptr to array of track recs  */
  120.    ULONG  ulBufSize;                      /* size of buffer              */
  121. } MCI_CD_REGTRACKS_PARMS;
  122.  
  123.  
  124. /********************************************/
  125. /* Environment settings to save and restore */
  126. /********************************************/
  127.  
  128. typedef struct _MCIDRV_CD_SAVE_PARMS
  129. {
  130.    ULONG ulPosition;                      /* current position in MMTIME       */
  131.    ULONG ulEndPlay;                       /* end play position                */
  132.    ULONG ulMode;                          /* Play mode: playing, paused, etc. */
  133.    ULONG ulLevel;                         /* volume levels                    */
  134.    ULONG ulVSDData;                       /* Extra VSD data storage area      */
  135. } MCIDRV_CD_SAVE_PARMS;
  136.  
  137. /********************************************/
  138. /* Read Long (2352-Byte) Sectors            */
  139. /********************************************/
  140.  
  141. /**************************************************************************/
  142. /* Flag for the MCIDRV_CD_READ_LONG message                               */
  143. /*   Default addressing mode for the ulFrom field is Hardware Red Book.   */
  144. /*   Absolute sector addressing for ISO-9660, or High Sierra Group        */
  145. /*   requires a flag, as does an MMTIME address.                          */
  146. /**************************************************************************/
  147.  
  148. #define MCI_CD_READLONG_HSG          0x00000100L
  149. #define MCI_CD_READLONG_MMTIME       0x00000200L
  150.  
  151. typedef struct _MCI_CD_READLONG_PARMS
  152. {
  153.    ULONG   ulFrom;                        /* read from this position   */
  154.    USHORT  usCount;                       /* Number of sectors to read */
  155.    PVOID   pReturn;                       /* Pointer to return buffer  */
  156.    ULONG   ulRetSize;                     /* Return buffer size        */
  157. } MCI_CD_READLONG_PARMS;
  158.  
  159. #pragma pack()
  160.  
  161.  
  162. /*******************************************************************/
  163. /* CD Table INI file, MMPMCD.INI, values                           */
  164. /*******************************************************************/
  165.  
  166. /*******************************************************************/
  167. /* Capability Flags I from the CD drive look-up table, MMPMCD.INI  */
  168. /*******************************************************************/
  169.  
  170. #define CDHW_CAP_CAN_EJECT    0x00000001  /* Can software eject disc         */
  171. #define CDHW_CAP_CAN_LOCK     0x00000002  /* Can lock drive/disable eject    */
  172. #define CDHW_CAP_READS_RAW    0x00000004  /* Can read raw sectors            */
  173. #define CDHW_CAP_CAN_WRITE    0x00000008  /* Can write to disc               */
  174. #define CDHW_CAP_CAN_PLAY     0x00000010  /* Can play CD-DA tracks           */
  175. #define CDHW_CAP_CAN_INTERLEV 0x00000020  /* Supports ISO-9660 interleaving  */
  176. #define CDHW_CAP_CAN_PREFETCH 0x00000080  /* Can prefetch internally         */
  177. #define CDHW_CAP_MANIP_AUDIO  0x00000100  /* Can manipulte audio channels    */
  178. #define CDHW_CAP_USES_REDBOOK 0x00000200  /* Can use Red Book mode           */
  179. #define CDHW_CAP_READS_XA     0x00000400  /* Can read CD-ROM/XA data         */
  180. #define CDHW_CAP_CONT_READS   0x00000800  /* Continues to read DA after stop */
  181. #define CDHW_CAP_CAN_REVERSE  0x00001000  /* Can play in reverse             */
  182. #define CDHW_CAP_READS_CDDA   0x40000000  /* Can read CD-DA audio tracks     */
  183.  
  184.  
  185. /*******************************************************************/
  186. /* Capability Flags II from the CD drive look-up table, MMPMCD.INI */
  187. /*******************************************************************/
  188.  
  189. #define CDHW_VOL_DEP_MASK     0x00000007  /* Volume dependency mask        */
  190. #define CDHW_VOL_DEP_NONE              0  /* Volume without dependency     */
  191. #define CDHW_VOL_DEP_HIGH              2  /* Volume is highest value       */
  192. #define CDHW_VOL_DEP_LOW               3  /* Volume is lowest value        */
  193. #define CDHW_VOL_DEP_LEFT              4  /* Volume is left volume         */
  194. #define CDHW_VOL_DEP_RIGHT             5  /* Volume is right volume        */
  195. #define CDHW_VOL_INDEP_MUTE   0x00000008  /* Mute has no dependency        */
  196. #define CDHW_CAP_LOCK_MOUNT   0x00000010  /* Can only lock when mounted    */
  197. #define CDHW_CAP_PLAY_VIDEO   0x00000020  /* Can play video                */
  198. #define CDHW_CAP_MODAL_ONLY   0x00000040  /* Stop req to interrupt PLAY    */
  199. #define CDHW_CAP_SUP_SEEK     0x00000080  /* Supports SEEK IOCTL           */
  200. #define CDHW_CAP_SUP_UPC      0x00000100  /* Supports UPC IOCTL            */
  201. #define CDHW_CAP_SUP_SUBCHAN  0x00000200  /* Supports sub-channel IOCTL    */
  202. #define CDHW_CAP_CAN_CLS_TRAY 0x00000400  /* Can close door/retract caddy  */
  203. #define CDHW_CAP_NO_STREAM    0x00001000  /* Cannot stream CD-DA when PDD  */
  204.                                           /*   says it can                 */
  205. #define CDHW_CAP_VAR_PLAY     0x80000000  /* Supports variable speeds      */
  206.  
  207. /* INI file record structure */
  208. #define CDINI_APPSIZE                  8  /* Application name size    */
  209. #define CDINI_KEYSIZE                 16  /* Key name size            */
  210. #define CDINI_VSD_NAME_SIZE            8  /* size of file name        */
  211. #define VOLUME_CONTROL               101  /* num of values, 0% - 100% */
  212.  
  213. #pragma pack(1)
  214.  
  215. typedef struct _MMPMCD_REC
  216. {
  217.    USHORT usEntryVer;                     /* Entry version                 */
  218.    ULONG  ulCaps1;                        /* Capability flag I             */
  219.    ULONG  ulCaps2;                        /* Capability flag II            */
  220.    CHAR   VSDName[CDINI_VSD_NAME_SIZE];   /* DLL name for VSD              */
  221.    ULONG  ulMinStart;                     /* Min starting addr, 0x00MMSSFF */
  222.    USHORT usVolCnt;                       /* volume level counter          */
  223.    USHORT ausVolValues[VOLUME_CONTROL];   /* volume control values         */
  224. } MMPMCD_REC;
  225.  
  226. #pragma pack()
  227.  
  228.