Although much of the software that runs on the ESP32 microcontroller is open source, the Wi-Fi driver is not. Instead, it uses a proprietary binary blob. This was no problem for [Jasper Devreker]’s reverse-engineering of the ESP32’s Wi-Fi stack so far until he came face to face with reverse-engineering the initialization of the Wi-Fi peripheral. As it turns out, there is a lot of work involved after you call esp_phy_enable
in the Espressif binary blob, with the team logging 53,286 peripheral accesses during the initialization phase. In comparison, sending a Wi-Fi packet takes about ten calls.
Currently, the way that the initialization step is handled is by having the initialization routine in the binary blob do its thing by configuring the radio and other elements before killing the FreeRTOS task and replacing it with their own version. The team is actively looking for a clean approach for moving forward that will avoid simply writing everything from scratch. For the Wi-Fi MAC, existing code (e.g., FreeBSD’s stack) could be used, but the radio code is much more of a headache. Clearly, there’s still a lot more work to be done in order to get a fully open-source Wi-Fi MAC and stack for the ESP32, but having the community (that’s you) pitch in might speed things up if there’s demand for an open-source driver.
[Jasper’s] been working on this for a while. He’s even built a Faraday cage to make the task easier.
Would really be great to make ESP32 fully open source! Keep on, thanks!
Heads up that this may have ramifications for radio spectrum licensing. Often these blobs are proprietary because of vague certification reasons. Some channels should not be used in various geographies etc. The way I think it works is that the company which sells radio components sell them together with a radio blob and won’t make any guaranteess if you run the hardware with any other software than their own.
Patents might play a role as well.
Author here: this is a programmable Wi-Fi microcontroller; you can already send on channels you’re not supposed to send on using their API.
Nah you can manually adjust local on Linux wifi dongles/computers. Also wifi is in the ism band, hence why end users don’t need licenses to tx ;).
Patents? Licenses? Certification? I’d take the risk if it meant that the WiFi stack didn’t have any baked-in malicious code.
I may be wrong but, I don’t believe people want to change the specs – there would be no point. They just want to know what’s in the code. And if the code is open to scrutiny : it’s verifiable.
It’s an open standard so there’s no competitive advantage to having a proprietary blob.
Author here: I don’t want to change the spec, but the ESP32 does not implement 802.11s standards-compliant mesh networking, and I would like to use that. If there is open-source code, that is possible.
And indeed, security is also a major factor (but there could still be silicon vulnerabilities/backdoors)
Jasper, you are my hero. Anxiously I refresh your blog for many months, hoping on an update.
Your work will liberate so many devices, it will bring joy and happiness. Please keep up the good work!!
look this https://blog.erethon.com/blog/2023/05/19/introduction-to-reticulum/
reticulum
meybe is possible run on this?
The public facing competitive advantage is by taking care of the expensive certification process in global markets costs are decreased for mid/low volume customers buying >5k parts a year.
The internal reason is that no one wants to show you how the sausage gets made.
Now THIS person knows what they are talking about, haha. Glad I’m not alone in having seen behind the curtains, of both sides. Cheers, mate.
Ok but what’s the benefit?