• muhyb@programming.dev
      link
      fedilink
      arrow-up
      35
      ·
      4 days ago

      We also need a native Wayland client for Steam, though it’s tied to Chromium Embedded Framework’s native Wayland support. Probably it will come with Electron’s support. No idea when.

    • ogeist@lemmy.world
      link
      fedilink
      arrow-up
      21
      ·
      4 days ago

      Could you elaborate on the advantages, I’m using wayland and steam for games, no issues so far.

    • INeedMana@lemmy.world
      link
      fedilink
      arrow-up
      4
      arrow-down
      7
      ·
      4 days ago

      I really hope Proton would stop running a container. It makes running additional programs harder (opentrack for example) and our computers less ours

      • patatahooligan@lemmy.world
        link
        fedilink
        arrow-up
        12
        ·
        4 days ago

        No way. Containers are absolutely necessary to provide reliability across a wide range of distros and to keep games working in the future.

        It makes running additional programs harder (opentrack for example)

        Then we need better tooling and documentation to interact with the container, not to get rid of them. I don’t see any technical limitation that would prevent your use case. It’s just not implemented or maybe simply undocumented.

        our computers less ours

        How so? The end result is probably the opposite. Without the containers Steam would be less reliable on unsupported distros, which might mean your only choice would be to use Ubuntu LTS. That would be a much bigger loss of control.

        • arc@lemm.ee
          link
          fedilink
          arrow-up
          2
          arrow-down
          1
          ·
          3 days ago

          That’s more or less it. Linux Torvalds hates the different package managers and dependencies in different dists and versions of dists. He claims it’s virtually impossible to ship products that just run on some random dist and cites his own sideproject which is a sea diving app where he builds binaries for Mac OSX and Windows but can’t for Linux. He also praises Valve for using containers.

          In theory it means slightly larger binaries, but the flipside it means Steam for Linux runs on a lot more dists, and so do the games and it’s far easier to test they actually run.

        • INeedMana@lemmy.world
          link
          fedilink
          arrow-up
          1
          arrow-down
          3
          ·
          4 days ago

          Containers are absolutely necessary to provide reliability across a wide range of distros and to keep games working in the future.

          We are going through more or less Wine anyway, the libraries on the system don’t matter as long as Wine compiles

          In ideal world it would be pure Wine, with Valve putting merge requests for things they want to change, instead of another EEE that’s only waiting to happen. More like AMD interacts with kernel driver. Valve already runs SteamOS, they can use it to have a stable 100% supported platform for their decks etc

          better tooling and documentation to interact with the container

          One of the core features of containers is process and process memory separation from host. So in case of headtracking (accessing game’s shared memory), containerization is directly working against it working. It’s not the tooling, it’s the choice of what to use

          Linux has had chroot since a long time if we are really afraid about supporting dwindling native client games

          How so? The end result is probably the opposite. Without the containers Steam would be less reliable on unsupported distros, which might mean your only choice would be to use Ubuntu LTS. That would be a much bigger loss of control.

          We have no control over what they put in those containers. Similar (to put perspective) as we have no control over what Google does in their Gapps (and app developers neither have!), So far we can go inside and inspect what are they running apart from the game’s exe directly. Once they disable the PRESSURE_VESSEL_SHELL=instead we will have no insight into what’s inside. And the other option - if it doesn’t work for some reason (with Wine I don’t really see it happening as what we run doesn’t rely on our OS libraries directly), you can create chroot, additional library packages with old versions, etc. Worst case scenario, Linux community will figure something out

          • Ferk@lemmy.ml
            link
            fedilink
            arrow-up
            3
            ·
            edit-2
            2 days ago

            We have no control over what they put in those containers

            Most games on Steam are proprietary software you don’t control to begin with. It seems reasonable to keep them encapsulated in containers (+1 if you run Steam on flatpak or so) rather than granting them the capacity to run amok in the entire system, which we would have even less control over.

            It seems contradictory to want to remove barriers that are preventing the software from taking more control, and at the same time complaining about how they are having too much control.

            • INeedMana@lemmy.world
              link
              fedilink
              arrow-up
              1
              arrow-down
              1
              ·
              2 days ago

              Most games on Steam are proprietary software you don’t control to begin with

              But those are small fries, not “the provider of games”

              rather than granting them the capacity to run amok in the entire system

              WDYM?

              1. we don’t run games as root
              2. we are speaking about Wine, so what they see is limited to WINEPREFIX
              • Ferk@lemmy.ml
                link
                fedilink
                arrow-up
                2
                ·
                edit-2
                2 days ago

                But those are small fries, not “the provider of games”

                They have less to loose, then. That’s just as dangerous, if not more.

                I’m a small fry too, would you run a binary I send you without any form of sandboxing?

                we don’t run games as root

                No, we typically run them with the same user that stores all our useful private data and that we typically type our passwords with.

                Also, why are you OK with that level of sandboxing? don’t you want more “control”? You say containers are bad, but using user roles to protect parts of the system is ok? why are you not running all as root if you want “control”?

                we are speaking about Wine, so what they see is limited to WINEPREFIX

                Not really, by default you have access to other drives (Z:\ being /, the fs root), wine is not a perfect sandbox, it’s not designed for that… and if you actually did want it to become one (which ultimately would also lead to a need for memory separation to fight memory-leak attacks) then it would not be that different from what’s being pursued. You’d be essentially building the container in a custom version of wine shipped by Valve on Steam, it does not make any difference in terms of “control”.

          • patatahooligan@lemmy.world
            link
            fedilink
            arrow-up
            4
            arrow-down
            1
            ·
            edit-2
            3 days ago

            We are going through more or less Wine anyway, the libraries on the system don’t matter as long as Wine compiles

            Which wine though?

            The one pre-packaged by your distro? That doesn’t work because Valve needs to control the version you use and to provide additional stuff not part of vanilla wine.

            The one part of proton that is built and delivered to your system by Valve? They would have to compile and support it for every set of dependency versions out there.

            One of the core features of containers is process and process memory separation from host.

            As far as container technology is concerned, the isolation is configurable. pressure-vessel is most likely using (possibly indirectly) namespaces and/or cgroups to achieve the isolation. I don’t see a technical reason that you can’t disable the isolation of shared memory or any other resource. The issue is whether you are given access to disable it.

            According to the docs the runtime is based on flatpak and uses bubblewrap and libcapsule. I don’t know about libcapsule, but I recall that bubblewrap has granular control over what resources it isolates.

            We have no control over what they put in those containers.

            Apparently, you can modify the container as shown here. But there’s no reason why you shouldn’t be able to install custom containers alongside the default ones in the same way that you can install custom proton versions. Steam just doesn’t provide the interface for it.

            Once they disable the PRESSURE_VESSEL_SHELL=instead we will have no insight into what’s inside.

            There already exists an alternative that is “more likely to be extended in future” rather than being removed as shown here. But I believe you would always be able to gain access to the container because it remains a chroot + namespace + cgroup isolation, all of which you can control on your system.

            and app developers neither have!

            App developers don’t control what’s on your system either. The container is a huge improvement for them because it at least gives them a known target to build for. They can still bundle dependencies in any way that they would on a non-containerized system. There’s no loss of control from their perspective.

            if it doesn’t work for some reason (with Wine I don’t really see it happening as what we run doesn’t rely on our OS libraries directly), you can create chroot, additional library packages with old versions, etc.

            That’s what pressure-vessel is and as shown above you can modify it. And if you couldn’t it would be a tooling issue, not an inherent container disadvantage.

            Worst case scenario, Linux community will figure something out

            No, they won’t. Compatibility significantly increased after Valve got involved. In fact, the linux community is porting pressure-vessel outside of Steam to use it across different launchers as umu. The community is headed towards using pressure-vessel for everything.

            Now I replied to each claim individually, but it’s not really about any specific point you’re making. The general idea is that there’s nothing inherent to container technology that prevents you from tinkering with it. Anything that you can’t do currently is because Steam is not designed to allow you to do it. It’s got nothing to do with whether Steam uses containers or not. Any control that you’ve lost over your system is because you’re using a proprietary app. They could remove the containers and still prevent tinkering, eg by using a bundled wine with no way for you to modify it or its launch options. It’s not about what Steam does, but about how it does it.

            • INeedMana@lemmy.world
              link
              fedilink
              arrow-up
              1
              ·
              3 days ago

              Which wine though?

              Most of Proton code is Wine. So basically if you have Wine in your system, library dependencies are not an issue anymore, apart from DLLs that some games require

              Valve needs to control the version you use and to provide additional stuff not part of vanilla wine

              And that is one of the reasons why I expect them to pull the rug at some point. Why are they doing a fork instead of contributing?

              The one part of proton that is built and delivered to your system by Valve? They would have to compile and support it for every set of dependency versions out there.

              Then why not let us manage Wine runners, like for example Lutris does?

              I don’t see a technical reason that you can’t disable the isolation of shared memory or any other resource. The issue is whether you are given access to disable it.

              And that is my issue

              But there’s no reason why you shouldn’t be able to install custom containers alongside the default ones in the same way that you can install custom proton versions. Steam just doesn’t provide the interface for it

              And that’s exactly my gripe. But I expect it will be easier to push back on using containerization in Proton, than making Valve allow us such control

              I believe you would always be able to gain access to the container because it remains a chroot + namespace + cgroup isolation, all of which you can control on your system

              I’m less optimistic. I expect they will in the future make it as hard as possible

              App developers don’t control what’s on your system either. The container is a huge improvement for them because it at least gives them a known target to build for. They can still bundle dependencies in any way that they would on a non-containerized system. There’s no loss of control from their perspective.

              That parenthesis was a tangent on Android Google apps, to show what I am afraid will happen in the future. Currently, in order for Android app to appear in the official Store, developer has to allow Google to repackage their app and sign it with Google key. So while we can inspect what is there in the code of the app in git, we don’t really know what lands on our phones if installed via Google Play

              And as for taking the topic back to game developers, when we are talking about games ran with Proton, their known target is Windows anyway

              That’s what pressure-vessel is and as shown above you can modify it. And if you couldn’t it would be a tooling issue, not an inherent container disadvantage.

              I couldn’t find a way to disable memory separation. And if that’s not available, that is an issue with pressure-vessel, not tools

              Compatibility significantly increased after Valve got involved

              I think that was only because of additional work spent on games. I haven’t seen an example where a game would not work at all with Wine but would work with Proton. There are improvements on how it runs, of course. But my argument is that if some implementation in Proton makes a game work better, then it should land in mainline Wine

              there’s nothing inherent to container technology that prevents you from tinkering with it. Anything that you can’t do currently is because Steam is not designed to allow you to do it. It’s got nothing to do with whether Steam uses containers or not

              Yes. But “please, don’t fuck us up” is not something we can enforce

              They could remove the containers and still prevent tinkering, eg by using a bundled wine with no way for you to modify it or its launch options

              We can always just go back to running Windows version of whole Steam via Wine, as we were doing before Proton

              • Ferk@lemmy.ml
                link
                fedilink
                arrow-up
                1
                ·
                2 days ago

                Currently, in order for Android app to appear in the official Store, developer has to allow Google to repackage their app and sign it with Google key. So while we can inspect what is there in the code of the app in git, we don’t really know what lands on our phones if installed via Google Play

                You can still open an APK and decompile it… it being signed with a specific key is no different than the digital signatures some attach to their emails, it’s a way to prove authenticity, not a way to encrypt the message… you can open the email without having to even care about the signature.

              • patatahooligan@lemmy.world
                link
                fedilink
                arrow-up
                3
                ·
                3 days ago

                Most of Proton code is Wine. So basically if you have Wine in your system, library dependencies are not an issue anymore, apart from DLLs that some games require

                If I have wine on my system and try to run steam-managed proton without any sort of runtime or container, then I’m running proton on different versions of libraries than the ones it was compiled for and tested on. Proton also has additional components which might mean additional dependencies, so your statement is false to begin with.

                Why are they doing a fork instead of contributing?

                The fork is open source. As far as I know, some contributions do get merged into wine. Valve is also funding work from Collabora which is contributed directly into wine. They cannot contribute the entirety of proton to wine because wine does not want all their contributions. This is a very common situation to arise when someone wants to use an open source project but their goals don’t align.

                But I expect it will be easier to push back on using containerization in Proton, than making Valve allow us such control

                Valve is never going to rip out a solution that is working great for them and risk causing issues for customers for no good reason. Thinking that Valve are more likely to remove containerization than they are to allow you to modify the container is, frankly, delusional. It’s also completely irrelevant, as I’ve already said. If Valve wants to “fuck us up” then they’re going to do it. Steam is a proprietary piece of software that supports DRM for all your (also proprietary) games, which are stored on the cloud. You have no control over your games, but containers have nothing to do with it. And if they did, and Valve really wanted to pull a trick on us, asking them to remove the containers would make even less sense…

                • INeedMana@lemmy.world
                  link
                  fedilink
                  arrow-up
                  1
                  ·
                  2 days ago

                  then I’m running proton on different versions of libraries than the ones it was compiled for and tested on. Proton also has additional components which might mean additional dependencies

                  We are slowly getting to the end of my depth in Wine. But in all the years of watching various Wine bugs and enhancements, I have never seen something blocked by the version of library or because some OS does not have, for example, current standard library updated. Kernel version, sure, but that’s much less a compatibility problem. Hence, as long as Wine compiled and is available on your system, from the game perspective, the only libs you have to worry about are Windows DLLs or Wine built-ins of those

                  The fork is open source. As far as I know, some contributions do get merged into wine. Valve is also funding work from Collabora which is contributed directly into wine

                  For now. I’m sure they would love to get into the position that console companies and Microsoft with its DirectX had. “You want to ensure your game works on the new gen? Here’s the paywalled support for our closed-source thing”.
                  If they haven’t started already, I expect them to come up with their own, closed sourced implementation in a few years/when they gain enough market

                  Thinking that Valve are more likely to remove containerization than they are to allow you to modify the container is, frankly, delusional

                  Boycotting their containerization might be doable. Forcing them to make their containerization configurable much less so

        • INeedMana@lemmy.world
          link
          fedilink
          arrow-up
          1
          ·
          4 days ago

          It’s a real hassle for running headtracking. And once they take away the possibility to run xterm instead, we won’t even be able to take a look inside

          I’ll take a look at protonhax, thanks. But I’m afraid that will still require to run opentrack twice

      • teawrecks@sopuli.xyz
        link
        fedilink
        arrow-up
        2
        ·
        4 days ago

        Does it? What containerization does it use? I thought it was similar to wine, just a process pointed at a windows exe, and an environment to make the app think it’s running in a windows filesystem.

        • patatahooligan@lemmy.world
          link
          fedilink
          arrow-up
          6
          ·
          edit-2
          4 days ago

          It’s a custom solution called pressure-vessel, which seems to be based on flatpak. You can read about it here. This is used to create a reproducible linux environment and has nothing to do with the windows translation layer. They run wine (proton) inside the container as you would expect.

          There is a recent effort to port this solution outside of steam in the form of umu. As far as I know it’s in a working state but I don’t know if it’s at feature parity with steam, especially on the game-specific fixes front. The end goal is to be a universal launcher that can be used from all frontends, so that all windows games run reliably and identically regardless of which GUI you use to manage your games.

          EDIT: welp, I just now noticed this info has already been posted by another user 🤷

        • INeedMana@lemmy.world
          link
          fedilink
          arrow-up
          1
          ·
          4 days ago

          Something internal. In order to run a third party app with access to the process (like headtracking), the only way I’ve found out to achieve that was to download a windows version of opentrack too and run it twice. One on Linux side, one inside the container and make them talk to each other via UDP

  • Flax@feddit.uk
    link
    fedilink
    English
    arrow-up
    25
    arrow-down
    4
    ·
    4 days ago

    Thought this was a satire until I realised that Wine is a linux application

    • blind3rdeye@lemm.ee
      link
      fedilink
      arrow-up
      2
      ·
      edit-2
      4 days ago

      What is Wine anyway? All I can work out is that it definitely is not an emulator… (probably it’s a fermented drink made from grapes, but implemented in Linux.)

      • herrvogel@lemmy.world
        link
        fedilink
        arrow-up
        5
        ·
        4 days ago

        It’s a translator. Takes commands that are meant for windows to understand, and translates them into something Linux can work with. If the program requires the services of the kernel, for instance, it makes its system call as usual but the call gets converted to a command for the Linux kernel. At the end of the day it’s the Linux kernel doing the work that was aimed at the windows kernel, and there is no windows kernel anywhere at all. That’s unlike an emulator where you’d be running the windows kernel inside your Linux environment.

        Wine also creates a windows-looking file structure so that programs can find the stuff they’re looking for where they expect them to be. Like, it creates a “program files” directory somewhere in your filesystem and tells the windows applications to look there if they need to. There’s more to it, but you get the gist I hope.

        In a way, wine extends your Linux environment to support windows stuff. Whereas an emulator would create a new windows environment entirely. The goal is not to trick software into thinking it’s on a windows machine, it’s to make it work on Linux. The difference there is that by making it work on Linux you can make it work together and share resources with the rest of the system instead of remaining isolated in its own emulated environment.

    • 🦄🦄🦄@feddit.org
      link
      fedilink
      arrow-up
      6
      ·
      4 days ago

      Huh I’ve been playing Cyberpunk in wayland all along. Hope you get to play too and that the issue wasn’t something else!

      • Petter1@lemm.ee
        link
        fedilink
        arrow-up
        4
        arrow-down
        1
        ·
        4 days ago

        Maybe it is just too much time since I last played or with proton on wayland, it just takes that bit more power, so that my good ol 980 isn’t handeling it well 🤔

  • penquin@lemm.ee
    link
    fedilink
    arrow-up
    7
    ·
    4 days ago

    By better hidpi support, does this mean that those “windows” specific windows that launch sometimes when I do things wine related will actually have a normal size on my 4k monitor instead of being microscopic?