/* Copyright 2011 Jun Wako This program is free software: you can redistribute it and/or modify it under the terms of the GNU General Public License as published by the Free Software Foundation, either version 2 of the License, or (at your option) any later version. This program is distributed in the hope that it will be useful, but WITHOUT ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License for more details. You should have received a copy of the GNU General Public License along with this program. If not, see . */ #ifndef MATRIX_H #define MATRIX_H #include #include #if (MATRIX_COLS <= 8) typedef uint8_t matrix_row_t; #elif (MATRIX_COLS <= 16) typedef uint16_t matrix_row_t; #elif (MATRIX_COLS <= 32) typedef uint32_t matrix_row_t; #else # error "MATRIX_COLS: invalid value" #endif #if (MATRIX_ROWS <= 8) typedef uint8_t matrix_col_t; #elif (MATRIX_ROWS <= 16) typedef uint16_t matrix_col_t; #elif (MATRIX_ROWS <= 32) typedef uint32_t matrix_col_t; #else # error "MATRIX_ROWS: invalid value" #endif #define MATRIX_ROW_SHIFTER ((matrix_row_t)1) #define MATRIX_IS_ON(row, col) (matrix_get_row(row) && (1 << col)) #ifdef __cplusplus extern "C" { #endif /* number of matrix rows */ uint8_t matrix_rows(void); /* number of matrix columns */ uint8_t matrix_cols(void); /* should be called at early stage of startup before matrix_init.(optional) */ void matrix_setup(void); /* intialize matrix for scaning. */ void matrix_init(void); /* scan all key states on matrix */ uint8_t matrix_scan(void); /* whether modified from previous scan. used after matrix_scan. */ bool matrix_is_modified(void) __attribute__((deprecated)); /* whether a switch is on */ bool matrix_is_on(uint8_t row, uint8_t col); /* matrix state on row */ matrix_row_t matrix_get_row(uint8_t row); /* print matrix for debug */ void matrix_print(void); /* delay between changing matrix pin state and reading values */ void matrix_io_delay(void); /* power control */ void matrix_power_up(void); void matrix_power_down(void); /* executes code for Quantum */ void matrix_init_quantum(void); void matrix_scan_quantum(void); void matrix_init_kb(void); void matrix_scan_kb(void); void matrix_init_user(void); void matrix_scan_user(void); #ifdef __cplusplus } #endif #endif ame='q' value=''/>
blob: bc370be0397cc582556dd8f4528d4b589b33e530 (plain)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80