Home | History | Annotate | Download | only in lib_src
      1 /*
      2 
      3     dls2.h
      4 
      5     Description:
      6 
      7     Interface defines and structures for the DLS2 extensions of DLS.
      8 
      9 
     10      Written by Microsoft 1998.  Released for public use.
     11 
     12 */
     13 
     14 #ifndef _INC_DLS2
     15 #define _INC_DLS2
     16 
     17 /*
     18      FOURCC's used in the DLS2 file, in addition to DLS1 chunks
     19 */
     20 
     21 #define FOURCC_RGN2  mmioFOURCC('r','g','n','2')
     22 #define FOURCC_LAR2  mmioFOURCC('l','a','r','2')
     23 #define FOURCC_ART2  mmioFOURCC('a','r','t','2')
     24 #define FOURCC_CDL   mmioFOURCC('c','d','l',' ')
     25 #define FOURCC_DLID  mmioFOURCC('d','l','i','d')
     26 
     27 /*
     28      Articulation connection graph definitions. These are in addition to
     29      the definitions in the DLS1 header.
     30 */
     31 
     32 /* Generic Sources (in addition to DLS1 sources. */
     33 #define CONN_SRC_POLYPRESSURE       0x0007  /* Polyphonic Pressure */
     34 #define CONN_SRC_CHANNELPRESSURE        0x0008  /* Channel Pressure */
     35 #define CONN_SRC_VIBRATO            0x0009  /* Vibrato LFO */
     36 #define CONN_SRC_MONOPRESSURE           0x000a  /* MIDI Mono pressure */
     37 
     38 
     39 /* Midi Controllers */
     40 #define CONN_SRC_CC91           0x00db  /* Reverb Send */
     41 #define CONN_SRC_CC93           0x00dd  /* Chorus Send */
     42 
     43 
     44 /* Generic Destinations */
     45 #define CONN_DST_GAIN           0x0001  /* Same as CONN_DST_ ATTENUATION, but more appropriate terminology. */
     46 #define CONN_DST_KEYNUMBER 0x0005  /* Key Number Generator */
     47 
     48 /* Audio Channel Output Destinations */
     49 #define CONN_DST_LEFT           0x0010  /* Left Channel Send */
     50 #define CONN_DST_RIGHT          0x0011  /* Right Channel Send */
     51 #define CONN_DST_CENTER         0x0012  /* Center Channel Send */
     52 #define CONN_DST_LEFTREAR           0x0013  /* Left Rear Channel Send */
     53 #define CONN_DST_RIGHTREAR          0x0014  /* Right Rear Channel Send */
     54 #define CONN_DST_LFE_CHANNEL        0x0015  /* LFE Channel Send */
     55 #define CONN_DST_CHORUS         0x0080  /* Chorus Send */
     56 #define CONN_DST_REVERB         0x0081  /* Reverb Send */
     57 
     58 /* Vibrato LFO Destinations */
     59 #define CONN_DST_VIB_FREQUENCY      0x0114  /* Vibrato Frequency */
     60 #define CONN_DST_VIB_STARTDELAY     0x0115  /* Vibrato Start Delay */
     61 
     62 /* EG1 Destinations */
     63 #define CONN_DST_EG1_DELAYTIME      0x020B  /* EG1 Delay Time */
     64 #define CONN_DST_EG1_HOLDTIME       0x020C  /* EG1 Hold Time */
     65 #define CONN_DST_EG1_SHUTDOWNTIME       0x020D  /* EG1 Shutdown Time */
     66 
     67 
     68 /*  EG2 Destinations */
     69 #define CONN_DST_EG2_DELAYTIME      0x030F  /* EG2 Delay Time */
     70 #define CONN_DST_EG2_HOLDTIME       0x0310  /* EG2 Hold Time */
     71 
     72 
     73 /* Filter Destinations */
     74 #define CONN_DST_FILTER_CUTOFF      0x0500  /* Filter Cutoff Frequency */
     75 #define CONN_DST_FILTER_Q           0x0501  /* Filter Resonance */
     76 
     77 
     78 /* Transforms */
     79 #define CONN_TRN_CONVEX         0x0002  /* Convex Transform */
     80 #define CONN_TRN_SWITCH         0x0003  /* Switch Transform */
     81 
     82 
     83 /*  Conditional chunk operators */
     84  #define DLS_CDL_AND            0x0001  /* X = X & Y */
     85  #define DLS_CDL_OR         0x0002  /* X = X | Y */
     86  #define DLS_CDL_XOR            0x0003  /* X = X ^ Y */
     87  #define DLS_CDL_ADD            0x0004  /* X = X + Y */
     88  #define DLS_CDL_SUBTRACT       0x0005  /* X = X - Y */
     89  #define DLS_CDL_MULTIPLY       0x0006  /* X = X * Y */
     90  #define DLS_CDL_DIVIDE     0x0007  /* X = X / Y */
     91  #define DLS_CDL_LOGICAL_AND    0x0008  /* X = X && Y */
     92  #define DLS_CDL_LOGICAL_OR     0x0009  /* X = X || Y */
     93  #define DLS_CDL_LT         0x000A  /* X = (X < Y) */
     94  #define DLS_CDL_LE         0x000B  /* X = (X <= Y) */
     95  #define DLS_CDL_GT         0x000C  /* X = (X > Y) */
     96  #define DLS_CDL_GE         0x000D  /* X = (X >= Y) */
     97  #define DLS_CDL_EQ         0x000E  /* X = (X == Y) */
     98  #define DLS_CDL_NOT            0x000F  /* X = !X */
     99  #define DLS_CDL_CONST      0x0010  /* 32-bit constant */
    100  #define DLS_CDL_QUERY      0x0011  /* 32-bit value returned from query */
    101  #define DLS_CDL_QUERYSUPPORTED 0x0012  /* 32-bit value returned from query */
    102 
    103 /*
    104   Loop and release
    105 */
    106 
    107 #define WLOOP_TYPE_RELEASE 1
    108 
    109 /*
    110   DLSID queries for <cdl-ck>
    111 */
    112 DEFINE_DLSID(DLSID_GMInHardware, 0x178f2f24, 0xc364, 0x11d1, 0xa7, 0x60, 0x00, 0x00, 0xf8, 0x75, 0xac, 0x12);
    113 DEFINE_DLSID(DLSID_GSInHardware, 0x178f2f25, 0xc364, 0x11d1, 0xa7, 0x60, 0x00, 0x00, 0xf8, 0x75, 0xac, 0x12);
    114 DEFINE_DLSID(DLSID_XGInHardware, 0x178f2f26, 0xc364, 0x11d1, 0xa7, 0x60, 0x00, 0x00, 0xf8, 0x75, 0xac, 0x12);
    115 DEFINE_DLSID(DLSID_SupportsDLS1, 0x178f2f27, 0xc364, 0x11d1, 0xa7, 0x60, 0x00, 0x00, 0xf8, 0x75, 0xac, 0x12);
    116 DEFINE_DLSID(DLSID_SupportsDLS2, 0xf14599e5, 0x4689, 0x11d2, 0xaf, 0xa6, 0x0, 0xaa, 0x0, 0x24, 0xd8, 0xb6);
    117 DEFINE_DLSID(DLSID_SampleMemorySize, 0x178f2f28, 0xc364, 0x11d1, 0xa7, 0x60, 0x00, 0x00, 0xf8, 0x75, 0xac, 0x12);
    118 DEFINE_DLSID(DLSID_ManufacturersID, 0xb03e1181, 0x8095, 0x11d2, 0xa1, 0xef, 0x0, 0x60, 0x8, 0x33, 0xdb, 0xd8);
    119 DEFINE_DLSID(DLSID_ProductID, 0xb03e1182, 0x8095, 0x11d2, 0xa1, 0xef, 0x0, 0x60, 0x8, 0x33, 0xdb, 0xd8);
    120 DEFINE_DLSID(DLSID_SamplePlaybackRate, 0x2a91f713, 0xa4bf, 0x11d2, 0xbb, 0xdf, 0x0, 0x60, 0x8, 0x33, 0xdb, 0xd8);
    121 #endif  /* _INC_DLS2 */
    122 
    123