mirror of
https://github.com/qmk/qmk_firmware.git
synced 2025-01-07 09:59:48 +00:00
Merge remote-tracking branch 'origin/develop' into xap
This commit is contained in:
commit
d2694da64d
@ -11,7 +11,8 @@
|
|||||||
#include "oled_driver.h"
|
#include "oled_driver.h"
|
||||||
#include "rgb_matrix.h"
|
#include "rgb_matrix.h"
|
||||||
|
|
||||||
// for memcpy
|
// for memcpy & snprintf
|
||||||
|
#include <stdio.h>
|
||||||
#include <string.h>
|
#include <string.h>
|
||||||
#include <transactions.h>
|
#include <transactions.h>
|
||||||
|
|
||||||
|
@ -1,76 +0,0 @@
|
|||||||
/*
|
|
||||||
* ----------------------------------------------------------------------------
|
|
||||||
* "THE BEER-WARE LICENSE" (Revision 42):
|
|
||||||
* <https://github.com/KarlK90> wrote this file. As long as you retain this
|
|
||||||
* notice you can do whatever you want with this stuff. If we meet some day, and
|
|
||||||
* you think this stuff is worth it, you can buy me a beer in return. KarlK90
|
|
||||||
* ----------------------------------------------------------------------------
|
|
||||||
*/
|
|
||||||
|
|
||||||
#include "matrix.h"
|
|
||||||
#include "atomic_util.h"
|
|
||||||
#include "gpio.h"
|
|
||||||
|
|
||||||
#define ROWS_PER_HAND (MATRIX_ROWS / 2)
|
|
||||||
static const pin_t row_pins[MATRIX_ROWS] = MATRIX_ROW_PINS;
|
|
||||||
static const pin_t col_pins[MATRIX_COLS] = MATRIX_COL_PINS;
|
|
||||||
|
|
||||||
void matrix_init_pins(void) {
|
|
||||||
for (size_t i = 0; i < MATRIX_COLS; i++) {
|
|
||||||
setPinInputHigh(col_pins[i]);
|
|
||||||
}
|
|
||||||
for (size_t i = 0; i < ROWS_PER_HAND; i++) {
|
|
||||||
setPinOutput(row_pins[i]);
|
|
||||||
writePinHigh(row_pins[i]);
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
void matrix_read_cols_on_row(matrix_row_t current_matrix[], uint8_t current_row) {
|
|
||||||
/* Drive row pin low. */
|
|
||||||
ATOMIC_BLOCK_FORCEON { writePinLow(row_pins[current_row]); }
|
|
||||||
matrix_output_select_delay();
|
|
||||||
|
|
||||||
/* Read all columns in one go, aka port scanning. */
|
|
||||||
uint16_t porta = palReadPort(GPIOA);
|
|
||||||
uint16_t portb = palReadPort(GPIOB);
|
|
||||||
|
|
||||||
// clang-format off
|
|
||||||
/* Order of pins on the mun is: A0, B11, B0, B10, B12, B2, A8
|
|
||||||
Pin is active low, therefore we have to invert the result. */
|
|
||||||
matrix_row_t cols = ~(((porta & (0x1 << 0)) >> 0) // A0 (0)
|
|
||||||
| ((portb & (0x1 << 11)) >> 10) // B11 (1)
|
|
||||||
| ((portb & (0x1 << 0)) << 2) // B0 (2)
|
|
||||||
| ((portb & (0x1 << 10)) >> 7) // B10 (3)
|
|
||||||
| ((portb & (0x1 << 12)) >> 8) // B12 (4)
|
|
||||||
| ((portb & (0x1 << 2)) << 3) // B2 (5)
|
|
||||||
| ((porta & (0x1 << 8)) >> 2)); // A8 (6)
|
|
||||||
// clang-format on
|
|
||||||
|
|
||||||
/* Reverse the order of columns for left hand as the board is flipped. */
|
|
||||||
// if (isLeftHand) {
|
|
||||||
// #if defined(__arm__)
|
|
||||||
// /* rbit assembly reverses bit order of 32bit registers. */
|
|
||||||
// uint32_t temp = cols;
|
|
||||||
// __asm__("rbit %0, %1" : "=r"(temp) : "r"(temp));
|
|
||||||
// cols = temp >> 24;
|
|
||||||
// #else
|
|
||||||
// /* RISC-V bit manipulation extension not present. Use bit-hack.
|
|
||||||
// https://graphics.stanford.edu/~seander/bithacks.html#ReverseByteWith32Bits */
|
|
||||||
// cols = (matrix_row_t)(((cols * 0x0802LU & 0x22110LU) | (cols * 0x8020LU & 0x88440LU)) * 0x10101LU >> 16);
|
|
||||||
// #endif
|
|
||||||
// }
|
|
||||||
|
|
||||||
current_matrix[current_row] = cols;
|
|
||||||
|
|
||||||
/* Drive row pin high again. */
|
|
||||||
ATOMIC_BLOCK_FORCEON { writePinHigh(row_pins[current_row]); }
|
|
||||||
matrix_output_unselect_delay(current_row, cols != 0);
|
|
||||||
}
|
|
||||||
|
|
||||||
#if defined(BUSY_WAIT)
|
|
||||||
void matrix_output_unselect_delay(uint8_t line, bool key_pressed) {
|
|
||||||
for (int32_t i = 0; i < BUSY_WAIT_INSTRUCTIONS; i++) {
|
|
||||||
__asm__ volatile("nop" ::: "memory");
|
|
||||||
}
|
|
||||||
}
|
|
||||||
#endif
|
|
@ -16,7 +16,7 @@ QUANTUM_LIB_SRC += i2c_master.c
|
|||||||
BOOTMAGIC_ENABLE = no # Enable Bootmagic Lite
|
BOOTMAGIC_ENABLE = no # Enable Bootmagic Lite
|
||||||
MOUSEKEY_ENABLE = no # Mouse keys
|
MOUSEKEY_ENABLE = no # Mouse keys
|
||||||
EXTRAKEY_ENABLE = yes # Audio control and System control
|
EXTRAKEY_ENABLE = yes # Audio control and System control
|
||||||
CONSOLE_ENABLE = yes # Console for debug
|
CONSOLE_ENABLE = no # Console for debug
|
||||||
COMMAND_ENABLE = no # Commands for debug and configuration
|
COMMAND_ENABLE = no # Commands for debug and configuration
|
||||||
NKRO_ENABLE = yes # Enable N-Key Rollover
|
NKRO_ENABLE = yes # Enable N-Key Rollover
|
||||||
AUDIO_ENABLE = no # Audio output
|
AUDIO_ENABLE = no # Audio output
|
||||||
@ -38,7 +38,4 @@ OPT = 3
|
|||||||
|
|
||||||
OPT_DEFS += -DOLED_FONT_H=\"keyboards/rgbkb/common/glcdfont.c\"
|
OPT_DEFS += -DOLED_FONT_H=\"keyboards/rgbkb/common/glcdfont.c\"
|
||||||
|
|
||||||
# matrix optimisations
|
|
||||||
SRC += matrix.c
|
|
||||||
|
|
||||||
DEFAULT_FOLDER = rgbkb/mun/rev1
|
DEFAULT_FOLDER = rgbkb/mun/rev1
|
||||||
|
@ -16,7 +16,7 @@ QUANTUM_LIB_SRC += i2c_master.c
|
|||||||
BOOTMAGIC_ENABLE = yes # Enable Bootmagic Lite
|
BOOTMAGIC_ENABLE = yes # Enable Bootmagic Lite
|
||||||
MOUSEKEY_ENABLE = yes # Mouse keys
|
MOUSEKEY_ENABLE = yes # Mouse keys
|
||||||
EXTRAKEY_ENABLE = yes # Audio control and System control
|
EXTRAKEY_ENABLE = yes # Audio control and System control
|
||||||
CONSOLE_ENABLE = yes # Console for debug
|
CONSOLE_ENABLE = no # Console for debug
|
||||||
COMMAND_ENABLE = no # Commands for debug and configuration
|
COMMAND_ENABLE = no # Commands for debug and configuration
|
||||||
NKRO_ENABLE = yes # Enable N-Key Rollover
|
NKRO_ENABLE = yes # Enable N-Key Rollover
|
||||||
AUDIO_ENABLE = yes # Audio output
|
AUDIO_ENABLE = yes # Audio output
|
||||||
@ -42,8 +42,4 @@ OPT = 3
|
|||||||
|
|
||||||
OPT_DEFS += -DOLED_FONT_H=\"keyboards/rgbkb/common/glcdfont.c\"
|
OPT_DEFS += -DOLED_FONT_H=\"keyboards/rgbkb/common/glcdfont.c\"
|
||||||
|
|
||||||
# TODO: Implement fast matrix scanning
|
|
||||||
# matrix optimisations
|
|
||||||
# SRC += matrix.c
|
|
||||||
|
|
||||||
DEFAULT_FOLDER = rgbkb/sol3/rev1
|
DEFAULT_FOLDER = rgbkb/sol3/rev1
|
||||||
|
Loading…
Reference in New Issue
Block a user