logo

qmk_firmware

custom branch of QMK firmware git clone https://anongit.hacktivis.me/git/qmk_firmware.git

ws2812.h (2995B)


  1. /*
  2. * This program is free software: you can redistribute it and/or modify
  3. * it under the terms of the GNU General Public License as published by
  4. * the Free Software Foundation, either version 2 of the License, or
  5. * (at your option) any later version.
  6. *
  7. * This program is distributed in the hope that it will be useful,
  8. * but WITHOUT ANY WARRANTY; without even the implied warranty of
  9. * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
  10. * GNU General Public License for more details.
  11. *
  12. * You should have received a copy of the GNU General Public License
  13. * along with this program. If not, see <http://www.gnu.org/licenses/>.
  14. */
  15. #pragma once
  16. #include "util.h"
  17. /*
  18. * The WS2812 datasheets define T1H 900ns, T0H 350ns, T1L 350ns, T0L 900ns. Hence, by default, these
  19. * are chosen to be conservative and avoid problems rather than for maximum throughput; in the code,
  20. * this is done by default using a WS2812_TIMING parameter that accounts for the whole window (1250ns)
  21. * and defining T1H and T0H; T1L and T0L are obtained by subtracting their low counterparts from the window.
  22. *
  23. * However, there are certain "WS2812"-like LEDs, like the SK6812s, which work in a similar
  24. * communication topology but use different timings for the window and the T1L, T1H, T0L and T0H.
  25. * This means that, albeit the same driver being applicable, the timings must be adapted.
  26. */
  27. #ifndef WS2812_TIMING
  28. # define WS2812_TIMING 1250
  29. #endif
  30. #ifndef WS2812_T1H
  31. # define WS2812_T1H 900 // Width of a 1 bit in ns
  32. #endif
  33. #ifndef WS2812_T1L
  34. # define WS2812_T1L (WS2812_TIMING - WS2812_T1H) // Width of a 1 bit in ns
  35. #endif
  36. #ifndef WS2812_T0H
  37. # define WS2812_T0H 350 // Width of a 0 bit in ns
  38. #endif
  39. #ifndef WS2812_T0L
  40. # define WS2812_T0L (WS2812_TIMING - WS2812_T0H) // Width of a 0 bit in ns
  41. #endif
  42. /*
  43. * Older WS2812s can handle a reset time (TRST) of 50us, but recent
  44. * component revisions require a minimum of 280us.
  45. */
  46. #if !defined(WS2812_TRST_US)
  47. # define WS2812_TRST_US 280
  48. #endif
  49. #if defined(RGBLIGHT_WS2812)
  50. # define WS2812_LED_COUNT RGBLIGHT_LED_COUNT
  51. #elif defined(RGB_MATRIX_WS2812)
  52. # define WS2812_LED_COUNT RGB_MATRIX_LED_COUNT
  53. #endif
  54. #define WS2812_BYTE_ORDER_RGB 0
  55. #define WS2812_BYTE_ORDER_GRB 1
  56. #define WS2812_BYTE_ORDER_BGR 2
  57. #ifndef WS2812_BYTE_ORDER
  58. # define WS2812_BYTE_ORDER WS2812_BYTE_ORDER_GRB
  59. #endif
  60. typedef struct PACKED ws2812_led_t {
  61. #if (WS2812_BYTE_ORDER == WS2812_BYTE_ORDER_GRB)
  62. uint8_t g;
  63. uint8_t r;
  64. uint8_t b;
  65. #elif (WS2812_BYTE_ORDER == WS2812_BYTE_ORDER_RGB)
  66. uint8_t r;
  67. uint8_t g;
  68. uint8_t b;
  69. #elif (WS2812_BYTE_ORDER == WS2812_BYTE_ORDER_BGR)
  70. uint8_t b;
  71. uint8_t g;
  72. uint8_t r;
  73. #endif
  74. #ifdef WS2812_RGBW
  75. uint8_t w;
  76. #endif
  77. } ws2812_led_t;
  78. void ws2812_init(void);
  79. void ws2812_set_color(int index, uint8_t red, uint8_t green, uint8_t blue);
  80. void ws2812_set_color_all(uint8_t red, uint8_t green, uint8_t blue);
  81. void ws2812_flush(void);
  82. void ws2812_rgb_to_rgbw(ws2812_led_t *led);