summaryrefslogtreecommitdiffstats
path: root/arm-wt-22k/lib_src/dls2.h
blob: 081557d907a312afca881a2c6ce59475d93de569 (plain)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
/*

    dls2.h

    Description:

    Interface defines and structures for the DLS2 extensions of DLS.


     Written by Microsoft 1998.  Released for public use.

*/

#ifndef _INC_DLS2
#define _INC_DLS2

/*
     FOURCC's used in the DLS2 file, in addition to DLS1 chunks
*/

#define FOURCC_RGN2  mmioFOURCC('r','g','n','2')
#define FOURCC_LAR2  mmioFOURCC('l','a','r','2')
#define FOURCC_ART2  mmioFOURCC('a','r','t','2')
#define FOURCC_CDL   mmioFOURCC('c','d','l',' ')
#define FOURCC_DLID  mmioFOURCC('d','l','i','d')

/*
     Articulation connection graph definitions. These are in addition to
     the definitions in the DLS1 header.
*/

/* Generic Sources (in addition to DLS1 sources. */
#define CONN_SRC_POLYPRESSURE       0x0007  /* Polyphonic Pressure */
#define CONN_SRC_CHANNELPRESSURE        0x0008  /* Channel Pressure */
#define CONN_SRC_VIBRATO            0x0009  /* Vibrato LFO */
#define CONN_SRC_MONOPRESSURE           0x000a  /* MIDI Mono pressure */


/* Midi Controllers */
#define CONN_SRC_CC91           0x00db  /* Reverb Send */
#define CONN_SRC_CC93           0x00dd  /* Chorus Send */


/* Generic Destinations */
#define CONN_DST_GAIN           0x0001  /* Same as CONN_DST_ ATTENUATION, but more appropriate terminology. */
#define CONN_DST_KEYNUMBER 0x0005  /* Key Number Generator */

/* Audio Channel Output Destinations */
#define CONN_DST_LEFT           0x0010  /* Left Channel Send */
#define CONN_DST_RIGHT          0x0011  /* Right Channel Send */
#define CONN_DST_CENTER         0x0012  /* Center Channel Send */
#define CONN_DST_LEFTREAR           0x0013  /* Left Rear Channel Send */
#define CONN_DST_RIGHTREAR          0x0014  /* Right Rear Channel Send */
#define CONN_DST_LFE_CHANNEL        0x0015  /* LFE Channel Send */
#define CONN_DST_CHORUS         0x0080  /* Chorus Send */
#define CONN_DST_REVERB         0x0081  /* Reverb Send */

/* Vibrato LFO Destinations */
#define CONN_DST_VIB_FREQUENCY      0x0114  /* Vibrato Frequency */
#define CONN_DST_VIB_STARTDELAY     0x0115  /* Vibrato Start Delay */

/* EG1 Destinations */
#define CONN_DST_EG1_DELAYTIME      0x020B  /* EG1 Delay Time */
#define CONN_DST_EG1_HOLDTIME       0x020C  /* EG1 Hold Time */
#define CONN_DST_EG1_SHUTDOWNTIME       0x020D  /* EG1 Shutdown Time */


/*  EG2 Destinations */
#define CONN_DST_EG2_DELAYTIME      0x030F  /* EG2 Delay Time */
#define CONN_DST_EG2_HOLDTIME       0x0310  /* EG2 Hold Time */


/* Filter Destinations */
#define CONN_DST_FILTER_CUTOFF      0x0500  /* Filter Cutoff Frequency */
#define CONN_DST_FILTER_Q           0x0501  /* Filter Resonance */


/* Transforms */
#define CONN_TRN_CONVEX         0x0002  /* Convex Transform */
#define CONN_TRN_SWITCH         0x0003  /* Switch Transform */


/*  Conditional chunk operators */
 #define DLS_CDL_AND            0x0001  /* X = X & Y */
 #define DLS_CDL_OR         0x0002  /* X = X | Y */
 #define DLS_CDL_XOR            0x0003  /* X = X ^ Y */
 #define DLS_CDL_ADD            0x0004  /* X = X + Y */
 #define DLS_CDL_SUBTRACT       0x0005  /* X = X - Y */
 #define DLS_CDL_MULTIPLY       0x0006  /* X = X * Y */
 #define DLS_CDL_DIVIDE     0x0007  /* X = X / Y */
 #define DLS_CDL_LOGICAL_AND    0x0008  /* X = X && Y */
 #define DLS_CDL_LOGICAL_OR     0x0009  /* X = X || Y */
 #define DLS_CDL_LT         0x000A  /* X = (X < Y) */
 #define DLS_CDL_LE         0x000B  /* X = (X <= Y) */
 #define DLS_CDL_GT         0x000C  /* X = (X > Y) */
 #define DLS_CDL_GE         0x000D  /* X = (X >= Y) */
 #define DLS_CDL_EQ         0x000E  /* X = (X == Y) */
 #define DLS_CDL_NOT            0x000F  /* X = !X */
 #define DLS_CDL_CONST      0x0010  /* 32-bit constant */
 #define DLS_CDL_QUERY      0x0011  /* 32-bit value returned from query */
 #define DLS_CDL_QUERYSUPPORTED 0x0012  /* 32-bit value returned from query */

/*
  Loop and release
*/

#define WLOOP_TYPE_RELEASE 1

/*
  DLSID queries for <cdl-ck>
*/
DEFINE_DLSID(DLSID_GMInHardware, 0x178f2f24, 0xc364, 0x11d1, 0xa7, 0x60, 0x00, 0x00, 0xf8, 0x75, 0xac, 0x12);
DEFINE_DLSID(DLSID_GSInHardware, 0x178f2f25, 0xc364, 0x11d1, 0xa7, 0x60, 0x00, 0x00, 0xf8, 0x75, 0xac, 0x12);
DEFINE_DLSID(DLSID_XGInHardware, 0x178f2f26, 0xc364, 0x11d1, 0xa7, 0x60, 0x00, 0x00, 0xf8, 0x75, 0xac, 0x12);
DEFINE_DLSID(DLSID_SupportsDLS1, 0x178f2f27, 0xc364, 0x11d1, 0xa7, 0x60, 0x00, 0x00, 0xf8, 0x75, 0xac, 0x12);
DEFINE_DLSID(DLSID_SupportsDLS2, 0xf14599e5, 0x4689, 0x11d2, 0xaf, 0xa6, 0x0, 0xaa, 0x0, 0x24, 0xd8, 0xb6);
DEFINE_DLSID(DLSID_SampleMemorySize, 0x178f2f28, 0xc364, 0x11d1, 0xa7, 0x60, 0x00, 0x00, 0xf8, 0x75, 0xac, 0x12);
DEFINE_DLSID(DLSID_ManufacturersID, 0xb03e1181, 0x8095, 0x11d2, 0xa1, 0xef, 0x0, 0x60, 0x8, 0x33, 0xdb, 0xd8);
DEFINE_DLSID(DLSID_ProductID, 0xb03e1182, 0x8095, 0x11d2, 0xa1, 0xef, 0x0, 0x60, 0x8, 0x33, 0xdb, 0xd8);
DEFINE_DLSID(DLSID_SamplePlaybackRate, 0x2a91f713, 0xa4bf, 0x11d2, 0xbb, 0xdf, 0x0, 0x60, 0x8, 0x33, 0xdb, 0xd8);
#endif  /* _INC_DLS2 */