Commit db1113fe authored by Gerald Pfeifer's avatar Gerald Pfeifer Committed by Alexandre Julliard

Improve error messages in OSS_WaveOutInit() and OSS_WaveInInit() and

warn instead of aborting in case of problems reading mixer info.
parent c5e507a4
...@@ -538,17 +538,18 @@ static BOOL OSS_WaveOutInit(OSS_DEVICE* ossdev) ...@@ -538,17 +538,18 @@ static BOOL OSS_WaveOutInit(OSS_DEVICE* ossdev)
if ((mixer = open(ossdev->mixer_name, O_RDONLY|O_NDELAY)) >= 0) { if ((mixer = open(ossdev->mixer_name, O_RDONLY|O_NDELAY)) >= 0) {
mixer_info info; mixer_info info;
if (ioctl(mixer, SOUND_MIXER_INFO, &info) >= 0) { if (ioctl(mixer, SOUND_MIXER_INFO, &info) >= 0) {
close(mixer);
strncpy(ossdev->ds_desc.szDesc, info.name, sizeof(info.name)); strncpy(ossdev->ds_desc.szDesc, info.name, sizeof(info.name));
strcpy(ossdev->ds_desc.szDrvName, "wineoss.drv"); strcpy(ossdev->ds_desc.szDrvName, "wineoss.drv");
strncpy(ossdev->out_caps.szPname, info.name, sizeof(info.name)); strncpy(ossdev->out_caps.szPname, info.name, sizeof(info.name));
TRACE("%s\n", ossdev->ds_desc.szDesc); TRACE("%s\n", ossdev->ds_desc.szDesc);
} else { } else {
ERR("%s: can't read info!\n", ossdev->mixer_name); /* FreeBSD up to at least 5.2 provides this ioctl, but does not
OSS_CloseDevice(ossdev); * implement it properly, and there are probably similar issues
close(mixer); * on other platforms, so we warn but try to go ahead.
return FALSE; */
WARN("%s: cannot read SOUND_MIXER_INFO!\n", ossdev->mixer_name);
} }
close(mixer);
} else { } else {
ERR("%s: %s\n", ossdev->mixer_name , strerror( errno )); ERR("%s: %s\n", ossdev->mixer_name , strerror( errno ));
OSS_CloseDevice(ossdev); OSS_CloseDevice(ossdev);
...@@ -680,15 +681,16 @@ static BOOL OSS_WaveInInit(OSS_DEVICE* ossdev) ...@@ -680,15 +681,16 @@ static BOOL OSS_WaveInInit(OSS_DEVICE* ossdev)
if ((mixer = open(ossdev->mixer_name, O_RDONLY|O_NDELAY)) >= 0) { if ((mixer = open(ossdev->mixer_name, O_RDONLY|O_NDELAY)) >= 0) {
mixer_info info; mixer_info info;
if (ioctl(mixer, SOUND_MIXER_INFO, &info) >= 0) { if (ioctl(mixer, SOUND_MIXER_INFO, &info) >= 0) {
close(mixer);
strncpy(ossdev->in_caps.szPname, info.name, sizeof(info.name)); strncpy(ossdev->in_caps.szPname, info.name, sizeof(info.name));
TRACE("%s\n", ossdev->ds_desc.szDesc); TRACE("%s\n", ossdev->ds_desc.szDesc);
} else { } else {
ERR("%s: can't read info!\n", ossdev->mixer_name); /* FreeBSD up to at least 5.2 provides this ioctl, but does not
OSS_CloseDevice(ossdev); * implement it properly, and there are probably similar issues
close(mixer); * on other platforms, so we warn but try to go ahead.
return FALSE; */
WARN("%s: cannot read SOUND_MIXER_INFO!\n", ossdev->mixer_name);
} }
close(mixer);
} else { } else {
ERR("%s: %s\n", ossdev->mixer_name, strerror(errno)); ERR("%s: %s\n", ossdev->mixer_name, strerror(errno));
OSS_CloseDevice(ossdev); OSS_CloseDevice(ossdev);
......
Markdown is supported
0% or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment