You can not select more than 25 topics Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.

107 lines
2.9 KiB

  1. #include "matrix.h"
  2. #include "debounce.h"
  3. #include "print.h"
  4. #include "debug.h"
  5. /* matrix state(1:on, 0:off) */
  6. matrix_row_t raw_matrix[MATRIX_ROWS];
  7. matrix_row_t matrix[MATRIX_ROWS];
  8. #ifdef MATRIX_MASKED
  9. extern const matrix_row_t matrix_mask[];
  10. #endif
  11. // user-defined overridable functions
  12. __attribute__((weak)) void matrix_init_kb(void) { matrix_init_user(); }
  13. __attribute__((weak)) void matrix_scan_kb(void) { matrix_scan_user(); }
  14. __attribute__((weak)) void matrix_init_user(void) {}
  15. __attribute__((weak)) void matrix_scan_user(void) {}
  16. // helper functions
  17. inline uint8_t matrix_rows(void) { return MATRIX_ROWS; }
  18. inline uint8_t matrix_cols(void) { return MATRIX_COLS; }
  19. inline bool matrix_is_on(uint8_t row, uint8_t col) { return (matrix[row] & ((matrix_row_t)1 << col)); }
  20. inline matrix_row_t matrix_get_row(uint8_t row) {
  21. // Matrix mask lets you disable switches in the returned matrix data. For example, if you have a
  22. // switch blocker installed and the switch is always pressed.
  23. #ifdef MATRIX_MASKED
  24. return matrix[row] & matrix_mask[row];
  25. #else
  26. return matrix[row];
  27. #endif
  28. }
  29. // Deprecated.
  30. bool matrix_is_modified(void) {
  31. if (debounce_active()) return false;
  32. return true;
  33. }
  34. #if (MATRIX_COLS <= 8)
  35. # define print_matrix_header() print("\nr/c 01234567\n")
  36. # define print_matrix_row(row) print_bin_reverse8(matrix_get_row(row))
  37. # define matrix_bitpop(row) bitpop(matrix_get_row(row))
  38. #elif (MATRIX_COLS <= 16)
  39. # define print_matrix_header() print("\nr/c 0123456789ABCDEF\n")
  40. # define print_matrix_row(row) print_bin_reverse16(matrix_get_row(row))
  41. # define matrix_bitpop(row) bitpop16(matrix_get_row(row))
  42. #elif (MATRIX_COLS <= 32)
  43. # define print_matrix_header() print("\nr/c 0123456789ABCDEF0123456789ABCDEF\n")
  44. # define print_matrix_row(row) print_bin_reverse32(matrix_get_row(row))
  45. # define matrix_bitpop(row) bitpop32(matrix_get_row(row))
  46. #endif
  47. void matrix_print(void) {
  48. print_matrix_header();
  49. for (uint8_t row = 0; row < MATRIX_ROWS; row++) {
  50. phex(row);
  51. print(": ");
  52. print_matrix_row(row);
  53. print("\n");
  54. }
  55. }
  56. uint8_t matrix_key_count(void) {
  57. uint8_t count = 0;
  58. for (uint8_t i = 0; i < MATRIX_ROWS; i++) {
  59. count += matrix_bitpop(i);
  60. }
  61. return count;
  62. }
  63. // CUSTOM MATRIX 'LITE'
  64. __attribute__((weak)) void matrix_init_custom(void) {}
  65. __attribute__((weak)) bool matrix_scan_custom(matrix_row_t current_matrix[]) { return true; }
  66. __attribute__((weak)) void matrix_init(void) {
  67. matrix_init_custom();
  68. // initialize matrix state: all keys off
  69. for (uint8_t i = 0; i < MATRIX_ROWS; i++) {
  70. raw_matrix[i] = 0;
  71. matrix[i] = 0;
  72. }
  73. debounce_init(MATRIX_ROWS);
  74. matrix_init_quantum();
  75. }
  76. __attribute__((weak)) uint8_t matrix_scan(void) {
  77. bool changed = matrix_scan_custom(raw_matrix);
  78. debounce(raw_matrix, matrix, MATRIX_ROWS, changed);
  79. matrix_scan_quantum();
  80. return changed;
  81. }