source: Daodan/MSYS2/mingw32/i686-w64-mingw32/include/mmddk.h@ 1194

Last change on this file since 1194 was 1166, checked in by rossy, 3 years ago

Daodan: Replace MinGW build env with an up-to-date MSYS2 env

File size: 12.9 KB
RevLine 
[1166]1/**
2 * This file has no copyright assigned and is placed in the Public Domain.
3 * This file is part of the mingw-w64 runtime package.
4 * No warranty is given; refer to the file DISCLAIMER.PD within this package.
5 */
6
7#ifndef _INC_MMDDK
8#define _INC_MMDDK
9
10#include <winapifamily.h>
11
12#if WINAPI_FAMILY_PARTITION(WINAPI_PARTITION_DESKTOP)
13
14#include "pshpack1.h"
15
16#ifdef __cplusplus
17extern "C" {
18#endif
19
20#ifdef MMNOTIMER
21#define MMNOTIMERDEV
22#endif
23#ifdef MMNOWAVE
24#define MMNOWAVEDEV
25#endif
26#ifdef MMNOMIDI
27#define MMNOMIDIDEV
28#endif
29#ifdef MMNOAUX
30#define MMNOAUXDEV
31#endif
32#ifdef MMNOJOY
33#define MMNOJOYDEV
34#endif
35#ifdef MMNOMMIO
36#define MMNOMMIODEV
37#endif
38#ifdef MMNOMCI
39#define MMNOMCIDEV
40#endif
41
42#ifndef NODRIVERS
43
44#define DRV_LOAD 0x0001
45#define DRV_ENABLE 0x0002
46#define DRV_OPEN 0x0003
47#define DRV_CLOSE 0x0004
48#define DRV_DISABLE 0x0005
49#define DRV_FREE 0x0006
50#define DRV_CONFIGURE 0x0007
51#define DRV_QUERYCONFIGURE 0x0008
52#define DRV_INSTALL 0x0009
53#define DRV_REMOVE 0x000a
54
55#define DRV_RESERVED 0x0800
56#define DRV_USER 0x4000
57
58#define DRIVERS_SECTION TEXT("DRIVERS32")
59#define MCI_SECTION TEXT("MCI32")
60
61#endif /* !NODRIVERS */
62
63#define DCB_NULL 0x0000
64#define DCB_WINDOW 0x0001
65#define DCB_TASK 0x0002
66#define DCB_FUNCTION 0x0003
67#define DCB_EVENT 0x0005
68#define DCB_TYPEMASK 0x0007
69#define DCB_NOSWITCH 0x0008
70
71#define DRVM_INIT 100
72#define DRVM_EXIT 101
73#define DRVM_DISABLE 102
74#define DRVM_ENABLE 103
75#define DRVM_INIT_EX 104
76
77#ifndef DRVM_MAPPER
78#define DRVM_MAPPER 0x2000
79#endif
80#define DRVM_USER 0x4000
81#define DRVM_MAPPER_STATUS (DRVM_MAPPER+0)
82#define DRVM_MAPPER_RECONFIGURE (DRVM_MAPPER+1)
83#define DRVM_MAPPER_PREFERRED_GET (DRVM_MAPPER+21)
84#define DRVM_MAPPER_CONSOLEVOICECOM_GET (DRVM_MAPPER+23)
85
86#define DRV_QUERYDEVNODE (DRV_RESERVED + 2)
87#define DRV_QUERYMAPPABLE (DRV_RESERVED + 5)
88#define DRV_QUERYMODULE (DRV_RESERVED + 9)
89#define DRV_PNPINSTALL (DRV_RESERVED + 11)
90#define DRV_QUERYDEVICEINTERFACE (DRV_RESERVED + 12)
91#define DRV_QUERYDEVICEINTERFACESIZE (DRV_RESERVED + 13)
92#define DRV_QUERYSTRINGID (DRV_RESERVED + 14)
93#define DRV_QUERYSTRINGIDSIZE (DRV_RESERVED + 15)
94#define DRV_QUERYIDFROMSTRINGID (DRV_RESERVED + 16)
95#define DRV_QUERYFUNCTIONINSTANCEID (DRV_RESERVED + 17)
96#define DRV_QUERYFUNCTIONINSTANCEIDSIZE (DRV_RESERVED + 18)
97
98#define DRVM_MAPPER_PREFERRED_FLAGS_PREFERREDONLY 0x00000001
99
100#define DRVM_IOCTL 0x100
101#define DRVM_ADD_THRU (DRVM_IOCTL+1)
102#define DRVM_REMOVE_THRU (DRVM_IOCTL+2)
103#define DRVM_IOCTL_LAST (DRVM_IOCTL+5)
104
105typedef struct {
106 DWORD dwSize;
107 DWORD dwCmd;
108} DRVM_IOCTL_DATA, *LPDRVM_IOCTL_DATA;
109
110#define DRVM_IOCTL_CMD_USER __MSABI_LONG(0x00000000)
111#define DRVM_IOCTL_CMD_SYSTEM __MSABI_LONG(0x80000000)
112
113#define VADMAD_Device_ID 0X0444
114
115typedef struct {
116 DWORD cbSize;
117 LPVOID pCaps;
118} MDEVICECAPSEX;
119
120#ifndef MMNOWAVEDEV
121
122#define WODM_INIT DRVM_INIT
123#define WIDM_INIT DRVM_INIT
124#define WODM_INIT_EX DRVM_INIT_EX
125#define WIDM_INIT_EX DRVM_INIT_EX
126
127typedef struct waveopendesc_tag {
128 HWAVE hWave;
129 LPWAVEFORMAT lpFormat;
130 DWORD_PTR dwCallback;
131 DWORD_PTR dwInstance;
132 UINT uMappedDeviceID;
133 DWORD_PTR dnDevNode;
134} WAVEOPENDESC, *LPWAVEOPENDESC;
135
136#define WODM_GETNUMDEVS 3
137#define WODM_GETDEVCAPS 4
138#define WODM_OPEN 5
139#define WODM_CLOSE 6
140#define WODM_PREPARE 7
141#define WODM_UNPREPARE 8
142#define WODM_WRITE 9
143#define WODM_PAUSE 10
144#define WODM_RESTART 11
145#define WODM_RESET 12
146#define WODM_GETPOS 13
147#define WODM_GETPITCH 14
148#define WODM_SETPITCH 15
149#define WODM_GETVOLUME 16
150#define WODM_SETVOLUME 17
151#define WODM_GETPLAYBACKRATE 18
152#define WODM_SETPLAYBACKRATE 19
153#define WODM_BREAKLOOP 20
154#define WODM_PREFERRED 21
155
156#define WODM_MAPPER_STATUS (DRVM_MAPPER_STATUS + 0)
157#define WAVEOUT_MAPPER_STATUS_DEVICE 0
158#define WAVEOUT_MAPPER_STATUS_MAPPED 1
159#define WAVEOUT_MAPPER_STATUS_FORMAT 2
160
161#define WODM_BUSY 21
162
163#define WIDM_GETNUMDEVS 50
164#define WIDM_GETDEVCAPS 51
165#define WIDM_OPEN 52
166#define WIDM_CLOSE 53
167#define WIDM_PREPARE 54
168#define WIDM_UNPREPARE 55
169#define WIDM_ADDBUFFER 56
170#define WIDM_START 57
171#define WIDM_STOP 58
172#define WIDM_RESET 59
173#define WIDM_GETPOS 60
174#define WIDM_PREFERRED 61
175
176#define WIDM_MAPPER_STATUS (DRVM_MAPPER_STATUS + 0)
177#define WAVEIN_MAPPER_STATUS_DEVICE 0
178#define WAVEIN_MAPPER_STATUS_MAPPED 1
179#define WAVEIN_MAPPER_STATUS_FORMAT 2
180
181#endif /* !MMNOWAVEDEV */
182
183#ifndef MMNOMIDIDEV
184
185#define MODM_USER DRVM_USER
186#define MIDM_USER DRVM_USER
187#define MODM_MAPPER DRVM_MAPPER
188#define MIDM_MAPPER DRVM_MAPPER
189
190#define MODM_INIT DRVM_INIT
191#define MIDM_INIT DRVM_INIT
192#define MODM_INIT_EX DRVM_INIT_EX
193#define MIDM_INIT_EX DRVM_INIT_EX
194
195#ifndef MMNOMIDI
196
197typedef struct midiopenstrmid_tag {
198 DWORD dwStreamID;
199 UINT uDeviceID;
200} MIDIOPENSTRMID;
201
202typedef struct midiopendesc_tag {
203 HMIDI hMidi;
204 DWORD_PTR dwCallback;
205 DWORD_PTR dwInstance;
206 DWORD_PTR dnDevNode;
207 DWORD cIds;
208 MIDIOPENSTRMID rgIds[1];
209} MIDIOPENDESC, *LPMIDIOPENDESC;
210
211#endif /* MMNOMIDI */
212
213#define MIDI_IO_PACKED __MSABI_LONG(0x00000000)
214#define MIDI_IO_COOKED __MSABI_LONG(0x00000002)
215
216#define MODM_GETNUMDEVS 1
217#define MODM_GETDEVCAPS 2
218#define MODM_OPEN 3
219#define MODM_CLOSE 4
220#define MODM_PREPARE 5
221#define MODM_UNPREPARE 6
222#define MODM_DATA 7
223#define MODM_LONGDATA 8
224#define MODM_RESET 9
225#define MODM_GETVOLUME 10
226#define MODM_SETVOLUME 11
227#define MODM_CACHEPATCHES 12
228#define MODM_CACHEDRUMPATCHES 13
229
230#if WINVER >= 0x400
231#define MODM_STRMDATA 14
232#define MODM_GETPOS 17
233#define MODM_PAUSE 18
234#define MODM_RESTART 19
235#define MODM_STOP 20
236#define MODM_PROPERTIES 21
237#define MODM_PREFERRED 22
238#define MODM_RECONFIGURE (MODM_USER + 0x0768)
239#endif
240
241#define MIDM_GETNUMDEVS 53
242#define MIDM_GETDEVCAPS 54
243#define MIDM_OPEN 55
244#define MIDM_CLOSE 56
245#define MIDM_PREPARE 57
246#define MIDM_UNPREPARE 58
247#define MIDM_ADDBUFFER 59
248#define MIDM_START 60
249#define MIDM_STOP 61
250#define MIDM_RESET 62
251
252#endif /* !MMNOMIDIDEV */
253
254#ifndef MMNOAUXDEV
255
256#define AUXM_INIT DRVM_INIT
257#define AUXM_INIT_EX DRVM_INIT_EX
258
259#define AUXDM_GETNUMDEVS 3
260#define AUXDM_GETDEVCAPS 4
261#define AUXDM_GETVOLUME 5
262#define AUXDM_SETVOLUME 6
263
264#endif /* !MMNOAUXDEV */
265
266#ifndef MMNOMIXERDEV
267
268typedef struct tMIXEROPENDESC {
269 HMIXER hmx;
270 LPVOID pReserved0;
271 DWORD_PTR dwCallback;
272 DWORD_PTR dwInstance;
273 DWORD_PTR dnDevNode;
274} MIXEROPENDESC, *PMIXEROPENDESC, *LPMIXEROPENDESC;
275
276#define MXDM_INIT DRVM_INIT
277#define MXDM_INIT_EX DRVM_INIT_EX
278#define MXDM_USER DRV_USER
279
280#define MXDM_BASE (1)
281#define MXDM_GETNUMDEVS (MXDM_BASE + 0)
282#define MXDM_GETDEVCAPS (MXDM_BASE + 1)
283#define MXDM_OPEN (MXDM_BASE + 2)
284#define MXDM_CLOSE (MXDM_BASE + 3)
285#define MXDM_GETLINEINFO (MXDM_BASE + 4)
286#define MXDM_GETLINECONTROLS (MXDM_BASE + 5)
287#define MXDM_GETCONTROLDETAILS (MXDM_BASE + 6)
288#define MXDM_SETCONTROLDETAILS (MXDM_BASE + 7)
289
290#endif /* !MMNOMIXERDEV */
291
292#ifndef MMNOTIMERDEV
293
294typedef struct timerevent_tag {
295 WORD wDelay;
296 WORD wResolution;
297 LPTIMECALLBACK lpFunction;
298 DWORD dwUser;
299 WORD wFlags;
300 WORD wReserved1;
301} TIMEREVENT, *LPTIMEREVENT;
302
303#define TDD_KILLTIMEREVENT (DRV_RESERVED + 0)
304#define TDD_SETTIMEREVENT (DRV_RESERVED + 4)
305#define TDD_GETSYSTEMTIME (DRV_RESERVED + 8)
306#define TDD_GETDEVCAPS (DRV_RESERVED + 12)
307#define TDD_BEGINMINPERIOD (DRV_RESERVED + 16)
308#define TDD_ENDMINPERIOD (DRV_RESERVED + 20)
309
310#endif /* !MMNOTIMERDEV */
311
312#ifndef MMNOJOYDEV
313
314#define JOY_CONFIGCHANGED_MSGSTRING "MSJSTICK_VJOYD_MSGSTR"
315
316#define JOY_HW_NONE 0
317#define JOY_HW_CUSTOM 1
318#define JOY_HW_2A_2B_GENERIC 2
319#define JOY_HW_2A_4B_GENERIC 3
320#define JOY_HW_2B_GAMEPAD 4
321#define JOY_HW_2B_FLIGHTYOKE 5
322#define JOY_HW_2B_FLIGHTYOKETHROTTLE 6
323#define JOY_HW_3A_2B_GENERIC 7
324#define JOY_HW_3A_4B_GENERIC 8
325#define JOY_HW_4B_GAMEPAD 9
326#define JOY_HW_4B_FLIGHTYOKE 10
327#define JOY_HW_4B_FLIGHTYOKETHROTTLE 11
328#define JOY_HW_LASTENTRY 12
329
330#define JOY_ISCAL_XY 0x00000001
331#define JOY_ISCAL_Z 0x00000002
332#define JOY_ISCAL_R 0x00000004
333#define JOY_ISCAL_U 0x00000008
334#define JOY_ISCAL_V 0x00000010
335#define JOY_ISCAL_POV 0x00000020
336
337#define JOY_POV_NUMDIRS 4
338#define JOY_POVVAL_FORWARD 0
339#define JOY_POVVAL_BACKWARD 1
340#define JOY_POVVAL_LEFT 2
341#define JOY_POVVAL_RIGHT 3
342
343#define JOY_HWS_HASZ 0x00000001
344#define JOY_HWS_HASPOV 0x00000002
345#define JOY_HWS_POVISBUTTONCOMBOS 0x00000004
346#define JOY_HWS_POVISPOLL 0x00000008
347#define JOY_HWS_ISYOKE 0x00000010
348#define JOY_HWS_ISGAMEPAD 0x00000020
349#define JOY_HWS_ISCARCTRL 0x00000040
350
351#define JOY_HWS_XISJ1Y 0x00000080
352#define JOY_HWS_XISJ2X 0x00000100
353#define JOY_HWS_XISJ2Y 0x00000200
354
355#define JOY_HWS_YISJ1X 0x00000400
356#define JOY_HWS_YISJ2X 0x00000800
357#define JOY_HWS_YISJ2Y 0x00001000
358
359#define JOY_HWS_ZISJ1X 0x00002000
360#define JOY_HWS_ZISJ1Y 0x00004000
361#define JOY_HWS_ZISJ2X 0x00008000
362
363#define JOY_HWS_POVISJ1X 0x00010000
364#define JOY_HWS_POVISJ1Y 0x00020000
365#define JOY_HWS_POVISJ2X 0x00040000
366
367#define JOY_HWS_HASR 0x00080000
368#define JOY_HWS_RISJ1X 0x00100000
369#define JOY_HWS_RISJ1Y 0x00200000
370#define JOY_HWS_RISJ2Y 0x00400000
371
372#define JOY_HWS_HASU 0x00800000
373#define JOY_HWS_HASV 0x01000000
374
375#define JOY_US_HASRUDDER 0x00000001
376#define JOY_US_PRESENT 0x00000002
377#define JOY_US_ISOEM 0x00000004
378
379typedef struct joypos_tag {
380 DWORD dwX;
381 DWORD dwY;
382 DWORD dwZ;
383 DWORD dwR;
384 DWORD dwU;
385 DWORD dwV;
386} JOYPOS, *LPJOYPOS;
387
388typedef struct joyrange_tag {
389 JOYPOS jpMin;
390 JOYPOS jpMax;
391 JOYPOS jpCenter;
392} JOYRANGE, *LPJOYRANGE;
393
394typedef struct joyreguservalues_tag {
395 DWORD dwTimeOut;
396 JOYRANGE jrvRanges;
397 JOYPOS jpDeadZone;
398} JOYREGUSERVALUES, *LPJOYREGUSERVALUES;
399
400typedef struct joyreghwsettings_tag {
401 DWORD dwFlags;
402 DWORD dwNumButtons;
403} JOYREGHWSETTINGS, *LPJOYHWSETTINGS;
404
405typedef struct joyreghwvalues_tag {
406 JOYRANGE jrvHardware;
407 DWORD dwPOVValues[JOY_POV_NUMDIRS];
408 DWORD dwCalFlags;
409} JOYREGHWVALUES, *LPJOYREGHWVALUES;
410
411typedef struct joyreghwconfig_tag {
412 JOYREGHWSETTINGS hws;
413 DWORD dwUsageSettings;
414 JOYREGHWVALUES hwv;
415 DWORD dwType;
416 DWORD dwReserved;
417} JOYREGHWCONFIG, *LPJOYREGHWCONFIG;
418
419typedef struct joycalibrate_tag {
420 WORD wXbase;
421 WORD wXdelta;
422 WORD wYbase;
423 WORD wYdelta;
424 WORD wZbase;
425 WORD wZdelta;
426} JOYCALIBRATE, *LPJOYCALIBRATE;
427
428typedef DWORD (JOYDEVMSGPROC)(DWORD, UINT, LONG, LONG);
429typedef JOYDEVMSGPROC *LPJOYDEVMSGPROC;
430
431#define JDD_GETNUMDEVS (DRV_RESERVED + 0x0001)
432#define JDD_GETDEVCAPS (DRV_RESERVED + 0x0002)
433#define JDD_GETPOS (DRV_RESERVED + 0x0101)
434#define JDD_SETCALIBRATION (DRV_RESERVED + 0x0102)
435#define JDD_CONFIGCHANGED (DRV_RESERVED + 0x0103)
436#define JDD_GETPOSEX (DRV_RESERVED + 0x0104)
437
438#endif /* !MMNOJOYDEV */
439
440#ifndef MAKELRESULT
441#define MAKELRESULT(low, high) ((LRESULT)MAKELONG(low, high))
442#endif
443
444#ifndef MMNOMCIDEV
445
446#define MCI_OPEN_DRIVER 0x0801
447#define MCI_CLOSE_DRIVER 0x0802
448
449#define MAKEMCIRESOURCE(wRet, wRes) MAKELRESULT((wRet), (wRes))
450
451#define MCI_FALSE (MCI_STRING_OFFSET + 19)
452#define MCI_TRUE (MCI_STRING_OFFSET + 20)
453
454#define MCI_FORMAT_RETURN_BASE MCI_FORMAT_MILLISECONDS_S
455#define MCI_FORMAT_MILLISECONDS_S (MCI_STRING_OFFSET + 21)
456#define MCI_FORMAT_HMS_S (MCI_STRING_OFFSET + 22)
457#define MCI_FORMAT_MSF_S (MCI_STRING_OFFSET + 23)
458#define MCI_FORMAT_FRAMES_S (MCI_STRING_OFFSET + 24)
459#define MCI_FORMAT_SMPTE_24_S (MCI_STRING_OFFSET + 25)
460#define MCI_FORMAT_SMPTE_25_S (MCI_STRING_OFFSET + 26)
461#define MCI_FORMAT_SMPTE_30_S (MCI_STRING_OFFSET + 27)
462#define MCI_FORMAT_SMPTE_30DROP_S (MCI_STRING_OFFSET + 28)
463#define MCI_FORMAT_BYTES_S (MCI_STRING_OFFSET + 29)
464#define MCI_FORMAT_SAMPLES_S (MCI_STRING_OFFSET + 30)
465#define MCI_FORMAT_TMSF_S (MCI_STRING_OFFSET + 31)
466
467#define MCI_VD_FORMAT_TRACK_S (MCI_VD_OFFSET + 5)
468
469#define WAVE_FORMAT_PCM_S (MCI_WAVE_OFFSET + 0)
470#define WAVE_MAPPER_S (MCI_WAVE_OFFSET + 1)
471
472#define MCI_SEQ_MAPPER_S (MCI_SEQ_OFFSET + 5)
473#define MCI_SEQ_FILE_S (MCI_SEQ_OFFSET + 6)
474#define MCI_SEQ_MIDI_S (MCI_SEQ_OFFSET + 7)
475#define MCI_SEQ_SMPTE_S (MCI_SEQ_OFFSET + 8)
476#define MCI_SEQ_FORMAT_SONGPTR_S (MCI_SEQ_OFFSET + 9)
477#define MCI_SEQ_NONE_S (MCI_SEQ_OFFSET + 10)
478#define MIDIMAPPER_S (MCI_SEQ_OFFSET + 11)
479
480#define MCI_TABLE_NOT_PRESENT ((UINT)-1)
481
482typedef struct {
483 MCIDEVICEID wDeviceID;
484 LPCWSTR lpstrParams;
485 UINT wCustomCommandTable;
486 UINT wType;
487} MCI_OPEN_DRIVER_PARMS, *LPMCI_OPEN_DRIVER_PARMS;
488
489#define MCI_MAX_DEVICE_TYPE_LENGTH 80
490
491#define MCI_RESOURCE_RETURNED 0x00010000
492#define MCI_COLONIZED3_RETURN 0x00020000
493#define MCI_COLONIZED4_RETURN 0x00040000
494#define MCI_INTEGER_RETURNED 0x00080000
495#define MCI_RESOURCE_DRIVER 0x00100000
496
497#define MCI_NO_COMMAND_TABLE ((UINT)(-1))
498
499#define MCI_COMMAND_HEAD 0
500#define MCI_STRING 1
501#define MCI_INTEGER 2
502#define MCI_END_COMMAND 3
503#define MCI_RETURN 4
504#define MCI_FLAG 5
505#define MCI_END_COMMAND_LIST 6
506#define MCI_RECT 7
507#define MCI_CONSTANT 8
508#define MCI_END_CONSTANT 9
509#define MCI_HWND 10
510#define MCI_HPAL 11
511#define MCI_HDC 12
512#ifdef _WIN64
513#define MCI_INTEGER64 13
514#endif
515
516#endif /* !MMNOMCIDEV */
517
518#ifndef MMNOTASKDEV
519
520#define TASKERR_NOTASKSUPPORT 1
521#define TASKERR_OUTOFMEMORY 2
522
523typedef VOID (TASKCALLBACK) (DWORD_PTR dwInst);
524typedef TASKCALLBACK *LPTASKCALLBACK;
525
526UINT APIENTRY mmTaskCreate(LPTASKCALLBACK lpfn, HANDLE *lph, DWORD_PTR dwInst);
527VOID APIENTRY mmTaskBlock(DWORD h);
528WINBOOL APIENTRY mmTaskSignal(DWORD h);
529VOID APIENTRY mmTaskYield(VOID);
530DWORD APIENTRY mmGetCurrentTask(VOID);
531
532#endif /* MMNOTASKDEV */
533
534#define MMDDKINC
535
536#ifdef __cplusplus
537}
538#endif
539
540#include "poppack.h"
541
542#endif /* WINAPI_PARTITION_DESKTOP */
543
544#endif /* _INC_MMDDK */
Note: See TracBrowser for help on using the repository browser.