An extremely simply Rust runtime for AVR microcontrollers.
AVRoxide was borne out of [my] frustration with attempting to develop for an [Arduino Nano Every] microcontroller board using the Rust programming language.
The Arduino Nano Every uses a different version of AVR microcontroller to the other Arduino family of boards - the [ATmega4809]. While there are HAL[^1] crates available for various Arduino boards, none of them works with this microcontroller, and that's a shame - it's actually a super nice chip and a good upgrade on the ones used in the 'traditional' Arduino boards. So, support for it in Rust would obviously be nice to have.
Naturally, the first thing I tried to do was to adapt some of the existing HALs to work with the Nano Every. But this turned out to be a little trickier than I anticipated, and in any event I discovered there were some things that I didn't like about those HALs. This is in no way a reflection on the quality of thoes HALs - much more a reflection on my Rust abilities - but I found I wanted something a little simpler and easier to understand.
And so, the idea of putting together my own HAL come to mind. But, I also wanted to move a little higher up the pipeline - not just to abstract away the hardware, but also to put in place some standard patterns for things like a standard event loop that would hide some of the details of things like interrupt handling from the application developer.
Thus, AVRoxide is born! The Rusty runtime for AVR microcontrollers.
Getting started guides are at https://avroxi.de/categories/gettingstarted/
This is an extremely early pre-alpha quality crate.
The intention is to expand it beyond the minimal set of devices currently supported, in due course. Until then, it is very much use at your own risk.