[Donion] [1.1.62] No audio and game freeze on quit with new default sound on linux
Re: [Donion] [1.1.62] No audio and game freeze on quit with new default sound on linux
I've also encountered this issue on Fedora 36 (pipewire 0.3.56, with support for pulse and alsa). I've tried changing settings, but so far I can't find any consistent patterns. Sometimes it works, sometimes it doesn't work, although I have only been able to replicate this bug on default (SDL), not on Allegro.
			
			
									
									
						Re: [Donion] [1.1.62] No audio and game freeze on quit with new default sound on linux
Hi, I was also able to replicate this bug just now after rebooting my system. Here's the log: https://rentry.co/4pc6h.Donion wrote: Mon Aug 08, 2022 8:08 amHi, could you please try one other thing: running 1.1.65 with default (sdl) audio backend and post the log? There is a little bit more logging than in 1.1.62 and it might help me troubleshoot this further. I appreciate your tests and reports very much!
Re: [Donion] [1.1.62] No audio and game freeze on quit with new default sound on linux
I found a pattern that might be interesting (sound is on default/SDL in all cases):
When I first run ./factorio (with no environment variables), the bug occurs.
If I then run SDL_AUDIODRIVER=pulse ./factorio, it is fixed.
Now running ./factorio, without the environment variable also works, as if it somehow remembered the last setting.
Then I run SDL_AUDIODRIVER=alsa ./factorio or SDL_AUDIODRIVER=dsp ./factorio, these don't work and factorio tells me it was unable to initialize audio. This is all fine I guess.
But if I then try running ./factorio, without the environment variable, the bug is back. As if it magically "forgot" the SDL_AUDIODRIVER=pulse setting causing it to fail.
That said I have been able to get the bug with SDL_AUDIODRIVER=pulse ./factorio once before, so this doesn't fix everything. I will see if I can replicate that too.
Edit: to clarify, I never exported SDL_AUDIODRIVER, so it does not get stored in the shell session.
Edit2: I can replicate the bug using SDL_AUDIODRIVER=pulse if I suspend and resume my system.
Edit3: In order to fix the problem after resuming from suspend, I need to take the following steps:
			
			
													When I first run ./factorio (with no environment variables), the bug occurs.
If I then run SDL_AUDIODRIVER=pulse ./factorio, it is fixed.
Now running ./factorio, without the environment variable also works, as if it somehow remembered the last setting.
Then I run SDL_AUDIODRIVER=alsa ./factorio or SDL_AUDIODRIVER=dsp ./factorio, these don't work and factorio tells me it was unable to initialize audio. This is all fine I guess.
But if I then try running ./factorio, without the environment variable, the bug is back. As if it magically "forgot" the SDL_AUDIODRIVER=pulse setting causing it to fail.
That said I have been able to get the bug with SDL_AUDIODRIVER=pulse ./factorio once before, so this doesn't fix everything. I will see if I can replicate that too.
Edit: to clarify, I never exported SDL_AUDIODRIVER, so it does not get stored in the shell session.
Edit2: I can replicate the bug using SDL_AUDIODRIVER=pulse if I suspend and resume my system.
Edit3: In order to fix the problem after resuming from suspend, I need to take the following steps:
- Set SDL_AUDIODRIVER to something like alsa or dsp to push the game/SDL out of it's remebered configuration
- Set SDL_AUDIODRIVER back to pulse to fix it
- Now it works again without needing to set SDL_AUDIODRIVER
					Last edited by Danacus on Mon Aug 08, 2022 8:55 am, edited 1 time in total.
									
			
									
						Re: [Donion] [1.1.62] No audio and game freeze on quit with new default sound on linux
Interesting indeed, I think I now have more questionsDanacus wrote: Mon Aug 08, 2022 8:44 am I found a pattern that might be interesting (sound is on default/SDL in all cases):
 , but thank you for your reports.
