From 2f80e790c6310ad24a4cb3d4a72c31314364fef7 Mon Sep 17 00:00:00 2001 From: tmk Date: Wed, 27 Oct 2010 20:51:45 +0900 Subject: new build method for macway --- macway/matrix.c | 90 ++++++++++++++++++++++++++++++++++++++++++++------------- 1 file changed, 70 insertions(+), 20 deletions(-) (limited to 'macway/matrix.c') diff --git a/macway/matrix.c b/macway/matrix.c index cb52d79c3..30da657ea 100644 --- a/macway/matrix.c +++ b/macway/matrix.c @@ -1,10 +1,13 @@ /* * scan matrix */ +#include +#include #include #include -#include "keymap.h" #include "matrix.h" +#include "print.h" +#include "util.h" // matrix is active low. (key on: 0/key off: 1) // row: Hi-Z(unselected)/low output(selected) @@ -18,11 +21,24 @@ uint8_t *matrix_prev; static uint8_t _matrix0[MATRIX_ROWS]; static uint8_t _matrix1[MATRIX_ROWS]; +static bool matrix_has_ghost_in_row(uint8_t row); static uint8_t read_col(void); static void unselect_rows(void); static void select_row(uint8_t row); +inline +int matrix_rows(void) +{ + return MATRIX_ROWS; +} + +inline +int matrix_cols(void) +{ + return MATRIX_COLS; +} + // this must be called once before matrix_scan. void matrix_init(void) { @@ -32,58 +48,91 @@ void matrix_init(void) PORTB = 0xFF; // initialize matrix state: all keys off - for (int i=0; i < MATRIX_ROWS; i++) _matrix0[i] = 0xFF; - for (int i=0; i < MATRIX_ROWS; i++) _matrix1[i] = 0xFF; + for (int i=0; i < MATRIX_ROWS; i++) _matrix0[i] = 0x00; + for (int i=0; i < MATRIX_ROWS; i++) _matrix1[i] = 0x00; matrix = _matrix0; matrix_prev = _matrix1; } -uint8_t matrix_scan(void) +int matrix_scan(void) { - uint8_t row, state; uint8_t *tmp; tmp = matrix_prev; matrix_prev = matrix; matrix = tmp; - for (row = 0; row < MATRIX_ROWS; row++) { - select_row(row); + for (int i = 0; i < MATRIX_ROWS; i++) { + select_row(i); _delay_us(30); // without this wait read unstable value. - state = read_col(); + matrix[i] = ~read_col(); unselect_rows(); - - matrix[row] = state; } return 1; } -bool matrix_is_modified(void) { - for (int i=0; i