Merge branch 'develop'
This commit is contained in:
		
						commit
						0188038bc0
					
				
							
								
								
									
										8
									
								
								Makefile
									
									
									
									
									
								
							
							
						
						
									
										8
									
								
								Makefile
									
									
									
									
									
								
							| @ -115,7 +115,7 @@ endef | ||||
| TRY_TO_MATCH_RULE_FROM_LIST = $(eval $(call TRY_TO_MATCH_RULE_FROM_LIST_HELPER,$1))$(RULE_FOUND) | ||||
| 
 | ||||
| # As TRY_TO_MATCH_RULE_FROM_LIST_HELPER, but with additional
 | ||||
| # resolution of DEFAULT_FOLDER and keyboard_aliases.hjson for provided rule 
 | ||||
| # resolution of keyboard_aliases.hjson for provided rule 
 | ||||
| define TRY_TO_MATCH_RULE_FROM_LIST_HELPER_KB | ||||
|     # Split on ":", padding with empty strings to avoid indexing issues | ||||
|     TOKEN1:=$$(shell python3 -c "import sys; print((sys.argv[1].split(':',1)+[''])[0])" $$(RULE)) | ||||
| @ -255,7 +255,7 @@ endef | ||||
| # if we are going to compile all keyboards, match the rest of the rule
 | ||||
| # for each of them
 | ||||
| define PARSE_ALL_KEYBOARDS | ||||
|     $$(eval $$(call PARSE_ALL_IN_LIST,PARSE_KEYBOARD,$(shell $(QMK_BIN) list-keyboards --no-resolve-defaults))) | ||||
|     $$(eval $$(call PARSE_ALL_IN_LIST,PARSE_KEYBOARD,$(shell $(QMK_BIN) list-keyboards))) | ||||
| endef | ||||
| 
 | ||||
| # Prints a list of all known keymaps for the given keyboard
 | ||||
| @ -447,7 +447,7 @@ git-submodules: git-submodule | ||||
| 
 | ||||
| .PHONY: list-keyboards | ||||
| list-keyboards: | ||||
| 	$(QMK_BIN) list-keyboards --no-resolve-defaults | tr '\n' ' ' | ||||
| 	$(QMK_BIN) list-keyboards | tr '\n' ' ' | ||||
| 
 | ||||
| .PHONY: list-tests | ||||
| list-tests: | ||||
| @ -455,7 +455,7 @@ list-tests: | ||||
| 
 | ||||
| .PHONY: generate-keyboards-file | ||||
| generate-keyboards-file: | ||||
| 	$(QMK_BIN) list-keyboards --no-resolve-defaults | ||||
| 	$(QMK_BIN) list-keyboards | ||||
| 
 | ||||
| .PHONY: clean | ||||
| clean: | ||||
|  | ||||
| @ -62,6 +62,7 @@ include $(BUILDDEFS_PATH)/common_features.mk | ||||
| include $(BUILDDEFS_PATH)/generic_features.mk | ||||
| include $(PLATFORM_PATH)/common.mk | ||||
| include $(TMK_PATH)/protocol.mk | ||||
| include $(QUANTUM_PATH)/battery/tests/rules.mk | ||||
| include $(QUANTUM_PATH)/debounce/tests/rules.mk | ||||
| include $(QUANTUM_PATH)/encoder/tests/rules.mk | ||||
| include $(QUANTUM_PATH)/os_detection/tests/rules.mk | ||||
|  | ||||
| @ -29,6 +29,8 @@ QUANTUM_SRC += \ | ||||
|     $(QUANTUM_DIR)/logging/debug.c \
 | ||||
|     $(QUANTUM_DIR)/logging/sendchar.c \
 | ||||
|     $(QUANTUM_DIR)/process_keycode/process_default_layer.c \
 | ||||
|     $(QUANTUM_DIR)/process_keycode/process_oneshot.c \
 | ||||
|     $(QUANTUM_DIR)/process_keycode/process_quantum.c \
 | ||||
| 
 | ||||
| include $(QUANTUM_DIR)/nvm/rules.mk | ||||
| 
 | ||||
| @ -633,6 +635,9 @@ ifeq ($(strip $(VIA_ENABLE)), yes) | ||||
|     RAW_ENABLE := yes | ||||
|     BOOTMAGIC_ENABLE := yes | ||||
|     TRI_LAYER_ENABLE := yes | ||||
|     ifeq ($(strip $(VIA_INSECURE)), yes) | ||||
|         OPT_DEFS += -DVIA_INSECURE | ||||
|     endif | ||||
| endif | ||||
| 
 | ||||
| ifeq ($(strip $(RAW_ENABLE)), yes) | ||||
| @ -940,21 +945,25 @@ ifeq ($(strip $(DIP_SWITCH_ENABLE)), yes) | ||||
|     endif | ||||
| endif | ||||
| 
 | ||||
| ifeq ($(strip $(BATTERY_ENABLE)), yes) | ||||
|     BATTERY_DRIVER_REQUIRED := yes | ||||
| endif | ||||
| 
 | ||||
| VALID_BATTERY_DRIVER_TYPES := adc custom vendor | ||||
| 
 | ||||
| BATTERY_DRIVER ?= adc | ||||
| BATTERY_DRIVER ?= none | ||||
| ifeq ($(strip $(BATTERY_DRIVER_REQUIRED)), yes) | ||||
|     ifeq ($(filter $(BATTERY_DRIVER),$(VALID_BATTERY_DRIVER_TYPES)),) | ||||
|         $(call CATASTROPHIC_ERROR,Invalid BATTERY_DRIVER,BATTERY_DRIVER="$(BATTERY_DRIVER)" is not a valid battery driver) | ||||
|     endif | ||||
| 
 | ||||
|     OPT_DEFS += -DBATTERY_DRIVER | ||||
|     OPT_DEFS += -DBATTERY_$(strip $(shell echo $(BATTERY_DRIVER) | tr '[:lower:]' '[:upper:]')) | ||||
|     OPT_DEFS += -DBATTERY_DRIVER_$(strip $(shell echo $(BATTERY_DRIVER) | tr '[:lower:]' '[:upper:]')) | ||||
| 
 | ||||
|     COMMON_VPATH += $(DRIVER_PATH)/battery | ||||
| 
 | ||||
|     SRC += battery.c | ||||
|     SRC += battery_$(strip $(BATTERY_DRIVER)).c | ||||
|     ifneq ($(strip $(BATTERY_DRIVER)), custom) | ||||
|         SRC += battery_$(strip $(BATTERY_DRIVER)).c | ||||
|     endif | ||||
| 
 | ||||
|     # add extra deps | ||||
|     ifeq ($(strip $(BATTERY_DRIVER)), adc) | ||||
|  | ||||
| @ -1,8 +1,3 @@ | ||||
| ifneq (,$(filter $(MCU),atmega32u4)) | ||||
|     # TODO: opt in rather than assume everything uses a pro micro | ||||
|     PIN_COMPATIBLE ?= promicro | ||||
| endif | ||||
| 
 | ||||
| # Remove whitespace from any rule.mk provided vars
 | ||||
| #   - env cannot be overwritten but cannot have whitespace anyway
 | ||||
| CONVERT_TO:=$(strip $(CONVERT_TO)) | ||||
|  | ||||
| @ -21,6 +21,7 @@ SPACE_CADET_ENABLE ?= yes | ||||
| GENERIC_FEATURES = \
 | ||||
|     AUTO_SHIFT \
 | ||||
|     AUTOCORRECT \
 | ||||
|     BATTERY \
 | ||||
|     BOOTMAGIC \
 | ||||
|     CAPS_WORD \
 | ||||
|     COMBO \
 | ||||
|  | ||||
| @ -1,6 +1,7 @@ | ||||
| TEST_LIST = $(sort $(patsubst %/test.mk,%, $(shell find $(ROOT_DIR)tests -type f -name test.mk))) | ||||
| FULL_TESTS := $(notdir $(TEST_LIST)) | ||||
| 
 | ||||
| include $(QUANTUM_PATH)/battery/tests/testlist.mk | ||||
| include $(QUANTUM_PATH)/debounce/tests/testlist.mk | ||||
| include $(QUANTUM_PATH)/encoder/tests/testlist.mk | ||||
| include $(QUANTUM_PATH)/os_detection/tests/testlist.mk | ||||
|  | ||||
| @ -43,6 +43,14 @@ | ||||
|     "BOOTMAGIC_ROW": {"info_key": "bootmagic.matrix.0", "value_type": "int"}, | ||||
|     "BOOTMAGIC_ROW_RIGHT": {"info_key": "split.bootmagic.matrix.0", "value_type": "int"}, | ||||
| 
 | ||||
|     // Battery | ||||
|     "BATTERY_SAMPLE_INTERVAL": {"info_key": "battery.sample_interval", "value_type": "int"}, | ||||
|     "BATTERY_ADC_PIN": {"info_key": "battery.adc.pin"}, | ||||
|     "BATTERY_ADC_REF_VOLTAGE_MV": {"info_key": "battery.adc.reference_voltage", "value_type": "int"}, | ||||
|     "BATTERY_ADC_VOLTAGE_DIVIDER_R1": {"info_key": "battery.adc.divider_r1", "value_type": "int"}, | ||||
|     "BATTERY_ADC_VOLTAGE_DIVIDER_R2": {"info_key": "battery.adc.divider_r2", "value_type": "int"}, | ||||
|     "BATTERY_ADC_RESOLUTION": {"info_key": "battery.adc.resolution", "value_type": "int"}, | ||||
| 
 | ||||
|     // Caps Word | ||||
|     "BOTH_SHIFTS_TURNS_ON_CAPS_WORD": {"info_key": "caps_word.both_shifts_turns_on", "value_type": "flag"}, | ||||
|     "CAPS_WORD_IDLE_TIMEOUT": {"info_key": "caps_word.idle_timeout", "value_type": "int"}, | ||||
| @ -120,6 +128,7 @@ | ||||
|     "MATRIX_HAS_GHOST": {"info_key": "matrix_pins.ghost", "value_type": "flag"}, | ||||
|     "MATRIX_INPUT_PRESSED_STATE": {"info_key": "matrix_pins.input_pressed_state", "value_type": "int"}, | ||||
|     "MATRIX_IO_DELAY": {"info_key": "matrix_pins.io_delay", "value_type": "int"}, | ||||
|     "MATRIX_MASKED": {"info_key": "matrix_pins.masked", "value_type": "flag"}, | ||||
| 
 | ||||
|     // Mouse Keys | ||||
|     "MOUSEKEY_DELAY": {"info_key": "mousekey.delay", "value_type": "int"}, | ||||
| @ -183,7 +192,7 @@ | ||||
| 
 | ||||
|     // Split Keyboard | ||||
|     "SOFT_SERIAL_PIN": {"info_key": "split.serial.pin"}, | ||||
|     "SOFT_SERIAL_SPEED": {"info_key": "split.soft_serial_speed"}, | ||||
|     "SELECT_SOFT_SERIAL_SPEED": {"info_key": "split.serial.speed"}, | ||||
|     "SPLIT_HAND_MATRIX_GRID": {"info_key": "split.handedness.matrix_grid", "value_type": "array", "to_c": false}, | ||||
|     "SPLIT_HAND_PIN": {"info_key": "split.handedness.pin"}, | ||||
|     "SPLIT_USB_DETECT": {"info_key": "split.usb_detect.enabled", "value_type": "flag"}, | ||||
|  | ||||
| @ -13,6 +13,7 @@ | ||||
| 
 | ||||
|     "AUDIO_DRIVER": {"info_key": "audio.driver"}, | ||||
|     "BACKLIGHT_DRIVER": {"info_key": "backlight.driver"}, | ||||
|     "BATTERY_DRIVER": {"info_key": "battery.driver"}, | ||||
|     "BLUETOOTH_DRIVER": {"info_key": "bluetooth.driver"}, | ||||
|     "BOARD": {"info_key": "board"}, | ||||
|     "BOOTLOADER": {"info_key": "bootloader", "warn_duplicate": false}, | ||||
| @ -53,8 +54,8 @@ | ||||
|     "WS2812_DRIVER": {"info_key": "ws2812.driver"}, | ||||
| 
 | ||||
