• sugar_in_your_tea@sh.itjust.works
    link
    fedilink
    English
    arrow-up
    7
    ·
    edit-2
    1 year ago

    Two things:

    • I never said Valve built DXVK or even WINE, just that they have a vested interest to ensure it works well on their AMD-based hardware
    • I never mentioned anything about the scheduler or any Linux imtrinsics other than the AMD GPU kernel module

    DirectX -> Vulkan isn’t a direct translation since the APIs aren’t 1:1, so there’s going to be some tuning in how APIs are mapped, and the tuning can differ depending on the GPU driver you’re using.

    It’s the same with processors, you can optimize a compiler to work better on AMD vs Intel or vice versa (look at Intel C++ compiler benchmarks for an example of that), even if they use the exact same set of instructions because the microarchitectures are optimized differently. This is because the way the instruction set gets mapped to the microarchitecture can impact performance significantly (something like 10% is possible, depending on the benchmark).

    GPU drivers are complicated, and there are a lot of areas where the interaction between the driver, software, and system services can be optimized. AMD’s drivers are open source, which helps with those optimization efforts. Then you throw in a big, well-funded, and motivated company like Valve funding development (both through salaries and donations) and you end up with AMD GPUs getting extra attention for things like DXVK.

    So I would expect AMD on Linux to perform better vs NVIDIA on Linux when compared to AMD vs NVIDIA on Windows. As in, the performance difference on Linux vs Windows would be more favorable for AMD cards than NVIDIA ones because AMD on Linux gets more attention than NVIDIA on Linux. I don’t expect the same for compute, since NVIDIA invests heavily in that space on Linux, so it’s not an inherent advantage of the platform (e.g. the scheduler discussion), but a question of where optimization efforts are focused.

    • havokdj@lemmy.world
      link
      fedilink
      English
      arrow-up
      1
      arrow-down
      10
      ·
      1 year ago

      Alright look, I’m not going to argue about who said what because we both know what we said and it is unrelated to the topic at hand.

      The reason the windows amd driver is bad is not due to performance, it is the very same reason why the proprietary driver is bad on Linux, it is horrible reliability.

      There are circumstances where they trade blows and circumstances where they perform similarly. If you really want to compare the two based on OS alone, you need to compare the equivalent drivers which is the proprietary one.

      • sugar_in_your_tea@sh.itjust.works
        link
        fedilink
        English
        arrow-up
        7
        ·
        edit-2
        1 year ago

        We’re already not doing an apples to apples comparison here because we’re comparing WINE+DXVK vs DirectX. Comparing the OS itself isn’t that interesting, at least from an end-user perspective, what is interesting is comparing the typical user experience on both platforms. As in, no tinkering with stuff, just installing in the most obvious way.

        Valve is optimizing for that typical user experience on their Steam Deck, and that translates to the desktop fairly well. They’re not really doing the same on Windows, so it’s interesting to compare devs+manufacturers optimizing stuff on Windows vs the community+Valve optimizing stuff on Linux.

        • havokdj@lemmy.world
          link
          fedilink
          English
          arrow-up
          1
          arrow-down
          7
          ·
          1 year ago

          Why would not comparing the OS itself be interesting? That is literally the foundation of everything you are seeing on the screen.

          You also can’t just compare WINE+DXVK to DirectX, because you can actually use DXVK on windows. If the video title was “directx vs dxvk” then that would be totally fair, but it is not, it is called “windows vs linux”. I’m simply trying to say that the vast majority of games are not going to see a 17% increase in GPU performance, your biggest boost is going to lie with CPU bound games because it is the truth.

          The only time you’ll see a game perform better on a GPU on Linux is when the game has a native version, and even then that only applies if they actively develop that version, many games are not actively developed and are even a few versions behind.

          • sugar_in_your_tea@sh.itjust.works
            link
            fedilink
            English
            arrow-up
            6
            ·
            1 year ago

            Because regular users aren’t going to be changing drivers based on the game, or doing a ton of system-level configuration to get a bit better performance.

            So it should be defaults vs defaults.

            If we want to compare OSes, we should do targeted benchmarks (Phoronix does a ton of those). There are far more interesting ways to compare schedulers than running games, and the same is true for disk performance, GPU overhead, etc.

            you can actually use DXVK on Windows

            How many people actually do that though? I’m guessing not many.

            “Windows vs Linux” is comparing the default experiences on both systems, and that’s interesting for people who are unlikely to change the defaults (i.e. most people).

            The only time you’ll see a game perform better on a GPU on Linux is when the game has a native version

            That’s just not true, as evidenced by this video. If you take the typical setup on Windows vs the typical setup on Linux, it seems you get a 17% average performance uplift on Linux on these games.

            That doesn’t mean Linux is 17% faster than Windows, nor does it mean you should expect games to run 17% better on Linux, it just means Linux is competitive and sometimes faster with the default configuration. And that’s interesting.

            • havokdj@lemmy.world
              link
              fedilink
              English
              arrow-up
              1
              arrow-down
              4
              ·
              1 year ago

              default configuration

              Linux does not have a default configuration, that’s why we have over 600 distros. If you want to have a baseline “default configuration” then fedora would be the way to go, which he has not used.

              Yes, he got a performance uplit by 17% on average in these games, the point he is trying to make is that you can get this in every game on Linux which is what is not true.

              Most of those games are also CPU bound, an area that Linux is going to destroy windows. Once again, I am referring to GPU performance specifically, as that is the general point that OP makes with these posts.

              • Caveman@lemmy.world
                link
                fedilink
                English
                arrow-up
                2
                ·
                1 year ago

                That may be true, but de facto defaults today is Proton experimental on Steam with the a recent Linux kernel. That’s pretty much the same across all distros.

                • sugar_in_your_tea@sh.itjust.works
                  link
                  fedilink
                  English
                  arrow-up
                  2
                  ·
                  1 year ago

                  Yup, the difference between Ubuntu, Fedora, and Arch or whatever isn’t going to be all that big, assuming you’re working with each distribution’s default kernel and running with a Steam’s provider runtime. You might get 1-2% here and there, but that’s pretty much within run to run variance anyway.

                • havokdj@lemmy.world
                  link
                  fedilink
                  English
                  arrow-up
                  1
                  arrow-down
                  1
                  ·
                  edit-2
                  1 year ago

                  That’s not all the factors that play a role in performance in games.

                  For instance, what fork of the kernel are they using? Are they using zram? What graphics driver are they using? Gamescope? Gamemode? All of those things affect performance of a game to varying degrees.

                  Also, Proton experimental is definitely not the default on any system, that would be Proton 8.

              • sugar_in_your_tea@sh.itjust.works
                link
                fedilink
                English
                arrow-up
                2
                ·
                1 year ago

                Sure, but each distro has a default configuration, and distros don’t vary that much in terms of performance with those default configurations for playing games. If there is a consistent performance difference, it’ll likely be something like 1-2%, which should be within run-to-run variance and not really impact the results.

                And if anyone assumes that an average between 10 games represents the difference you’ll see on average for your own games doesn’t understand statistics because 10 games is not enough to be a representative sample, especially since they weren’t even randomly selected to begin with. It’s still an interesting result.

                CPU bound… Linux is going to destroy Windows

                You’re being hyperbolic here.

                The differences, all else being equal, should be pretty small most of the time unless there’s a hardware driver issue (e.g. when Intel’s new p-core vs e-core split came out, Windows had much better support).

                If we’re seeing a huge difference, more is going on than just a “better” scheduler or more efficient kernel or whatever. It’s much more likely Windows is using DirectX and Linux is using DXVK or something. The bigger the gap, the less likely it’s the kernel that’s doing it.

                As someone who has used Linux exclusively for ~15 years, these kinds of benchmarks are certainly exciting. However, we need to be careful to not read too much into them.