Update atomic GPIO macros in keyboard custom matrix (#23796)

This commit is contained in:
Ryan 2024-07-13 18:41:05 +10:00 committed by GitHub
parent 5c43a9bed1
commit 1552cf2ddc
No known key found for this signature in database
GPG key ID: B5690EEEBB952194
20 changed files with 270 additions and 270 deletions

View file

@ -34,21 +34,21 @@ static pin_t col_pins[MATRIX_COLS] = MATRIX_COL_PINS;
#define ROWS_PER_HAND (MATRIX_ROWS)
static inline void setPinOutput_writeLow(pin_t pin) {
static inline void gpio_atomic_set_pin_output_low(pin_t pin) {
ATOMIC_BLOCK_FORCEON {
gpio_set_pin_output(pin);
gpio_write_pin_low(pin);
}
}
static inline void setPinOutput_writeHigh(pin_t pin) {
static inline void gpio_atomic_set_pin_output_high(pin_t pin) {
ATOMIC_BLOCK_FORCEON {
gpio_set_pin_output(pin);
gpio_write_pin_high(pin);
}
}
static inline void setPinInputHigh_atomic(pin_t pin) {
static inline void gpio_atomic_set_pin_input_high(pin_t pin) {
ATOMIC_BLOCK_FORCEON {
gpio_set_pin_input_high(pin);
}
@ -65,35 +65,35 @@ static inline uint8_t readMatrixPin(pin_t pin) {
static void shiftOutMultiple(uint16_t dataOut) {
for (uint8_t i = 0; i < 8; i++) {
if (dataOut & 0x1) {
setPinOutput_writeHigh(DATA_PIN);
gpio_atomic_set_pin_output_high(DATA_PIN);
} else {
setPinOutput_writeLow(DATA_PIN);
gpio_atomic_set_pin_output_low(DATA_PIN);
}
dataOut = dataOut >> 1;
setPinOutput_writeHigh(CLOCK_PIN);
setPinOutput_writeLow(CLOCK_PIN);
gpio_atomic_set_pin_output_high(CLOCK_PIN);
gpio_atomic_set_pin_output_low(CLOCK_PIN);
}
setPinOutput_writeHigh(LATCH_PIN);
setPinOutput_writeLow(LATCH_PIN);
gpio_atomic_set_pin_output_high(LATCH_PIN);
gpio_atomic_set_pin_output_low(LATCH_PIN);
}
static void shiftOut_single(uint8_t dataOut) {
if (dataOut & 0x1) {
setPinOutput_writeHigh(DATA_PIN);
gpio_atomic_set_pin_output_high(DATA_PIN);
} else {
setPinOutput_writeLow(DATA_PIN);
gpio_atomic_set_pin_output_low(DATA_PIN);
}
setPinOutput_writeHigh(CLOCK_PIN);
setPinOutput_writeLow(CLOCK_PIN);
setPinOutput_writeHigh(LATCH_PIN);
setPinOutput_writeLow(LATCH_PIN);
gpio_atomic_set_pin_output_high(CLOCK_PIN);
gpio_atomic_set_pin_output_low(CLOCK_PIN);
gpio_atomic_set_pin_output_high(LATCH_PIN);
gpio_atomic_set_pin_output_low(LATCH_PIN);
}
static bool select_col(uint8_t col) {
pin_t pin = col_pins[col];
if (pin != NO_PIN) {
setPinOutput_writeLow(pin);
gpio_atomic_set_pin_output_low(pin);
return true;
} else {
if (col == (MATRIX_COLS - 8)) {
@ -111,16 +111,16 @@ static void unselect_col(uint8_t col) {
if (pin != NO_PIN) {
#ifdef MATRIX_UNSELECT_DRIVE_HIGH
setPinOutput_writeHigh(pin);
gpio_atomic_set_pin_output_high(pin);
#else
setPinInputHigh_atomic(pin);
gpio_atomic_set_pin_input_high(pin);
#endif
} else {
if (col == (MATRIX_COLS - 1)) {
setPinOutput_writeHigh(CLOCK_PIN);
setPinOutput_writeLow(CLOCK_PIN);
setPinOutput_writeHigh(LATCH_PIN);
setPinOutput_writeLow(LATCH_PIN);
gpio_atomic_set_pin_output_high(CLOCK_PIN);
gpio_atomic_set_pin_output_low(CLOCK_PIN);
gpio_atomic_set_pin_output_high(LATCH_PIN);
gpio_atomic_set_pin_output_low(LATCH_PIN);
}
}
}
@ -131,9 +131,9 @@ static void unselect_cols(void) {
pin_t pin = col_pins[x];
if (pin != NO_PIN) {
#ifdef MATRIX_UNSELECT_DRIVE_HIGH
setPinOutput_writeHigh(pin);
gpio_atomic_set_pin_output_high(pin);
#else
setPinInputHigh_atomic(pin);
gpio_atomic_set_pin_input_high(pin);
#endif
} else {
if (x == (MATRIX_COLS - 1)) {
@ -148,7 +148,7 @@ static void matrix_init_pins(void) {
unselect_cols();
for (uint8_t x = 0; x < MATRIX_ROWS; x++) {
if (row_pins[x] != NO_PIN) {
setPinInputHigh_atomic(row_pins[x]);
gpio_atomic_set_pin_input_high(row_pins[x]);
}
}
}