<html>
<head>
<base href="https://bugs.freedesktop.org/">
</head>
<body>
<p>
<div>
<b><a class="bz_bug_link
bz_status_NEW "
title="NEW - Clipping with per-stream volume above 100% even though device volume below 100%"
href="https://bugs.freedesktop.org/show_bug.cgi?id=97777#c6">Comment # 6</a>
on <a class="bz_bug_link
bz_status_NEW "
title="NEW - Clipping with per-stream volume above 100% even though device volume below 100%"
href="https://bugs.freedesktop.org/show_bug.cgi?id=97777">bug 97777</a>
from <span class="vcard"><a class="email" href="mailto:tanuk@iki.fi" title="Tanu Kaskinen <tanuk@iki.fi>"> <span class="fn">Tanu Kaskinen</span></a>
</span></b>
<pre>(In reply to Niklas Haas from <a href="show_bug.cgi?id=97777#c5">comment #5</a>)
<span class="quote">> > module-match can almost do what you want. The only problem is that it
> > overrides volumes set by module-stream-restore. See [1] for documentation.
> > Adding a new configuration option to change the hook callback priority
> > should be pretty trivial (the module uses a hook to get notified of new
> > streams, and the callback priorities decide the ordering between
> > module-match and module-stream-restore).
>
> Indeed it does, and it does work well for me, apart from the part where it
> overrides stream restoring. On the subject of making it configurable, it
> feels sort of “weird” to have this filter expose its hook priority as a user
> configurable variable, and using the filter also seem like a bit of abuse.</span >
Yes, exposing the hook priority to users is awkward, but I couldn't think of
better ways to configure the ordering between module-match and
module-stream-restore.
<span class="quote">> If we're touching source code, wouldn't it be better to add an option to
> module-stream-restore indicating what volume to pick for streams that it
> fails observing?</span >
That sounds quite good.
<span class="quote">> Or perhaps adding a new `module-default-volume` that runs
> after everything else and just sets a configurable volume if unset.</span >
That's certainly a possibility, but having a separate module for such a small
bit of functionality doesn't feel very nice.
Another possibility would be to add an option for default stream volume to
daemon.conf.
Currently I like the idea of adding an option to module-stream-restore the
most.
<span class="quote">> That being said, module-match being capable of running before
> module-stream-restore definitely seems like a useful feature to have
> regardless, because I might want to set different default volumes based on
> the title (but still retain the ability to make changes of my own).
>
> P.s. I wonder if it would be possible to get module-match to detect changes
> to the match table in realtime, although for that I suppose I could use
> inotify + unload-module && load-module.</span >
My preferred method of realtime configuration changes is to use pactl or other
client (the infrastructure for communicating between clients and individual
modules sucks currently, though). That is, no manual editing of configuration
files. That said, reloading configuration files could still be useful for
distribution maintainers, if for example installing some package causes
configuration changes, so I don't think I'd oppose a patch that implements
configuration reloading.
I'm a bit concerned that automatic reloading could cause trouble when updating
pulseaudio, if the update brings new configuration that is not supported by the
currently-running daemon process. Requiring manual action ("pactl
reload-configuration" or SIGHUP) might be a good idea.
<span class="quote">> Anyway, how do you propose exposing this to the user? I noticed while digging
> through the source that there's a pa_sink_input_new_data->volume_is_set bool,
> maybe the right way to approach this would be to add a ‘force’ option to
> module_stream_restore which forcibly applies saved volumes even if
> volume_is_set was already true by the time the fixate hook got called?</span >
I don't think that would be much better than having a hook priority option in
module-match, because module-stream-restore can't reliably force anything that
happens in hook callbacks after module-stream-restore's own callback.
Explaining the semantics accurately to users would be as problematic as
explaining the hook priorities. Adding a default volume option to
module-stream-restore seems like a better solution.</pre>
</div>
</p>
<hr>
<span>You are receiving this mail because:</span>
<ul>
<li>You are the assignee for the bug.</li>
<li>You are the QA Contact for the bug.</li>
</ul>
</body>
</html>