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.

67 points

Here’s the thing, you’re not going to force all of us to learn Rust

That seems like a poor attitude imo.

permalink
report
reply
35 points

A valid point tho. Generally it is difficult to ask everybody to learn a new language.

permalink
report
parent
reply
-3 points

It isn’t unreasonable to ask someone to learn a new language, if they currently only speak Sumeric.

permalink
report
parent
reply
47 points

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.

permalink
report
parent
reply
37 points
*

“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”.

permalink
report
parent
reply
22 points

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.

permalink
report
parent
reply
5 points

It’s not a question of what’s the better option. In reality we have a lot of software that already exists and works, and you can’t replace it all in bulk at the same time. So the question is whether the implementation of Rust makes logistical sense, given the difficulties of maintaining currently existing software while replacing some parts of it.

permalink
report
parent
reply
35 points

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.

permalink
report
parent
reply
24 points

It would be a valid point if he weren’t literally speaking over the people trying to tell him that they’re not demanding he learn Rust: https://youtu.be/WiPp9YEBV0Q?si=b3OB4Y9LU-ffJA4c&t=1548

permalink
report
parent
reply
-8 points

If the linux kernel had any real budget to speak of, they could hire rust experts to maintain the rust code. But the “linux” foundation spends 2% of its budget on Linux, this is the situation you end up with.

Anti Commercial-AI license

permalink
report
parent
reply
21 points
*

I believe that’s incorrect. The reporter who started this rumor either misunderstood the meaning of the chart or was lying through his teeth. I’ll find the original source and share it here later.

Linux Foundation Report.

This is the actual source. If you simply scroll through it, you’ll see they’re investing in many things that move the Linux ecosystem forward. Open standards, open hardware, security in the software stack, providing for latest market needs, keeping an eye on legislation that could affect Linux, staying in touch with important entities in the industry, and so on.

Scroll down near the bottom and you’ll find where the reporter got their information from. It’s an expenditure chart and, sure enough, it says “Linux Kernel Support 2%” Note, however, that it also says:

  • Community Tooling 5%
  • Training and Certifications 7%
  • Project Infrastructure 9%
  • Project Support 64% (!)

Note that it doesn’t say how any of them is further divided. Remember all the things I mentioned earlier? All of that is value for Linux as a whole.

Software projects aren’t just about programming the big thing. Working on a large project will show you this. Could the foundation spend more on Linux? Maybe. But saying they only spend 2% on it is disingenuous.

The reporter doesn’t mention this in his clickbait piece, either because he doesn’t get it in the first place, or more likely because he just wants to push his views.

This is yet another example why Lunduke isn’t a credible source of news.

permalink
report
parent
reply
25 points

Oh jeeze, you have no idea. You can watch it yourself: https://youtu.be/WiPp9YEBV0Q?si=b3OB4Y9LU-ffJA4c&t=1548

That timestamp is about where the audience member (a maintainer of ext4 and related utilities) starts speaking. The “here’s the thing” quote is around 28:40.

permalink
report
parent
reply
19 points

Wow what an absolute dick

permalink
report
parent
reply
-9 points

That seems like a poor attitude imo.

Why do you believe that forcing something onto everyone around you is justifiable? I mean, if what you’re pushing is half as good as what you’re claiming it to be, wouldn’t you be seeing people lining up to jump on the bandwagon?

It’s strange how people push tools not based on technical merits and technological traits, but on fads and peer pressure.

permalink
report
parent
reply
14 points
*

It is literally being pushed for its technical merits and traits.

Memory safe code with comparable performance in the kernel seems like an absolute no brainer.

Also if you watch the video all he’s asking for is consistent interfaces for the file systems. He’s not even trying to get them to use rust. And the guy starts screeching about how he’ll code however he wants.

Is it wrong to expect a consistent and well documented interface?

Pretty sure C is actually being pushed against its technical merits here.

permalink
report
parent
reply
-10 points
*

It’s wrong to force it. Most choices in history don’t end up with the best one being used. Beta was better than VHS for example. Rust people are very bad at convincing others to try it, and objectively many people just don’t want to or don’t like it for various reasons.

Personally I highly dislike the syntax. People like familiar things, and to me it’s just too different from C++.

If anything I think Swift will be an easier sell when the speed and cross-platform issues are solved.

permalink
report
parent
reply
6 points

I mean aren’t they forcing everyone else to learn C/C++ otherwise? If we follow that logic, at least

permalink
report
parent
reply
4 points

I guess you can argue it’s already written in C. So that was always a requirement.

permalink
report
parent
reply
3 points

That way we’ll just find maintainers went near extinct over time, just like COBOL developers that are as rare as they are expensive. Only Linux kernel isn’t a bank, and maybe will not have as much money to pay to rare developers capable of maintaining C codebase

