summaryrefslogtreecommitdiffstats
path: root/quantum/dip_switch.c
diff options
context:
space:
mode:
authorXScorpion2 <rcalt2vt@gmail.com>2021-08-19 12:39:15 -0500
committerGitHub <noreply@github.com>2021-08-19 18:39:15 +0100
commit9d1c98c891bb8e1e98dc618e0693a7efff23a22e (patch)
treeb3ceeb02861a2e94c248c1e538e9b8db456ffa47 /quantum/dip_switch.c
parentaf3673a5b6985f4364210c3656f323624c2e1962 (diff)
Added right vs left specific pin assignments for dip switch (#13074)
* Added right vs left specific pin assignments for dip switch * Update feature_dip_switch.md * Ran formatting tools
Diffstat (limited to 'quantum/dip_switch.c')
-rw-r--r--quantum/dip_switch.c26
1 files changed, 24 insertions, 2 deletions
diff --git a/quantum/dip_switch.c b/quantum/dip_switch.c
index 72789ca8e8..2608cae594 100644
--- a/quantum/dip_switch.c
+++ b/quantum/dip_switch.c
@@ -17,6 +17,9 @@
*/
#include "dip_switch.h"
+#ifdef SPLIT_KEYBOARD
+# include "split_common/split_util.h"
+#endif
// for memcpy
#include <string.h>
@@ -32,6 +35,9 @@
#ifdef DIP_SWITCH_PINS
# define NUMBER_OF_DIP_SWITCHES (sizeof(dip_switch_pad) / sizeof(pin_t))
static pin_t dip_switch_pad[] = DIP_SWITCH_PINS;
+# if defined(SPLIT_KEYBOARD) && defined(DIP_SWITCH_PINS_RIGHT)
+static pin_t dip_switch_pad_right[] = DIP_SWITCH_PINS_RIGHT;
+# endif
#endif
#ifdef DIP_SWITCH_MATRIX_GRID
@@ -60,7 +66,15 @@ __attribute__((weak)) bool dip_switch_update_mask_kb(uint32_t state) { return di
void dip_switch_init(void) {
#ifdef DIP_SWITCH_PINS
for (uint8_t i = 0; i < NUMBER_OF_DIP_SWITCHES; i++) {
- setPinInputHigh(dip_switch_pad[i]);
+# if defined(SPLIT_KEYBOARD) && defined(DIP_SWITCH_PINS_RIGHT)
+ if (isLeftHand) {
+# endif
+ setPinInputHigh(dip_switch_pad[i]);
+# if defined(SPLIT_KEYBOARD) && defined(DIP_SWITCH_PINS_RIGHT)
+ } else {
+ setPinInputHigh(dip_switch_pad_right[i]);
+ }
+# endif
}
dip_switch_read(true);
#endif
@@ -89,7 +103,15 @@ void dip_switch_read(bool forced) {
for (uint8_t i = 0; i < NUMBER_OF_DIP_SWITCHES; i++) {
#ifdef DIP_SWITCH_PINS
- dip_switch_state[i] = !readPin(dip_switch_pad[i]);
+# if defined(SPLIT_KEYBOARD) && defined(DIP_SWITCH_PINS_RIGHT)
+ if (isLeftHand) {
+# endif
+ dip_switch_state[i] = !readPin(dip_switch_pad[i]);
+# if defined(SPLIT_KEYBOARD) && defined(DIP_SWITCH_PINS_RIGHT)
+ } else {
+ dip_switch_state[i] = !readPin(dip_switch_pad_right[i]);
+ }
+# endif
#endif
#ifdef DIP_SWITCH_MATRIX_GRID
dip_switch_state[i] = peek_matrix(dip_switch_pad[i].row, dip_switch_pad[i].col, read_raw);