]> git.donarmstrong.com Git - qmk_firmware.git/commitdiff
Adds wait to i2c (debounce)
authorJack Humbert <jack.humb@gmail.com>
Mon, 4 Jul 2016 16:13:41 +0000 (12:13 -0400)
committerErez Zukerman <ezuk@madmimi.com>
Mon, 4 Jul 2016 16:13:41 +0000 (12:13 -0400)
keyboards/ergodox_ez/matrix.c

index 1bacff2a5d53915e397726415ff6c908045395a3..9c1efa1d05acb4bee691f771c943316b57ac93bf 100644 (file)
@@ -27,7 +27,7 @@ along with this program.  If not, see <http://www.gnu.org/licenses/>.
 #include <stdint.h>
 #include <stdbool.h>
 #include <avr/io.h>
-#include <util/delay.h>
+#include "wait.h"
 #include "action_layer.h"
 #include "print.h"
 #include "debug.h"
@@ -166,6 +166,7 @@ uint8_t matrix_scan(void)
 
     for (uint8_t i = 0; i < MATRIX_ROWS; i++) {
         select_row(i);
+        wait_us(30);  // without this wait read unstable value.
         matrix_row_t cols = read_cols(i);
         if (matrix_debouncing[i] != cols) {
             matrix_debouncing[i] = cols;
@@ -179,7 +180,7 @@ uint8_t matrix_scan(void)
 
     if (debouncing) {
         if (--debouncing) {
-            _delay_ms(2);
+            wait_us(1);
         } else {
             for (uint8_t i = 0; i < MATRIX_ROWS; i++) {
                 matrix[i] = matrix_debouncing[i];
@@ -267,7 +268,6 @@ static matrix_row_t read_cols(uint8_t row)
             return data;
         }
     } else {
-        _delay_us(30);  // without this wait read unstable value.
         // read from teensy
         return
             (PINF&(1<<0) ? 0 : (1<<0)) |