mirror of
https://github.com/Keychron/qmk_firmware.git
synced 2024-12-25 18:48:05 +06:00
Align Dip Switch feature (#22625)
This commit is contained in:
parent
e471cb80cb
commit
42245651e7
@ -19,8 +19,6 @@
|
|||||||
#include <string.h> // for memcpy
|
#include <string.h> // for memcpy
|
||||||
|
|
||||||
#include "dip_switch.h"
|
#include "dip_switch.h"
|
||||||
#include "gpio.h"
|
|
||||||
#include "util.h"
|
|
||||||
|
|
||||||
#ifdef SPLIT_KEYBOARD
|
#ifdef SPLIT_KEYBOARD
|
||||||
# include "split_common/split_util.h"
|
# include "split_common/split_util.h"
|
||||||
@ -35,24 +33,17 @@
|
|||||||
#endif
|
#endif
|
||||||
|
|
||||||
#ifdef DIP_SWITCH_PINS
|
#ifdef DIP_SWITCH_PINS
|
||||||
# define NUMBER_OF_DIP_SWITCHES (ARRAY_SIZE(dip_switch_pad))
|
|
||||||
static pin_t dip_switch_pad[] = DIP_SWITCH_PINS;
|
static pin_t dip_switch_pad[] = DIP_SWITCH_PINS;
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
#ifdef DIP_SWITCH_MATRIX_GRID
|
#ifdef DIP_SWITCH_MATRIX_GRID
|
||||||
typedef struct matrix_index_t {
|
static matrix_intersection_t dip_switch_pad[] = DIP_SWITCH_MATRIX_GRID;
|
||||||
uint8_t row;
|
|
||||||
uint8_t col;
|
|
||||||
} matrix_index_t;
|
|
||||||
|
|
||||||
# define NUMBER_OF_DIP_SWITCHES (ARRAY_SIZE(dip_switch_pad))
|
|
||||||
static matrix_index_t dip_switch_pad[] = DIP_SWITCH_MATRIX_GRID;
|
|
||||||
extern bool peek_matrix(uint8_t row_index, uint8_t col_index, bool read_raw);
|
extern bool peek_matrix(uint8_t row_index, uint8_t col_index, bool read_raw);
|
||||||
static uint16_t scan_count;
|
static uint16_t scan_count;
|
||||||
#endif /* DIP_SWITCH_MATRIX_GRID */
|
#endif /* DIP_SWITCH_MATRIX_GRID */
|
||||||
|
|
||||||
static bool dip_switch_state[NUMBER_OF_DIP_SWITCHES] = {0};
|
static bool dip_switch_state[NUM_DIP_SWITCHES] = {0};
|
||||||
static bool last_dip_switch_state[NUMBER_OF_DIP_SWITCHES] = {0};
|
static bool last_dip_switch_state[NUM_DIP_SWITCHES] = {0};
|
||||||
|
|
||||||
__attribute__((weak)) bool dip_switch_update_user(uint8_t index, bool active) {
|
__attribute__((weak)) bool dip_switch_update_user(uint8_t index, bool active) {
|
||||||
return true;
|
return true;
|
||||||
@ -75,12 +66,12 @@ void dip_switch_init(void) {
|
|||||||
# if defined(SPLIT_KEYBOARD) && defined(DIP_SWITCH_PINS_RIGHT)
|
# if defined(SPLIT_KEYBOARD) && defined(DIP_SWITCH_PINS_RIGHT)
|
||||||
if (!isLeftHand) {
|
if (!isLeftHand) {
|
||||||
const pin_t dip_switch_pad_right[] = DIP_SWITCH_PINS_RIGHT;
|
const pin_t dip_switch_pad_right[] = DIP_SWITCH_PINS_RIGHT;
|
||||||
for (uint8_t i = 0; i < NUMBER_OF_DIP_SWITCHES; i++) {
|
for (uint8_t i = 0; i < NUM_DIP_SWITCHES; i++) {
|
||||||
dip_switch_pad[i] = dip_switch_pad_right[i];
|
dip_switch_pad[i] = dip_switch_pad_right[i];
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
# endif
|
# endif
|
||||||
for (uint8_t i = 0; i < NUMBER_OF_DIP_SWITCHES; i++) {
|
for (uint8_t i = 0; i < NUM_DIP_SWITCHES; i++) {
|
||||||
setPinInputHigh(dip_switch_pad[i]);
|
setPinInputHigh(dip_switch_pad[i]);
|
||||||
}
|
}
|
||||||
dip_switch_read(true);
|
dip_switch_read(true);
|
||||||
@ -108,7 +99,7 @@ void dip_switch_read(bool forced) {
|
|||||||
}
|
}
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
for (uint8_t i = 0; i < NUMBER_OF_DIP_SWITCHES; i++) {
|
for (uint8_t i = 0; i < NUM_DIP_SWITCHES; i++) {
|
||||||
#ifdef DIP_SWITCH_PINS
|
#ifdef DIP_SWITCH_PINS
|
||||||
dip_switch_state[i] = !readPin(dip_switch_pad[i]);
|
dip_switch_state[i] = !readPin(dip_switch_pad[i]);
|
||||||
#endif
|
#endif
|
||||||
@ -126,3 +117,7 @@ void dip_switch_read(bool forced) {
|
|||||||
memcpy(last_dip_switch_state, dip_switch_state, sizeof(dip_switch_state));
|
memcpy(last_dip_switch_state, dip_switch_state, sizeof(dip_switch_state));
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
void dip_switch_task(void) {
|
||||||
|
dip_switch_read(false);
|
||||||
|
}
|
||||||
|
@ -20,11 +20,29 @@
|
|||||||
|
|
||||||
#include <stdbool.h>
|
#include <stdbool.h>
|
||||||
#include <stdint.h>
|
#include <stdint.h>
|
||||||
|
#include "gpio.h"
|
||||||
|
#include "util.h"
|
||||||
|
|
||||||
|
#if defined(DIP_SWITCH_PINS)
|
||||||
|
# define NUM_DIP_SWITCHES ARRAY_SIZE(((pin_t[])DIP_SWITCH_PINS))
|
||||||
|
#elif defined(DIP_SWITCH_MATRIX_GRID)
|
||||||
|
typedef struct matrix_intersection_t {
|
||||||
|
uint8_t row;
|
||||||
|
uint8_t col;
|
||||||
|
} matrix_intersection_t;
|
||||||
|
# define NUM_DIP_SWITCHES ARRAY_SIZE(((matrix_intersection_t[])DIP_SWITCH_MATRIX_GRID))
|
||||||
|
#endif
|
||||||
|
|
||||||
|
#ifndef NUM_DIP_SWITCHES
|
||||||
|
# define NUM_DIP_SWITCHES 0
|
||||||
|
#endif
|
||||||
|
|
||||||
bool dip_switch_update_kb(uint8_t index, bool active);
|
bool dip_switch_update_kb(uint8_t index, bool active);
|
||||||
bool dip_switch_update_user(uint8_t index, bool active);
|
bool dip_switch_update_user(uint8_t index, bool active);
|
||||||
bool dip_switch_update_mask_user(uint32_t state);
|
bool dip_switch_update_mask_user(uint32_t state);
|
||||||
bool dip_switch_update_mask_kb(uint32_t state);
|
bool dip_switch_update_mask_kb(uint32_t state);
|
||||||
|
|
||||||
void dip_switch_init(void);
|
|
||||||
void dip_switch_read(bool forced);
|
void dip_switch_read(bool forced);
|
||||||
|
|
||||||
|
void dip_switch_init(void);
|
||||||
|
void dip_switch_task(void);
|
||||||
|
@ -615,7 +615,7 @@ void quantum_task(void) {
|
|||||||
#endif
|
#endif
|
||||||
|
|
||||||
#ifdef DIP_SWITCH_ENABLE
|
#ifdef DIP_SWITCH_ENABLE
|
||||||
dip_switch_read(false);
|
dip_switch_task();
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
#ifdef AUTO_SHIFT_ENABLE
|
#ifdef AUTO_SHIFT_ENABLE
|
||||||
|
Loading…
Reference in New Issue
Block a user