-
-
Notifications
You must be signed in to change notification settings - Fork 280
New issue
Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.
By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.
Already on GitHub? Sign in to your account
playing new sound will play a already paused/stopped sound prev #3422
Comments
I think we already have a discussion about this somewhere. But I can't remember the issue name. In any case it is a hard to solve this as things are right now on PipeWire's side. There isn't a pipeline management infrastructure like the one provided by GStreamer. Where you can force the pipeline to remain active until the last plugin has received a message sent by the first plugin. PipeWire is in total control of the plugins activation as well as for how long they keep running.
I wonder if you soundcard drier has the same problem as mine. When my soundcard comes back from the suspended state it does a very annoying crackling. It has nothing to do with EasyEffects. The difference is that depending on the plugins I am using the crackling amplitude can be very high. But it is still there when EasyEffects is not running. In cases like this the only solution is disabling the soundcard suspension in the server configuration. |
Based on the list of plugins you provided on the other issue EasyEffects pipeline should have almost no data stored inside each plugin. In other words the extra latency displayed in EasyEffects bottom panel should be very small and virtually unnoticeable by ear. |
no. but if my volume is around 80-90 and im playing smth loud, it would crack rly hard too... and idk wats up but my speaker performance VERY different between linux and windows(i dual boot) in windows, 10% of it is around 80% of it in linux. and in windows it never crack(volume)... its a eden |
Actually this isn't the case when using the |
Forget my last comment. You are using the |
With the plugins you are using the extra latency should be close to zero. What means that the amount of data stored in it is negligible. I wonder from where the "last 0.1s sound" you are listening to is coming from. |
no idea... but def sth dealing with easyeffects because its nowhere to be seen if i kill easyeffects |
I wonder if the one storing old buffers is the null-sink... If issue is still there when EE global bypass is enabled or the plugins are removed from the pipeline then the null-sink is the one with the old data. |
any news here? I have the same problem with an USB DAC |
The situation is still the same on my side. Somehow on my hardware I can't notice this happening. My guess is that the interaction between pipewire and the soundcard drivers is relevant. When I am listening to something on spotify and then play a youtube video I do not listen a fraction of the paused spotify song like described in the first post. |
Thats exactly my problem. A fraction from the last played media is played. |
@ManuVice which plugins are you using? What is the quantum and rate values pw-top shows for your soundcard when you playing something? |
A quantum of 2048 combined with a sampling rate of 48000 Hz would lead to a minimum latency of about
Is this "plopp" really an audio that is part of what was being played before or just an weird noise? Maybe what is happening is the noise some soundcards do when PipeWire takes them from the suspended state back to the active state. My soundcard does that. EasyEffects effects just make the noise more noticeable. Another possibility is that you have set the equalizer to a mode that is not |
Correction. To a mode different than |
equalizer is set to IIR
90% of the time I hear a small cut from my last played track or a voice from the last played video I didnt touch my pipewire config. Only things I have changed are:
51-disable-suspension.conf:
in 50-alsa-config.conf:
I played a lot with these two settings (api.alsa.period-size, api.alsa.headroom) and quantum settings in pipewire.conf but nothing changed for me. I rolled back the most settings to default |
This problem happens to me too. Setting the equalizer to IIR generates an imperceptible peak on resume and practically solves the problem. |
I wonder if it is possible to do this. We do not have control over the start and stop operation. PipeWire is the one controlling that. It may seem strange but it is the way things are handled. We only link the filters and handle inside each one of them the audio buffers that come. The filter does not know if somewhere far away a stream is starting. We can separately monitor each stream state and get this information. But as the whole process is asynchronous PipeWire may have already resumed the flow of buffers to each plugin by the time we get to know if it is a new stream the one responsible tor the new buffers. What I think is odd is that some users had this problem in the past even when we still provided a control that forced the output effects pipeline to remain active for several seconds. In a situation like this one all the old buffers should have already been drained. That is why I suspect that in most cases what is happening is the noise some cards generate when PipeWire brings them back from suspended state.
For example let's consider the case of an user that uses only the equalizer. The pipeline would be
. With the equalizer in the IIR mode the additional latency reported by the plugin is zero. So probably there ise no old data stored inside it. The spectrum and the output level meter work in passthrough mode. So they can not be the ones responsible for old data. So the one left to point the finger to would be the null-sink used to create the virtual device. But this is 100% PipeWire's code. We just ask it to load the virtual device for us. Maybe the null-sink is storing data. What would be a little unexpected. |
Another strange problem here If I switch the tab in gnome settings I have audio distortion. I wanted to record the whole thing with obs-studio, but if I start obs the problem is gone.. I had to record it with my phone.. If I disable easyeffects or start obs no distortion. video with easyeffects and distortion agc-vid-20250115-160926746_hbsCf41b.mp4video with easyeffects + obs no distortion agc-vid-20250115-161012966_y7GBcHEm.mp4 |
For some reason the videos can not be played. But based on what your are describing the issue is probably related to PipeWire's dynamic latency switching. What you are doing on GNOME settings is probably making PipeWire switch to a different quantum value. Try to take a look at The fact that keeping OBS opened fixes it is also understandable for the same reasons. The latency requested by OBS is probably smaller than the one requested by gnome settings. So the switching does not happen while OBS is running. |
May I ask which sound card you are using? |
The one from the motherboard https://rog.asus.com/motherboards/rog-strix/rog-strix-b650e-e-gaming-wifi-model/helpdesk_bios/. I use its optical port output. |
When starting If I do PEQ in pipewire, I don't get delays or garbage sounds.
|
That is a lot of delay. Are you using the equalizer in |
Oh... It is not a delay. It is just the length of the audio data. Are you able to put these files here? |
|
I am doing some tests and the results depend on the plugin. So far things are fine with the
The ideal solution would be to make the pipeline keep playing for some time after the last player stops sending buffers to our virtual device. It is probably what PipeWire is doing in its built-in filter chain. The problem is that it does not offer a way for us to do the same. Or at least it didn't the last time I looked at the available API. |
I have the feeling that it will be more efficient to revisit this issue once the port to Qt is ready. There I am doing again something we used to do in the past and it definitely helps the Qt branch to deal with it. But it won't help the current gtk branch as it is. The inactivity timeout in EasyEffects preferences window used to be applied to both pipelines instead of just the microphone pipeline. But as relinking our filters on the fly seems to trigger a random and very hard to reproduce PipeWire bug that makes one of the channels to not have audio I stopped unlinking and relinking the output effects pipeline on demand. But in the Qt branch I've decided to bring back this procedure although it is not clear if PipeWire has fixed the other bug on their side. The reason why this procedure helps the Qt branch to deal with this old data issue is that there we are able to actually destroy the filter class after the disconnection. What clears the internal data. For some reason I could never figure out this caused crashes in the gtk branch. |
I verified that if I use |
EasyEffects Version
7.1.8
What package are you using?
Arch (easyeffects)
Distribution
Arch BTW
Describe the bug
currently: #3386
but theres also two anomaly:
Expected Behavior
none of above happening
Debug Log
Debug Log
Additional Information
#3386
in case ur wondering, i dont have any delay effects/options set
The text was updated successfully, but these errors were encountered: