• FizzyOrange@programming.dev
    link
    fedilink
    arrow-up
    17
    ·
    2 months ago

    Ask the Rust maintainers to fix it presumably? The antagonist in the video above claimed there are 50 filesystems in Linux. Do they really fix all 50 filesystems themselves when they change the semantics of the filesystem API? I would be very surprised. I suspect what actually happens currently is either

    1. They actually don’t change the semantics very often at all. It should surely be stable by now?
    2. They change the semantics and silently break a load of niche filesystems.

    I mean, the best answer is “just learn Rust”. If you are incapable of learning Rust you shouldn’t be writing filesystems in C, because that is way harder. And if you don’t want to learn Rust because you can’t be bothered to keep up with the state of the art then you should probably find a different hobby.

    These “ooo they’re trying to force us to learn Rust” people are like my mum complaining you have to do everything online these days “they’re going to take away our cheque books!” 🙄

    • soulsource@discuss.tchncs.de
      link
      fedilink
      arrow-up
      5
      ·
      2 months ago

      I would be very surprised if they wouldn’t fix all 50 filesystems.

      In all projects I have worked on (which does not include the Linux kernel) submitting a merge request with changes that don’t compile is an absolute no-go. What happens there is, that the CI pipeline runs, fails, and instead of a code review the person submitting the MR gets a note that their CI run failed, and they should fix it before re-opening the MR.

      • FizzyOrange@programming.dev
        link
        fedilink
        arrow-up
        7
        ·
        2 months ago

        submitting a merge request with changes that don’t compile is an absolute no-go.

        Right but unless the tests for all 50 filesystems are excellent (I’d be surprised; does Linux even have a CI system?) then the fact that you’ve broken some of them isn’t going to cause a compile error. That’s what the linked presentation was about! Rust encodes more semantic information into the type system so it can detect breakages at compile time. With C you’re relying entirely on tests.

    • Corbin@programming.dev
      link
      fedilink
      English
      arrow-up
      3
      ·
      2 months ago

      At some point, reading kernel code is easier than speculating. The answer is actually 3. there are multiple semantics for filesystems in the VFS layer of the kernel. For example, XFS is the most prominent user of the “async” semantics; all transactions in XFS are fundamentally asynchronous. By comparison, something like ext4 uses the “standard” semantics, where actions are synchronous. These correspond to filling out different parts of the VFS structs and registering different handlers for different actions; they might as well be two distinct APIs. It is generally suspected that all filesystem semantics are broken in different ways.

      Also, “hobby” is the wrong word; the lieutenant doing the yelling is paid to work on Linux and Debian. There are financial aspects to the situation; it’s not solely politics or machismo, although those are both on display.

      • FizzyOrange@programming.dev
        link
        fedilink
        arrow-up
        3
        ·
        2 months ago

        Well that just sounds insane. Isn’t the whole point of an abstracted API that you can write code for it once and it works with all of the implementations?