|     // Items we want flagged in lint | ||||
|     "DEFAULT_FOLDER": {"info_key": "_deprecated.default_folder", "deprecated": true}, | ||||
|     "CTPC": {"info_key": "_invalid.ctpc", "invalid": true, "replace_with": "CONVERT_TO=proton_c"}, | ||||
|     "CONVERT_TO_PROTON_C": {"info_key": "_invalid.ctpc", "invalid": true, "replace_with": "CONVERT_TO=proton_c"}, | ||||
|     "DEFAULT_FOLDER": {"info_key": "_invalid.default_folder", "invalid": true}, | ||||
|     "VIAL_ENABLE": {"info_key": "_invalid.vial", "invalid": true} | ||||
| } | ||||
|  | ||||
| @ -68,6 +68,81 @@ | ||||
|     "bakeneko80": { | ||||
|         "target": "kkatano/bakeneko80" | ||||
|     }, | ||||
|     "bastardkb/charybdis/3x5/v2/elitec": { | ||||
|         "target": "bastardkb/charybdis/3x5/elitec" | ||||
|     }, | ||||
|     "bastardkb/charybdis/3x5/v2/splinky_2": { | ||||
|         "target": "bastardkb/charybdis/3x5/elitec" | ||||
|     }, | ||||
|     "bastardkb/charybdis/3x5/v2/splinky_3": { | ||||
|         "target": "bastardkb/charybdis/3x5/elitec" | ||||
|     }, | ||||
|     "bastardkb/charybdis/3x5/v2/stemcell": { | ||||
|         "target": "bastardkb/charybdis/3x5/elitec" | ||||
|     }, | ||||
|     "bastardkb/charybdis/3x6/v2/elitec": { | ||||
|         "target": "bastardkb/charybdis/3x6/elitec" | ||||
|     }, | ||||
|     "bastardkb/charybdis/3x6/v2/splinky_2": { | ||||
|         "target": "bastardkb/charybdis/3x6/elitec" | ||||
|     }, | ||||
|     "bastardkb/charybdis/3x6/v2/splinky_3": { | ||||
|         "target": "bastardkb/charybdis/3x6/elitec" | ||||
|     }, | ||||
|     "bastardkb/charybdis/3x6/v2/stemcell": { | ||||
|         "target": "bastardkb/charybdis/3x6/elitec" | ||||
|     }, | ||||
|     "bastardkb/charybdis/4x6/v2/elitec": { | ||||
|         "target": "bastardkb/charybdis/4x6/elitec" | ||||
|     }, | ||||
|     "bastardkb/charybdis/4x6/v2/splinky_2": { | ||||
|         "target": "bastardkb/charybdis/4x6/elitec" | ||||
|     }, | ||||
|     "bastardkb/charybdis/4x6/v2/splinky_3": { | ||||
|         "target": "bastardkb/charybdis/4x6/elitec" | ||||
|     }, | ||||
|     "bastardkb/charybdis/4x6/v2/stemcell": { | ||||
|         "target": "bastardkb/charybdis/4x6/elitec" | ||||
|     }, | ||||
|     "bastardkb/dilemma/3x5_2/splinky": { | ||||
|         "target": "bastardkb/dilemma/3x5_2/promicro" | ||||
|     }, | ||||
|     "bastardkb/scylla/v2/elitec": { | ||||
|         "target": "bastardkb/scylla/promicro" | ||||
|     }, | ||||
|     "bastardkb/scylla/v2/splinky_2": { | ||||
|         "target": "bastardkb/scylla/promicro" | ||||
|     }, | ||||
|     "bastardkb/scylla/v2/splinky_3": { | ||||
|         "target": "bastardkb/scylla/promicro" | ||||
|     }, | ||||
|     "bastardkb/scylla/v2/stemcell": { | ||||
|         "target": "bastardkb/scylla/promicro" | ||||
|     }, | ||||
|     "bastardkb/skeletyl/v2/elitec": { | ||||
|         "target": "bastardkb/skeletyl/promicro" | ||||
|     }, | ||||
|     "bastardkb/skeletyl/v2/splinky_2": { | ||||
|         "target": "bastardkb/skeletyl/promicro" | ||||
|     }, | ||||
|     "bastardkb/skeletyl/v2/splinky_3": { | ||||
|         "target": "bastardkb/skeletyl/promicro" | ||||
|     }, | ||||
|     "bastardkb/skeletyl/v2/stemcell": { | ||||
|         "target": "bastardkb/skeletyl/promicro" | ||||
|     }, | ||||
|     "bastardkb/tbkmini/v2/elitec": { | ||||
|         "target": "bastardkb/tbkmini/promicro" | ||||
|     }, | ||||
|     "bastardkb/tbkmini/v2/splinky_2": { | ||||
|         "target": "bastardkb/tbkmini/promicro" | ||||
|     }, | ||||
|     "bastardkb/tbkmini/v2/splinky_3": { | ||||
|         "target": "bastardkb/tbkmini/promicro" | ||||
|     }, | ||||
|     "bastardkb/tbkmini/v2/stemcell": { | ||||
|         "target": "bastardkb/tbkmini/promicro" | ||||
|     }, | ||||
|     "bear_face": { | ||||
|         "target": "bear_face/v1" | ||||
|     }, | ||||
| @ -257,44 +332,11 @@ | ||||
|     "handwired/jscotto/scottostarter": { | ||||
|         "target": "handwired/scottokeebs/scottostarter" | ||||
|     }, | ||||
|     "helix/pico/sc/back": { | ||||
|         "target": "helix/pico/sc" | ||||
|     "helix": { | ||||
|         "target": "helix/beta" | ||||
|     }, | ||||
|     "helix/pico/sc/under": { | ||||
|         "target": "helix/pico/sc" | ||||
|     }, | ||||
|     "helix/rev2/back/oled": { | ||||
|         "target": "helix/rev2/back" | ||||
|     }, | ||||
|     "helix/rev2/oled": { | ||||
|         "target": "helix/rev2" | ||||
|     }, | ||||
|     "helix/rev2/oled/back": { | ||||
|         "target": "helix/rev2/back" | ||||
|     }, | ||||
|     "helix/rev2/oled/under": { | ||||
|         "target": "helix/rev2/under" | ||||
|     }, | ||||
|     "helix/rev2/sc/back": { | ||||
|         "target": "helix/rev2/sc" | ||||
|     }, | ||||
|     "helix/rev2/sc/oled": { | ||||
|         "target": "helix/rev2/sc" | ||||
|     }, | ||||
|     "helix/rev2/sc/oledback": { | ||||
|         "target": "helix/rev2/sc" | ||||
|     }, | ||||
|     "helix/rev2/sc/oledunder": { | ||||
|         "target": "helix/rev2/sc" | ||||
|     }, | ||||
|     "helix/rev2/sc/under": { | ||||
|         "target": "helix/rev2/sc" | ||||
|     }, | ||||
|     "helix/rev2/under": { | ||||
|         "target": "helix/rev2/sc" | ||||
|     }, | ||||
|     "helix/rev2/under/oled": { | ||||
|         "target": "helix/rev2/under" | ||||
|     "helix/rev2": { | ||||
|         "target": "helix/beta" | ||||
|     }, | ||||
|     "honeycomb": { | ||||
|         "target": "keyhive/honeycomb" | ||||
| @ -407,6 +449,9 @@ | ||||
|     "lfkeyboards/smk65": { | ||||
|         "target": "lfkeyboards/smk65/revb" | ||||
|     }, | ||||
|     "ll3macorn/bongopad": { | ||||
|         "target": "ll3ma/bongopad" | ||||
|     }, | ||||
|     "m3v3van": { | ||||
|         "target": "matthewdias/m3n3van" | ||||
|     }, | ||||
| @ -1881,6 +1926,12 @@ | ||||
|     "kin80": { | ||||
|         "target": "kin80/blackpill401" | ||||
|     }, | ||||
|     "kprepublic/cstc40/daughterboard": { | ||||
|         "target": "kprepublic/cstc40/rev1" | ||||
|     }, | ||||
|     "kprepublic/cstc40/single_pcb": { | ||||
|         "target": "kprepublic/cstc40/rev2" | ||||
|     }, | ||||
|     "kumaokobo/kudox_full": { | ||||
|         "target": "kumaokobo/kudox_full/rev1" | ||||
|     }, | ||||
| @ -2214,8 +2265,17 @@ | ||||
|     "trnthsn/s6xty5neor2": { | ||||
|         "target": "trnthsn/s6xty5neor2/stm32f103" | ||||
|     }, | ||||
|     "tweetydabird/lotus58": { | ||||
|         "target": "tweetydabird/lotus58/promicro" | ||||
|     "tweetydabird/lotus58/elite_c": { | ||||
|         "target": "tweetydabird/lotus58" | ||||
|     }, | ||||
|     "tweetydabird/lotus58/nanoboot": { | ||||
|         "target": "tweetydabird/lotus58" | ||||
|     }, | ||||
|     "tweetydabird/lotus58/promicro": { | ||||
|         "target": "tweetydabird/lotus58" | ||||
|     }, | ||||
|     "tweetydabird/lotus58/rp2040_ce": { | ||||
|         "target": "tweetydabird/lotus58" | ||||
|     }, | ||||
|     "unison": { | ||||
|         "target": "unison/v04" | ||||
| @ -2258,5 +2318,54 @@ | ||||
|     }, | ||||
|     "zsa/planck_ez": { | ||||
|         "target": "zsa/planck_ez/base" | ||||
|     }, | ||||
|     // DEFAULT_FOLDER removed during 2025 Q3 cycle | ||||
|     "cannonkeys/satisfaction75": { | ||||
|         "target": "cannonkeys/satisfaction75/rev1" | ||||
|     }, | ||||
|     "converter/adb_usb": { | ||||
|         "target": "converter/adb_usb/rev1" | ||||
|     }, | ||||
|     "converter/sun_usb": { | ||||
|         "target": "converter/sun_usb/type5" | ||||
|     }, | ||||
|     "converter/usb_usb": { | ||||
|         "target": "converter/usb_usb/hasu" | ||||
|     }, | ||||
|     "durgod/dgk6x": { | ||||
|         "target": "durgod/dgk6x/hades_ansi" | ||||
|     }, | ||||
|     "ergodox_ez": { | ||||
|         "target": "ergodox_ez/base" | ||||
|     }, | ||||
|     "ferris/0_2": { | ||||
|         "target": "ferris/0_2/base" | ||||
|     }, | ||||
|     "handwired/dygma/raise": { | ||||
|         "target": "handwired/dygma/raise/ansi" | ||||
|     }, | ||||
|     "helix/rev3_4rows": { | ||||
|         "target": "helix/rev3" | ||||
|     }, | ||||
|     "helix/rev3_5rows": { | ||||
|         "target": "helix/rev3" | ||||
|     }, | ||||
|     "ibm/model_m/mschwingen": { | ||||
|         "target": "ibm/model_m/mschwingen/led_wired" | ||||
|     }, | ||||
|     "mechwild/sugarglider": { | ||||
|         "target": "mechwild/sugarglider/wide_oled/f401" | ||||
|     }, | ||||
|     "mechwild/sugarglider/wide_oled": { | ||||
|         "target": "mechwild/sugarglider/wide_oled/f401" | ||||
|     }, | ||||
|     "novelkeys/nk65": { | ||||
|         "target": "novelkeys/nk65/v1" | ||||
|     }, | ||||
|     "novelkeys/nk65/base": { | ||||
|         "target": "novelkeys/nk65/v1" | ||||
|     }, | ||||
|     "sirius/uni660/rev2": { | ||||
|         "target": "sirius/uni660/rev2/ansi" | ||||
|     } | ||||
| } | ||||
|  | ||||
| @ -188,6 +188,28 @@ | ||||
|                 "as_caps_lock": {"type": "boolean"} | ||||
|             } | ||||
|         }, | ||||
|         "battery": { | ||||
|             "type": "object", | ||||
|             "additionalProperties": false, | ||||
|             "properties": { | ||||
|                 "driver": { | ||||
|                     "type": "string", | ||||
|                     "enum": ["adc", "custom", "vendor"] | ||||
|                 }, | ||||
|                 "adc": { | ||||
|                     "type": "object", | ||||
|                     "additionalProperties": false, | ||||
|                     "properties": { | ||||
|                         "pin": {"$ref": "./definitions.jsonschema#/mcu_pin"}, | ||||
|                         "reference_voltage": {"type": "integer"}, | ||||
|                         "divider_r1": {"type": "integer"}, | ||||
|                         "divider_r2": {"type": "integer"}, | ||||
|                         "resolution": {"type": "integer"} | ||||
|                     } | ||||
|                 }, | ||||
|                 "sample_interval": {"type": "integer"} | ||||
|             } | ||||
|         }, | ||||
|         "bluetooth": { | ||||
|             "type": "object", | ||||
|             "additionalProperties": false, | ||||
| @ -473,6 +495,7 @@ | ||||
|                 "ghost": {"type": "boolean"}, | ||||
|                 "input_pressed_state": {"$ref": "./definitions.jsonschema#/unsigned_int"}, | ||||
|                 "io_delay": {"$ref": "./definitions.jsonschema#/unsigned_int"}, | ||||
|                 "masked": {"type": "boolean"}, | ||||
|                 "direct": { | ||||
|                     "type": "array", | ||||
|                     "items": {"$ref": "./definitions.jsonschema#/mcu_pin_array"} | ||||
| @ -863,8 +886,7 @@ | ||||
|                 }, | ||||
|                 "soft_serial_speed": { | ||||
|                     "type": "integer", | ||||
|                     "minimum": 0, | ||||
|                     "maximum": 5 | ||||
|                     "$comment": "Deprecated: use split.serial.speed instead" | ||||
|                 }, | ||||
|                 "serial": { | ||||
|                     "type": "object", | ||||
| @ -874,7 +896,12 @@ | ||||
|                             "type": "string", | ||||
|                             "enum": ["bitbang", "usart", "vendor"] | ||||
|                         }, | ||||
|                         "pin": {"$ref": "./definitions.jsonschema#/mcu_pin"} | ||||
|                         "pin": {"$ref": "./definitions.jsonschema#/mcu_pin"}, | ||||
|                         "speed": { | ||||
|                             "type": "integer", | ||||
|                             "minimum": 0, | ||||
|                             "maximum": 5 | ||||
|                         } | ||||
|                     } | ||||
|                 }, | ||||
|                 "transport": { | ||||
|  | ||||
							
								
								
									
										181
									
								
								docs/ChangeLog/20250831.md
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										181
									
								
								docs/ChangeLog/20250831.md
									
									
									
									
									
										Normal file
									
								
							| @ -0,0 +1,181 @@ | ||||
| # QMK Breaking Changes - 2025 Aug 31 Changelog | ||||
| 
 | ||||
| ## Changes Requiring User Action | ||||
| 
 | ||||
| ### Updated Keyboard Codebases | ||||
| 
 | ||||
| | Old Keyboard Name                    | New Keyboard Name                | | ||||
| |--------------------------------------|----------------------------------| | ||||
| | bastardkb/charybdis/3x5/v2/elitec    | bastardkb/charybdis/3x5/elitec   | | ||||
| | bastardkb/charybdis/3x5/v2/splinky_2 | bastardkb/charybdis/3x5/elitec   | | ||||
| | bastardkb/charybdis/3x5/v2/splinky_3 | bastardkb/charybdis/3x5/elitec   | | ||||
| | bastardkb/charybdis/3x5/v2/stemcell  | bastardkb/charybdis/3x5/elitec   | | ||||
| | bastardkb/charybdis/3x6/v2/elitec    | bastardkb/charybdis/3x6/elitec   | | ||||
| | bastardkb/charybdis/3x6/v2/splinky_2 | bastardkb/charybdis/3x6/elitec   | | ||||
| | bastardkb/charybdis/3x6/v2/splinky_3 | bastardkb/charybdis/3x6/elitec   | | ||||
| | bastardkb/charybdis/3x6/v2/stemcell  | bastardkb/charybdis/3x6/elitec   | | ||||
| | bastardkb/charybdis/4x6/v2/elitec    | bastardkb/charybdis/4x6/elitec   | | ||||
| | bastardkb/charybdis/4x6/v2/splinky_2 | bastardkb/charybdis/4x6/elitec   | | ||||
| | bastardkb/charybdis/4x6/v2/splinky_3 | bastardkb/charybdis/4x6/elitec   | | ||||
| | bastardkb/charybdis/4x6/v2/stemcell  | bastardkb/charybdis/4x6/elitec   | | ||||
| | bastardkb/dilemma/3x5_2/splinky      | bastardkb/dilemma/3x5_2/promicro | | ||||
| | bastardkb/scylla/v2/elitec           | bastardkb/scylla/promicro        | | ||||
| | bastardkb/scylla/v2/splinky_2        | bastardkb/scylla/promicro        | | ||||
| | bastardkb/scylla/v2/splinky_3        | bastardkb/scylla/promicro        | | ||||
| | bastardkb/scylla/v2/stemcell         | bastardkb/scylla/promicro        | | ||||
| | bastardkb/skeletyl/v2/elitec         | bastardkb/skeletyl/promicro      | | ||||
| | bastardkb/skeletyl/v2/splinky_2      | bastardkb/skeletyl/promicro      | | ||||
| | bastardkb/skeletyl/v2/splinky_3      | bastardkb/skeletyl/promicro      | | ||||
| | bastardkb/skeletyl/v2/stemcell       | bastardkb/skeletyl/promicro      | | ||||
| | bastardkb/tbkmini/v2/elitec          | bastardkb/tbkmini/promicro       | | ||||
| | bastardkb/tbkmini/v2/splinky_2       | bastardkb/tbkmini/promicro       | | ||||
| | bastardkb/tbkmini/v2/splinky_3       | bastardkb/tbkmini/promicro       | | ||||
| | bastardkb/tbkmini/v2/stemcell        | bastardkb/tbkmini/promicro       | | ||||
| | helix/rev2                           | helix/beta                       | | ||||
| | helix/rev3_4rows                     | helix/rev3                       | | ||||
| | helix/rev3_5rows                     | helix/rev3                       | | ||||
| | kprepublic/cstc40/daughterboard      | kprepublic/cstc40/rev1           | | ||||
| | kprepublic/cstc40/single_pcb         | kprepublic/cstc40/rev2           | | ||||
| | ll3macorn/bongopad                   | ll3ma/bongopad                   | | ||||
| | novelkeys/nk65/base                  | novelkeys/nk65/v1                | | ||||
| | tweetydabird/lotus58/elite_c         | tweetydabird/lotus58             | | ||||
| | tweetydabird/lotus58/nanoboot        | tweetydabird/lotus58             | | ||||
| | tweetydabird/lotus58/promicro        | tweetydabird/lotus58             | | ||||
| | tweetydabird/lotus58/rp2040_ce       | tweetydabird/lotus58             | | ||||
| 
 | ||||
| ### Mitigate VIA keylogger security issues [#25414](https://github.com/qmk/qmk_firmware/pull/25414) | ||||
| 
 | ||||
| VIA's keyboard matrix testing functionality, which allows users to identify active key presses, has been identified as a potential security concern by community members and security researchers. This feature has been demonstrated to enable unauthorized keystroke capture, with documented examples showing how malicious scripts could exploit this capability to create keyloggers. A recent security assessment revealed that user credentials could be compromised by exploiting the matrix testing function combined with VIA's keycode assignment queries. In this attack scenario, a script could remain active during a locked session and capture password input when users authenticate upon return. | ||||
| 
 | ||||
| The QMK team notified the VIA team of this security vulnerability on May 17, 2022, and made multiple subsequent attempts to coordinate a mitigation strategy. Despite repeated outreach, the VIA team has provided no acknowledgment or response to these security concerns. Given the severity of the potential security implications and the lack of engagement from the VIA team, the QMK team has unilaterally implemented a security enhancement that modifies the keyboard matrix testing functionality to prevent the reporting of key press events. This change prioritizes user security and data protection over potential feature compatibility concerns within VIA. | ||||
| 
 | ||||
| ## Deprecation Notices | ||||
| 
 | ||||
| In line with the [notice period](../support_deprecation_policy#how-much-advance-notice-will-be-given), deprecation notices for larger items are listed here. | ||||
| 
 | ||||
| ### `DEFAULT_FOLDER` removal ([#23281](https://github.com/qmk/qmk_firmware/pull/23281)) | ||||
| 
 | ||||
| `DEFAULT_FOLDER` was originally introduced to work around limitations within the build system. | ||||
| Parent folders containing common configuration would create invalid build targets. | ||||
| 
 | ||||
| With the introduction of [`keyboard.json`](./20240526#keyboard-json) as a configuration file, the build system now has a consistent method to detect build targets. | ||||
| The `DEFAULT_FOLDER` functionality is now removed with the intent that `rules.mk` is now pure configuration. | ||||
| 
 | ||||
| Backwards compatibility of build targets has been maintained where possible. | ||||
| 
 | ||||
| ### Converter `Pin Compatible` updates ([#20330](https://github.com/qmk/qmk_firmware/pull/20330)) | ||||
| 
 | ||||
| Converter support has been further limited to only function if a keyboard declares that it is compatible. | ||||
| 
 | ||||
| This can be configured in the following ways: | ||||
| 
 | ||||
| :::::tabs | ||||
| 
 | ||||
| ==== keyboard.json | ||||
| 
 | ||||
| ```json [keyboard.json] | ||||
| { | ||||
|     "development_board": "promicro", // [!code focus] | ||||
| } | ||||
| ``` | ||||
| 
 | ||||
| ==== rules.mk | ||||
| 
 | ||||
| ```make [rules.mk] | ||||
| PIN_COMPATIBLE = promicro | ||||
| ``` | ||||
| 
 | ||||
| ::::: | ||||
| 
 | ||||
| see the [Converters Feature](../feature_converters) documentation for more information. | ||||
| 
 | ||||
| ### Removal of deprecated RGB and Mouse keycodes ([#25444](https://github.com/qmk/qmk_firmware/pull/25444)) | ||||
| 
 | ||||
| Backwards compatibility of deprecated RGB and Mouse keycodes has been removed. | ||||
| 
 | ||||
| See the following documentation for the list of currently supported keycodes: | ||||
| 
 | ||||
| * [RGB Lighting](../features/rgblight#keycodes) | ||||
| * [RGB Matrix](../features/rgb_matrix#keycodes) | ||||
| * [Mouse keys](../features/mouse_keys#mapping-mouse-actions) | ||||
| 
 | ||||
| ## Full changelist | ||||
| 
 | ||||
| Core: | ||||
| * Remove converter assumption that everything is a promicro ([#20330](https://github.com/qmk/qmk_firmware/pull/20330)) | ||||
| * Remove `DEFAULT_FOLDER` handling ([#23281](https://github.com/qmk/qmk_firmware/pull/23281)) | ||||
| * Add core handling for pointing device failures. ([#25315](https://github.com/qmk/qmk_firmware/pull/25315)) | ||||
| * Relocate remaining `process_record_quantum` keycodes ([#25328](https://github.com/qmk/qmk_firmware/pull/25328)) | ||||
| * Remove `process_action_kb` callback ([#25331](https://github.com/qmk/qmk_firmware/pull/25331)) | ||||
| * Add `{rgb|led}_matrix_get_mode_name()`. ([#25344](https://github.com/qmk/qmk_firmware/pull/25344)) | ||||
| * Align sleep_led logic ([#25395](https://github.com/qmk/qmk_firmware/pull/25395)) | ||||
| * Mitigate VIA keylogger security issues ([#25414](https://github.com/qmk/qmk_firmware/pull/25414)) | ||||
| * Deprecate some nonstandard mod & mod-tap keycode aliases ([#25437](https://github.com/qmk/qmk_firmware/pull/25437)) | ||||
| * Refactor Starlight Smooth matrix effect ([#25442](https://github.com/qmk/qmk_firmware/pull/25442)) | ||||
| * Remove deprecated `RGB_` and Mouse keycodes ([#25444](https://github.com/qmk/qmk_firmware/pull/25444)) | ||||
| * Configure SPI for `QMK_PM2040` board ([#25481](https://github.com/qmk/qmk_firmware/pull/25481)) | ||||
| * Configure SPI for `STEMCELL` board ([#25486](https://github.com/qmk/qmk_firmware/pull/25486)) | ||||
| * Configure SPI for `QMK_BLOK` board ([#25487](https://github.com/qmk/qmk_firmware/pull/25487)) | ||||
| * Clamp reactive offset value ([#25489](https://github.com/qmk/qmk_firmware/pull/25489)) | ||||
| * Relocate `AUDIO_INIT_DELAY` implementation ([#25491](https://github.com/qmk/qmk_firmware/pull/25491)) | ||||
| * Add MATRIX_ROWS_PER_HAND definition ([#25513](https://github.com/qmk/qmk_firmware/pull/25513)) | ||||
| * Refactor battery driver ([#25550](https://github.com/qmk/qmk_firmware/pull/25550)) | ||||
| * Add cachyos as pattern when installing dependencies ([#25580](https://github.com/qmk/qmk_firmware/pull/25580)) | ||||
| 
 | ||||
| CLI: | ||||
| * Add MATRIX_MASKED DD config ([#25383](https://github.com/qmk/qmk_firmware/pull/25383)) | ||||
| * Ensure keyboard aliases do not point to themselves ([#25500](https://github.com/qmk/qmk_firmware/pull/25500)) | ||||
| 
 | ||||
| Keyboards: | ||||
| * [Update] E8ghtyNeo caps indicator ([#25009](https://github.com/qmk/qmk_firmware/pull/25009)) | ||||
| * Keychron C3 Pro `c3_pro.c` corrections ([#25049](https://github.com/qmk/qmk_firmware/pull/25049)) | ||||
| * Update franky36 pid and vid ([#25160](https://github.com/qmk/qmk_firmware/pull/25160)) | ||||
| * Added Encoder support for Soyuz ([#25279](https://github.com/qmk/qmk_firmware/pull/25279)) | ||||
| * CSTC40 rev3 (FXTWINK) ([#25285](https://github.com/qmk/qmk_firmware/pull/25285)) | ||||
| * Migrate remaining `DEFAULT_FOLDER` to keyboard aliases ([#25291](https://github.com/qmk/qmk_firmware/pull/25291)) | ||||
| * Configure boards to use development_board - R ([#25316](https://github.com/qmk/qmk_firmware/pull/25316)) | ||||
| * Configure boards to use development_board - P ([#25317](https://github.com/qmk/qmk_firmware/pull/25317)) | ||||
| * Configure boards to use development_board - NO ([#25338](https://github.com/qmk/qmk_firmware/pull/25338)) | ||||
| * Configure boards to use development_board - LM ([#25341](https://github.com/qmk/qmk_firmware/pull/25341)) | ||||
| * maple_computing/launchpad - Remove broken `default_rgb` keymap ([#25342](https://github.com/qmk/qmk_firmware/pull/25342)) | ||||
| * update winry25 VID and PID ([#25351](https://github.com/qmk/qmk_firmware/pull/25351)) | ||||
| * Configure boards to use development_board - DE ([#25369](https://github.com/qmk/qmk_firmware/pull/25369)) | ||||
| * Configure boards to use development_board - FGHIJ ([#25370](https://github.com/qmk/qmk_firmware/pull/25370)) | ||||
| * refactor(mercutio): layouts & reformatting ([#25408](https://github.com/qmk/qmk_firmware/pull/25408)) | ||||
| * Configure boards to use development_board - ABC ([#25417](https://github.com/qmk/qmk_firmware/pull/25417)) | ||||
| * Configure boards to use development_board - K ([#25421](https://github.com/qmk/qmk_firmware/pull/25421)) | ||||
| * Refactor `helix/pico` ([#25428](https://github.com/qmk/qmk_firmware/pull/25428)) | ||||
| * Refactor `helix/rev2` ([#25429](https://github.com/qmk/qmk_firmware/pull/25429)) | ||||
| * Refactor `helix/rev3_{4,5}rows` ([#25430](https://github.com/qmk/qmk_firmware/pull/25430)) | ||||
| * Migrate `helix` common configuration ([#25433](https://github.com/qmk/qmk_firmware/pull/25433)) | ||||
| * Refactor `bastardkb/tbkmini` ([#25438](https://github.com/qmk/qmk_firmware/pull/25438)) | ||||
| * Convert `novelkeys/nk65` to use RGB Matrix ([#25450](https://github.com/qmk/qmk_firmware/pull/25450)) | ||||
| * Convert moon to lite custom matrix ([#25452](https://github.com/qmk/qmk_firmware/pull/25452)) | ||||
| * Refactor `bastardkb/skeletyl` ([#25456](https://github.com/qmk/qmk_firmware/pull/25456)) | ||||
| * Refactor `bastardkb/scylla` ([#25459](https://github.com/qmk/qmk_firmware/pull/25459)) | ||||
| * Refactor `bastardkb/dilemma/3x5_2` ([#25462](https://github.com/qmk/qmk_firmware/pull/25462)) | ||||
| * Migrate `usb.force_nkro` to `host.default.nkro` ([#25468](https://github.com/qmk/qmk_firmware/pull/25468)) | ||||
| * Give mouse report to pointing_device_task_user first in ploopyco devices ([#25475](https://github.com/qmk/qmk_firmware/pull/25475)) | ||||
| * Refactor `bastardkb/charybdis/3x5` ([#25488](https://github.com/qmk/qmk_firmware/pull/25488)) | ||||
| * Refactor `bastardkb/charybdis/3x6` ([#25493](https://github.com/qmk/qmk_firmware/pull/25493)) | ||||
| * Refactor `bastardkb/charybdis/4x6` ([#25494](https://github.com/qmk/qmk_firmware/pull/25494)) | ||||
| * Rebrand For Ll3ma Keyboards ([#25498](https://github.com/qmk/qmk_firmware/pull/25498)) | ||||
| * Remove some encoder resolution that duplicate defaults ([#25517](https://github.com/qmk/qmk_firmware/pull/25517)) | ||||
| * Remove overriding of `DF()` within keyboards ([#25541](https://github.com/qmk/qmk_firmware/pull/25541)) | ||||
| * Refactor inland/kb83 ([#25542](https://github.com/qmk/qmk_firmware/pull/25542)) | ||||
| * Refactor `tweetydabird/lotus58` ([#25547](https://github.com/qmk/qmk_firmware/pull/25547)) | ||||
| * Swap spleeb to default GENERIC_PROMICRO_RP2040 board files ([#25564](https://github.com/qmk/qmk_firmware/pull/25564)) | ||||
| 
 | ||||
| Keyboard fixes: | ||||
| * Fix `keebio/quefrency/rev1:default60` ([#25423](https://github.com/qmk/qmk_firmware/pull/25423)) | ||||
| * Fixup `bastardkb/tbkmini` keymap's build target ([#25458](https://github.com/qmk/qmk_firmware/pull/25458)) | ||||
| * Miscellaneous fixes for lint warnings ([#25469](https://github.com/qmk/qmk_firmware/pull/25469)) | ||||
| * Fix pytest/has_community default keymap location ([#25471](https://github.com/qmk/qmk_firmware/pull/25471)) | ||||
| * Fix serial speed DD configuration & migrate keyboards ([#25546](https://github.com/qmk/qmk_firmware/pull/25546)) | ||||
| * Update rgb x coordinate of rightmost column ([#25556](https://github.com/qmk/qmk_firmware/pull/25556)) | ||||
| 
 | ||||
| Bugs: | ||||
| * Fix buggy switch statement in quantum.c ([#25322](https://github.com/qmk/qmk_firmware/pull/25322)) | ||||
| * Compilation fixes for `-fno-common` ([#25436](https://github.com/qmk/qmk_firmware/pull/25436)) | ||||
| * Only userspace should be searched for keyboard aliases when locating keymaps ([#25477](https://github.com/qmk/qmk_firmware/pull/25477)) | ||||
| * Allow `qmk flash <filename>` to flash AT32 boards ([#25497](https://github.com/qmk/qmk_firmware/pull/25497)) | ||||
| @ -175,6 +175,7 @@ | ||||
|                         ] | ||||
|                     }, | ||||
|                     { "text": "Audio", "link": "/features/audio" }, | ||||
|                     { "text": "Battery", "link": "/features/battery" }, | ||||
|                     { "text": "Bootmagic", "link": "/features/bootmagic" }, | ||||
|                     { "text": "Converters", "link": "/feature_converters" }, | ||||
|                     { "text": "Custom Matrix", "link": "/custom_matrix" }, | ||||
| @ -213,7 +214,7 @@ | ||||
|                     { "text": "My Pull Request Was Flagged", "link": "/breaking_changes_instructions" }, | ||||
|                     { | ||||
|                         "text": "Most Recent ChangeLog", | ||||
|                         "link": "/ChangeLog/20250525" | ||||
|                         "link": "/ChangeLog/20250831" | ||||
|                     }, | ||||
|                     { "text": "Past Breaking Changes", "link": "/breaking_changes_history" }, | ||||
|                     { "text": "Deprecation Policy", "link": "/support_deprecation_policy" } | ||||
|  | ||||
| @ -10,25 +10,25 @@ Practically, this means QMK merges the `develop` branch into the `master` branch | ||||
| 
 | ||||
| ## What has been included in past Breaking Changes? | ||||
| 
 | ||||
| * [2025 Aug 31](ChangeLog/20250831) | ||||
| * [2025 May 25](ChangeLog/20250525) | ||||
| * [2025 Feb 23](ChangeLog/20250223) | ||||
| * [2024 Nov 24](ChangeLog/20241124) | ||||
| * [Older Breaking Changes](breaking_changes_history) | ||||
| 
 | ||||
| ## When is the next Breaking Change? | ||||
| 
 | ||||
| The next Breaking Change is scheduled for Aug 31, 2025. | ||||
| The next Breaking Change is scheduled for November 30, 2025. | ||||
| 
 | ||||
| ### Important Dates | ||||
| 
 | ||||
| * 2025 May 25 - `develop` is tagged with a new release version. Each push to `master` is subsequently merged to `develop` by GitHub actions. | ||||
| * 2025 Aug 3 - `develop` closed to new PRs. | ||||
| * 2025 Aug 3 - Call for testers. | ||||
| * 2025 Aug 17 - Last day for merges -- after this point `develop` is locked for testing and accepts only bugfixes | ||||
| * 2025 Aug 24 - `develop` is locked, only critical bugfix PRs merged. | ||||
| * 2025 Aug 29 - `master` is locked, no PRs merged. | ||||
| * 2025 Aug 31 - Merge `develop` to `master`. | ||||
| * 2025 Aug 31 - `master` is unlocked. PRs can be merged again. | ||||
| * 2025 Aug 31 - `develop` is tagged with a new release version. Each push to `master` is subsequently merged to `develop` by GitHub actions. | ||||
| * 2025 Nov 2 - `develop` closed to new PRs. | ||||
| * 2025 Nov 2 - Call for testers. | ||||
| * 2025 Nov 16 - Last day for merges -- after this point `develop` is locked for testing and accepts only bugfixes | ||||
| * 2025 Nov 23 - `develop` is locked, only critical bugfix PRs merged. | ||||
| * 2025 Nov 28 - `master` is locked, no PRs merged. | ||||
| * 2025 Nov 30 - Merge `develop` to `master`. | ||||
| * 2025 Nov 30 - `master` is unlocked. PRs can be merged again. | ||||
| 
 | ||||
| ## What changes will be included? | ||||
| 
 | ||||
|  | ||||
| @ -2,6 +2,7 @@ | ||||
| 
 | ||||
| This page links to all previous changelogs from the QMK Breaking Changes process. | ||||
| 
 | ||||
| * [2025 Aug 31](ChangeLog/20250831) - version 0.30.0 | ||||
| * [2025 May 25](ChangeLog/20250525) - version 0.29.0 | ||||
| * [2025 Feb 23](ChangeLog/20250223) - version 0.28.0 | ||||
| * [2024 Nov 24](ChangeLog/20241124) - version 0.27.0 | ||||
|  | ||||
| @ -364,8 +364,6 @@ This is a [make](https://www.gnu.org/software/make/manual/make.html) file that i | ||||
| 
 | ||||
| ## Build Options | ||||
| 
 | ||||
| * `DEFAULT_FOLDER` | ||||
|   * Used to specify a default folder when a keyboard has more than one sub-folder. | ||||
| * `FIRMWARE_FORMAT` | ||||
|   * Defines which format (bin, hex) is copied to the root `qmk_firmware` folder after building. | ||||
| * `SRC` | ||||
|  | ||||
| @ -1,6 +1,6 @@ | ||||
| # Battery Driver | ||||
| 
 | ||||
| This driver provides support for sampling battery level. | ||||
| This driver provides support for directly sampling battery level. | ||||
| 
 | ||||
| ## Usage | ||||
| 
 | ||||
| @ -10,21 +10,17 @@ To use this driver, add the following to your `rules.mk`: | ||||
| BATTERY_DRIVER_REQUIRED = yes | ||||
| ``` | ||||
| 
 | ||||
| ## Basic Configuration {#basic-configuration} | ||||
| 
 | ||||
| Add the following to your `config.h`: | ||||
| 
 | ||||
| |Define                    |Default |Description                                       | | ||||
| |--------------------------|--------|--------------------------------------------------| | ||||
| |`BATTERY_SAMPLE_INTERVAL` |`30000` |The time between battery samples in milliseconds. | | ||||
| ::::info Note | ||||
| This is already configured for you if you are using the [Battery](../features/battery) feature. | ||||
| :::: | ||||
| 
 | ||||
| ## Driver Configuration {#driver-configuration} | ||||
| 
 | ||||
| Driver selection can be configured in `rules.mk` as `BATTERY_DRIVER`. Valid values are `adc` (default), `vendor`, or `custom`. See below for information on individual drivers. | ||||
| Driver selection can be configured in `rules.mk` as `BATTERY_DRIVER`. Valid values are `adc`, `vendor`, or `custom`. See below for information on individual drivers. | ||||
| 
 | ||||
| ### ADC Driver {#adc-driver} | ||||
| 
 | ||||
| This is the default battery driver. The default configuration assumes the battery is connected to a ADC capable pin through a voltage divider. | ||||
| The default configuration assumes the battery is connected to a ADC capable pin through a voltage divider. | ||||
| 
 | ||||
| ```make | ||||
| BATTERY_DRIVER = adc | ||||
| @ -32,42 +28,25 @@ BATTERY_DRIVER = adc | ||||
| 
 | ||||
| The following `#define`s apply only to the `adc` driver: | ||||
| 
 | ||||
| |Define                       |Default       |Description                                                   | | ||||
| |-----------------------------|--------------|--------------------------------------------------------------| | ||||
| |`BATTERY_PIN`                |*Not defined* |The GPIO pin connected to the voltage divider.                | | ||||
| |`BATTERY_REF_VOLTAGE_MV`     |`3300`        |The ADC reverence voltage, in millivolts.                     | | ||||
| |`BATTERY_VOLTAGE_DIVIDER_R1` |`100`         |The voltage divider resistance, in kOhm. Set to 0 to disable. | | ||||
| |`BATTERY_VOLTAGE_DIVIDER_R2` |`100`         |The voltage divider resistance, in kOhm. Set to 0 to disable. | | ||||
| |`BATTERY_ADC_RESOLUTION`     |`10`          |The ADC resolution configured for the ADC Driver.             | | ||||
| |Define                           |Default       |Description                                                   | | ||||
| |---------------------------------|--------------|--------------------------------------------------------------| | ||||
| |`BATTERY_ADC_PIN`                |*Not defined* |The GPIO pin connected to the voltage divider.                | | ||||
| |`BATTERY_ADC_REF_VOLTAGE_MV`     |`3300`        |The ADC reverence voltage, in millivolts.                     | | ||||
| |`BATTERY_ADC_VOLTAGE_DIVIDER_R1` |`100`         |The voltage divider resistance, in kOhm. Set to 0 to disable. | | ||||
| |`BATTERY_ADC_VOLTAGE_DIVIDER_R2` |`100`         |The voltage divider resistance, in kOhm. Set to 0 to disable. | | ||||
| |`BATTERY_ADC_RESOLUTION`         |`10`          |The ADC resolution configured for the ADC Driver.             | | ||||
| 
 | ||||
| ## Functions | ||||
| ### Custom Driver {#custom-driver} | ||||
| 
 | ||||
| ### `uint8_t battery_get_percent(void)` {#api-battery-get-percent} | ||||
| A custom driver is expected to implement the following interface: | ||||
| 
 | ||||
| Sample battery level. | ||||
| ```c | ||||
| void battery_driver_init(void) { | ||||
|     // Perform any initialisation here | ||||
| } | ||||
| 
 | ||||
| #### Return Value {#api-battery-get-percent-return} | ||||
| 
 | ||||
| The battery percentage, in the range 0-100. | ||||
| 
 | ||||
| ## Callbacks | ||||
| 
 | ||||
| ### `void battery_percent_changed_user(uint8_t level)` {#api-battery-percent-changed-user} | ||||
| 
 | ||||
| User hook called when battery level changed. | ||||
| 
 | ||||
| ### Arguments {#api-battery-percent-changed-user-arguments} | ||||
| 
 | ||||
|  - `uint8_t level`   | ||||
|    The battery percentage, in the range 0-100. | ||||
| 
 | ||||
| --- | ||||
| 
 | ||||
| ### `void battery_percent_changed_kb(uint8_t level)` {#api-battery-percent-changed-kb} | ||||
| 
 | ||||
| Keyboard hook called when battery level changed. | ||||
| 
 | ||||
| ### Arguments {#api-battery-percent-changed-kb-arguments} | ||||
| 
 | ||||
|  - `uint8_t level`   | ||||
|    The battery percentage, in the range 0-100. | ||||
| uint8_t battery_driver_sample_percent(void) { | ||||
|     // Read and return current state here | ||||
|     return value; | ||||
| } | ||||
| ``` | ||||
|  | ||||
| @ -2,36 +2,36 @@ | ||||
| 
 | ||||
| These allow you to combine a modifier with a keycode. When pressed, the keydown event for the modifier, then `kc` will be sent. On release, the keyup event for `kc`, then the modifier will be sent. | ||||
| 
 | ||||
| |Key       |Aliases                           |Description                                                                    | | ||||
| |----------|----------------------------------|-------------------------------------------------------------------------------| | ||||
| |`LCTL(kc)`|`C(kc)`                           |Hold Left Control and press `kc`                                               | | ||||
| |`LSFT(kc)`|`S(kc)`                           |Hold Left Shift and press `kc`                                                 | | ||||
| |`LALT(kc)`|`A(kc)`, `LOPT(kc)`               |Hold Left Alt and press `kc`                                                   | | ||||
| |`LGUI(kc)`|`G(kc)`, `LCMD(kc)`, `LWIN(kc)`   |Hold Left GUI and press `kc`                                                   | | ||||
| |`LCS(kc)` |                                  |Hold Left Control and Left Shift and press `kc`                                | | ||||
| |`LCA(kc)` |                                  |Hold Left Control and Left Alt and press `kc`                                  | | ||||
| |`LCG(kc)` |                                  |Hold Left Control and Left GUI and press `kc`                                  | | ||||
| |`LSA(kc)` |                                  |Hold Left Shift and Left Alt and press `kc`                                    | | ||||
| |`LSG(kc)` |`SGUI(kc)`, `SCMD(kc)`, `SWIN(kc)`|Hold Left Shift and Left GUI and press `kc`                                    | | ||||
| |`LAG(kc)` |                                  |Hold Left Alt and Left GUI and press `kc`                                      | | ||||
| |`LCSG(kc)`|                                  |Hold Left Control, Left Shift and Left GUI and press `kc`                      | | ||||
| |`LCAG(kc)`|                                  |Hold Left Control, Left Alt and Left GUI and press `kc`                        | | ||||
| |`LSAG(kc)`|                                  |Hold Left Shift, Left Alt and Left GUI and press `kc`                          | | ||||
| |`RCTL(kc)`|                                  |Hold Right Control and press `kc`                                              | | ||||
| |`RSFT(kc)`|                                  |Hold Right Shift and press `kc`                                                | | ||||
| |`RALT(kc)`|`ROPT(kc)`, `ALGR(kc)`            |Hold Right Alt and press `kc`                                                  | | ||||
| |`RGUI(kc)`|`RCMD(kc)`, `RWIN(kc)`            |Hold Right GUI and press `kc`                                                  | | ||||
| |`RCA(kc)` |                                  |Hold Right Control and Right Alt and press `kc`                                | | ||||
| |`RCS(kc)` |                                  |Hold Right Control and Right Shift and press `kc`                              | | ||||
| |`RCG(kc)` |                                  |Hold Right Control and Right GUI and press `kc`                                | | ||||
| |`RSA(kc)` |`SAGR(kc)`                        |Hold Right Shift and Right Alt and press `kc`                                  | | ||||
| |`RSG(kc)` |                                  |Hold Right Shift and Right GUI and press `kc`                                  | | ||||
| |`RAG(kc)` |                                  |Hold Right Alt and Right GUI and press `kc`                                    | | ||||
| |`RCSG(kc)`|                                  |Hold Right Control, Right Shift and Right GUI and press `kc`                   | | ||||
| |`RCAG(kc)`|                                  |Hold Right Control, Right Alt and Right GUI and press `kc`                     | | ||||
| |`RSAG(kc)`|                                  |Hold Right Shift, Right Alt and Right GUI and press `kc`                       | | ||||
| |`MEH(kc)` |                                  |Hold Left Control, Left Shift and Left Alt and press `kc`                      | | ||||
| |`HYPR(kc)`|                                  |Hold Left Control, Left Shift, Left Alt and Left GUI and press `kc`<sup>1</sup>| | ||||
| |Key       |Aliases                        |Description                                                                    | | ||||
| |----------|-------------------------------|-------------------------------------------------------------------------------| | ||||
| |`LCTL(kc)`|`C(kc)`                        |Hold Left Control and press `kc`                                               | | ||||
| |`LSFT(kc)`|`S(kc)`                        |Hold Left Shift and press `kc`                                                 | | ||||
| |`LALT(kc)`|`A(kc)`, `LOPT(kc)`            |Hold Left Alt and press `kc`                                                   | | ||||
| |`LGUI(kc)`|`G(kc)`, `LCMD(kc)`, `LWIN(kc)`|Hold Left GUI and press `kc`                                                   | | ||||
| |`LCS(kc)` |                               |Hold Left Control and Left Shift and press `kc`                                | | ||||
| |`LCA(kc)` |                               |Hold Left Control and Left Alt and press `kc`                                  | | ||||
| |`LCG(kc)` |                               |Hold Left Control and Left GUI and press `kc`                                  | | ||||
| |`LSA(kc)` |                               |Hold Left Shift and Left Alt and press `kc`                                    | | ||||
| |`LSG(kc)` |                               |Hold Left Shift and Left GUI and press `kc`                                    | | ||||
| |`LAG(kc)` |                               |Hold Left Alt and Left GUI and press `kc`                                      | | ||||
| |`LCSG(kc)`|                               |Hold Left Control, Left Shift and Left GUI and press `kc`                      | | ||||
| |`LCAG(kc)`|                               |Hold Left Control, Left Alt and Left GUI and press `kc`                        | | ||||
| |`LSAG(kc)`|                               |Hold Left Shift, Left Alt and Left GUI and press `kc`                          | | ||||
| |`RCTL(kc)`|                               |Hold Right Control and press `kc`                                              | | ||||
| |`RSFT(kc)`|                               |Hold Right Shift and press `kc`                                                | | ||||
| |`RALT(kc)`|`ROPT(kc)`, `ALGR(kc)`         |Hold Right Alt and press `kc`                                                  | | ||||
| |`RGUI(kc)`|`RCMD(kc)`, `RWIN(kc)`         |Hold Right GUI and press `kc`                                                  | | ||||
| |`RCA(kc)` |                               |Hold Right Control and Right Alt and press `kc`                                | | ||||
| |`RCS(kc)` |                               |Hold Right Control and Right Shift and press `kc`                              | | ||||
| |`RCG(kc)` |                               |Hold Right Control and Right GUI and press `kc`                                | | ||||
| |`RSA(kc)` |                               |Hold Right Shift and Right Alt and press `kc`                                  | | ||||
| |`RSG(kc)` |                               |Hold Right Shift and Right GUI and press `kc`                                  | | ||||
| |`RAG(kc)` |                               |Hold Right Alt and Right GUI and press `kc`                                    | | ||||
| |`RCSG(kc)`|                               |Hold Right Control, Right Shift and Right GUI and press `kc`                   | | ||||
| |`RCAG(kc)`|                               |Hold Right Control, Right Alt and Right GUI and press `kc`                     | | ||||
| |`RSAG(kc)`|                               |Hold Right Shift, Right Alt and Right GUI and press `kc`                       | | ||||
| |`MEH(kc)` |                               |Hold Left Control, Left Shift and Left Alt and press `kc`                      | | ||||
| |`HYPR(kc)`|                               |Hold Left Control, Left Shift, Left Alt and Left GUI and press `kc`<sup>1</sup>| | ||||
| 
 | ||||
| <sup>1. More information on the Hyper key can be found on [this blog post by Brett Terpstra](https://brettterpstra.com/2012/12/08/a-useful-caps-lock-key/).</sup> | ||||
| 
 | ||||
|  | ||||
							
								
								
									
										55
									
								
								docs/features/battery.md
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										55
									
								
								docs/features/battery.md
									
									
									
									
									
										Normal file
									
								
							| @ -0,0 +1,55 @@ | ||||
| # Battery | ||||
| 
 | ||||
| This feature provides the high level abstraction for sampling battery level. | ||||
| 
 | ||||
| ## Usage | ||||
| 
 | ||||
| To use this driver, add the following to your `rules.mk`: | ||||
| 
 | ||||
| ```make | ||||
| BATTERY_ENABLE = yes | ||||
| ``` | ||||
| 
 | ||||
| ## Basic Configuration {#basic-configuration} | ||||
| 
 | ||||
| Add the following to your `config.h`: | ||||
| 
 | ||||
| |Define                    |Default |Description                                       | | ||||
| |--------------------------|--------|--------------------------------------------------| | ||||
| |`BATTERY_SAMPLE_INTERVAL` |`30000` |The time between battery samples in milliseconds. | | ||||
| 
 | ||||
| ## Driver Configuration {#driver-configuration} | ||||
| 
 | ||||
| See the [Battery Driver](../drivers/battery) documentation for more information. | ||||
| 
 | ||||
| ## Functions | ||||
| 
 | ||||
| ### `uint8_t battery_get_percent(void)` {#api-battery-get-percent} | ||||
| 
 | ||||
| Sample battery level. | ||||
| 
 | ||||
| #### Return Value {#api-battery-get-percent-return} | ||||
| 
 | ||||
| The battery percentage, in the range 0-100. | ||||
| 
 | ||||
| ## Callbacks | ||||
| 
 | ||||
| ### `void battery_percent_changed_user(uint8_t level)` {#api-battery-percent-changed-user} | ||||
| 
 | ||||
| User hook called when battery level changed. | ||||
| 
 | ||||
| ### Arguments {#api-battery-percent-changed-user-arguments} | ||||
| 
 | ||||
|  - `uint8_t level`   | ||||
|    The battery percentage, in the range 0-100. | ||||
| 
 | ||||
| --- | ||||
| 
 | ||||
| ### `void battery_percent_changed_kb(uint8_t level)` {#api-battery-percent-changed-kb} | ||||
| 
 | ||||
| Keyboard hook called when battery level changed. | ||||
| 
 | ||||
| ### Arguments {#api-battery-percent-changed-kb-arguments} | ||||
| 
 | ||||
|  - `uint8_t level`   | ||||
|    The battery percentage, in the range 0-100. | ||||
| @ -214,9 +214,30 @@ led_matrix_mode(LED_MATRIX_CUSTOM_my_cool_effect); | ||||
| For inspiration and examples, check out the built-in effects under `quantum/led_matrix/animations/`. | ||||
| 
 | ||||
| 
 | ||||
| ## Naming | ||||
| 
 | ||||
| If you wish to be able to use the name of an effect in your code -- say for a display indicator -- then you can enable the function `led_matrix_get_mode_name` in the following manner: | ||||
| 
 | ||||
| In your keymap's `config.h`: | ||||
| ```c | ||||
| #define LED_MATRIX_MODE_NAME_ENABLE | ||||
| ``` | ||||
| 
 | ||||
| In your `keymap.c` | ||||
| ```c | ||||
| const char* effect_name = led_matrix_get_mode_name(led_matrix_get_mode()); | ||||
| // do something with `effect_name`, like `oled_write_ln(effect_name, false);` | ||||
| ``` | ||||
| 
 | ||||
| ::: info | ||||
| `led_matrix_get_mode_name()` is not enabled by default as it increases the amount of flash memory used by the firmware based on the number of effects enabled. | ||||
| ::: | ||||
| 
 | ||||
| 
 | ||||
| ## Additional `config.h` Options {#additional-configh-options} | ||||
| 
 | ||||
| ```c | ||||
| #define LED_MATRIX_MODE_NAME_ENABLE // enables led_matrix_get_mode_name() | ||||
| #define LED_MATRIX_KEYRELEASES // reactive effects respond to keyreleases (instead of keypresses) | ||||
| #define LED_MATRIX_TIMEOUT 0 // number of milliseconds to wait until led automatically turns off | ||||
| #define LED_MATRIX_SLEEP // turn off effects when suspended | ||||
|  | ||||
| @ -379,7 +379,7 @@ POINTING_DEVICE_DRIVER = custom | ||||
| Using the custom driver will require implementing the following functions: | ||||
| 
 | ||||
| ```c | ||||
| void           pointing_device_driver_init(void) {} | ||||
| bool           pointing_device_driver_init(void) { return true; } | ||||
| report_mouse_t pointing_device_driver_get_report(report_mouse_t mouse_report) { return mouse_report; } | ||||
| uint16_t       pointing_device_driver_get_cpi(void) { return 0; } | ||||
| void           pointing_device_driver_set_cpi(uint16_t cpi) {} | ||||
| @ -467,20 +467,22 @@ If there is a `_RIGHT` configuration option or callback, the [common configurati | ||||
| 
 | ||||
| ## Callbacks and Functions  | ||||
| 
 | ||||
| | Function                                                   | Description                                                                                                   | | ||||
| | ---------------------------------------------------------- | ------------------------------------------------------------------------------------------------------------- | | ||||
| | `pointing_device_init_kb(void)`                            | Callback to allow for keyboard level initialization. Useful for additional hardware sensors.                  | | ||||
| | `pointing_device_init_user(void)`                          | Callback to allow for user level initialization. Useful for additional hardware sensors.                      | | ||||
| | `pointing_device_task_kb(mouse_report)`                    | Callback that sends sensor data, so keyboard code can intercept and modify the data.  Returns a mouse report. | | ||||
| | `pointing_device_task_user(mouse_report)`                  | Callback that sends sensor data, so user code can intercept and modify the data.  Returns a mouse report.     | | ||||
| | `pointing_device_handle_buttons(buttons, pressed, button)` | Callback to handle hardware button presses. Returns a `uint8_t`.                                              | | ||||
| | `pointing_device_get_cpi(void)`                            | Gets the current CPI/DPI setting from the sensor, if supported.                                               | | ||||
| | `pointing_device_set_cpi(uint16_t)`                        | Sets the CPI/DPI, if supported.                                                                               | | ||||
| | `pointing_device_get_report(void)`                         | Returns the current mouse report (as a `report_mouse_t` data structure).                                      | | ||||
| | `pointing_device_set_report(mouse_report)`                 | Sets the mouse report to the assigned `report_mouse_t` data structured passed to the function.                | | ||||
| | `pointing_device_send(void)`                               | Sends the current mouse report to the host system.  Function can be replaced.                                 | | ||||
| | `has_mouse_report_changed(new_report, old_report)`         | Compares the old and new `report_mouse_t` data and returns true only if it has changed.                       | | ||||
| | `pointing_device_adjust_by_defines(mouse_report)`          | Applies rotations and invert configurations to a raw mouse report.                                            | | ||||
| | Function                                                      | Description                                                                                                   | | ||||
| | ------------------------------------------------------------- | ------------------------------------------------------------------------------------------------------------- | | ||||
| | `pointing_device_init_kb(void)`                               | Callback to allow for keyboard level initialization. Useful for additional hardware sensors.                  | | ||||
| | `pointing_device_init_user(void)`                             | Callback to allow for user level initialization. Useful for additional hardware sensors.                      | | ||||
| | `pointing_device_task_kb(mouse_report)`                       | Callback that sends sensor data, so keyboard code can intercept and modify the data.  Returns a mouse report. | | ||||
| | `pointing_device_task_user(mouse_report)`                     | Callback that sends sensor data, so user code can intercept and modify the data.  Returns a mouse report.     | | ||||
| | `pointing_device_handle_buttons(buttons, pressed, button)`    | Callback to handle hardware button presses. Returns a `uint8_t`.                                              | | ||||
| | `pointing_device_get_cpi(void)`                               | Gets the current CPI/DPI setting from the sensor, if supported.                                               | | ||||
| | `pointing_device_set_cpi(uint16_t)`                           | Sets the CPI/DPI, if supported.                                                                               | | ||||
| | `pointing_device_get_report(void)`                            | Returns the current mouse report (as a `report_mouse_t` data structure).                                      | | ||||
| | `pointing_device_set_report(mouse_report)`                    | Sets the mouse report to the assigned `report_mouse_t` data structured passed to the function.                | | ||||
| | `pointing_device_send(void)`                                  | Sends the current mouse report to the host system.  Function can be replaced.                                 | | ||||
| | `has_mouse_report_changed(new_report, old_report)`            | Compares the old and new `report_mouse_t` data and returns true only if it has changed.                       | | ||||
| | `pointing_device_adjust_by_defines(mouse_report)`             | Applies rotations and invert configurations to a raw mouse report.                                            | | ||||
| | `pointing_device_get_status(void)`                            | Returns device status as `pointing_device_status_t` a good return is `POINTING_DEVICE_STATUS_SUCCESS`.        | | ||||
| | `pointing_device_set_status(pointing_device_status_t status)` | Sets device status, anything other than `POINTING_DEVICE_STATUS_SUCCESS` will disable reports from the device.| | ||||
| 
 | ||||
| 
 | ||||
| ## Split Keyboard Callbacks and Functions | ||||
|  | ||||
| @ -365,9 +365,30 @@ These are shorthands to popular colors. The `RGB` ones can be passed to the `set | ||||
| These are defined in [`color.h`](https://github.com/qmk/qmk_firmware/blob/master/quantum/color.h). Feel free to add to this list! | ||||
| 
 | ||||
| 
 | ||||
| ## Naming | ||||
| 
 | ||||
| If you wish to be able to use the name of an effect in your code -- say for a display indicator -- then you can enable the function `rgb_matrix_get_mode_name` in the following manner: | ||||
| 
 | ||||
| In your keymap's `config.h`: | ||||
| ```c | ||||
| #define RGB_MATRIX_MODE_NAME_ENABLE | ||||
| ``` | ||||
| 
 | ||||
| In your `keymap.c` | ||||
| ```c | ||||
| const char* effect_name = rgb_matrix_get_mode_name(rgb_matrix_get_mode()); | ||||
| // do something with `effect_name`, like `oled_write_ln(effect_name, false);` | ||||
| ``` | ||||
| 
 | ||||
| ::: info | ||||
| `rgb_matrix_get_mode_name()` is not enabled by default as it increases the amount of flash memory used by the firmware based on the number of effects enabled. | ||||
| ::: | ||||
| 
 | ||||
| 
 | ||||
| ## Additional `config.h` Options {#additional-configh-options} | ||||
| 
 | ||||
| ```c | ||||
| #define RGB_MATRIX_MODE_NAME_ENABLE // enables rgb_matrix_get_mode_name() | ||||
| #define RGB_MATRIX_KEYRELEASES // reactive effects respond to keyreleases (instead of keypresses) | ||||
| #define RGB_MATRIX_TIMEOUT 0 // number of milliseconds to wait until rgb automatically turns off | ||||
| #define RGB_MATRIX_SLEEP // turn off effects when suspended | ||||
|  | ||||
| @ -657,38 +657,38 @@ See also: [Mouse Keys](features/mouse_keys) | ||||
| 
 | ||||
| See also: [Modifier Keys](feature_advanced_keycodes#modifier-keys) | ||||
| 
 | ||||
| |Key       |Aliases                           |Description                                                        | | ||||
| |----------|----------------------------------|-------------------------------------------------------------------| | ||||
| |`LCTL(kc)`|`C(kc)`                           |Hold Left Control and press `kc`                                   | | ||||
| |`LSFT(kc)`|`S(kc)`                           |Hold Left Shift and press `kc`                                     | | ||||
| |`LALT(kc)`|`A(kc)`, `LOPT(kc)`               |Hold Left Alt and press `kc`                                       | | ||||
| |`LGUI(kc)`|`G(kc)`, `LCMD(kc)`, `LWIN(kc)`   |Hold Left GUI and press `kc`                                       | | ||||
| |`LCS(kc)` |                                  |Hold Left Control and Left Shift and press `kc`                    | | ||||
| |`LCA(kc)` |                                  |Hold Left Control and Left Alt and press `kc`                      | | ||||
| |`LCG(kc)` |                                  |Hold Left Control and Left GUI and press `kc`                      | | ||||
| |`LSA(kc)` |                                  |Hold Left Shift and Left Alt and press `kc`                        | | ||||
| |`LSG(kc)` |`SGUI(kc)`, `SCMD(kc)`, `SWIN(kc)`|Hold Left Shift and Left GUI and press `kc`                        | | ||||
| |`LAG(kc)` |                                  |Hold Left Alt and Left GUI and press `kc`                          | | ||||
| |`LCSG(kc)`|                                  |Hold Left Control, Left Shift and Left GUI and press `kc`          | | ||||
| |`LCAG(kc)`|                                  |Hold Left Control, Left Alt and Left GUI and press `kc`            | | ||||
| |`LSAG(kc)`|                                  |Hold Left Shift, Left Alt and Left GUI and press `kc`              | | ||||
| |`RCTL(kc)`|                                  |Hold Right Control and press `kc`                                  | | ||||
| |`RSFT(kc)`|                                  |Hold Right Shift and press `kc`                                    | | ||||
| |`RALT(kc)`|`ROPT(kc)`, `ALGR(kc)`            |Hold Right Alt and press `kc`                                      | | ||||
| |`RGUI(kc)`|`RCMD(kc)`, `RWIN(kc)`            |Hold Right GUI and press `kc`                                      | | ||||
| |`RCS(kc)` |                                  |Hold Right Control and Right Shift and press `kc`                  | | ||||
| |`RCA(kc)` |                                  |Hold Right Control and Right Alt and press `kc`                    | | ||||
| |`RCG(kc)` |                                  |Hold Right Control and Right GUI and press `kc`                    | | ||||
| |`RSA(kc)` |`SAGR(kc)`                        |Hold Right Shift and Right Alt and press `kc`                      | | ||||
| |`RSG(kc)` |                                  |Hold Right Shift and Right GUI and press `kc`                      | | ||||
| |`RAG(kc)` |                                  |Hold Right Alt and Right GUI and press `kc`                        | | ||||
| |`RCSG(kc)`|                                  |Hold Right Control, Right Shift and Right GUI and press `kc`       | | ||||
| |`RCAG(kc)`|                                  |Hold Right Control, Right Alt and Right GUI and press `kc`         | | ||||
| |`RSAG(kc)`|                                  |Hold Right Shift, Right Alt and Right GUI and press `kc`           | | ||||
| |`MEH(kc)` |                                  |Hold Left Control, Left Shift and Left Alt and press `kc`          | | ||||
| |`HYPR(kc)`|                                  |Hold Left Control, Left Shift, Left Alt and Left GUI and press `kc`| | ||||
| |`KC_MEH`  |                                  |Left Control, Left Shift and Left Alt                              | | ||||
| |`KC_HYPR` |                                  |Left Control, Left Shift, Left Alt and Left GUI                    | | ||||
| |Key       |Aliases                        |Description                                                        | | ||||
| |----------|-------------------------------|-------------------------------------------------------------------| | ||||
| |`LCTL(kc)`|`C(kc)`                        |Hold Left Control and press `kc`                                   | | ||||
| |`LSFT(kc)`|`S(kc)`                        |Hold Left Shift and press `kc`                                     | | ||||
| |`LALT(kc)`|`A(kc)`, `LOPT(kc)`            |Hold Left Alt and press `kc`                                       | | ||||
| |`LGUI(kc)`|`G(kc)`, `LCMD(kc)`, `LWIN(kc)`|Hold Left GUI and press `kc`                                       | | ||||
| |`LCS(kc)` |                               |Hold Left Control and Left Shift and press `kc`                    | | ||||
| |`LCA(kc)` |                               |Hold Left Control and Left Alt and press `kc`                      | | ||||
| |`LCG(kc)` |                               |Hold Left Control and Left GUI and press `kc`                      | | ||||
| |`LSA(kc)` |                               |Hold Left Shift and Left Alt and press `kc`                        | | ||||
| |`LSG(kc)` |                               |Hold Left Shift and Left GUI and press `kc`                        | | ||||
| |`LAG(kc)` |                               |Hold Left Alt and Left GUI and press `kc`                          | | ||||
| |`LCSG(kc)`|                               |Hold Left Control, Left Shift and Left GUI and press `kc`          | | ||||
| |`LCAG(kc)`|                               |Hold Left Control, Left Alt and Left GUI and press `kc`            | | ||||
| |`LSAG(kc)`|                               |Hold Left Shift, Left Alt and Left GUI and press `kc`              | | ||||
| |`RCTL(kc)`|                               |Hold Right Control and press `kc`                                  | | ||||
| |`RSFT(kc)`|                               |Hold Right Shift and press `kc`                                    | | ||||
| |`RALT(kc)`|`ROPT(kc)`, `ALGR(kc)`         |Hold Right Alt and press `kc`                                      | | ||||
| |`RGUI(kc)`|`RCMD(kc)`, `RWIN(kc)`         |Hold Right GUI and press `kc`                                      | | ||||
| |`RCS(kc)` |                               |Hold Right Control and Right Shift and press `kc`                  | | ||||
| |`RCA(kc)` |                               |Hold Right Control and Right Alt and press `kc`                    | | ||||
| |`RCG(kc)` |                               |Hold Right Control and Right GUI and press `kc`                    | | ||||
| |`RSA(kc)` |                               |Hold Right Shift and Right Alt and press `kc`                      | | ||||
| |`RSG(kc)` |                               |Hold Right Shift and Right GUI and press `kc`                      | | ||||
| |`RAG(kc)` |                               |Hold Right Alt and Right GUI and press `kc`                        | | ||||
| |`RCSG(kc)`|                               |Hold Right Control, Right Shift and Right GUI and press `kc`       | | ||||
| |`RCAG(kc)`|                               |Hold Right Control, Right Alt and Right GUI and press `kc`         | | ||||
| |`RSAG(kc)`|                               |Hold Right Shift, Right Alt and Right GUI and press `kc`           | | ||||
| |`MEH(kc)` |                               |Hold Left Control, Left Shift and Left Alt and press `kc`          | | ||||
| |`HYPR(kc)`|                               |Hold Left Control, Left Shift, Left Alt and Left GUI and press `kc`| | ||||
| |`KC_MEH`  |                               |Left Control, Left Shift and Left Alt                              | | ||||
| |`KC_HYPR` |                               |Left Control, Left Shift, Left Alt and Left GUI                    | | ||||
| 
 | ||||
| ## Mod-Tap Keys {#mod-tap-keys} | ||||
| 
 | ||||
| @ -705,7 +705,7 @@ See also: [Mod-Tap](mod_tap) | ||||
| |`LCA_T(kc)`  |                                                                 |Left Control and Left Alt when held, `kc` when tapped                      | | ||||
| |`LCG_T(kc)`  |                                                                 |Left Control and Left GUI when held, `kc` when tapped                      | | ||||
| |`LSA_T(kc)`  |                                                                 |Left Shift and Left Alt when held, `kc` when tapped                        | | ||||
| |`LSG_T(kc)`  |`SGUI_T(kc)`, `SCMD_T(kc)`, `SWIN_T(kc)`                         |Left Shift and Left GUI when held, `kc` when tapped                        | | ||||
| |`LSG_T(kc)`  |                                                                 |Left Shift and Left GUI when held, `kc` when tapped                        | | ||||
| |`LAG_T(kc)`  |                                                                 |Left Alt and Left GUI when held, `kc` when tapped                          | | ||||
| |`LCSG_T(kc)` |                                                                 |Left Control, Left Shift and Left GUI when held, `kc` when tapped          | | ||||
| |`LCAG_T(kc)` |                                                                 |Left Control, Left Alt and Left GUI when held, `kc` when tapped            | | ||||
| @ -717,14 +717,14 @@ See also: [Mod-Tap](mod_tap) | ||||
| |`RCS_T(kc)`  |                                                                 |Right Control and Right Shift when held, `kc` when tapped                  | | ||||
| |`RCA_T(kc)`  |                                                                 |Right Control and Right Alt when held, `kc` when tapped                    | | ||||
| |`RCG_T(kc)`  |                                                                 |Right Control and Right GUI when held, `kc` when tapped                    | | ||||
| |`RSA_T(kc)`  |`SAGR_T(kc)`                                                     |Right Shift and Right Alt when held, `kc` when tapped                      | | ||||
| |`RSA_T(kc)`  |                                                                 |Right Shift and Right Alt when held, `kc` when tapped                      | | ||||
| |`RSG_T(kc)`  |                                                                 |Right Shift and Right GUI when held, `kc` when tapped                      | | ||||
| |`RAG_T(kc)`  |                                                                 |Right Alt and Right GUI when held, `kc` when tapped                        | | ||||
| |`RCSG_T(kc)` |                                                                 |Right Control, Right Shift and Right GUI when held, `kc` when tapped       | | ||||
| |`RCAG_T(kc)` |                                                                 |Right Control, Right Alt and Right GUI when held, `kc` when tapped         | | ||||
| |`RSAG_T(kc)` |                                                                 |Right Shift, Right Alt and Right GUI when held, `kc` when tapped           | | ||||
| |`MEH_T(kc)`  |                                                                 |Left Control, Left Shift and Left Alt when held, `kc` when tapped          | | ||||
| |`HYPR_T(kc)` |`ALL_T(kc)`                                                      |Left Control, Left Shift, Left Alt and Left GUI when held, `kc` when tapped| | ||||
| |`HYPR_T(kc)` |                                                                 |Left Control, Left Shift, Left Alt and Left GUI when held, `kc` when tapped| | ||||
| 
 | ||||
| ## Tapping Term Keys {#tapping-term-keys} | ||||
| 
 | ||||
|  | ||||
| @ -37,7 +37,7 @@ For convenience, QMK includes some Mod-Tap shortcuts to make common combinations | ||||
| |`LCA_T(kc)` |                                                                 |Left Control and Left Alt when held, `kc` when tapped                                  | | ||||
| |`LCG_T(kc)` |                                                                 |Left Control and Left GUI when held, `kc` when tapped                                  | | ||||
| |`LSA_T(kc)` |                                                                 |Left Shift and Left Alt when held, `kc` when tapped                                    | | ||||
| |`LSG_T(kc)` |`SGUI_T(kc)`, `SCMD_T(kc)`, `SWIN_T(kc)`                         |Left Shift and Left GUI when held, `kc` when tapped                                    | | ||||
| |`LSG_T(kc)` |                                                                 |Left Shift and Left GUI when held, `kc` when tapped                                    | | ||||
| |`LAG_T(kc)` |                                                                 |Left Alt and Left GUI when held, `kc` when tapped                                      | | ||||
| |`LCSG_T(kc)`|                                                                 |Left Control, Left Shift and Left GUI when held, `kc` when tapped                      | | ||||
| |`LCAG_T(kc)`|                                                                 |Left Control, Left Alt and Left GUI when held, `kc` when tapped                        | | ||||
| @ -49,14 +49,14 @@ For convenience, QMK includes some Mod-Tap shortcuts to make common combinations | ||||
| |`RCS_T(kc)` |                                                                 |Right Control and Right Shift when held, `kc` when tapped                              | | ||||
| |`RCA_T(kc)` |                                                                 |Right Control and Right Alt when held, `kc` when tapped                                | | ||||
| |`RCG_T(kc)` |                                                                 |Right Control and Right GUI when held, `kc` when tapped                                | | ||||
| |`RSA_T(kc)` |`SAGR_T(kc)`                                                     |Right Shift and Right Alt when held, `kc` when tapped                                  | | ||||
| |`RSA_T(kc)` |                                                                 |Right Shift and Right Alt when held, `kc` when tapped                                  | | ||||
| |`RSG_T(kc)` |                                                                 |Right Shift and Right GUI when held, `kc` when tapped                                  | | ||||
| |`RAG_T(kc)` |                                                                 |Right Alt and Right GUI when held, `kc` when tapped                                    | | ||||
| |`RCSG_T(kc)`|                                                                 |Right Control, Right Shift and Right GUI when held, `kc` when tapped                   | | ||||
| |`RCAG_T(kc)`|                                                                 |Right Control, Right Alt and Right GUI when held, `kc` when tapped                     | | ||||
| |`RSAG_T(kc)`|                                                                 |Right Shift, Right Alt and Right GUI when held, `kc` when tapped                       | | ||||
| |`MEH_T(kc)` |                                                                 |Left Control, Left Shift and Left Alt when held, `kc` when tapped                      | | ||||
| |`HYPR_T(kc)`|`ALL_T(kc)`                                                      |Left Control, Left Shift, Left Alt and Left GUI when held, `kc` when tapped<sup>1</sup>| | ||||
| |`HYPR_T(kc)`|                                                                 |Left Control, Left Shift, Left Alt and Left GUI when held, `kc` when tapped<sup>1</sup>| | ||||
| 
 | ||||
| <sup>1. More information on the Hyper key can be found on [this blog post by Brett Terpstra](https://brettterpstra.com/2012/12/08/a-useful-caps-lock-key/).</sup> | ||||
| 
 | ||||
|  | ||||
| @ -179,6 +179,32 @@ Configures the [Backlight](features/backlight) feature. | ||||
|     * `pins` <Badge type="info">Array: Pin</Badge> | ||||
|         * A list of GPIO pins connected to the backlight LEDs (`software` and `timer` drivers only). | ||||
| 
 | ||||
| ## Battery | ||||
| 
 | ||||
| Configures the [Battery](features/battery) feature. | ||||
| 
 | ||||
| * `battery` | ||||
|     * `adc` | ||||
|         * `pin` <Badge type="info">Pin</Badge> <Badge>Required</Badge> | ||||
|             * The GPIO pin connected to the voltage divider. | ||||
|         * `reference_voltage` <Badge type="info">Number</Badge> | ||||
|             * The ADC reverence voltage, in millivolts.  | ||||
|             * Default: `3300` | ||||
|         * `divider_r1` <Badge type="info">Number</Badge> | ||||
|             * The voltage divider resistance, in kOhm. Set to 0 to disable. | ||||
|             * Default: `100` | ||||
|         * `divider_r2` <Badge type="info">Number</Badge> | ||||
|             * The voltage divider resistance, in kOhm. Set to 0 to disable. | ||||
|             * Default: `100` | ||||
|         * `resolution` <Badge type="info">Number</Badge> | ||||
|             * The ADC resolution configured for the ADC Driver. | ||||
|             * Default: `10` | ||||
|     * `driver` <Badge type="info">String</Badge> <Badge>Required</Badge> | ||||
|         * The driver to use. Must be one of `adc`, `custom`, `vendor`. | ||||
|     * `sample_interval` <Badge type="info">Number</Badge> | ||||
|         * The delay between sampling the battery in milliseconds. | ||||
|         * Default: `30000` (30 s) | ||||
| 
 | ||||
| ## Wireless/Bluetooth {#bluetooth} | ||||
| 
 | ||||
| Configures the [Wireless](features/wireless) feature. | ||||
| @ -480,6 +506,9 @@ Configures the [LED Matrix](features/led_matrix) feature. | ||||
|     * `io_delay` <Badge type="info">Number</Badge> | ||||
|         * The amount of time to wait between row/col selection and col/row pin reading, in microseconds. | ||||
|         * Default: `30` (30 µs) | ||||
|     * `masked` <Badge type="info">Boolean</Badge> | ||||
|         * Whether configured intersections should be ignored. | ||||
|         * Default: `false` | ||||
|     * `rows` <Badge type="info">Array: Pin</Badge> | ||||
|         * A list of GPIO pins connected to the matrix rows. | ||||
|         * Example: `["B0", "B1", "B2"]` | ||||
| @ -750,9 +779,9 @@ Configures the [Split Keyboard](features/split_keyboard) feature. | ||||
|             * Default: `"bitbang"` | ||||
|         * `pin` <Badge type="info">Pin</Badge> | ||||
|             * The GPIO pin to use for transmit and receive. | ||||
|     * `soft_serial_speed` <Badge type="info">Number</Badge> | ||||
|         * The protocol speed, from `0` to `5` (`serial` transport protocol only). | ||||
|         * Default: `1` | ||||
|         * `speed` <Badge type="info">Number</Badge> | ||||
|             * The protocol speed, from `0` to `5` (fastest to slowest). | ||||
|             * Default: `1` | ||||
|     * `transport` | ||||
|         * `protocol` <Badge type="info">String</Badge> | ||||
|             * The split transport protocol to use. Must be one of `custom`, `i2c`, `serial`. | ||||
|  | ||||
| @ -1,23 +1,24 @@ | ||||
| // Copyright 2025 QMK
 | ||||
| // SPDX-License-Identifier: GPL-2.0-or-later
 | ||||
| 
 | ||||
| #include "battery_driver.h" | ||||
| #include "analog.h" | ||||
| #include "gpio.h" | ||||
| 
 | ||||
| #ifndef BATTERY_PIN | ||||
| #    error("BATTERY_PIN not configured!") | ||||
| #ifndef BATTERY_ADC_PIN | ||||
| #    error("BATTERY_ADC_PIN not configured!") | ||||
| #endif | ||||
| 
 | ||||
| #ifndef BATTERY_REF_VOLTAGE_MV | ||||
| #    define BATTERY_REF_VOLTAGE_MV 3300 | ||||
| #ifndef BATTERY_ADC_REF_VOLTAGE_MV | ||||
| #    define BATTERY_ADC_REF_VOLTAGE_MV 3300 | ||||
| #endif | ||||
| 
 | ||||
| #ifndef BATTERY_VOLTAGE_DIVIDER_R1 | ||||
| #ifndef BATTERY_ADC_VOLTAGE_DIVIDER_R1 | ||||
| #    define BATTERY_VOLTAGE_DIVIDER_R1 100 | ||||
| #endif | ||||
| 
 | ||||
| #ifndef BATTERY_VOLTAGE_DIVIDER_R2 | ||||
| #    define BATTERY_VOLTAGE_DIVIDER_R2 100 | ||||
| #ifndef BATTERY_ADC_VOLTAGE_DIVIDER_R2 | ||||
| #    define BATTERY_ADC_VOLTAGE_DIVIDER_R2 100 | ||||
| #endif | ||||
| 
 | ||||
| // TODO: infer from adc config?
 | ||||
| @ -26,16 +27,16 @@ | ||||
| #endif | ||||
| 
 | ||||
| void battery_driver_init(void) { | ||||
|     gpio_set_pin_input(BATTERY_PIN); | ||||
|     gpio_set_pin_input(BATTERY_ADC_PIN); | ||||
| } | ||||
| 
 | ||||
| uint16_t battery_driver_get_mv(void) { | ||||
|     uint32_t raw = analogReadPin(BATTERY_PIN); | ||||
|     uint32_t raw = analogReadPin(BATTERY_ADC_PIN); | ||||
| 
 | ||||
|     uint32_t bat_mv = raw * BATTERY_REF_VOLTAGE_MV / (1 << BATTERY_ADC_RESOLUTION); | ||||
|     uint32_t bat_mv = raw * BATTERY_ADC_REF_VOLTAGE_MV / (1 << BATTERY_ADC_RESOLUTION); | ||||
| 
 | ||||
| #if BATTERY_VOLTAGE_DIVIDER_R1 > 0 && BATTERY_VOLTAGE_DIVIDER_R2 > 0 | ||||
|     bat_mv = bat_mv * (BATTERY_VOLTAGE_DIVIDER_R1 + BATTERY_VOLTAGE_DIVIDER_R2) / BATTERY_VOLTAGE_DIVIDER_R2; | ||||
| #if BATTERY_VOLTAGE_DIVIDER_R1 > 0 && BATTERY_ADC_VOLTAGE_DIVIDER_R2 > 0 | ||||
|     bat_mv = bat_mv * (BATTERY_VOLTAGE_DIVIDER_R1 + BATTERY_ADC_VOLTAGE_DIVIDER_R2) / BATTERY_ADC_VOLTAGE_DIVIDER_R2; | ||||
| #endif | ||||
| 
 | ||||
|     return bat_mv; | ||||
|  | ||||
| @ -55,7 +55,7 @@ const pointing_device_driver_t adns5050_pointing_device_driver = { | ||||
| 
 | ||||
| static bool powered_down = false; | ||||
| 
 | ||||
| void adns5050_init(void) { | ||||
| bool adns5050_init(void) { | ||||
|     // Initialize the ADNS serial pins.
 | ||||
|     gpio_set_pin_output(ADNS5050_SCLK_PIN); | ||||
|     gpio_set_pin_output(ADNS5050_SDIO_PIN); | ||||
| @ -75,6 +75,8 @@ void adns5050_init(void) { | ||||
|     // gets the adns ready for write commands
 | ||||
|     // (for example, setting the dpi).
 | ||||
|     adns5050_read_burst(); | ||||
| 
 | ||||
|     return adns5050_check_signature(); | ||||
| } | ||||
| 
 | ||||
| // Perform a synchronization with the ADNS.
 | ||||
| @ -220,7 +222,7 @@ uint16_t adns5050_get_cpi(void) { | ||||
|     return (uint16_t)((cpival & 0b10000) * 125); | ||||
| } | ||||
| 
 | ||||
| bool adns5050_check_signature(void) { | ||||
| bool __attribute__((weak)) adns5050_check_signature(void) { | ||||
|     uint8_t pid  = adns5050_read_reg(REG_PRODUCT_ID); | ||||
|     uint8_t rid  = adns5050_read_reg(REG_REVISION_ID); | ||||
|     uint8_t pid2 = adns5050_read_reg(REG_PRODUCT_ID2); | ||||
|  | ||||
| @ -70,12 +70,12 @@ typedef struct { | ||||
|     int8_t dy; | ||||
| } report_adns5050_t; | ||||
| 
 | ||||
| const pointing_device_driver_t adns5050_pointing_device_driver; | ||||
| extern const pointing_device_driver_t adns5050_pointing_device_driver; | ||||
| 
 | ||||
| // A bunch of functions to implement the ADNS5050-specific serial protocol.
 | ||||
| // Note that the "serial.h" driver is insufficient, because it does not
 | ||||
| // manually manipulate a serial clock signal.
 | ||||
| void              adns5050_init(void); | ||||
| bool              adns5050_init(void); | ||||
| void              adns5050_sync(void); | ||||
| uint8_t           adns5050_serial_read(void); | ||||
| void              adns5050_serial_write(uint8_t data); | ||||
|  | ||||
| @ -115,7 +115,14 @@ uint8_t adns9800_read(uint8_t reg_addr) { | ||||
|     return data; | ||||
| } | ||||
| 
 | ||||
| void adns9800_init(void) { | ||||
| bool __attribute__((weak)) adns9800_check_signature(void) { | ||||
|     if (adns9800_read(REG_Product_ID) != 0x33) { | ||||
|         return false; | ||||
|     } | ||||
|     return true; | ||||
| } | ||||
| 
 | ||||
| bool adns9800_init(void) { | ||||
|     gpio_set_pin_output(ADNS9800_CS_PIN); | ||||
| 
 | ||||
|     spi_init(); | ||||
| @ -178,6 +185,8 @@ void adns9800_init(void) { | ||||
|     adns9800_write(REG_LASER_CTRL0, laser_ctrl0 & 0xf0); | ||||
| 
 | ||||
|     adns9800_set_cpi(ADNS9800_CPI); | ||||
| 
 | ||||
|     return adns9800_check_signature(); | ||||
| } | ||||
| 
 | ||||
| config_adns9800_t adns9800_get_config(void) { | ||||
|  | ||||
| @ -61,9 +61,9 @@ typedef struct { | ||||
|     int16_t y; | ||||
| } report_adns9800_t; | ||||
| 
 | ||||
| const pointing_device_driver_t adns9800_pointing_device_driver; | ||||
| extern const pointing_device_driver_t adns9800_pointing_device_driver; | ||||
| 
 | ||||
| void              adns9800_init(void); | ||||
| bool              adns9800_init(void); | ||||
| config_adns9800_t adns9800_get_config(void); | ||||
| void              adns9800_set_config(config_adns9800_t); | ||||
| uint16_t          adns9800_get_cpi(void); | ||||
|  | ||||
| @ -135,7 +135,7 @@ report_analog_joystick_t analog_joystick_read(void) { | ||||
|     return report; | ||||
| } | ||||
| 
 | ||||
| void analog_joystick_init(void) { | ||||
| bool analog_joystick_init(void) { | ||||
|     gpio_set_pin_input_high(ANALOG_JOYSTICK_X_AXIS_PIN); | ||||
|     gpio_set_pin_input_high(ANALOG_JOYSTICK_Y_AXIS_PIN); | ||||
| 
 | ||||
| @ -152,6 +152,8 @@ void analog_joystick_init(void) { | ||||
|     maxAxisValues[0] = xOrigin + 100; | ||||
|     maxAxisValues[1] = yOrigin + 100; | ||||
| #endif | ||||
| 
 | ||||
|     return true; | ||||
| } | ||||
| 
 | ||||
| report_mouse_t analog_joystick_get_report(report_mouse_t mouse_report) { | ||||
|  | ||||
| @ -43,7 +43,7 @@ | ||||
| #    define ANALOG_JOYSTICK_SPEED_MAX 2 | ||||
| #endif | ||||
| 
 | ||||
| const pointing_device_driver_t analog_joystick_pointing_device_driver; | ||||
| extern const pointing_device_driver_t analog_joystick_pointing_device_driver; | ||||
| 
 | ||||
| typedef struct { | ||||
|     int8_t x; | ||||
| @ -51,5 +51,5 @@ typedef struct { | ||||
|     bool   button; | ||||
| } report_analog_joystick_t; | ||||
| report_analog_joystick_t analog_joystick_read(void); | ||||
| void                     analog_joystick_init(void); | ||||
| bool                     analog_joystick_init(void); | ||||
| report_mouse_t           analog_joystick_get_report(report_mouse_t mouse_report); | ||||
|  | ||||
| @ -321,7 +321,7 @@ void azoteq_iqs5xx_setup_resolution(void) { | ||||
| 
 | ||||
| static i2c_status_t azoteq_iqs5xx_init_status = 1; | ||||
| 
 | ||||
| void azoteq_iqs5xx_init(void) { | ||||
| bool azoteq_iqs5xx_init(void) { | ||||
|     i2c_init(); | ||||
|     i2c_ping_address(AZOTEQ_IQS5XX_ADDRESS, 1); // wake
 | ||||
|     azoteq_iqs5xx_reset_suspend(true, false, true); | ||||
| @ -349,67 +349,65 @@ void azoteq_iqs5xx_init(void) { | ||||
|         azoteq_iqs5xx_init_status |= azoteq_iqs5xx_set_gesture_config(true); | ||||
|         wait_ms(AZOTEQ_IQS5XX_REPORT_RATE + 1); | ||||
|     } | ||||
| 
 | ||||
|     return azoteq_iqs5xx_init_status == I2C_STATUS_SUCCESS; | ||||
| }; | ||||
| 
 | ||||
| report_mouse_t azoteq_iqs5xx_get_report(report_mouse_t mouse_report) { | ||||
|     report_mouse_t temp_report = {0}; | ||||
| 
 | ||||
|     if (azoteq_iqs5xx_init_status == I2C_STATUS_SUCCESS) { | ||||
|         azoteq_iqs5xx_base_data_t base_data       = {0}; | ||||
|         i2c_status_t              status          = azoteq_iqs5xx_get_base_data(&base_data); | ||||
|         bool                      ignore_movement = false; | ||||
|     azoteq_iqs5xx_base_data_t base_data       = {0}; | ||||
|     i2c_status_t              status          = azoteq_iqs5xx_get_base_data(&base_data); | ||||
|     bool                      ignore_movement = false; | ||||
| 
 | ||||
|         if (status == I2C_STATUS_SUCCESS) { | ||||
|     if (status == I2C_STATUS_SUCCESS) { | ||||
| #ifdef POINTING_DEVICE_DEBUG | ||||
|             if (base_data.previous_cycle_time > AZOTEQ_IQS5XX_REPORT_RATE) { | ||||
|                 pd_dprintf("IQS5XX - previous cycle time missed, took: %dms\n", base_data.previous_cycle_time); | ||||
|             } | ||||
| #endif | ||||
|             if (base_data.gesture_events_0.single_tap || base_data.gesture_events_0.press_and_hold) { | ||||
|                 pd_dprintf("IQS5XX - Single tap/hold.\n"); | ||||
|                 temp_report.buttons = pointing_device_handle_buttons(temp_report.buttons, true, POINTING_DEVICE_BUTTON1); | ||||
|             } else if (base_data.gesture_events_1.two_finger_tap) { | ||||
|                 pd_dprintf("IQS5XX - Two finger tap.\n"); | ||||
|                 temp_report.buttons = pointing_device_handle_buttons(temp_report.buttons, true, POINTING_DEVICE_BUTTON2); | ||||
|             } else if (base_data.gesture_events_0.swipe_x_neg) { | ||||
|                 pd_dprintf("IQS5XX - X-.\n"); | ||||
|                 temp_report.buttons = pointing_device_handle_buttons(temp_report.buttons, true, POINTING_DEVICE_BUTTON4); | ||||
|                 ignore_movement     = true; | ||||
|             } else if (base_data.gesture_events_0.swipe_x_pos) { | ||||
|                 pd_dprintf("IQS5XX - X+.\n"); | ||||
|                 temp_report.buttons = pointing_device_handle_buttons(temp_report.buttons, true, POINTING_DEVICE_BUTTON5); | ||||
|                 ignore_movement     = true; | ||||
|             } else if (base_data.gesture_events_0.swipe_y_neg) { | ||||
|                 pd_dprintf("IQS5XX - Y-.\n"); | ||||
|                 temp_report.buttons = pointing_device_handle_buttons(temp_report.buttons, true, POINTING_DEVICE_BUTTON6); | ||||
|                 ignore_movement     = true; | ||||
|             } else if (base_data.gesture_events_0.swipe_y_pos) { | ||||
|                 pd_dprintf("IQS5XX - Y+.\n"); | ||||
|                 temp_report.buttons = pointing_device_handle_buttons(temp_report.buttons, true, POINTING_DEVICE_BUTTON3); | ||||
|                 ignore_movement     = true; | ||||
|             } else if (base_data.gesture_events_1.zoom) { | ||||
|                 if (AZOTEQ_IQS5XX_COMBINE_H_L_BYTES(base_data.x.h, base_data.x.l) < 0) { | ||||
|                     pd_dprintf("IQS5XX - Zoom out.\n"); | ||||
|                     temp_report.buttons = pointing_device_handle_buttons(temp_report.buttons, true, POINTING_DEVICE_BUTTON7); | ||||
|                 } else if (AZOTEQ_IQS5XX_COMBINE_H_L_BYTES(base_data.x.h, base_data.x.l) > 0) { | ||||
|                     pd_dprintf("IQS5XX - Zoom in.\n"); | ||||
|                     temp_report.buttons = pointing_device_handle_buttons(temp_report.buttons, true, POINTING_DEVICE_BUTTON8); | ||||
|                 } | ||||
|             } else if (base_data.gesture_events_1.scroll) { | ||||
|                 pd_dprintf("IQS5XX - Scroll.\n"); | ||||
|                 temp_report.h = CONSTRAIN_HID(AZOTEQ_IQS5XX_COMBINE_H_L_BYTES(base_data.x.h, base_data.x.l)); | ||||
|                 temp_report.v = CONSTRAIN_HID(AZOTEQ_IQS5XX_COMBINE_H_L_BYTES(base_data.y.h, base_data.y.l)); | ||||
|             } | ||||
|             if (base_data.number_of_fingers == 1 && !ignore_movement) { | ||||
|                 temp_report.x = CONSTRAIN_HID_XY(AZOTEQ_IQS5XX_COMBINE_H_L_BYTES(base_data.x.h, base_data.x.l)); | ||||
|                 temp_report.y = CONSTRAIN_HID_XY(AZOTEQ_IQS5XX_COMBINE_H_L_BYTES(base_data.y.h, base_data.y.l)); | ||||
|             } | ||||
| 
 | ||||
|         } else { | ||||
|             pd_dprintf("IQS5XX - get report failed, i2c status: %d \n", status); | ||||
|         if (base_data.previous_cycle_time > AZOTEQ_IQS5XX_REPORT_RATE) { | ||||
|             pd_dprintf("IQS5XX - previous cycle time missed, took: %dms\n", base_data.previous_cycle_time); | ||||
|         } | ||||
| #endif | ||||
|         if (base_data.gesture_events_0.single_tap || base_data.gesture_events_0.press_and_hold) { | ||||
|             pd_dprintf("IQS5XX - Single tap/hold.\n"); | ||||
|             temp_report.buttons = pointing_device_handle_buttons(temp_report.buttons, true, POINTING_DEVICE_BUTTON1); | ||||
|         } else if (base_data.gesture_events_1.two_finger_tap) { | ||||
|             pd_dprintf("IQS5XX - Two finger tap.\n"); | ||||
|             temp_report.buttons = pointing_device_handle_buttons(temp_report.buttons, true, POINTING_DEVICE_BUTTON2); | ||||
|         } else if (base_data.gesture_events_0.swipe_x_neg) { | ||||
|             pd_dprintf("IQS5XX - X-.\n"); | ||||
|             temp_report.buttons = pointing_device_handle_buttons(temp_report.buttons, true, POINTING_DEVICE_BUTTON4); | ||||
|             ignore_movement     = true; | ||||
|         } else if (base_data.gesture_events_0.swipe_x_pos) { | ||||
|             pd_dprintf("IQS5XX - X+.\n"); | ||||
|             temp_report.buttons = pointing_device_handle_buttons(temp_report.buttons, true, POINTING_DEVICE_BUTTON5); | ||||
|             ignore_movement     = true; | ||||
|         } else if (base_data.gesture_events_0.swipe_y_neg) { | ||||
|             pd_dprintf("IQS5XX - Y-.\n"); | ||||
|             temp_report.buttons = pointing_device_handle_buttons(temp_report.buttons, true, POINTING_DEVICE_BUTTON6); | ||||
|             ignore_movement     = true; | ||||
|         } else if (base_data.gesture_events_0.swipe_y_pos) { | ||||
|             pd_dprintf("IQS5XX - Y+.\n"); | ||||
|             temp_report.buttons = pointing_device_handle_buttons(temp_report.buttons, true, POINTING_DEVICE_BUTTON3); | ||||
|             ignore_movement     = true; | ||||
|         } else if (base_data.gesture_events_1.zoom) { | ||||
|             if (AZOTEQ_IQS5XX_COMBINE_H_L_BYTES(base_data.x.h, base_data.x.l) < 0) { | ||||
|                 pd_dprintf("IQS5XX - Zoom out.\n"); | ||||
|                 temp_report.buttons = pointing_device_handle_buttons(temp_report.buttons, true, POINTING_DEVICE_BUTTON7); | ||||
|             } else if (AZOTEQ_IQS5XX_COMBINE_H_L_BYTES(base_data.x.h, base_data.x.l) > 0) { | ||||
|                 pd_dprintf("IQS5XX - Zoom in.\n"); | ||||
|                 temp_report.buttons = pointing_device_handle_buttons(temp_report.buttons, true, POINTING_DEVICE_BUTTON8); | ||||
|             } | ||||
|         } else if (base_data.gesture_events_1.scroll) { | ||||
|             pd_dprintf("IQS5XX - Scroll.\n"); | ||||
|             temp_report.h = CONSTRAIN_HID(AZOTEQ_IQS5XX_COMBINE_H_L_BYTES(base_data.x.h, base_data.x.l)); | ||||
|             temp_report.v = CONSTRAIN_HID(AZOTEQ_IQS5XX_COMBINE_H_L_BYTES(base_data.y.h, base_data.y.l)); | ||||
|         } | ||||
|         if (base_data.number_of_fingers == 1 && !ignore_movement) { | ||||
|             temp_report.x = CONSTRAIN_HID_XY(AZOTEQ_IQS5XX_COMBINE_H_L_BYTES(base_data.x.h, base_data.x.l)); | ||||
|             temp_report.y = CONSTRAIN_HID_XY(AZOTEQ_IQS5XX_COMBINE_H_L_BYTES(base_data.y.h, base_data.y.l)); | ||||
|         } | ||||
| 
 | ||||
|     } else { | ||||
|         pd_dprintf("IQS5XX - Init failed, i2c status: %d \n", azoteq_iqs5xx_init_status); | ||||
|         pd_dprintf("IQS5XX - get report failed, i2c status: %d \n", status); | ||||
|     } | ||||
| 
 | ||||
|     return temp_report; | ||||
|  | ||||
| @ -178,9 +178,9 @@ typedef struct { | ||||
| #    define POINTING_DEVICE_TASK_THROTTLE_MS AZOTEQ_IQS5XX_REPORT_RATE + 1 | ||||
| #endif | ||||
| 
 | ||||
| const pointing_device_driver_t azoteq_iqs5xx_pointing_device_driver; | ||||
| extern const pointing_device_driver_t azoteq_iqs5xx_pointing_device_driver; | ||||
| 
 | ||||
| void           azoteq_iqs5xx_init(void); | ||||
| bool           azoteq_iqs5xx_init(void); | ||||
| i2c_status_t   azoteq_iqs5xx_wake(void); | ||||
| report_mouse_t azoteq_iqs5xx_get_report(report_mouse_t mouse_report); | ||||
| i2c_status_t   azoteq_iqs5xx_get_report_rate(azoteq_iqs5xx_report_rate_t *report_rate, azoteq_iqs5xx_charging_modes_t mode, bool end_session); | ||||
|  | ||||
| @ -18,7 +18,6 @@ | ||||
| #    endif | ||||
| #endif | ||||
| 
 | ||||
| bool     touchpad_init; | ||||
| uint16_t scale_data = CIRQUE_PINNACLE_DEFAULT_SCALE; | ||||
| 
 | ||||
| void cirque_pinnacle_clear_flags(void); | ||||
| @ -232,14 +231,14 @@ bool cirque_pinnacle_connected(void) { | ||||
| } | ||||
| 
 | ||||
| /*  Pinnacle-based TM040040/TM035035/TM023023 Functions  */ | ||||
| void cirque_pinnacle_init(void) { | ||||
| bool cirque_pinnacle_init(void) { | ||||
| #if defined(POINTING_DEVICE_DRIVER_cirque_pinnacle_spi) | ||||
|     spi_init(); | ||||
| #elif defined(POINTING_DEVICE_DRIVER_cirque_pinnacle_i2c) | ||||
|     i2c_init(); | ||||
| #endif | ||||
| 
 | ||||
|     touchpad_init = true; | ||||
|     bool touchpad_init = true; | ||||
| 
 | ||||
|     // send a RESET command now, in case QMK had a soft-reset without a power cycle
 | ||||
|     RAP_Write(HOSTREG__SYSCONFIG1, HOSTREG__SYSCONFIG1__RESET); | ||||
| @ -293,6 +292,8 @@ void cirque_pinnacle_init(void) { | ||||
| #ifndef CIRQUE_PINNACLE_SKIP_SENSOR_CHECK | ||||
|     touchpad_init = cirque_pinnacle_connected(); | ||||
| #endif | ||||
| 
 | ||||
|     return touchpad_init; | ||||
| } | ||||
| 
 | ||||
| pinnacle_data_t cirque_pinnacle_read_data(void) { | ||||
|  | ||||
| @ -112,9 +112,9 @@ typedef struct { | ||||
| 
 | ||||
| #define cirque_pinnacle_i2c_pointing_device_driver cirque_pinnacle_pointing_device_driver | ||||
| #define cirque_pinnacle_spi_pointing_device_driver cirque_pinnacle_pointing_device_driver | ||||
| const pointing_device_driver_t cirque_pinnacle_pointing_device_driver; | ||||
| extern const pointing_device_driver_t cirque_pinnacle_pointing_device_driver; | ||||
| 
 | ||||
| void            cirque_pinnacle_init(void); | ||||
| bool            cirque_pinnacle_init(void); | ||||
| void            cirque_pinnacle_calibrate(void); | ||||
| void            cirque_pinnacle_cursor_smoothing(bool enable); | ||||
| pinnacle_data_t cirque_pinnacle_read_data(void); | ||||
|  | ||||
| @ -7,29 +7,22 @@ | ||||
| #define WRITE_MASK 0x80 | ||||
| #define READ_MASK 0xA0 | ||||
| 
 | ||||
| extern bool touchpad_init; | ||||
| 
 | ||||
| /*  RAP Functions */ | ||||
| // Reads <count> Pinnacle registers starting at <address>
 | ||||
| void RAP_ReadBytes(uint8_t address, uint8_t* data, uint8_t count) { | ||||
|     uint8_t cmdByte = READ_MASK | address; // Form the READ command byte
 | ||||
|     if (touchpad_init) { | ||||
|         i2c_write_register(CIRQUE_PINNACLE_ADDR << 1, cmdByte, NULL, 0, CIRQUE_PINNACLE_TIMEOUT); | ||||
|         if (i2c_read_register(CIRQUE_PINNACLE_ADDR << 1, cmdByte, data, count, CIRQUE_PINNACLE_TIMEOUT) != I2C_STATUS_SUCCESS) { | ||||
|             pd_dprintf("error cirque_pinnacle i2c_read_register\n"); | ||||
|             touchpad_init = false; | ||||
|         } | ||||
|     i2c_write_register(CIRQUE_PINNACLE_ADDR << 1, cmdByte, NULL, 0, CIRQUE_PINNACLE_TIMEOUT); | ||||
|     if (i2c_read_register(CIRQUE_PINNACLE_ADDR << 1, cmdByte, data, count, CIRQUE_PINNACLE_TIMEOUT) != I2C_STATUS_SUCCESS) { | ||||
|         pd_dprintf("error cirque_pinnacle i2c_read_register\n"); | ||||
|         pointing_device_set_status(POINTING_DEVICE_STATUS_FAILED); | ||||
|     } | ||||
| } | ||||
| 
 | ||||
| // Writes single-byte <data> to <address>
 | ||||
| void RAP_Write(uint8_t address, uint8_t data) { | ||||
|     uint8_t cmdByte = WRITE_MASK | address; // Form the WRITE command byte
 | ||||
| 
 | ||||
|     if (touchpad_init) { | ||||
|         if (i2c_write_register(CIRQUE_PINNACLE_ADDR << 1, cmdByte, &data, sizeof(data), CIRQUE_PINNACLE_TIMEOUT) != I2C_STATUS_SUCCESS) { | ||||
|             pd_dprintf("error cirque_pinnacle i2c_write_register\n"); | ||||
|             touchpad_init = false; | ||||
|         } | ||||
|     if (i2c_write_register(CIRQUE_PINNACLE_ADDR << 1, cmdByte, &data, sizeof(data), CIRQUE_PINNACLE_TIMEOUT) != I2C_STATUS_SUCCESS) { | ||||
|         pd_dprintf("error cirque_pinnacle i2c_write_register\n"); | ||||
|         pointing_device_set_status(POINTING_DEVICE_STATUS_FAILED); | ||||
|     } | ||||
| } | ||||
|  | ||||
| @ -7,40 +7,35 @@ | ||||
| #define READ_MASK 0xA0 | ||||
| #define FILLER_BYTE 0xFC | ||||
| 
 | ||||
| extern bool touchpad_init; | ||||
| 
 | ||||
| /*  RAP Functions */ | ||||
| // Reads <count> Pinnacle registers starting at <address>
 | ||||
| void RAP_ReadBytes(uint8_t address, uint8_t* data, uint8_t count) { | ||||
|     uint8_t cmdByte = READ_MASK | address; // Form the READ command byte
 | ||||
|     if (touchpad_init) { | ||||
|         if (spi_start(CIRQUE_PINNACLE_SPI_CS_PIN, CIRQUE_PINNACLE_SPI_LSBFIRST, CIRQUE_PINNACLE_SPI_MODE, CIRQUE_PINNACLE_SPI_DIVISOR)) { | ||||
|             spi_write(cmdByte);     // write command byte, receive filler
 | ||||
|             spi_write(FILLER_BYTE); // write & receive filler
 | ||||
|             spi_write(FILLER_BYTE); // write & receive filler
 | ||||
|             for (uint8_t i = 0; i < count; i++) { | ||||
|                 data[i] = spi_write(FILLER_BYTE); // write filler, receive data on the third filler send
 | ||||
|             } | ||||
|         } else { | ||||
|             pd_dprintf("error cirque_pinnacle spi_start read\n"); | ||||
|             touchpad_init = false; | ||||
| 
 | ||||
|     if (spi_start(CIRQUE_PINNACLE_SPI_CS_PIN, CIRQUE_PINNACLE_SPI_LSBFIRST, CIRQUE_PINNACLE_SPI_MODE, CIRQUE_PINNACLE_SPI_DIVISOR)) { | ||||
|         spi_write(cmdByte);     // write command byte, receive filler
 | ||||
|         spi_write(FILLER_BYTE); // write & receive filler
 | ||||
|         spi_write(FILLER_BYTE); // write & receive filler
 | ||||
|         for (uint8_t i = 0; i < count; i++) { | ||||
|             data[i] = spi_write(FILLER_BYTE); // write filler, receive data on the third filler send
 | ||||
|         } | ||||
|         spi_stop(); | ||||
|     } else { | ||||
|         pd_dprintf("error cirque_pinnacle spi_start read\n"); | ||||
|         pointing_device_set_status(POINTING_DEVICE_STATUS_FAILED); | ||||
|     } | ||||
|     spi_stop(); | ||||
| } | ||||
| 
 | ||||
| // Writes single-byte <data> to <address>
 | ||||
| void RAP_Write(uint8_t address, uint8_t data) { | ||||
|     uint8_t cmdByte = WRITE_MASK | address; // Form the WRITE command byte
 | ||||
| 
 | ||||
|     if (touchpad_init) { | ||||
|         if (spi_start(CIRQUE_PINNACLE_SPI_CS_PIN, CIRQUE_PINNACLE_SPI_LSBFIRST, CIRQUE_PINNACLE_SPI_MODE, CIRQUE_PINNACLE_SPI_DIVISOR)) { | ||||
|             spi_write(cmdByte); | ||||
|             spi_write(data); | ||||
|         } else { | ||||
|             pd_dprintf("error cirque_pinnacle spi_start write\n"); | ||||
|             touchpad_init = false; | ||||
|         } | ||||
|         spi_stop(); | ||||
|     if (spi_start(CIRQUE_PINNACLE_SPI_CS_PIN, CIRQUE_PINNACLE_SPI_LSBFIRST, CIRQUE_PINNACLE_SPI_MODE, CIRQUE_PINNACLE_SPI_DIVISOR)) { | ||||
|         spi_write(cmdByte); | ||||
|         spi_write(data); | ||||
|     } else { | ||||
|         pd_dprintf("error cirque_pinnacle spi_start write\n"); | ||||
|         pointing_device_set_status(POINTING_DEVICE_STATUS_FAILED); | ||||
|     } | ||||
|     spi_stop(); | ||||
| } | ||||
|  | ||||
| @ -58,7 +58,15 @@ const pointing_device_driver_t paw3204_pointing_device_driver = { | ||||
|     .get_cpi    = paw3204_get_cpi, | ||||
| }; | ||||
| 
 | ||||
| void paw3204_init(void) { | ||||
| uint8_t read_pid_paw3204(void) { | ||||
|     return paw3204_read_reg(REG_PID1); | ||||
| } | ||||
| 
 | ||||
| bool __attribute__((weak)) paw3204_check_signature(void) { | ||||
|     return (read_pid_paw3204() == 0x30); | ||||
| } | ||||
| 
 | ||||
| bool paw3204_init(void) { | ||||
|     gpio_set_pin_output(PAW3204_SCLK_PIN);     // setclockpin to output
 | ||||
|     gpio_set_pin_input_high(PAW3204_SDIO_PIN); // set datapin input high
 | ||||
| 
 | ||||
| @ -69,6 +77,8 @@ void paw3204_init(void) { | ||||
|     paw3204_read_reg(0x01); // read id2
 | ||||
|     // PAW3204_write_reg(REG_SETUP,0x06);  // dont reset sensor and set cpi 1600
 | ||||
|     paw3204_write_reg(REG_IMGTRASH, 0x32); // write image trashhold
 | ||||
| 
 | ||||
|     return paw3204_check_signature(); | ||||
| } | ||||
| 
 | ||||
| uint8_t paw3204_serial_read(void) { | ||||
| @ -175,10 +185,6 @@ uint16_t paw3204_get_cpi(void) { | ||||
|     return cpival; | ||||
| } | ||||
| 
 | ||||
| uint8_t read_pid_paw3204(void) { | ||||
|     return paw3204_read_reg(REG_PID1); | ||||
| } | ||||
| 
 | ||||
| report_mouse_t paw3204_get_report(report_mouse_t mouse_report) { | ||||
|     report_paw3204_t data = paw3204_read(); | ||||
|     if (data.isMotion) { | ||||
|  | ||||
| @ -41,7 +41,7 @@ typedef struct { | ||||
|     bool    isMotion; | ||||
| } report_paw3204_t; | ||||
| 
 | ||||
| const pointing_device_driver_t paw3204_pointing_device_driver; | ||||
| extern const pointing_device_driver_t paw3204_pointing_device_driver; | ||||
| 
 | ||||
| /**
 | ||||
|  * @brief Initializes the sensor so it is in a working state and ready to | ||||
| @ -50,7 +50,7 @@ const pointing_device_driver_t paw3204_pointing_device_driver; | ||||
|  * @return true Initialization was a success | ||||
|  * @return false Initialization failed, do not proceed operation | ||||
|  */ | ||||
| void paw3204_init(void); | ||||
| bool paw3204_init(void); | ||||
| 
 | ||||
| /**
 | ||||
|  * @brief Reads and clears the current delta, and motion register values on the | ||||
|  | ||||
| @ -82,9 +82,12 @@ i2c_status_t read_pimoroni_trackball(pimoroni_data_t *data) { | ||||
|     return status; | ||||
| } | ||||
| 
 | ||||
| __attribute__((weak)) void pimoroni_trackball_device_init(void) { | ||||
| __attribute__((weak)) bool pimoroni_trackball_device_init(void) { | ||||
|     i2c_init(); | ||||
|     pimoroni_trackball_set_rgbw(0x00, 0x00, 0x00, 0x00); | ||||
|     uint8_t      rgbw_data[4] = {0}; | ||||
|     i2c_status_t status       = i2c_write_register(PIMORONI_TRACKBALL_ADDRESS << 1, PIMORONI_TRACKBALL_REG_LED_RED, rgbw_data, sizeof(rgbw_data), PIMORONI_TRACKBALL_TIMEOUT); | ||||
| 
 | ||||
|     return (status == I2C_STATUS_SUCCESS); | ||||
| } | ||||
| 
 | ||||
| int16_t pimoroni_trackball_get_offsets(uint8_t negative_dir, uint8_t positive_dir, uint8_t scale) { | ||||
|  | ||||
| @ -50,9 +50,9 @@ typedef struct { | ||||
|     uint8_t click; | ||||
| } pimoroni_data_t; | ||||
| 
 | ||||
| const pointing_device_driver_t pimoroni_trackball_pointing_device_driver; | ||||
| extern const pointing_device_driver_t pimoroni_trackball_pointing_device_driver; | ||||
| 
 | ||||
| void           pimoroni_trackball_device_init(void); | ||||
| bool           pimoroni_trackball_device_init(void); | ||||
| void           pimoroni_trackball_set_rgbw(uint8_t red, uint8_t green, uint8_t blue, uint8_t white); | ||||
| int16_t        pimoroni_trackball_get_offsets(uint8_t negative_dir, uint8_t positive_dir, uint8_t scale); | ||||
| uint16_t       pimoroni_trackball_get_cpi(void); | ||||
|  | ||||
| @ -30,7 +30,7 @@ const pointing_device_driver_t pmw3320_pointing_device_drivera = { | ||||
|     .get_cpi    = pmw3320_get_cpi, | ||||
| }; | ||||
| 
 | ||||
| void pmw3320_init(void) { | ||||
| bool pmw3320_init(void) { | ||||
|     // Initialize sensor serial pins.
 | ||||
|     gpio_set_pin_output(PMW3320_SCLK_PIN); | ||||
|     gpio_set_pin_output(PMW3320_SDIO_PIN); | ||||
| @ -56,6 +56,8 @@ void pmw3320_init(void) { | ||||
|     pmw3320_write_reg(REG_Led_Control, 0x4); | ||||
|     // Disable rest mode
 | ||||
|     pmw3320_write_reg(REG_Performance, 0x80); | ||||
| 
 | ||||
|     return pmw3320_check_signature(); | ||||
| } | ||||
| 
 | ||||
| // Perform a synchronization with sensor.
 | ||||
| @ -192,7 +194,7 @@ void pmw3320_set_cpi(uint16_t cpi) { | ||||
|     pmw3320_write_reg(REG_Resolution, 0x20 | cpival); | ||||
| } | ||||
| 
 | ||||
| bool pmw3320_check_signature(void) { | ||||
| bool __attribute__((weak)) pmw3320_check_signature(void) { | ||||
|     uint8_t pid  = pmw3320_read_reg(REG_Product_ID); | ||||
|     uint8_t pid2 = pmw3320_read_reg(REG_Inverse_Product_ID); | ||||
| 
 | ||||
|  | ||||
| @ -55,13 +55,13 @@ typedef struct { | ||||
|     int8_t dy; | ||||
| } report_pmw3320_t; | ||||
| 
 | ||||
| const pointing_device_driver_t pmw3320_pointing_device_driver; | ||||
| extern const pointing_device_driver_t pmw3320_pointing_device_driver; | ||||
| 
 | ||||
| // A bunch of functions to implement the PMW3320-specific serial protocol.
 | ||||
| // Mostly taken from ADNS5050 driver.
 | ||||
| // Note that the "serial.h" driver is insufficient, because it does not
 | ||||
| // manually manipulate a serial clock signal.
 | ||||
| void             pmw3320_init(void); | ||||
| bool             pmw3320_init(void); | ||||
| void             pmw3320_sync(void); | ||||
| uint8_t          pmw3320_serial_read(void); | ||||
| void             pmw3320_serial_write(uint8_t data); | ||||
|  | ||||
| @ -29,4 +29,4 @@ void pmw33xx_set_cpi(uint8_t sensor, uint16_t cpi) { | ||||
| } | ||||
| 
 | ||||
| // PID, Inverse PID
 | ||||
| const uint8_t pmw33xx_firmware_signature[2] PROGMEM = {0x42, 0xBD}; | ||||
| const uint8_t pmw33xx_firmware_signature[2] PROGMEM = {0x47, 0xB8}; | ||||
|  | ||||
| @ -102,7 +102,7 @@ uint8_t pmw33xx_read(uint8_t sensor, uint8_t reg_addr) { | ||||
|     return data; | ||||
| } | ||||
| 
 | ||||
| bool pmw33xx_check_signature(uint8_t sensor) { | ||||
| __attribute__((weak)) bool pmw33xx_check_signature(uint8_t sensor) { | ||||
|     uint8_t signature_dump[2] = { | ||||
|         pmw33xx_read(sensor, REG_Product_ID), | ||||
|         pmw33xx_read(sensor, REG_Inverse_Product_ID), | ||||
| @ -236,8 +236,8 @@ pmw33xx_report_t pmw33xx_read_burst(uint8_t sensor) { | ||||
|     return report; | ||||
| } | ||||
| 
 | ||||
| void pmw33xx_init_wrapper(void) { | ||||
|     pmw33xx_init(0); | ||||
| bool pmw33xx_init_wrapper(void) { | ||||
|     return pmw33xx_init(0); | ||||
| } | ||||
| 
 | ||||
| void pmw33xx_set_cpi_wrapper(uint16_t cpi) { | ||||
|  | ||||
| @ -106,7 +106,7 @@ STATIC_ASSERT(sizeof((pmw33xx_report_t){0}.motion) == 1, "pmw33xx_report_t.motio | ||||
| 
 | ||||
| #define pmw3360_pointing_device_driver pmw33xx_pointing_device_driver; | ||||
| #define pmw3389_pointing_device_driver pmw33xx_pointing_device_driver; | ||||
| const pointing_device_driver_t pmw33xx_pointing_device_driver; | ||||
| extern const pointing_device_driver_t pmw33xx_pointing_device_driver; | ||||
| 
 | ||||
| /**
 | ||||
|  * @brief Initializes the given sensor so it is in a working state and ready to | ||||
| @ -177,7 +177,7 @@ uint8_t pmw33xx_read(uint8_t sensor, uint8_t reg_addr); | ||||
|  */ | ||||
| bool pmw33xx_write(uint8_t sensor, uint8_t reg_addr, uint8_t data); | ||||
| 
 | ||||
| void           pmw33xx_init_wrapper(void); | ||||
| bool           pmw33xx_init_wrapper(void); | ||||
| void           pmw33xx_set_cpi_wrapper(uint16_t cpi); | ||||
| uint16_t       pmw33xx_get_cpi_wrapper(void); | ||||
| report_mouse_t pmw33xx_get_report(report_mouse_t mouse_report); | ||||
|  | ||||
| @ -8,3 +8,4 @@ | ||||
| #define I2C_DRIVER I2CD1 | ||||
| #define OLED_BRIGHTNESS 128 | ||||
| #define OLED_FONT_H "keyboards/1upkeyboards/pi50/lib/glcdfont.c" | ||||
| #define RGB_MATRIX_MODE_NAME_ENABLE | ||||
|  | ||||
| @ -18,49 +18,6 @@ | ||||
| #include <ctype.h> | ||||
| #include <stdio.h> | ||||
| 
 | ||||
| #if defined(RGB_MATRIX_EFFECT) | ||||
| #    undef RGB_MATRIX_EFFECT | ||||
| #endif // defined(RGB_MATRIX_EFFECT)
 | ||||
| 
 | ||||
| #define RGB_MATRIX_EFFECT(x) RGB_MATRIX_EFFECT_##x, | ||||
| enum { | ||||
|     RGB_MATRIX_EFFECT_NONE, | ||||
| #include "rgb_matrix_effects.inc" | ||||
| #undef RGB_MATRIX_EFFECT | ||||
| #ifdef RGB_MATRIX_CUSTOM_KB | ||||
| #    include "rgb_matrix_kb.inc" | ||||
| #endif | ||||
| #ifdef RGB_MATRIX_CUSTOM_USER | ||||
| #    include "rgb_matrix_user.inc" | ||||
| #endif | ||||
| #if defined(COMMUNITY_MODULES_ENABLE) && __has_include("rgb_matrix_community_modules.inc") | ||||
| #    include "rgb_matrix_community_modules.inc" | ||||
| #endif | ||||
| }; | ||||
| 
 | ||||
| #define RGB_MATRIX_EFFECT(x)    \ | ||||
|     case RGB_MATRIX_EFFECT_##x: \ | ||||
|         return #x; | ||||
| const char* rgb_matrix_name(uint8_t effect) { | ||||
|     switch (effect) { | ||||
|         case RGB_MATRIX_EFFECT_NONE: | ||||
|             return "NONE"; | ||||
| #include "rgb_matrix_effects.inc" | ||||
| #undef RGB_MATRIX_EFFECT | ||||
| #ifdef RGB_MATRIX_CUSTOM_KB | ||||
| #    include "rgb_matrix_kb.inc" | ||||
| #endif | ||||
| #ifdef RGB_MATRIX_CUSTOM_USER | ||||
| #    include "rgb_matrix_user.inc" | ||||
| #endif | ||||
| #if defined(COMMUNITY_MODULES_ENABLE) && __has_include("rgb_matrix_community_modules.inc") | ||||
| #    include "rgb_matrix_community_modules.inc" | ||||
| #endif | ||||
|         default: | ||||
|             return "UNKNOWN"; | ||||
|     } | ||||
| } | ||||
| 
 | ||||
| #ifdef OLED_ENABLE | ||||
| 
 | ||||
| static uint32_t oled_logo_timer = 0; | ||||
| @ -154,7 +111,7 @@ void user_oled_magic(void) { | ||||
|     oled_write_P(led_state.num_lock ? PSTR("Num(x) ") : PSTR("Num( ) "), false); | ||||
|     oled_write_P(led_state.scroll_lock ? PSTR("Scrl(x)") : PSTR("Scrl( )"), false); | ||||
| 
 | ||||
|     char *mode_name = strdup(rgb_matrix_name(rgb_matrix_get_mode())); | ||||
|     char *mode_name = strdup(rgb_matrix_get_mode_name(rgb_matrix_get_mode())); | ||||
|     if (mode_name != NULL) { | ||||
|         int len = strlen(mode_name); | ||||
|         bool capitalize_next = true; | ||||
|  | ||||
| @ -89,9 +89,9 @@ bool process_record_kb(uint16_t keycode, keyrecord_t* record) { | ||||
|     if (IS_MOUSEKEY_BUTTON(keycode)) { | ||||
|         report_mouse_t currentReport = pointing_device_get_report(); | ||||
|         if (record->event.pressed) { | ||||
|             currentReport.buttons |= 1 << (keycode - KC_MS_BTN1); | ||||
|             currentReport.buttons |= 1 << (keycode - QK_MOUSE_BUTTON_1); | ||||
|         } else { | ||||
|             currentReport.buttons &= ~(1 << (keycode - KC_MS_BTN1)); | ||||
|             currentReport.buttons &= ~(1 << (keycode - QK_MOUSE_BUTTON_1)); | ||||
|         } | ||||
|         pointing_device_set_report(currentReport); | ||||
|         pointing_device_send(); | ||||
|  | ||||
| @ -101,7 +101,7 @@ LAYOUT( /* Tab */ | ||||
|   KC_ESC,  KC_CALC, KC_WHOM, KC_MAIL, KC_MYCM, _______, _______, _______, _______, _______, KC_PSCR, _______, | ||||
|   _______, _______, _______, _______, _______, _______, _______, _______, _______, _______, _______, _______, | ||||
|   _______, LED_TOG, LED_CHG, _______, _______, _______, _______, _______, _______, _______, _______, _______, | ||||
|   _______, _______, _______, _______, _______,     _______,      _______, KC_MS_L, KC_MS_D, KC_MS_U, KC_MS_R | ||||
|   _______, _______, _______, _______, _______,     _______,      _______, MS_LEFT, MS_DOWN, MS_UP,   MS_RGHT | ||||
| ), | ||||
| }; | ||||
| 
 | ||||
|  | ||||
| @ -53,7 +53,7 @@ LAYOUT( /* Tab */ | ||||
|   KC_ESC,  KC_CALC, KC_WHOM, KC_MAIL, KC_MYCM, _______, _______, _______, _______, _______, KC_PSCR, _______, | ||||
|   _______, _______, _______, _______, _______, _______, _______, _______, _______, _______, _______, _______, | ||||
|   _______, UG_TOGG, UG_NEXT, UG_HUEU, UG_HUED, UG_SATU, UG_SATD, UG_VALU, UG_VALD, _______, _______, _______, | ||||
|   _______, _______, _______, _______, _______,     _______,      _______, KC_MS_L, KC_MS_D, KC_MS_U, KC_MS_R | ||||
|   _______, _______, _______, _______, _______,     _______,      _______, MS_LEFT, MS_DOWN, MS_UP,   MS_RGHT | ||||
| ), | ||||
| }; | ||||
| 
 | ||||
|  | ||||
| @ -42,8 +42,7 @@ | ||||
|     "qmk": { | ||||
|         "tap_keycode_delay": 10 | ||||
|     }, | ||||
|     "processor": "atmega32u4", | ||||
|     "bootloader": "caterina", | ||||
|     "development_board": "promicro", | ||||
|     "layouts": { | ||||
|         "LAYOUT_all": { | ||||
|             "layout": [ | ||||
|  | ||||
| @ -29,13 +29,13 @@ const uint16_t PROGMEM keymaps[][MATRIX_ROWS][MATRIX_COLS] = { | ||||
| 
 | ||||
|     [_MAIN] = LAYOUT( | ||||
|         //┌────────┬────────┬────────┐┌────────┬────────┬────────┬────────┬────────┬────────┐                          ┌────────┬────────┬────────┬────────┬────────┬────────┐┌────────┬────────┬────────┐
 | ||||
|            _______, KC_WH_U, _______,  KC_ESC,  KC_1,    KC_2,    KC_3,    KC_4,    KC_5,                               KC_6,    KC_7,    KC_8,    KC_9,    KC_0,    KC_BSPC,  KC_MINS, KC_EQL,  KC_GRV, | ||||
|            _______, MS_WHLU, _______,  KC_ESC,  KC_1,    KC_2,    KC_3,    KC_4,    KC_5,                               KC_6,    KC_7,    KC_8,    KC_9,    KC_0,    KC_BSPC,  KC_MINS, KC_EQL,  KC_GRV, | ||||
|         //├────────┼────────┼────────┤├────────┼────────┼────────┼────────┼────────┼────────┤                          ├────────┼────────┼────────┼────────┼────────┼────────┤├────────┼────────┼────────┤
 | ||||
|            KC_BTN1, KC_WH_D, KC_BTN2,  KC_TAB,  KC_Q,    KC_W,    KC_E,    KC_R,    KC_T,                               KC_Y,    KC_U,    KC_I,    KC_O,    KC_P,    KC_DEL,   KC_LBRC, KC_RBRC, KC_BSLS, | ||||
|            MS_BTN1, MS_WHLD, MS_BTN2,  KC_TAB,  KC_Q,    KC_W,    KC_E,    KC_R,    KC_T,                               KC_Y,    KC_U,    KC_I,    KC_O,    KC_P,    KC_DEL,   KC_LBRC, KC_RBRC, KC_BSLS, | ||||
|         //├────────┼────────┼────────┤├────────┼────────┼────────┼────────┼────────┼────────┤                          ├────────┼────────┼────────┼────────┼────────┼────────┤├────────┼────────┼────────┤
 | ||||
|                     KC_MS_U,           KC_LCTL, KC_A,    KC_S,    KC_D,    KC_F,    KC_G,                               KC_H,    KC_J,    KC_K,    KC_L,    KC_SCLN, KC_QUOT,           KC_UP, | ||||
|                     MS_UP,             KC_LCTL, KC_A,    KC_S,    KC_D,    KC_F,    KC_G,                               KC_H,    KC_J,    KC_K,    KC_L,    KC_SCLN, KC_QUOT,           KC_UP, | ||||
|         //├────────┼────────┼────────┤├────────┼────────┼────────┼────────┼────────┼────────┤                          ├────────┼────────┼────────┼────────┼────────┼────────┤├────────┼────────┼────────┤
 | ||||
|            KC_MS_L, KC_MS_D, KC_MS_R,  KC_LSFT, KC_Z,    KC_X,    KC_C,    KC_V,    KC_B,                               KC_N,    KC_M,    KC_COMM, KC_DOT,  KC_SLSH, KC_RSFT,  KC_LEFT, KC_DOWN, KC_RIGHT, | ||||
|            MS_LEFT, MS_DOWN, MS_RGHT,  KC_LSFT, KC_Z,    KC_X,    KC_C,    KC_V,    KC_B,                               KC_N,    KC_M,    KC_COMM, KC_DOT,  KC_SLSH, KC_RSFT,  KC_LEFT, KC_DOWN, KC_RIGHT, | ||||
|         //└────────┴────────┴────────┘└────────┴────────┼────────┼────────┼────────┼────────┼────────┐        ┌────────┼────────┼────────┼────────┴────────┴────────┴────────┘└────────┴────────┴────────┘
 | ||||
|                                                                   KC_LCTL, KC_LALT, KC_LGUI, KC_SPC,           KC_ENT,  RAISE,   LOWER,   XXXXXXX | ||||
|         //                                                       └────────┴────────┴────────┴────────┘        └────────┴────────┴────────┴────────┘
 | ||||
| @ -45,7 +45,7 @@ const uint16_t PROGMEM keymaps[][MATRIX_ROWS][MATRIX_COLS] = { | ||||
|         //┌────────┬────────┬────────┐┌────────┬────────┬────────┬────────┬────────┬────────┐                          ┌────────┬────────┬────────┬────────┬────────┬────────┐┌────────┬────────┬────────┐
 | ||||
|            _______, _______, _______,  QK_BOOT, _______, _______, _______, _______, _______,                            _______, _______, _______, _______, _______, _______,  KC_MUTE, KC_VOLD, KC_VOLU, | ||||
|         //├────────┼────────┼────────┤├────────┼────────┼────────┼────────┼────────┼────────┤                          ├────────┼────────┼────────┼────────┼────────┼────────┤├────────┼────────┼────────┤
 | ||||
|            _______, KC_BTN3, _______,  _______, _______, _______, _______, _______, _______,                            _______, _______, _______, _______, _______, _______,  _______, _______, _______, | ||||
|            _______, MS_BTN3, _______,  _______, _______, _______, _______, _______, _______,                            _______, _______, _______, _______, _______, _______,  _______, _______, _______, | ||||
|         //├────────┼────────┼────────┤├────────┼────────┼────────┼────────┼────────┼────────┤                          ├────────┼────────┼────────┼────────┼────────┼────────┤├────────┼────────┼────────┤
 | ||||
|                     _______,           _______, _______, _______, _______, _______, _______,                            _______, _______, _______, _______, _______, _______,           _______, | ||||
|         //├────────┼────────┼────────┤├────────┼────────┼────────┼────────┼────────┼────────┤                          ├────────┼────────┼────────┼────────┼────────┼────────┤├────────┼────────┼────────┤
 | ||||
|  | ||||
| @ -2,7 +2,7 @@ | ||||
|     "manufacturer": "Louis Dalibard", | ||||
|     "keyboard_name": "ai", | ||||
|     "maintainer": "make42", | ||||
|     "bootloader": "caterina", | ||||
|     "development_board": "promicro", | ||||
|     "diode_direction": "COL2ROW", | ||||
|     "features": { | ||||
|         "bootmagic": true, | ||||
| @ -14,7 +14,6 @@ | ||||
|         "cols": ["F5", "F6", "F7", "B1"], | ||||
|         "rows": ["D0", "D4", "C6", "D7", "D1"] | ||||
|     }, | ||||
|     "processor": "atmega32u4", | ||||
|     "usb": { | ||||
|         "device_version": "1.0.0", | ||||
|         "pid": "0x0000", | ||||
|  | ||||
| @ -38,9 +38,9 @@ const uint16_t PROGMEM keymaps[][MATRIX_ROWS][MATRIX_COLS] = { | ||||
| 	), | ||||
| 	[2] = LAYOUT( /* Mousekeys and Numpad */ | ||||
| 		KC_NO,   _______, _______, _______, _______, _______, _______, KC_NUM,  KC_P7,   KC_P8,   KC_P9,   KC_PSLS, _______, _______, | ||||
| 		KC_NO,   _______, KC_BTN1, KC_MS_U, KC_BTN2, KC_WH_U, _______, _______, KC_P4,   KC_P5,   KC_P6,   KC_PAST, _______, _______, | ||||
| 		TO(1),   _______, KC_MS_L, KC_MS_D, KC_MS_R, KC_WH_D, _______, _______, KC_P1,   KC_P2,   KC_P3,   KC_PMNS, _______, _______, | ||||
| 		TO(1),   _______, KC_ACL0, KC_ACL1, KC_ACL2, KC_BTN3, _______, DBLZERO, KC_P0,   KC_PDOT, KC_PENT, KC_PPLS, _______, MANUAL, | ||||
| 		KC_NO,   _______, MS_BTN1, MS_UP,   MS_BTN2, MS_WHLU, _______, _______, KC_P4,   KC_P5,   KC_P6,   KC_PAST, _______, _______, | ||||
| 		TO(1),   _______, MS_LEFT, MS_DOWN, MS_RGHT, MS_WHLD, _______, _______, KC_P1,   KC_P2,   KC_P3,   KC_PMNS, _______, _______, | ||||
| 		TO(1),   _______, MS_ACL0, MS_ACL1, MS_ACL2, MS_BTN3, _______, DBLZERO, KC_P0,   KC_PDOT, KC_PENT, KC_PPLS, _______, MANUAL, | ||||
| 			     _______, _______, _______, _______, _______, _______, _______, _______, _______, _______, _______, _______ | ||||
| 	) | ||||
| }; | ||||
|  | ||||
| @ -38,7 +38,7 @@ const uint16_t PROGMEM keymaps[][MATRIX_ROWS][MATRIX_COLS] = { | ||||
|   KC_ESC  , QK_BOOT, _______ , _______ , _______ , _______ , _______ , _______ , _______ , _______ , _______ , _______ , | ||||
|   _______ , KC_F11  , KC_F12  , KC_F13  , KC_F14  , KC_F15  , KC_F16  , KC_F17  , KC_F18  , KC_F19  , KC_F20  , _______ , | ||||
|   _______ , KC_F1   , KC_F2   , KC_F3   , KC_F4   , KC_F5   , KC_F6   , KC_F7   , KC_F8   , KC_F9   , KC_F10  , _______ , | ||||
|   _______ , _______ , _______ , _______ , _______ , _______ , _______ , KC_MS_L , KC_MS_D , KC_MS_U , KC_MS_R , _______ | ||||
|   _______ , _______ , _______ , _______ , _______ , _______ , _______ , MS_LEFT , MS_DOWN , MS_UP   , MS_RGHT , _______ | ||||
| ), | ||||
| }; | ||||
| 
 | ||||
|  | ||||
| @ -125,24 +125,15 @@ const snled27351_led_t PROGMEM g_snled27351_leds[SNLED27351_LED_COUNT] = { | ||||
| }; | ||||
| #endif // RGB_MATRIX_ENABLE
 | ||||
| 
 | ||||
| enum __layers {  | ||||
| 	WIN_B,  | ||||
| 	WIN_W,  | ||||
| 	WIN_FN,  | ||||
| 	MAC_B,  | ||||
| 	MAC_W,  | ||||
| 	MAC_FN,  | ||||
| }; | ||||
| 
 | ||||
| // clang-format on
 | ||||
| 
 | ||||
| void matrix_init_kb(void) { | ||||
| void keyboard_post_init_kb(void) { | ||||
|     gpio_set_pin_output(LED_MAC_OS_PIN); // LDE2 MAC\WIN
 | ||||
|     gpio_write_pin_low(LED_MAC_OS_PIN); | ||||
|     gpio_set_pin_output(LED_WIN_LOCK_PIN); // LED3 Win Lock
 | ||||
|     gpio_write_pin_low(LED_WIN_LOCK_PIN); | ||||
| 
 | ||||
|     matrix_init_user(); | ||||
|     keyboard_post_init_user(); | ||||
| } | ||||
| 
 | ||||
| void housekeeping_task_kb(void){ | ||||
| @ -155,18 +146,6 @@ bool process_record_kb(uint16_t keycode, keyrecord_t* record) { | ||||
|         return false; | ||||
|     } | ||||
|     switch (keycode) { | ||||
|         case DF(WIN_B): | ||||
|             if (record->event.pressed) { | ||||
|                 set_single_persistent_default_layer(WIN_B); | ||||
|             } | ||||
|             return false; | ||||
|         case DF(MAC_B): | ||||
|             if (record->event.pressed) { | ||||
|                 set_single_persistent_default_layer(MAC_B); | ||||
|                 keymap_config.no_gui = 0; | ||||
|                 eeconfig_update_keymap(&keymap_config); | ||||
|             } | ||||
|             return false; | ||||
|         case QK_RGB_MATRIX_TOGGLE: | ||||
|             if (record->event.pressed) { | ||||
|                 switch (rgb_matrix_get_flags()) { | ||||
|  | ||||
| @ -7,8 +7,12 @@ | ||||
|         "vid": "0xFFFE", | ||||
|         "pid": "0x000C", | ||||
|         "device_version": "1.0.4", | ||||
|         "suspend_wakeup_delay": 400, | ||||
|         "force_nkro": true | ||||
|         "suspend_wakeup_delay": 400 | ||||
|     }, | ||||
|     "host": { | ||||
|         "default": { | ||||
|             "nkro": true | ||||
|         } | ||||
|     }, | ||||
|     "processor": "WB32FQ95", | ||||
|     "bootloader": "wb32-dfu", | ||||
|  | ||||
| @ -48,7 +48,7 @@ const uint16_t PROGMEM keymaps[][MATRIX_ROWS][MATRIX_COLS] = { | ||||
|     [WIN_FN] = LAYOUT_tkl_ansi( /* FN */ | ||||
|         _______, KC_MYCM, KC_MAIL, KC_WSCH, KC_WHOM, KC_MSEL, KC_MPLY, KC_MPRV, KC_MNXT, _______,_______,  _______, _______,          _______, _______, _______, | ||||
|         _______, _______, _______, _______, _______, _______, _______, _______, _______, _______, _______, RM_SPDD, RM_SPDU, _______, _______, _______, _______, | ||||
|         _______, _______,TG(WIN_W),_______, _______, _______, _______, _______, _______, DF(MAC_B),_______,_______, _______, RM_NEXT, _______, _______, _______, | ||||
|         _______, _______,TG(WIN_W),_______, _______, _______, _______, _______, _______, PDF(MAC_B),_______,_______, _______, RM_NEXT, _______, _______, _______, | ||||
|         _______, _______, _______, _______, _______, _______, _______, _______, _______, RM_TOGG, _______, _______,          RM_HUEU, | ||||
|         _______, _______, _______, KC_CALC, _______, _______, _______, KC_MUTE, KC_VOLD, KC_VOLU, _______,                   _______,          RM_VALU, | ||||
|         _______, GU_TOGG, _______,                   _______,                            _______, _______, _______,          _______, RM_SATD, RM_VALD, RM_SATU), | ||||
| @ -71,7 +71,7 @@ const uint16_t PROGMEM keymaps[][MATRIX_ROWS][MATRIX_COLS] = { | ||||
|     [MAC_FN] = LAYOUT_tkl_ansi( /* FN */ | ||||
|         KC_ESC,  KC_F1,   KC_F2,   KC_F3,   KC_F4,  _______,  _______, KC_F7,   KC_F8,   KC_F9,   KC_F10,  KC_F11,  KC_F12,           _______, _______, _______, | ||||
|         _______, _______, _______, _______, _______, _______, _______, _______, _______, _______, _______, RM_SPDD, RM_SPDU, _______, _______, _______, _______, | ||||
|         _______, _______,TG(MAC_W),_______, _______, _______, _______, _______, _______, DF(WIN_B),_______,_______, _______, RM_NEXT, _______, _______, _______, | ||||
|         _______, _______,TG(MAC_W),_______, _______, _______, _______, _______, _______, PDF(WIN_B),_______,_______, _______, RM_NEXT, _______, _______, _______, | ||||
|         _______, _______, _______, _______, _______, _______, _______, _______, _______, RM_TOGG, _______, _______,          RM_HUEU, | ||||
|         _______, _______, _______, KC_CALC, _______, _______, _______, KC_MUTE, KC_VOLD, KC_VOLU, _______,                   _______,          RM_VALU, | ||||
|         _______, _______, _______,                   _______,                            _______, _______, _______,          _______, RM_SATD, RM_VALD, RM_SATU) | ||||
|  | ||||
| @ -7,8 +7,12 @@ | ||||
|         "vid": "0xFFFE", | ||||
|         "pid": "0x000D", | ||||
|         "device_version": "1.0.3", | ||||
|         "suspend_wakeup_delay": 400, | ||||
|         "force_nkro": true | ||||
|         "suspend_wakeup_delay": 400 | ||||
|     }, | ||||
|     "host": { | ||||
|         "default": { | ||||
|             "nkro": true | ||||
|         } | ||||
|     }, | ||||
|     "processor": "WB32FQ95", | ||||
|     "bootloader": "wb32-dfu", | ||||
|  | ||||
| @ -7,8 +7,12 @@ | ||||
|         "vid": "0xFFFE", | ||||
|         "pid": "0x0010", | ||||
|         "device_version": "1.0.1", | ||||
|         "suspend_wakeup_delay": 400, | ||||
|         "force_nkro": true | ||||
|         "suspend_wakeup_delay": 400 | ||||
|     }, | ||||
|     "host": { | ||||
|         "default": { | ||||
|             "nkro": true | ||||
|         } | ||||
|     }, | ||||
|     "processor": "WB32FQ95", | ||||
|     "bootloader": "wb32-dfu", | ||||
|  | ||||
| @ -7,8 +7,12 @@ | ||||
|         "vid": "0xFFFE", | ||||
|         "pid": "0x000E", | ||||
|         "device_version": "1.0.2", | ||||
|         "suspend_wakeup_delay": 400, | ||||
|         "force_nkro": true | ||||
|         "suspend_wakeup_delay": 400 | ||||
|     }, | ||||
|     "host": { | ||||
|         "default": { | ||||
|             "nkro": true | ||||
|         } | ||||
|     }, | ||||
|     "processor": "WB32FQ95", | ||||
|     "bootloader": "wb32-dfu", | ||||
|  | ||||
| @ -1,19 +0,0 @@ | ||||
| /*
 | ||||
| Copyright 2021 Spencer Deven <splitlogicdesign@gmail.com> | ||||
| 
 | ||||
| This program is free software: you can redistribute it and/or modify | ||||
| it under the terms of the GNU General Public License as published by | ||||
| the Free Software Foundation, either version 3 of the License, or | ||||
| (at your option) any later version. | ||||
| 
 | ||||
| This program is distributed in the hope that it will be useful, | ||||
| but WITHOUT ANY WARRANTY; without even the implied warranty of | ||||
| MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the | ||||
| GNU General Public License for more details. | ||||
| 
 | ||||
| You should have received a copy of the GNU General Public License | ||||
| along with this program.  If not, see <http://www.gnu.org/licenses/>.
 | ||||
| */ | ||||
| #pragma once | ||||
| 
 | ||||
| #define SELECT_SOFT_SERIAL_SPEED 1 | ||||
| @ -71,8 +71,7 @@ | ||||
|             "pin": "D3" | ||||
|         } | ||||
|     }, | ||||
|     "processor": "atmega32u4", | ||||
|     "bootloader": "caterina", | ||||
|     "development_board": "promicro", | ||||
|     "layouts": { | ||||
|         "LAYOUT": { | ||||
|             "layout": [ | ||||
|  | ||||
| @ -45,8 +45,7 @@ | ||||
|     "rows": ["D4", "B4", "B5"] | ||||
|   }, | ||||
|   "diode_direction": "COL2ROW", | ||||
|   "processor": "atmega32u4", | ||||
|   "bootloader": "caterina", | ||||
|   "development_board": "promicro", | ||||
|   "layouts": { | ||||
|     "LAYOUT": { | ||||
|       "layout": [ | ||||
|  | ||||
| @ -5,8 +5,12 @@ | ||||
|     "usb": { | ||||
|         "vid": "0x00D8", | ||||
|         "pid": "0x6068", | ||||
|         "device_version": "0.0.1", | ||||
|         "force_nkro": true | ||||
|         "device_version": "0.0.1" | ||||
|     }, | ||||
|     "host": { | ||||
|         "default": { | ||||
|             "nkro": true | ||||
|         } | ||||
|     }, | ||||
|     "features": { | ||||
|         "backlight": true, | ||||
|  | ||||
| @ -15,8 +15,7 @@ | ||||
|         "rows": ["E6", "B3"] | ||||
|     }, | ||||
|     "diode_direction": "COL2ROW", | ||||
|     "processor": "atmega32u4", | ||||
|     "bootloader": "caterina", | ||||
|     "development_board": "promicro", | ||||
|     "layouts": { | ||||
|         "LAYOUT": { | ||||
|             "layout": [ | ||||
|  | ||||
| @ -25,8 +25,7 @@ | ||||
|     "qmk": { | ||||
|         "tap_keycode_delay": 50 | ||||
|     }, | ||||
|     "processor": "atmega32u4", | ||||
|     "bootloader": "caterina", | ||||
|     "development_board": "promicro", | ||||
|     "layouts": { | ||||
|         "LAYOUT": { | ||||
|             "layout": [ | ||||
|  | ||||
| @ -31,8 +31,7 @@ | ||||
|     "ws2812": { | ||||
|         "pin": "D3" | ||||
|     }, | ||||
|     "processor": "atmega32u4", | ||||
|     "bootloader": "caterina", | ||||
|     "development_board": "promicro", | ||||
|     "layouts": { | ||||
|         "LAYOUT": { | ||||
|             "layout": [ | ||||
|  | ||||
| @ -20,9 +20,9 @@ along with this program.  If not, see <http://www.gnu.org/licenses/>. | ||||
| bool encoder_update_user(uint8_t index, bool clockwise) { | ||||
|   if (index == 0) { /* First encoder */ | ||||
|     if (clockwise) { | ||||
|       tap_code(KC_MS_WH_UP); | ||||
|       tap_code(MS_WHLU); | ||||
|     } else { | ||||
|       tap_code(KC_MS_WH_DOWN); | ||||
|       tap_code(MS_WHLD); | ||||
|     } | ||||
|   } | ||||
|     return true; | ||||
|  | ||||
| @ -10,7 +10,7 @@ enum layers { | ||||
| const uint16_t PROGMEM keymaps[][MATRIX_ROWS][MATRIX_COLS] = { | ||||
|     [BASE] = LAYOUT( | ||||
|         KC_VOLU, KC_F1,   KC_F2,   KC_F3,   KC_F4,   KC_F5,   KC_F6,    KC_F7,                            KC_F8,   KC_F9,   KC_F10,  KC_F11,  KC_F12,  KC_EQL,   KC_PSCR,  KC_DEL, | ||||
|         KC_VOLD, KC_ESC,  KC_GRV,  KC_1,    KC_2,    KC_3,    KC_4,     KC_5,   RM_NEXT,        KC_BTN1,  KC_6,    KC_7,    KC_8,    KC_9,    KC_0,    KC_MINS,       KC_BSPC, | ||||
|         KC_VOLD, KC_ESC,  KC_GRV,  KC_1,    KC_2,    KC_3,    KC_4,     KC_5,   RM_NEXT,        MS_BTN1,  KC_6,    KC_7,    KC_8,    KC_9,    KC_0,    KC_MINS,       KC_BSPC, | ||||
|         KC_MPLY,       KC_TAB,     KC_Q,    KC_W,    KC_E,    KC_R,     KC_T,   C(KC_C),        C(KC_V),  KC_Y,    KC_U,    KC_I,    KC_O,    KC_P,    KC_LBRC,  KC_RBRC,  KC_BSLS, | ||||
|         KC_MNXT,      KC_CAPS,     KC_A,    KC_S,    KC_D,    KC_F,     KC_G,   C(KC_Z),        C(KC_Y),  KC_H,    KC_J,    KC_K,    KC_L,    KC_SCLN, KC_QUOT,       KC_ENT, | ||||
|         KC_MPRV,      KC_LSFT,     KC_Z,    KC_X,    KC_C,    KC_V,     KC_B,   KC_ENT,         KC_ENT,   KC_N,    KC_M,    KC_COMM, KC_DOT,  KC_SLSH, KC_RSFT,  KC_UP,    KC_HOME, | ||||
| @ -20,6 +20,6 @@ const uint16_t PROGMEM keymaps[][MATRIX_ROWS][MATRIX_COLS] = { | ||||
| 
 | ||||
| #if defined(ENCODER_MAP_ENABLE) | ||||
| const uint16_t PROGMEM encoder_map[][NUM_ENCODERS][NUM_DIRECTIONS] = { | ||||
|     [BASE] =   { ENCODER_CCW_CW(RM_HUEU, RM_HUED), ENCODER_CCW_CW(KC_WH_U, KC_WH_D) }, | ||||
|     [BASE] =   { ENCODER_CCW_CW(RM_HUEU, RM_HUED), ENCODER_CCW_CW(MS_WHLU, MS_WHLD) }, | ||||
| }; | ||||
| #endif | ||||
|  | ||||
| @ -18,8 +18,8 @@ const uint16_t PROGMEM keymaps[][MATRIX_ROWS][MATRIX_COLS] = { | ||||
| ), | ||||
|     [_LAYERB] = LAYOUT_5x16( | ||||
|         KC_ESC ,RM_TOGG,RM_PREV ,RM_NEXT    ,RM_VALD ,RM_VALU                                              ,RM_SPDD    ,RM_SPDU ,RM_HUED ,RM_HUEU ,RM_SATD ,RM_SATU , | ||||
|         KC_TAB ,KC_Q   ,KC_W    ,KC_E       ,KC_R    ,KC_T                                                 ,KC_Y       ,KC_BTN1 ,KC_MS_U ,KC_BTN2 ,KC_P    ,KC_EQL  , | ||||
|         KC_LCTL,KC_A   ,KC_S    ,KC_D       ,KC_F    ,KC_G                                                 ,KC_H       ,KC_MS_L ,KC_MS_D ,KC_MS_R ,KC_SCLN ,KC_QUOT , | ||||
|         KC_TAB ,KC_Q   ,KC_W    ,KC_E       ,KC_R    ,KC_T                                                 ,KC_Y       ,MS_BTN1 ,MS_UP   ,MS_BTN2 ,KC_P    ,KC_EQL  , | ||||
|         KC_LCTL,KC_A   ,KC_S    ,KC_D       ,KC_F    ,KC_G                                                 ,KC_H       ,MS_LEFT ,MS_DOWN ,MS_RGHT ,KC_SCLN ,KC_QUOT , | ||||
|         KC_LSFT,KC_Z   ,KC_X    ,KC_C       ,KC_V    ,KC_B    ,KC_LBRC          ,KC_MUTE          ,KC_RBRC ,KC_N       ,KC_M    ,KC_COMM ,KC_DOT  ,KC_SLSH ,KC_RSFT , | ||||
|         KC_LBRC,KC_PSCR,KC_CAPS ,_______    ,KC_LGUI ,KC_LALT ,KC_SPC  ,KC_END          ,KC_HOME  ,KC_ENT  ,KC_BSPC    ,_______ ,KC_INS  ,KC_DEL  ,KC_BSLS ,KC_RBRC | ||||
| ), | ||||
|  | ||||
| @ -5,8 +5,12 @@ | ||||
|     "usb": { | ||||
|         "vid": "0x416B", | ||||
|         "pid": "0x0081", | ||||
|         "device_version": "0.0.1", | ||||
|         "force_nkro": true | ||||
|         "device_version": "0.0.1" | ||||
|     }, | ||||
|     "host": { | ||||
|         "default": { | ||||
|             "nkro": true | ||||
|         } | ||||
|     }, | ||||
|     "rgb_matrix": { | ||||
|         "animations": { | ||||
|  | ||||
| @ -203,8 +203,8 @@ const uint16_t PROGMEM keymaps[][MATRIX_ROWS][MATRIX_COLS] = { | ||||
|   [_FN] = LAYOUT_ortho_5x15( /* FUNCTION */ | ||||
|      KC_NUM,  KC_F1,   KC_F2,   KC_F3,   KC_F4,   KC_F5,   KC_F6,   KC_F7,   KC_F8,   KC_F9,   KC_F10,  KC_F11,  KC_F12,  ___T___, ___T___, | ||||
|      KC_SCRL, KC_F13,  KC_F14,  KC_F15,  KC_F16,  KC_F17,  KC_F18,  KC_F19,  KC_F20,  KC_F21,  KC_F22,  KC_F23,  KC_F24,  KC_PAUS, KC_PSCR, | ||||
|      KC_CAPS, KC_BTN5, KC_BTN4, KC_BTN3, KC_BTN2, KC_ACL0, KC_ACL2, KC_MNXT, KC_VOLD, KC_VOLU, KC_MPLY, _______, ___T___, ___T___, KC_WH_U, | ||||
|      _______, _______, DF(_QW), DF(_CM), DF(_DV), _______, _______, _______, _______, _______, _______, ___T___, ___T___, KC_MS_U, KC_WH_D, | ||||
|      _______, _______, _______, _______, _______, KC_BTN1, KC_BTN1, _______, _______, _______, _______, _______, KC_MS_L, KC_MS_D, KC_MS_R | ||||
|      KC_CAPS, MS_BTN5, MS_BTN4, MS_BTN3, MS_BTN2, MS_ACL0, MS_ACL2, KC_MNXT, KC_VOLD, KC_VOLU, KC_MPLY, _______, ___T___, ___T___, MS_WHLU, | ||||
|      _______, _______, DF(_QW), DF(_CM), DF(_DV), _______, _______, _______, _______, _______, _______, ___T___, ___T___, MS_UP,   MS_WHLD, | ||||
|      _______, _______, _______, _______, _______, MS_BTN1, MS_BTN1, _______, _______, _______, _______, _______, MS_LEFT, MS_DOWN, MS_RGHT | ||||
|   ), | ||||
| }; | ||||
|  | ||||
| @ -27,8 +27,7 @@ | ||||
|     "rows": ["D2", "D3", "D1", "D0", "D4"] | ||||
|   }, | ||||
|   "diode_direction": "ROW2COL", | ||||
|   "processor": "atmega32u4", | ||||
|   "bootloader": "caterina", | ||||
|   "development_board": "promicro", | ||||
|   "layouts": { | ||||
|     "LAYOUT": { | ||||
|       "layout": [ | ||||
|  | ||||
| @ -31,9 +31,9 @@ bool encoder_update_kb(uint8_t index, bool clockwise) { | ||||
|     } | ||||
|     if (index == 0) { | ||||
|       if (clockwise) { | ||||
|           tap_code(KC_WH_U); | ||||
|           tap_code(MS_WHLU); | ||||
|       } else { | ||||
|           tap_code(KC_WH_D); | ||||
|           tap_code(MS_WHLD); | ||||
|       } | ||||
|     } | ||||
|     return true; | ||||
|  | ||||
| @ -31,9 +31,9 @@ bool encoder_update_kb(uint8_t index, bool clockwise) { | ||||
|     } | ||||
|     if (index == 0) { | ||||
|       if (clockwise) { | ||||
|           tap_code(KC_WH_U); | ||||
|           tap_code(MS_WHLU); | ||||
|       } else { | ||||
|           tap_code(KC_WH_D); | ||||
|           tap_code(MS_WHLD); | ||||
|       } | ||||
|     } | ||||
|     return true; | ||||
|  | ||||
| @ -25,8 +25,7 @@ | ||||
|             "pin": "D2" | ||||
|         } | ||||
|     }, | ||||
|     "processor": "atmega32u4", | ||||
|     "bootloader": "caterina", | ||||
|     "development_board": "promicro", | ||||
|     "layouts": { | ||||
|         "LAYOUT": { | ||||
|             "layout": [ | ||||
|  | ||||
| @ -39,8 +39,7 @@ | ||||
|             "pin": "D2" | ||||
|         } | ||||
|     }, | ||||
|     "processor": "atmega32u4", | ||||
|     "bootloader": "caterina", | ||||
|     "development_board": "promicro", | ||||
|     "layouts": { | ||||
|         "LAYOUT": { | ||||
|             "layout": [ | ||||
|  | ||||
| @ -38,8 +38,7 @@ | ||||
|     "ws2812": { | ||||
|         "pin": "D3" | ||||
|     }, | ||||
|     "processor": "atmega32u4", | ||||
|     "bootloader": "caterina", | ||||
|     "development_board": "promicro", | ||||
|     "layouts": { | ||||
|         "LAYOUT": { | ||||
|             "layout": [ | ||||
|  | ||||
| @ -53,8 +53,7 @@ | ||||
|             "alternating": true | ||||
|         } | ||||
|     }, | ||||
|     "processor": "atmega32u4", | ||||
|     "bootloader": "caterina", | ||||
|     "development_board": "promicro", | ||||
|     "layouts": { | ||||
|         "LAYOUT": { | ||||
|             "layout": [ | ||||
|  | ||||
| @ -37,8 +37,8 @@ const uint16_t PROGMEM keymaps[][MATRIX_ROWS][MATRIX_COLS] = { | ||||
|      */ | ||||
|     [0] = LAYOUT( | ||||
|         _______, KC_GRV , KC_1   , KC_2   , KC_3   , KC_4   , KC_5,                                           KC_6   , KC_7   , KC_8   , KC_9   , KC_0   , KC_MINS, KC_EQL, | ||||
|         _______, KC_BTN2, KC_Q   , KC_W   , KC_E   , KC_R   , KC_T,                                           KC_Y   , KC_U   , KC_I   , KC_O   , KC_P   , KC_LBRC, KC_RBRC, | ||||
|         _______, KC_BTN1, KC_A   , KC_S   , KC_D   , KC_F   , KC_G,    _______,                      _______, KC_H   , KC_J   , KC_K   , KC_L   , KC_SCLN, KC_QUOT, KC_NUHS, | ||||
|         _______, MS_BTN2, KC_Q   , KC_W   , KC_E   , KC_R   , KC_T,                                           KC_Y   , KC_U   , KC_I   , KC_O   , KC_P   , KC_LBRC, KC_RBRC, | ||||
|         _______, MS_BTN1, KC_A   , KC_S   , KC_D   , KC_F   , KC_G,    _______,                      _______, KC_H   , KC_J   , KC_K   , KC_L   , KC_SCLN, KC_QUOT, KC_NUHS, | ||||
|         _______, KC_NUBS, KC_Z   , KC_X   , KC_C   , KC_V   , KC_B,    KC_LALT, MO(2)  ,    _______, KC_DEL , KC_N   , KC_M   , KC_COMM, KC_DOT , KC_SLSH, _______, _______, | ||||
|                                                      KC_LSFT, _LG_ESC, KC_TAB , MO(1)  ,    _______, KC_ENT,  _RC_SPC, _RS_BSP | ||||
|     ), | ||||
| @ -79,9 +79,9 @@ const uint16_t PROGMEM keymaps[][MATRIX_ROWS][MATRIX_COLS] = { | ||||
|      */ | ||||
|     [2] = LAYOUT( | ||||
|         _______, _______, _______, _______, _______, _______, _______,                                        _______, _______, _______, _______, _______, _______, _______, | ||||
|         _______, _______, _______, _______, _______, _______, _______,                                        KC_WH_L, KC_WH_D, KC_WH_U, KC_WH_R, _______, _______, _______, | ||||
|         _______, _______, _______, _______, _______, _______, _______, _______,                      _______, KC_MS_L, KC_MS_D, KC_MS_U, KC_MS_R, _______, _______, _______, | ||||
|         _______, _______, _______, _______, _______, _______, _______,                                        MS_WHLL, MS_WHLD, MS_WHLU, MS_WHLR, _______, _______, _______, | ||||
|         _______, _______, _______, _______, _______, _______, _______, _______,                      _______, MS_LEFT, MS_DOWN, MS_UP,   MS_RGHT, _______, _______, _______, | ||||
|         _______, _______, _______, _______, _______, _______, _______, _______, _______,    _______, _______, _______, _______, _______, _______, _______, _______, _______, | ||||
|                                                      _______, _______, _______, _______,    _______, _______, KC_BTN1, KC_BTN2 | ||||
|                                                      _______, _______, _______, _______,    _______, _______, MS_BTN1, MS_BTN2 | ||||
|     ), | ||||
| }; | ||||
|  | ||||
| @ -27,8 +27,7 @@ | ||||
|         "levels": 7, | ||||
|         "max_brightness": 150 | ||||
|     }, | ||||
|     "processor": "atmega32u4", | ||||
|     "bootloader": "caterina", | ||||
|     "development_board": "promicro", | ||||
|     "layout_aliases": { | ||||
|         "LAYOUT_rev41lp": "LAYOUT" | ||||
|     }, | ||||
|  | ||||
| @ -21,6 +21,10 @@ along with this program.  If not, see <http://www.gnu.org/licenses/>. | ||||
| 
 | ||||
| #include "bajjak.h" | ||||
| 
 | ||||
| bool bajjak_left_led_1 = 0; | ||||
| bool bajjak_left_led_2 = 0; | ||||
| bool bajjak_left_led_3 = 0; | ||||
| 
 | ||||
| extern inline void bajjak_board_led_on(void); | ||||
| extern inline void bajjak_right_led_1_on(void); | ||||
| extern inline void bajjak_right_led_2_on(void); | ||||
|  | ||||
| @ -66,9 +66,9 @@ inline void bajjak_right_led_3_off(void)   { gpio_set_pin_input(B7); gpio_write_ | ||||
| inline void bajjak_right_led_off(uint8_t led) { gpio_set_pin_input(led+4); gpio_write_pin_low(led+4); } | ||||
| 
 | ||||
| #ifdef LEFT_LEDS | ||||
| bool bajjak_left_led_1; | ||||
| bool bajjak_left_led_2; | ||||
| bool bajjak_left_led_3; | ||||
| extern bool bajjak_left_led_1; | ||||
| extern bool bajjak_left_led_2; | ||||
| extern bool bajjak_left_led_3; | ||||
| 
 | ||||
| inline void bajjak_left_led_1_on(void)    { bajjak_left_led_1 = 1; } | ||||
| inline void bajjak_left_led_2_on(void)    { bajjak_left_led_2 = 1; } | ||||
|  | ||||
| @ -122,9 +122,9 @@ const uint16_t PROGMEM keymaps[][MATRIX_ROWS][MATRIX_COLS] = { | ||||
| //  Left hand                                                                                          Right hand
 | ||||
|     XXXXXXX,    XXXXXXX,    XXXXXXX,    XXXXXXX,    XXXXXXX,      XXXXXXX,      XXXXXXX,       XXXXXXX,     XXXXXXX,    XXXXXXX,    XXXXXXX,  XXXXXXX,    XXXXXXX,    XXXXXXX, | ||||
|     KC_SLEP,    KC_BRID,    KC_BRIU,    XXXXXXX,    XXXXXXX,      XXXXXXX,      KC_EJCT,       XXXXXXX,     KC_MPRV,    KC_MPLY,    KC_MNXT,  KC_MUTE,    KC_VOLD,    KC_VOLU, | ||||
|     XXXXXXX,    XXXXXXX,    KC_BTN1,    KC_MS_U,    KC_BTN2,      KC_WH_U,      XXXXXXX,       XXXXXXX,     XXXXXXX,    XXXXXXX,    XXXXXXX,  XXXXXXX,    XXXXXXX,    XXXXXXX, | ||||
|     QK_BOOT,    XXXXXXX,    KC_MS_L,    KC_MS_D,    KC_MS_R,      KC_WH_D,      XXXXXXX,       XXXXXXX,     XXXXXXX,    XXXXXXX,    XXXXXXX,  XXXXXXX,    XXXXXXX,    XXXXXXX, | ||||
|     _______,    XXXXXXX,    KC_WH_L,    XXXXXXX,    KC_WH_R,      XXXXXXX,                                  DF(SYMB),   XXXXXXX,    XXXXXXX,  XXXXXXX,    XXXXXXX,    XXXXXXX, | ||||
|     XXXXXXX,    XXXXXXX,    MS_BTN1,    MS_UP,      MS_BTN2,      MS_WHLU,      XXXXXXX,       XXXXXXX,     XXXXXXX,    XXXXXXX,    XXXXXXX,  XXXXXXX,    XXXXXXX,    XXXXXXX, | ||||
|     QK_BOOT,    XXXXXXX,    MS_LEFT,    MS_DOWN,    MS_RGHT,      MS_WHLD,      XXXXXXX,       XXXXXXX,     XXXXXXX,    XXXXXXX,    XXXXXXX,  XXXXXXX,    XXXXXXX,    XXXXXXX, | ||||
|     _______,    XXXXXXX,    MS_WHLL,    XXXXXXX,    MS_WHLR,      XXXXXXX,                                  DF(SYMB),   XXXXXXX,    XXXXXXX,  XXXXXXX,    XXXXXXX,    XXXXXXX, | ||||
|     _______,    _______,    _______,    _______,    _______,                                                            _______,    _______,  XXXXXXX,    XXXXXXX,    DF(BASE), | ||||
|                                                                        _______, _______,        _______, _______, | ||||
|                                                                                 _______,        _______, | ||||
|  | ||||
| @ -128,9 +128,9 @@ const uint16_t PROGMEM keymaps[][MATRIX_ROWS][MATRIX_COLS] = { | ||||
| //  Left hand                                                                                          Right hand
 | ||||
|     KC_SLEP,    KC_BRID,    KC_BRIU,            _______,    _______,      _______,      _______,       KC_MPRV,     KC_MPLY,      KC_MNXT,      KC_MUTE,    KC_VOLD,    KC_VOLU,    KC_EJCT, | ||||
|     _______,    _______,    _______,            _______,    _______,      _______,      _______,       _______,     _______,      _______,      _______,    _______,    _______,    _______, | ||||
|     KC_TAB,     _______,    KC_BTN1,            KC_MS_U,    KC_BTN2,      KC_WH_U,      _______,       _______,     _______,      _______,      _______,    _______,    _______,    _______, | ||||
|     KC_CAPS,    _______,    KC_MS_L,            KC_MS_D,    KC_MS_R,      KC_WH_D,      _______,       _______,     _______,      _______,      _______,    _______,    _______,    _______, | ||||
|     KC_LSFT,    _______,    KC_WH_L,            _______,    KC_WH_R,      _______,                                  _______,      _______,      _______,    _______,    _______,    _______, | ||||
|     KC_TAB,     _______,    MS_BTN1,            MS_UP,      MS_BTN2,      MS_WHLU,      _______,       _______,     _______,      _______,      _______,    _______,    _______,    _______, | ||||
|     KC_CAPS,    _______,    MS_LEFT,            MS_DOWN,    MS_RGHT,      MS_WHLD,      _______,       _______,     _______,      _______,      _______,    _______,    _______,    _______, | ||||
|     KC_LSFT,    _______,    MS_WHLL,            _______,    MS_WHLR,      _______,                                  _______,      _______,      _______,    _______,    _______,    _______, | ||||
|     KC_LCTL,    KC_LGUI,    ALT_T(KC_INSERT),   KC_LEFT,    KC_RGHT,                                                              KC_UP,        KC_DOWN,    _______,    _______,    QK_BOOT, | ||||
|                                                                  CTL_T(KC_ESC), KC_LALT,       KC_RGUI, CTL_T(KC_RALT), | ||||
|                                                                                 KC_HOME,       KC_PGUP, | ||||
|  | ||||
| @ -2,7 +2,7 @@ | ||||
|     "manufacturer": "Balloondog", | ||||
|     "keyboard_name": "TR90PM", | ||||
|     "maintainer": "balloondogcaps", | ||||
|     "bootloader": "caterina", | ||||
|     "development_board": "promicro", | ||||
|     "diode_direction": "COL2ROW", | ||||
|     "features": { | ||||
|         "bootmagic": true, | ||||
| @ -14,7 +14,6 @@ | ||||
|         "cols": ["D1", "D0", "D4"], | ||||
|         "rows": ["C6", "D7", "E6"] | ||||
|     }, | ||||
|     "processor": "atmega32u4", | ||||
|     "usb": { | ||||
|         "device_version": "1.0.0", | ||||
|         "pid": "0x0002", | ||||
|  | ||||
| @ -47,8 +47,7 @@ | ||||
|     "ws2812": { | ||||
|         "pin": "D3" | ||||
|     }, | ||||
|     "processor": "atmega32u4", | ||||
|     "bootloader": "caterina", | ||||
|     "development_board": "promicro", | ||||
|     "layouts": { | ||||
|         "LAYOUT": { | ||||
|             "layout": [ | ||||
|  | ||||
| @ -30,8 +30,7 @@ | ||||
|             "pin": "D2" | ||||
|         } | ||||
|     }, | ||||
|     "processor": "atmega32u4", | ||||
|     "bootloader": "caterina", | ||||
|     "development_board": "promicro", | ||||
|     "layouts": { | ||||
|         "LAYOUT": { | ||||
|             "layout": [ | ||||
|  | ||||
| @ -56,8 +56,7 @@ | ||||
|             "twinkle": true | ||||
|         } | ||||
|     }, | ||||
|     "processor": "atmega32u4", | ||||
|     "bootloader": "caterina", | ||||
|     "development_board": "promicro", | ||||
|     "layouts": { | ||||
|         "LAYOUT": { | ||||
|             "layout": [ | ||||
|  | ||||
| @ -1,87 +0,0 @@ | ||||
| /*
 | ||||
|  * Copyright 2020 Christopher Courtney <drashna@live.com> (@drashna) | ||||
|  * Copyright 2021 Quentin LEBASTARD <qlebastard@gmail.com> | ||||
|  * Copyright 2021 Charly Delay <charly@codesink.dev> (@0xcharly) | ||||
|  * | ||||
|  * This program is free software: you can redistribute it and/or modify | ||||
|  * it under the terms of the GNU General Publicw License as published by | ||||
|  * the Free Software Foundation, either version 2 of the License, or | ||||
|  * (at your option) any later version. | ||||
|  * | ||||
|  * This program is distributed in the hope that it will be useful, | ||||
|  * but WITHOUT ANY WARRANTY; without even the implied warranty of | ||||
|  * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the | ||||
|  * GNU General Public License for more details. | ||||
|  * | ||||
|  * You should have received a copy of the GNU General Public License | ||||
|  * along with this program.  If not, see <http://www.gnu.org/licenses/>.
 | ||||
|  */ | ||||
| 
 | ||||
| #include "charybdis.h" | ||||
| 
 | ||||
| // clang-format off
 | ||||
| #ifdef RGB_MATRIX_ENABLE | ||||
| /**
 | ||||
|  * \brief LEDs index. | ||||
|  * | ||||
|  * ╭────────────────────╮                 ╭────────────────────╮ | ||||
|  *    2   3   8   9  12                     30  27  26  21  20 | ||||
|  * ├────────────────────┤                 ├────────────────────┤ | ||||
|  *    1   4   7  10  13                     31  28  25  22  19 | ||||
|  * ├────────────────────┤                 ├────────────────────┤ | ||||
|  *    0   5   6  11  14                     32  29  24  23  18 | ||||
|  * ╰────────────────────╯                 ╰────────────────────╯ | ||||
|  *                   15  16  17     33  34  XX | ||||
|  *                 ╰────────────╯ ╰────────────╯ | ||||
|  * | ||||
|  * Note: the LED config simulates 36 LEDs instead of the actual 35 to prevent | ||||
|  * confusion when testing LEDs during assembly when handedness is not set | ||||
|  * correctly.  Those fake LEDs are bound to the physical top-left corner. | ||||
|  */ | ||||
| led_config_t g_led_config = { { | ||||
|     /* Key Matrix to LED index. */ | ||||
|     // Left split.
 | ||||
|     {      2,      3,      8,      9,     12 }, // Top row
 | ||||
|     {      1,      4,      7,     10,     13 }, // Middle row
 | ||||
|     {      0,      5,      6,     11,     14 }, // Bottom row
 | ||||
|     {     17, NO_LED,     15,     16, NO_LED }, // Thumb cluster
 | ||||
|     // Right split.
 | ||||
|     {     20,     21,     26,     27,     30 }, // Top row
 | ||||
|     {     19,     22,     25,     28,     31 }, // Middle row
 | ||||
|     {     18,     23,     24,     29,     32 }, // Bottom row
 | ||||
|     {     33, NO_LED,     34, NO_LED, NO_LED }, // Thumb cluster
 | ||||
| }, { | ||||
|     /* LED index to physical position. */ | ||||
|     // Left split.
 | ||||
|     /* index=0  */ {   0,  42 }, {   0,  21 }, {   0,   0 }, // col 1 (left most)
 | ||||
|     /* index=3  */ {  18,   0 }, {  18,  21 }, {  18,  42 }, // col 2
 | ||||
|     /* index=6  */ {  36,  42 }, {  36,  21 }, {  36,   0 }, | ||||
|     /* index=9  */ {  54,   0 }, {  54,  21 }, {  54,  42 }, | ||||
|     /* index=12 */ {  72,   0 }, {  72,  21 }, {  72,  42 }, | ||||
|     /* index=15 */ {  72,  64 }, {  90,  64 }, { 108,  64 }, // Thumb cluster
 | ||||
|     // Right split.
 | ||||
|     /* index=18 */ { 224,  42 }, { 224,  21 }, { 224,   0 }, // col 10 (right most)
 | ||||
|     /* index=21 */ { 206,   0 }, { 206,  21 }, { 206,  42 }, // col 9
 | ||||
|     /* index=24 */ { 188,  42 }, { 188,  21 }, { 188,   0 }, | ||||
|     /* index=27 */ { 170,   0 }, { 170,  21 }, { 170,  42 }, | ||||
|     /* index=30 */ { 152,   0 }, { 152,  21 }, { 152,  42 }, | ||||
|     /* index=33 */ { 134,  64 }, { 152,  64 }, {   0,   0 }, | ||||
| }, { | ||||
|     /* LED index to flag. */ | ||||
|     // Left split.
 | ||||
|     /* index=0  */ LED_FLAG_KEYLIGHT, LED_FLAG_KEYLIGHT, LED_FLAG_KEYLIGHT, // col 1
 | ||||
|     /* index=3  */ LED_FLAG_KEYLIGHT, LED_FLAG_KEYLIGHT, LED_FLAG_KEYLIGHT, // col 2
 | ||||
|     /* index=6  */ LED_FLAG_KEYLIGHT, LED_FLAG_KEYLIGHT, LED_FLAG_KEYLIGHT, | ||||
|     /* index=9  */ LED_FLAG_KEYLIGHT, LED_FLAG_KEYLIGHT, LED_FLAG_KEYLIGHT, | ||||
|     /* index=12 */ LED_FLAG_KEYLIGHT, LED_FLAG_KEYLIGHT, LED_FLAG_KEYLIGHT, | ||||
|     /* index=15 */ LED_FLAG_MODIFIER, LED_FLAG_MODIFIER, LED_FLAG_MODIFIER, // Thumb cluster
 | ||||
|     // Right split.
 | ||||
|     /* index=18 */ LED_FLAG_KEYLIGHT, LED_FLAG_KEYLIGHT, LED_FLAG_KEYLIGHT, // col 10
 | ||||
|     /* index=21 */ LED_FLAG_KEYLIGHT, LED_FLAG_KEYLIGHT, LED_FLAG_KEYLIGHT, // col 9
 | ||||
|     /* index=24 */ LED_FLAG_KEYLIGHT, LED_FLAG_KEYLIGHT, LED_FLAG_KEYLIGHT, | ||||
|     /* index=27 */ LED_FLAG_KEYLIGHT, LED_FLAG_KEYLIGHT, LED_FLAG_KEYLIGHT, | ||||
|     /* index=30 */ LED_FLAG_KEYLIGHT, LED_FLAG_KEYLIGHT, LED_FLAG_KEYLIGHT, | ||||
|     /* index=33 */ LED_FLAG_KEYLIGHT, LED_FLAG_KEYLIGHT, LED_FLAG_KEYLIGHT, // Thumb cluster
 | ||||
| } }; | ||||
| #endif | ||||
| // clang-format on
 | ||||
| @ -1,28 +1,9 @@ | ||||
| /*
 | ||||
|  * Copyright 2020 Christopher Courtney <drashna@live.com> (@drashna) | ||||
|  * Copyright 2021 Stefan Kerkmann (@KarlK90) | ||||
|  * Copyright 2021 Charly Delay <charly@codesink.dev> (@0xcharly) | ||||
|  * | ||||
|  * This program is free software: you can redistribute it and/or modify | ||||
|  * it under the terms of the GNU General Publicw License as published by | ||||
|  * the Free Software Foundation, either version 2 of the License, or | ||||
|  * (at your option) any later version. | ||||
|  * | ||||
|  * This program is distributed in the hope that it will be useful, | ||||
|  * but WITHOUT ANY WARRANTY; without even the implied warranty of | ||||
|  * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the | ||||
|  * GNU General Public License for more details. | ||||
|  * | ||||
|  * You should have received a copy of the GNU General Public License | ||||
|  * along with this program.  If not, see <http://www.gnu.org/licenses/>.
 | ||||
|  */ | ||||
| 
 | ||||
| // Copyright 2020 Christopher Courtney <drashna@live.com> (@drashna)
 | ||||
| // Copyright 2021 Stefan Kerkmann (@KarlK90)
 | ||||
| // Copyright 2021 Charly Delay <charly@codesink.dev> (@0xcharly)
 | ||||
| // SPDX-License-Identifier: GPL-2.0-or-later
 | ||||
| #pragma once | ||||
| 
 | ||||
| /* Handedness. */ | ||||
| #define SPLIT_HAND_PIN A3 // High -> left, Low -> right.
 | ||||
| 
 | ||||
| /* RGB settings. */ | ||||
| #define WS2812_PWM_DRIVER PWMD2 | ||||
| #define WS2812_PWM_CHANNEL 2 | ||||
| #define WS2812_PWM_PAL_MODE 1 | ||||
| @ -30,14 +11,6 @@ | ||||
| #define WS2812_PWM_DMA_STREAM STM32_DMA1_STREAM1 | ||||
| #define WS2812_PWM_DMA_CHANNEL 3 | ||||
| 
 | ||||
| /* Serial configuration for split keyboard. */ | ||||
| #define SERIAL_USART_TX_PIN A9 | ||||
| 
 | ||||
| /* CRC. */ | ||||
| #define CRC8_USE_TABLE | ||||
| #define CRC8_OPTIMIZE_SPEED | ||||
| 
 | ||||
| /* SPI config for EEPROM and pmw3360 sensor. */ | ||||
| #define SPI_DRIVER SPID1 | ||||
| #define SPI_SCK_PIN A5 | ||||
| #define SPI_SCK_PAL_MODE 5 | ||||
| @ -46,9 +19,7 @@ | ||||
| #define SPI_MISO_PIN A6 | ||||
| #define SPI_MISO_PAL_MODE 5 | ||||
| 
 | ||||
| /* EEPROM config. */ | ||||
| #define EXTERNAL_EEPROM_SPI_SLAVE_SELECT_PIN A4 | ||||
| 
 | ||||
| /* PMW3360 settings. */ | ||||
| #define POINTING_DEVICE_CS_PIN B14 | ||||
| #define PMW33XX_CS_DIVISOR 64 | ||||
|  | ||||
| @ -1,21 +1,6 @@ | ||||
| /**
 | ||||
|  * Copyright 2020 Nick Brassel (tzarc) | ||||
|  * Copyright 2021 Charly Delay <charly@codesink.dev> (@0xcharly) | ||||
|  * | ||||
|  * This program is free software: you can redistribute it and/or modify | ||||
|  * it under the terms of the GNU General Public License as published by | ||||
|  * the Free Software Foundation, either version 2 of the License, or | ||||
|  * (at your option) any later version. | ||||
|  * | ||||
|  * This program is distributed in the hope that it will be useful, | ||||
|  * but WITHOUT ANY WARRANTY; without even the implied warranty of | ||||
|  * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the | ||||
|  * GNU General Public License for more details. | ||||
|  * | ||||
|  * You should have received a copy of the GNU General Public License | ||||
|  * along with this program.  If not, see <http://www.gnu.org/licenses/>.
 | ||||
|  */ | ||||
| 
 | ||||
| // Copyright 2020 Nick Brassel (tzarc)
 | ||||
| // Copyright 2021 Charly Delay <charly@codesink.dev> (@0xcharly)
 | ||||
| // SPDX-License-Identifier: GPL-2.0-or-later
 | ||||
| #pragma once | ||||
| 
 | ||||
| #define HAL_USE_PWM TRUE | ||||
|  | ||||
| @ -1,38 +1,23 @@ | ||||
| { | ||||
|     "keyboard_name": "Charybdis Nano (3x5) Blackpill", | ||||
|     "usb": { | ||||
|         "device_version": "1.0.0", | ||||
|         "shared_endpoint": { | ||||
|             "keyboard": true | ||||
|         } | ||||
|     }, | ||||
|     "features": { | ||||
|         "bootmagic": true, | ||||
|         "mousekey": true, | ||||
|         "extrakey": true, | ||||
|         "rgb_matrix": true, | ||||
|         "pointing_device": true | ||||
|     }, | ||||
|     "development_board": "blackpill_f411", | ||||
|     "eeprom": { | ||||
|         "driver": "spi" | ||||
|     }, | ||||
|     "split": { | ||||
|         "enabled": true | ||||
|     }, | ||||
|     "rgb_matrix": { | ||||
|         "driver": "ws2812" | ||||
|     }, | ||||
|     "ws2812": { | ||||
|         "pin": "A1", | ||||
|         "driver": "pwm" | ||||
|     }, | ||||
|     "build": { | ||||
|         "debounce_type": "asym_eager_defer_pk" | ||||
|     }, | ||||
|     "matrix_pins": { | ||||
|         "cols": ["B1", "B10", "B3", "B4", "B5"], | ||||
|         "rows": ["A2", "B8", "A8", "B9"] | ||||
|     }, | ||||
|     "diode_direction": "ROW2COL", | ||||
|     "development_board": "blackpill_f411" | ||||
|     "split": { | ||||
|         "handedness": { | ||||
|             "pin": "A3" | ||||
|         }, | ||||
|         "serial": { | ||||
|             "driver": "usart", | ||||
|             "pin": "A9" | ||||
|         } | ||||
|     }, | ||||
|     "ws2812": { | ||||
|         "driver": "pwm", | ||||
|         "pin": "A1" | ||||
|     } | ||||
| } | ||||
|  | ||||
| @ -1,22 +1,7 @@ | ||||
| /*
 | ||||
|  * Copyright 2020 Nick Brassel (tzarc) | ||||
|  * Copyright 2021 Stefan Kerkmann (@KarlK90) | ||||
|  * Copyright 2021 Charly Delay <charly@codesink.dev> (@0xcharly) | ||||
|  * | ||||
|  * This program is free software: you can redistribute it and/or modify | ||||
|  * it under the terms of the GNU General Public License as published by | ||||
|  * the Free Software Foundation, either version 2 of the License, or | ||||
|  * (at your option) any later version. | ||||
|  * | ||||
|  * This program is distributed in the hope that it will be useful, | ||||
|  * but WITHOUT ANY WARRANTY; without even the implied warranty of | ||||
|  * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the | ||||
|  * GNU General Public License for more details. | ||||
|  * | ||||
|  * You should have received a copy of the GNU General Public License | ||||
|  * along with this program.  If not, see <http://www.gnu.org/licenses/>.
 | ||||
|  */ | ||||
| 
 | ||||
| // Copyright 2020 Nick Brassel (tzarc)
 | ||||
| // Copyright 2021 Stefan Kerkmann (@KarlK90)
 | ||||
| // Copyright 2021 Charly Delay <charly@codesink.dev> (@0xcharly)
 | ||||
| // SPDX-License-Identifier: GPL-2.0-or-later
 | ||||
| #pragma once | ||||
| 
 | ||||
| #include_next <mcuconf.h> | ||||
| @ -30,11 +15,6 @@ | ||||
| #undef STM32_SPI_USE_SPI1 | ||||
| #define STM32_SPI_USE_SPI1 TRUE | ||||
| 
 | ||||
| #undef STM32_SPI_SPI1_RX_DMA_STREAM | ||||
| #define STM32_SPI_SPI1_RX_DMA_STREAM STM32_DMA_STREAM_ID(2, 0) | ||||
| #undef STM32_SPI_SPI1_TX_DMA_STREAM | ||||
| #define STM32_SPI_SPI1_TX_DMA_STREAM STM32_DMA_STREAM_ID(2, 3) | ||||
| 
 | ||||
| #undef STM32_SERIAL_USE_USART1 | ||||
| #define STM32_SERIAL_USE_USART1 TRUE | ||||
| 
 | ||||
|  | ||||
| @ -1,3 +0,0 @@ | ||||
| # Charybdis Nano (3x5) BlackPill | ||||
| 
 | ||||
| An ergonomic keyboard with integrated trackball, with BlackPill (STM32F411) mod. | ||||
| @ -1,5 +0,0 @@ | ||||
| AUDIO_SUPPORTED = no        # Audio is not supported | ||||
| 
 | ||||
| POINTING_DEVICE_DRIVER = pmw3360 | ||||
| MOUSE_SHARED_EP = no # Unify multiple HID interfaces into a single Endpoint | ||||
| SERIAL_DRIVER = usart | ||||
| @ -1,22 +0,0 @@ | ||||
| /*
 | ||||
|  * Copyright 2021 Quentin LEBASTARD <qlebastard@gmail.com> | ||||
|  * Copyright 2021 Charly Delay <charly@codesink.dev> (@0xcharly) | ||||
|  * | ||||
|  * This program is free software: you can redistribute it and/or modify | ||||
|  * it under the terms of the GNU General Public License as published by | ||||
|  * the Free Software Foundation, either version 2 of the License, or | ||||
|  * (at your option) any later version. | ||||
|  * | ||||
|  * This program is distributed in the hope that it will be useful, | ||||
|  * but WITHOUT ANY WARRANTY; without even the implied warranty of | ||||
|  * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the | ||||
|  * GNU General Public License for more details. | ||||
|  * | ||||
|  * You should have received a copy of the GNU General Public License | ||||
|  * along with this program.  If not, see <http://www.gnu.org/licenses/>.
 | ||||
|  */ | ||||
| 
 | ||||
| #pragma once | ||||
| 
 | ||||
| /* Trackball angle adjustment. */ | ||||
| #define ROTATIONAL_TRANSFORM_ANGLE -25 | ||||
							
								
								
									
										5
									
								
								keyboards/bastardkb/charybdis/3x5/elitec/config.h
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										5
									
								
								keyboards/bastardkb/charybdis/3x5/elitec/config.h
									
									
									
									
									
										Normal file
									
								
							| @ -0,0 +1,5 @@ | ||||
| // Copyright 2022 Charly Delay <charly@codesink.dev> (@0xcharly)
 | ||||
| // SPDX-License-Identifier: GPL-2.0-or-later
 | ||||
| #pragma once | ||||
| 
 | ||||
| #define POINTING_DEVICE_CS_PIN F0 | ||||
Some files were not shown because too many files have changed in this diff Show More
		Loading…
	
	
			
			x
			
			
		
	
		Reference in New Issue
	
	Block a user