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.

138 lines
4.4 KiB

  1. //#include <stdint.h>
  2. //#include <stdbool.h>
  3. #include <string.h>
  4. #include "hal.h"
  5. #include "timer.h"
  6. #include "wait.h"
  7. #include "print.h"
  8. #include "matrix.h"
  9. #include "debug.h"
  10. /* matrix state(1:on, 0:off) */
  11. static matrix_row_t matrix[MATRIX_ROWS];
  12. static matrix_row_t matrix_debouncing[MATRIX_ROWS];
  13. static bool debouncing = false;
  14. static uint16_t debouncing_time = 0;
  15. void matrix_init(void)
  16. {
  17. debug_matrix = true;
  18. /* Column(sense) */
  19. palSetPadMode(GPIOD, 5, PAL_MODE_INPUT_PULLDOWN);
  20. palSetPadMode(GPIOD, 6, PAL_MODE_INPUT_PULLDOWN);
  21. palSetPadMode(GPIOD, 7, PAL_MODE_INPUT_PULLDOWN);
  22. palSetPadMode(GPIOC, 1, PAL_MODE_INPUT_PULLDOWN);
  23. palSetPadMode(GPIOC, 2, PAL_MODE_INPUT_PULLDOWN);
  24. palSetPadMode(GPIOC, 3, PAL_MODE_INPUT_PULLDOWN);
  25. palSetPadMode(GPIOC, 4, PAL_MODE_INPUT_PULLDOWN);
  26. palSetPadMode(GPIOC, 5, PAL_MODE_INPUT_PULLDOWN);
  27. palSetPadMode(GPIOC, 6, PAL_MODE_INPUT_PULLDOWN);
  28. palSetPadMode(GPIOC, 7, PAL_MODE_INPUT_PULLDOWN);
  29. /* Row(strobe) */
  30. palSetPadMode(GPIOB, 2, PAL_MODE_OUTPUT_PUSHPULL);
  31. palSetPadMode(GPIOB, 3, PAL_MODE_OUTPUT_PUSHPULL);
  32. palSetPadMode(GPIOB, 18, PAL_MODE_OUTPUT_PUSHPULL);
  33. palSetPadMode(GPIOB, 19, PAL_MODE_OUTPUT_PUSHPULL);
  34. palSetPadMode(GPIOC, 0, PAL_MODE_OUTPUT_PUSHPULL);
  35. palSetPadMode(GPIOC, 8, PAL_MODE_OUTPUT_PUSHPULL);
  36. palSetPadMode(GPIOC, 9, PAL_MODE_OUTPUT_PUSHPULL);
  37. palSetPadMode(GPIOD, 0, PAL_MODE_OUTPUT_PUSHPULL);
  38. palSetPadMode(GPIOD, 1, PAL_MODE_OUTPUT_PUSHPULL);
  39. palSetPadMode(GPIOD, 4, PAL_MODE_OUTPUT_PUSHPULL);
  40. memset(matrix, 0, MATRIX_ROWS * sizeof(matrix_row_t));
  41. memset(matrix_debouncing, 0, MATRIX_ROWS * sizeof(matrix_row_t));
  42. matrix_init_quantum();
  43. }
  44. uint8_t matrix_scan(void)
  45. {
  46. for (int row = 0; row < MATRIX_ROWS; row++) {
  47. matrix_row_t data = 0;
  48. // strobe row
  49. switch (row) {
  50. case 0: palSetPad(GPIOB, 2); break;
  51. case 1: palSetPad(GPIOB, 3); break;
  52. case 2: palSetPad(GPIOB, 18); break;
  53. case 3: palSetPad(GPIOB, 19); break;
  54. case 4: palSetPad(GPIOC, 0); break;
  55. case 5: palSetPad(GPIOC, 8); break;
  56. case 6: palSetPad(GPIOC, 9); break;
  57. case 7: palSetPad(GPIOD, 0); break;
  58. case 8: palSetPad(GPIOD, 1); break;
  59. case 9: palSetPad(GPIOD, 4); break;
  60. }
  61. // need wait to settle pin state
  62. // if you wait too short, or have a too high update rate
  63. // the keyboard might freeze, or there might not be enough
  64. // processing power to update the LCD screen properly.
  65. // 20us, or two ticks at 100000Hz seems to be OK
  66. wait_us(20);
  67. // read col data: { PTD5, PTD6, PTD7, PTC1, PTC2, PTC3, PTC4, PTC5, PTC6, PTC7 }
  68. data = ((palReadPort(GPIOC) & 0xFEUL) << 2) |
  69. ((palReadPort(GPIOD) & 0xE0UL) >> 5);
  70. // un-strobe row
  71. switch (row) {
  72. case 0: palClearPad(GPIOB, 2); break;
  73. case 1: palClearPad(GPIOB, 3); break;
  74. case 2: palClearPad(GPIOB, 18); break;
  75. case 3: palClearPad(GPIOB, 19); break;
  76. case 4: palClearPad(GPIOC, 0); break;
  77. case 5: palClearPad(GPIOC, 8); break;
  78. case 6: palClearPad(GPIOC, 9); break;
  79. case 7: palClearPad(GPIOD, 0); break;
  80. case 8: palClearPad(GPIOD, 1); break;
  81. case 9: palClearPad(GPIOD, 4); break;
  82. }
  83. if (matrix_debouncing[row] != data) {
  84. matrix_debouncing[row] = data;
  85. debouncing = true;
  86. debouncing_time = timer_read();
  87. }
  88. }
  89. if (debouncing && timer_elapsed(debouncing_time) > DEBOUNCE) {
  90. for (int row = 0; row < MATRIX_ROWS; row++) {
  91. matrix[row] = matrix_debouncing[row];
  92. }
  93. debouncing = false;
  94. }
  95. matrix_scan_quantum();
  96. return 1;
  97. }
  98. bool matrix_is_on(uint8_t row, uint8_t col)
  99. {
  100. return (matrix[row] & (1 << col));
  101. }
  102. matrix_row_t matrix_get_row(uint8_t row)
  103. {
  104. return matrix[row];
  105. }
  106. void matrix_print(void)
  107. {
  108. xprintf("\nr/c 01234567\n");
  109. for (uint8_t row = 0; row < MATRIX_ROWS; row++) {
  110. xprintf("%02X: ", row);
  111. matrix_row_t data = matrix_get_row(row);
  112. for (int col = 0; col < MATRIX_COLS; col++) {
  113. if (data & (1<<col))
  114. xprintf("1");
  115. else
  116. xprintf("0");
  117. }
  118. xprintf("\n");
  119. }
  120. wait_ms(50);
  121. }