diff options
author | tmk <nobody@nowhere> | 2012-11-23 12:33:42 +0900 |
---|---|---|
committer | tmk <nobody@nowhere> | 2012-11-23 12:33:42 +0900 |
commit | 6caefe9649d88673719e969502d220c5e9dcd124 (patch) | |
tree | 332455746dd60b60d18f5eec39487f96192fe330 /common/keyboard.c | |
parent | 613fdb24fcdb4f8920f0d344cad5800d343f535c (diff) |
Fixes from Tranquilite@GH.
- Fix keyboard_task() when matrix column size > 16
- Add clear_keyboard() in NKRO command to avoid stucking keys.
- Fix function name in print.c.
Diffstat (limited to 'common/keyboard.c')
-rw-r--r-- | common/keyboard.c | 10 |
1 files changed, 5 insertions, 5 deletions
diff --git a/common/keyboard.c b/common/keyboard.c index fa22116f17..cd1ceb420c 100644 --- a/common/keyboard.c +++ b/common/keyboard.c @@ -564,20 +564,20 @@ void keyboard_task(void) matrix_row_t matrix_change = 0; matrix_scan(); - for (int r = 0; r < MATRIX_ROWS; r++) { + for (uint8_t r = 0; r < MATRIX_ROWS; r++) { matrix_row = matrix_get_row(r); matrix_change = matrix_row ^ matrix_prev[r]; if (matrix_change) { if (debug_matrix) matrix_print(); - for (int c = 0; c < MATRIX_COLS; c++) { - if (matrix_change & (1<<c)) { + for (uint8_t c = 0; c < MATRIX_COLS; c++) { + if (matrix_change & ((matrix_row_t)1<<c)) { process_key((keyevent_t){ .key = (key_t){ .row = r, .col = c }, - .pressed = (matrix_row & (1<<c)) + .pressed = (matrix_row & ((matrix_row_t)1<<c)) }); // record a processed key - matrix_prev[r] ^= (1<<c); + matrix_prev[r] ^= ((matrix_row_t)1<<c); // process a key per task call goto MATRIX_LOOP_END; } |