No description
Find a file
2022-06-20 14:01:08 +02:00
vhdl fix: work around ghdl#2102 2022-06-20 13:15:22 +02:00
.gitignore Add basic tools and VHDL skeleton 2022-06-03 19:11:07 +02:00
.gitmodules Add ws2812 submodule 2022-06-05 10:21:44 +02:00
arty_a7_35.xdc vhdl: rename clk_sys to sys_clk 2022-06-05 21:36:10 +02:00
gen_liteeth.py Pixel UDP port demo 2022-06-05 16:35:20 +02:00
Makefile chore: clean up makefile, remove unused targets 2022-06-20 13:24:31 +02:00
Makefile.nextpnr fix: suppress ghdl binding warnings during synthesis 2022-06-20 13:16:51 +02:00
Makefile.symbiflow fix(Makefile.symbiflow): fix read_verilog yosys command 2022-06-03 22:18:09 +02:00
README.md fix 2022-06-20 14:01:08 +02:00

WS2812 driver gateware for blinkenwall v3

At 100 FPS, a single strand of WS2812 can only be just over 300 LEDs long:

MAX_LENGTH = (1 / FPS - RESET_TIME) / BIT_TIME / BITS_PER_PIXEL
318 = (1 / 100 - 50e-6) / 1.3e-6 / 24

Because blinkenwall v3 has 64 * 96 = 6144 pixels, driving it at 100 FPS requires at least 6144 / 318 = 20 parallel drivers. For simplicity, the wall is devided into 24 strands of 256 LEDs. Unfortunately, most microcontrollers have at most a couple WS2812-capable interfaces (typically SPI), so this would require coordinating several microcontrollers in parallel. A much more integrated solution is to instantiate as many WS2812 drivers as desired in an FPGA, then point the entire video firehose at the FPGA.

Ethernet communication

The controller accepts UDP packets containing image data on port 61437 ("PIXEL"). Each packet contains color data for one strand of LEDs.

The packet structure is as follows:

00 01 02 03 04 05 06 07 08 09 0a 0b 0c 0d 0e 0f
00 magic (`0x5049_584c`) strand number frame number 0 pixel 1
10 0 pixel 2 0 pixel 3 0 pixel 4 ...