Re: Is it time for remove (crap) ALSA from kernel tree ?

From: Rene Herman
Date: Thu Jun 28 2007 - 08:42:54 EST


On 06/28/2007 05:04 AM, Patrick Draper wrote:

Rene Herman wrote:

So -- the fact that mixing actually works for you when using libaoss means software mixing is working correctly for your ALSA setup. The only thing you should do is _use_ ALSA (natively) and not its OSS emulation so you can drop the library preload.

Cool. How do I go about figuring out what every app uses? For example, you mentioned that the flash 9 plugin, which I also use, is an ALSA aware application. How do you know?

Various methods. If all's well, the application has a config menu where you can look at and change the settings.

Or, running ldd on the binary to see if it's linked to libasound, "grep /proc/<pid>/maps libasound" (also catches dlopen), "strace" or usually easiest and what I tended to do -- "lsmod" to see if starting the app triggered the automatic loading of snd-pcm-oss and snd-mixer-oss which I don't normally have loaded.

This is the "[things are still not great] partly _due_ to people maintaining OSS is somehow a valid choice on Linux" that I stated early in this thread. I actually believe the kernel space OSS emulation has been fairly counter productive -- it's allowed applications to stay with an obsolete interface since the users didn't even have to _know_ due to it all just working. At least with the userspace emulation, people know they are using an OSS emulation if they are starting the application with an library preload.

The kernel space emulation is a bit more bullet-proof in the sense that the userspace emulation would not for example help with applications that use direct syscalls to open device nodes and I guess that was important.

When OSS/Free was replaced with ALSA inside the Linux kernel this was a big change in an area most users use and any such change inevitably opens up big cans of change resistant wankers who understand the old interface and have no need for the new one and will tell you that you did it all wrong, it was all for nothing and you suck period. They'll keep it up for years and years generally. The kernel-space OSS emulation _does_ mostly just work, which is the kind of thing that you need in this environment to be allowed to tell these people to go sexually entertain themselves.

Perhaps it's now finally coming to the time where the kernel space emulation can be deprecated and eventually removed. Or not...

I need the check out everything that I use which needs sound (vmware,
skype, kmplayer, etc.) I don't have source code for at least two of
those.

I don't know if vmware by now supports native ALSA but it didn't use to. The current version of skype (1.4, still called a beta it seems) does.

kmplayer seems to be a frontend for various mediaplayer solutions. Don't you just love that mess? Its backends include MPlayer and Xine, and both these can talk native ALSA fine at least. For mplayer, use a "ao=alsa" line in the .mplayer/config file (or just start it with -ao alsa) and for xine, look in its setup menu (audio tab, having set the interface level to beter than "beginner").

Rene.

-
To unsubscribe from this list: send the line "unsubscribe linux-kernel" in
the body of a message to majordomo@xxxxxxxxxxxxxxx
More majordomo info at http://vger.kernel.org/majordomo-info.html
Please read the FAQ at http://www.tux.org/lkml/