-
Notifications
You must be signed in to change notification settings - Fork 86
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
Some Feral ports need launch option workarounds with glibc 2.37+ and recent Steam Runtime default #613
Comments
Latest glibc deprecated some (undocumented) behaviors related to AT_PLATFORM that broke a number of native titles. This is unlikely to get fixed in glibc, your workaround is generally correct, the preferred outcome would be to have these games fixed (can easily be addressed with a launch script). |
tl;dr: The general workaround for affected games is to copy or symlink all the libraries from For searchability, I believe this is a regression when upgrading glibc from 2.36 (this game worked) to 2.37 (doesn't work). Several games ported by Feral Interactive are affected. The ones that I know about are:
but it probably affects other Feral games that were ported to Linux at around the same time. This is a game issue (the game cannot find its own bundled libraries) rather than a Steam Runtime issue (the game can find libraries provided by the Steam Runtime, those are not the problem). I looked into this a few weeks ago, and there doesn't seem to be a good general way for the Steam Runtime to work around it. The common factor is that these games add Game-specific workarounds:
Workarounds that no longer work:
|
It's probably worth retitling this to "Mad Max and other Feral ports need a workaround with glibc 2.37+" or something like that, to clarify its scope. |
I emailed Feral regarding the issue, including a proposed one-line fix to their launch scripts but have yet to get a reply. In the case for Tomb Raider 2013, adding Likewise, adding If Feral doesn't reply, is it possible for Valve devs to push an update to Feral's Linux Steam game depots on their behalf? |
NOTE: Dirt Rally didn't work with previous versions of glibc as well. For Dirt Rally, you can unlock a beta branch that runs out of the box with the password
The only caveat to using the feral_support_branch is that it's on game version 1.22 and not 1.23, but it DOES have working RaceNet support. I haven't tested MP capabilities between 1.22 and 1.23 because none of my friends play the game, and RaceNet doesn't work on 1.23 native or proton. Upon comparing the lib folders between the two branches, the missing libraries in the main branch are EDIT: On arch linux you might have to additionally install libxcrypt-compat for the feral_support_branch to launch |
Sorry, I believe Valve's policy is that only the publisher/developer can modify game depots, and Valve will ship whatever game binaries the publisher/developer has provided. If the game ceases to work on a more recent OS, then it's up to the publisher/developer to address that. I contacted Crystal Dynamics about Tomb Raider (2013) when I discovered this problem, and I received an acknowledgement, but I haven't seen any updates since then. It's understandable that fixing the Linux port of a 10 year old game is not being treated as a particularly high priority. What Valve can do is to configure the game to default to running the Windows version via Proton on Steam Deck, in preference to running the native Linux version directly. For example, this was done for Tomb Raider (2013) on 2023-08-24. This doesn't currently affect desktop Linux, though. |
This is a known issue in Arch's packaging of the Steam client, https://bugs.archlinux.org/task/75443. |
This change in Dirt Rally's beta branch is the same hotfix that I mentioned as being included in the paid version of Life Is Strange. It seems to have been intended as a workaround for a much older glibc bug, but as a side-effect, it accidentally fixes this newer issue too.
It shouldn't actually be necessary for a game to bundle its own copy of those: the Steam Runtime provides both of them (although if |
Despite much digging I was unable to determine why Dirt Rally failed to launch with steam runtime, despite the launch script saying it was compiled against it, meaning it should work with it indefinitely (unless the runtime breaks the game). Might take a deeper look into this over the weekend.
------- Original Message -------
…On Thursday, August 31st, 2023 at 12:46 PM, Simon McVittie ***@***.***> wrote:
> Ensure the ld library seach path works for multilib
This change in Dirt Rally's beta branch is the same hotfix that I mentioned as being included in the paid version of Life Is Strange. It seems to have been intended as a workaround for a much older glibc bug, but as a side-effect, it accidentally fixes this newer issue too.
> Upon comparing the lib folders between the two branches, the missing libraries in the main branch are libcrypto.so.1.0.0 and libssl.so.1.0.0
It shouldn't actually be necessary for a game to bundle its own copy of those: the Steam Runtime provides both of them (although if libcrypt.so.1 is missing, they might not load successfully).
—
Reply to this email directly, [view it on GitHub](#613 (comment)), or [unsubscribe](https://github.com/notifications/unsubscribe-auth/AE5Z7N4YL67DP5GD6RRPVJLXYCBQXANCNFSM6AAAAAA3UPWEUA).
You are receiving this because you commented.Message ID: ***@***.***>
|
Sorry, it's not that simple: the goal of the Steam Runtime is to keep games compiled against it working forever, but sometimes incompatible changes happen in host OS components like glibc that are outside our control. |
Oh, that didn't even occur to me. Sadly Dirt Rally doesn't launch in the Steam Runtime even with the workaround from the beta branch added back to the script on the main branch.
Unrelated request, not even sure you can do this, but would it be possible for us to pick between Scout, Soldier, and Sniper when running a game with Steam Runtime. I feel like that'd help test things a bit better to identify if a breakage is within Steam Runtime itself
------- Original Message -------
…On Thursday, August 31st, 2023 at 12:57 PM, Simon McVittie ***@***.***> wrote:
> despite the launch script saying it was compiled against it, meaning it should work with it indefinitely (unless the runtime breaks the game)
Sorry, it's not that simple: the goal of the Steam Runtime is to keep games compiled against it working forever, but sometimes incompatible changes happen in host OS components like glibc that are outside our control.
—
Reply to this email directly, [view it on GitHub](#613 (comment)), or [unsubscribe](https://github.com/notifications/unsubscribe-auth/AE5Z7N2SIH3RRLXPRLDPZH3XYCC4HANCNFSM6AAAAAA3UPWEUA).
You are receiving this because you commented.Message ID: ***@***.***>
|
No, that's not something that should be done. Before soldier/sniper became available, all games were meant to be compiled in a scout environment and would always be run in a scout environment, so the only safe assumption is that we must continue to run them in a scout-compatible environment. soldier and sniper are not 100% backward-compatible with scout (legacy libraries like GTK 2 and OpenSSL 1.0 are not included), so they are not expected to ever support all games that ran correctly in scout. For games intended to be run under scout (the vast majority of native Linux games on Steam right now), you have two options, and there is a third option that could in principle be provided but currently is not:
A minority of native Linux games (Battle for Wesnoth, Counter-Strike 2, Dota 2, Endless Sky, Retroarch) have been specifically set up so that Steam assumes they were compiled in sniper, and will always run them on |
I've edited my first comment #613 (comment) to highlight the currently-recommended workaround for the affected games via launch options. Beyond that, unfortunately this is "won't fix" (or more accurately "can't fix") from our point of view: it's up to the game publisher/developer to solve this by updating the game's depot contents.
We were able to fix this from the Steam Runtime side without observing any regressions, so Steam releases since the 2023-10-24 beta have included a fallback copy of
This has also been fixed: Arch's |
@smcv |
Sorry, I am not a developer or publisher of this game, and you haven't provided enough information about it to know whether the problem you are having is the same as this one or something different. If you believe this is a Steam Runtime problem, please open a separate issue and provide the information and logs requested by the issue template - that will give us enough information to either improve the suggested launch options and close your separate issue as a duplicate of this one, or diagnose it as something different. |
The Steam Linux Runtime container default for all Linux Games further breaks Mad Max and the LD_LIBRARY_PATH workaround no longer works: |
With SLR, the
|
The nature of workarounds is that they're often going to be very sensitive to subtle implementation details. |
Yeah, I've updated the issue with the new launch option workarounds, along with a workaround for Dirt Rally and Life is Strange : Before the Storm. Perhaps other known broken games with workarounds can be added to the list. |
@XaeroVincent, At some point I'll try to look into giving SLR an option for "after entering the container, please prepend this to the
If this has the same issue involving glibc private symbols described in https://github.com/vkc-1974/XCOM2WotC-f35, then that is not the same thing as what we're discussing here, and its workaround is also very different. To avoid confusion I would recommend treating it as a separate issue, presumably affecting XCOM2: War of the Chosen, Life is Strange: Before the Storm and possibly others. Life is Strange: Before the Storm (Deck Nine, 2017, Unity engine) should not be confused with the original Life is Strange (Dontnod, 2013, Unreal engine), even though they are from the same series and were both ported to Linux by Feral. They are different games with different bugs. |
Right. The games launch consecutive times with the standard
That sounds like a good feature to have or maybe some sort of workaround for these broken games added internally into the Steam Runtime, since it's unlikely Feral will fix these issues? It would be nice to be able to just click Play and the games start.
Yeah I know it's a different issue but related to a different glibc change. The script accessing that github page is mine and tailored to work with Life is Strange Before the Storm. The original Life is Strange game runs out-of-the box without any launch options or patched libraries for me. I don't think I can test the free demo after owning the full game? My idea was to perhaps turn this report into a Feral game "mega issue", where workarounds and discussions can be found for all broken Feral Linux ports, regardless of specific technicalities of why they broke. |
Please don't. As the person doing a lot of the triaging and bug fixing for the Steam Runtime, I strongly prefer not to have mega-issues that conflate more than one underlying problem, because that's an issue that we can most likely never close - even if we can find a way to resolve or work around most of the underlying root causes! And during the time that it remains open, it will accumulate well-intentioned messages about different underlying problems, which means we have to spend more time disentangling several different root causes in order to understand the problem, leaving less time available for actually fixing anything. Sorry, but this is primarily an issue tracker for Steam users to report issues to us so that we can (try to) fix them. Being able to document workarounds for other Steam users for the things we can't fix is also useful, but that's only a secondary purpose of an issue tracker. The LiS:BtS issue might also be a more general thing for a different generation of Feral ports, since you're reusing a workaround that seems to have been developed for Xcom 2. I think it would be worth discussing on a separate issue (particularly if we can involve the author of the Xcom 2 workaround in that discussion), but not here. |
Yes, I believe that's correct. Technically it isn't actually a free demo - Steam has a mechanism for publishing demos, and Life is Strange 1 doesn't use it. Instead, it's been implemented as a short free game (containing the engine and episode 1) with some paid DLC (the rest of the episodes). Normally if a game developer uses that technique, when they update the engine with bug fixes, free and paying users would get exactly the same engine and therefore the same bug fixes. Unfortunately, their workaround for this same issue wasn't implemented as part of the engine, but instead is in a separate hotfix depot which was made available as part of the "paid-for game" (technically, the paid-for DLC episodes). I don't know whether the developer did this intentionally or accidentally, but my guess would be accidentally (they probably weren't thinking about free-to-play demo users when they published the hotfix). As far as I can tell, it wasn't even a hotfix for this bug - it's a workaround for an unrelated regression in an older version of glibc (which was subsequently fixed in glibc), but it accidentally fixes this bug as a side-effect. |
Ah, I'm too used to using |
Nice. I see "Legacy runtime 1.0" was added to the compatibility tool list. |
A mess. Sounds like Feral should just remove that depot from Steam and just have the Windows version with Proton as a free Episode 1. |
Native Linux versions of some Feral ports no longer launch on Steam without providing game launch options and other things:
Mad Max, Tomb Raider (2013), Deus Ex: Mankind Divided:
LD_LIBRARY_PATH="$(pwd)/lib/x86_64:$(pwd)/lib/i686:$LD_LIBRARY_PATH" %command%
Select Properties > Compatibility > "Force the use of a specific Steam Play compatibility tool" thenLegacy runtime 1.0
from the list.DiRT Rally: Need to opt into the
feral_support_branch
private beta branch. Select Properties > Betas. Typeferaldirtsupport
then selectferal_support_branch - feral_support_branch
from the Beta Participation list.Life is Strange: Before the Storm: Download this file and remove the
.txt
from the name and run it as a script. You'll only need to run the script once, unless you delete the created library file or reinstall/repair the game.lisbts_fix.sh.txt
The text was updated successfully, but these errors were encountered: