<html><head><style type="text/css"><!-- DIV {margin:0px;} --></style></head><body><div style="font-family:arial,helvetica,sans-serif;font-size:10pt"><div>Hi,<br><br>1. I was wondering if MP3/DTS/AC3 passthrough is at the discussion point only or is someone actively looking at developing it?<br>2. I think that encoding needs to be considered as part of the design ie. the possibility of AC3 or MP3 encoding before output to SPDIF.<br><br>Perhaps you're already past this point, but there is an Alsa utility iecset which returns (and can set) whether raw data or PCM is being passed to SPDIF. So presumably the Pulseaudio passthrough for Alsa just needs to call the same function that utility does.<br><br>Can someone point me to any design and API docs for Pulseaudio as I'm interested in learning where and how it connects to Alsa?<br><br>Cheers,<br>Mike<br></div><div style="font-family: arial,helvetica,sans-serif; font-size: 10pt;"><br><div style="font-family:
 arial,helvetica,sans-serif; font-size: 13px;"><font size="2" face="Tahoma"><hr size="1"><b><span style="font-weight: bold;">From:</span></b> pl bossart &lt;bossart.nospam@gmail.com&gt;<br><b><span style="font-weight: bold;">To:</span></b> General PulseAudio Discussion &lt;pulseaudio-discuss@mail.0pointer.de&gt;<br><b><span style="font-weight: bold;">Sent:</span></b> Fri, 9 July, 2010 16:51:21<br><b><span style="font-weight: bold;">Subject:</span></b> Re: [pulseaudio-discuss] {PATCH][RFC] AC3 passthrough support<br></font><br>&gt; I agree that it's not really a good solution to require the user to<br>&gt; change the card profile manually to enable passthrough via spdif. But as<br>&gt; I said, a separate module could take care switching between the profiles<br>&gt; as needed.<br><br>I don't understand your proposal. What do you mean by separate<br>'module' and how would this work with the current mixer profiles?<br><br>&gt; Having thought this for a
 while, the only thing that really irritates me<br>&gt; in your design is that the semantics of the PA_SINK_PASSTHROUGH become<br>&gt; messy: the flag says that "in addition to normal PCM streams, this sink<br>&gt; supports also passthrough streams, except at times when there already<br>&gt; exist PCM streams, and btw, while a passthrough stream is playing, PCM<br>&gt; streams cease to be supported". I guess that's not a very practical<br>&gt; problem, though.<br><br>It's not really my design, it's just how SPDIF/HDMI work...<br><br>&gt; Ah, but now a better argument popped into my mind. If a sink can enter<br>&gt; the passthrough mode on the fly, then that has a consequence that<br>&gt; affects any application that is interested in sink volumes: whether a<br>&gt; sink has adjustable volume can change any time. That's not very nice.<br><br>Duh? If we fixed the volume stuff so that that the volume control app<br>disables its sliders when passthrough AC3
 is enabled, what would be<br>the issue. This is how VLC works, when you stream AC3 data the volume<br>control is no longer enabled.<br><br>&gt; Even if we have only two formats, iec958 and mp3, I don't see why the<br>&gt; sink flags would the proper place to specify the format. I believe most<br>&gt; of the passthrough related code is only interested in the fact that the<br>&gt; stream data shall not be touched. If there are multiple flags for all<br>&gt; the different passthrough formats, then all that code will have to check<br>&gt; for two flags instead of one.<br><br>I guess we could have a two-step process, where you first detect if<br>the sink and sink-input have support for PASSTHROUGH, and then in a<br>second step you verify that the 'subtype' (iec958 or mp3) is<br>compatible. The logic for rejecting connections is the same... You<br>only need one last step to make sure types are compatible.<br><br>&gt; There would of course be a standard
 implementation for sinks that don't<br>&gt; do any "strange" stuff. I thought individual sink implementations could<br>&gt; choose to amend the standard logic, but actually I'm not sure how it<br>&gt; could be done without duplicating code.<br>&gt;<br>&gt; Giving it a second thought, the "can this sink input be connected to<br>&gt; this sink" question can be thought equally well as a method of sinks or<br>&gt; sink inputs, or even as a plain old independent function. So, doing it<br>&gt; like you do it in your patch is fine by me (just don't use "iec958"<br>&gt; where the logic isn't really bound to the exact format).<br><br>As I said above, we can have a first pass implemented in the core that<br>checks things are fine, then a second pass implemented by sinks who<br>support passthrough mode to check fine-grained compatibility.<br><br>&gt;&gt; &gt; The NOVOLUME flags can be exported to clients, so they can choose to not<br>&gt;&gt; &gt; show any volume
 controls. Legacy clients should get the<br>&gt;&gt; &gt; PA_ERR_NOTSUPPORTED error when trying to change the volume of streams or<br>&gt;&gt; &gt; sinks that have the NOVOLUME flag.<br>&gt;&gt;<br>&gt;&gt; Yes the volume needs more work. I don't really understand all this<br>&gt;&gt; code through, so for now I disabled the set-volume() routines without<br>&gt;&gt; notifying the client. You end-up in the situation where pavucontrol<br>&gt;&gt; can change the volume but nothing happens, this is not user-friendly.<br>&gt;&gt; Is this NOVOLUME flag an existing one, or something that would need to be added?<br>&gt;<br>&gt; It needs to be added.<br><br>There's already a detection in the mixer code that the hw_volume is<br>available or not. Maybe we can use this as well.<br>_______________________________________________<br>pulseaudio-discuss mailing list<br><a ymailto="mailto:pulseaudio-discuss@mail.0pointer.de"
 href="mailto:pulseaudio-discuss@mail.0pointer.de">pulseaudio-discuss@mail.0pointer.de</a><br><a href="https://tango.0pointer.de/mailman/listinfo/pulseaudio-discuss" target="_blank">https://tango.0pointer.de/mailman/listinfo/pulseaudio-discuss</a><br></div></div>
</div><br>



      </body></html>