]> git.donarmstrong.com Git - qmk_firmware.git/commitdiff
Malloc array in debounce_eager_pk, since split keyboards only use MATRIX_ROWS/2.
authoralex-ong <the.onga@gmail.com>
Sat, 26 Jan 2019 12:18:24 +0000 (23:18 +1100)
committeralex-ong <the.onga@gmail.com>
Sat, 26 Jan 2019 12:18:24 +0000 (23:18 +1100)
quantum/debounce/debounce_eager_pk.c

index f1457496e927e7b9a1f0892756d1c8c7d1d4c0c1..af11362efc918b1f48d63f508d47fa693dcf5d38 100644 (file)
@@ -21,6 +21,7 @@ No further inputs are accepted until DEBOUNCE milliseconds have occurred.
 #include "debounce.h"
 #include "matrix.h"
 #include "timer.h"
+#include <stdlib.h>
 
 #ifndef DEBOUNCE
   #define DEBOUNCE 5
@@ -39,7 +40,7 @@ No further inputs are accepted until DEBOUNCE milliseconds have occurred.
 
 #define debounce_counter_t uint8_t
 
-static debounce_counter_t debounce_counters[MATRIX_ROWS*MATRIX_COLS];
+static debounce_counter_t *debounce_counters;
 
 #define DEBOUNCE_ELAPSED 251
 #define MAX_DEBOUNCE (DEBOUNCE_ELAPSED - 1)
@@ -47,10 +48,12 @@ static debounce_counter_t debounce_counters[MATRIX_ROWS*MATRIX_COLS];
 void update_debounce_counters(uint8_t num_rows, uint8_t current_time);
 void transfer_matrix_values(matrix_row_t raw[], matrix_row_t cooked[], uint8_t num_rows, uint8_t current_time);
 
+//we use num_rows rather than MATRIX_ROWS to support split keyboards
 void debounce_init(uint8_t num_rows)
 {
+  debounce_counters = (debounce_counter_t*)malloc(num_rows*MATRIX_COLS * sizeof(debounce_counter_t));
   int i = 0;
-  for (uint8_t r = 0; r < MATRIX_ROWS; r++)
+  for (uint8_t r = 0; r < num_rows; r++)
   {
     for (uint8_t c = 0; c < MATRIX_COLS; c++)
     {