The 8-bit (MCU) manifesto
Eight-bit microcontrollers aren't relics; they are a design philosophy. You might want to use them more.
Last week, my article about AVR Dx microcontrollers made it to the front page of Hacker News. Many commenters on the site reminisced about the good old days of 8-bit microcontrollers — and then advised others to let go of the past. Instead of clinging on to the AVR architecture, they recommended prototyping with Orange Pi 5 Pro. Or perhaps buying an Adafruit ESP32 board. Worst-case, you should be giving some thought to STM32G0 or CH32V003.
All of these recommendations are right — and all of them are wrong. Oversimplifying a bit, the market for general-purpose embedded processors can be divided into three major segments: 8-bit MCUs, 32-bit MCUs, and systems-on-a-chip (SoC / SBC).
The segmentation isn’t about progressing from the worst to the best. Instead, it goes like this:
8-bit MCUs are designed for process control — that is, taking data from sensors and input surfaces, and then operating small displays, motors, or other output devices according to some straightforward plan. The chips are orders of magnitude faster than their 1980s progenitors, but don’t have a lot of RAM — simply because it’s not needed for the job. Instead, the MCU die is crammed with gadgets useful for instrumentation: op-amps, voltage comparators, top-notch ADCs and DACs, multi-voltage I/O ports, and so on. The category is geared toward low power consumption and a supremely predictable and intuitive real-time operating environment.
Most 32-bit MCUs are designed for memory- and CPU-intensive tasks: processing video or audio streams, high-speed communications, and so on. They might have a decent amount of RAM, a DMA controller, a MIPI interface, network transceivers, hardware crypto, and an FPU. On the flip side, the instrumentation features usually lag behind; on most lower-cost chips, you’d be lucky to get some 5V-tolerant pins. Predictable execution is sacrificed for instruction pipelining, data prefetching, write caching, and so on. All the added complexity also means that something as simple as changing the clock speed on a Cortex-M7 chip can be a small ordeal.
Finally, SoCs are just desktop computers in disguise. They will usually have a high-performance 32-bit or 64-bit processor running at gigahertz speeds, gobs of RAM, an integrated GPU, Bluetooth, and so forth. Their primary niche are multifunction Linux-based devices: smartphones, gaming consoles, or entertainment systems. On the flip side, a SoC is an expensive and clunky way to do process automation or signal processing. There are gotchas that come with having a million lines of code standing between you and that I/O port.
Nothing requires the use of an 8-bit ALU for process automation; it’s just that there are limited benefits to designing a separate “lo-fi” 32-bit platform for process control when comparatively simpler 8-bit architectures work fine. To be fair, there are some barebones 32-bit RISC-V and ARM Cortex-M0 contenders in the ring — but in the end, it’s not necessarily clever to choose more bits. It might help, it might hurt if it pushes you toward the wrong product — but most often, it makes no difference at all.
We could wrap up here, but wi-fi throws a wrench in the works. Most MCUs don’t support it, probably because it’s a complicated and computationally-intensive protocol that could be handled by a companion chip. Enter Espressif: the company came up with a series of wi-fi chipsets that could be interfaced to standard microcontrollers. But they also had an epiphany: if they need all this computing power for wi-fi, they might as well open up some room for user-supplied code — and effectively start selling dirt-cheap 32-bit microcontrollers with wireless connectivity baked in.
Because of this, a lot of internet-enabled process automation and simple compute is done with Espressif chips such as the ESP32 series — even though the basic models are not particularly well-suited for either job. But hey: ideological purity is for suckers, and free wi-fi is a steal.
For a catalog of my articles on programming 8-bit and 32-bit MCUs, click here.
Don't forget USB-PD. Almost all of those interfaces are themselves 8-bit MCUs (usually an 8052 variant), and some of the slightly higher level chips are... full-fledged M0s!
https://flameeyes.blog/2023/08/13/usb-power-delivery-for-hobby-projects/
Also even Espressif has a tiered system by now, ESP32 is the most common hobbyist option, but there's a number of low-power variants that have next to no use...
PIC32MX