-
Notifications
You must be signed in to change notification settings - Fork 1.1k
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
Proton not working when multiple Linux users share a single installation path #4820
Comments
Hello @Maykin-99, upstream wine does not allow the wine prefix to be being owned by another user to prevent an entire category of problems. Proton inherits this behavior and ideally, your issue would need to be evaluated and resolved upstream with vanilla wine before looking at it here. |
I'm pretty sure this is a Steam client limitation more than anything else. You're not intended to share Steam Library folders between users. Some applications do stupid things like write files directly into the Library folders, which can fail with multiple users. |
@kisak-valve: I'm sure Wine does what it does for a good reason. In fact, if we look into their forum it states "Risk of of registry corruption" as the reason: Link In the same post it also suggests creating a wine prefix for each user and store the data outside of it:
So I simply ask Valve to follow their advice.
I'm honestly not sure which piece of software (Steam Client vs. Proton) is configuring wineprefix. I'll reference this issue in the
I disagree. It works in Windows and I expect it to work in Linux as well.
Though in my experience this only causes that save games & configurations are shared unintendedly. And I don't expect Valve to fix game developer's "stupid things". |
Fixes ValveSoftware#4820 by setting the base directory of `CompatData` from `steamapps/compatdata/<steamid>/` to `steamapps/compatdata/<steamid>/<userid>/` (I'm honestly surprised that it worked without a hitch). The only issue is that the old files still exist. Ideally we would move them to the new path. I assume that would belong in `upgrade_pfx`? Or is it even necessary?
i've spend evening trying to launch game on my notebook for my friend to get to this issue. Can we at least for now have some proper error pop up? Cause right now if you try to do that steam will do funny: button is blue cause game is running, oh and now button is green to launch it again like nothing happened whatsoever, and even error text in console does not provide that much information, cause i was setting that share library permission to all kinds of stuff. |
Just adding a voice to the chorus, it would be lovely if this could be fixed. We have a single Linux computer shared by the household. Games are massive, so we install them to a shared directory and use Family Sharing to share the games, but of course run into this proton permissions issue. I don't see the point of local family sharing if you still have to install games per-user. |
Also wanted to add that this would be a really useful addition. I am trying to share a game library between an admin account that is meant for regular PC use and a passwordless account that is meant to be used via controller in front of a TV (ie. console-style experience). I've tried a number of different solutions, but haven't found a way to get past the "compatdata is not owned by you" error. |
Agreed - this is stopping me sharing my games with my kids with their own accounts |
Yet another comment to this 3 year old thread. Other people in my household can't play games run with proton without granting access to the sys admin user, which not only becomes an inconvenience, but also a privacy and security concern since it would mean giving other people access to first of all a personal user, but also to possibly a sudoer. This would also help mimic native games behavior. Giving an option to grant access based on group rather than user ownership is the way to go forward with this issue. |
Yep, I'm in the same boat as others. I'd love to see this resolved for the same reasons. |
Same here, my partner and I share the "gaming pc", and we don't have enough storage to install 100+GB like BD3 or FO76 twice, I understand the limitations because of how privileges work in Linux, but games are getting bigger and bigger, and it's not viable to install things twice anymore. To me (not a programmer) this approach seems pretty clean and I´d like to think that its possible using symlinks for the game data while keeping the prefixes in the home folders. I read somewhere while looking for a solution for this that sharing the installation folder would mean having to share game settings between users, but afaik that isn't true for pretty much every modern game. And when it comes to older games saving confs in the installation folder, I wouldn't consider that to be a problem because that's the intended behavior and would work in windows just the same. |
I would like to see this too. |
I just want /compatdata to be independent of the library. Most games save to /compatdata and this would prevent save files being shared, as weel as the issues with permission. I don't see any drawback. Heck, this PR fixes all the issues with the current implementation. |
Currently facing the same issue. My kids and I finally got a super-duper gaming PC, I'm a linux pro user for over 10 years, did my best to give the shared permissions to the games storage directory, but this still raises permission issues. No CS today, no CS tomorrow. Why are you doing it to us? It's a torture. And my son asks me if somebody better skilled than me can solve it.. Please fix it |
@kamichal you can do some really cursed thing where the shared library compatdata is mounted to a compatdata inside each user during log-in It is not the proper fix, but could help you and your family |
I could try, but what exactly do you mean? Sounds like not a symbolic link, but some per-user mount, isn't? |
Pretty much. I haven't tested it yet, as I'm going to be building a shared super-duper PC during November, but I've asked around and you should create a service for each user that does this on login This has the annoying issue of making it a nightmare if you change from one user to another(as in, Linux user) without ending that session, but hey, better than nothing. |
Won't this mess up cause for a steam library to work it needs the .acf files outside the |
I am curious to know how @Rhimlock's solution works as well, right now my workaround is I have a
Of course, with extra work you could detect and fix these things with the script, use pid files or maybe systemd configuration to ensure not more than 1 steam runs at a time, etc. But I've not done that. However, Rhimlock's suggestion basically flips the idea around, rather than "share everything except compatdata", it's "share only common". But I do wonder about files like acf, and other folder I don't fully understand like workshop. It looks like shadercache would be duplicated, on my system it's only 2GB though. And it's probably better than downloading and temp folders are not shared, but there's probably still going to be issues if 2 users try to download or update the same game at the same time. Download is not likely, but auto-update could be if both users are running Steam concurrently. I noticed on Windows, it looks like if another user launches Steam, it kills the other instance, so there's probably reason for that... |
@etyarews So the *.acf-Files are all in my home-folder, while the content from common is located in the shared folder. @gillius As far as I can tell, you tried to link those files from your shared folder to your home-directory instead of changing the ownership. So my solution is the opposite of yours ;-) My steam-storage is the default in ~/.steam/debian-installation where all items from Proton and SteamRuntime are located. And this linked common folder looks like this I hope this makes it a little bit easier to understand. |
@Rhimlock From my understanding, Steam requires the .acf files to properly recognize and import the game. Here's what I understand is going to happen:
I don't think Bob will have access to the game. I've checked here by deleting the |
@etyarews I can confirm that @Rhimlock 's solution works: we have multiple users (me and my kids) who use Steam.
Now the issue is gone that he wasn't able to run games using Proton which I previously installed with my own account under /home/share/SteamLibrary |
@alxchnr Not sure if I understand this right, but Steam will only create the appmanifest*.acf file when your son tries to install a game that already exists on the shared library, this means he has to manually select "Install", right? This is a problem I was pointing out is that without the files, Steam will require manual intervention to pick up the games, which is less than ideal. |
@etyarews Yes, he has to "install" it manually and Steam will recognize that the installation data is already available in the shared /common folder - instead of newly downloading and installing separately. But I also see that your scenario is quite different from mine: my son sees the available but not yet installed games in his Steam library as I made them visible to him by the family sharing option. |
@etyarews know I understand what you meant. And @alxchnr 's explanation is correct. I have a family group in Steam for my wife and myself and we got some games we like to share but also some that one of us wants to play but the other one does not care about. So they don't show up in the ready to play filter. |
Yeah, while I don't love how this needs manual intervention, I think this is the ideal solution. A benefit is that since Steam is "installing" the game again, it means that a shortcut will be created for Bob I'm also going to link the |
I've switched to the method mentioned by @Rhimlock #4820 (comment). Some notes:
In summary, it works, but it's not "production-ready" in the sense it requires some baby-sitting. Uninstalls don't work and I still have fear if someone keeps steam running in background on locked screen and you switch users and have multiple steam running, which is easy to do since it stays in system tray. I manage this by always trying to sign off and/or exit Steam explicitly, but I can't say the same for my kids. However, for my use it's a lot better than the alternative of multiple downloads of 100+ GB games. To share properly on Linux some system daemon or lockfiles to prevent concurrent update/install/uninstall operations, as well as per-user compatdata, and to be really user friendly, some UX to set up the shared folder. That said, this is a Proton GH and not Steam so changes would be needed in both to support. |
A bigger issue with @Rhimlock method that I'm facing is that, untill every user has installed a game, you cannot mod it. When a user "installs" a game, Steam verifies the installation if it is already installed, if the game is modded then it un-mods it |
I've followed these instructions on Reddit to allow multiple Linux users to share the same installation folder without dealing with permission issues. That seems to work so far for Linux-native games.
The issue with Proton games is that Wine does not allow using a Wine-Prefix that doesn't belong to the current user.
Example:
Both Steam clients on both Linux accounts are configured to download the games in
/opt/games/Steam
.User
maykin
installs a Windows game and a Wineprefix in/opt/games/Steam/steamapps/compatdata/430190/pfx
is created.User
steamuser
wants to play the same game.It does not need to install the game again, since
maykin
already installed it.When attempting to start the game nothing happens (no game & no error message).
When inspecting the logs the following error occur:
The relevant part is (so I assume)
wine(server): /opt/games/Steam/steamapps/compatdata/430190/pfx is not owned by you
.The directory is owned by
maykin
butsteamuser
has read and write access to it but Wine - for security reasons apparently - doesn't care and demands that the prefix is owned by the current user, i.e.steamuser
.My suggestion:
Instead of creating the prefix here:
/opt/games/Steam/steamapps/compatdata/<gameid>/pfx
we could place it there:/opt/games/Steam/steamapps/compatdata/<gameid>/pfx/<userid>
Put the
device_c
in a separate directory outside the prefix, e.g. in/opt/games/Steam/steamapps/compatdata/<gameid>/data
, and place a symbolic link in/opt/games/Steam/steamapps/compatdata/<gameid>/pfx/<userid/device_c
that points to thedata
directoryThe text was updated successfully, but these errors were encountered: