summaryrefslogtreecommitdiff
path: root/led
diff options
context:
space:
mode:
Diffstat (limited to 'led')
-rw-r--r--led/ws2801/README26
-rw-r--r--led/ws281x/README15
2 files changed, 22 insertions, 19 deletions
diff --git a/led/ws2801/README b/led/ws2801/README
index c8385d8..4c87282 100644
--- a/led/ws2801/README
+++ b/led/ws2801/README
@@ -2,39 +2,40 @@
WS2801 LED strip
-------------------------------------------------------------------------------
-This is a capture of data output an LED universes of 50 RGB LEDS.
+This is a capture of data output to a LED universe of 50 RGB LEDs.
-Every universe at full capacity of has a frame size of 768 bytes and can clock
+Every universe at full capacity has a frame size of 768 bytes and can clock
out at roughly 100 frames per second.
Details:
- Koen Kooi's evil vendor tree: https://github.com/koenkooi/kernel
- - PRU WS2801 firmware: https://github.com/mranostay/ws28xx-lighting-pru
+ - PRU WS28xx firmware: https://github.com/mranostay/ws28xx-lighting-pru
- WS2801 datasheet: http://www.adafruit.com/datasheets/WS2801.pdf
-WS2812B protocol overview
--------------------------
+WS2801 protocol overview
+------------------------
-Each LED receives and the stores the first 24-bits of RGB ordered data then
+Each LED receives and then stores the first 24-bits of RGB ordered data then
passes any more out the Data Output pin to the next LED in the chain.
-There is no CS line but latching is done when CLK is held low for >500 uS
+There is no CS line but latching is done when CLK is held low for >500 uS.
-This functions as a "reverse" shift register and allows the strip length not to
-be defined in the protocol.
+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)
+The logic analyzer used was a Saleae Logic16 (at 5MHz):
- Probe WS2812B LED strip
- -------------------------
+ Probe WS2801 LED strip
+ ----------------------------
1 (black) Universe #1
2 (brown) Clock
+
Data
----
@@ -44,3 +45,4 @@ The sigrok command line used was:
sigrok-cli --driver saleae-logic16 --samples 10M --config samplerate=5mhz \
-p 0=UNI1,1=CLK -o ws2801_2ch_5mhz.sr
+
diff --git a/led/ws281x/README b/led/ws281x/README
index 392acaa..b933a8e 100644
--- a/led/ws281x/README
+++ b/led/ws281x/README
@@ -8,31 +8,31 @@ 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
+ - PRU WS28xx 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.
+All values have a +/- tolerance of 150 nanoseconds so the PRU firmware uses
+the slightly different timing values 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
+Each LED receives and then 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.
+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).
+The logic analyzer used was a Saleae Logic16 (at 5MHz):
Probe WS2812B LED strip
-----------------------------
@@ -51,3 +51,4 @@ 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
+