From 8151708077e865a809f64c20fd323f41b0876f76 Mon Sep 17 00:00:00 2001 From: Matt Ranostay Date: Thu, 26 Dec 2013 16:23:00 -0800 Subject: ws281x: Add WS2812B protocol dump Four universe dump of WS2812B LED strips driving using a AM335x PRU firmware. Signed-off-by: Matt Ranostay --- led/ws281x/README | 53 +++++++++++++++++++++++++++++++++++++++++++++++++++++ 1 file changed, 53 insertions(+) create mode 100644 led/ws281x/README (limited to 'led/ws281x/README') diff --git a/led/ws281x/README b/led/ws281x/README new file mode 100644 index 0000000..392acaa --- /dev/null +++ b/led/ws281x/README @@ -0,0 +1,53 @@ +------------------------------------------------------------------------------- +WS2812B LED strip +------------------------------------------------------------------------------- + +This is a capture of data output to 4 LED universes of 256 RGB LEDs. +Every universe has a frame size of 768 bytes and the dumps are clocked at +roughly 100 frames per second. + +Details: + - Koen Kooi's evil vendor tree: https://github.com/koenkooi/kernel + - PRU WS281x firmware: https://github.com/mranostay/ws28xx-lighting-pru + - WS2812B datasheet: http://www.adafruit.com/datasheets/WS2812.pdf + + +WS2812B protocol overview +------------------------- + +All values have +/- tolerance of 150 nanoseconds so the PRU firmware uses +slightly different timing value below to sync the high/low transitions. + + Logic low -> high 0.40 uS -> low 0.85 uS (1.25 uS) + Logic high -> high 0.80 uS -> low 0.45 uS (1.25 uS) + Latch -> low 50 uS + +Each LED receives and the stores the first 24-bits of GRB ordered data then +passes any more out the Data Output pin to the next LED in the chain. + +This functions as a "reverse" shift register and allows the strip length not to +be defined in the protocol. + + +Logic analyzer setup +-------------------- + +The logic analzyer used was a Saleae Logic16 (at 5MHz). + + Probe WS2812B LED strip + ----------------------------- + 1 (black) Universe #1 + 2 (brown) Universe #2 + 3 (red) Universe #3 + 4 (orange) Universe #4 + + +Data +---- + +The data contains various RGB values and frames. + +The sigrok command line used was: + + sigrok-cli --driver saleae-logic16 --samples 10M --config samplerate=5mhz \ + -p 0=UNI1,1=UNI2,2=UNI3,3=UNI4 -o ws281x_4ch_5mhz.sr -- cgit v1.2.3-70-g09d2