native OSS_GETVERSION ioctl doesn't really work
Juergen Lock
nox at jelal.kn-bremen.de
Tue Jan 12 18:17:13 UTC 2010
On Tue, Jan 12, 2010 at 01:25:02PM +0200, Alexander Motin wrote:
> Juergen Lock wrote:
> > While fixing qemu for the upcoming 0.12.1 (or .2) qemu-devel port
> > I discovered that the OSS_GETVERSION ioctl added by r164613 in 2006,
> > http://svn.freebsd.org/viewvc/base?view=revision&revision=164613
> > is only implemented for the mixer device (other than in the Linuxolator),
> > and on top of that that code is never reached because OSS_GETVERSION
> > is defined as an _IOR ('M', ...), which are all handled by an
> > if ((cmd & MIXER_READ(0)) == MIXER_READ(0)) {
> > ...
> > here,
> > http://fxr.watson.org/fxr/source/dev/sound/pcm/mixer.c#L1255
> > and so even if actually done on a mixer device the ioctl ends up failing
> > with ENXIO.
> >
> > JFY... :)
> > Juergen
> >
> > PS: I guess I can try to make a patch, but only if its needed :)
>
> Fixed it for mixer in HEAD. I see 4Front OSS also implements it for
> sndstat and audio devices. Is it right, or it is some kind of bug or
> workaround?
I'd say it's right, apps depend on the ioctl being available also on
/dev/dsp etc. too. (Or at least qemu 0.12 does, thats where I
discovered the bug. I haven't looked at other apps so far...)
And thank you for the fix! :)
Juergen
More information about the freebsd-multimedia
mailing list