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

      I can’t claim full understanding, but what I took away from it was that NVIDIA somehow ended up using GPL-licensed code in their proprietary drivers, possibly in a way that could incriminate the Linux kernel if not handled properly. My best guess (as someone with no kernel programming experience) is that NVIDIA sometimes contributes code directly to the Linux kernel that exists solely to support their proprietary drivers (the shims mentioned in the article). Apparently, these shims were exporting GPL-licensed code for use inside the proprietary drivers, which would be a violation of the GPL (unless NVIDIA made the source code for their proprietary drivers freely available in compliance with the GPL).

      TLDR: (I think?) NVIDIA essentially infected the linux kernel with license violations to support their proprietary drivers, and the linux kernel devs are working to excise the violations and prevent anything like that going forward.

    • dan_linder@lemmy.world
      link
      fedilink
      English
      arrow-up
      24
      ·
      1 year ago

      I’m not an expert but this is what I understand from a podcast l listened to (https://twit.tv/shows/untitled-linux-show):

      There’s a subset of Linux users who desire or need GPL compliant environments for they purposes (personal or work related).

      There’s a kernel flag that is set to track if the drivers or gas loaded are also 100% GPL.

      NVidia wrote their own video driver which is NOT GPL compliant, so as soon as they are loaded the kennel flag is set to “not GPL”. To get around the simple checks for GPL compliant drivers, NVidia wrote a wrapper (a “condom”) to lie that it was GPL-compliant when it was violating the GPL flag meaning.

      The Linux 6.6 release apparently has more protections to keep NVidia from working around the GPL check. (For now…)

    • IHeartBadCode@kbin.social
      link
      fedilink
      arrow-up
      23
      ·
      1 year ago

      Tainted kernels are not supported. Kernel devs aren’t spending time to fix bugs that come from a taint (uses blobs of code that are not open sourced) driver. Because the closed drivers can wreck all kinds of havoc and the kernel devs are helpless to fix the actual “source” of the problem.

      There’s been all kinds of ways for the kernel to detect tainted binaries. nVidia is notorious for trying to circumvent that detection so that engineers can sit there and blame the kernel for failures.

      nVidia has been a massively shit company to the open source community. If I had a list of most anti FOSS companies to ever exist, nVidia would be right behind SCO, with like TiVo behind nVidia. I know it’s hard but people who enjoy open source projects shouldn’t do business with the company. But if you got to have a nVidia card so be it, but I cannot NOT recommend nVidia enough.

      • JATtho@sopuli.xyz
        link
        fedilink
        English
        arrow-up
        1
        ·
        edit-2
        1 year ago

        I almost posted comment about this but I had to keep it short. The Nvidia has an problem with their driver tainting the customers kernel/system which renders the customer in bad situation. (Of not being able to get support from kernel devs)

        The proprietary taint is there for exactly for this reason:

        • You load an proprietary module and all bets are off.
        • For starters, you cannot tell there isn’t a backdoor engineered into it.
        • Even if the module behaves well, you now cannot debug the rest of the system any more, because all trust is gone.
        • You cannot (at least easily) audit such system.

        Nvidia solution to this is breaking the kernel license terms and acting like illegal smugglers in-order to access those sweet sweet GPL-only kernel APIs as lazily as possible. I would say that this is just arrogant and greedy way of doing software development. On top of this the kernel devs get all the blame for their vigilantly of trying to exercise their own license terms.

        I think if nvidia would not be this arrogant and vile to the kernel devs, they would already have an proper kernel module that could co-exist between the GPL and proprietary code. If the proprietary code is implemented only in user-space/firmware they can keep their secrets: The user-space <-> kernel-space is an boundary where kernel GPL ends. Implementing such thing would not be easy, but I don’t regard it being impossible: look at android.

        In extreme: If the hostility continues, kernel devs just might be forced to go invent an corporate blacklist that goes against all principles of co-operation.

        Others slightly more sane hw vendors, probably thought: fuck it. It is more profitable to push some FOSS code into the public than keeping the entire thing an trade secret. (I assume this results in the weirdly large firmware blobs that obfuscate and separate the actual hardware from the FOSS drivers)

        EDIT: I read more about this issue. From proprietary code vendors viewpoint the current kernel is kind of “GPL or gtfo” situation. Linux kernel doesn’t really have an internal stable ABI for modules/drivers. Implementing such thing would require (partly) dropping the monolithic design of the Linux kernel… Such interface would be then able to added to the GPL exemption of syscall users. This would open such big can of worms that it looks to be impossible.

    • ono@lemmy.caOP
      link
      fedilink
      English
      arrow-up
      13
      ·
      1 year ago

      Disclaimer: I haven’t looked at the code.

      It looks like Nvidia’s proprietary driver was caught circumventing measures that keep proprietary code from mixing with GPL code in the kernel, deliberately violating the kernel’s license. The kernel maintainers are responding by adding more restrictions.

    • ono@lemmy.caOP
      link
      fedilink
      English
      arrow-up
      34
      ·
      edit-2
      1 year ago

      No, it’s the same reason as always: Nvidia stubbornly refusing to play by the rules, cooperate with the maintainers, respect other people’s software licenses, or let you know how to communicate with the hardware you bought. It’s part of why I stopped giving them money.

        • j4k3@lemmy.world
          link
          fedilink
          English
          arrow-up
          12
          ·
          1 year ago

          You mean that stalkerware that removed out your privacy for profit? Yeah good luck with that shit. There are far reaching implications for this stupid nonsense with Nvidia. The stuff it really screws with is outside of the kernel and what makes it easy for most people to use Linux. Without it, the intellectual barrier for real freedom becomes much harder. If you’re into the new digital age of medieval feudalism, whatever, that is your choice. I prefer to avoid stepping back 1000 years of sociopolitical progression.

          This is about ownership. If you didn’t 100% own what you pay for, you are a serf and a slave in all but name. No serf wanted feudalism, they were just too stupid to see what they lost when they lost it and do something about it while they had the chance. It won’t impact you much, but your grandchildren will despise you for these choices and your failure to value freedom and ownership. They are what you are really sacrificing to ignorance

            • MentalEdge@sopuli.xyz
              link
              fedilink
              English
              arrow-up
              4
              ·
              1 year ago

              So as long as they use plenty of lube, and do it while you sleep, you don’t mind it in the ass?

              NVIDIA engages in some truly atrocious business practices, that they also produce really powerful GPUs, keep their software working (when it benefits them), and develop exciting new technology, excuses none of it.

                • MentalEdge@sopuli.xyz
                  link
                  fedilink
                  English
                  arrow-up
                  4
                  ·
                  edit-2
                  1 year ago

                  I’m implying nothing. I’m straight up stating that all of that good stuff, still leaves the fact that nvidia is actively fucking every other participant in the industry. Including the customer.

                  Windows is just about the only thing they aren’t actively screwing with, because god forbid their biggest customer base had to deal with bugs. They might wake up and take a closer look at their BS.

                  They are pricing out their board partners to the point EVGA said fuck it, were done. They are gouging their “budget” tier cards so hard they wont sell, and are too stubborn to course correct because they got used to that cryptobro money. They tried to buy ARM after being shunned by the mobile industry because tegra chips were a fucking mess to integrate. They lock basic features like nvfbc behind driver-side software locks so they only work with GFE.

                  Literally every business partner nvidia has ever had, hates them. The only reason the industry at large isn’t even more hostile to them, is out of fear. Apple has straight up sworn off ever working with nvidia again.

                  And you think Linux is the problem?

        • squiblet@kbin.social
          link
          fedilink
          arrow-up
          12
          arrow-down
          1
          ·
          1 year ago

          Well no shit, this is about the GPL software license that Linux uses, and obviously Windows does not