mirror of https://github.com/tongzx/nt5src
You can not select more than 25 topics
Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.
274 lines
6.9 KiB
274 lines
6.9 KiB
#include <windows.h>
|
|
#include <mmsystem.h>
|
|
#include <mmddk.h>
|
|
|
|
#include "wvmapper.h"
|
|
|
|
HINSTANCE g_hmodThis;
|
|
WORD gwodOpenCount = 0 ;
|
|
struct wod_tag gwod ;
|
|
DWORD gDeviceAddress ;
|
|
WORD gPinHandle ;
|
|
|
|
LRESULT _loadds CALLBACK DriverProc (dwId, hDriver, wMsg, lParam1, lParam2 )
|
|
DWORD dwId ;
|
|
HDRVR hDriver ;
|
|
WORD wMsg ;
|
|
LPARAM lParam1 ;
|
|
LPARAM lParam2 ;
|
|
{
|
|
switch ( wMsg ) {
|
|
case DRV_OPEN:
|
|
OutputDebugString ( "WVMAPPER :: DRV_OPEN\n" ) ;
|
|
return ( OpenDevice() ) ;
|
|
case DRV_CLOSE:
|
|
OutputDebugString ( "WVMAPPER :: DRV_CLOSE\n" ) ;
|
|
break ;
|
|
case DRV_CONFIGURE:
|
|
OutputDebugString ( "WVMAPPER :: DRV_CONFIGURE\n" ) ;
|
|
break ;
|
|
case DRV_DISABLE:
|
|
OutputDebugString ( "WVMAPPER :: DRV_DISABLE\n" ) ;
|
|
break ;
|
|
case DRV_ENABLE:
|
|
OutputDebugString ( "WVMAPPER :: DRV_ENABLE\n" ) ;
|
|
break ;
|
|
case DRV_FREE:
|
|
OutputDebugString ( "WVMAPPER :: DRV_FREE\n" ) ;
|
|
break ;
|
|
case DRV_INSTALL:
|
|
OutputDebugString ( "WVMAPPER :: DRV_INSTALL\n" ) ;
|
|
break ;
|
|
case DRV_LOAD:
|
|
OutputDebugString ( "WVMAPPER :: DRV_LOAD\n" ) ;
|
|
break ;
|
|
case DRV_POWER:
|
|
OutputDebugString ( "WVMAPPER :: DRV_POWER\n" ) ;
|
|
break ;
|
|
case DRV_QUERYCONFIGURE:
|
|
OutputDebugString ( "WVMAPPER :: DRV_QUERYCONFIGURE\n" ) ;
|
|
break ;
|
|
case DRV_REMOVE:
|
|
OutputDebugString ( "WVMAPPER :: DRV_REMOVE\n" ) ;
|
|
break ;
|
|
default:
|
|
OutputDebugString ( "WVMAPPER :: DRV_OTHERS\n" ) ;
|
|
}
|
|
return (1L) ;
|
|
}
|
|
|
|
DWORD FAR PASCAL _loadds wodMessage (uDevId, uMsg, dwUser, dwParam1, dwParam2)
|
|
UINT uDevId ;
|
|
UINT uMsg ;
|
|
DWORD dwUser ;
|
|
DWORD dwParam1 ;
|
|
DWORD dwParam2 ;
|
|
{
|
|
switch (uMsg) {
|
|
case WODM_BREAKLOOP:
|
|
OutputDebugString ( "WVMAPPER :: WODM_BREAKLOOP\n" ) ;
|
|
return ( MMSYSERR_NOERROR ) ;
|
|
case WODM_CLOSE:
|
|
OutputDebugString ( "WVMAPPER :: WODM_CLOSE\n" ) ;
|
|
return (wodmClose()) ;
|
|
|
|
case WODM_GETDEVCAPS:
|
|
OutputDebugString ( "WVMAPPER :: WODM_GETDEVCAPS\n" ) ;
|
|
return (wodmGetDevCaps ( (LPWAVEOUTCAPS) dwParam1, dwParam2 ) ) ;
|
|
|
|
case WODM_GETNUMDEVS:
|
|
OutputDebugString ( "WVMAPPER :: WODM_GETNUMDEVS\n" ) ;
|
|
return ( 1 ) ;
|
|
case WODM_GETPOS:
|
|
OutputDebugString ( "WVMAPPER :: WODM_GETPOS\n" ) ;
|
|
return ( MMSYSERR_NOERROR ) ;
|
|
case WODM_OPEN:
|
|
OutputDebugString ( "WVMAPPER :: WODM_OPEN\n" ) ;
|
|
return wodmOpen ( (LPWAVEOPENDESC) dwParam1, dwParam2 ) ;
|
|
case WODM_PAUSE:
|
|
OutputDebugString ( "WVMAPPER :: WODM_PAUSE\n" ) ;
|
|
return ( MMSYSERR_NOERROR ) ;
|
|
case WODM_RESET:
|
|
OutputDebugString ( "WVMAPPER :: WODM_RESET\n" ) ;
|
|
return ( MMSYSERR_NOERROR ) ;
|
|
case WODM_RESTART:
|
|
OutputDebugString ( "WVMAPPER :: WODM_RESTART\n" ) ;
|
|
return ( MMSYSERR_NOERROR ) ;
|
|
case WODM_WRITE:
|
|
OutputDebugString ( "WVMAPPER :: WODM_WRITE\n" ) ;
|
|
return ( wodmWrite ( (LPWAVEHDR)dwParam1, dwParam2) ) ;
|
|
default:
|
|
OutputDebugString ( "WVMAPPER :: WODM_OTHERS\n" ) ;
|
|
return ( MMSYSERR_NOTSUPPORTED ) ;
|
|
}
|
|
|
|
return (TRUE) ;
|
|
}
|
|
|
|
DWORD FAR PASCAL _loadds widMessage (uDevId, uMsg, dwUser, dwParam1, dwParam2)
|
|
UINT uDevId ;
|
|
UINT uMsg ;
|
|
DWORD dwUser ;
|
|
DWORD dwParam1 ;
|
|
DWORD dwParam2 ;
|
|
{
|
|
switch (uMsg) {
|
|
case WIDM_CLOSE:
|
|
OutputDebugString ( "WVMAPPER :: WIDM_CLOSE\n" ) ;
|
|
return ( MMSYSERR_NOERROR ) ;
|
|
case WIDM_GETDEVCAPS:
|
|
OutputDebugString ( "WVMAPPER :: WIDM_GETDEVCAPS\n" ) ;
|
|
return ( MMSYSERR_NOERROR ) ;
|
|
case WIDM_GETNUMDEVS:
|
|
OutputDebugString ( "WVMAPPER :: WIDM_GETNUMDEVS\n" ) ;
|
|
return ( 1 ) ;
|
|
case WIDM_GETPOS:
|
|
OutputDebugString ( "WVMAPPER :: WIDM_GETPOS\n" ) ;
|
|
return ( MMSYSERR_NOERROR ) ;
|
|
case WIDM_OPEN:
|
|
OutputDebugString ( "WVMAPPER :: WIDM_OPEN\n" ) ;
|
|
return ( MMSYSERR_NOERROR ) ;
|
|
case WIDM_RESET:
|
|
OutputDebugString ( "WVMAPPER :: WIDM_RESET\n" ) ;
|
|
return ( MMSYSERR_NOERROR ) ;
|
|
default:
|
|
OutputDebugString ( "WVMAPPER :: WIDM_OTHERS\n" ) ;
|
|
return ( MMSYSERR_NOTSUPPORTED ) ;
|
|
}
|
|
|
|
return (TRUE) ;
|
|
}
|
|
|
|
BOOL FAR PASCAL LibMain(HANDLE hInstance, WORD wHeapSize, LPSTR lpszCmdLine)
|
|
{
|
|
|
|
g_hmodThis = hInstance;
|
|
return(TRUE);
|
|
}
|
|
|
|
MMRESULT wodmGetDevCaps ( lpWaveOutCaps, dwSize )
|
|
LPWAVEOUTCAPS lpWaveOutCaps ;
|
|
DWORD dwSize ;
|
|
{
|
|
char *name = "WDM WaveOut Mapper" ;
|
|
char far *tmp ;
|
|
|
|
lpWaveOutCaps->wMid = 1 ;
|
|
lpWaveOutCaps->wPid = 1 ;
|
|
lpWaveOutCaps->vDriverVersion = 1 ;
|
|
lpWaveOutCaps->dwFormats = WAVE_FORMAT_4S16 ;
|
|
lpWaveOutCaps->wChannels = 2 ;
|
|
lpWaveOutCaps->dwSupport = 0 ;
|
|
tmp = &lpWaveOutCaps->szPname[0] ;
|
|
while ( *name ) {
|
|
*tmp++ = *name++ ;
|
|
}
|
|
*tmp = '\0' ;
|
|
return ( MMSYSERR_NOERROR ) ;
|
|
}
|
|
|
|
MMRESULT wodmOpen ( lpWaveOpenDesc, Flags )
|
|
LPWAVEOPENDESC lpWaveOpenDesc ;
|
|
DWORD Flags ;
|
|
{
|
|
LPWAVEFORMAT lpWaveFormat ;
|
|
|
|
if ( Flags & WAVE_FORMAT_QUERY ) {
|
|
lpWaveFormat = lpWaveOpenDesc->lpFormat ;
|
|
if ( (lpWaveFormat->wFormatTag != WAVE_FORMAT_PCM) ||
|
|
(lpWaveFormat->nChannels != MIXER_CHANNELS) ||
|
|
(lpWaveFormat->nSamplesPerSec != MIXER_SAMPLE_RATE) ||
|
|
(lpWaveFormat->nBlockAlign != (MIXER_CHANNELS*MIXER_SAMPLE_SIZE)) )
|
|
return ( WAVERR_BADFORMAT ) ;
|
|
return ( MMSYSERR_NOERROR ) ;
|
|
}
|
|
|
|
if ( gwodOpenCount )
|
|
return ( MMSYSERR_ALLOCATED ) ;
|
|
gPinHandle = OpenPin((LPWAVEFORMAT)lpWaveOpenDesc->lpFormat) ;
|
|
if ( !gPinHandle )
|
|
return ( MMSYSERR_NOTENABLED ) ;
|
|
gwodOpenCount++ ;
|
|
gwod.hWave = lpWaveOpenDesc->hWave ;
|
|
gwod.dwInstance = lpWaveOpenDesc->dwInstance ;
|
|
gwod.dwCallBack = lpWaveOpenDesc->dwCallback ;
|
|
gwod.dwFlags = Flags & (~WAVE_FORMAT_QUERY) ;
|
|
wodCallBack ( WOM_OPEN, 0L, 0L ) ;
|
|
return ( MMSYSERR_NOERROR) ;
|
|
}
|
|
|
|
MMRESULT wodmClose ()
|
|
{
|
|
if ( (gwodOpenCount != 1) ) {
|
|
OutputDebugString ( "Wierd waveout open count -- %d" ) ;
|
|
_asm int 3 ;
|
|
}
|
|
ClosePin ( gPinHandle ) ;
|
|
gwodOpenCount-- ;
|
|
wodCallBack ( WOM_CLOSE, 0L, 0L ) ;
|
|
return (MMSYSERR_NOERROR) ;
|
|
}
|
|
|
|
MMRESULT wodmWrite ( lpWaveHdr, dwSize )
|
|
LPWAVEHDR lpWaveHdr ;
|
|
DWORD dwSize ;
|
|
{
|
|
lpWaveHdr->dwFlags |= WHDR_INQUEUE ;
|
|
lpWaveHdr->dwFlags &= ~WHDR_DONE ;
|
|
WritePin ( lpWaveHdr ) ;
|
|
return ( MMSYSERR_NOERROR ) ;
|
|
}
|
|
|
|
VOID wodCallBack ( msg, dw1, dw2 )
|
|
WORD msg ;
|
|
DWORD dw1 ;
|
|
DWORD dw2 ;
|
|
{
|
|
DriverCallback(
|
|
gwod.dwCallBack, // user's callback DWORD
|
|
HIWORD(gwod.dwFlags), // callback flags
|
|
gwod.hWave, // handle to the wave device
|
|
msg, // the message
|
|
gwod.dwInstance, // user's instance data
|
|
dw1, // first DWORD
|
|
dw2 ) ; // second DWORD
|
|
}
|
|
|
|
WORD ClosePin ( PinHandle )
|
|
WORD PinHandle;
|
|
{
|
|
WORD result ;
|
|
_asm {
|
|
mov ax, CLOSE_PIN
|
|
mov bx, word ptr PinHandle
|
|
call dword ptr [gDeviceAddress]
|
|
mov result, ax
|
|
}
|
|
return (result) ;
|
|
}
|
|
|
|
LRESULT OpenDevice ()
|
|
{
|
|
_asm {
|
|
xor ax, ax
|
|
mov es, ax
|
|
mov di, ax
|
|
mov ax, 1684h
|
|
mov bx, WVMAPPER_DEVICE_ID
|
|
int 2fh
|
|
mov word ptr [gDeviceAddress], di
|
|
mov word ptr [gDeviceAddress+2], es
|
|
}
|
|
if ( gDeviceAddress )
|
|
return ( 1L ) ;
|
|
else
|
|
return ( 0L ) ;
|
|
}
|
|
|
|
VOID PASCAL FAR _loadds WODCOMPLETEIO (lpWaveHdr)
|
|
LPWAVEHDR lpWaveHdr ;
|
|
{
|
|
lpWaveHdr->dwFlags &= ~WHDR_INQUEUE ;
|
|
lpWaveHdr->dwFlags |= WHDR_DONE ;
|
|
wodCallBack ( WOM_DONE, (DWORD)lpWaveHdr, 0L) ;
|
|
}
|