A Starpusher controls 4 x strips of APA102 LEDs (up to 420 LEDs per strip), taking LED information via UDP ethernet packets. We've tested it to run 4 x 420 LED strips at 60FPS with no glitches.
A Starpush comprises a WT32 ETH01 with a custom-designed Starshield. The Starshield has a DIP switch that configures the Static IP address a given Starpusher uses and has headers for 4 LED strips.
See the comments in main/starpusher.c for a codebase guide.
Starshield code is built using the esp-idf toolchain.
- Follow the steps in the Standard Toolchain Setup Guide,
- Activate the esp-idf environment in a terminal (typically
$ get_idf
after following the setup guide, - Build the codebase
$ idf.py build
, - Connect your Starshield PCB to a WT32 ETH01 base board,
- Connect a USB UART to the UART header on the Starshield,
- Flash the Starpusher code onto the WT32 ETH01 by running
$ idf.py -p /dev/ttyUSB0 flash
- Monitor the WT32 ETH01's logs by running
$ idf.py -p /dev/ttyUSB0 monitor
By default, on bootup, an ESP32 uses the value of pin IO12 to determine SPI Flash chip voltage. It has an internal pull-down so defaults to low (3.3V flash chip). If held high during bootup, then ESP32 treats Flash Chip voltage as 1.8V.
On our board we have a pull-up on IO12 since it's used to set the device ID via dip switch. The fix is to blow an eFuse on the ESP32 that fixes Flash chip voltage to 3.3v.
Do the following:
- Set all dip switches on the ON position (this pulls IO12 low so it will actually boot),
- Run the following command to permanently burn the eFuse governing flash voltage so it's forced to 3.3V
$ espefuse.py --do-not-confirm --port /dev/ttyUSBx set_flash_voltage 3.3V
Replacing/dev/ttyUSBx
with the port of your USB tty.
Schematics, gerber, BOM, and pick-and-place data for the Starshield V2 is in the starshield
sub-folder.
The WT32 ETH01 that the Starshield sits sits on can be progammed via a USB UART (all development was done with a DSD TECH SH-U09C5) which has RTS and DTR pins so that ESP-IDF can program the ESP32 without having to manually fiddle with jumpers / manual resets.