2010-02-26 11:43:19 +00:00
|
|
|
#pragma once
|
2009-02-12 20:13:19 +00:00
|
|
|
|
|
|
|
///
|
|
|
|
/// WDMAUD Interface Definition
|
|
|
|
///
|
|
|
|
/// History: 12/02/2008 Created
|
|
|
|
|
2009-02-15 13:31:52 +00:00
|
|
|
// These are now in sndtypes.h
|
|
|
|
/*
|
2009-02-12 20:13:19 +00:00
|
|
|
typedef enum
|
|
|
|
{
|
|
|
|
DEVICE_TYPE_NONE = 0,
|
|
|
|
DEVICE_TYPE_WAVE_OUT,
|
|
|
|
DEVICE_TYPE_WAVE_IN,
|
|
|
|
DEVICE_TYPE_MIDI_IN,
|
|
|
|
DEVICE_TYPE_MIDI_OUT,
|
|
|
|
DEVICE_TYPE_AUX_IN,
|
|
|
|
DEVICE_TYPE_AUX_OUT
|
|
|
|
|
|
|
|
}AUDIO_DEVICE_TYPE;
|
2009-02-15 13:31:52 +00:00
|
|
|
*/
|
|
|
|
|
|
|
|
#include <sndtypes.h>
|
2009-02-12 20:13:19 +00:00
|
|
|
|
|
|
|
typedef struct
|
|
|
|
{
|
2009-09-24 18:11:22 +00:00
|
|
|
KSSTREAM_HEADER Header;
|
2009-02-15 13:31:52 +00:00
|
|
|
SOUND_DEVICE_TYPE DeviceType;
|
2010-03-25 05:03:29 +00:00
|
|
|
ULONG_PTR DeviceIndex;
|
2009-02-12 20:13:19 +00:00
|
|
|
|
|
|
|
HANDLE hDevice;
|
|
|
|
ULONG DeviceCount;
|
2009-09-25 18:06:13 +00:00
|
|
|
ULONG Flags;
|
2009-02-12 20:13:19 +00:00
|
|
|
|
|
|
|
union
|
|
|
|
{
|
2009-09-24 19:24:22 +00:00
|
|
|
MIXERCAPSW MixCaps;
|
2009-09-24 18:11:22 +00:00
|
|
|
MIXERCONTROLDETAILS MixDetails;
|
|
|
|
MIXERLINECONTROLSW MixControls;
|
|
|
|
MIXERLINEW MixLine;
|
2009-02-12 20:13:19 +00:00
|
|
|
WAVEFORMATEX WaveFormatEx;
|
2009-02-24 18:05:07 +00:00
|
|
|
WAVEOUTCAPSW WaveOutCaps;
|
|
|
|
AUXCAPSW AuxCaps;
|
2009-07-11 23:23:40 +00:00
|
|
|
WAVEINCAPSW WaveInCaps;
|
|
|
|
ULONGLONG Position;
|
2009-10-26 23:10:05 +00:00
|
|
|
struct
|
|
|
|
{
|
|
|
|
LPWSTR DeviceInterfaceString;
|
|
|
|
ULONG DeviceInterfaceStringSize;
|
|
|
|
}Interface;
|
2009-11-13 01:48:28 +00:00
|
|
|
|
|
|
|
struct
|
|
|
|
{
|
|
|
|
HANDLE hMixer;
|
|
|
|
ULONG NotificationType;
|
|
|
|
ULONG Value;
|
|
|
|
}MixerEvent;
|
2009-07-11 23:23:40 +00:00
|
|
|
KSSTATE State;
|
2009-11-28 17:06:22 +00:00
|
|
|
KSRESET ResetStream;
|
2009-07-11 23:23:40 +00:00
|
|
|
ULONG Volume;
|
2009-07-17 19:15:52 +00:00
|
|
|
ULONG FrameSize;
|
2009-11-13 01:48:28 +00:00
|
|
|
HANDLE hNotifyEvent;
|
2009-02-12 20:13:19 +00:00
|
|
|
}u;
|
|
|
|
|
2009-02-21 20:18:44 +00:00
|
|
|
}WDMAUD_DEVICE_INFO, *PWDMAUD_DEVICE_INFO;
|
2009-02-12 20:13:19 +00:00
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
/// IOCTL_OPEN_WDMAUD
|
|
|
|
///
|
|
|
|
/// Description: This IOCTL informs wdmaud that an application whats to use wdmsys for a waveOut / waveIn / aux operation
|
|
|
|
///
|
|
|
|
/// Arguments: InputBuffer is a pointer to a WDMAUD_DEVICE_INFO structure,
|
|
|
|
/// InputBufferSize is size of WDMAUD_DEVICE_INFO structure
|
|
|
|
/// Note: DeviceType identifies the device type, DeviceIndex the index, WaveFormatEx the device details
|
|
|
|
/// Result: is returned in hDevice
|
|
|
|
/// Return Code: STATUS_SUCCESS indicates success, otherwise appropiate error code
|
|
|
|
/// Prequsites: none
|
|
|
|
|
2009-02-15 13:31:52 +00:00
|
|
|
#define IOCTL_OPEN_WDMAUD \
|
|
|
|
CTL_CODE(FILE_DEVICE_SOUND, \
|
|
|
|
0, \
|
|
|
|
METHOD_BUFFERED, \
|
2009-02-16 14:49:59 +00:00
|
|
|
FILE_CREATE_TREE_CONNECTION | FILE_ANY_ACCESS)
|
2009-02-12 20:13:19 +00:00
|
|
|
|
|
|
|
|
|
|
|
/// IOCTL_CLOSE_WDMAUD
|
|
|
|
///
|
|
|
|
/// Description: This IOCTL informs that an application has finished with wdmsys and closes the connection
|
|
|
|
///
|
|
|
|
/// Arguments: InputBuffer is a pointer to a WDMAUD_DEVICE_INFO structure,
|
|
|
|
/// InputBufferSize is size of WDMAUD_DEVICE_INFO structure
|
|
|
|
/// Note: DeviceType, DeviceIndex and hDevice must be set
|
|
|
|
/// ReturnCode: STATUS_SUCCESS indicates success
|
|
|
|
/// Prequsites: openend device
|
|
|
|
|
2009-02-15 13:31:52 +00:00
|
|
|
#define IOCTL_CLOSE_WDMAUD \
|
|
|
|
CTL_CODE(FILE_DEVICE_SOUND, \
|
|
|
|
1, \
|
|
|
|
METHOD_BUFFERED, \
|
2009-02-16 14:49:59 +00:00
|
|
|
FILE_CREATE_TREE_CONNECTION | FILE_ANY_ACCESS) \
|
2009-02-12 20:13:19 +00:00
|
|
|
|
|
|
|
|
|
|
|
/// IOCTL_GETNUMDEVS_TYPE
|
|
|
|
///
|
|
|
|
/// Description: This IOCTL queries the number of devices currently present of a specific type. The caller passes a WDMAUD_DEVICE_INFO structure.
|
|
|
|
///
|
|
|
|
/// Arguments: InputBuffer is a pointer to a WDMAUD_DEVICE_INFO structure,
|
|
|
|
/// InputBufferSize is size of WDMAUD_DEVICE_INFO structure
|
|
|
|
/// Note: The DeviceType contains the requested device type.
|
|
|
|
/// Result: The result is returned in DeviceCount
|
|
|
|
/// ReturnCode: STATUS_SUCCESS indicates success
|
|
|
|
/// Prequsites: none
|
|
|
|
|
2009-02-15 13:31:52 +00:00
|
|
|
#define IOCTL_GETNUMDEVS_TYPE \
|
|
|
|
CTL_CODE(FILE_DEVICE_SOUND, \
|
|
|
|
2, \
|
|
|
|
METHOD_BUFFERED, \
|
2009-02-16 14:49:59 +00:00
|
|
|
FILE_CREATE_TREE_CONNECTION | FILE_ANY_ACCESS)
|
2009-02-12 20:13:19 +00:00
|
|
|
|
|
|
|
|
|
|
|
/// IOCTL_SETDEVICE_STATE
|
|
|
|
///
|
|
|
|
/// Description: This IOCTL sets an opened waveOut / waveIn / midiIn / midiOut / aux device to specific state
|
|
|
|
///
|
|
|
|
/// Arguments: InputBuffer is a pointer to a WDMAUD_DEVICE_INFO structure,
|
|
|
|
/// InputBufferSize is size of WDMAUD_DEVICE_INFO structure
|
|
|
|
/// Note: The DeviceType, DeviceIndex, hDevice and State member must be set. State determines the new state
|
|
|
|
/// ReturnCode: STATUS_SUCCESS indicates success
|
|
|
|
/// Prequsites: opened device
|
|
|
|
|
2009-02-15 13:31:52 +00:00
|
|
|
#define IOCTL_SETDEVICE_STATE \
|
|
|
|
CTL_CODE(FILE_DEVICE_SOUND, \
|
|
|
|
3, \
|
|
|
|
METHOD_BUFFERED, \
|
2009-02-16 14:49:59 +00:00
|
|
|
FILE_CREATE_TREE_CONNECTION | FILE_ANY_ACCESS)
|
2009-02-12 20:13:19 +00:00
|
|
|
|
|
|
|
|
|
|
|
/// IOCTL_GETDEVID
|
|
|
|
///
|
|
|
|
/// Description: This IOCTL returns the device index by its provided handle
|
|
|
|
///
|
|
|
|
/// Arguments: InputBuffer is a pointer to a WDMAUD_DEVICE_INFO structure,
|
|
|
|
/// InputBufferSize is size of WDMAUD_DEVICE_INFO structure
|
|
|
|
/// Note: The DeviceType and hDevice must be set
|
|
|
|
/// Result: The result is returned in DeviceIndex
|
|
|
|
/// ReturnCode: STATUS_SUCCESS indicates success
|
|
|
|
/// Prequsites: opened device
|
|
|
|
|
2009-02-15 13:31:52 +00:00
|
|
|
#define IOCTL_GETDEVID \
|
|
|
|
CTL_CODE(FILE_DEVICE_SOUND, \
|
|
|
|
4, \
|
|
|
|
METHOD_BUFFERED, \
|
2009-02-16 14:49:59 +00:00
|
|
|
FILE_CREATE_TREE_CONNECTION | FILE_ANY_ACCESS)
|
2009-02-12 20:13:19 +00:00
|
|
|
|
|
|
|
|
|
|
|
/// IOCTL_GETVOLUME
|
|
|
|
///
|
|
|
|
/// Description: This IOCTL returns the volume a device
|
|
|
|
///
|
|
|
|
/// Arguments: InputBuffer is a pointer to a WDMAUD_DEVICE_INFO structure,
|
|
|
|
/// InputBufferSize is size of WDMAUD_DEVICE_INFO structure
|
|
|
|
/// Note: The DeviceType and hDevice must be set
|
|
|
|
/// Result: The result is returned in Volume
|
|
|
|
/// ReturnCode: STATUS_SUCCESS indicates success
|
|
|
|
/// Prequsites: opened device
|
|
|
|
|
2009-02-15 13:31:52 +00:00
|
|
|
#define IOCTL_GETVOLUME \
|
|
|
|
CTL_CODE(FILE_DEVICE_SOUND, \
|
|
|
|
5, \
|
2009-02-16 14:49:59 +00:00
|
|
|
METHOD_BUFFERED, \
|
|
|
|
FILE_CREATE_TREE_CONNECTION | FILE_ANY_ACCESS)
|
2009-02-12 20:13:19 +00:00
|
|
|
|
|
|
|
|
|
|
|
/// IOCTL_SETVOLUME
|
|
|
|
///
|
|
|
|
/// Description: This IOCTL sets the volume a device
|
|
|
|
///
|
|
|
|
/// Arguments: InputBuffer is a pointer to a WDMAUD_DEVICE_INFO structure,
|
|
|
|
/// InputBufferSize is size of WDMAUD_DEVICE_INFO structure
|
|
|
|
/// Note: The DeviceType, hDevice and Volume must be set
|
|
|
|
/// ReturnCode: STATUS_SUCCESS indicates success
|
|
|
|
/// Prequsites: opened device
|
|
|
|
|
2009-02-15 13:31:52 +00:00
|
|
|
#define IOCTL_SETVOLUME \
|
|
|
|
CTL_CODE(FILE_DEVICE_SOUND, \
|
|
|
|
6, \
|
|
|
|
METHOD_BUFFERED, \
|
2009-02-16 14:49:59 +00:00
|
|
|
FILE_CREATE_TREE_CONNECTION | FILE_ANY_ACCESS)
|
2009-02-12 20:13:19 +00:00
|
|
|
|
|
|
|
|
|
|
|
/// IOCTL_GETCAPABILTIES
|
|
|
|
///
|
|
|
|
/// Description: This IOCTL retrieves the capabilties of an specific device
|
|
|
|
///
|
|
|
|
/// Arguments: InputBuffer is a pointer to a WDMAUD_DEVICE_INFO structure,
|
|
|
|
/// InputBufferSize is size of WDMAUD_DEVICE_INFO structure
|
|
|
|
/// Note: The DeviceType and DeviceIndex must be set
|
|
|
|
/// ReturnCode: STATUS_SUCCESS indicates success
|
|
|
|
/// Prequsites: none
|
|
|
|
|
2009-02-15 13:31:52 +00:00
|
|
|
#define IOCTL_GETCAPABILITIES \
|
|
|
|
CTL_CODE(FILE_DEVICE_SOUND, \
|
|
|
|
7, \
|
|
|
|
METHOD_BUFFERED, \
|
2009-02-16 14:49:59 +00:00
|
|
|
FILE_CREATE_TREE_CONNECTION | FILE_ANY_ACCESS)
|
2009-02-12 20:13:19 +00:00
|
|
|
|
|
|
|
|
|
|
|
/// IOCTL_WRITEDATA
|
|
|
|
///
|
|
|
|
/// Description: This IOCTL writes data to specified device
|
|
|
|
///
|
|
|
|
/// Arguments: InputBuffer is a pointer to a WDMAUD_DEVICE_INFO structure,
|
|
|
|
/// InputBufferSize is size of WDMAUD_DEVICE_INFO structure
|
|
|
|
/// Note: The DeviceType, DeviceIndex, hDevice, BufferSize and Buffer must be set
|
|
|
|
/// ReturnCode: STATUS_SUCCESS indicates success
|
|
|
|
/// Prequsites: opened device
|
|
|
|
|
2009-02-15 13:31:52 +00:00
|
|
|
#define IOCTL_WRITEDATA \
|
|
|
|
CTL_CODE(FILE_DEVICE_SOUND, \
|
|
|
|
8, \
|
|
|
|
METHOD_BUFFERED, \
|
2009-02-16 14:49:59 +00:00
|
|
|
FILE_CREATE_TREE_CONNECTION | FILE_ANY_ACCESS)
|
2009-02-12 20:13:19 +00:00
|
|
|
|
2009-07-11 23:23:40 +00:00
|
|
|
/// IOCTL_GETPOS
|
|
|
|
///
|
|
|
|
/// Description: This IOCTL retrieves the current playback / write position
|
|
|
|
///
|
|
|
|
/// Arguments: InputBuffer is a pointer to a WDMAUD_DEVICE_INFO structure,
|
|
|
|
/// InputBufferSize is size of WDMAUD_DEVICE_INFO structure
|
|
|
|
/// Note: The DeviceType and hDevice must be set
|
2009-07-17 19:15:52 +00:00
|
|
|
/// Result: The result is returned in Position
|
2009-07-11 23:23:40 +00:00
|
|
|
/// ReturnCode: STATUS_SUCCESS indicates success
|
|
|
|
/// Prequsites: opened device
|
|
|
|
|
|
|
|
#define IOCTL_GETPOS \
|
|
|
|
CTL_CODE(FILE_DEVICE_SOUND, \
|
|
|
|
9, \
|
|
|
|
METHOD_BUFFERED, \
|
|
|
|
FILE_CREATE_TREE_CONNECTION | FILE_ANY_ACCESS)
|
|
|
|
|
2009-07-17 19:15:52 +00:00
|
|
|
/// IOCTL_GETFRAMESIZE
|
|
|
|
///
|
|
|
|
/// Description: This IOCTL retrieves the frame size requirements for an audio pin
|
|
|
|
///
|
|
|
|
/// Arguments: InputBuffer is a pointer to a WDMAUD_DEVICE_INFO structure,
|
|
|
|
/// InputBufferSize is size of WDMAUD_DEVICE_INFO structure
|
|
|
|
/// Note: The DeviceType and hDevice must be set
|
|
|
|
/// Result: The result is returned in FrameSize
|
|
|
|
/// ReturnCode: STATUS_SUCCESS indicates success
|
|
|
|
/// Prequsites: opened device
|
|
|
|
|
|
|
|
#define IOCTL_GETFRAMESIZE \
|
|
|
|
CTL_CODE(FILE_DEVICE_SOUND, \
|
|
|
|
10, \
|
|
|
|
METHOD_BUFFERED, \
|
|
|
|
FILE_CREATE_TREE_CONNECTION | FILE_ANY_ACCESS)
|
|
|
|
|
2009-09-25 18:06:13 +00:00
|
|
|
/// IOCTL_GETLINEINFO
|
|
|
|
///
|
|
|
|
/// Description: This IOCTL retrieves information on a mixerline
|
|
|
|
///
|
|
|
|
/// Arguments: InputBuffer is a pointer to a WDMAUD_DEVICE_INFO structure,
|
|
|
|
/// InputBufferSize is size of WDMAUD_DEVICE_INFO structure
|
|
|
|
/// Note: The hDevice member must be set
|
|
|
|
/// Result: The result is returned in MixLine
|
|
|
|
/// ReturnCode: STATUS_SUCCESS indicates success
|
|
|
|
/// Prequsites: opened device
|
|
|
|
|
|
|
|
#define IOCTL_GETLINEINFO \
|
|
|
|
CTL_CODE(FILE_DEVICE_SOUND, \
|
|
|
|
11, \
|
|
|
|
METHOD_BUFFERED, \
|
|
|
|
FILE_CREATE_TREE_CONNECTION | FILE_ANY_ACCESS)
|
|
|
|
|
|
|
|
|
|
|
|
/// IOCTL_GETLINECONTROLS
|
|
|
|
///
|
|
|
|
/// Description: This IOCTL retrieves controls of a mixerline
|
|
|
|
///
|
|
|
|
/// Arguments: InputBuffer is a pointer to a WDMAUD_DEVICE_INFO structure,
|
|
|
|
/// InputBufferSize is size of WDMAUD_DEVICE_INFO structure
|
|
|
|
/// Note: The hDevice member must be set
|
|
|
|
/// Result: The result is returned in MixControls
|
|
|
|
/// ReturnCode: STATUS_SUCCESS indicates success
|
|
|
|
/// Prequsites: opened device
|
|
|
|
|
|
|
|
#define IOCTL_GETLINECONTROLS \
|
|
|
|
CTL_CODE(FILE_DEVICE_SOUND, \
|
|
|
|
12, \
|
|
|
|
METHOD_BUFFERED, \
|
|
|
|
FILE_CREATE_TREE_CONNECTION | FILE_ANY_ACCESS)
|
|
|
|
|
|
|
|
|
|
|
|
/// IOCTL_SETCONTROLDETAILS
|
|
|
|
///
|
|
|
|
/// Description: This IOCTL sets details of a control of a mixerline
|
|
|
|
///
|
|
|
|
/// Arguments: InputBuffer is a pointer to a WDMAUD_DEVICE_INFO structure,
|
|
|
|
/// InputBufferSize is size of WDMAUD_DEVICE_INFO structure
|
|
|
|
/// Note: The hDevice member must be set
|
|
|
|
/// ReturnCode: STATUS_SUCCESS indicates success
|
|
|
|
/// Prequsites: opened device
|
|
|
|
|
|
|
|
#define IOCTL_SETCONTROLDETAILS \
|
|
|
|
CTL_CODE(FILE_DEVICE_SOUND, \
|
|
|
|
13, \
|
|
|
|
METHOD_BUFFERED, \
|
|
|
|
FILE_CREATE_TREE_CONNECTION | FILE_ANY_ACCESS)
|
|
|
|
|
|
|
|
|
|
|
|
/// IOCTL_GETCONTROLDETAILS
|
|
|
|
///
|
|
|
|
/// Description: This IOCTL gets details of a control of a mixerline
|
|
|
|
///
|
|
|
|
/// Arguments: InputBuffer is a pointer to a WDMAUD_DEVICE_INFO structure,
|
|
|
|
/// InputBufferSize is size of WDMAUD_DEVICE_INFO structure
|
|
|
|
/// Note: The hDevice member must be set
|
|
|
|
/// Result: The result is returned in MixDetails
|
|
|
|
/// ReturnCode: STATUS_SUCCESS indicates success
|
|
|
|
/// Prequsites: opened device
|
|
|
|
|
|
|
|
#define IOCTL_GETCONTROLDETAILS \
|
|
|
|
CTL_CODE(FILE_DEVICE_SOUND, \
|
|
|
|
14, \
|
|
|
|
METHOD_BUFFERED, \
|
|
|
|
FILE_CREATE_TREE_CONNECTION | FILE_ANY_ACCESS)
|
2009-02-12 20:13:19 +00:00
|
|
|
|
2009-10-26 23:10:05 +00:00
|
|
|
|
|
|
|
/// IOCTL_QUERYDEVICEINTERFACESTRING
|
|
|
|
///
|
|
|
|
/// Description: This IOCTL queries the mixer / playback / recording device for its device interface string
|
|
|
|
///
|
|
|
|
/// Arguments: InputBuffer is a pointer to a WDMAUD_DEVICE_INFO structure,
|
|
|
|
/// InputBufferSize is size of WDMAUD_DEVICE_INFO structure
|
|
|
|
/// Note: The DeviceType, DeviceIndex must be set
|
|
|
|
/// Result: The size is returned in Interface.DeviceInterfaceStringSize and if a buffer is supplied in Interface.DeviceInterfaceString
|
|
|
|
/// the device interface string is stored
|
|
|
|
/// ReturnCode: STATUS_SUCCESS indicates success
|
|
|
|
|
|
|
|
#define IOCTL_QUERYDEVICEINTERFACESTRING \
|
|
|
|
CTL_CODE(FILE_DEVICE_SOUND, \
|
|
|
|
15, \
|
|
|
|
METHOD_BUFFERED, \
|
|
|
|
FILE_CREATE_TREE_CONNECTION | FILE_ANY_ACCESS)
|
|
|
|
|
2009-11-13 01:48:28 +00:00
|
|
|
/// IOCTL_GET_MIXER_EVENT
|
|
|
|
///
|
2009-11-28 17:06:22 +00:00
|
|
|
/// Description: This IOCTL queries for wdmaud driver if there any new kernel streaming events available
|
2009-11-13 01:48:28 +00:00
|
|
|
///
|
|
|
|
/// Arguments: InputBuffer is a pointer to a WDMAUD_DEVICE_INFO structure,
|
|
|
|
/// InputBufferSize is size of WDMAUD_DEVICE_INFO structure
|
|
|
|
/// Note: The hDevice member must be set
|
|
|
|
/// Result: The result is returned in the struct MixerInfo
|
|
|
|
/// ReturnCode: STATUS_SUCCESS indicates success
|
|
|
|
|
|
|
|
#define IOCTL_GET_MIXER_EVENT \
|
|
|
|
CTL_CODE(FILE_DEVICE_SOUND, \
|
|
|
|
16, \
|
|
|
|
METHOD_BUFFERED, \
|
|
|
|
FILE_CREATE_TREE_CONNECTION | FILE_ANY_ACCESS)
|
|
|
|
|
2009-11-28 17:06:22 +00:00
|
|
|
/// IOCTL_RESET_STREAM
|
|
|
|
///
|
|
|
|
/// Description: This IOCTL instructs wdmaud to reset a stream
|
|
|
|
///
|
|
|
|
/// Arguments: InputBuffer is a pointer to a WDMAUD_DEVICE_INFO structure,
|
|
|
|
/// InputBufferSize is size of WDMAUD_DEVICE_INFO structure
|
|
|
|
/// Note: The hDevice member must be set and DeviceType
|
|
|
|
/// ReturnCode: STATUS_SUCCESS indicates success
|
2009-11-13 01:48:28 +00:00
|
|
|
|
2009-11-28 17:06:22 +00:00
|
|
|
#define IOCTL_RESET_STREAM \
|
|
|
|
CTL_CODE(FILE_DEVICE_SOUND, \
|
|
|
|
17, \
|
|
|
|
METHOD_BUFFERED, \
|
|
|
|
FILE_CREATE_TREE_CONNECTION | FILE_ANY_ACCESS)
|