diff options
| author | Nick Brassel <nick@tzarc.org> | 2021-06-09 17:19:42 +1000 |
|---|---|---|
| committer | GitHub <noreply@github.com> | 2021-06-09 17:19:42 +1000 |
| commit | f287597c19dc926c7c28cefa32ffc3f0b4fdba7f (patch) | |
| tree | 563ea4a0083f2205c7c89f0262455ccec8a3cb44 /docs/custom_quantum_functions.md | |
| parent | cbfa2dba2594d419aea1cf26584751ced9411ded (diff) | |
| download | qmk_firmware-f287597c19dc926c7c28cefa32ffc3f0b4fdba7f.tar.gz qmk_firmware-f287597c19dc926c7c28cefa32ffc3f0b4fdba7f.zip | |
Use single memcmp to determine if matrix changed. (#13064)
* Use memcmp to determine if matrix changed.
* Firmware size issues.
* Add documentation for the lack of need of MATRIX_ROW_PINS/MATRIX_COL_PINS, when overriding low-level matrix functions.
Diffstat (limited to 'docs/custom_quantum_functions.md')
| -rw-r--r-- | docs/custom_quantum_functions.md | 8 |
1 files changed, 8 insertions, 0 deletions
diff --git a/docs/custom_quantum_functions.md b/docs/custom_quantum_functions.md index 694b421e7..30c637bb4 100644 --- a/docs/custom_quantum_functions.md +++ b/docs/custom_quantum_functions.md | |||
| @@ -144,6 +144,14 @@ This is useful for setting up stuff that you may need elsewhere, but isn't hardw | |||
| 144 | * Keyboard/Revision: `void matrix_init_kb(void)` | 144 | * Keyboard/Revision: `void matrix_init_kb(void)` |
| 145 | * Keymap: `void matrix_init_user(void)` | 145 | * Keymap: `void matrix_init_user(void)` |
| 146 | 146 | ||
| 147 | ### Low-level Matrix Overrides Function Documentation :id=low-level-matrix-overrides | ||
| 148 | |||
| 149 | * GPIO pin initialisation: `void matrix_init_pins(void)` | ||
| 150 | * This needs to perform the low-level initialisation of all row and column pins. By default this will initialise the input/output state of each of the GPIO pins listed in `MATRIX_ROW_PINS` and `MATRIX_COL_PINS`, based on whether or not the keyboard is set up for `ROW2COL`, `COL2ROW`, or `DIRECT_PINS`. Should the keyboard designer override this function, no initialisation of pin state will occur within QMK itself, instead deferring to the keyboard's override. | ||
| 151 | * `COL2ROW`-based row reads: `void matrix_read_rows_on_col(matrix_row_t current_matrix[], uint8_t current_col)` | ||
| 152 | * `ROW2COL`-based column reads: `void matrix_read_cols_on_row(matrix_row_t current_matrix[], uint8_t current_row)` | ||
| 153 | * `DIRECT_PINS`-based reads: `void matrix_read_cols_on_row(matrix_row_t current_matrix[], uint8_t current_row)` | ||
| 154 | * These three functions need to perform the low-level retrieval of matrix state of relevant input pins, based on the matrix type. Only one of the functions should be implemented, if needed. By default this will iterate through `MATRIX_ROW_PINS` and `MATRIX_COL_PINS`, configuring the inputs and outputs based on whether or not the keyboard is set up for `ROW2COL`, `COL2ROW`, or `DIRECT_PINS`. Should the keyboard designer override this function, no manipulation of matrix GPIO pin state will occur within QMK itself, instead deferring to the keyboard's override. | ||
| 147 | 155 | ||
| 148 | ## Keyboard Post Initialization code | 156 | ## Keyboard Post Initialization code |
| 149 | 157 | ||
