Skip to content

Commit 8d49dd7

Browse files
authored
Merge pull request FastLED#1306 from PaulStoffregen/master
Fix WS2812B timing on Teensy 4.x
2 parents 1d236ab + 0ea8c7c commit 8d49dd7

File tree

3 files changed

+70
-6
lines changed

3 files changed

+70
-6
lines changed

src/platforms/arm/mxrt1062/clockless_arm_mxrt1062.h

+5-5
Original file line numberDiff line numberDiff line change
@@ -56,24 +56,24 @@ class ClocklessController : public CPixelLEDController<RGB_ORDER> {
5656
next_mark = ARM_DWT_CYCCNT + off[0];
5757
FastPin<DATA_PIN>::hi();
5858
if(b&0x80) {
59-
while((next_mark - ARM_DWT_CYCCNT) > off[1]);
59+
while((next_mark - ARM_DWT_CYCCNT) > off[2]);
6060
FastPin<DATA_PIN>::lo();
6161
} else {
62-
while((next_mark - ARM_DWT_CYCCNT) > off[2]);
62+
while((next_mark - ARM_DWT_CYCCNT) > off[1]);
6363
FastPin<DATA_PIN>::lo();
6464
}
6565
b <<= 1;
6666
}
6767

6868
while(ARM_DWT_CYCCNT < next_mark);
69-
next_mark = ARM_DWT_CYCCNT + off[1];
69+
next_mark = ARM_DWT_CYCCNT + off[0];
7070
FastPin<DATA_PIN>::hi();
7171

7272
if(b&0x80) {
7373
while((next_mark - ARM_DWT_CYCCNT) > off[2]);
7474
FastPin<DATA_PIN>::lo();
7575
} else {
76-
while((next_mark - ARM_DWT_CYCCNT) > off[2]);
76+
while((next_mark - ARM_DWT_CYCCNT) > off[1]);
7777
FastPin<DATA_PIN>::lo();
7878
}
7979
}
@@ -91,7 +91,7 @@ class ClocklessController : public CPixelLEDController<RGB_ORDER> {
9191
off[1] = _FASTLED_NS_TO_DWT(T2+T3);
9292
off[2] = _FASTLED_NS_TO_DWT(T3);
9393

94-
uint32_t wait_off = _FASTLED_NS_TO_DWT((WAIT_TIME-INTERRUPT_THRESHOLD));
94+
uint32_t wait_off = _FASTLED_NS_TO_DWT((WAIT_TIME-INTERRUPT_THRESHOLD)*1000);
9595

9696
uint32_t next_mark = ARM_DWT_CYCCNT + off[0];
9797

src/platforms/arm/mxrt1062/fastled_arm_mxrt1062.h

+1-1
Original file line numberDiff line numberDiff line change
@@ -3,7 +3,7 @@
33

44
#include "fastpin_arm_mxrt1062.h"
55
#include "fastspi_arm_mxrt1062.h"
6-
#include "../k20/octows2811_controller.h"
6+
#include "octows2811_controller.h"
77
#include "../k20/ws2812serial_controller.h"
88
#include "../k20/smartmatrix_t3.h"
99
#include "clockless_arm_mxrt1062.h"
Original file line numberDiff line numberDiff line change
@@ -0,0 +1,64 @@
1+
#ifndef __INC_OCTOWS2811_CONTROLLER_H
2+
#define __INC_OCTOWS2811_CONTROLLER_H
3+
4+
#ifdef USE_OCTOWS2811
5+
6+
// #include "OctoWS2811.h"
7+
8+
FASTLED_NAMESPACE_BEGIN
9+
10+
template<EOrder RGB_ORDER = GRB, uint8_t CHIP = WS2811_800kHz>
11+
class COctoWS2811Controller : public CPixelLEDController<RGB_ORDER, 8, 0xFF> {
12+
OctoWS2811 *pocto;
13+
uint8_t *drawbuffer,*framebuffer;
14+
15+
void _init(int nLeds) {
16+
if(pocto == NULL) {
17+
drawbuffer = (uint8_t*)malloc(nLeds * 8 * 3);
18+
framebuffer = (uint8_t*)malloc(nLeds * 8 * 3);
19+
20+
// byte ordering is handled in show by the pixel controller
21+
int config = WS2811_RGB;
22+
config |= CHIP;
23+
24+
pocto = new OctoWS2811(nLeds, framebuffer, drawbuffer, config);
25+
26+
pocto->begin();
27+
}
28+
}
29+
public:
30+
COctoWS2811Controller() { pocto = NULL; }
31+
virtual int size() { return CLEDController::size() * 8; }
32+
33+
virtual void init() { /* do nothing yet */ }
34+
35+
virtual void showPixels(PixelController<RGB_ORDER, 8, 0xFF> &pixels) {
36+
uint32_t size = pixels.size();
37+
uint32_t sizeTimes8 = 8U * size;
38+
_init(size);
39+
40+
uint32_t index = 0;
41+
while (pixels.has(1)) {
42+
for (uint32_t i = 0; i < 8; i++) {
43+
uint8_t r = pixels.loadAndScale0(i);
44+
uint8_t g = pixels.loadAndScale1(i);
45+
uint8_t b = pixels.loadAndScale2(i);
46+
pocto->setPixel(index, r, g, b);
47+
index += size;
48+
}
49+
index -= sizeTimes8;
50+
index++;
51+
pixels.stepDithering();
52+
pixels.advanceData();
53+
}
54+
55+
pocto->show();
56+
}
57+
58+
};
59+
60+
FASTLED_NAMESPACE_END
61+
62+
#endif
63+
64+
#endif

0 commit comments

Comments
 (0)