diff options
Diffstat (limited to 'drivers/chibios')
-rw-r--r-- | drivers/chibios/ws2812.c | 2 | ||||
-rw-r--r-- | drivers/chibios/ws2812.h | 16 | ||||
-rw-r--r-- | drivers/chibios/ws2812_pwm.c | 7 | ||||
-rw-r--r-- | drivers/chibios/ws2812_spi.c | 2 |
4 files changed, 5 insertions, 22 deletions
diff --git a/drivers/chibios/ws2812.c b/drivers/chibios/ws2812.c index 2c2d9fb2d..5917b7f0e 100644 --- a/drivers/chibios/ws2812.c +++ b/drivers/chibios/ws2812.c | |||
@@ -51,7 +51,7 @@ | |||
51 | 51 | ||
52 | // The reset gap can be 6000 ns, but depending on the LED strip it may have to be increased | 52 | // The reset gap can be 6000 ns, but depending on the LED strip it may have to be increased |
53 | // to values like 600000 ns. If it is too small, the pixels will show nothing most of the time. | 53 | // to values like 600000 ns. If it is too small, the pixels will show nothing most of the time. |
54 | #define RES 10000 // Width of the low gap between bits to cause a frame to latch | 54 | #define RES (1000 * WS2812_TRST_US) // Width of the low gap between bits to cause a frame to latch |
55 | 55 | ||
56 | void sendByte(uint8_t byte) { | 56 | void sendByte(uint8_t byte) { |
57 | // WS2812 protocol wants most significant bits first | 57 | // WS2812 protocol wants most significant bits first |
diff --git a/drivers/chibios/ws2812.h b/drivers/chibios/ws2812.h deleted file mode 100644 index 41c22a00b..000000000 --- a/drivers/chibios/ws2812.h +++ /dev/null | |||
@@ -1,16 +0,0 @@ | |||
1 | #pragma once | ||
2 | |||
3 | #include "quantum/color.h" | ||
4 | |||
5 | /* User Interface | ||
6 | * | ||
7 | * Input: | ||
8 | * ledarray: An array of GRB data describing the LED colors | ||
9 | * number_of_leds: The number of LEDs to write | ||
10 | * | ||
11 | * The functions will perform the following actions: | ||
12 | * - Set the data-out pin as output | ||
13 | * - Send out the LED data | ||
14 | * - Wait 50us to reset the LEDs | ||
15 | */ | ||
16 | void ws2812_setleds(LED_TYPE *ledarray, uint16_t number_of_leds); | ||
diff --git a/drivers/chibios/ws2812_pwm.c b/drivers/chibios/ws2812_pwm.c index ba45d0042..7113db11e 100644 --- a/drivers/chibios/ws2812_pwm.c +++ b/drivers/chibios/ws2812_pwm.c | |||
@@ -53,11 +53,10 @@ | |||
53 | /** | 53 | /** |
54 | * @brief Number of bit-periods to hold the data line low at the end of a frame | 54 | * @brief Number of bit-periods to hold the data line low at the end of a frame |
55 | * | 55 | * |
56 | * The reset period for each frame must be at least 50 uS; so we add in 50 bit-times | 56 | * The reset period for each frame is defined in WS2812_TRST_US. |
57 | * of zeroes at the end. (50 bits)*(1.25 uS/bit) = 62.5 uS, which gives us some | 57 | * Calculate the number of zeroes to add at the end assuming 1.25 uS/bit: |
58 | * slack in the timing requirements | ||
59 | */ | 58 | */ |
60 | #define WS2812_RESET_BIT_N (50) | 59 | #define WS2812_RESET_BIT_N (1000 * WS2812_TRST_US / 1250) |
61 | #define WS2812_COLOR_BIT_N (RGBLED_NUM * 24) /**< Number of data bits */ | 60 | #define WS2812_COLOR_BIT_N (RGBLED_NUM * 24) /**< Number of data bits */ |
62 | #define WS2812_BIT_N (WS2812_COLOR_BIT_N + WS2812_RESET_BIT_N) /**< Total number of bits in a frame */ | 61 | #define WS2812_BIT_N (WS2812_COLOR_BIT_N + WS2812_RESET_BIT_N) /**< Total number of bits in a frame */ |
63 | 62 | ||
diff --git a/drivers/chibios/ws2812_spi.c b/drivers/chibios/ws2812_spi.c index 3bbada7fe..7a1d2f05d 100644 --- a/drivers/chibios/ws2812_spi.c +++ b/drivers/chibios/ws2812_spi.c | |||
@@ -36,7 +36,7 @@ | |||
36 | #define NB_COLORS 3 | 36 | #define NB_COLORS 3 |
37 | #define BYTES_FOR_LED (BYTES_FOR_LED_BYTE * NB_COLORS) | 37 | #define BYTES_FOR_LED (BYTES_FOR_LED_BYTE * NB_COLORS) |
38 | #define DATA_SIZE (BYTES_FOR_LED * RGBLED_NUM) | 38 | #define DATA_SIZE (BYTES_FOR_LED * RGBLED_NUM) |
39 | #define RESET_SIZE 200 | 39 | #define RESET_SIZE (1000 * WS2812_TRST_US / (2 * 1250)) |
40 | #define PREAMBLE_SIZE 4 | 40 | #define PREAMBLE_SIZE 4 |
41 | 41 | ||
42 | static uint8_t txbuf[PREAMBLE_SIZE + DATA_SIZE + RESET_SIZE] = {0}; | 42 | static uint8_t txbuf[PREAMBLE_SIZE + DATA_SIZE + RESET_SIZE] = {0}; |