permalink
report
parent
reply
1 point

Yeah, I know, but I meant that that technically forces C on everyone.

permalink
report
parent
reply
4 points

If the target for the firmware has stdlib already implemented, my experience has been that it is indeed easy with minimal experience in the language.

permalink
report
reply
32 points

Mixing “firmware” with “easy with minimal experience” in the same sentence makes me cringe…

permalink
report
parent
reply
13 points

That’s fair. To be clear, I meant minimal experience with the Rust programming language. I’ve mainly tinkered with ESP32 types of MCUs in Arduino and CircuitPython when it comes to firmware, but have much more software experience. In some ways, I found the little bit of Rust that I tried easier because of the tooling - defaulting to a CLI tool to flash rather than an IDE is much more comfortable for me.

permalink
report
parent
reply
0 points

I’ve been meaning to play with rust, and I’ve always enjoyed tinkering with various MCUs… Although I’m not very strong with firmware/embedded programming.

Do you think programming an ESP32 is a good project for learning rust?
Any suggested place to start? (Tutorials, YouTube Vida etc)

permalink
report
parent
reply
3 points

Meh, it’s depends on what you do. I know several low level C engineers who would be far more comfortable rolling a fresh driver over doing some more abstract intro CS projects.

permalink
report
parent
reply
70 points

One of the deep-pocketed founding members of the Rust Foundation says it’s easy. I’m surprised.

permalink
report
reply
-2 points

Your mom is easy… said the deep-pocketed founding member of the Rust Foundation.

permalink
report
parent
reply
14 points

Clearly Rust is a conspiracy.

permalink
report
parent
reply
6 points

Clearly Rust is a conspiracy.

Anyone in software development who was not born yesterday is already well aware of the whole FOMO cycle:

  1. hey there’s a shiny new tool,
  2. it’s so fantastic only morons don’t use it,
  3. oh god what a huge mistake I did,
  4. hey, there’s a shiny new tool,
permalink
report
parent
reply
10 points

I assume that you do know that tools improve objectively in the cycle and are making a joke on purpose.

permalink
report
parent
reply
2 points

Yeah, because the new tools are never actually better, right? If condescending luddites like you had your way we’d still be living in the literal stone age. At every step of the way, people like you have smugly said that the older, more established ways of doing things were good enough and new ways were just a fad that would die out.

Your favorite language was dismissed as fad when it was new. High level languages were a fad. Computing was a fad. Electricity was a fad. See a pattern?

Nice job projecting with the “only morons” bit, BTW, when it is in fact you who started off by denigrating people whose preferences are different from yours.

permalink
report
parent
reply

The ruinous powers are plotting once more

permalink
report
parent
reply
21 points

Wut? They’re a member, because they find Rust useful. This is just them saying another time that they find Rust useful.
While they (and everyone using Rust) will benefit off of more people using Rust, it’s not like they have a vested interest to the point of spreading misinformation.

permalink
report
parent
reply
11 points

They’re a member, because they find Rust useful. This is just them saying another time that they find Rust useful.

Fans of a programming language stating they like the programming language is hardly thought-provoking stuff. There are also apps written in brainfuck and that means nothing as well.

permalink
report
parent
reply
5 points

I’m pretty sure that’s not how dyslexia works, but either way, I didn’t write that. And while the title of the article suggests otherwise, the news here isn’t that Google says something is easy. The news is that they published a guide to make that thing easy.

permalink
report
parent
reply
-1 points

You probably can’t run rust without some proprietary Google shit lock - in code.

permalink
report
parent
reply
10 points

They need to tell that to Theodore Ts’o.

permalink
report
reply
46 points
*

2024: Google says replacing C/C++ with Rust is easy

2025: Google buys Rust

2026: Google shuts down Rust

permalink
report
reply
8 points
*

😆🙄🤔Wait, Isn’t rust a community made project?

permalink
report
parent
reply
18 points

It is. Do not worry

permalink
report
parent
reply
2 points

<@:^)

permalink
report
parent
reply
3 points

2028: Rust 2

permalink
report
parent
reply

Programming

!programming@programming.dev

Create post

Welcome to the main community in programming.dev! Feel free to post anything relating to programming here!

Cross posting is strongly encouraged in the instance. If you feel your post or another person’s post makes sense in another community cross post into it.

Hope you enjoy the instance!

Rules

Rules

  • Follow the programming.dev instance rules
  • Keep content related to programming in some way
  • If you’re posting long videos try to add in some form of tldr for those who don’t want to watch videos

Wormhole

Follow the wormhole through a path of communities !webdev@programming.dev



Community stats

  • 3K

    Monthly active users

  • 1.7K

    Posts

  • 28K

    Comments