logo

qmk_firmware

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

launch_1.c (8412B)


  1. /*
  2. * Copyright (C) 2021 System76
  3. *
  4. * This program is free software: you can redistribute it and/or modify
  5. * it under the terms of the GNU General Public License as published by
  6. * the Free Software Foundation, either version 3 of the License, or
  7. * (at your option) any later version.
  8. *
  9. * This program is distributed in the hope that it will be useful,
  10. * but WITHOUT ANY WARRANTY; without even the implied warranty of
  11. * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
  12. * GNU General Public License for more details.
  13. *
  14. * You should have received a copy of the GNU General Public License
  15. * along with this program. If not, see <https://www.gnu.org/licenses/>.
  16. */
  17. #include "quantum.h"
  18. #include "eeprom.h"
  19. #include "usb_mux.h"
  20. // clang-format off
  21. #ifdef RGB_MATRIX_ENABLE
  22. // LEDs by index
  23. // 0 1 2 3 4 5 6 7 8 9
  24. // 00 LM4 LL4 LK4 LJ4 LI4 LH4 LG4 LF4 LE4 LD4
  25. // 10 LC4 LB4 LA4 LA5 LB5 LC5 LD5 LE5 LG5 LH5
  26. // 20 LI5 LJ5 LK5 LL5 LM5 LO3 LM3 LL3 LK3 LJ3
  27. // 30 LI3 LH3 LG3 LF3 LE3 LD3 LC3 LB3 LA3 LA2
  28. // 40 LB2 LC2 LD2 LE2 LF2 LG2 LH2 LI2 LJ2 LK2
  29. // 50 LL2 LM2 LN2 LO2 LO1 LN1 LM1 LL1 LK1 LJ1
  30. // 60 LI1 LH1 LG1 LF1 LE1 LD1 LC1 LB1 LA1 LA0
  31. // 70 LB0 LC0 LD0 LE0 LF0 LG0 LH0 LI0 LJ0 LK0
  32. // 80 LL0 LM0 LN0 LO0
  33. led_config_t g_led_config = { {
  34. // Key matrix to LED index
  35. /* A B C D E F G H I J K L M N O */
  36. /* 0 69, 70, 71, 72, 73, 74, 75, 76, 77, 78, 79, 80, 81, 82, 83, */
  37. /* 1 68, 67, 66, 65, 64, 63, 62, 61, 60, 59, 58, 57, 56, 55, 54, */
  38. /* 2 39, 40, 41, 42, 43, 44, 45, 46, 47, 48, 49, 50, 51, 52, 53, */
  39. /* 3 38, 37, 36, 35, 34, 33, 32, 31, 30, 29, 28, 27, 26, 25, */
  40. /* 4 12, 11, 10, 9, 8, 7, 6, 5, 4, 3, 2, 1, 0, */
  41. /* 5 13, 14, 15, 16, 17, 18, 19, 20, 21, 22, 23, 24 */
  42. { 69, 70, 71, 72, 73, 74, 75, 76, 77, 78, 79, 80, 81, 82 },
  43. { 68, 67, 66, 65, 64, 63, 62, 61, 60, 59, 58, 57, 56, 55 },
  44. { 39, 40, 41, 42, 43, 44, 45, 46, 47, 48, 49, 50, 51, 52 },
  45. { 38, 37, 36, 35, 34, 33, 32, 31, 30, 29, 28, 27, 26, 83 },
  46. { 12, 11, 10, 9, 8, 7, 6, 5, 4, 3, 2, 1, 0, 54 },
  47. { 13, 14, 15, 16, 17, 25, 18, 19, 20, 21, 22, 23, 24, 53 },
  48. }, {
  49. // LED index to physical position (see leds.sh in `launch' repo)
  50. /* 00 */ {209, 51}, {190, 51}, {171, 51}, {156, 51}, {140, 51}, {125, 51}, {110, 51}, {95, 51}, {80, 51}, {65, 51},
  51. /* 10 */ {49, 51}, {34, 51}, {11, 51}, {8, 64}, {27, 64}, {42, 64}, {57, 64}, {80, 64}, {110, 64}, {133, 64},
  52. /* 20 */ {148, 64}, {167, 64}, {194, 64}, {209, 64}, {224, 64}, {224, 38}, {197, 38}, {178, 38}, {163, 38}, {148, 38},
  53. /* 30 */ {133, 38}, {118, 38}, {103, 38}, {87, 38}, {72, 38}, {57, 38}, {42, 38}, {27, 38}, {8, 38}, {4, 26},
  54. /* 40 */ {23, 26}, {38, 26}, {53, 26}, {68, 26}, {84, 26}, {99, 26}, {114, 26}, {129, 26}, {144, 26}, {159, 26},
  55. /* 50 */ {175, 26}, {190, 26}, {205, 26}, {224, 26}, {224, 13}, {201, 13}, {182, 13}, {167, 13}, {152, 13}, {137, 13},
  56. /* 60 */ {121, 13}, {106, 13}, {91, 13}, {76, 13}, {61, 13}, {46, 13}, {30, 13}, {15, 13}, {0, 13}, {0, 0},
  57. /* 70 */ {15, 0}, {30, 0}, {46, 0}, {61, 0}, {76, 0}, {91, 0}, {106, 0}, {121, 0}, {137, 0}, {152, 0},
  58. /* 80 */ {167, 0}, {182, 0}, {201, 0}, {224, 0}
  59. }, {
  60. // LED index to flags (set all to LED_FLAG_KEYLIGHT)
  61. /* 0 1 2 3 4 5 6 7 8 9 */
  62. /* 00 */ 4, 4, 4, 4, 4, 4, 4, 4, 4, 4,
  63. /* 10 */ 4, 4, 4, 4, 4, 4, 4, 4, 4, 4,
  64. /* 20 */ 4, 4, 4, 4, 4, 4, 4, 4, 4, 4,
  65. /* 30 */ 4, 4, 4, 4, 4, 4, 4, 4, 4, 4,
  66. /* 40 */ 4, 4, 4, 4, 4, 4, 4, 4, 4, 4,
  67. /* 50 */ 4, 4, 4, 4, 4, 4, 4, 4, 4, 4,
  68. /* 60 */ 4, 4, 4, 4, 4, 4, 4, 4, 4, 4,
  69. /* 70 */ 4, 4, 4, 4, 4, 4, 4, 4, 4, 4,
  70. /* 80 */ 4, 4, 4, 4
  71. } };
  72. #endif // RGB_MATRIX_ENABLE
  73. bool eeprom_is_valid(void) {
  74. return (
  75. eeprom_read_word(((void *)EEPROM_MAGIC_ADDR)) == EEPROM_MAGIC &&
  76. eeprom_read_byte(((void *)EEPROM_VERSION_ADDR)) == EEPROM_VERSION
  77. );
  78. }
  79. // clang-format on
  80. void eeprom_set_valid(bool valid) {
  81. eeprom_update_word(((void *)EEPROM_MAGIC_ADDR), valid ? EEPROM_MAGIC : 0xFFFF);
  82. eeprom_update_byte(((void *)EEPROM_VERSION_ADDR), valid ? EEPROM_VERSION : 0xFF);
  83. }
  84. void bootmagic_lite_reset_eeprom(void) {
  85. // Set the keyboard-specific EEPROM state as invalid
  86. eeprom_set_valid(false);
  87. // Set the TMK/QMK EEPROM state as invalid
  88. eeconfig_disable();
  89. }
  90. // The lite version of TMK's bootmagic based on Wilba.
  91. // 100% less potential for accidentally making the keyboard do stupid things.
  92. void bootmagic_lite(void) {
  93. // Perform multiple scans because debouncing can't be turned off.
  94. matrix_scan();
  95. #if defined(DEBOUNCE) && DEBOUNCE > 0
  96. wait_ms(DEBOUNCE * 2);
  97. #else
  98. wait_ms(30);
  99. #endif
  100. matrix_scan();
  101. // If the configured key (commonly Esc) is held down on power up,
  102. // reset the EEPROM valid state and jump to bootloader.
  103. uint8_t row = 0; // BOOTMAGIC_LITE_ROW;
  104. uint8_t col = 0; // BOOTMAGIC_LITE_COLUMN;
  105. if (matrix_get_row(row) & (1 << col)) {
  106. bootmagic_lite_reset_eeprom();
  107. // Jump to bootloader.
  108. bootloader_jump();
  109. }
  110. }
  111. void system76_ec_rgb_eeprom(bool write);
  112. void system76_ec_rgb_layer(layer_state_t layer_state);
  113. void system76_ec_unlock(void);
  114. bool system76_ec_is_unlocked(void);
  115. rgb_config_t layer_rgb[DYNAMIC_KEYMAP_LAYER_COUNT];
  116. void matrix_init_kb(void) {
  117. usb_mux_init();
  118. bootmagic_lite();
  119. if (!eeprom_is_valid()) {
  120. dynamic_keymap_reset();
  121. dynamic_keymap_macro_reset();
  122. system76_ec_rgb_eeprom(true);
  123. eeprom_set_valid(true);
  124. } else {
  125. system76_ec_rgb_eeprom(false);
  126. }
  127. system76_ec_rgb_layer(layer_state);
  128. matrix_init_user();
  129. }
  130. void housekeeping_task_kb(void) {
  131. usb_mux_event();
  132. }
  133. #define LEVEL(value) (uint8_t)(((uint16_t)value) * ((uint16_t)RGB_MATRIX_MAXIMUM_BRIGHTNESS) / ((uint16_t)255))
  134. // clang-format off
  135. static const uint8_t levels[] = {
  136. LEVEL(48),
  137. LEVEL(72),
  138. LEVEL(96),
  139. LEVEL(144),
  140. LEVEL(192),
  141. LEVEL(255)
  142. };
  143. // clang-format on
  144. static uint8_t toggle_level = RGB_MATRIX_MAXIMUM_BRIGHTNESS;
  145. extern bool input_disabled;
  146. static void set_value_all_layers(uint8_t value) {
  147. if (!system76_ec_is_unlocked()) {
  148. for (int8_t layer = 0; layer < DYNAMIC_KEYMAP_LAYER_COUNT; layer++) {
  149. layer_rgb[layer].hsv.v = value;
  150. }
  151. system76_ec_rgb_layer(layer_state);
  152. }
  153. }
  154. bool process_record_kb(uint16_t keycode, keyrecord_t *record) {
  155. if (input_disabled) {
  156. return false;
  157. }
  158. if (!process_record_user(keycode, record)) {
  159. return false;
  160. }
  161. switch (keycode) {
  162. case QK_BOOT:
  163. if (record->event.pressed) {
  164. system76_ec_unlock();
  165. }
  166. #ifdef SYSTEM76_EC
  167. return false;
  168. #else
  169. return true;
  170. #endif
  171. case QK_RGB_MATRIX_VALUE_DOWN:
  172. if (record->event.pressed) {
  173. uint8_t level = rgb_matrix_config.hsv.v;
  174. for (int i = sizeof(levels) - 1; i >= 0; i--) {
  175. if (levels[i] < level) {
  176. level = levels[i];
  177. break;
  178. }
  179. }
  180. set_value_all_layers(level);
  181. }
  182. return false;
  183. case QK_RGB_MATRIX_VALUE_UP:
  184. if (record->event.pressed) {
  185. uint8_t level = rgb_matrix_config.hsv.v;
  186. for (int i = 0; i < sizeof(levels); i++) {
  187. if (levels[i] > level) {
  188. level = levels[i];
  189. break;
  190. }
  191. }
  192. set_value_all_layers(level);
  193. }
  194. return false;
  195. case QK_RGB_MATRIX_TOGGLE:
  196. if (record->event.pressed) {
  197. uint8_t level = 0;
  198. if (rgb_matrix_config.hsv.v == 0) {
  199. level = toggle_level;
  200. } else {
  201. toggle_level = rgb_matrix_config.hsv.v;
  202. }
  203. set_value_all_layers(level);
  204. }
  205. return false;
  206. }
  207. return true;
  208. }
  209. layer_state_t layer_state_set_kb(layer_state_t layer_state) {
  210. system76_ec_rgb_layer(layer_state);
  211. return layer_state_set_user(layer_state);
  212. }
  213. #ifdef CONSOLE_ENABLE
  214. void keyboard_post_init_kb(void) {
  215. debug_enable = true;
  216. debug_matrix = false;
  217. debug_keyboard = false;
  218. keyboard_post_init_user();
  219. }
  220. #endif // CONSOLE_ENABLE