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

  1. /****************************************************************************/
  2. /*                                                                          */
  3. /* Module Name:  CDAUDIO.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 from the VSD to the MCI Driver.             */
  43. /*************************************************************************/
  44.  
  45. typedef VOID (*PFNCDMCD) (DWORD, DWORD, DWORD);
  46.  
  47.  
  48. /***********************************/
  49. /* CDAudRegister record structures */
  50. /***********************************/
  51. #pragma pack(1)
  52.  
  53. typedef struct   /* ID a disc, used to verify a disc change                 */
  54. {                /* must stay at 8 bytes to equal size of UPC               */
  55.    BYTE   Mode;                           /* mode, 0=UPC, 1=ID              */
  56.    WORD   wTrack1;                        /* address of track one in MMTIME */
  57.    BYTE   NumTracks;                      /* number of tracks               */
  58.    DWORD  dwLeadOut;                      /* address of lead out track      */
  59. } MCI_CD_ID;
  60.  
  61. typedef struct /* CD-ROM Drive information, determines capabilities */
  62. {
  63.    WORD   wCaps;                          /* capabilities                   */
  64.    DWORD  dwPrerollType;                  /* preroll type                   */
  65.    DWORD  dwPrerollTime;                  /* preroll time                   */
  66.    DWORD  dwMinStartTime;                 /* minimum starting time          */
  67.    DWORD  dwCDMCDID;                      /* CD MCD ID for instance         */
  68.    PFNCDMCD pCDMCDReturn;                 /* addr of CD MCD Return function */
  69. } MCI_CD_REGDRIVE_PARMS;
  70.  
  71. /*************************************************/
  72. /* These flags are valid for the wCaps Field     */
  73. /*************************************************/
  74. #define CDVSD_CAP_CAN_RECORD  0x0001    /* Can record audio               */
  75. #define CDVSD_CAP_HAS_AUDIO   0x0002    /* Can play audio                 */
  76. #define CDVSD_CAP_HAS_VIDEO   0x0004    /* Can play video                 */
  77. #define CDVSD_CAP_CAN_EJECT   0x0010    /* Can eject disc                 */
  78. #define CDVSD_CAP_CAN_STREAM  0x0020    /* Can stream                     */
  79. #define CDVSD_CAP_HAS_DAC     0x0040    /* Can process internal           */
  80. #define CDVSD_CAP_CAN_LOCK    0x0080    /* Can disable manual eject       */
  81. #define CDVSD_CAP_CAN_VOLUME  0x0100    /* Can manipulate volume settings */
  82. #define CDVSD_CAP_CAN_REVERSE 0x0200    /* Can play in reverse            */
  83. #define CDVSD_CAP_CAN_V_SPEED 0x0400    /* Can vary play speed            */
  84. #define CDVSD_CAP_CAN_CUE     0x0800    /* Can read sequent. after break  */
  85.                                         /* Used for Cue, Pause, and Seek  */
  86.  
  87.  
  88. typedef struct /* Information about the disc  */
  89. {
  90.    BYTE   LowestTrackNum;                 /* lowest track number  */
  91.    BYTE   HighestTrackNum;                /* highest track number */
  92.    BYTE   UPC[UPC_SIZE];                  /* upc, 13 BCD + 4bit 0 */
  93.    MCI_CD_ID DiscID;                      /* Disc ID              */
  94. } MCI_CD_REGDISC_PARMS;
  95.  
  96. typedef struct /* Information about each track */
  97. {
  98.    BYTE   TrackNum;                       /* track number               */
  99.    DWORD  dwStartAddr;                    /* starting address in MMTIME */
  100.    DWORD  dwEndAddr;                      /* ending address             */
  101.    BYTE   TrackControl;                   /* track control information  */
  102. } MCI_CD_REGTRACK_REC;
  103.  
  104. typedef struct /* Track information, used to verify address */
  105. {
  106.    MCI_CD_REGTRACK_REC *TrackRecArr;      /* ptr to array of track recs  */
  107.    DWORD  dwBufSize;                      /* size of buffer              */
  108. } MCI_CD_REGTRACKS_PARMS;
  109.  
  110.  
  111. /********************************************/
  112. /* Environment settings to save and restore */
  113. /********************************************/
  114.  
  115. typedef struct
  116. {
  117.    DWORD dwPosition;                      /* current position in MMTIME       */
  118.    DWORD dwEndPlay;                       /* end play position                */
  119.    DWORD dwMode;                          /* Play mode: playing, paused, etc. */
  120.    DWORD dwLevel;                         /* volume levels                    */
  121.    DWORD dwVSDData;                       /* Extra VSD data storage area      */
  122. } MCIDRV_CD_SAVE_PARMS;
  123.  
  124. /********************************************/
  125. /* Read Long (2352-Byte) Sectors            */
  126. /********************************************/
  127.  
  128. /**************************************************************************/
  129. /* Flag for the MCIDRV_CD_READ_LONG message                               */
  130. /*   Default addressing mode for the dwFrom field is Hardware Red Book.   */
  131. /*   Absolute sector addressing for ISO-9660, or High Sierra Group        */
  132. /*   requires a flag, as does an MMTIME address.                          */
  133. /**************************************************************************/
  134.  
  135. #define MCI_CD_READLONG_HSG          0x00000100L
  136. #define MCI_CD_READLONG_MMTIME       0x00000200L
  137.  
  138. typedef struct
  139. {
  140.    DWORD   dwFrom;                        /* read from this position   */
  141.    WORD    wCount;                        /* Number of sectors to read */
  142.    LPSTR   lpstrReturn;                   /* Pointer to return buffer  */
  143.    DWORD   dwRetSize;                     /* Return buffer size        */
  144. } MCI_CD_READLONG_PARMS;
  145.  
  146. #pragma pack()
  147.  
  148.  
  149. /*******************************************************************/
  150. /* CD Table INI file, MMPMCD.INI, values                           */
  151. /*******************************************************************/
  152.  
  153. /*******************************************************************/
  154. /* Capability Flags I from the CD drive look-up table, MMPMCD.INI  */
  155. /*******************************************************************/
  156.  
  157. #define CDHW_CAP_CAN_EJECT    0x00000001  /* Can software eject disc         */
  158. #define CDHW_CAP_CAN_LOCK     0x00000002  /* Can lock drive/disable eject    */
  159. #define CDHW_CAP_READS_RAW    0x00000004  /* Can read raw sectors            */
  160. #define CDHW_CAP_CAN_WRITE    0x00000008  /* Can write to disc               */
  161. #define CDHW_CAP_CAN_PLAY     0x00000010  /* Can play CD-DA tracks           */
  162. #define CDHW_CAP_CAN_INTERLEV 0x00000020  /* Supports ISO-9660 interleaving  */
  163. #define CDHW_CAP_CAN_PREFETCH 0x00000080  /* Can prefetch internally         */
  164. #define CDHW_CAP_MANIP_AUDIO  0x00000100  /* Can manipulte audio channels    */
  165. #define CDHW_CAP_USES_REDBOOK 0x00000200  /* Can use Red Book mode           */
  166. #define CDHW_CAP_READS_XA     0x00000400  /* Can read CD-ROM/XA data         */
  167. #define CDHW_CAP_CONT_READS   0x00000800  /* Continues to read DA after stop */
  168. #define CDHW_CAP_CAN_REVERSE  0x00001000  /* Can play in reverse             */
  169. #define CDHW_CAP_READS_CDDA   0x40000000  /* Can read CD-DA audio tracks     */
  170.  
  171.  
  172. /*******************************************************************/
  173. /* Capability Flags II from the CD drive look-up table, MMPMCD.INI */
  174. /*******************************************************************/
  175.  
  176. #define CDHW_VOL_DEP_MASK     0x00000007  /* Volume dependency mask        */
  177. #define CDHW_VOL_DEP_NONE              0  /* Volume without dependency     */
  178. #define CDHW_VOL_DEP_HIGH              2  /* Volume is highest value       */
  179. #define CDHW_VOL_DEP_LOW               3  /* Volume is lowest value        */
  180. #define CDHW_VOL_DEP_LEFT              4  /* Volume is left volume         */
  181. #define CDHW_VOL_DEP_RIGHT             5  /* Volume is right volume        */
  182. #define CDHW_VOL_INDEP_MUTE   0x00000008  /* Mute has no dependency        */
  183. #define CDHW_CAP_LOCK_MOUNT   0x00000010  /* Can only lock when mounted    */
  184. #define CDHW_CAP_PLAY_VIDEO   0x00000020  /* Can play video                */
  185. #define CDHW_CAP_MODAL_ONLY   0x00000040  /* Stop req to interrupt PLAY    */
  186. #define CDHW_CAP_SUP_SEEK     0x00000080  /* Supports SEEK IOCTL           */
  187. #define CDHW_CAP_SUP_UPC      0x00000100  /* Supports UPC IOCTL            */
  188. #define CDHW_CAP_SUP_SUBCHAN  0x00000200  /* Supports sub-channel IOCTL    */
  189. #define CDHW_CAP_CAN_CLS_TRAY 0x00000400  /* Can close door/retract caddy  */
  190. #define CDHW_CAP_NO_STREAM    0x00001000  /* Cannot stream CD-DA when PDD  */
  191.                                           /*   says it can                 */
  192. #define CDHW_CAP_VAR_PLAY     0x80000000  /* Supports variable speeds      */
  193.  
  194. /* INI file record structure */
  195. #define CDINI_APPSIZE                  8  /* Application name size    */
  196. #define CDINI_KEYSIZE                 16  /* Key name size            */
  197. #define CDINI_VSD_NAME_SIZE            8  /* size of file name        */
  198. #define VOLUME_CONTROL               101  /* num of values, 0% - 100% */
  199.  
  200. #pragma pack(1)
  201.  
  202. typedef struct
  203. {
  204.    USHORT usEntryVer;                     /* Entry version                 */
  205.    ULONG  ulCaps1;                        /* Capability flag I             */
  206.    ULONG  ulCaps2;                        /* Capability flag II            */
  207.    CHAR   VSDName[CDINI_VSD_NAME_SIZE];   /* DLL name for VSD              */
  208.    ULONG  ulMinStart;                     /* Min starting addr, 0x00MMSSFF */
  209.    USHORT usVolCnt;                       /* volume level counter          */
  210.    USHORT ausVolValues[VOLUME_CONTROL];   /* volume control values         */
  211. } MMPMCD_REC;
  212.  
  213. #pragma pack()
  214.  
  215.  
  216.