small range fixes for OSS driver
changed to the new debug channel interface
This commit is contained in:
parent
54e4ba048a
commit
1d1a6bb4a7
|
@ -14,7 +14,7 @@
|
||||||
#include "windef.h"
|
#include "windef.h"
|
||||||
#include "driver.h"
|
#include "driver.h"
|
||||||
#include "multimedia.h"
|
#include "multimedia.h"
|
||||||
#include "debug.h"
|
#include "debugtools.h"
|
||||||
|
|
||||||
DEFAULT_DEBUG_CHANNEL(mmaux)
|
DEFAULT_DEBUG_CHANNEL(mmaux)
|
||||||
|
|
||||||
|
@ -32,16 +32,16 @@ static DWORD AUX_GetDevCaps(WORD wDevID, LPAUXCAPS16 lpCaps, DWORD dwSize)
|
||||||
{
|
{
|
||||||
#ifdef HAVE_OSS
|
#ifdef HAVE_OSS
|
||||||
int mixer,volume;
|
int mixer,volume;
|
||||||
|
|
||||||
TRACE(mmaux,"(%04X, %p, %lu);\n", wDevID, lpCaps, dwSize);
|
TRACE("(%04X, %p, %lu);\n", wDevID, lpCaps, dwSize);
|
||||||
if (lpCaps == NULL) return MMSYSERR_NOTENABLED;
|
if (lpCaps == NULL) return MMSYSERR_NOTENABLED;
|
||||||
if ((mixer = open(MIXER_DEV, O_RDWR)) < 0) {
|
if ((mixer = open(MIXER_DEV, O_RDWR)) < 0) {
|
||||||
WARN(mmaux, "mixer device not available !\n");
|
WARN("mixer device not available !\n");
|
||||||
return MMSYSERR_NOTENABLED;
|
return MMSYSERR_NOTENABLED;
|
||||||
}
|
}
|
||||||
if (ioctl(mixer, SOUND_MIXER_READ_LINE, &volume) == -1) {
|
if (ioctl(mixer, SOUND_MIXER_READ_LINE, &volume) == -1) {
|
||||||
close(mixer);
|
close(mixer);
|
||||||
WARN(mmaux, "unable read mixer !\n");
|
WARN("unable read mixer !\n");
|
||||||
return MMSYSERR_NOTENABLED;
|
return MMSYSERR_NOTENABLED;
|
||||||
}
|
}
|
||||||
close(mixer);
|
close(mixer);
|
||||||
|
@ -50,37 +50,37 @@ static DWORD AUX_GetDevCaps(WORD wDevID, LPAUXCAPS16 lpCaps, DWORD dwSize)
|
||||||
lpCaps->vDriverVersion = 0x0200;
|
lpCaps->vDriverVersion = 0x0200;
|
||||||
lpCaps->dwSupport = AUXCAPS_VOLUME | AUXCAPS_LRVOLUME;
|
lpCaps->dwSupport = AUXCAPS_VOLUME | AUXCAPS_LRVOLUME;
|
||||||
switch (wDevID) {
|
switch (wDevID) {
|
||||||
case 0:
|
case 0:
|
||||||
lpCaps->wPid = 0x0196;
|
lpCaps->wPid = 0x0196;
|
||||||
strcpy(lpCaps->szPname, "SB16 Aux: Wave");
|
strcpy(lpCaps->szPname, "SB16 Aux: Wave");
|
||||||
lpCaps->wTechnology = AUXCAPS_AUXIN;
|
lpCaps->wTechnology = AUXCAPS_AUXIN;
|
||||||
break;
|
break;
|
||||||
case 1:
|
case 1:
|
||||||
lpCaps->wPid = 0x0197;
|
lpCaps->wPid = 0x0197;
|
||||||
strcpy(lpCaps->szPname, "SB16 Aux: Midi Synth");
|
strcpy(lpCaps->szPname, "SB16 Aux: Midi Synth");
|
||||||
lpCaps->wTechnology = AUXCAPS_AUXIN;
|
lpCaps->wTechnology = AUXCAPS_AUXIN;
|
||||||
break;
|
break;
|
||||||
case 2:
|
case 2:
|
||||||
lpCaps->wPid = 0x0191;
|
lpCaps->wPid = 0x0191;
|
||||||
strcpy(lpCaps->szPname, "SB16 Aux: CD");
|
strcpy(lpCaps->szPname, "SB16 Aux: CD");
|
||||||
lpCaps->wTechnology = AUXCAPS_CDAUDIO;
|
lpCaps->wTechnology = AUXCAPS_CDAUDIO;
|
||||||
break;
|
break;
|
||||||
case 3:
|
case 3:
|
||||||
lpCaps->wPid = 0x0192;
|
lpCaps->wPid = 0x0192;
|
||||||
strcpy(lpCaps->szPname, "SB16 Aux: Line-In");
|
strcpy(lpCaps->szPname, "SB16 Aux: Line-In");
|
||||||
lpCaps->wTechnology = AUXCAPS_AUXIN;
|
lpCaps->wTechnology = AUXCAPS_AUXIN;
|
||||||
break;
|
break;
|
||||||
case 4:
|
case 4:
|
||||||
lpCaps->wPid = 0x0193;
|
lpCaps->wPid = 0x0193;
|
||||||
strcpy(lpCaps->szPname, "SB16 Aux: Mic");
|
strcpy(lpCaps->szPname, "SB16 Aux: Mic");
|
||||||
lpCaps->wTechnology = AUXCAPS_AUXIN;
|
lpCaps->wTechnology = AUXCAPS_AUXIN;
|
||||||
break;
|
break;
|
||||||
case 5:
|
case 5:
|
||||||
lpCaps->wPid = 0x0194;
|
lpCaps->wPid = 0x0194;
|
||||||
strcpy(lpCaps->szPname, "SB16 Aux: Master");
|
strcpy(lpCaps->szPname, "SB16 Aux: Master");
|
||||||
lpCaps->wTechnology = AUXCAPS_AUXIN;
|
lpCaps->wTechnology = AUXCAPS_AUXIN;
|
||||||
break;
|
break;
|
||||||
}
|
}
|
||||||
#else
|
#else
|
||||||
lpCaps->wMid = 0xAA;
|
lpCaps->wMid = 0xAA;
|
||||||
lpCaps->wPid = 0x55;
|
lpCaps->wPid = 0x55;
|
||||||
|
@ -102,52 +102,52 @@ static DWORD AUX_GetDevCaps(WORD wDevID, LPAUXCAPS16 lpCaps, DWORD dwSize)
|
||||||
static DWORD AUX_GetVolume(WORD wDevID, LPDWORD lpdwVol)
|
static DWORD AUX_GetVolume(WORD wDevID, LPDWORD lpdwVol)
|
||||||
{
|
{
|
||||||
#ifdef HAVE_OSS
|
#ifdef HAVE_OSS
|
||||||
int mixer,volume,left,right,cmd;
|
int mixer, volume, left, right, cmd;
|
||||||
|
|
||||||
TRACE(mmaux,"(%04X, %p);\n", wDevID, lpdwVol);
|
TRACE("(%04X, %p);\n", wDevID, lpdwVol);
|
||||||
if (lpdwVol == NULL) return MMSYSERR_NOTENABLED;
|
if (lpdwVol == NULL) return MMSYSERR_NOTENABLED;
|
||||||
if ((mixer = open(MIXER_DEV, O_RDWR)) < 0) {
|
if ((mixer = open(MIXER_DEV, O_RDWR)) < 0) {
|
||||||
WARN(mmaux, "mixer device not available !\n");
|
WARN("mixer device not available !\n");
|
||||||
return MMSYSERR_NOTENABLED;
|
return MMSYSERR_NOTENABLED;
|
||||||
}
|
}
|
||||||
switch(wDevID) {
|
switch(wDevID) {
|
||||||
case 0:
|
case 0:
|
||||||
TRACE(mmaux,"SOUND_MIXER_READ_PCM !\n");
|
TRACE("SOUND_MIXER_READ_PCM !\n");
|
||||||
cmd = SOUND_MIXER_READ_PCM;
|
cmd = SOUND_MIXER_READ_PCM;
|
||||||
break;
|
break;
|
||||||
case 1:
|
case 1:
|
||||||
TRACE(mmaux,"SOUND_MIXER_READ_SYNTH !\n");
|
TRACE("SOUND_MIXER_READ_SYNTH !\n");
|
||||||
cmd = SOUND_MIXER_READ_SYNTH;
|
cmd = SOUND_MIXER_READ_SYNTH;
|
||||||
break;
|
break;
|
||||||
case 2:
|
case 2:
|
||||||
TRACE(mmaux,"SOUND_MIXER_READ_CD !\n");
|
TRACE("SOUND_MIXER_READ_CD !\n");
|
||||||
cmd = SOUND_MIXER_READ_CD;
|
cmd = SOUND_MIXER_READ_CD;
|
||||||
break;
|
break;
|
||||||
case 3:
|
case 3:
|
||||||
TRACE(mmaux,"SOUND_MIXER_READ_LINE !\n");
|
TRACE("SOUND_MIXER_READ_LINE !\n");
|
||||||
cmd = SOUND_MIXER_READ_LINE;
|
cmd = SOUND_MIXER_READ_LINE;
|
||||||
break;
|
break;
|
||||||
case 4:
|
case 4:
|
||||||
TRACE(mmaux,"SOUND_MIXER_READ_MIC !\n");
|
TRACE("SOUND_MIXER_READ_MIC !\n");
|
||||||
cmd = SOUND_MIXER_READ_MIC;
|
cmd = SOUND_MIXER_READ_MIC;
|
||||||
break;
|
break;
|
||||||
case 5:
|
case 5:
|
||||||
TRACE(mmaux,"SOUND_MIXER_READ_VOLUME !\n");
|
TRACE("SOUND_MIXER_READ_VOLUME !\n");
|
||||||
cmd = SOUND_MIXER_READ_VOLUME;
|
cmd = SOUND_MIXER_READ_VOLUME;
|
||||||
break;
|
break;
|
||||||
default:
|
default:
|
||||||
WARN(mmaux, "invalid device id=%04X !\n", wDevID);
|
WARN("invalid device id=%04X !\n", wDevID);
|
||||||
return MMSYSERR_NOTENABLED;
|
return MMSYSERR_NOTENABLED;
|
||||||
}
|
}
|
||||||
if (ioctl(mixer, cmd, &volume) == -1) {
|
if (ioctl(mixer, cmd, &volume) == -1) {
|
||||||
WARN(mmaux, "unable read mixer !\n");
|
WARN("unable read mixer !\n");
|
||||||
return MMSYSERR_NOTENABLED;
|
return MMSYSERR_NOTENABLED;
|
||||||
}
|
}
|
||||||
close(mixer);
|
close(mixer);
|
||||||
left = volume & 0x7F;
|
left = LOBYTE(LOWORD(volume));
|
||||||
right = (volume >> 8) & 0x7F;
|
right = HIBYTE(LOWORD(volume));
|
||||||
TRACE(mmaux,"left=%d right=%d !\n", left, right);
|
TRACE("left=%d right=%d !\n", left, right);
|
||||||
*lpdwVol = MAKELONG(left << 9, right << 9);
|
*lpdwVol = MAKELONG((left * 0xFFFFL) / 100, (right * 0xFFFFL) / 100);
|
||||||
return MMSYSERR_NOERROR;
|
return MMSYSERR_NOERROR;
|
||||||
#else
|
#else
|
||||||
return MMSYSERR_NOTENABLED;
|
return MMSYSERR_NOTENABLED;
|
||||||
|
@ -160,49 +160,54 @@ static DWORD AUX_GetVolume(WORD wDevID, LPDWORD lpdwVol)
|
||||||
static DWORD AUX_SetVolume(WORD wDevID, DWORD dwParam)
|
static DWORD AUX_SetVolume(WORD wDevID, DWORD dwParam)
|
||||||
{
|
{
|
||||||
#ifdef HAVE_OSS
|
#ifdef HAVE_OSS
|
||||||
int mixer;
|
int mixer;
|
||||||
int volume;
|
int volume, left, right;
|
||||||
int cmd;
|
int cmd;
|
||||||
TRACE(mmaux,"(%04X, %08lX);\n", wDevID, dwParam);
|
|
||||||
volume = (LOWORD(dwParam) >> 9 & 0x7F) +
|
TRACE("(%04X, %08lX);\n", wDevID, dwParam);
|
||||||
((HIWORD(dwParam) >> 9 & 0x7F) << 8);
|
|
||||||
|
left = (LOWORD(dwParam) * 100) >> 16;
|
||||||
|
right = (HIWORD(dwParam) * 100) >> 16;
|
||||||
|
volume = (right << 8) | left;
|
||||||
|
|
||||||
if ((mixer = open(MIXER_DEV, O_RDWR)) < 0) {
|
if ((mixer = open(MIXER_DEV, O_RDWR)) < 0) {
|
||||||
WARN(mmaux, "mixer device not available !\n");
|
WARN("mixer device not available !\n");
|
||||||
return MMSYSERR_NOTENABLED;
|
return MMSYSERR_NOTENABLED;
|
||||||
}
|
}
|
||||||
|
|
||||||
switch(wDevID) {
|
switch(wDevID) {
|
||||||
case 0:
|
case 0:
|
||||||
TRACE(mmaux,"SOUND_MIXER_WRITE_PCM !\n");
|
TRACE("SOUND_MIXER_WRITE_PCM !\n");
|
||||||
cmd = SOUND_MIXER_WRITE_PCM;
|
cmd = SOUND_MIXER_WRITE_PCM;
|
||||||
break;
|
break;
|
||||||
case 1:
|
case 1:
|
||||||
TRACE(mmaux,"SOUND_MIXER_WRITE_SYNTH !\n");
|
TRACE("SOUND_MIXER_WRITE_SYNTH !\n");
|
||||||
cmd = SOUND_MIXER_WRITE_SYNTH;
|
cmd = SOUND_MIXER_WRITE_SYNTH;
|
||||||
break;
|
break;
|
||||||
case 2:
|
case 2:
|
||||||
TRACE(mmaux,"SOUND_MIXER_WRITE_CD !\n");
|
TRACE("SOUND_MIXER_WRITE_CD !\n");
|
||||||
cmd = SOUND_MIXER_WRITE_CD;
|
cmd = SOUND_MIXER_WRITE_CD;
|
||||||
break;
|
break;
|
||||||
case 3:
|
case 3:
|
||||||
TRACE(mmaux,"SOUND_MIXER_WRITE_LINE !\n");
|
TRACE("SOUND_MIXER_WRITE_LINE !\n");
|
||||||
cmd = SOUND_MIXER_WRITE_LINE;
|
cmd = SOUND_MIXER_WRITE_LINE;
|
||||||
break;
|
break;
|
||||||
case 4:
|
case 4:
|
||||||
TRACE(mmaux,"SOUND_MIXER_WRITE_MIC !\n");
|
TRACE("SOUND_MIXER_WRITE_MIC !\n");
|
||||||
cmd = SOUND_MIXER_WRITE_MIC;
|
cmd = SOUND_MIXER_WRITE_MIC;
|
||||||
break;
|
break;
|
||||||
case 5:
|
case 5:
|
||||||
TRACE(mmaux,"SOUND_MIXER_WRITE_VOLUME !\n");
|
TRACE("SOUND_MIXER_WRITE_VOLUME !\n");
|
||||||
cmd = SOUND_MIXER_WRITE_VOLUME;
|
cmd = SOUND_MIXER_WRITE_VOLUME;
|
||||||
break;
|
break;
|
||||||
default:
|
default:
|
||||||
WARN(mmaux,"invalid device id=%04X !\n", wDevID);
|
WARN("invalid device id=%04X !\n", wDevID);
|
||||||
return MMSYSERR_NOTENABLED;
|
|
||||||
}
|
|
||||||
if (ioctl(mixer, cmd, &volume) == -1) {
|
|
||||||
WARN(mmaux, "unable set mixer !\n");
|
|
||||||
return MMSYSERR_NOTENABLED;
|
return MMSYSERR_NOTENABLED;
|
||||||
}
|
}
|
||||||
|
if (ioctl(mixer, cmd, &volume) == -1) {
|
||||||
|
WARN("unable set mixer !\n");
|
||||||
|
return MMSYSERR_NOTENABLED;
|
||||||
|
}
|
||||||
close(mixer);
|
close(mixer);
|
||||||
return MMSYSERR_NOERROR;
|
return MMSYSERR_NOERROR;
|
||||||
#else
|
#else
|
||||||
|
@ -215,22 +220,22 @@ static DWORD AUX_SetVolume(WORD wDevID, DWORD dwParam)
|
||||||
* auxMessage [sample driver]
|
* auxMessage [sample driver]
|
||||||
*/
|
*/
|
||||||
DWORD WINAPI auxMessage(WORD wDevID, WORD wMsg, DWORD dwUser,
|
DWORD WINAPI auxMessage(WORD wDevID, WORD wMsg, DWORD dwUser,
|
||||||
DWORD dwParam1, DWORD dwParam2)
|
DWORD dwParam1, DWORD dwParam2)
|
||||||
{
|
{
|
||||||
TRACE(mmaux,"(%04X, %04X, %08lX, %08lX, %08lX);\n",
|
TRACE("(%04X, %04X, %08lX, %08lX, %08lX);\n",
|
||||||
wDevID, wMsg, dwUser, dwParam1, dwParam2);
|
wDevID, wMsg, dwUser, dwParam1, dwParam2);
|
||||||
switch(wMsg) {
|
switch(wMsg) {
|
||||||
case AUXDM_GETDEVCAPS:
|
case AUXDM_GETDEVCAPS:
|
||||||
return AUX_GetDevCaps(wDevID,(LPAUXCAPS16)dwParam1,dwParam2);
|
return AUX_GetDevCaps(wDevID,(LPAUXCAPS16)dwParam1,dwParam2);
|
||||||
case AUXDM_GETNUMDEVS:
|
case AUXDM_GETNUMDEVS:
|
||||||
TRACE(mmaux,"return %d;\n", NumDev);
|
TRACE("return %d;\n", NumDev);
|
||||||
return NumDev;
|
return NumDev;
|
||||||
case AUXDM_GETVOLUME:
|
case AUXDM_GETVOLUME:
|
||||||
return AUX_GetVolume(wDevID,(LPDWORD)dwParam1);
|
return AUX_GetVolume(wDevID,(LPDWORD)dwParam1);
|
||||||
case AUXDM_SETVOLUME:
|
case AUXDM_SETVOLUME:
|
||||||
return AUX_SetVolume(wDevID,dwParam1);
|
return AUX_SetVolume(wDevID,dwParam1);
|
||||||
default:
|
default:
|
||||||
WARN(mmaux, "unknown message !\n");
|
WARN("unknown message !\n");
|
||||||
}
|
}
|
||||||
return MMSYSERR_NOTSUPPORTED;
|
return MMSYSERR_NOTSUPPORTED;
|
||||||
}
|
}
|
||||||
|
|
Loading…
Reference in New Issue