Google recently rewrote the firmware for protected virtual machines in its Android Virtualization Framework using the Rust programming language and wants you to do the same, assuming you deal with firmware.

In a write-up on Thursday, Android engineers Ivan Lozano and Dominik Maier dig into the technical details of replacing legacy C and C++ code with Rust.

“You’ll see how easy it is to boost security with drop-in Rust replacements, and we’ll even demonstrate how the Rust toolchain can handle specialized bare-metal targets,” said Lozano and Maier.

Easy is not a term commonly heard with regard to a programming language known for its steep learning curve.

Nor is it easy to get C and C++ developers to see the world with Rust-tinted lenses. Just last week, one of the maintainers of the Rust for Linux project - created to work Rust code into the C-based Linux kernel - stepped down, citing resistance from Linux kernel developers.

“Here’s the thing, you’re not going to force all of us to learn Rust,” said a Linux kernel contributor during a lively discussion earlier this year at a conference.

    • tiredofsametab@fedia.io
      link
      fedilink
      arrow-up
      1
      ·
      11 days ago

      I mean, I work as a software engineering and if I’m not doing continuing ed, be it about architecture, storage, or new languages, I’m going to be of less value in the marketplace. I’ve learnt languages I didn’t particularly want to in the past for work (though I generally came to tolerate or even like some of them. Not lua, though; lua can go to hell).

      If Rust truly is the better, safer option, then these people are holding everything back.

      • wewbull@feddit.uk
        link
        fedilink
        English
        arrow-up
        1
        ·
        edit-2
        11 days ago

        “learn Rust” in this case is learn it to a level where all of the little behaviour around cross language integrations are understood and security flaws won’t be introduced. Expert level.

        It’s not “I did a pet project over the weekend”.

        • tiredofsametab@fedia.io
          link
          fedilink
          arrow-up
          1
          ·
          11 days ago

          You are correct and I am aware of that. However, it also seems that they both refuse to learn it and refuse to work with people at that expert level based on the recent drama, which seems very much like holding things back to me.

          • Strykker@programming.dev
            link
            fedilink
            arrow-up
            0
            ·
            10 days ago

            Sure for newcomers to a project like the Linux kernel they have to learn C , because that is what the project is currently written in, but trying to transition the Linux kernel to rust forces people who already are contributing to go and learn rust to be able to continue what they were already doing. And sure you can argue that it’s being done so not everything has to go over at once, but there is a level of rust knowledge required at the interface between the two languages, and that burden is as far as I’ve seen being forced on those long term contributors.

            It’s not the same thing.

            • arendjr@programming.dev
              link
              fedilink
              arrow-up
              1
              ·
              9 days ago

              and that burden is as far as I’ve seen being forced on those long term contributors.

              This is not what is happening. The current long term contributors were asked to clarify semantics about C APIs, so the Rust maintainers could take it from there. At no point were the C maintainers asked to help maintain the Rust bindings.

      • stupidcasey@lemmy.world
        link
        fedilink
        arrow-up
        0
        ·
        11 days ago

        C/C++ is the bedrock of our modern civilization in some ways more fundamental than actual bedrock, the first step in getting any OS running is making it run C and after that you are basically done, it’s not surprising that developers resist, if nothing else it’s a common language, and standards are hard to change on the best of days. This isn’t just learning a language, it’s a complete paradigm shift.

        • calcopiritus@lemmy.world
          link
          fedilink
          arrow-up
          0
          ·
          10 days ago

          The bedrock of modern civilizations is expensive to develop, buggy and unergonomic though.

          If you make C run, you probably (I’m not sure, would have to verify) can make rust run. And if there isn’t yet, there will probably soon be a C compiler written in rust, so you can choose to bootstrap from wherever you prefer.

          C’s ABI will probably last longer than C, since there is not a stable rust ABI though.

    • theherk@lemmy.world
      link
      fedilink
      arrow-up
      0
      ·
      10 days ago

      Fortunately, they aren’t being asked to do that. All the rust team was requesting was metadata about the call signatures so that they could have a grasp on expected behavior.