, but thank you for your reports.Re: [Donion] [1.1.62] No audio and game freeze on quit with new default sound on linux
I was hoping this could help you replicate the issue while debugging. My best guess right now is that setting SDL_AUDIODRIVER and running the game somehow changes some kind of state somewhere. Could be factorio, SDL or even PipeWire.
Re: [Donion] [1.1.62] No audio and game freeze on quit with new default sound on linux
That's the thing, so far I was unable to replicate the issue on any distro/configuration I've got my hands on.Danacus wrote: Mon Aug 08, 2022 8:58 am I was hoping this could help you replicate the issue while debugging. My best guess right now is that setting SDL_AUDIODRIVER and running the game somehow changes some kind of state somewhere. Could be factorio, SDL or even PipeWire.
But yes, once I can replicate it, your information will help.
Re: [Donion] [1.1.62] No audio and game freeze on quit with new default sound on linux
I wanted to try one last thing: removing configuration files for PulseAudio/PipeWire. So I renamed the configuration directories, such that it would use default configuration. After restarting PipeWire and WirePlumber, I couldn't replicate the bug anymore.
So I restarted my computer, opened my web browser and started factorio. The bug was back. However, this was the last time I was able to replicate the bug. My steps to replicate the bug no longer worked. I tried different things, such as opening the web browser before launching factorio, or launching factorio as the only program connected to PipeWire. Each time it worked just fine, with or without SDL_AUDIODRIVER=pulse, no matter how much I tried to replicate the bug.
I decided to restore my configuration files, expecting to be able to replicate the bug again, but I can't, I still just works fine. I suspended and rebooted my system several times, but I can't replicate it anymore. It's like it magically fixed itself somehow. But there are still other people encountering this issue.
What makes this even weirder is that I recently switched to Fedora (with my old configuration files from my previous Arch Linux installation copied over). So it was basically a clean install.
I'm sorry that I am only able to give you more questions instead of answers 
 
I'll let you know if the bug occurs again at some point.
			
			
									
									
						So I restarted my computer, opened my web browser and started factorio. The bug was back. However, this was the last time I was able to replicate the bug. My steps to replicate the bug no longer worked. I tried different things, such as opening the web browser before launching factorio, or launching factorio as the only program connected to PipeWire. Each time it worked just fine, with or without SDL_AUDIODRIVER=pulse, no matter how much I tried to replicate the bug.
I decided to restore my configuration files, expecting to be able to replicate the bug again, but I can't, I still just works fine. I suspended and rebooted my system several times, but I can't replicate it anymore. It's like it magically fixed itself somehow. But there are still other people encountering this issue.
What makes this even weirder is that I recently switched to Fedora (with my old configuration files from my previous Arch Linux installation copied over). So it was basically a clean install.
I'm sorry that I am only able to give you more questions instead of answers
 
 I'll let you know if the bug occurs again at some point.
Re: [Donion] [1.1.62] No audio and game freeze on quit with new default sound on linux
Danacus wrote: Mon Aug 08, 2022 9:50 am I'm sorry that I am only able to give you more questions instead of answers
I'll let you know if the bug occurs again at some point.
 No worries, thanks.
 No worries, thanks.- 
				sitting.duc
