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