- Burner Inserter 
- Posts: 6
- Joined: Fri Jul 12, 2019 11:23 pm
- Contact:
Re: [Donion] [1.1.62] No audio and game freeze on quit with new default sound on linux
Hello, my original log from https://pastebin.com/cGPxKfPd was from 1.1.65, is the detail you want in there?Donion wrote: Mon Aug 08, 2022 8:08 amHi, could you please try one other thing: running 1.1.65 with default (sdl) audio backend and post the log? There is a little bit more logging than in 1.1.62 and it might help me troubleshoot this further. I appreciate your tests and reports very much!
Re: [Donion] [1.1.62] No audio and game freeze on quit with new default sound on linux
Ah, right. Yes, that's what I wanted to see, although it doesn't provide more information, the audio is seemingly initialized properly, but obviously it isn't.sitting.duc wrote: Mon Aug 08, 2022 12:12 pmHello, my original log from https://pastebin.com/cGPxKfPd was from 1.1.65, is the detail you want in there?Donion wrote: Mon Aug 08, 2022 8:08 amHi, could you please try one other thing: running 1.1.65 with default (sdl) audio backend and post the log? There is a little bit more logging than in 1.1.62 and it might help me troubleshoot this further. I appreciate your tests and reports very much!
Do you by any chance have multiple audio devices? What does
Code: Select all
inxi -ARe: [1.1.62] game freeze on quit after starting with new default sound - wasreverting audio to allegro on linux
I was able to reproduce this on my machine (Manjaro with PulseAudio and pulseaudio-alsa) on version 1.1.65 by forcing the ALSA driver withFiorra wrote: Wed Jul 27, 2022 9:05 pm I got a different take on these symptoms: I'm playing along as usual, when suddenly the audio goes silent. I saved my game, tried to restart, and then I got the same hang: "Quitting: user-quit." is the last line, double ctrl-c to quit.
A while earlier, there was a message on stderrALSA lib pcm.c:8568:(snd_pcm_recover) underrun occurred
Code: Select all
SDL_AUDIODRIVER=alsaI also saw the underrun ocurring before the audio stops, but I also saw it stopped without the underrun so it's just a symptom of the issue, not a cause.
When using the pulseaudio driver, it works fine.
Re: [Donion] [1.1.62] No audio and game freeze on quit with new default sound on linux
The issue occurred again today. The game starts without sound on pulse backend (I know it can't be using alsa backend, because libasound_module_pcm_pipewire.so is not supported by factorio on alsa backend, it only looks for libasound_module_pcm_pulse.so, which I don't have, but that's another issue I guess. Point being, if it was using the alsa backend it would tell me it failed).
I restarted my game a few times, and the bug consistently kept reoccurring. I do have multiple audio devices. inxi -A only shows HD Audio and HDMI Audio, but there is also EasyEffects Sink, an audio sink from a program that adds effects to sound such as EQ. I killed that program and then factorio did work properly, but I don't think EasyEffects is actually at fault. I restarted EasyEffects and restarted factorio. It still just worked. I can even switch factorio between EasyEffects Sink and HD Audio without issues. It might be related, but I'm not sure.
			
			
									
									
						I restarted my game a few times, and the bug consistently kept reoccurring. I do have multiple audio devices. inxi -A only shows HD Audio and HDMI Audio, but there is also EasyEffects Sink, an audio sink from a program that adds effects to sound such as EQ. I killed that program and then factorio did work properly, but I don't think EasyEffects is actually at fault. I restarted EasyEffects and restarted factorio. It still just worked. I can even switch factorio between EasyEffects Sink and HD Audio without issues. It might be related, but I'm not sure.
- 
				sitting.duc
- Burner Inserter 
- Posts: 6
- Joined: Fri Jul 12, 2019 11:23 pm
- Contact:
Re: [Donion] [1.1.62] No audio and game freeze on quit with new default sound on linux
Yes, I have multiple sound drivers. Off the top of my head I can't tell which of these is actually my sound card. (laptop etc)Donion wrote: Mon Aug 08, 2022 12:26 pmAh, right. Yes, that's what I wanted to see, although it doesn't provide more information, the audio is seemingly initialized properly, but obviously it isn't.sitting.duc wrote: Mon Aug 08, 2022 12:12 pm
Hello, my original log from https://pastebin.com/cGPxKfPd was from 1.1.65, is the detail you want in there?
Do you by any chance have multiple audio devices? What doesshow? When you run SDL backend and Allegro backend, do they both show up in pavucontrol under the same output device?Code: Select all
inxi -A
Code: Select all
gsharp@sunrise:~$ inxi -A
Audio:     Card-1 Intel 8 Series/C220 Series High Definition Audio Controller driver: snd_hda_intel
           Card-2 Intel Xeon E3-1200 v3/4th Gen Core Processor HD Audio Controller driver: snd_hda_intel
           Card-3 NVIDIA GK104 HDMI Audio Controller driver: snd_hda_intel
           Sound: Advanced Linux Sound Architecture v: k4.15.0-189-generic

Configuration pane says "GK104 HDMI Audio Controller" is profile = Off. "Built-in Audio" is profile = Off. "Built-in Audio" is profile = "Analog Stereo Duplex".
Output Devices pane has one entry, "Built-in Audio Analog Stereo", Speakers. It has a little volume meter that does respond to Factorio.
Playback pane shows "System Sounds" and "Factorio: Allegro Voice" and the little volume meter does respond to Factorio too.
Yeah, this appreciates the picture.


With config.ini line commented out and Factorio using SDL, there is no sound output, and the little volume meter is not responding.
Re: [Donion] [1.1.62] No audio and game freeze on quit with new default sound on linux
This might be completely unrelated, and this audio issue might be making me go insane, but I was trying to install a mod for NieR Automata and it was crashing. The crash seemed to be related to audio too:
I couldn't get it to work (except under the most ridiculous circumstances https://github.com/SpecialKO/SpecialK/issues/22), so I gave up and decided to return to playing factorio.
But then I noticed sound wasn't working. So I closed my music player and opened pavucontrol. Then I started factorio again and sound was working again.
So then, out of curiousity, I wanted to know if the audio-related crash in NieR Automata with the SpecialK mod was somehow fixed as well. And it was magically fixed.
The point of this whole story is that:
- This issue might be related to other programs, not just factorio
- The error messages from SpecialK might be useful, although that's probably quite unlikely.
- I might have more ways to reproduce/debug this issue
- I might be going insane and seeing patterns that don't exist
Edit: there does seem to be a connection between those issues. I started my computer today: neither game works, both get their audio bug. I open pavucontrol, and just like that they both work.
			
			
									
									
						Code: Select all
08/11/2022 16:38:05.573: [  WASAPI  ] SK_WASAPI_GetAudioSessionControl (...) Failed During Enumerator Setup : SK_WASAPI_GetAudioSessionControl (...): Failed on Line 222 of C:\Users\amcol\source\repos\SpecialK\src\sound.cpp -- (HRESULT: 80004001) -- "Not implemented."
But then I noticed sound wasn't working. So I closed my music player and opened pavucontrol. Then I started factorio again and sound was working again.
So then, out of curiousity, I wanted to know if the audio-related crash in NieR Automata with the SpecialK mod was somehow fixed as well. And it was magically fixed.
The point of this whole story is that:
- This issue might be related to other programs, not just factorio
- The error messages from SpecialK might be useful, although that's probably quite unlikely.
- I might have more ways to reproduce/debug this issue
- I might be going insane and seeing patterns that don't exist
Edit: there does seem to be a connection between those issues. I started my computer today: neither game works, both get their audio bug. I open pavucontrol, and just like that they both work.
Re: [Donion] [1.1.62] No audio and game freeze on quit with new default sound on linux
Hello, I have a similar issue:
* Xubuntu 20.04
* pulseaudio
* audio-backend=default or sdl
* steam
*
This happens since today update to 1.1.68, as I am on steam stable channel, I suppose it was in 1.1.61 previously.
Game freeze on quit, but also in game when I move near some factory (by moving player, or satellite view).
Changing `audio-backend=allegro` seems to fix the issue (not tested on long running game).
			
			
									
									* Xubuntu 20.04
* pulseaudio
* audio-backend=default or sdl
* steam
*
Code: Select all
inxi -A
Audio:     Device-1: NVIDIA TU106 High Definition Audio driver: snd_hda_intel 
           Device-2: Advanced Micro Devices [AMD] Starship/Matisse HD Audio driver: snd_hda_intel 
           Sound Server: ALSA v: k5.4.0-124-generic Game freeze on quit, but also in game when I move near some factory (by moving player, or satellite view).
Changing `audio-backend=allegro` seems to fix the issue (not tested on long running game).
Ubuntu 16.04 x86_64 - Steam
						Re: [Donion] [1.1.62] No audio and game freeze on quit with new default sound on linux
Added launch option --audio-driver=allegro in Steam did the trick for me.
Ubuntu 20.04.1
			
			
									
									
						Ubuntu 20.04.1
- 
				LordBlackwood
- Manual Inserter 
- Posts: 4
- Joined: Thu Jun 04, 2020 9:45 am
- Contact:
[1.1.68] bluetooth headphones only have sound if connected prior to game launch (macOS)
If i connect my AirPods prior to launching Factorio, everything works fine and i can hear the game audio over the headphones.
But if i launch factorio while they are not connected, and then connect them when the game is already running, there is no sound.
This only affects Factorio, since audio from all other applications still works fine over the AirPods.
Local audio (i.e., via the built-in speakers) still works fine regardless of when i connect or disconnect the headphones, it's only the bluetooth audio that doesn't work if the AirPods aren't already connected on launch.
Specifying the launch option fixes this.
Possibly related to:
- viewtopic.php?f=182&t=102981 (though that bug report mentions getting an error message on launch, which i am not)
- viewtopic.php?f=182&t=102982 (though that report mentions the game freezing when changing the audio system, which i was not able to reproduce)
(Furthermore, both of the above-linked reports are Linux-specific and seem to be related to the presence (or lack thereof) of specific linux audio drivers and packages, which of course does not apply to macOS.)
			
							But if i launch factorio while they are not connected, and then connect them when the game is already running, there is no sound.
This only affects Factorio, since audio from all other applications still works fine over the AirPods.
Local audio (i.e., via the built-in speakers) still works fine regardless of when i connect or disconnect the headphones, it's only the bluetooth audio that doesn't work if the AirPods aren't already connected on launch.
Specifying the
Code: Select all
--audio-driver=allegroPossibly related to:
- viewtopic.php?f=182&t=102981 (though that bug report mentions getting an error message on launch, which i am not)
- viewtopic.php?f=182&t=102982 (though that report mentions the game freezing when changing the audio system, which i was not able to reproduce)
(Furthermore, both of the above-linked reports are Linux-specific and seem to be related to the presence (or lack thereof) of specific linux audio drivers and packages, which of course does not apply to macOS.)
- Attachments
- 
			
		
		
				- factorio-current.log
- (107.17 KiB) Downloaded 142 times
 
Re: [Donion] [1.1.62] No audio and game freeze on quit with new default sound on linux
With version 1.1.71, the SDL and its audio backend has been updated to a newer version. Some of you have already tested it (or a similar build) and it solved your issues. I cannot guarantee that it solves all issues everywhere but I'm moving this thread to Resolved. I would ask people that still have issues to create a new thread, otherwise this thread could be here forever.
			
			
									
									
						
