Compare commits
	
		
			66 Commits
		
	
	
		
			0.6.55
			...
			keymap_fol
		
	
	| Author | SHA1 | Date | |
|---|---|---|---|
|  | 1b7efbc03b | ||
|  | e54159d9e8 | ||
|  | d01f40edbf | ||
|  | 13f49ad8d9 | ||
|  | 0f89d7efed | ||
|  | 2fccc1a064 | ||
|  | 53c518f7d4 | ||
|  | bcbc64aed8 | ||
|  | 459dfa510e | ||
|  | 5bb1e7869c | ||
|  | 58c4ba096a | ||
|  | c8cc9c6aab | ||
|  | e1e4a51472 | ||
|  | c53a8ead93 | ||
|  | a6afb16c90 | ||
|  | 21665df8eb | ||
|  | ff4a1ae5d2 | ||
|  | 018a0142d2 | ||
|  | c1f6f1308b | ||
|  | 274283420d | ||
|  | 874f5a5c07 | ||
|  | 161c68b48a | ||
|  | 5fad8d774d | ||
|  | 4fdc9badd3 | ||
|  | af6107bee8 | ||
|  | d233737c95 | ||
|  | 3e282ab203 | ||
|  | 1c0d85c143 | ||
|  | 7c19e9fa04 | ||
|  | 9fccfc8dd5 | ||
|  | 1cb72a9c59 | ||
|  | 82146ecfc0 | ||
|  | 4a1984d33e | ||
|  | 676080372c | ||
|  | 0af7415981 | ||
|  | df371458b3 | ||
|  | e0e5efbead | ||
|  | edb4460e64 | ||
|  | fe72bfa070 | ||
|  | 25642c8840 | ||
|  | 03b1904b2e | ||
|  | bb71a988c2 | ||
|  | ddee61c9ba | ||
|  | 91efe74365 | ||
|  | 12a64ff24b | ||
|  | b034896cd3 | ||
|  | 2bd625b754 | ||
|  | da32068f48 | ||
|  | b308d6709e | ||
|  | 123ad0de95 | ||
|  | 00fc38435f | ||
|  | 8b5b41bb47 | ||
|  | 4bdde668e1 | ||
|  | 3c0d86eb47 | ||
|  | f60166c1a1 | ||
|  | 7d59f83b2e | ||
|  | be81cd8c98 | ||
|  | b075df1c87 | ||
|  | 8a91aa5e6c | ||
|  | fae437cfad | ||
|  | fc91bf4a65 | ||
|  | 78ea99d154 | ||
|  | 2165f9d654 | ||
|  | 31df12c84f | ||
|  | d09d9f32bd | ||
|  | 690a08cbbb | 
							
								
								
									
										1
									
								
								.gitmodules
									
									
									
									
										vendored
									
									
								
							
							
						
						
									
										1
									
								
								.gitmodules
									
									
									
									
										vendored
									
									
								
							| @@ -1,6 +1,7 @@ | ||||
| [submodule "lib/chibios"] | ||||
| 	path = lib/chibios | ||||
| 	url = https://github.com/qmk/ChibiOS | ||||
|   branch = handwire | ||||
| [submodule "lib/chibios-contrib"] | ||||
| 	path = lib/chibios-contrib | ||||
| 	url = https://github.com/qmk/ChibiOS-Contrib | ||||
|   | ||||
							
								
								
									
										13
									
								
								Makefile
									
									
									
									
									
								
							
							
						
						
									
										13
									
								
								Makefile
									
									
									
									
									
								
							| @@ -320,6 +320,14 @@ define PARSE_KEYBOARD | ||||
|     KEYMAPS += $$(notdir $$(patsubst %/.,%,$$(wildcard $(ROOT_DIR)/keyboards/$$(KEYBOARD_FOLDER_PATH_3)/keymaps/*/.))) | ||||
|     KEYMAPS += $$(notdir $$(patsubst %/.,%,$$(wildcard $(ROOT_DIR)/keyboards/$$(KEYBOARD_FOLDER_PATH_4)/keymaps/*/.))) | ||||
|     KEYMAPS += $$(notdir $$(patsubst %/.,%,$$(wildcard $(ROOT_DIR)/keyboards/$$(KEYBOARD_FOLDER_PATH_5)/keymaps/*/.))) | ||||
|  | ||||
|     # get subkeymaps too | ||||
|     KEYMAPS += $$(patsubst $(ROOT_DIR)/keyboards/$$(KEYBOARD_FOLDER_PATH_1)/keymaps/%,%,$$(patsubst %/.,%,$$(wildcard $(ROOT_DIR)/keyboards/$$(KEYBOARD_FOLDER_PATH_1)/keymaps/*/*/.))) | ||||
|     KEYMAPS += $$(patsubst $(ROOT_DIR)/keyboards/$$(KEYBOARD_FOLDER_PATH_2)/keymaps/%,%,$$(patsubst %/.,%,$$(wildcard $(ROOT_DIR)/keyboards/$$(KEYBOARD_FOLDER_PATH_2)/keymaps/*/*/.))) | ||||
|     KEYMAPS += $$(patsubst $(ROOT_DIR)/keyboards/$$(KEYBOARD_FOLDER_PATH_3)/keymaps/%,%,$$(patsubst %/.,%,$$(wildcard $(ROOT_DIR)/keyboards/$$(KEYBOARD_FOLDER_PATH_3)/keymaps/*/*/.))) | ||||
|     KEYMAPS += $$(patsubst $(ROOT_DIR)/keyboards/$$(KEYBOARD_FOLDER_PATH_4)/keymaps/%,%,$$(patsubst %/.,%,$$(wildcard $(ROOT_DIR)/keyboards/$$(KEYBOARD_FOLDER_PATH_4)/keymaps/*/*/.))) | ||||
|     KEYMAPS += $$(patsubst $(ROOT_DIR)/keyboards/$$(KEYBOARD_FOLDER_PATH_5)/keymaps/%,%,$$(patsubst %/.,%,$$(wildcard $(ROOT_DIR)/keyboards/$$(KEYBOARD_FOLDER_PATH_5)/keymaps/*/*/.))) | ||||
|  | ||||
|     # this might be needed, but in a different form | ||||
|     #KEYMAPS := $$(sort $$(filter-out $$(KEYBOARD_FOLDER_1) $$(KEYBOARD_FOLDER_2) \ | ||||
|         $$(KEYBOARD_FOLDER_3) $$(KEYBOARD_FOLDER_4) $$(KEYBOARD_FOLDER_5), $$(KEYMAPS))) | ||||
| @@ -356,6 +364,8 @@ define PARSE_KEYBOARD | ||||
|  | ||||
|     KEYMAPS := $$(sort $$(KEYMAPS) $$(LAYOUT_KEYMAPS)) | ||||
|  | ||||
|     # $$(eval $$(info $$(KEYMAPS))) | ||||
|  | ||||
|     # if the rule after removing the start of it is empty (we haven't specified a kemap or target) | ||||
|     # compile all the keymaps | ||||
|     ifeq ($$(RULE),) | ||||
| @@ -411,7 +421,8 @@ define PARSE_KEYMAP | ||||
|     MAKE_TARGET := $$(patsubst :%,%,$$(RULE)) | ||||
|     # We need to generate an unique indentifer to append to the COMMANDS list | ||||
|     CURRENT_KB_UNDER := $$(subst /,_,$$(CURRENT_KB)) | ||||
|     COMMAND := COMMAND_KEYBOARD_$$(CURRENT_KB_UNDER)_KEYMAP_$$(CURRENT_KM) | ||||
|     CURRENT_KM_UNDER := $$(subst /,_,$$(CURRENT_KM)) | ||||
|     COMMAND := COMMAND_KEYBOARD_$$(CURRENT_KB_UNDER)_KEYMAP_$$(CURRENT_KM_UNDER) | ||||
|     # If we are compiling a keyboard without a subproject, we want to display just the name | ||||
|     # of the keyboard, otherwise keyboard/subproject | ||||
|     KB_SP := $$(CURRENT_KB) | ||||
|   | ||||
| @@ -19,8 +19,9 @@ KEYBOARD_FOLDER_4 := $(notdir $(KEYBOARD_FOLDER_PATH_4)) | ||||
| KEYBOARD_FOLDER_5 := $(notdir $(KEYBOARD_FOLDER_PATH_5)) | ||||
|  | ||||
| KEYBOARD_FILESAFE := $(subst /,_,$(KEYBOARD)) | ||||
| KEYMAP_FILESAFE := $(subst /,_,$(KEYMAP)) | ||||
|  | ||||
| TARGET ?= $(KEYBOARD_FILESAFE)_$(KEYMAP) | ||||
| TARGET ?= $(KEYBOARD_FILESAFE)_$(KEYMAP_FILESAFE) | ||||
| KEYBOARD_OUTPUT := $(BUILD_DIR)/obj_$(KEYBOARD_FILESAFE) | ||||
|  | ||||
| # Force expansion | ||||
| @@ -176,26 +177,44 @@ MAIN_KEYMAP_PATH_3 := $(KEYBOARD_PATH_3)/keymaps/$(KEYMAP) | ||||
| MAIN_KEYMAP_PATH_4 := $(KEYBOARD_PATH_4)/keymaps/$(KEYMAP) | ||||
| MAIN_KEYMAP_PATH_5 := $(KEYBOARD_PATH_5)/keymaps/$(KEYMAP) | ||||
|  | ||||
| PARENT_MAIN_KEYMAP_PATH_1 := $(patsubst %/,%,$(dir $(MAIN_KEYMAP_PATH_1))) | ||||
| PARENT_MAIN_KEYMAP_PATH_2 := $(patsubst %/,%,$(dir $(MAIN_KEYMAP_PATH_2))) | ||||
| PARENT_MAIN_KEYMAP_PATH_3 := $(patsubst %/,%,$(dir $(MAIN_KEYMAP_PATH_3))) | ||||
| PARENT_MAIN_KEYMAP_PATH_4 := $(patsubst %/,%,$(dir $(MAIN_KEYMAP_PATH_4))) | ||||
| PARENT_MAIN_KEYMAP_PATH_5 := $(patsubst %/,%,$(dir $(MAIN_KEYMAP_PATH_5))) | ||||
|  | ||||
| # $(info $(PARENT_MAIN_KEYMAP_PATH_1)) | ||||
|  | ||||
| ifneq ("$(wildcard $(MAIN_KEYMAP_PATH_5)/keymap.c)","") | ||||
|     -include $(MAIN_KEYMAP_PATH_5)/rules.mk | ||||
|     KEYMAP_C := $(MAIN_KEYMAP_PATH_5)/keymap.c | ||||
|     KEYMAP_PATH := $(MAIN_KEYMAP_PATH_5) | ||||
| else ifneq ("$(wildcard $(PARENT_MAIN_KEYMAP_PATH_5)/keymap.c)","") | ||||
|     KEYMAP_C := $(PARENT_MAIN_KEYMAP_PATH_5)/keymap.c | ||||
|     KEYMAP_PATH := $(MAIN_KEYMAP_PATH_5) | ||||
| else ifneq ("$(wildcard $(MAIN_KEYMAP_PATH_4)/keymap.c)","") | ||||
|     -include $(MAIN_KEYMAP_PATH_4)/rules.mk | ||||
|     KEYMAP_C := $(MAIN_KEYMAP_PATH_4)/keymap.c | ||||
|     KEYMAP_PATH := $(MAIN_KEYMAP_PATH_4) | ||||
| else ifneq ("$(wildcard $(PARENT_MAIN_KEYMAP_PATH_4)/keymap.c)","") | ||||
|     KEYMAP_C := $(PARENT_MAIN_KEYMAP_PATH_4)/keymap.c | ||||
|     KEYMAP_PATH := $(MAIN_KEYMAP_PATH_4) | ||||
| else ifneq ("$(wildcard $(MAIN_KEYMAP_PATH_3)/keymap.c)","") | ||||
|     -include $(MAIN_KEYMAP_PATH_3)/rules.mk | ||||
|     KEYMAP_C := $(MAIN_KEYMAP_PATH_3)/keymap.c | ||||
|     KEYMAP_PATH := $(MAIN_KEYMAP_PATH_3) | ||||
| else ifneq ("$(wildcard $(PARENT_MAIN_KEYMAP_PATH_3)/keymap.c)","") | ||||
|     KEYMAP_C := $(PARENT_MAIN_KEYMAP_PATH_3)/keymap.c | ||||
|     KEYMAP_PATH := $(MAIN_KEYMAP_PATH_3) | ||||
| else ifneq ("$(wildcard $(MAIN_KEYMAP_PATH_2)/keymap.c)","") | ||||
|     -include $(MAIN_KEYMAP_PATH_2)/rules.mk | ||||
|     KEYMAP_C := $(MAIN_KEYMAP_PATH_2)/keymap.c | ||||
|     KEYMAP_PATH := $(MAIN_KEYMAP_PATH_2) | ||||
| else ifneq ("$(wildcard $(PARENT_MAIN_KEYMAP_PATH_2)/keymap.c)","") | ||||
|     KEYMAP_C := $(PARENT_MAIN_KEYMAP_PATH_2)/keymap.c | ||||
|     KEYMAP_PATH := $(MAIN_KEYMAP_PATH_2) | ||||
| else ifneq ("$(wildcard $(MAIN_KEYMAP_PATH_1)/keymap.c)","") | ||||
|     -include $(MAIN_KEYMAP_PATH_1)/rules.mk | ||||
|     KEYMAP_C := $(MAIN_KEYMAP_PATH_1)/keymap.c | ||||
|     KEYMAP_PATH := $(MAIN_KEYMAP_PATH_1) | ||||
| else ifneq ("$(wildcard $(PARENT_MAIN_KEYMAP_PATH_1)/keymap.c)","") | ||||
|     KEYMAP_C := $(PARENT_MAIN_KEYMAP_PATH_1)/keymap.c | ||||
|     KEYMAP_PATH := $(MAIN_KEYMAP_PATH_1) | ||||
| else ifneq ($(LAYOUTS),) | ||||
|     include build_layout.mk | ||||
| else | ||||
| @@ -203,26 +222,34 @@ else | ||||
|     # this state should never be reached | ||||
| endif | ||||
|  | ||||
|  | ||||
| PARENT_KEYMAP_PATH := $(patsubst %/,%,$(dir $(KEYMAP_PATH))) | ||||
|  | ||||
| # User space stuff | ||||
| ifeq ("$(USER_NAME)","") | ||||
|     USER_NAME := $(KEYMAP) | ||||
| endif | ||||
| USER_PATH := users/$(USER_NAME) | ||||
|  | ||||
| -include $(USER_PATH)/rules.mk | ||||
| ifneq ("$(wildcard $(USER_PATH)/config.h)","") | ||||
|     CONFIG_H += $(USER_PATH)/config.h | ||||
| endif | ||||
|  | ||||
|  | ||||
| # Object files directory | ||||
| #     To put object files in current directory, use a dot (.), do NOT make | ||||
| #     this an empty or blank macro! | ||||
| KEYMAP_OUTPUT := $(BUILD_DIR)/obj_$(TARGET) | ||||
|  | ||||
| -include $(PARENT_KEYMAP_PATH)/rules.mk | ||||
| -include $(KEYMAP_PATH)/rules.mk | ||||
| -include $(USER_PATH)/rules.mk | ||||
|  | ||||
| ifneq ("$(wildcard $(PARENT_KEYMAP_PATH)/config.h)","") | ||||
|     CONFIG_H += $(PARENT_KEYMAP_PATH)/config.h | ||||
| endif | ||||
| ifneq ("$(wildcard $(KEYMAP_PATH)/config.h)","") | ||||
|     CONFIG_H += $(KEYMAP_PATH)/config.h | ||||
| endif | ||||
| ifneq ("$(wildcard $(USER_PATH)/config.h)","") | ||||
|     CONFIG_H += $(USER_PATH)/config.h | ||||
| endif | ||||
|  | ||||
| # # project specific files | ||||
| SRC += $(KEYBOARD_SRC) \ | ||||
| @@ -233,6 +260,7 @@ SRC += $(KEYBOARD_SRC) \ | ||||
| #EXTRALDFLAGS = -Wl,--relax | ||||
|  | ||||
| # Search Path | ||||
| VPATH += $(PARENT_KEYMAP_PATH) | ||||
| VPATH += $(KEYMAP_PATH) | ||||
| VPATH += $(KEYBOARD_PATHS) | ||||
| VPATH += $(COMMON_VPATH) | ||||
|   | ||||
| @@ -3,11 +3,15 @@ LAYOUTS_REPOS := $(patsubst %/,%,$(sort $(dir $(wildcard $(LAYOUTS_PATH)/*/)))) | ||||
|  | ||||
| define SEARCH_LAYOUTS_REPO | ||||
|     LAYOUT_KEYMAP_PATH := $$(LAYOUTS_REPO)/$$(LAYOUT)/$$(KEYMAP) | ||||
|     PARENT_LAYOUT_KEYMAP_PATH := $(patsubst %/,%,$(dir $(LAYOUT_KEYMAP_PATH))) | ||||
|     LAYOUT_KEYMAP_C := $$(LAYOUT_KEYMAP_PATH)/keymap.c | ||||
|     PARENT_LAYOUT_KEYMAP_C := $$(PARENT_LAYOUT_KEYMAP_PATH)/keymap.c | ||||
|     ifneq ("$$(wildcard $$(LAYOUT_KEYMAP_C))","") | ||||
|         -include $$(LAYOUT_KEYMAP_PATH)/rules.mk | ||||
|         KEYMAP_C := $$(LAYOUT_KEYMAP_C) | ||||
|         KEYMAP_PATH := $$(LAYOUT_KEYMAP_PATH) | ||||
|     else ifneq ("$$(wildcard $$(PARENT_LAYOUT_KEYMAP_C))","") | ||||
|         KEYMAP_C := $$(PARENT_LAYOUT_KEYMAP_C) | ||||
|         KEYMAP_PATH := $$(LAYOUT_KEYMAP_PATH) | ||||
|     endif | ||||
| endef | ||||
|  | ||||
|   | ||||
							
								
								
									
										10
									
								
								common.mk
									
									
									
									
									
								
							
							
						
						
									
										10
									
								
								common.mk
									
									
									
									
									
								
							| @@ -3,16 +3,16 @@ include message.mk | ||||
| # Directory common source files exist | ||||
| TOP_DIR = . | ||||
| TMK_DIR = tmk_core | ||||
| TMK_PATH = $(TOP_DIR)/$(TMK_DIR) | ||||
| LIB_PATH = $(TOP_DIR)/lib | ||||
| TMK_PATH = $(TMK_DIR) | ||||
| LIB_PATH = lib | ||||
|  | ||||
| QUANTUM_DIR = quantum | ||||
| QUANTUM_PATH = $(TOP_DIR)/$(QUANTUM_DIR) | ||||
| QUANTUM_PATH = $(QUANTUM_DIR) | ||||
|  | ||||
| DRIVER_DIR = drivers | ||||
| DRIVER_PATH = $(TOP_DIR)/$(DRIVER_DIR) | ||||
| DRIVER_PATH = $(DRIVER_DIR) | ||||
|  | ||||
| BUILD_DIR := $(TOP_DIR)/.build | ||||
| BUILD_DIR := .build | ||||
|  | ||||
| COMMON_VPATH := $(TOP_DIR) | ||||
| COMMON_VPATH += $(TMK_PATH) | ||||
|   | ||||
| @@ -20,6 +20,13 @@ SERIAL_SRC += $(wildcard $(SERIAL_PATH)/system/*.c) | ||||
| SERIAL_DEFS += -DSERIAL_LINK_ENABLE | ||||
| COMMON_VPATH += $(SERIAL_PATH) | ||||
|  | ||||
| COMMON_VPATH += $(DRIVER_PATH) | ||||
| ifeq ($(PLATFORM),AVR) | ||||
|   COMMON_VPATH += $(DRIVER_PATH)/avr | ||||
| else | ||||
|   COMMON_VPATH += $(DRIVER_PATH)/arm | ||||
| endif | ||||
|  | ||||
| ifeq ($(strip $(API_SYSEX_ENABLE)), yes) | ||||
|     OPT_DEFS += -DAPI_SYSEX_ENABLE | ||||
|     SRC += $(QUANTUM_DIR)/api/api_sysex.c | ||||
| @@ -117,7 +124,7 @@ endif | ||||
| ifeq ($(strip $(RGB_MATRIX_ENABLE)), yes) | ||||
|     OPT_DEFS += -DRGB_MATRIX_ENABLE | ||||
|     SRC += is31fl3731.c | ||||
|     SRC += i2c_master.c | ||||
|     I2C_ENABLE = yes | ||||
|     SRC += $(QUANTUM_DIR)/color.c | ||||
|     SRC += $(QUANTUM_DIR)/rgb_matrix.c | ||||
|     CIE1931_CURVE = yes | ||||
| @@ -197,6 +204,25 @@ ifeq ($(strip $(USB_HID_ENABLE)), yes) | ||||
|     include $(TMK_DIR)/protocol/usb_hid.mk | ||||
| endif | ||||
|  | ||||
| ifeq ($(strip $(I2C_SLAVE_ENABLE)), yes) | ||||
|     I2C_ENABLE = yes | ||||
|     OPT_DEFS += -DI2C_SLAVE_ENABLE | ||||
| endif | ||||
|  | ||||
| ifeq ($(strip $(ENCODER_ENABLE)), yes) | ||||
|     OPT_DEFS += -DENCODER_ENABLE | ||||
|     SRC += $(QUANTUM_DIR)/encoder.c | ||||
| endif | ||||
|  | ||||
| ifeq ($(strip $(QWIIC_KEYBOARD_ENABLE)), yes) | ||||
|     SRC += qwiic/qwiic_keyboard.c | ||||
|     OPT_DEFS += -DQWIIC_KEYBOARD_ENABLE | ||||
| endif | ||||
|  | ||||
| ifeq ($(strip $(I2C_ENABLE)), yes) | ||||
|     SRC += twi2c.c | ||||
| endif | ||||
|  | ||||
| QUANTUM_SRC:= \ | ||||
|     $(QUANTUM_DIR)/quantum.c \ | ||||
|     $(QUANTUM_DIR)/keymap_common.c \ | ||||
|   | ||||
| @@ -34,6 +34,7 @@ | ||||
|   * [Bootmagic](feature_bootmagic.md) | ||||
|   * [Command](feature_command.md) | ||||
|   * [Dynamic Macros](feature_dynamic_macros.md) | ||||
|   * [Encoders](feature_encoders.md) | ||||
|   * [Grave Escape](feature_grave_esc.md) | ||||
|   * [Key Lock](feature_key_lock.md) | ||||
|   * [Layouts](feature_layouts.md) | ||||
|   | ||||
							
								
								
									
										41
									
								
								docs/feature_encoders.md
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										41
									
								
								docs/feature_encoders.md
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,41 @@ | ||||
| # Encoders | ||||
|  | ||||
| Basic encoders are supported by adding this to your `rules.mk`: | ||||
|  | ||||
|     ENCODER_ENABLE = yes | ||||
|  | ||||
| and this to your `config.h`: | ||||
|  | ||||
|     #define NUMBER_OF_ENCODERS 1 | ||||
|     #define ENCODERS_PAD_A { B12 } | ||||
|     #define ENCODERS_PAD_B { B13 } | ||||
|  | ||||
| Each PAD_A/B variable defines an array so multiple encoders can be defined, e.g.: | ||||
|  | ||||
|     #define ENCODERS_PAD_A { encoder1a, encoder2a } | ||||
|     #define ENCODERS_PAD_B { encoder1a, encoder2b } | ||||
|  | ||||
| If your encoder's clockwise directions are incorrect, you can swap the A & B pad definitions. | ||||
|  | ||||
| Additionally, the resolution can be specified in the same file (the default & suggested is 4): | ||||
|  | ||||
|     #define ENCODER_RESOLUTION 4 | ||||
|  | ||||
| ## Callbacks | ||||
|  | ||||
| The callback functions can be inserted into your `<keyboard>.c`: | ||||
|  | ||||
|     void encoder_update_kb(uint8_t index, bool clockwise) { | ||||
|         encoder_update_user(index, clockwise); | ||||
|     } | ||||
|  | ||||
| or `keymap.c`: | ||||
|  | ||||
|     void encoder_update_user(uint8_t index, bool clockwise) { | ||||
|          | ||||
|     } | ||||
|  | ||||
|  | ||||
| ## Hardware | ||||
|  | ||||
| The A an B lines of the encoders should be wired directly to the MCU, and the C/common lines should be wired to ground. | ||||
							
								
								
									
										168
									
								
								drivers/arm/twi2c.c
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										168
									
								
								drivers/arm/twi2c.c
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,168 @@ | ||||
| /* Copyright 2018 Jack Humbert | ||||
|  * | ||||
|  * 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/>. | ||||
|  */ | ||||
|  | ||||
| #include "twi2c.h" | ||||
| #include <string.h> | ||||
| #include <hal.h> | ||||
| #include "chprintf.h" | ||||
| #include "memstreams.h" | ||||
| #include "printf.h" | ||||
| #include "hal_i2cslave.h" | ||||
|  | ||||
| /** | ||||
|  * I2C slave test routine. | ||||
|  * | ||||
|  * To use: Add file to a project, call startComms() with the address of a serial stream | ||||
|  * | ||||
|  * There are two different responses: | ||||
|  *  a) A read-only transaction - returns the "Initial Reply" message | ||||
|  *  b) A write then read transaction - calls a message processor and returns the generated reply. | ||||
|  *          Stretches clock until reply available. | ||||
|  */ | ||||
| // static const I2CConfig masterI2CConfig = { | ||||
| //   400000 | ||||
| // }; | ||||
|  | ||||
| I2CSlaveMsgCB twi2c_incoming_message_process, twi2c_catch_error, twi2c_clear_after_send; | ||||
| twi2c_message_received twi2c_message_received_callback; | ||||
|  | ||||
| static uint8_t twi2c_address; | ||||
|  | ||||
| static const I2CConfig i2cconfig = { | ||||
|   STM32_TIMINGR_PRESC(15U) | | ||||
|   STM32_TIMINGR_SCLDEL(4U) | STM32_TIMINGR_SDADEL(2U) | | ||||
|   STM32_TIMINGR_SCLH(15U)  | STM32_TIMINGR_SCLL(21U), | ||||
|   0, | ||||
|   0 | ||||
| }; | ||||
|  | ||||
| /** | ||||
|  * Track I2C errors | ||||
|  */ | ||||
| uint8_t gotI2cError = 0; | ||||
| uint32_t lastI2cErrorFlags = 0; | ||||
|  | ||||
| // Called from ISR to log error | ||||
| void noteI2cError(uint32_t flags) | ||||
| { | ||||
|   lastI2cErrorFlags = flags; | ||||
|   gotI2cError = 1; | ||||
| } | ||||
|  | ||||
| /** | ||||
|  * Generic error handler | ||||
|  * | ||||
|  * Called in interrupt context, so need to watch what we do | ||||
|  */ | ||||
| void twi2c_catch_error(I2CDriver *i2cp) | ||||
| { | ||||
|   noteI2cError(i2cp->errors); | ||||
| } | ||||
|  | ||||
| /** | ||||
|  * Callback after sending of response complete - restores default reply in case polled | ||||
|  */ | ||||
| void twi2c_clear_after_send(I2CDriver *i2cp) | ||||
| { | ||||
|   // echoReply.size = 0;               // Clear receive message | ||||
|   // i2cSlaveReplyI(i2cp, &initialReply); | ||||
| } | ||||
|  | ||||
| uint8_t twi2c_start(void) { | ||||
|   i2cStart(&I2C_DRIVER, &i2cconfig); | ||||
|   return 0; | ||||
| } | ||||
|  | ||||
| void twi2c_init(void) { | ||||
|   palSetGroupMode(GPIOB,6,7, PAL_MODE_INPUT);       // Try releasing special pins for a short time | ||||
|   chThdSleepMilliseconds(10); | ||||
|  | ||||
|   palSetPadMode(GPIOB, 6, PAL_MODE_ALTERNATE(4) | PAL_STM32_OTYPE_OPENDRAIN | PAL_STM32_PUPDR_PULLUP); | ||||
|   palSetPadMode(GPIOB, 7, PAL_MODE_ALTERNATE(4) | PAL_STM32_OTYPE_OPENDRAIN | PAL_STM32_PUPDR_PULLUP); | ||||
|  | ||||
|   // try high drive (from kiibohd) | ||||
|   // I2C_DRIVER.i2c->C2 |= I2Cx_C2_HDRS; | ||||
|   // try glitch fixing (from kiibohd) | ||||
|   // I2C_DRIVER.i2c->FLT = 4; | ||||
| } | ||||
|  | ||||
| uint8_t twi2c_write(uint8_t data) { | ||||
|   return i2cMasterTransmitTimeout(&I2C_DRIVER, twi2c_address/2, &data, 1, 0, 0, MS2ST(100)); | ||||
| } | ||||
|  | ||||
| uint8_t twi2c_transmit(uint8_t address, uint8_t * data, uint16_t length) { | ||||
|   return i2cMasterTransmitTimeout(&I2C_DRIVER, address/2, data, length, 0, 0, MS2ST(100)); | ||||
| } | ||||
|  | ||||
| uint8_t twi2c_receive(uint8_t address, uint8_t * data, uint16_t length) { | ||||
|   return i2cMasterReceiveTimeout(&I2C_DRIVER, address/2, data, length, MS2ST(100)); | ||||
| } | ||||
|  | ||||
|  | ||||
| uint8_t twi2c_incoming_body[50]; | ||||
| uint8_t twi2c_outgoing_body[1024]; | ||||
|  | ||||
| // Response to received messages | ||||
| I2CSlaveMsg twi2c_incoming_message = { | ||||
|   sizeof(twi2c_incoming_body), | ||||
|   twi2c_incoming_body, | ||||
|   NULL, | ||||
|   twi2c_incoming_message_process, | ||||
|   twi2c_catch_error                   /* Error hook */ | ||||
| }; | ||||
|  | ||||
| void twi2c_incoming_message_process(I2CDriver * i2cp) { | ||||
|   size_t len = i2cSlaveBytes(i2cp); | ||||
|   (*twi2c_message_received_callback)(i2cp, twi2c_incoming_body, len); | ||||
| } | ||||
|  | ||||
| // Response to received messages | ||||
| I2CSlaveMsg twi2c_outgoing_message = { | ||||
|   sizeof(twi2c_outgoing_body), | ||||
|   twi2c_outgoing_body, | ||||
|   NULL, | ||||
|   twi2c_clear_after_send, | ||||
|   twi2c_catch_error | ||||
| }; | ||||
|  | ||||
| uint8_t twi2c_reply(I2CDriver * i2cp, uint8_t * data, uint16_t length) { | ||||
|   memcpy(twi2c_outgoing_body, data, length); | ||||
|   twi2c_outgoing_message.size = length; | ||||
|   i2cSlaveReplyI(i2cp, &twi2c_outgoing_message); | ||||
|   return 0; | ||||
| } | ||||
|  | ||||
| uint8_t twi2c_transmit_receive(uint8_t address, uint8_t * tx_body, uint16_t tx_length, uint8_t * rx_body, uint16_t rx_length) { | ||||
|   return i2cMasterTransmitTimeout(&I2C_DRIVER, address/2, tx_body, tx_length, rx_body, rx_length, MS2ST(100)); | ||||
| } | ||||
|  | ||||
| uint8_t twi2c_start_listening(uint8_t address, twi2c_message_received callback) { | ||||
|   twi2c_message_received_callback = callback; | ||||
|   I2C_DRIVER.slaveTimeout = MS2ST(100); | ||||
|   i2cSlaveConfigure(&I2C_DRIVER, &twi2c_incoming_message, &twi2c_outgoing_message); | ||||
|   i2cMatchAddress(&I2C_DRIVER, address/2); | ||||
|   return 0; | ||||
| } | ||||
|  | ||||
| uint8_t twi2c_restart_listening(uint8_t address) { | ||||
|   i2cMatchAddress(&I2C_DRIVER, address/2); | ||||
|   return 0; | ||||
| } | ||||
|  | ||||
| void twi2c_stop(void) { | ||||
|   i2cUnmatchAll(&I2C_DRIVER); | ||||
|   i2cStop(&I2C_DRIVER); | ||||
| } | ||||
							
								
								
									
										48
									
								
								drivers/arm/twi2c.h
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										48
									
								
								drivers/arm/twi2c.h
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,48 @@ | ||||
| /* Copyright 2018 Jack Humbert | ||||
|  * | ||||
|  * 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/>. | ||||
|  */ | ||||
|  | ||||
| #ifndef TWI2C_H | ||||
| #define TWI2C_H | ||||
|  | ||||
| #include "ch.h" | ||||
| #include "hal.h" | ||||
|  | ||||
| #ifndef I2C_DRIVER | ||||
|   #define I2C_DRIVER I2CD1 | ||||
| #endif | ||||
|  | ||||
| #define slaveI2Caddress  0x30       /* Address in our terms - halved by later code */ | ||||
| //#define myOtherI2Caddress 0x19 | ||||
| I2CSlaveMsgCB twi2c_incoming_message_process, twi2c_catch_error, twi2c_clear_after_send; | ||||
| typedef void (*twi2c_message_received)(I2CDriver *, uint8_t *, uint16_t); | ||||
|  | ||||
| void twi2c_init(void); | ||||
| uint8_t twi2c_start(void); | ||||
| uint8_t twi2c_write(uint8_t data); | ||||
| uint8_t twi2c_read_ack(void); | ||||
| uint8_t twi2c_read_nack(void); | ||||
| uint8_t twi2c_transmit(uint8_t address, uint8_t* data, uint16_t length); | ||||
| uint8_t twi2c_receive(uint8_t address, uint8_t* data, uint16_t length); | ||||
| uint8_t twi2c_writeReg(uint8_t devaddr, uint8_t regaddr, uint8_t* data, uint16_t length); | ||||
| uint8_t twi2c_readReg(uint8_t devaddr, uint8_t regaddr, uint8_t* data, uint16_t length); | ||||
| void twi2c_stop(void); | ||||
|  | ||||
| uint8_t twi2c_reply(I2CDriver * i2cp, uint8_t * data, uint16_t length); | ||||
| uint8_t twi2c_transmit_receive(uint8_t address, uint8_t * tx_body, uint16_t tx_length, uint8_t * rx_body, uint16_t rx_length); | ||||
| uint8_t twi2c_start_listening(uint8_t address, twi2c_message_received callback); | ||||
| uint8_t twi2c_restart_listening(uint8_t address); | ||||
|  | ||||
| #endif | ||||
							
								
								
									
										159
									
								
								drivers/arm/ws2812.c
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										159
									
								
								drivers/arm/ws2812.c
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,159 @@ | ||||
| /* | ||||
|  * LEDDriver.c | ||||
|  * | ||||
|  *  Created on: Aug 26, 2013 | ||||
|  *      Author: Omri Iluz | ||||
|  */ | ||||
|  | ||||
| #include "ws2812.h" | ||||
| #include "stdlib.h" | ||||
|  | ||||
| static uint8_t *fb; | ||||
| static int sLeds; | ||||
| static stm32_gpio_t *sPort; | ||||
| static uint32_t sMask; | ||||
| uint8_t* dma_source; | ||||
|  | ||||
| void setColor(uint8_t color, uint8_t *buf,uint32_t mask){ | ||||
|   int i; | ||||
|   for (i=0;i<8;i++){ | ||||
|     buf[i]=((color<<i)&0b10000000?0x0:mask); | ||||
|   } | ||||
| } | ||||
|  | ||||
| void setColorRGB(Color c, uint8_t *buf, uint32_t mask){ | ||||
|   setColor(c.G,buf, mask); | ||||
|   setColor(c.R,buf+8, mask); | ||||
|   setColor(c.B,buf+16, mask); | ||||
| } | ||||
|  | ||||
| /** | ||||
|  * @brief   Initialize Led Driver | ||||
|  * @details Initialize the Led Driver based on parameters. | ||||
|  *          Following initialization, the frame buffer would automatically be | ||||
|  *          exported to the supplied port and pins in the right timing to drive | ||||
|  *          a chain of WS2812B controllers | ||||
|  * @note    The function assumes the controller is running at 72Mhz | ||||
|  * @note    Timing is critical for WS2812. While all timing is done in hardware | ||||
|  *          need to verify memory bandwidth is not exhausted to avoid DMA delays | ||||
|  * | ||||
|  * @param[in] leds      length of the LED chain controlled by each pin | ||||
|  * @param[in] port      which port would be used for output | ||||
|  * @param[in] mask      Which pins would be used for output, each pin is a full chain | ||||
|  * @param[out] o_fb     initialized frame buffer | ||||
|  * | ||||
|  */ | ||||
| void ledDriverInit(int leds, stm32_gpio_t *port, uint32_t mask, uint8_t **o_fb) { | ||||
|   sLeds=leds; | ||||
|   sPort=port; | ||||
|   sMask=mask; | ||||
|   palSetGroupMode(port, sMask, 0, PAL_MODE_OUTPUT_PUSHPULL|PAL_STM32_OSPEED_HIGHEST|PAL_STM32_PUPDR_FLOATING); | ||||
|  | ||||
|   // configure pwm timers - | ||||
|   // timer 2 as master, active for data transmission and inactive to disable transmission during reset period (50uS) | ||||
|   // timer 3 as slave, during active time creates a 1.25 uS signal, with duty cycle controlled by frame buffer values | ||||
|   static PWMConfig pwmc2 = {72000000 / 90, /* 800Khz PWM clock frequency. 1/90 of PWMC3   */ | ||||
|                             (72000000 / 90) * 0.05, /*Total period is 50ms (20FPS), including sLeds cycles + reset length for ws2812b and FB writes  */ | ||||
|                             NULL, | ||||
|                             { {PWM_OUTPUT_ACTIVE_HIGH, NULL}, | ||||
|                               {PWM_OUTPUT_DISABLED, NULL}, | ||||
|                               {PWM_OUTPUT_DISABLED, NULL}, | ||||
|                               {PWM_OUTPUT_DISABLED, NULL}}, | ||||
|                               TIM_CR2_MMS_2, /* master mode selection */ | ||||
|                               0, }; | ||||
|   /* master mode selection */ | ||||
|   static PWMConfig pwmc3 = {72000000,/* 72Mhz PWM clock frequency.   */ | ||||
|                             90, /* 90 cycles period (1.25 uS per period @72Mhz       */ | ||||
|                             NULL, | ||||
|                             { {PWM_OUTPUT_ACTIVE_HIGH, NULL}, | ||||
|                               {PWM_OUTPUT_ACTIVE_HIGH, NULL}, | ||||
|                               {PWM_OUTPUT_ACTIVE_HIGH, NULL}, | ||||
|                               {PWM_OUTPUT_ACTIVE_HIGH, NULL}}, | ||||
|                               0, | ||||
|                               0, | ||||
|   }; | ||||
|   dma_source = chHeapAlloc(NULL, 1); | ||||
|   fb = chHeapAlloc(NULL, ((sLeds) * 24)+10); | ||||
|   *o_fb=fb; | ||||
|   int j; | ||||
|   for (j = 0; j < (sLeds) * 24; j++) fb[j] = 0; | ||||
|   dma_source[0] = sMask; | ||||
|   // DMA stream 2, triggered by channel3 pwm signal. if FB indicates, reset output value early to indicate "0" bit to ws2812 | ||||
|   dmaStreamAllocate(STM32_DMA1_STREAM2, 10, NULL, NULL); | ||||
|   dmaStreamSetPeripheral(STM32_DMA1_STREAM2, &(sPort->BSRR.H.clear)); | ||||
|   dmaStreamSetMemory0(STM32_DMA1_STREAM2, fb); | ||||
|   dmaStreamSetTransactionSize(STM32_DMA1_STREAM2, (sLeds) * 24); | ||||
|   dmaStreamSetMode( | ||||
|       STM32_DMA1_STREAM2, | ||||
|       STM32_DMA_CR_DIR_M2P | STM32_DMA_CR_MINC | STM32_DMA_CR_PSIZE_BYTE | ||||
|       | STM32_DMA_CR_MSIZE_BYTE | STM32_DMA_CR_CIRC | STM32_DMA_CR_PL(2)); | ||||
|   // DMA stream 3, triggered by pwm update event. output high at beginning of signal | ||||
|   dmaStreamAllocate(STM32_DMA1_STREAM3, 10, NULL, NULL); | ||||
|   dmaStreamSetPeripheral(STM32_DMA1_STREAM3, &(sPort->BSRR.H.set)); | ||||
|   dmaStreamSetMemory0(STM32_DMA1_STREAM3, dma_source); | ||||
|   dmaStreamSetTransactionSize(STM32_DMA1_STREAM3, 1); | ||||
|   dmaStreamSetMode( | ||||
|       STM32_DMA1_STREAM3, STM32_DMA_CR_TEIE | | ||||
|       STM32_DMA_CR_DIR_M2P | STM32_DMA_CR_PSIZE_BYTE | STM32_DMA_CR_MSIZE_BYTE | ||||
|       | STM32_DMA_CR_CIRC | STM32_DMA_CR_PL(3)); | ||||
|   // DMA stream 6, triggered by channel1 update event. reset output value late to indicate "1" bit to ws2812. | ||||
|   // always triggers but no affect if dma stream 2 already change output value to 0 | ||||
|   dmaStreamAllocate(STM32_DMA1_STREAM6, 10, NULL, NULL); | ||||
|   dmaStreamSetPeripheral(STM32_DMA1_STREAM6, &(sPort->BSRR.H.clear)); | ||||
|   dmaStreamSetMemory0(STM32_DMA1_STREAM6, dma_source); | ||||
|   dmaStreamSetTransactionSize(STM32_DMA1_STREAM6, 1); | ||||
|   dmaStreamSetMode( | ||||
|       STM32_DMA1_STREAM6, | ||||
|       STM32_DMA_CR_DIR_M2P | STM32_DMA_CR_PSIZE_BYTE | STM32_DMA_CR_MSIZE_BYTE | ||||
|       | STM32_DMA_CR_CIRC | STM32_DMA_CR_PL(3)); | ||||
|   pwmStart(&PWMD2, &pwmc2); | ||||
|   pwmStart(&PWMD3, &pwmc3); | ||||
|   // set pwm3 as slave, triggerd by pwm2 oc1 event. disables pwmd2 for synchronization. | ||||
|   PWMD3.tim->SMCR |= TIM_SMCR_SMS_0 | TIM_SMCR_SMS_2 | TIM_SMCR_TS_0; | ||||
|   PWMD2.tim->CR1 &= ~TIM_CR1_CEN; | ||||
|   // set pwm values. | ||||
|   // 28 (duty in ticks) / 90 (period in ticks) * 1.25uS (period in S) = 0.39 uS | ||||
|   pwmEnableChannel(&PWMD3, 2, 28); | ||||
|   // 58 (duty in ticks) / 90 (period in ticks) * 1.25uS (period in S) = 0.806 uS | ||||
|   pwmEnableChannel(&PWMD3, 0, 58); | ||||
|   // active during transfer of 90 cycles * sLeds * 24 bytes * 1/90 multiplier | ||||
|   pwmEnableChannel(&PWMD2, 0, 90 * sLeds * 24 / 90); | ||||
|   // stop and reset counters for synchronization | ||||
|   PWMD2.tim->CNT = 0; | ||||
|   // Slave (TIM3) needs to "update" immediately after master (TIM2) start in order to start in sync. | ||||
|   // this initial sync is crucial for the stability of the run | ||||
|   PWMD3.tim->CNT = 89; | ||||
|   PWMD3.tim->DIER |= TIM_DIER_CC3DE | TIM_DIER_CC1DE | TIM_DIER_UDE; | ||||
|   dmaStreamEnable(STM32_DMA1_STREAM3); | ||||
|   dmaStreamEnable(STM32_DMA1_STREAM6); | ||||
|   dmaStreamEnable(STM32_DMA1_STREAM2); | ||||
|   // all systems go! both timers and all channels are configured to resonate | ||||
|   // in complete sync without any need for CPU cycles (only DMA and timers) | ||||
|   // start pwm2 for system to start resonating | ||||
|   PWMD2.tim->CR1 |= TIM_CR1_CEN; | ||||
| } | ||||
|  | ||||
| void ledDriverWaitCycle(void){ | ||||
|   while (PWMD2.tim->CNT < 90 * sLeds * 24 / 90){chThdSleepMicroseconds(1);}; | ||||
| } | ||||
|  | ||||
| void testPatternFB(uint8_t *fb){ | ||||
|   int i; | ||||
|   Color tmpC = {rand()%256, rand()%256, rand()%256}; | ||||
|   for (i=0;i<sLeds;i++){ | ||||
|     setColorRGB(tmpC,fb+24*i, sMask); | ||||
|   } | ||||
| } | ||||
|  | ||||
| void ws2812_setleds(LED_TYPE *ledarray, uint16_t number_of_leds) { | ||||
| //   uint8_t i = 0; | ||||
| //   while (i < number_of_leds) { | ||||
| //     ws2812_write_led(i, ledarray[i].r, ledarray[i].g, ledarray[i].b); | ||||
| //     i++; | ||||
| //   } | ||||
| } | ||||
|  | ||||
|  | ||||
| void ws2812_setleds_rgbw(LED_TYPE *ledarray, uint16_t number_of_leds) { | ||||
|  | ||||
| } | ||||
							
								
								
									
										31
									
								
								drivers/arm/ws2812.h
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										31
									
								
								drivers/arm/ws2812.h
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,31 @@ | ||||
| /* | ||||
|  * LEDDriver.h | ||||
|  * | ||||
|  *  Created on: Aug 26, 2013 | ||||
|  *      Author: Omri Iluz | ||||
|  */ | ||||
|  | ||||
| #ifndef WS2812_H_ | ||||
| #define WS2812_H_ | ||||
|  | ||||
| #include "hal.h" | ||||
| #include "rgblight_types.h" | ||||
|  | ||||
| #define sign(x) (( x > 0 ) - ( x < 0 )) | ||||
|  | ||||
| typedef struct Color Color; | ||||
| struct Color { | ||||
|   uint8_t R; | ||||
|   uint8_t G; | ||||
|   uint8_t B; | ||||
| }; | ||||
|  | ||||
| void ledDriverInit(int leds, stm32_gpio_t *port, uint32_t mask, uint8_t **o_fb); | ||||
| void setColorRGB(Color c, uint8_t *buf, uint32_t mask); | ||||
| void testPatternFB(uint8_t *fb); | ||||
| void ledDriverWaitCycle(void); | ||||
|  | ||||
| void ws2812_setleds(LED_TYPE *ledarray, uint16_t number_of_leds); | ||||
| void ws2812_setleds_rgbw(LED_TYPE *ledarray, uint16_t number_of_leds); | ||||
|  | ||||
| #endif /* LEDDRIVER_H_ */ | ||||
| @@ -1,22 +0,0 @@ | ||||
| /* Library made by: g4lvanix | ||||
|  * Github repository: https://github.com/g4lvanix/I2C-master-lib | ||||
|  */ | ||||
|  | ||||
| #ifndef I2C_MASTER_H | ||||
| #define I2C_MASTER_H | ||||
|  | ||||
| #define I2C_READ 0x01 | ||||
| #define I2C_WRITE 0x00 | ||||
|  | ||||
| void i2c_init(void); | ||||
| uint8_t i2c_start(uint8_t address); | ||||
| uint8_t i2c_write(uint8_t data); | ||||
| uint8_t i2c_read_ack(void); | ||||
| uint8_t i2c_read_nack(void); | ||||
| uint8_t i2c_transmit(uint8_t address, uint8_t* data, uint16_t length); | ||||
| uint8_t i2c_receive(uint8_t address, uint8_t* data, uint16_t length); | ||||
| uint8_t i2c_writeReg(uint8_t devaddr, uint8_t regaddr, uint8_t* data, uint16_t length); | ||||
| uint8_t i2c_readReg(uint8_t devaddr, uint8_t regaddr, uint8_t* data, uint16_t length); | ||||
| void i2c_stop(void); | ||||
|  | ||||
| #endif // I2C_MASTER_H | ||||
| @@ -1,244 +0,0 @@ | ||||
| /* Copyright 2017 Jason Williams | ||||
|  * Copyright 2018 Jack Humbert | ||||
|  * | ||||
|  * 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/>. | ||||
|  */ | ||||
|  | ||||
| #include "is31fl3731.h" | ||||
| #include <avr/interrupt.h> | ||||
| #include <avr/io.h> | ||||
| #include <util/delay.h> | ||||
| #include <string.h> | ||||
| #include "i2c_master.h" | ||||
| #include "progmem.h" | ||||
|  | ||||
| // This is a 7-bit address, that gets left-shifted and bit 0 | ||||
| // set to 0 for write, 1 for read (as per I2C protocol) | ||||
| // The address will vary depending on your wiring: | ||||
| // 0b1110100 AD <-> GND | ||||
| // 0b1110111 AD <-> VCC | ||||
| // 0b1110101 AD <-> SCL | ||||
| // 0b1110110 AD <-> SDA | ||||
| #define ISSI_ADDR_DEFAULT 0x74 | ||||
|  | ||||
| #define ISSI_REG_CONFIG  0x00 | ||||
| #define ISSI_REG_CONFIG_PICTUREMODE 0x00 | ||||
| #define ISSI_REG_CONFIG_AUTOPLAYMODE 0x08 | ||||
| #define ISSI_REG_CONFIG_AUDIOPLAYMODE 0x18 | ||||
|  | ||||
| #define ISSI_CONF_PICTUREMODE 0x00 | ||||
| #define ISSI_CONF_AUTOFRAMEMODE 0x04 | ||||
| #define ISSI_CONF_AUDIOMODE 0x08 | ||||
|  | ||||
| #define ISSI_REG_PICTUREFRAME  0x01 | ||||
|  | ||||
| #define ISSI_REG_SHUTDOWN 0x0A | ||||
| #define ISSI_REG_AUDIOSYNC 0x06 | ||||
|  | ||||
| #define ISSI_COMMANDREGISTER 0xFD | ||||
| #define ISSI_BANK_FUNCTIONREG 0x0B    // helpfully called 'page nine' | ||||
|  | ||||
| // Transfer buffer for TWITransmitData() | ||||
| uint8_t g_twi_transfer_buffer[20]; | ||||
|  | ||||
| // These buffers match the IS31FL3731 PWM registers 0x24-0xB3. | ||||
| // Storing them like this is optimal for I2C transfers to the registers. | ||||
| // We could optimize this and take out the unused registers from these | ||||
| // buffers and the transfers in IS31FL3731_write_pwm_buffer() but it's | ||||
| // probably not worth the extra complexity. | ||||
| uint8_t g_pwm_buffer[DRIVER_COUNT][144]; | ||||
| bool g_pwm_buffer_update_required = false; | ||||
|  | ||||
| uint8_t g_led_control_registers[DRIVER_COUNT][18] = { { 0 }, { 0 } }; | ||||
| bool g_led_control_registers_update_required = false; | ||||
|  | ||||
| // This is the bit pattern in the LED control registers | ||||
| // (for matrix A, add one to register for matrix B) | ||||
| // | ||||
| //  reg -  b7  b6  b5  b4  b3  b2  b1  b0 | ||||
| // 0x00 - R08,R07,R06,R05,R04,R03,R02,R01 | ||||
| // 0x02 - G08,G07,G06,G05,G04,G03,G02,R00 | ||||
| // 0x04 - B08,B07,B06,B05,B04,B03,G01,G00 | ||||
| // 0x06 -  - , - , - , - , - ,B02,B01,B00 | ||||
| // 0x08 -  - , - , - , - , - , - , - , - | ||||
| // 0x0A - B17,B16,B15, - , - , - , - , - | ||||
| // 0x0C - G17,G16,B14,B13,B12,B11,B10,B09 | ||||
| // 0x0E - R17,G15,G14,G13,G12,G11,G10,G09 | ||||
| // 0x10 - R16,R15,R14,R13,R12,R11,R10,R09 | ||||
|  | ||||
|  | ||||
| void IS31FL3731_write_register( uint8_t addr, uint8_t reg, uint8_t data ) | ||||
| { | ||||
| 	g_twi_transfer_buffer[0] = reg; | ||||
| 	g_twi_transfer_buffer[1] = data; | ||||
|  | ||||
| 	//Transmit data until succesful | ||||
| 	while(i2c_transmit(addr << 1, g_twi_transfer_buffer,2) != 0);  | ||||
| } | ||||
|  | ||||
| void IS31FL3731_write_pwm_buffer( uint8_t addr, uint8_t *pwm_buffer ) | ||||
| { | ||||
| 	// assumes bank is already selected | ||||
|  | ||||
| 	// transmit PWM registers in 9 transfers of 16 bytes | ||||
| 	// g_twi_transfer_buffer[] is 20 bytes | ||||
|  | ||||
| 	// iterate over the pwm_buffer contents at 16 byte intervals | ||||
| 	for ( int i = 0; i < 144; i += 16 ) | ||||
| 	{ | ||||
| 		// set the first register, e.g. 0x24, 0x34, 0x44, etc. | ||||
| 		g_twi_transfer_buffer[0] = 0x24 + i; | ||||
| 		// copy the data from i to i+15 | ||||
| 		// device will auto-increment register for data after the first byte | ||||
| 		// thus this sets registers 0x24-0x33, 0x34-0x43, etc. in one transfer | ||||
| 		for ( int j = 0; j < 16; j++ ) | ||||
| 		{ | ||||
| 			g_twi_transfer_buffer[1 + j] = pwm_buffer[i + j]; | ||||
| 		} | ||||
|  | ||||
| 		//Transmit buffer until succesful | ||||
| 		while(i2c_transmit(addr << 1, g_twi_transfer_buffer,17) != 0); | ||||
| 	} | ||||
| } | ||||
|  | ||||
| void IS31FL3731_init( uint8_t addr ) | ||||
| { | ||||
| 	// In order to avoid the LEDs being driven with garbage data | ||||
| 	// in the LED driver's PWM registers, first enable software shutdown, | ||||
| 	// then set up the mode and other settings, clear the PWM registers, | ||||
| 	// then disable software shutdown. | ||||
|  | ||||
| 	// select "function register" bank | ||||
| 	IS31FL3731_write_register( addr, ISSI_COMMANDREGISTER, ISSI_BANK_FUNCTIONREG ); | ||||
|  | ||||
| 	// enable software shutdown | ||||
| 	IS31FL3731_write_register( addr, ISSI_REG_SHUTDOWN, 0x00 ); | ||||
| 	// this delay was copied from other drivers, might not be needed | ||||
| 	_delay_ms( 10 ); | ||||
|  | ||||
| 	// picture mode | ||||
| 	IS31FL3731_write_register( addr, ISSI_REG_CONFIG, ISSI_REG_CONFIG_PICTUREMODE ); | ||||
| 	// display frame 0 | ||||
| 	IS31FL3731_write_register( addr, ISSI_REG_PICTUREFRAME, 0x00 ); | ||||
| 	// audio sync off | ||||
| 	IS31FL3731_write_register( addr, ISSI_REG_AUDIOSYNC, 0x00 ); | ||||
|  | ||||
| 	// select bank 0 | ||||
| 	IS31FL3731_write_register( addr, ISSI_COMMANDREGISTER, 0 ); | ||||
|  | ||||
| 	// turn off all LEDs in the LED control register | ||||
| 	for ( int i = 0x00; i <= 0x11; i++ ) | ||||
| 	{ | ||||
| 		IS31FL3731_write_register( addr, i, 0x00 ); | ||||
| 	} | ||||
|  | ||||
| 	// turn off all LEDs in the blink control register (not really needed) | ||||
| 	for ( int i = 0x12; i <= 0x23; i++ ) | ||||
| 	{ | ||||
| 		IS31FL3731_write_register( addr, i, 0x00 ); | ||||
| 	} | ||||
|  | ||||
| 	// set PWM on all LEDs to 0 | ||||
| 	for ( int i = 0x24; i <= 0xB3; i++ ) | ||||
| 	{ | ||||
| 		IS31FL3731_write_register( addr, i, 0x00 ); | ||||
| 	} | ||||
|  | ||||
| 	// select "function register" bank | ||||
| 	IS31FL3731_write_register( addr, ISSI_COMMANDREGISTER, ISSI_BANK_FUNCTIONREG ); | ||||
|  | ||||
| 	// disable software shutdown | ||||
| 	IS31FL3731_write_register( addr, ISSI_REG_SHUTDOWN, 0x01 ); | ||||
|  | ||||
| 	// select bank 0 and leave it selected. | ||||
| 	// most usage after initialization is just writing PWM buffers in bank 0 | ||||
| 	// as there's not much point in double-buffering | ||||
| 	IS31FL3731_write_register( addr, ISSI_COMMANDREGISTER, 0 ); | ||||
| } | ||||
|  | ||||
| void IS31FL3731_set_color( int index, uint8_t red, uint8_t green, uint8_t blue ) | ||||
| { | ||||
| 	if ( index >= 0 && index < DRIVER_LED_TOTAL ) { | ||||
| 		is31_led led = g_is31_leds[index]; | ||||
|  | ||||
| 		// Subtract 0x24 to get the second index of g_pwm_buffer | ||||
| 		g_pwm_buffer[led.driver][led.r - 0x24] = red; | ||||
| 		g_pwm_buffer[led.driver][led.g - 0x24] = green; | ||||
| 		g_pwm_buffer[led.driver][led.b - 0x24] = blue; | ||||
| 		g_pwm_buffer_update_required = true; | ||||
| 	} | ||||
| } | ||||
|  | ||||
| void IS31FL3731_set_color_all( uint8_t red, uint8_t green, uint8_t blue ) | ||||
| { | ||||
| 	for ( int i = 0; i < DRIVER_LED_TOTAL; i++ ) | ||||
| 	{ | ||||
| 		IS31FL3731_set_color( i, red, green, blue ); | ||||
| 	} | ||||
| } | ||||
|  | ||||
| void IS31FL3731_set_led_control_register( uint8_t index, bool red, bool green, bool blue ) | ||||
| { | ||||
| 	is31_led led = g_is31_leds[index]; | ||||
|  | ||||
|   uint8_t control_register_r = (led.r - 0x24) / 8; | ||||
|   uint8_t control_register_g = (led.g - 0x24) / 8; | ||||
|   uint8_t control_register_b = (led.b - 0x24) / 8; | ||||
|   uint8_t bit_r = (led.r - 0x24) % 8; | ||||
|   uint8_t bit_g = (led.g - 0x24) % 8; | ||||
|   uint8_t bit_b = (led.b - 0x24) % 8; | ||||
|  | ||||
| 	if ( red ) { | ||||
| 		g_led_control_registers[led.driver][control_register_r] |= (1 << bit_r); | ||||
| 	} else { | ||||
| 		g_led_control_registers[led.driver][control_register_r] &= ~(1 << bit_r); | ||||
| 	} | ||||
| 	if ( green ) { | ||||
| 		g_led_control_registers[led.driver][control_register_g] |= (1 << bit_g); | ||||
| 	} else { | ||||
| 		g_led_control_registers[led.driver][control_register_g] &= ~(1 << bit_g); | ||||
| 	} | ||||
| 	if ( blue ) { | ||||
| 		g_led_control_registers[led.driver][control_register_b] |= (1 << bit_b); | ||||
| 	} else { | ||||
| 		g_led_control_registers[led.driver][control_register_b] &= ~(1 << bit_b); | ||||
| 	} | ||||
|  | ||||
| 	g_led_control_registers_update_required = true; | ||||
|  | ||||
|  | ||||
| } | ||||
|  | ||||
| void IS31FL3731_update_pwm_buffers( uint8_t addr1, uint8_t addr2 ) | ||||
| { | ||||
| 	if ( g_pwm_buffer_update_required ) | ||||
| 	{ | ||||
| 		IS31FL3731_write_pwm_buffer( addr1, g_pwm_buffer[0] ); | ||||
| 		IS31FL3731_write_pwm_buffer( addr2, g_pwm_buffer[1] ); | ||||
| 	} | ||||
| 	g_pwm_buffer_update_required = false; | ||||
| } | ||||
|  | ||||
| void IS31FL3731_update_led_control_registers( uint8_t addr1, uint8_t addr2 ) | ||||
| { | ||||
| 	if ( g_led_control_registers_update_required ) | ||||
| 	{ | ||||
| 		for ( int i=0; i<18; i++ ) | ||||
| 		{ | ||||
| 			IS31FL3731_write_register(addr1, i, g_led_control_registers[0][i] ); | ||||
| 			IS31FL3731_write_register(addr2, i, g_led_control_registers[1][i] ); | ||||
| 		} | ||||
| 	} | ||||
| } | ||||
|  | ||||
							
								
								
									
										56
									
								
								drivers/avr/i2c_master.c → drivers/avr/twi2c.c
									
									
									
									
									
										
										
										Executable file → Normal file
									
								
							
							
						
						
									
										56
									
								
								drivers/avr/i2c_master.c → drivers/avr/twi2c.c
									
									
									
									
									
										
										
										Executable file → Normal file
									
								
							| @@ -5,18 +5,18 @@ | ||||
| #include <avr/io.h> | ||||
| #include <util/twi.h> | ||||
| 
 | ||||
| #include "i2c_master.h" | ||||
| #include "twi2c.h" | ||||
| 
 | ||||
| #define F_SCL 400000UL // SCL frequency
 | ||||
| #define Prescaler 1 | ||||
| #define TWBR_val ((((F_CPU / F_SCL) / Prescaler) - 16 ) / 2) | ||||
| 
 | ||||
| void i2c_init(void) | ||||
| void twi2c_init(void) | ||||
| { | ||||
| 	TWBR = (uint8_t)TWBR_val; | ||||
| } | ||||
| 
 | ||||
| uint8_t i2c_start(uint8_t address) | ||||
| uint8_t twi2c_start(uint8_t address) | ||||
| { | ||||
| 	// reset TWI control register
 | ||||
| 	TWCR = 0; | ||||
| @@ -42,7 +42,7 @@ uint8_t i2c_start(uint8_t address) | ||||
| 	return 0; | ||||
| } | ||||
| 
 | ||||
| uint8_t i2c_write(uint8_t data) | ||||
| uint8_t twi2c_write(uint8_t data) | ||||
| { | ||||
| 	// load data into data register
 | ||||
| 	TWDR = data; | ||||
| @@ -56,7 +56,7 @@ uint8_t i2c_write(uint8_t data) | ||||
| 	return 0; | ||||
| } | ||||
| 
 | ||||
| uint8_t i2c_read_ack(void) | ||||
| uint8_t twi2c_read_ack(void) | ||||
| { | ||||
| 
 | ||||
| 	// start TWI module and acknowledge data after reception
 | ||||
| @@ -67,7 +67,7 @@ uint8_t i2c_read_ack(void) | ||||
| 	return TWDR; | ||||
| } | ||||
| 
 | ||||
| uint8_t i2c_read_nack(void) | ||||
| uint8_t twi2c_read_nack(void) | ||||
| { | ||||
| 
 | ||||
| 	// start receiving without acknowledging reception
 | ||||
| @@ -78,71 +78,71 @@ uint8_t i2c_read_nack(void) | ||||
| 	return TWDR; | ||||
| } | ||||
| 
 | ||||
| uint8_t i2c_transmit(uint8_t address, uint8_t* data, uint16_t length) | ||||
| uint8_t twi2c_transmit(uint8_t address, uint8_t* data, uint16_t length) | ||||
| { | ||||
| 	if (i2c_start(address | I2C_WRITE)) return 1; | ||||
| 	if (twi2c_start(address | I2C_WRITE)) return 1; | ||||
| 
 | ||||
| 	for (uint16_t i = 0; i < length; i++) | ||||
| 	{ | ||||
| 		if (i2c_write(data[i])) return 1; | ||||
| 		if (twi2c_write(data[i])) return 1; | ||||
| 	} | ||||
| 
 | ||||
| 	i2c_stop(); | ||||
| 	twi2c_stop(); | ||||
| 
 | ||||
| 	return 0; | ||||
| } | ||||
| 
 | ||||
| uint8_t i2c_receive(uint8_t address, uint8_t* data, uint16_t length) | ||||
| uint8_t twi2c_receive(uint8_t address, uint8_t* data, uint16_t length) | ||||
| { | ||||
| 	if (i2c_start(address | I2C_READ)) return 1; | ||||
| 	if (twi2c_start(address | I2C_READ)) return 1; | ||||
| 
 | ||||
| 	for (uint16_t i = 0; i < (length-1); i++) | ||||
| 	{ | ||||
| 		data[i] = i2c_read_ack(); | ||||
| 		data[i] = twi2c_read_ack(); | ||||
| 	} | ||||
| 	data[(length-1)] = i2c_read_nack(); | ||||
| 	data[(length-1)] = twi2c_read_nack(); | ||||
| 
 | ||||
| 	i2c_stop(); | ||||
| 	twi2c_stop(); | ||||
| 
 | ||||
| 	return 0; | ||||
| } | ||||
| 
 | ||||
| uint8_t i2c_writeReg(uint8_t devaddr, uint8_t regaddr, uint8_t* data, uint16_t length) | ||||
| uint8_t twi2c_writeReg(uint8_t devaddr, uint8_t regaddr, uint8_t* data, uint16_t length) | ||||
| { | ||||
| 	if (i2c_start(devaddr | 0x00)) return 1; | ||||
| 	if (twi2c_start(devaddr | 0x00)) return 1; | ||||
| 
 | ||||
| 	i2c_write(regaddr); | ||||
| 	twi2c_write(regaddr); | ||||
| 
 | ||||
| 	for (uint16_t i = 0; i < length; i++) | ||||
| 	{ | ||||
| 		if (i2c_write(data[i])) return 1; | ||||
| 		if (twi2c_write(data[i])) return 1; | ||||
| 	} | ||||
| 
 | ||||
| 	i2c_stop(); | ||||
| 	twi2c_stop(); | ||||
| 
 | ||||
| 	return 0; | ||||
| } | ||||
| 
 | ||||
| uint8_t i2c_readReg(uint8_t devaddr, uint8_t regaddr, uint8_t* data, uint16_t length) | ||||
| uint8_t twi2c_readReg(uint8_t devaddr, uint8_t regaddr, uint8_t* data, uint16_t length) | ||||
| { | ||||
| 	if (i2c_start(devaddr)) return 1; | ||||
| 	if (twi2c_start(devaddr)) return 1; | ||||
| 
 | ||||
| 	i2c_write(regaddr); | ||||
| 	twi2c_write(regaddr); | ||||
| 
 | ||||
| 	if (i2c_start(devaddr | 0x01)) return 1; | ||||
| 	if (twi2c_start(devaddr | 0x01)) return 1; | ||||
| 
 | ||||
| 	for (uint16_t i = 0; i < (length-1); i++) | ||||
| 	{ | ||||
| 		data[i] = i2c_read_ack(); | ||||
| 		data[i] = twi2c_read_ack(); | ||||
| 	} | ||||
| 	data[(length-1)] = i2c_read_nack(); | ||||
| 	data[(length-1)] = twi2c_read_nack(); | ||||
| 
 | ||||
| 	i2c_stop(); | ||||
| 	twi2c_stop(); | ||||
| 
 | ||||
| 	return 0; | ||||
| } | ||||
| 
 | ||||
| void i2c_stop(void) | ||||
| void twi2c_stop(void) | ||||
| { | ||||
| 	// transmit STOP condition
 | ||||
| 	TWCR = (1<<TWINT) | (1<<TWEN) | (1<<TWSTO); | ||||
							
								
								
									
										22
									
								
								drivers/avr/twi2c.h
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										22
									
								
								drivers/avr/twi2c.h
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,22 @@ | ||||
| /* Library made by: g4lvanix | ||||
|  * Github repository: https://github.com/g4lvanix/I2C-master-lib | ||||
|  */ | ||||
|  | ||||
| #ifndef TWI2C_H | ||||
| #define TWI2C_H | ||||
|  | ||||
| #define I2C_READ 0x01 | ||||
| #define I2C_WRITE 0x00 | ||||
|  | ||||
| void twi2c_init(void); | ||||
| uint8_t twi2c_start(uint8_t address); | ||||
| uint8_t twi2c_write(uint8_t data); | ||||
| uint8_t twi2c_read_ack(void); | ||||
| uint8_t twi2c_read_nack(void); | ||||
| uint8_t twi2c_transmit(uint8_t address, uint8_t* data, uint16_t length); | ||||
| uint8_t twi2c_receive(uint8_t address, uint8_t* data, uint16_t length); | ||||
| uint8_t twi2c_writeReg(uint8_t devaddr, uint8_t regaddr, uint8_t* data, uint16_t length); | ||||
| uint8_t twi2c_readReg(uint8_t devaddr, uint8_t regaddr, uint8_t* data, uint16_t length); | ||||
| void twi2c_stop(void); | ||||
|  | ||||
| #endif // I2C_MASTER_H | ||||
							
								
								
									
										244
									
								
								drivers/is31fl3731.c
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										244
									
								
								drivers/is31fl3731.c
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,244 @@ | ||||
| /* Copyright 2017 Jason Williams | ||||
|  * Copyright 2018 Jack Humbert | ||||
|  * | ||||
|  * 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/>. | ||||
|  */ | ||||
|  | ||||
| #include "is31fl3731.h" | ||||
| #include "wait.h" | ||||
| #include <string.h> | ||||
| #include "twi2c.h" | ||||
| #include "progmem.h" | ||||
|  | ||||
| // This is a 7-bit address, that gets left-shifted and bit 0 | ||||
| // set to 0 for write, 1 for read (as per I2C protocol) | ||||
| // The address will vary depending on your wiring: | ||||
| // 0b1110100 AD <-> GND | ||||
| // 0b1110111 AD <-> VCC | ||||
| // 0b1110101 AD <-> SCL | ||||
| // 0b1110110 AD <-> SDA | ||||
| #define ISSI_ADDR_DEFAULT 0x74 | ||||
|  | ||||
| #define ISSI_REG_CONFIG  0x00 | ||||
| #define ISSI_REG_CONFIG_PICTUREMODE 0x00 | ||||
| #define ISSI_REG_CONFIG_AUTOPLAYMODE 0x08 | ||||
| #define ISSI_REG_CONFIG_AUDIOPLAYMODE 0x18 | ||||
|  | ||||
| #define ISSI_CONF_PICTUREMODE 0x00 | ||||
| #define ISSI_CONF_AUTOFRAMEMODE 0x04 | ||||
| #define ISSI_CONF_AUDIOMODE 0x08 | ||||
|  | ||||
| #define ISSI_REG_PICTUREFRAME  0x01 | ||||
|  | ||||
| #define ISSI_REG_SHUTDOWN 0x0A | ||||
| #define ISSI_REG_AUDIOSYNC 0x06 | ||||
|  | ||||
| #define ISSI_COMMANDREGISTER 0xFD | ||||
| #define ISSI_BANK_FUNCTIONREG 0x0B    // helpfully called 'page nine' | ||||
|  | ||||
| // Transfer buffer for TWITransmitData() | ||||
| uint8_t g_twi_transfer_buffer[20]; | ||||
|  | ||||
| // These buffers match the IS31FL3731 PWM registers 0x24-0xB3. | ||||
| // Storing them like this is optimal for I2C transfers to the registers. | ||||
| // We could optimize this and take out the unused registers from these | ||||
| // buffers and the transfers in IS31FL3731_write_pwm_buffer() but it's | ||||
| // probably not worth the extra complexity. | ||||
| uint8_t g_pwm_buffer[DRIVER_COUNT][144]; | ||||
| bool g_pwm_buffer_update_required = false; | ||||
|  | ||||
| uint8_t g_led_control_registers[DRIVER_COUNT][18] = { { 0 }, { 0 } }; | ||||
| bool g_led_control_registers_update_required = false; | ||||
|  | ||||
| // This is the bit pattern in the LED control registers | ||||
| // (for matrix A, add one to register for matrix B) | ||||
| // | ||||
| //  reg -  b7  b6  b5  b4  b3  b2  b1  b0 | ||||
| // 0x00 - R08,R07,R06,R05,R04,R03,R02,R01 | ||||
| // 0x02 - G08,G07,G06,G05,G04,G03,G02,R00 | ||||
| // 0x04 - B08,B07,B06,B05,B04,B03,G01,G00 | ||||
| // 0x06 -  - , - , - , - , - ,B02,B01,B00 | ||||
| // 0x08 -  - , - , - , - , - , - , - , - | ||||
| // 0x0A - B17,B16,B15, - , - , - , - , - | ||||
| // 0x0C - G17,G16,B14,B13,B12,B11,B10,B09 | ||||
| // 0x0E - R17,G15,G14,G13,G12,G11,G10,G09 | ||||
| // 0x10 - R16,R15,R14,R13,R12,R11,R10,R09 | ||||
|  | ||||
|  | ||||
| void IS31FL3731_write_register( uint8_t addr, uint8_t reg, uint8_t data ) | ||||
| { | ||||
|   g_twi_transfer_buffer[0] = reg; | ||||
|   g_twi_transfer_buffer[1] = data; | ||||
|  | ||||
|   //Transmit data until succesful | ||||
|   //while(twi2c_transmit(addr << 1, g_twi_transfer_buffer,2) != 0); | ||||
|   twi2c_transmit(addr << 1, g_twi_transfer_buffer,2); | ||||
| } | ||||
|  | ||||
| void IS31FL3731_write_pwm_buffer( uint8_t addr, uint8_t *pwm_buffer ) | ||||
| { | ||||
|   // assumes bank is already selected | ||||
|  | ||||
|   // transmit PWM registers in 9 transfers of 16 bytes | ||||
|   // g_twi_transfer_buffer[] is 20 bytes | ||||
|  | ||||
|   // iterate over the pwm_buffer contents at 16 byte intervals | ||||
|   for ( int i = 0; i < 144; i += 16 ) | ||||
|   { | ||||
|     // set the first register, e.g. 0x24, 0x34, 0x44, etc. | ||||
|     g_twi_transfer_buffer[0] = 0x24 + i; | ||||
|     // copy the data from i to i+15 | ||||
|     // device will auto-increment register for data after the first byte | ||||
|     // thus this sets registers 0x24-0x33, 0x34-0x43, etc. in one transfer | ||||
|     for ( int j = 0; j < 16; j++ ) | ||||
|     { | ||||
|       g_twi_transfer_buffer[1 + j] = pwm_buffer[i + j]; | ||||
|     } | ||||
|  | ||||
|     //Transmit buffer until succesful | ||||
|     //while(twi2c_transmit(addr << 1, g_twi_transfer_buffer,17) != 0); | ||||
|     twi2c_transmit(addr << 1, g_twi_transfer_buffer,17); | ||||
|   } | ||||
| } | ||||
|  | ||||
| void IS31FL3731_init( uint8_t addr ) | ||||
| { | ||||
|   // In order to avoid the LEDs being driven with garbage data | ||||
|   // in the LED driver's PWM registers, first enable software shutdown, | ||||
|   // then set up the mode and other settings, clear the PWM registers, | ||||
|   // then disable software shutdown. | ||||
|  | ||||
|   // select "function register" bank | ||||
|   IS31FL3731_write_register( addr, ISSI_COMMANDREGISTER, ISSI_BANK_FUNCTIONREG ); | ||||
|  | ||||
|   // enable software shutdown | ||||
|   IS31FL3731_write_register( addr, ISSI_REG_SHUTDOWN, 0x00 ); | ||||
|   // this delay was copied from other drivers, might not be needed | ||||
|   wait_ms( 10 ); | ||||
|  | ||||
|   // picture mode | ||||
|   IS31FL3731_write_register( addr, ISSI_REG_CONFIG, ISSI_REG_CONFIG_PICTUREMODE ); | ||||
|   // display frame 0 | ||||
|   IS31FL3731_write_register( addr, ISSI_REG_PICTUREFRAME, 0x00 ); | ||||
|   // audio sync off | ||||
|   IS31FL3731_write_register( addr, ISSI_REG_AUDIOSYNC, 0x00 ); | ||||
|  | ||||
|   // select bank 0 | ||||
|   IS31FL3731_write_register( addr, ISSI_COMMANDREGISTER, 0 ); | ||||
|  | ||||
|   // turn off all LEDs in the LED control register | ||||
|   for ( int i = 0x00; i <= 0x11; i++ ) | ||||
|   { | ||||
|     IS31FL3731_write_register( addr, i, 0x00 ); | ||||
|   } | ||||
|  | ||||
|   // turn off all LEDs in the blink control register (not really needed) | ||||
|   for ( int i = 0x12; i <= 0x23; i++ ) | ||||
|   { | ||||
|     IS31FL3731_write_register( addr, i, 0x00 ); | ||||
|   } | ||||
|  | ||||
|   // set PWM on all LEDs to 0 | ||||
|   for ( int i = 0x24; i <= 0xB3; i++ ) | ||||
|   { | ||||
|     IS31FL3731_write_register( addr, i, 0x00 ); | ||||
|   } | ||||
|  | ||||
|   // select "function register" bank | ||||
|   IS31FL3731_write_register( addr, ISSI_COMMANDREGISTER, ISSI_BANK_FUNCTIONREG ); | ||||
|  | ||||
|   // disable software shutdown | ||||
|   IS31FL3731_write_register( addr, ISSI_REG_SHUTDOWN, 0x01 ); | ||||
|  | ||||
|   // select bank 0 and leave it selected. | ||||
|   // most usage after initialization is just writing PWM buffers in bank 0 | ||||
|   // as there's not much point in double-buffering | ||||
|   IS31FL3731_write_register( addr, ISSI_COMMANDREGISTER, 0 ); | ||||
| } | ||||
|  | ||||
| void IS31FL3731_set_color( int index, uint8_t red, uint8_t green, uint8_t blue ) | ||||
| { | ||||
|   if ( index >= 0 && index < DRIVER_LED_TOTAL ) { | ||||
|     is31_led led = g_is31_leds[index]; | ||||
|  | ||||
|     // Subtract 0x24 to get the second index of g_pwm_buffer | ||||
|     g_pwm_buffer[led.driver][led.r - 0x24] = red; | ||||
|     g_pwm_buffer[led.driver][led.g - 0x24] = green; | ||||
|     g_pwm_buffer[led.driver][led.b - 0x24] = blue; | ||||
|     g_pwm_buffer_update_required = true; | ||||
|   } | ||||
| } | ||||
|  | ||||
| void IS31FL3731_set_color_all( uint8_t red, uint8_t green, uint8_t blue ) | ||||
| { | ||||
|   for ( int i = 0; i < DRIVER_LED_TOTAL; i++ ) | ||||
|   { | ||||
|     IS31FL3731_set_color( i, red, green, blue ); | ||||
|   } | ||||
| } | ||||
|  | ||||
| void IS31FL3731_set_led_control_register( uint8_t index, bool red, bool green, bool blue ) | ||||
| { | ||||
|   is31_led led = g_is31_leds[index]; | ||||
|  | ||||
|   uint8_t control_register_r = (led.r - 0x24) / 8; | ||||
|   uint8_t control_register_g = (led.g - 0x24) / 8; | ||||
|   uint8_t control_register_b = (led.b - 0x24) / 8; | ||||
|   uint8_t bit_r = (led.r - 0x24) % 8; | ||||
|   uint8_t bit_g = (led.g - 0x24) % 8; | ||||
|   uint8_t bit_b = (led.b - 0x24) % 8; | ||||
|  | ||||
|   if ( red ) { | ||||
|     g_led_control_registers[led.driver][control_register_r] |= (1 << bit_r); | ||||
|   } else { | ||||
|     g_led_control_registers[led.driver][control_register_r] &= ~(1 << bit_r); | ||||
|   } | ||||
|   if ( green ) { | ||||
|     g_led_control_registers[led.driver][control_register_g] |= (1 << bit_g); | ||||
|   } else { | ||||
|     g_led_control_registers[led.driver][control_register_g] &= ~(1 << bit_g); | ||||
|   } | ||||
|   if ( blue ) { | ||||
|     g_led_control_registers[led.driver][control_register_b] |= (1 << bit_b); | ||||
|   } else { | ||||
|     g_led_control_registers[led.driver][control_register_b] &= ~(1 << bit_b); | ||||
|   } | ||||
|  | ||||
|   g_led_control_registers_update_required = true; | ||||
|  | ||||
|  | ||||
| } | ||||
|  | ||||
| void IS31FL3731_update_pwm_buffers( uint8_t addr1, uint8_t addr2 ) | ||||
| { | ||||
|   if ( g_pwm_buffer_update_required ) | ||||
|   { | ||||
|     IS31FL3731_write_pwm_buffer( addr1, g_pwm_buffer[0] ); | ||||
|     IS31FL3731_write_pwm_buffer( addr2, g_pwm_buffer[1] ); | ||||
|   } | ||||
|   g_pwm_buffer_update_required = false; | ||||
| } | ||||
|  | ||||
| void IS31FL3731_update_led_control_registers( uint8_t addr1, uint8_t addr2 ) | ||||
| { | ||||
|   if ( g_led_control_registers_update_required ) | ||||
|   { | ||||
|     for ( int i=0; i<18; i++ ) | ||||
|     { | ||||
|       IS31FL3731_write_register(addr1, i, g_led_control_registers[0][i] ); | ||||
|       IS31FL3731_write_register(addr2, i, g_led_control_registers[1][i] ); | ||||
|     } | ||||
|   } | ||||
| } | ||||
|  | ||||
							
								
								
									
										202
									
								
								drivers/qwiic/qwiic_keyboard.c
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										202
									
								
								drivers/qwiic/qwiic_keyboard.c
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,202 @@ | ||||
| /* Copyright 2018 Jack Humbert | ||||
|  * | ||||
|  * 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/>. | ||||
|  */ | ||||
|  | ||||
| #include "qwiic_keyboard.h" | ||||
| #include "keymap.h" | ||||
| #include "matrix.h" | ||||
| #include "keyboard.h" | ||||
| #include "twi2c.h" | ||||
| #include <string.h> | ||||
| #include "usb_main.h" | ||||
| #include "usb_driver.h" | ||||
|  | ||||
| #define QWIIC_KEYBOARD_LAYERS 16 | ||||
| #define QWIIC_KEYBOARD_ROWS 8 | ||||
| #define QWIIC_KEYBOARD_COLS 8 | ||||
|  | ||||
| #define qwiic_matrix_t uint8_t | ||||
|  | ||||
| #define QWIIC_KEYBOARD_HANDSHAKE_ADDRESS       0b01010100 | ||||
| #define QWIIC_KEYBOARD_LISTENING_ADDRESS_START 0b01010110 | ||||
| #define QWIIC_KEYBOARD_HANDSHAKE_MESSAGE_SIZE  (QWIIC_KEYBOARD_LAYERS * QWIIC_KEYBOARD_ROWS * QWIIC_KEYBOARD_COLS) | ||||
| #define QWIIC_KEYBOARD_MATRIX_MESSAGE_SIZE     MATRIX_ROWS | ||||
|  | ||||
| void qwiic_keyboard_write_keymap(uint8_t * pointer); | ||||
| void qwiic_keyboard_read_keymap(uint8_t * pointer); | ||||
|  | ||||
| bool qwiic_keyboard_master = false; | ||||
| bool qwiic_keyboard_connected = false; | ||||
| uint8_t qwiic_keyboard_handshake_message[QWIIC_KEYBOARD_HANDSHAKE_MESSAGE_SIZE] = {0}; | ||||
| uint8_t qwiic_keyboard_matrix_message[QWIIC_KEYBOARD_ROWS] = {0}; | ||||
| twi2c_message_received qwiic_keyboard_message_received_ptr = qwiic_keyboard_message_received; | ||||
|  | ||||
| uint16_t qwiic_keyboard_keymap[QWIIC_KEYBOARD_LAYERS][QWIIC_KEYBOARD_ROWS][QWIIC_KEYBOARD_COLS] = {0}; | ||||
| uint8_t qwiic_keyboard_listening_address = QWIIC_KEYBOARD_LISTENING_ADDRESS_START; | ||||
| uint8_t qwiic_keyboard_processing_slave = false; | ||||
|  | ||||
| void qwiic_keyboard_init(void) { | ||||
|   twi2c_init(); | ||||
|   twi2c_start(); | ||||
|   twi2c_start_listening(QWIIC_KEYBOARD_HANDSHAKE_ADDRESS, qwiic_keyboard_message_received_ptr); | ||||
| } | ||||
|  | ||||
| void qwiic_keyboard_set_master(void) { | ||||
|   twi2c_stop(); | ||||
|   twi2c_start(); | ||||
|   qwiic_keyboard_master = true; | ||||
| } | ||||
|  | ||||
| uint8_t command[1] = { 0x00 }; | ||||
|  | ||||
| void qwiic_keyboard_task(void) { | ||||
|   if (USB_DRIVER.state == USB_ACTIVE) | ||||
|     qwiic_keyboard_master = true; | ||||
|   else | ||||
|     qwiic_keyboard_master = false; | ||||
|   if (qwiic_keyboard_master) { | ||||
|     if (qwiic_keyboard_connected) { | ||||
|       // send empty message, expecting matrix info | ||||
|       if (MSG_OK == twi2c_transmit_receive(qwiic_keyboard_listening_address, | ||||
|         command, 1, | ||||
|         qwiic_keyboard_matrix_message, QWIIC_KEYBOARD_MATRIX_MESSAGE_SIZE | ||||
|       )) { | ||||
|         // majority of this is pulled from keyboard.c:keyboard_task() | ||||
|         static qwiic_matrix_t matrix_prev[QWIIC_KEYBOARD_ROWS]; | ||||
|         qwiic_matrix_t matrix_row = 0; | ||||
|         qwiic_matrix_t matrix_change = 0; | ||||
|         #ifdef QMK_KEYS_PER_SCAN | ||||
|           uint8_t keys_processed = 0; | ||||
|         #endif | ||||
|         qwiic_keyboard_processing_slave = true; | ||||
|         for (uint8_t r = 0; r < QWIIC_KEYBOARD_ROWS; r++) { | ||||
|           matrix_row = qwiic_keyboard_matrix_message[r]; | ||||
|           matrix_change = matrix_row ^ matrix_prev[r]; | ||||
|           if (matrix_change) { | ||||
|             for (uint8_t c = 0; c < QWIIC_KEYBOARD_COLS; c++) { | ||||
|               if (matrix_change & ((qwiic_matrix_t)1<<c)) { | ||||
|                 action_exec((keyevent_t){ | ||||
|                   .key = (keypos_t){ .row = r, .col = c }, | ||||
|                   .pressed = (matrix_row & ((qwiic_matrix_t)1<<c)), | ||||
|                   .time = (timer_read() | 1) /* time should not be 0 */ | ||||
|                 }); | ||||
|                 // record a processed key | ||||
|                 matrix_prev[r] ^= ((qwiic_matrix_t)1<<c); | ||||
|                 #ifdef QMK_KEYS_PER_SCAN | ||||
|                   // only jump out if we have processed "enough" keys. | ||||
|                   if (++keys_processed >= QMK_KEYS_PER_SCAN) | ||||
|                 #endif | ||||
|                 // process a key per task call | ||||
|                 goto QWIIC_MATRIX_LOOP_END; | ||||
|               } | ||||
|             } | ||||
|           } | ||||
|         } | ||||
|         // call with pseudo tick event when no real key event. | ||||
|         #ifdef QMK_KEYS_PER_SCAN | ||||
|           // we can get here with some keys processed now. | ||||
|           if (!keys_processed) | ||||
|         #endif | ||||
|         action_exec(TICK); | ||||
|         QWIIC_MATRIX_LOOP_END: | ||||
|         qwiic_keyboard_processing_slave = false; | ||||
|       } else { | ||||
|         // disconnect | ||||
|         // qwiic_keyboard_connected = false; | ||||
|       } | ||||
|     } else { // if not connected | ||||
|       // send new address to listen on, expect back keymap | ||||
|       if (MSG_OK == twi2c_transmit_receive(QWIIC_KEYBOARD_HANDSHAKE_ADDRESS, | ||||
|         &qwiic_keyboard_listening_address, 1, | ||||
|         qwiic_keyboard_handshake_message, QWIIC_KEYBOARD_HANDSHAKE_MESSAGE_SIZE | ||||
|       )) { | ||||
|         qwiic_keyboard_connected = true; | ||||
|         // load keymap into memory | ||||
|         qwiic_keyboard_read_keymap(qwiic_keyboard_handshake_message); | ||||
|       } | ||||
|     } | ||||
|   } | ||||
| } | ||||
|  | ||||
| float song_one_up[][2]  = SONG(ONE_UP_SOUND); | ||||
| bool first_message = true; | ||||
|  | ||||
| void qwiic_keyboard_message_received(I2CDriver *i2cp, uint8_t * body, uint16_t size) { | ||||
|   if (qwiic_keyboard_connected) { | ||||
|     for (uint8_t row = 0; row < QWIIC_KEYBOARD_ROWS; row++) { | ||||
|       if (row < MATRIX_ROWS) { | ||||
|         qwiic_keyboard_matrix_message[row] = matrix_get_row(row); | ||||
|       } else { | ||||
|         qwiic_keyboard_matrix_message[row] = 0; | ||||
|       } | ||||
|     } | ||||
|     twi2c_reply(i2cp, qwiic_keyboard_matrix_message, QWIIC_KEYBOARD_MATRIX_MESSAGE_SIZE); | ||||
|     if (first_message) { | ||||
|       PLAY_SONG(song_one_up); | ||||
|       first_message = false; | ||||
|     } | ||||
|   } else { | ||||
|     qwiic_keyboard_connected = true; | ||||
|     qwiic_keyboard_master = false; | ||||
|     qwiic_keyboard_listening_address = body[0]; | ||||
|     twi2c_restart_listening(qwiic_keyboard_listening_address); | ||||
|     qwiic_keyboard_write_keymap(qwiic_keyboard_handshake_message); | ||||
|     twi2c_reply(i2cp, qwiic_keyboard_handshake_message, QWIIC_KEYBOARD_HANDSHAKE_MESSAGE_SIZE); | ||||
|   } | ||||
| } | ||||
|  | ||||
| // qwiic_keyboard_message_received_ptr = qwiic_keyboard_message_received; | ||||
|  | ||||
| __attribute__((optimize("O0"))) | ||||
| void qwiic_keyboard_write_keymap(uint8_t * pointer) { | ||||
|   for (uint8_t layer = 0; layer < QWIIC_KEYBOARD_LAYERS; layer++) { | ||||
|     for (uint8_t row = 0; row < QWIIC_KEYBOARD_ROWS; row++) { | ||||
|       for (uint8_t col = 0; col < QWIIC_KEYBOARD_COLS; col++) { | ||||
|         uint16_t keycode = pgm_read_word(&keymaps[layer][row][col]); | ||||
|         *pointer++ = (keycode >> 8); | ||||
|         *pointer++ = (keycode & 0xFF); | ||||
|       } | ||||
|     } | ||||
|   } | ||||
| } | ||||
|  | ||||
| void qwiic_keyboard_read_keymap(uint8_t * pointer) { | ||||
|   for (uint8_t layer = 0; layer < QWIIC_KEYBOARD_LAYERS; layer++) { | ||||
|     for (uint8_t row = 0; row < QWIIC_KEYBOARD_ROWS; row++) { | ||||
|       for (uint8_t col = 0; col < QWIIC_KEYBOARD_COLS; col++) { | ||||
|         uint16_t keycode = ((*pointer++) << 8); | ||||
|         keycode |= (*pointer++); | ||||
|         qwiic_keyboard_keymap[layer][row][col] = keycode; | ||||
|       } | ||||
|     } | ||||
|   } | ||||
| } | ||||
|  | ||||
| // overwrite the built-in function - slaves don't need to process keycodes | ||||
| bool is_keyboard_master(void) { | ||||
|   return qwiic_keyboard_master; | ||||
| } | ||||
|  | ||||
| // overwrite the built-in function | ||||
| uint16_t keymap_key_to_keycode(uint8_t layer, keypos_t key) { | ||||
|   if (qwiic_keyboard_processing_slave) { | ||||
|     // trick the built-in handling to accept our replacement keymap | ||||
|     return qwiic_keyboard_keymap[(layer)][(key.row)][(key.col)]; | ||||
|     //return KC_A; | ||||
|   } else { | ||||
|     // Read entire word (16bits) | ||||
|     return pgm_read_word(&keymaps[(layer)][(key.row)][(key.col)]); | ||||
|   } | ||||
| } | ||||
							
								
								
									
										26
									
								
								drivers/qwiic/qwiic_keyboard.h
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										26
									
								
								drivers/qwiic/qwiic_keyboard.h
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,26 @@ | ||||
| /* Copyright 2018 Jack Humbert | ||||
|  * | ||||
|  * 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/>. | ||||
|  */ | ||||
|  | ||||
| #ifndef QWIIC_KEYBOARD_H | ||||
| #define QWIIC_KEYBOARD_H | ||||
|  | ||||
| #include "quantum.h" | ||||
|  | ||||
| void qwiic_keyboard_init(void); | ||||
| void qwiic_keyboard_task(void); | ||||
| void qwiic_keyboard_message_received(I2CDriver *i2cp, uint8_t * body, uint16_t size); | ||||
|  | ||||
| #endif | ||||
							
								
								
									
										126
									
								
								keyboards/muon_light/boards/GENERIC_STM32_F303XC/board.c
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										126
									
								
								keyboards/muon_light/boards/GENERIC_STM32_F303XC/board.c
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,126 @@ | ||||
| /* | ||||
|     ChibiOS - Copyright (C) 2006..2016 Giovanni Di Sirio | ||||
|  | ||||
|     Licensed under the Apache License, Version 2.0 (the "License"); | ||||
|     you may not use this file except in compliance with the License. | ||||
|     You may obtain a copy of the License at | ||||
|  | ||||
|         http://www.apache.org/licenses/LICENSE-2.0 | ||||
|  | ||||
|     Unless required by applicable law or agreed to in writing, software | ||||
|     distributed under the License is distributed on an "AS IS" BASIS, | ||||
|     WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. | ||||
|     See the License for the specific language governing permissions and | ||||
|     limitations under the License. | ||||
| */ | ||||
|  | ||||
| #include "hal.h" | ||||
|  | ||||
| #if HAL_USE_PAL || defined(__DOXYGEN__) | ||||
| /** | ||||
|  * @brief   PAL setup. | ||||
|  * @details Digital I/O ports static configuration as defined in @p board.h. | ||||
|  *          This variable is used by the HAL when initializing the PAL driver. | ||||
|  */ | ||||
| const PALConfig pal_default_config = { | ||||
| #if STM32_HAS_GPIOA | ||||
|   {VAL_GPIOA_MODER, VAL_GPIOA_OTYPER, VAL_GPIOA_OSPEEDR, VAL_GPIOA_PUPDR, | ||||
|    VAL_GPIOA_ODR,   VAL_GPIOA_AFRL,   VAL_GPIOA_AFRH}, | ||||
| #endif | ||||
| #if STM32_HAS_GPIOB | ||||
|   {VAL_GPIOB_MODER, VAL_GPIOB_OTYPER, VAL_GPIOB_OSPEEDR, VAL_GPIOB_PUPDR, | ||||
|    VAL_GPIOB_ODR,   VAL_GPIOB_AFRL,   VAL_GPIOB_AFRH}, | ||||
| #endif | ||||
| #if STM32_HAS_GPIOC | ||||
|   {VAL_GPIOC_MODER, VAL_GPIOC_OTYPER, VAL_GPIOC_OSPEEDR, VAL_GPIOC_PUPDR, | ||||
|    VAL_GPIOC_ODR,   VAL_GPIOC_AFRL,   VAL_GPIOC_AFRH}, | ||||
| #endif | ||||
| #if STM32_HAS_GPIOD | ||||
|   {VAL_GPIOD_MODER, VAL_GPIOD_OTYPER, VAL_GPIOD_OSPEEDR, VAL_GPIOD_PUPDR, | ||||
|    VAL_GPIOD_ODR,   VAL_GPIOD_AFRL,   VAL_GPIOD_AFRH}, | ||||
| #endif | ||||
| #if STM32_HAS_GPIOE | ||||
|   {VAL_GPIOE_MODER, VAL_GPIOE_OTYPER, VAL_GPIOE_OSPEEDR, VAL_GPIOE_PUPDR, | ||||
|    VAL_GPIOE_ODR,   VAL_GPIOE_AFRL,   VAL_GPIOE_AFRH}, | ||||
| #endif | ||||
| #if STM32_HAS_GPIOF | ||||
|   {VAL_GPIOF_MODER, VAL_GPIOF_OTYPER, VAL_GPIOF_OSPEEDR, VAL_GPIOF_PUPDR, | ||||
|    VAL_GPIOF_ODR,   VAL_GPIOF_AFRL,   VAL_GPIOF_AFRH}, | ||||
| #endif | ||||
| #if STM32_HAS_GPIOG | ||||
|   {VAL_GPIOG_MODER, VAL_GPIOG_OTYPER, VAL_GPIOG_OSPEEDR, VAL_GPIOG_PUPDR, | ||||
|    VAL_GPIOG_ODR,   VAL_GPIOG_AFRL,   VAL_GPIOG_AFRH}, | ||||
| #endif | ||||
| #if STM32_HAS_GPIOH | ||||
|   {VAL_GPIOH_MODER, VAL_GPIOH_OTYPER, VAL_GPIOH_OSPEEDR, VAL_GPIOH_PUPDR, | ||||
|    VAL_GPIOH_ODR,   VAL_GPIOH_AFRL,   VAL_GPIOH_AFRH}, | ||||
| #endif | ||||
| #if STM32_HAS_GPIOI | ||||
|   {VAL_GPIOI_MODER, VAL_GPIOI_OTYPER, VAL_GPIOI_OSPEEDR, VAL_GPIOI_PUPDR, | ||||
|    VAL_GPIOI_ODR,   VAL_GPIOI_AFRL,   VAL_GPIOI_AFRH} | ||||
| #endif | ||||
| }; | ||||
| #endif | ||||
|  | ||||
| void enter_bootloader_mode_if_requested(void); | ||||
|  | ||||
| /** | ||||
|  * @brief   Early initialization code. | ||||
|  * @details This initialization must be performed just after stack setup | ||||
|  *          and before any other initialization. | ||||
|  */ | ||||
| void __early_init(void) { | ||||
|   enter_bootloader_mode_if_requested(); | ||||
|   stm32_clock_init(); | ||||
| } | ||||
|  | ||||
| #if HAL_USE_SDC || defined(__DOXYGEN__) | ||||
| /** | ||||
|  * @brief   SDC card detection. | ||||
|  */ | ||||
| bool sdc_lld_is_card_inserted(SDCDriver *sdcp) { | ||||
|  | ||||
|   (void)sdcp; | ||||
|   /* TODO: Fill the implementation.*/ | ||||
|   return true; | ||||
| } | ||||
|  | ||||
| /** | ||||
|  * @brief   SDC card write protection detection. | ||||
|  */ | ||||
| bool sdc_lld_is_write_protected(SDCDriver *sdcp) { | ||||
|  | ||||
|   (void)sdcp; | ||||
|   /* TODO: Fill the implementation.*/ | ||||
|   return false; | ||||
| } | ||||
| #endif /* HAL_USE_SDC */ | ||||
|  | ||||
| #if HAL_USE_MMC_SPI || defined(__DOXYGEN__) | ||||
| /** | ||||
|  * @brief   MMC_SPI card detection. | ||||
|  */ | ||||
| bool mmc_lld_is_card_inserted(MMCDriver *mmcp) { | ||||
|  | ||||
|   (void)mmcp; | ||||
|   /* TODO: Fill the implementation.*/ | ||||
|   return true; | ||||
| } | ||||
|  | ||||
| /** | ||||
|  * @brief   MMC_SPI card write protection detection. | ||||
|  */ | ||||
| bool mmc_lld_is_write_protected(MMCDriver *mmcp) { | ||||
|  | ||||
|   (void)mmcp; | ||||
|   /* TODO: Fill the implementation.*/ | ||||
|   return false; | ||||
| } | ||||
| #endif | ||||
|  | ||||
| /** | ||||
|  * @brief   Board-specific initialization code. | ||||
|  * @todo    Add your board-specific code, if any. | ||||
|  */ | ||||
| void boardInit(void) { | ||||
| } | ||||
							
								
								
									
										1187
									
								
								keyboards/muon_light/boards/GENERIC_STM32_F303XC/board.h
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										1187
									
								
								keyboards/muon_light/boards/GENERIC_STM32_F303XC/board.h
									
									
									
									
									
										Normal file
									
								
							
										
											
												File diff suppressed because it is too large
												Load Diff
											
										
									
								
							| @@ -0,0 +1,5 @@ | ||||
| # List of all the board related files. | ||||
| BOARDSRC = $(BOARD_PATH)/boards/GENERIC_STM32_F303XC/board.c | ||||
|  | ||||
| # Required include directories | ||||
| BOARDINC = $(BOARD_PATH)/boards/GENERIC_STM32_F303XC | ||||
							
								
								
									
										7
									
								
								keyboards/muon_light/bootloader_defs.h
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										7
									
								
								keyboards/muon_light/bootloader_defs.h
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,7 @@ | ||||
| /* Address for jumping to bootloader on STM32 chips. */ | ||||
| /* It is chip dependent, the correct number can be looked up here: | ||||
|  * http://www.st.com/web/en/resource/technical/document/application_note/CD00167594.pdf | ||||
|  * This also requires a patch to chibios: | ||||
|  *  <tmk_dir>/tmk_core/tool/chibios/ch-bootloader-jump.patch | ||||
|  */ | ||||
| #define STM32_BOOTLOADER_ADDRESS 0x1FFFD800 | ||||
							
								
								
									
										520
									
								
								keyboards/muon_light/chconf.h
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										520
									
								
								keyboards/muon_light/chconf.h
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,520 @@ | ||||
| /* | ||||
|     ChibiOS - Copyright (C) 2006..2016 Giovanni Di Sirio | ||||
|  | ||||
|     Licensed under the Apache License, Version 2.0 (the "License"); | ||||
|     you may not use this file except in compliance with the License. | ||||
|     You may obtain a copy of the License at | ||||
|  | ||||
|         http://www.apache.org/licenses/LICENSE-2.0 | ||||
|  | ||||
|     Unless required by applicable law or agreed to in writing, software | ||||
|     distributed under the License is distributed on an "AS IS" BASIS, | ||||
|     WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. | ||||
|     See the License for the specific language governing permissions and | ||||
|     limitations under the License. | ||||
| */ | ||||
|  | ||||
| /** | ||||
|  * @file    templates/chconf.h | ||||
|  * @brief   Configuration file template. | ||||
|  * @details A copy of this file must be placed in each project directory, it | ||||
|  *          contains the application specific kernel settings. | ||||
|  * | ||||
|  * @addtogroup config | ||||
|  * @details Kernel related settings and hooks. | ||||
|  * @{ | ||||
|  */ | ||||
|  | ||||
| #ifndef CHCONF_H | ||||
| #define CHCONF_H | ||||
|  | ||||
| #define _CHIBIOS_RT_CONF_ | ||||
|  | ||||
| /*===========================================================================*/ | ||||
| /** | ||||
|  * @name System timers settings | ||||
|  * @{ | ||||
|  */ | ||||
| /*===========================================================================*/ | ||||
|  | ||||
| /** | ||||
|  * @brief   System time counter resolution. | ||||
|  * @note    Allowed values are 16 or 32 bits. | ||||
|  */ | ||||
| #define CH_CFG_ST_RESOLUTION                32 | ||||
|  | ||||
| /** | ||||
|  * @brief   System tick frequency. | ||||
|  * @details Frequency of the system timer that drives the system ticks. This | ||||
|  *          setting also defines the system tick time unit. | ||||
|  */ | ||||
| #define CH_CFG_ST_FREQUENCY                 10000 | ||||
|  | ||||
| /** | ||||
|  * @brief   Time delta constant for the tick-less mode. | ||||
|  * @note    If this value is zero then the system uses the classic | ||||
|  *          periodic tick. This value represents the minimum number | ||||
|  *          of ticks that is safe to specify in a timeout directive. | ||||
|  *          The value one is not valid, timeouts are rounded up to | ||||
|  *          this value. | ||||
|  */ | ||||
| #define CH_CFG_ST_TIMEDELTA                 2 | ||||
|  | ||||
| /** @} */ | ||||
|  | ||||
| /*===========================================================================*/ | ||||
| /** | ||||
|  * @name Kernel parameters and options | ||||
|  * @{ | ||||
|  */ | ||||
| /*===========================================================================*/ | ||||
|  | ||||
| /** | ||||
|  * @brief   Round robin interval. | ||||
|  * @details This constant is the number of system ticks allowed for the | ||||
|  *          threads before preemption occurs. Setting this value to zero | ||||
|  *          disables the preemption for threads with equal priority and the | ||||
|  *          round robin becomes cooperative. Note that higher priority | ||||
|  *          threads can still preempt, the kernel is always preemptive. | ||||
|  * @note    Disabling the round robin preemption makes the kernel more compact | ||||
|  *          and generally faster. | ||||
|  * @note    The round robin preemption is not supported in tickless mode and | ||||
|  *          must be set to zero in that case. | ||||
|  */ | ||||
| #define CH_CFG_TIME_QUANTUM                 0 | ||||
|  | ||||
| /** | ||||
|  * @brief   Managed RAM size. | ||||
|  * @details Size of the RAM area to be managed by the OS. If set to zero | ||||
|  *          then the whole available RAM is used. The core memory is made | ||||
|  *          available to the heap allocator and/or can be used directly through | ||||
|  *          the simplified core memory allocator. | ||||
|  * | ||||
|  * @note    In order to let the OS manage the whole RAM the linker script must | ||||
|  *          provide the @p __heap_base__ and @p __heap_end__ symbols. | ||||
|  * @note    Requires @p CH_CFG_USE_MEMCORE. | ||||
|  */ | ||||
| #define CH_CFG_MEMCORE_SIZE                 0 | ||||
|  | ||||
| /** | ||||
|  * @brief   Idle thread automatic spawn suppression. | ||||
|  * @details When this option is activated the function @p chSysInit() | ||||
|  *          does not spawn the idle thread. The application @p main() | ||||
|  *          function becomes the idle thread and must implement an | ||||
|  *          infinite loop. | ||||
|  */ | ||||
| #define CH_CFG_NO_IDLE_THREAD               FALSE | ||||
|  | ||||
| /** @} */ | ||||
|  | ||||
| /*===========================================================================*/ | ||||
| /** | ||||
|  * @name Performance options | ||||
|  * @{ | ||||
|  */ | ||||
| /*===========================================================================*/ | ||||
|  | ||||
| /** | ||||
|  * @brief   OS optimization. | ||||
|  * @details If enabled then time efficient rather than space efficient code | ||||
|  *          is used when two possible implementations exist. | ||||
|  * | ||||
|  * @note    This is not related to the compiler optimization options. | ||||
|  * @note    The default is @p TRUE. | ||||
|  */ | ||||
| #define CH_CFG_OPTIMIZE_SPEED               TRUE | ||||
|  | ||||
| /** @} */ | ||||
|  | ||||
| /*===========================================================================*/ | ||||
| /** | ||||
|  * @name Subsystem options | ||||
|  * @{ | ||||
|  */ | ||||
| /*===========================================================================*/ | ||||
|  | ||||
| /** | ||||
|  * @brief   Time Measurement APIs. | ||||
|  * @details If enabled then the time measurement APIs are included in | ||||
|  *          the kernel. | ||||
|  * | ||||
|  * @note    The default is @p TRUE. | ||||
|  */ | ||||
| #define CH_CFG_USE_TM                       TRUE | ||||
|  | ||||
| /** | ||||
|  * @brief   Threads registry APIs. | ||||
|  * @details If enabled then the registry APIs are included in the kernel. | ||||
|  * | ||||
|  * @note    The default is @p TRUE. | ||||
|  */ | ||||
| #define CH_CFG_USE_REGISTRY                 TRUE | ||||
|  | ||||
| /** | ||||
|  * @brief   Threads synchronization APIs. | ||||
|  * @details If enabled then the @p chThdWait() function is included in | ||||
|  *          the kernel. | ||||
|  * | ||||
|  * @note    The default is @p TRUE. | ||||
|  */ | ||||
| #define CH_CFG_USE_WAITEXIT                 TRUE | ||||
|  | ||||
| /** | ||||
|  * @brief   Semaphores APIs. | ||||
|  * @details If enabled then the Semaphores APIs are included in the kernel. | ||||
|  * | ||||
|  * @note    The default is @p TRUE. | ||||
|  */ | ||||
| #define CH_CFG_USE_SEMAPHORES               TRUE | ||||
|  | ||||
| /** | ||||
|  * @brief   Semaphores queuing mode. | ||||
|  * @details If enabled then the threads are enqueued on semaphores by | ||||
|  *          priority rather than in FIFO order. | ||||
|  * | ||||
|  * @note    The default is @p FALSE. Enable this if you have special | ||||
|  *          requirements. | ||||
|  * @note    Requires @p CH_CFG_USE_SEMAPHORES. | ||||
|  */ | ||||
| #define CH_CFG_USE_SEMAPHORES_PRIORITY      FALSE | ||||
|  | ||||
| /** | ||||
|  * @brief   Mutexes APIs. | ||||
|  * @details If enabled then the mutexes APIs are included in the kernel. | ||||
|  * | ||||
|  * @note    The default is @p TRUE. | ||||
|  */ | ||||
| #define CH_CFG_USE_MUTEXES                  TRUE | ||||
|  | ||||
| /** | ||||
|  * @brief   Enables recursive behavior on mutexes. | ||||
|  * @note    Recursive mutexes are heavier and have an increased | ||||
|  *          memory footprint. | ||||
|  * | ||||
|  * @note    The default is @p FALSE. | ||||
|  * @note    Requires @p CH_CFG_USE_MUTEXES. | ||||
|  */ | ||||
| #define CH_CFG_USE_MUTEXES_RECURSIVE        FALSE | ||||
|  | ||||
| /** | ||||
|  * @brief   Conditional Variables APIs. | ||||
|  * @details If enabled then the conditional variables APIs are included | ||||
|  *          in the kernel. | ||||
|  * | ||||
|  * @note    The default is @p TRUE. | ||||
|  * @note    Requires @p CH_CFG_USE_MUTEXES. | ||||
|  */ | ||||
| #define CH_CFG_USE_CONDVARS                 TRUE | ||||
|  | ||||
| /** | ||||
|  * @brief   Conditional Variables APIs with timeout. | ||||
|  * @details If enabled then the conditional variables APIs with timeout | ||||
|  *          specification are included in the kernel. | ||||
|  * | ||||
|  * @note    The default is @p TRUE. | ||||
|  * @note    Requires @p CH_CFG_USE_CONDVARS. | ||||
|  */ | ||||
| #define CH_CFG_USE_CONDVARS_TIMEOUT         TRUE | ||||
|  | ||||
| /** | ||||
|  * @brief   Events Flags APIs. | ||||
|  * @details If enabled then the event flags APIs are included in the kernel. | ||||
|  * | ||||
|  * @note    The default is @p TRUE. | ||||
|  */ | ||||
| #define CH_CFG_USE_EVENTS                   TRUE | ||||
|  | ||||
| /** | ||||
|  * @brief   Events Flags APIs with timeout. | ||||
|  * @details If enabled then the events APIs with timeout specification | ||||
|  *          are included in the kernel. | ||||
|  * | ||||
|  * @note    The default is @p TRUE. | ||||
|  * @note    Requires @p CH_CFG_USE_EVENTS. | ||||
|  */ | ||||
| #define CH_CFG_USE_EVENTS_TIMEOUT           TRUE | ||||
|  | ||||
| /** | ||||
|  * @brief   Synchronous Messages APIs. | ||||
|  * @details If enabled then the synchronous messages APIs are included | ||||
|  *          in the kernel. | ||||
|  * | ||||
|  * @note    The default is @p TRUE. | ||||
|  */ | ||||
| #define CH_CFG_USE_MESSAGES                 TRUE | ||||
|  | ||||
| /** | ||||
|  * @brief   Synchronous Messages queuing mode. | ||||
|  * @details If enabled then messages are served by priority rather than in | ||||
|  *          FIFO order. | ||||
|  * | ||||
|  * @note    The default is @p FALSE. Enable this if you have special | ||||
|  *          requirements. | ||||
|  * @note    Requires @p CH_CFG_USE_MESSAGES. | ||||
|  */ | ||||
| #define CH_CFG_USE_MESSAGES_PRIORITY        TRUE | ||||
|  | ||||
| /** | ||||
|  * @brief   Mailboxes APIs. | ||||
|  * @details If enabled then the asynchronous messages (mailboxes) APIs are | ||||
|  *          included in the kernel. | ||||
|  * | ||||
|  * @note    The default is @p TRUE. | ||||
|  * @note    Requires @p CH_CFG_USE_SEMAPHORES. | ||||
|  */ | ||||
| #define CH_CFG_USE_MAILBOXES                TRUE | ||||
|  | ||||
| /** | ||||
|  * @brief   Core Memory Manager APIs. | ||||
|  * @details If enabled then the core memory manager APIs are included | ||||
|  *          in the kernel. | ||||
|  * | ||||
|  * @note    The default is @p TRUE. | ||||
|  */ | ||||
| #define CH_CFG_USE_MEMCORE                  TRUE | ||||
|  | ||||
| /** | ||||
|  * @brief   Heap Allocator APIs. | ||||
|  * @details If enabled then the memory heap allocator APIs are included | ||||
|  *          in the kernel. | ||||
|  * | ||||
|  * @note    The default is @p TRUE. | ||||
|  * @note    Requires @p CH_CFG_USE_MEMCORE and either @p CH_CFG_USE_MUTEXES or | ||||
|  *          @p CH_CFG_USE_SEMAPHORES. | ||||
|  * @note    Mutexes are recommended. | ||||
|  */ | ||||
| #define CH_CFG_USE_HEAP                     TRUE | ||||
|  | ||||
| /** | ||||
|  * @brief   Memory Pools Allocator APIs. | ||||
|  * @details If enabled then the memory pools allocator APIs are included | ||||
|  *          in the kernel. | ||||
|  * | ||||
|  * @note    The default is @p TRUE. | ||||
|  */ | ||||
| #define CH_CFG_USE_MEMPOOLS                 TRUE | ||||
|  | ||||
| /** | ||||
|  * @brief   Dynamic Threads APIs. | ||||
|  * @details If enabled then the dynamic threads creation APIs are included | ||||
|  *          in the kernel. | ||||
|  * | ||||
|  * @note    The default is @p TRUE. | ||||
|  * @note    Requires @p CH_CFG_USE_WAITEXIT. | ||||
|  * @note    Requires @p CH_CFG_USE_HEAP and/or @p CH_CFG_USE_MEMPOOLS. | ||||
|  */ | ||||
| #define CH_CFG_USE_DYNAMIC                  TRUE | ||||
|  | ||||
| /** @} */ | ||||
|  | ||||
| /*===========================================================================*/ | ||||
| /** | ||||
|  * @name Debug options | ||||
|  * @{ | ||||
|  */ | ||||
| /*===========================================================================*/ | ||||
|  | ||||
| /** | ||||
|  * @brief   Debug option, kernel statistics. | ||||
|  * | ||||
|  * @note    The default is @p FALSE. | ||||
|  */ | ||||
| #define CH_DBG_STATISTICS                   FALSE | ||||
|  | ||||
| /** | ||||
|  * @brief   Debug option, system state check. | ||||
|  * @details If enabled the correct call protocol for system APIs is checked | ||||
|  *          at runtime. | ||||
|  * | ||||
|  * @note    The default is @p FALSE. | ||||
|  */ | ||||
| #define CH_DBG_SYSTEM_STATE_CHECK           FALSE | ||||
|  | ||||
| /** | ||||
|  * @brief   Debug option, parameters checks. | ||||
|  * @details If enabled then the checks on the API functions input | ||||
|  *          parameters are activated. | ||||
|  * | ||||
|  * @note    The default is @p FALSE. | ||||
|  */ | ||||
| #define CH_DBG_ENABLE_CHECKS                FALSE | ||||
|  | ||||
| /** | ||||
|  * @brief   Debug option, consistency checks. | ||||
|  * @details If enabled then all the assertions in the kernel code are | ||||
|  *          activated. This includes consistency checks inside the kernel, | ||||
|  *          runtime anomalies and port-defined checks. | ||||
|  * | ||||
|  * @note    The default is @p FALSE. | ||||
|  */ | ||||
| #define CH_DBG_ENABLE_ASSERTS               FALSE | ||||
|  | ||||
| /** | ||||
|  * @brief   Debug option, trace buffer. | ||||
|  * @details If enabled then the trace buffer is activated. | ||||
|  * | ||||
|  * @note    The default is @p CH_DBG_TRACE_MASK_DISABLED. | ||||
|  */ | ||||
| #define CH_DBG_TRACE_MASK                   CH_DBG_TRACE_MASK_DISABLED | ||||
|  | ||||
| /** | ||||
|  * @brief   Trace buffer entries. | ||||
|  * @note    The trace buffer is only allocated if @p CH_DBG_TRACE_MASK is | ||||
|  *          different from @p CH_DBG_TRACE_MASK_DISABLED. | ||||
|  */ | ||||
| #define CH_DBG_TRACE_BUFFER_SIZE            128 | ||||
|  | ||||
| /** | ||||
|  * @brief   Debug option, stack checks. | ||||
|  * @details If enabled then a runtime stack check is performed. | ||||
|  * | ||||
|  * @note    The default is @p FALSE. | ||||
|  * @note    The stack check is performed in a architecture/port dependent way. | ||||
|  *          It may not be implemented or some ports. | ||||
|  * @note    The default failure mode is to halt the system with the global | ||||
|  *          @p panic_msg variable set to @p NULL. | ||||
|  */ | ||||
| #define CH_DBG_ENABLE_STACK_CHECK           TRUE | ||||
|  | ||||
| /** | ||||
|  * @brief   Debug option, stacks initialization. | ||||
|  * @details If enabled then the threads working area is filled with a byte | ||||
|  *          value when a thread is created. This can be useful for the | ||||
|  *          runtime measurement of the used stack. | ||||
|  * | ||||
|  * @note    The default is @p FALSE. | ||||
|  */ | ||||
| #define CH_DBG_FILL_THREADS                 FALSE | ||||
|  | ||||
| /** | ||||
|  * @brief   Debug option, threads profiling. | ||||
|  * @details If enabled then a field is added to the @p thread_t structure that | ||||
|  *          counts the system ticks occurred while executing the thread. | ||||
|  * | ||||
|  * @note    The default is @p FALSE. | ||||
|  * @note    This debug option is not currently compatible with the | ||||
|  *          tickless mode. | ||||
|  */ | ||||
| #define CH_DBG_THREADS_PROFILING            FALSE | ||||
|  | ||||
| /** @} */ | ||||
|  | ||||
| /*===========================================================================*/ | ||||
| /** | ||||
|  * @name Kernel hooks | ||||
|  * @{ | ||||
|  */ | ||||
| /*===========================================================================*/ | ||||
|  | ||||
| /** | ||||
|  * @brief   Threads descriptor structure extension. | ||||
|  * @details User fields added to the end of the @p thread_t structure. | ||||
|  */ | ||||
| #define CH_CFG_THREAD_EXTRA_FIELDS                                          \ | ||||
|   /* Add threads custom fields here.*/ | ||||
|  | ||||
| /** | ||||
|  * @brief   Threads initialization hook. | ||||
|  * @details User initialization code added to the @p chThdInit() API. | ||||
|  * | ||||
|  * @note    It is invoked from within @p chThdInit() and implicitly from all | ||||
|  *          the threads creation APIs. | ||||
|  */ | ||||
| #define CH_CFG_THREAD_INIT_HOOK(tp) {                                       \ | ||||
|   /* Add threads initialization code here.*/                                \ | ||||
| } | ||||
|  | ||||
| /** | ||||
|  * @brief   Threads finalization hook. | ||||
|  * @details User finalization code added to the @p chThdExit() API. | ||||
|  */ | ||||
| #define CH_CFG_THREAD_EXIT_HOOK(tp) {                                       \ | ||||
|   /* Add threads finalization code here.*/                                  \ | ||||
| } | ||||
|  | ||||
| /** | ||||
|  * @brief   Context switch hook. | ||||
|  * @details This hook is invoked just before switching between threads. | ||||
|  */ | ||||
| #define CH_CFG_CONTEXT_SWITCH_HOOK(ntp, otp) {                              \ | ||||
|   /* Context switch code here.*/                                            \ | ||||
| } | ||||
|  | ||||
| /** | ||||
|  * @brief   ISR enter hook. | ||||
|  */ | ||||
| #define CH_CFG_IRQ_PROLOGUE_HOOK() {                                        \ | ||||
|   /* IRQ prologue code here.*/                                              \ | ||||
| } | ||||
|  | ||||
| /** | ||||
|  * @brief   ISR exit hook. | ||||
|  */ | ||||
| #define CH_CFG_IRQ_EPILOGUE_HOOK() {                                        \ | ||||
|   /* IRQ epilogue code here.*/                                              \ | ||||
| } | ||||
|  | ||||
| /** | ||||
|  * @brief   Idle thread enter hook. | ||||
|  * @note    This hook is invoked within a critical zone, no OS functions | ||||
|  *          should be invoked from here. | ||||
|  * @note    This macro can be used to activate a power saving mode. | ||||
|  */ | ||||
| #define CH_CFG_IDLE_ENTER_HOOK() {                                          \ | ||||
|   /* Idle-enter code here.*/                                                \ | ||||
| } | ||||
|  | ||||
| /** | ||||
|  * @brief   Idle thread leave hook. | ||||
|  * @note    This hook is invoked within a critical zone, no OS functions | ||||
|  *          should be invoked from here. | ||||
|  * @note    This macro can be used to deactivate a power saving mode. | ||||
|  */ | ||||
| #define CH_CFG_IDLE_LEAVE_HOOK() {                                          \ | ||||
|   /* Idle-leave code here.*/                                                \ | ||||
| } | ||||
|  | ||||
| /** | ||||
|  * @brief   Idle Loop hook. | ||||
|  * @details This hook is continuously invoked by the idle thread loop. | ||||
|  */ | ||||
| #define CH_CFG_IDLE_LOOP_HOOK() {                                           \ | ||||
|   /* Idle loop code here.*/                                                 \ | ||||
| } | ||||
|  | ||||
| /** | ||||
|  * @brief   System tick event hook. | ||||
|  * @details This hook is invoked in the system tick handler immediately | ||||
|  *          after processing the virtual timers queue. | ||||
|  */ | ||||
| #define CH_CFG_SYSTEM_TICK_HOOK() {                                         \ | ||||
|   /* System tick event code here.*/                                         \ | ||||
| } | ||||
|  | ||||
| /** | ||||
|  * @brief   System halt hook. | ||||
|  * @details This hook is invoked in case to a system halting error before | ||||
|  *          the system is halted. | ||||
|  */ | ||||
| #define CH_CFG_SYSTEM_HALT_HOOK(reason) {                                   \ | ||||
|   /* System halt code here.*/                                               \ | ||||
| } | ||||
|  | ||||
| /** | ||||
|  * @brief   Trace hook. | ||||
|  * @details This hook is invoked each time a new record is written in the | ||||
|  *          trace buffer. | ||||
|  */ | ||||
| #define CH_CFG_TRACE_HOOK(tep) {                                            \ | ||||
|   /* Trace code here.*/                                                     \ | ||||
| } | ||||
|  | ||||
| /** @} */ | ||||
|  | ||||
| /*===========================================================================*/ | ||||
| /* Port-specific settings (override port settings defaulted in chcore.h).    */ | ||||
| /*===========================================================================*/ | ||||
|  | ||||
| #endif  /* CHCONF_H */ | ||||
|  | ||||
| /** @} */ | ||||
							
								
								
									
										154
									
								
								keyboards/muon_light/config.h
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										154
									
								
								keyboards/muon_light/config.h
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,154 @@ | ||||
| /* | ||||
| Copyright 2012 Jun Wako <wakojun@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 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/>. | ||||
| */ | ||||
|  | ||||
| #ifndef CONFIG_H | ||||
| #define CONFIG_H | ||||
|  | ||||
| #include "config_common.h" | ||||
|  | ||||
| /* USB Device descriptor parameter */ | ||||
| #define VENDOR_ID       0xFEED | ||||
| #define PRODUCT_ID      0x6160 | ||||
| #define MANUFACTURER    OLKB | ||||
| #define PRODUCT         Muon Light | ||||
| #define DESCRIPTION     A compact ortholinear keyboard | ||||
| #define DEVICE_VER      0x0001 | ||||
|  | ||||
| /* key matrix size */ | ||||
| #define MATRIX_ROWS 4 | ||||
| #define MATRIX_COLS 6 | ||||
|  | ||||
| /* | ||||
|  * Keyboard Matrix Assignments | ||||
|  * | ||||
|  * Change this to how you wired your keyboard | ||||
|  * COLS: AVR pins used for columns, left to right | ||||
|  * ROWS: AVR pins used for rows, top to bottom | ||||
|  * DIODE_DIRECTION: COL2ROW = COL = Anode (+), ROW = Cathode (-, marked on diode) | ||||
|  *                  ROW2COL = ROW = Anode (+), COL = Cathode (-, marked on diode) | ||||
|  * | ||||
| */ | ||||
| #undef MATRIX_ROW_PINS | ||||
| #undef MATRIX_COL_PINS | ||||
| #define MATRIX_ROW_PINS { B5, B10, A9, A8 } | ||||
| #define MATRIX_COL_PINS { A10, B2, A15, A0, A1, A2 } | ||||
|  | ||||
| /* COL2ROW or ROW2COL */ | ||||
| #define DIODE_DIRECTION COL2ROW | ||||
|  | ||||
| #define MUSIC_MAP | ||||
|  | ||||
| #define NUMBER_OF_ENCODERS 1 | ||||
| #define ENCODERS_PAD_A { B12 } | ||||
| #define ENCODERS_PAD_B { B13 } | ||||
|  | ||||
| /* Debounce reduces chatter (unintended double-presses) - set 0 if debouncing is not needed */ | ||||
| #define DEBOUNCE 6 | ||||
|  | ||||
| /* Prevent modifiers from being stuck on after layer changes. */ | ||||
| #define PREVENT_STUCK_MODIFIERS | ||||
|  | ||||
| /* Mechanical locking support. Use KC_LCAP, KC_LNUM or KC_LSCR instead in keymap */ | ||||
| //#define LOCKING_SUPPORT_ENABLE | ||||
| /* Locking resynchronize hack */ | ||||
| //#define LOCKING_RESYNC_ENABLE | ||||
|  | ||||
| /* | ||||
|  * Force NKRO | ||||
|  * | ||||
|  * Force NKRO (nKey Rollover) to be enabled by default, regardless of the saved | ||||
|  * state in the bootmagic EEPROM settings. (Note that NKRO must be enabled in the | ||||
|  * makefile for this to work.) | ||||
|  * | ||||
|  * If forced on, NKRO can be disabled via magic key (default = LShift+RShift+N) | ||||
|  * until the next keyboard reset. | ||||
|  * | ||||
|  * NKRO may prevent your keystrokes from being detected in the BIOS, but it is | ||||
|  * fully operational during normal computer usage. | ||||
|  * | ||||
|  * For a less heavy-handed approach, enable NKRO via magic key (LShift+RShift+N) | ||||
|  * or via bootmagic (hold SPACE+N while plugging in the keyboard). Once set by | ||||
|  * bootmagic, NKRO mode will always be enabled until it is toggled again during a | ||||
|  * power-up. | ||||
|  * | ||||
|  */ | ||||
| //#define FORCE_NKRO | ||||
|  | ||||
| /* key combination for magic key command */ | ||||
| #define IS_COMMAND() ( \ | ||||
|   keyboard_report->mods == (MOD_BIT(KC_LSHIFT) | MOD_BIT(KC_RSHIFT)) \ | ||||
| ) | ||||
|  | ||||
| /* | ||||
|  * Feature disable options | ||||
|  *  These options are also useful to firmware size reduction. | ||||
|  */ | ||||
|  | ||||
| /* disable debug print */ | ||||
| //#define NO_DEBUG | ||||
|  | ||||
| /* disable print */ | ||||
| //#define NO_PRINT | ||||
|  | ||||
| /* disable action features */ | ||||
| //#define NO_ACTION_LAYER | ||||
| //#define NO_ACTION_TAPPING | ||||
| //#define NO_ACTION_ONESHOT | ||||
| //#define NO_ACTION_MACRO | ||||
| //#define NO_ACTION_FUNCTION | ||||
|  | ||||
| /* | ||||
|  * MIDI options | ||||
|  */ | ||||
|  | ||||
| /* Prevent use of disabled MIDI features in the keymap */ | ||||
| //#define MIDI_ENABLE_STRICT 1 | ||||
|  | ||||
| /* enable basic MIDI features: | ||||
|    - MIDI notes can be sent when in Music mode is on | ||||
| */ | ||||
| //#define MIDI_BASIC | ||||
|  | ||||
| /* enable advanced MIDI features: | ||||
|    - MIDI notes can be added to the keymap | ||||
|    - Octave shift and transpose | ||||
|    - Virtual sustain, portamento, and modulation wheel | ||||
|    - etc. | ||||
| */ | ||||
| //#define MIDI_ADVANCED | ||||
|  | ||||
| /* override number of MIDI tone keycodes (each octave adds 12 keycodes and allocates 12 bytes) */ | ||||
| //#define MIDI_TONE_KEYCODE_OCTAVES 1 | ||||
|  | ||||
| // This is a 7-bit address, that gets left-shifted and bit 0 | ||||
| // set to 0 for write, 1 for read (as per I2C protocol) | ||||
| // The address will vary depending on your wiring: | ||||
| // 0b1110100 AD <-> GND | ||||
| // 0b1110111 AD <-> VCC | ||||
| // 0b1110101 AD <-> SCL | ||||
| // 0b1110110 AD <-> SDA | ||||
| #define DRIVER_ADDR_1 0b1110100 | ||||
| #define DRIVER_ADDR_2 0b1110110 | ||||
|  | ||||
| #define DRIVER_COUNT 2 | ||||
| #define DRIVER_1_LED_TOTAL 25 | ||||
| #define DRIVER_2_LED_TOTAL 24 | ||||
| #define DRIVER_LED_TOTAL DRIVER_1_LED_TOTAL + DRIVER_2_LED_TOTAL | ||||
|  | ||||
| #define NO_USB_STARTUP_CHECK | ||||
|  | ||||
| #endif | ||||
							
								
								
									
										395
									
								
								keyboards/muon_light/halconf.h
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										395
									
								
								keyboards/muon_light/halconf.h
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,395 @@ | ||||
| /* | ||||
|     ChibiOS - Copyright (C) 2006..2016 Giovanni Di Sirio | ||||
|  | ||||
|     Licensed under the Apache License, Version 2.0 (the "License"); | ||||
|     you may not use this file except in compliance with the License. | ||||
|     You may obtain a copy of the License at | ||||
|  | ||||
|         http://www.apache.org/licenses/LICENSE-2.0 | ||||
|  | ||||
|     Unless required by applicable law or agreed to in writing, software | ||||
|     distributed under the License is distributed on an "AS IS" BASIS, | ||||
|     WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. | ||||
|     See the License for the specific language governing permissions and | ||||
|     limitations under the License. | ||||
| */ | ||||
|  | ||||
| /** | ||||
|  * @file    templates/halconf.h | ||||
|  * @brief   HAL configuration header. | ||||
|  * @details HAL configuration file, this file allows to enable or disable the | ||||
|  *          various device drivers from your application. You may also use | ||||
|  *          this file in order to override the device drivers default settings. | ||||
|  * | ||||
|  * @addtogroup HAL_CONF | ||||
|  * @{ | ||||
|  */ | ||||
|  | ||||
| #ifndef HALCONF_H | ||||
| #define HALCONF_H | ||||
|  | ||||
| #include "mcuconf.h" | ||||
|  | ||||
| /** | ||||
|  * @brief   Enables the PAL subsystem. | ||||
|  */ | ||||
| #if !defined(HAL_USE_PAL) || defined(__DOXYGEN__) | ||||
| #define HAL_USE_PAL                 TRUE | ||||
| #endif | ||||
|  | ||||
| /** | ||||
|  * @brief   Enables the ADC subsystem. | ||||
|  */ | ||||
| #if !defined(HAL_USE_ADC) || defined(__DOXYGEN__) | ||||
| #define HAL_USE_ADC                 FALSE | ||||
| #endif | ||||
|  | ||||
| /** | ||||
|  * @brief   Enables the CAN subsystem. | ||||
|  */ | ||||
| #if !defined(HAL_USE_CAN) || defined(__DOXYGEN__) | ||||
| #define HAL_USE_CAN                 FALSE | ||||
| #endif | ||||
|  | ||||
| /** | ||||
|  * @brief   Enables the DAC subsystem. | ||||
|  */ | ||||
| #if !defined(HAL_USE_DAC) || defined(__DOXYGEN__) | ||||
| #define HAL_USE_DAC                 TRUE | ||||
| #endif | ||||
|  | ||||
| /** | ||||
|  * @brief   Enables the EXT subsystem. | ||||
|  */ | ||||
| #if !defined(HAL_USE_EXT) || defined(__DOXYGEN__) | ||||
| #define HAL_USE_EXT                 FALSE | ||||
| #endif | ||||
|  | ||||
| /** | ||||
|  * @brief   Enables the GPT subsystem. | ||||
|  */ | ||||
| #if !defined(HAL_USE_GPT) || defined(__DOXYGEN__) | ||||
| #define HAL_USE_GPT                 TRUE | ||||
| #endif | ||||
|  | ||||
| /** | ||||
|  * @brief   Enables the I2C subsystem. | ||||
|  */ | ||||
| #if !defined(HAL_USE_I2C) || defined(__DOXYGEN__) | ||||
| #define HAL_USE_I2C                 TRUE | ||||
| #endif | ||||
|  | ||||
| /** | ||||
|  * @brief   Enables the I2C Slave subsystem. | ||||
|  */ | ||||
| #if !defined(HAL_USE_I2C_SLAVE) || defined(__DOXYGEN__) | ||||
| #define HAL_USE_I2C_SLAVE           TRUE | ||||
| #endif | ||||
|  | ||||
| /** | ||||
|  * @brief   Enables the I2S subsystem. | ||||
|  */ | ||||
| #if !defined(HAL_USE_I2S) || defined(__DOXYGEN__) | ||||
| #define HAL_USE_I2S                 FALSE | ||||
| #endif | ||||
|  | ||||
| /** | ||||
|  * @brief   Enables the ICU subsystem. | ||||
|  */ | ||||
| #if !defined(HAL_USE_ICU) || defined(__DOXYGEN__) | ||||
| #define HAL_USE_ICU                 FALSE | ||||
| #endif | ||||
|  | ||||
| /** | ||||
|  * @brief   Enables the MAC subsystem. | ||||
|  */ | ||||
| #if !defined(HAL_USE_MAC) || defined(__DOXYGEN__) | ||||
| #define HAL_USE_MAC                 FALSE | ||||
| #endif | ||||
|  | ||||
| /** | ||||
|  * @brief   Enables the MMC_SPI subsystem. | ||||
|  */ | ||||
| #if !defined(HAL_USE_MMC_SPI) || defined(__DOXYGEN__) | ||||
| #define HAL_USE_MMC_SPI             FALSE | ||||
| #endif | ||||
|  | ||||
| /** | ||||
|  * @brief   Enables the PWM subsystem. | ||||
|  */ | ||||
| #if !defined(HAL_USE_PWM) || defined(__DOXYGEN__) | ||||
| #define HAL_USE_PWM                 FALSE | ||||
| #endif | ||||
|  | ||||
| /** | ||||
|  * @brief   Enables the QSPI subsystem. | ||||
|  */ | ||||
| #if !defined(HAL_USE_QSPI) || defined(__DOXYGEN__) | ||||
| #define HAL_USE_QSPI                FALSE | ||||
| #endif | ||||
|  | ||||
| /** | ||||
|  * @brief   Enables the RTC subsystem. | ||||
|  */ | ||||
| #if !defined(HAL_USE_RTC) || defined(__DOXYGEN__) | ||||
| #define HAL_USE_RTC                 FALSE | ||||
| #endif | ||||
|  | ||||
| /** | ||||
|  * @brief   Enables the SDC subsystem. | ||||
|  */ | ||||
| #if !defined(HAL_USE_SDC) || defined(__DOXYGEN__) | ||||
| #define HAL_USE_SDC                 FALSE | ||||
| #endif | ||||
|  | ||||
| /** | ||||
|  * @brief   Enables the SERIAL subsystem. | ||||
|  */ | ||||
| #if !defined(HAL_USE_SERIAL) || defined(__DOXYGEN__) | ||||
| #define HAL_USE_SERIAL              FALSE | ||||
| #endif | ||||
|  | ||||
| /** | ||||
|  * @brief   Enables the SERIAL over USB subsystem. | ||||
|  */ | ||||
| #if !defined(HAL_USE_SERIAL_USB) || defined(__DOXYGEN__) | ||||
| #define HAL_USE_SERIAL_USB          TRUE | ||||
| #endif | ||||
|  | ||||
| /** | ||||
|  * @brief   Enables the SPI subsystem. | ||||
|  */ | ||||
| #if !defined(HAL_USE_SPI) || defined(__DOXYGEN__) | ||||
| #define HAL_USE_SPI                 FALSE | ||||
| #endif | ||||
|  | ||||
| /** | ||||
|  * @brief   Enables the UART subsystem. | ||||
|  */ | ||||
| #if !defined(HAL_USE_UART) || defined(__DOXYGEN__) | ||||
| #define HAL_USE_UART                FALSE | ||||
| #endif | ||||
|  | ||||
| /** | ||||
|  * @brief   Enables the USB subsystem. | ||||
|  */ | ||||
| #if !defined(HAL_USE_USB) || defined(__DOXYGEN__) | ||||
| #define HAL_USE_USB                 TRUE | ||||
| #endif | ||||
|  | ||||
| /** | ||||
|  * @brief   Enables the WDG subsystem. | ||||
|  */ | ||||
| #if !defined(HAL_USE_WDG) || defined(__DOXYGEN__) | ||||
| #define HAL_USE_WDG                 FALSE | ||||
| #endif | ||||
|  | ||||
| /*===========================================================================*/ | ||||
| /* ADC driver related settings.                                              */ | ||||
| /*===========================================================================*/ | ||||
|  | ||||
| /** | ||||
|  * @brief   Enables synchronous APIs. | ||||
|  * @note    Disabling this option saves both code and data space. | ||||
|  */ | ||||
| #if !defined(ADC_USE_WAIT) || defined(__DOXYGEN__) | ||||
| #define ADC_USE_WAIT                TRUE | ||||
| #endif | ||||
|  | ||||
| /** | ||||
|  * @brief   Enables the @p adcAcquireBus() and @p adcReleaseBus() APIs. | ||||
|  * @note    Disabling this option saves both code and data space. | ||||
|  */ | ||||
| #if !defined(ADC_USE_MUTUAL_EXCLUSION) || defined(__DOXYGEN__) | ||||
| #define ADC_USE_MUTUAL_EXCLUSION    TRUE | ||||
| #endif | ||||
|  | ||||
| /*===========================================================================*/ | ||||
| /* CAN driver related settings.                                              */ | ||||
| /*===========================================================================*/ | ||||
|  | ||||
| /** | ||||
|  * @brief   Sleep mode related APIs inclusion switch. | ||||
|  */ | ||||
| #if !defined(CAN_USE_SLEEP_MODE) || defined(__DOXYGEN__) | ||||
| #define CAN_USE_SLEEP_MODE          TRUE | ||||
| #endif | ||||
|  | ||||
| /*===========================================================================*/ | ||||
| /* I2C driver related settings.                                              */ | ||||
| /*===========================================================================*/ | ||||
|  | ||||
| /** | ||||
|  * @brief   Enables the mutual exclusion APIs on the I2C bus. | ||||
|  */ | ||||
| #if !defined(I2C_USE_MUTUAL_EXCLUSION) || defined(__DOXYGEN__) | ||||
| #define I2C_USE_MUTUAL_EXCLUSION    TRUE | ||||
| #endif | ||||
|  | ||||
| /*===========================================================================*/ | ||||
| /* MAC driver related settings.                                              */ | ||||
| /*===========================================================================*/ | ||||
|  | ||||
| /** | ||||
|  * @brief   Enables an event sources for incoming packets. | ||||
|  */ | ||||
| #if !defined(MAC_USE_ZERO_COPY) || defined(__DOXYGEN__) | ||||
| #define MAC_USE_ZERO_COPY           FALSE | ||||
| #endif | ||||
|  | ||||
| /** | ||||
|  * @brief   Enables an event sources for incoming packets. | ||||
|  */ | ||||
| #if !defined(MAC_USE_EVENTS) || defined(__DOXYGEN__) | ||||
| #define MAC_USE_EVENTS              TRUE | ||||
| #endif | ||||
|  | ||||
| /*===========================================================================*/ | ||||
| /* MMC_SPI driver related settings.                                          */ | ||||
| /*===========================================================================*/ | ||||
|  | ||||
| /** | ||||
|  * @brief   Delays insertions. | ||||
|  * @details If enabled this options inserts delays into the MMC waiting | ||||
|  *          routines releasing some extra CPU time for the threads with | ||||
|  *          lower priority, this may slow down the driver a bit however. | ||||
|  *          This option is recommended also if the SPI driver does not | ||||
|  *          use a DMA channel and heavily loads the CPU. | ||||
|  */ | ||||
| #if !defined(MMC_NICE_WAITING) || defined(__DOXYGEN__) | ||||
| #define MMC_NICE_WAITING            TRUE | ||||
| #endif | ||||
|  | ||||
| /*===========================================================================*/ | ||||
| /* SDC driver related settings.                                              */ | ||||
| /*===========================================================================*/ | ||||
|  | ||||
| /** | ||||
|  * @brief   Number of initialization attempts before rejecting the card. | ||||
|  * @note    Attempts are performed at 10mS intervals. | ||||
|  */ | ||||
| #if !defined(SDC_INIT_RETRY) || defined(__DOXYGEN__) | ||||
| #define SDC_INIT_RETRY              100 | ||||
| #endif | ||||
|  | ||||
| /** | ||||
|  * @brief   Include support for MMC cards. | ||||
|  * @note    MMC support is not yet implemented so this option must be kept | ||||
|  *          at @p FALSE. | ||||
|  */ | ||||
| #if !defined(SDC_MMC_SUPPORT) || defined(__DOXYGEN__) | ||||
| #define SDC_MMC_SUPPORT             FALSE | ||||
| #endif | ||||
|  | ||||
| /** | ||||
|  * @brief   Delays insertions. | ||||
|  * @details If enabled this options inserts delays into the MMC waiting | ||||
|  *          routines releasing some extra CPU time for the threads with | ||||
|  *          lower priority, this may slow down the driver a bit however. | ||||
|  */ | ||||
| #if !defined(SDC_NICE_WAITING) || defined(__DOXYGEN__) | ||||
| #define SDC_NICE_WAITING            TRUE | ||||
| #endif | ||||
|  | ||||
| /*===========================================================================*/ | ||||
| /* SERIAL driver related settings.                                           */ | ||||
| /*===========================================================================*/ | ||||
|  | ||||
| /** | ||||
|  * @brief   Default bit rate. | ||||
|  * @details Configuration parameter, this is the baud rate selected for the | ||||
|  *          default configuration. | ||||
|  */ | ||||
| #if !defined(SERIAL_DEFAULT_BITRATE) || defined(__DOXYGEN__) | ||||
| #define SERIAL_DEFAULT_BITRATE      38400 | ||||
| #endif | ||||
|  | ||||
| /** | ||||
|  * @brief   Serial buffers size. | ||||
|  * @details Configuration parameter, you can change the depth of the queue | ||||
|  *          buffers depending on the requirements of your application. | ||||
|  * @note    The default is 16 bytes for both the transmission and receive | ||||
|  *          buffers. | ||||
|  */ | ||||
| #if !defined(SERIAL_BUFFERS_SIZE) || defined(__DOXYGEN__) | ||||
| #define SERIAL_BUFFERS_SIZE         16 | ||||
| #endif | ||||
|  | ||||
| /*===========================================================================*/ | ||||
| /* SERIAL_USB driver related setting.                                        */ | ||||
| /*===========================================================================*/ | ||||
|  | ||||
| /** | ||||
|  * @brief   Serial over USB buffers size. | ||||
|  * @details Configuration parameter, the buffer size must be a multiple of | ||||
|  *          the USB data endpoint maximum packet size. | ||||
|  * @note    The default is 256 bytes for both the transmission and receive | ||||
|  *          buffers. | ||||
|  */ | ||||
| #if !defined(SERIAL_USB_BUFFERS_SIZE) || defined(__DOXYGEN__) | ||||
| #define SERIAL_USB_BUFFERS_SIZE     1 | ||||
| #endif | ||||
|  | ||||
| /** | ||||
|  * @brief   Serial over USB number of buffers. | ||||
|  * @note    The default is 2 buffers. | ||||
|  */ | ||||
| #if !defined(SERIAL_USB_BUFFERS_NUMBER) || defined(__DOXYGEN__) | ||||
| #define SERIAL_USB_BUFFERS_NUMBER   2 | ||||
| #endif | ||||
|  | ||||
| /*===========================================================================*/ | ||||
| /* SPI driver related settings.                                              */ | ||||
| /*===========================================================================*/ | ||||
|  | ||||
| /** | ||||
|  * @brief   Enables synchronous APIs. | ||||
|  * @note    Disabling this option saves both code and data space. | ||||
|  */ | ||||
| #if !defined(SPI_USE_WAIT) || defined(__DOXYGEN__) | ||||
| #define SPI_USE_WAIT                TRUE | ||||
| #endif | ||||
|  | ||||
| /** | ||||
|  * @brief   Enables the @p spiAcquireBus() and @p spiReleaseBus() APIs. | ||||
|  * @note    Disabling this option saves both code and data space. | ||||
|  */ | ||||
| #if !defined(SPI_USE_MUTUAL_EXCLUSION) || defined(__DOXYGEN__) | ||||
| #define SPI_USE_MUTUAL_EXCLUSION    TRUE | ||||
| #endif | ||||
|  | ||||
| /*===========================================================================*/ | ||||
| /* UART driver related settings.                                             */ | ||||
| /*===========================================================================*/ | ||||
|  | ||||
| /** | ||||
|  * @brief   Enables synchronous APIs. | ||||
|  * @note    Disabling this option saves both code and data space. | ||||
|  */ | ||||
| #if !defined(UART_USE_WAIT) || defined(__DOXYGEN__) | ||||
| #define UART_USE_WAIT               FALSE | ||||
| #endif | ||||
|  | ||||
| /** | ||||
|  * @brief   Enables the @p uartAcquireBus() and @p uartReleaseBus() APIs. | ||||
|  * @note    Disabling this option saves both code and data space. | ||||
|  */ | ||||
| #if !defined(UART_USE_MUTUAL_EXCLUSION) || defined(__DOXYGEN__) | ||||
| #define UART_USE_MUTUAL_EXCLUSION   FALSE | ||||
| #endif | ||||
|  | ||||
| /*===========================================================================*/ | ||||
| /* USB driver related settings.                                              */ | ||||
| /*===========================================================================*/ | ||||
|  | ||||
| /** | ||||
|  * @brief   Enables synchronous APIs. | ||||
|  * @note    Disabling this option saves both code and data space. | ||||
|  */ | ||||
| #if !defined(USB_USE_WAIT) || defined(__DOXYGEN__) | ||||
| #define USB_USE_WAIT                TRUE | ||||
| #endif | ||||
|  | ||||
| #endif /* HALCONF_H */ | ||||
|  | ||||
| /** @} */ | ||||
							
								
								
									
										38
									
								
								keyboards/muon_light/info.json
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										38
									
								
								keyboards/muon_light/info.json
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,38 @@ | ||||
| { | ||||
|   "keyboard_name": "Muon Light", | ||||
|   "keyboard_folder": "muon_light", | ||||
|   "url": "https://olkb.com/muon_light", | ||||
|   "maintainer": "jackhumbert", | ||||
|   "width": 6, | ||||
|   "height": 4, | ||||
|   "layouts": { | ||||
|     "LAYOUT_4x6_ortho": { | ||||
|       "key_count": 24, | ||||
|       "layout": [ | ||||
|         { "w": 1, "x": 0, "y": 0 }, | ||||
|         { "w": 1, "x": 1, "y": 0 }, | ||||
|         { "w": 1, "x": 2, "y": 0 }, | ||||
|         { "w": 1, "x": 3, "y": 0 }, | ||||
|         { "w": 1, "x": 4, "y": 0 }, | ||||
|         { "w": 1, "x": 5, "y": 0 }, | ||||
|         { "w": 1, "x": 0, "y": 1 }, | ||||
|         { "w": 1, "x": 1, "y": 1 }, | ||||
|         { "w": 1, "x": 2, "y": 1 }, | ||||
|         { "w": 1, "x": 3, "y": 1 }, | ||||
|         { "w": 1, "x": 4, "y": 1 }, | ||||
|         { "w": 1, "x": 5, "y": 1 }, | ||||
|         { "w": 1, "x": 0, "y": 2 }, | ||||
|         { "w": 1, "x": 1, "y": 2 }, | ||||
|         { "w": 1, "x": 2, "y": 2 }, | ||||
|         { "w": 1, "x": 3, "y": 2 }, | ||||
|         { "w": 1, "x": 4, "y": 2 }, | ||||
|         { "w": 1, "x": 5, "y": 2 }, | ||||
|         { "w": 1, "x": 0, "y": 3 }, | ||||
|         { "w": 1, "x": 1, "y": 3 }, | ||||
|         { "w": 1, "x": 2, "y": 3 }, | ||||
|         { "w": 1, "x": 3, "y": 3 }, | ||||
|         { "w": 1, "x": 4, "y": 3 }, | ||||
|         { "w": 1, "x": 5, "y": 3 } ] | ||||
|     } | ||||
|   } | ||||
| } | ||||
							
								
								
									
										43
									
								
								keyboards/muon_light/keymaps/default/config.h
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										43
									
								
								keyboards/muon_light/keymaps/default/config.h
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,43 @@ | ||||
| #ifndef CONFIG_USER_H | ||||
| #define CONFIG_USER_H | ||||
|  | ||||
| #include "config_common.h" | ||||
|  | ||||
| #ifdef AUDIO_ENABLE | ||||
|     #define STARTUP_SONG SONG(PLANCK_SOUND) | ||||
|     // #define STARTUP_SONG SONG(NO_SOUND) | ||||
|  | ||||
|     #define DEFAULT_LAYER_SONGS { SONG(QWERTY_SOUND), \ | ||||
|                                   SONG(COLEMAK_SOUND), \ | ||||
|                                   SONG(DVORAK_SOUND) \ | ||||
|                                 } | ||||
| #endif | ||||
|  | ||||
| /* | ||||
|  * MIDI options | ||||
|  */ | ||||
|  | ||||
| /* Prevent use of disabled MIDI features in the keymap */ | ||||
| //#define MIDI_ENABLE_STRICT 1 | ||||
|  | ||||
| /* enable basic MIDI features: | ||||
|    - MIDI notes can be sent when in Music mode is on | ||||
| */ | ||||
|  | ||||
| #define MIDI_BASIC | ||||
|  | ||||
| /* enable advanced MIDI features: | ||||
|    - MIDI notes can be added to the keymap | ||||
|    - Octave shift and transpose | ||||
|    - Virtual sustain, portamento, and modulation wheel | ||||
|    - etc. | ||||
| */ | ||||
| //#define MIDI_ADVANCED | ||||
|  | ||||
| /* override number of MIDI tone keycodes (each octave adds 12 keycodes and allocates 12 bytes) */ | ||||
| //#define MIDI_TONE_KEYCODE_OCTAVES 2 | ||||
|  | ||||
| // Most tactile encoders have detents every 4 stages | ||||
| #define ENCODER_RESOLUTION 4 | ||||
|  | ||||
| #endif | ||||
							
								
								
									
										309
									
								
								keyboards/muon_light/keymaps/default/keymap.c
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										309
									
								
								keyboards/muon_light/keymaps/default/keymap.c
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,309 @@ | ||||
| /* Copyright 2015-2018 Jack Humbert | ||||
|  * | ||||
|  * 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/>. | ||||
|  */ | ||||
|  | ||||
| #include "muon_light.h" | ||||
| #include "action_layer.h" | ||||
|  | ||||
| extern keymap_config_t keymap_config; | ||||
|  | ||||
| enum planck_layers { | ||||
|   _QWERTY, | ||||
|   _COLEMAK, | ||||
|   _DVORAK, | ||||
|   _LOWER, | ||||
|   _RAISE, | ||||
|   _PLOVER, | ||||
|   _ADJUST | ||||
| }; | ||||
|  | ||||
| enum planck_keycodes { | ||||
|   QWERTY = SAFE_RANGE, | ||||
|   COLEMAK, | ||||
|   DVORAK, | ||||
|   PLOVER, | ||||
|   BACKLIT, | ||||
|   EXT_PLV | ||||
| }; | ||||
|  | ||||
| #define LOWER MO(_LOWER) | ||||
| #define RAISE MO(_RAISE) | ||||
|  | ||||
| const uint16_t PROGMEM keymaps[][MATRIX_ROWS][MATRIX_COLS] = { | ||||
|  | ||||
| /* Qwerty | ||||
|  * ,-----------------------------------------------------------------------------------. | ||||
|  * | Tab  |   Q  |   W  |   E  |   R  |   T  |   Y  |   U  |   I  |   O  |   P  | Bksp | | ||||
|  * |------+------+------+------+------+-------------+------+------+------+------+------| | ||||
|  * | Esc  |   A  |   S  |   D  |   F  |   G  |   H  |   J  |   K  |   L  |   ;  |  "   | | ||||
|  * |------+------+------+------+------+------|------+------+------+------+------+------| | ||||
|  * | Shift|   Z  |   X  |   C  |   V  |   B  |   N  |   M  |   ,  |   .  |   /  |Enter | | ||||
|  * |------+------+------+------+------+------+------+------+------+------+------+------| | ||||
|  * | Brite| Ctrl | Alt  | GUI  |Lower |    Space    |Raise | Left | Down |  Up  |Right | | ||||
|  * `-----------------------------------------------------------------------------------' | ||||
|  */ | ||||
| [_QWERTY] = LAYOUT_ortho_4x6( | ||||
|   #ifdef MUON_LEFT | ||||
|     KC_TAB,  KC_Q,    KC_W,    KC_E,    KC_R,    KC_T, | ||||
|     KC_ESC,  KC_A,    KC_S,    KC_D,    KC_F,    KC_G, | ||||
|     KC_LSFT, KC_Z,    KC_X,    KC_C,    KC_V,    KC_B, | ||||
|     BACKLIT, KC_LCTL, KC_LALT, KC_LGUI, LOWER,   KC_SPC | ||||
|   #else | ||||
|     KC_Y,    KC_U,    KC_I,    KC_O,    KC_P,    KC_BSPC, | ||||
|     KC_H,    KC_J,    KC_K,    KC_L,    KC_SCLN, KC_QUOT, | ||||
|     KC_N,    KC_M,    KC_COMM, KC_DOT,  KC_SLSH, KC_ENT, | ||||
|     KC_SPC,  RAISE,   KC_LEFT, KC_DOWN, KC_UP,   KC_RGHT | ||||
|   #endif | ||||
| ), | ||||
|  | ||||
| /* Colemak | ||||
|  * ,-----------------------------------------------------------------------------------. | ||||
|  * | Tab  |   Q  |   W  |   F  |   P  |   G  |   J  |   L  |   U  |   Y  |   ;  | Bksp | | ||||
|  * |------+------+------+------+------+-------------+------+------+------+------+------| | ||||
|  * | Esc  |   A  |   R  |   S  |   T  |   D  |   H  |   N  |   E  |   I  |   O  |  "   | | ||||
|  * |------+------+------+------+------+------|------+------+------+------+------+------| | ||||
|  * | Shift|   Z  |   X  |   C  |   V  |   B  |   K  |   M  |   ,  |   .  |   /  |Enter | | ||||
|  * |------+------+------+------+------+------+------+------+------+------+------+------| | ||||
|  * | Brite| Ctrl | Alt  | GUI  |Lower |    Space    |Raise | Left | Down |  Up  |Right | | ||||
|  * `-----------------------------------------------------------------------------------' | ||||
|  */ | ||||
| [_COLEMAK] = LAYOUT_ortho_4x6( | ||||
|   #ifdef MUON_LEFT | ||||
|     KC_TAB,  KC_Q,    KC_W,    KC_F,    KC_P,    KC_G, | ||||
|     KC_ESC,  KC_A,    KC_R,    KC_S,    KC_T,    KC_D, | ||||
|     KC_LSFT, KC_Z,    KC_X,    KC_C,    KC_V,    KC_B, | ||||
|     BACKLIT, KC_LCTL, KC_LALT, KC_LGUI, LOWER,   KC_SPC | ||||
|   #else | ||||
|     KC_J,    KC_L,    KC_U,    KC_Y,    KC_SCLN, KC_BSPC, | ||||
|     KC_H,    KC_N,    KC_E,    KC_I,    KC_O,    KC_QUOT, | ||||
|     KC_K,    KC_M,    KC_COMM, KC_DOT,  KC_SLSH, KC_ENT, | ||||
|     KC_SPC,  RAISE,   KC_LEFT, KC_DOWN, KC_UP,   KC_RGHT | ||||
|   #endif | ||||
| ), | ||||
|  | ||||
| /* Dvorak | ||||
|  * ,-----------------------------------------------------------------------------------. | ||||
|  * | Tab  |   "  |   ,  |   .  |   P  |   Y  |   F  |   G  |   C  |   R  |   L  | Bksp | | ||||
|  * |------+------+------+------+------+-------------+------+------+------+------+------| | ||||
|  * | Esc  |   A  |   O  |   E  |   U  |   I  |   D  |   H  |   T  |   N  |   S  |  /   | | ||||
|  * |------+------+------+------+------+------|------+------+------+------+------+------| | ||||
|  * | Shift|   ;  |   Q  |   J  |   K  |   X  |   B  |   M  |   W  |   V  |   Z  |Enter | | ||||
|  * |------+------+------+------+------+------+------+------+------+------+------+------| | ||||
|  * | Brite| Ctrl | Alt  | GUI  |Lower |    Space    |Raise | Left | Down |  Up  |Right | | ||||
|  * `-----------------------------------------------------------------------------------' | ||||
|  */ | ||||
| [_DVORAK] = LAYOUT_ortho_4x6( | ||||
|   #ifdef MUON_LEFT | ||||
|     KC_TAB,  KC_QUOT, KC_COMM, KC_DOT,  KC_P,    KC_Y, | ||||
|     KC_ESC,  KC_A,    KC_O,    KC_E,    KC_U,    KC_I, | ||||
|     KC_LSFT, KC_SCLN, KC_Q,    KC_J,    KC_K,    KC_X, | ||||
|     BACKLIT, KC_LCTL, KC_LALT, KC_LGUI, LOWER,   KC_SPC | ||||
|   #else | ||||
|     KC_F,    KC_G,    KC_C,    KC_R,    KC_L,    KC_BSPC, | ||||
|     KC_D,    KC_H,    KC_T,    KC_N,    KC_S,    KC_SLSH, | ||||
|     KC_B,    KC_M,    KC_W,    KC_V,    KC_Z,    KC_ENT, | ||||
|     KC_SPC,  RAISE,   KC_LEFT, KC_DOWN, KC_UP,   KC_RGHT | ||||
|   #endif | ||||
| ), | ||||
|  | ||||
| /* Lower | ||||
|  * ,-----------------------------------------------------------------------------------. | ||||
|  * |   ~  |   !  |   @  |   #  |   $  |   %  |   ^  |   &  |   *  |   (  |   )  | Bksp | | ||||
|  * |------+------+------+------+------+-------------+------+------+------+------+------| | ||||
|  * | Del  |  F1  |  F2  |  F3  |  F4  |  F5  |  F6  |   _  |   +  |   {  |   }  |  |   | | ||||
|  * |------+------+------+------+------+------|------+------+------+------+------+------| | ||||
|  * |      |  F7  |  F8  |  F9  |  F10 |  F11 |  F12 |ISO ~ |ISO | | Home | End  |      | | ||||
|  * |------+------+------+------+------+------+------+------+------+------+------+------| | ||||
|  * |      |      |      |      |      |             |      | Next | Vol- | Vol+ | Play | | ||||
|  * `-----------------------------------------------------------------------------------' | ||||
|  */ | ||||
| [_LOWER] = LAYOUT_ortho_4x6( | ||||
|   #ifdef MUON_LEFT | ||||
|     KC_TILD, KC_EXLM, KC_AT,   KC_HASH, KC_DLR,  KC_PERC, | ||||
|     KC_DEL,  KC_F1,   KC_F2,   KC_F3,   KC_F4,   KC_F5, | ||||
|     _______, KC_F7,   KC_F8,   KC_F9,   KC_F10,  KC_F11, | ||||
|     _______, _______, _______, _______, _______, _______ | ||||
|   #else | ||||
|     KC_CIRC, KC_AMPR,    KC_ASTR,    KC_LPRN, KC_RPRN, KC_BSPC, | ||||
|     KC_F6,   KC_UNDS,    KC_PLUS,    KC_LCBR, KC_RCBR, KC_PIPE, | ||||
|     KC_F12,  S(KC_NUHS), S(KC_NUBS), KC_HOME, KC_END,  _______, | ||||
|     _______, _______,    KC_MNXT,    KC_VOLD, KC_VOLU, KC_MPLY | ||||
|   #endif | ||||
| ), | ||||
|  | ||||
| /* Raise | ||||
|  * ,-----------------------------------------------------------------------------------. | ||||
|  * |   `  |   1  |   2  |   3  |   4  |   5  |   6  |   7  |   8  |   9  |   0  | Bksp | | ||||
|  * |------+------+------+------+------+-------------+------+------+------+------+------| | ||||
|  * | Del  |  F1  |  F2  |  F3  |  F4  |  F5  |  F6  |   -  |   =  |   [  |   ]  |  \   | | ||||
|  * |------+------+------+------+------+------|------+------+------+------+------+------| | ||||
|  * |      |  F7  |  F8  |  F9  |  F10 |  F11 |  F12 |ISO # |ISO / |Pg Up |Pg Dn |      | | ||||
|  * |------+------+------+------+------+------+------+------+------+------+------+------| | ||||
|  * |      |      |      |      |      |             |      | Next | Vol- | Vol+ | Play | | ||||
|  * `-----------------------------------------------------------------------------------' | ||||
|  */ | ||||
| [_RAISE] = LAYOUT_ortho_4x6( | ||||
|   #ifdef MUON_LEFT | ||||
|     KC_GRV,  KC_1,    KC_2,    KC_3,    KC_4,    KC_5, | ||||
|     KC_DEL,  KC_F1,   KC_F2,   KC_F3,   KC_F4,   KC_F5, | ||||
|     _______, KC_F7,   KC_F8,   KC_F9,   KC_F10,  KC_F11, | ||||
|     _______, _______, _______, _______, _______, _______ | ||||
|   #else | ||||
|     KC_6,    KC_7,    KC_8,    KC_9,    KC_0,    KC_BSPC, | ||||
|     KC_F6,   KC_MINS, KC_EQL,  KC_LBRC, KC_RBRC, KC_BSLS, | ||||
|     KC_F12,  KC_NUHS, KC_NUBS, KC_PGUP, KC_PGDN, _______, | ||||
|     _______, _______, KC_MNXT, KC_VOLD, KC_VOLU, KC_MPLY | ||||
|   #endif | ||||
| ), | ||||
|  | ||||
| /* Plover layer (http://opensteno.org) | ||||
|  * ,-----------------------------------------------------------------------------------. | ||||
|  * |   #  |   #  |   #  |   #  |   #  |   #  |   #  |   #  |   #  |   #  |   #  |   #  | | ||||
|  * |------+------+------+------+------+-------------+------+------+------+------+------| | ||||
|  * |      |   S  |   T  |   P  |   H  |   *  |   *  |   F  |   P  |   L  |   T  |   D  | | ||||
|  * |------+------+------+------+------+------|------+------+------+------+------+------| | ||||
|  * |      |   S  |   K  |   W  |   R  |   *  |   *  |   R  |   B  |   G  |   S  |   Z  | | ||||
|  * |------+------+------+------+------+------+------+------+------+------+------+------| | ||||
|  * | Exit |      |      |   A  |   O  |             |   E  |   U  |      |      |      | | ||||
|  * `-----------------------------------------------------------------------------------' | ||||
|  */ | ||||
|  | ||||
| [_PLOVER] = LAYOUT_ortho_4x6( | ||||
|   #ifdef MUON_LEFT | ||||
|     KC_1,    KC_1,    KC_1,    KC_1,    KC_1,    KC_1, | ||||
|     XXXXXXX, KC_Q,    KC_W,    KC_E,    KC_R,    KC_T, | ||||
|     XXXXXXX, KC_A,    KC_S,    KC_D,    KC_F,    KC_G, | ||||
|     EXT_PLV, XXXXXXX, XXXXXXX, KC_C,    KC_V,    XXXXXXX | ||||
|   #else | ||||
|     KC_1,    KC_1,    KC_1,    KC_1,    KC_1,    KC_1   , | ||||
|     KC_Y,    KC_U,    KC_I,    KC_O,    KC_P,    KC_LBRC, | ||||
|     KC_H,    KC_J,    KC_K,    KC_L,    KC_SCLN, KC_QUOT, | ||||
|     XXXXXXX, KC_N,    KC_M,    XXXXXXX, XXXXXXX, XXXXXXX | ||||
|   #endif | ||||
| ), | ||||
|  | ||||
| /* Adjust (Lower + Raise) | ||||
|  * ,-----------------------------------------------------------------------------------. | ||||
|  * |      | Reset|      |      |      |      |      |      |      |      |      |  Del | | ||||
|  * |------+------+------+------+------+-------------+------+------+------+------+------| | ||||
|  * |      |      |      |Aud on|Audoff|AGnorm|AGswap|Qwerty|Colemk|Dvorak|Plover|      | | ||||
|  * |------+------+------+------+------+------|------+------+------+------+------+------| | ||||
|  * |      |Voice-|Voice+|Mus on|Musoff|MIDIon|MIDIof|      |      |      |      |      | | ||||
|  * |------+------+------+------+------+------+------+------+------+------+------+------| | ||||
|  * |      |      |      |      |      |             |      |      |      |      |      | | ||||
|  * `-----------------------------------------------------------------------------------' | ||||
|  */ | ||||
| [_ADJUST] = LAYOUT_ortho_4x6( | ||||
|   #ifdef MUON_LEFT | ||||
|     _______, RESET,   DEBUG,    RGB_TOG, RGB_MOD, RGB_HUI, | ||||
|     _______, _______, MU_MOD,  AU_ON,   AU_OFF,  AG_NORM, | ||||
|     _______, MUV_DE,  MUV_IN,  MU_ON,   MU_OFF,  MI_ON, | ||||
|     _______, _______, _______, _______, _______, _______ | ||||
|   #else | ||||
|     RGB_HUD, RGB_SAI, RGB_SAD, RGB_VAI, RGB_VAD, KC_DEL , | ||||
|     AG_SWAP, QWERTY,  COLEMAK, DVORAK,  PLOVER,  _______, | ||||
|     MI_OFF,  TERM_ON, TERM_OFF, _______, _______, _______, | ||||
|     _______, _______, _______, _______, _______, _______ | ||||
|   #endif | ||||
| ) | ||||
|  | ||||
|  | ||||
| }; | ||||
|  | ||||
| #ifdef AUDIO_ENABLE | ||||
|   float plover_song[][2]     = SONG(PLOVER_SOUND); | ||||
|   float plover_gb_song[][2]  = SONG(PLOVER_GOODBYE_SOUND); | ||||
| #endif | ||||
|  | ||||
| uint32_t layer_state_set_user(uint32_t state) { | ||||
|   return update_tri_layer_state(state, _LOWER, _RAISE, _ADJUST); | ||||
| } | ||||
|  | ||||
| bool process_record_user(uint16_t keycode, keyrecord_t *record) { | ||||
|   switch (keycode) { | ||||
|     case QWERTY: | ||||
|       if (record->event.pressed) { | ||||
|         print("mode just switched to qwerty and this is a huge string\n"); | ||||
|         set_single_persistent_default_layer(_QWERTY); | ||||
|       } | ||||
|       return false; | ||||
|       break; | ||||
|     case COLEMAK: | ||||
|       if (record->event.pressed) { | ||||
|         set_single_persistent_default_layer(_COLEMAK); | ||||
|       } | ||||
|       return false; | ||||
|       break; | ||||
|     case DVORAK: | ||||
|       if (record->event.pressed) { | ||||
|         set_single_persistent_default_layer(_DVORAK); | ||||
|       } | ||||
|       return false; | ||||
|       break; | ||||
|     case BACKLIT: | ||||
|       if (record->event.pressed) { | ||||
|         register_code(KC_RSFT); | ||||
|         #ifdef BACKLIGHT_ENABLE | ||||
|           backlight_step(); | ||||
|         #endif | ||||
|       } else { | ||||
|         unregister_code(KC_RSFT); | ||||
|       } | ||||
|       return false; | ||||
|       break; | ||||
|     case PLOVER: | ||||
|       if (record->event.pressed) { | ||||
|         #ifdef AUDIO_ENABLE | ||||
|           stop_all_notes(); | ||||
|           PLAY_SONG(plover_song); | ||||
|         #endif | ||||
|         layer_off(_RAISE); | ||||
|         layer_off(_LOWER); | ||||
|         layer_off(_ADJUST); | ||||
|         layer_on(_PLOVER); | ||||
|         if (!eeconfig_is_enabled()) { | ||||
|             eeconfig_init(); | ||||
|         } | ||||
|         keymap_config.raw = eeconfig_read_keymap(); | ||||
|         keymap_config.nkro = 1; | ||||
|         eeconfig_update_keymap(keymap_config.raw); | ||||
|       } | ||||
|       return false; | ||||
|       break; | ||||
|     case EXT_PLV: | ||||
|       if (record->event.pressed) { | ||||
|         #ifdef AUDIO_ENABLE | ||||
|           PLAY_SONG(plover_gb_song); | ||||
|         #endif | ||||
|         layer_off(_PLOVER); | ||||
|       } | ||||
|       return false; | ||||
|       break; | ||||
|   } | ||||
|   return true; | ||||
| } | ||||
|  | ||||
| void matrix_scan_user(void) { | ||||
| } | ||||
|  | ||||
| bool music_mask_user(uint16_t keycode) { | ||||
|   switch (keycode) { | ||||
|     case RAISE: | ||||
|     case LOWER: | ||||
|       return false; | ||||
|     default: | ||||
|       return true; | ||||
|   } | ||||
| } | ||||
							
								
								
									
										2
									
								
								keyboards/muon_light/keymaps/default/readme.md
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										2
									
								
								keyboards/muon_light/keymaps/default/readme.md
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,2 @@ | ||||
| # The Default Planck Layout | ||||
|  | ||||
							
								
								
									
										0
									
								
								keyboards/muon_light/keymaps/default/rules.mk
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										0
									
								
								keyboards/muon_light/keymaps/default/rules.mk
									
									
									
									
									
										Normal file
									
								
							
							
								
								
									
										124
									
								
								keyboards/muon_light/matrix.c
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										124
									
								
								keyboards/muon_light/matrix.c
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,124 @@ | ||||
| #include <stdint.h> | ||||
| #include <stdbool.h> | ||||
| #include <string.h> | ||||
| #include "hal.h" | ||||
| #include "timer.h" | ||||
| #include "wait.h" | ||||
| #include "printf.h" | ||||
| #include "backlight.h" | ||||
| #include "matrix.h" | ||||
| #include "action.h" | ||||
| #include "keycode.h" | ||||
| #include <string.h> | ||||
| #include "quantum.h" | ||||
|  | ||||
| /* | ||||
|  *     col: { A10, B2, A15, A0, A1, A2, B0, B1, C13, A6, A7, A3 } | ||||
|  *     row: { B5, B10, A9, A8 } | ||||
|  */ | ||||
| /* matrix state(1:on, 0:off) */ | ||||
| static matrix_row_t matrix[MATRIX_ROWS]; | ||||
| static matrix_row_t matrix_debouncing[MATRIX_COLS]; | ||||
| static bool debouncing = false; | ||||
| static uint16_t debouncing_time = 0; | ||||
|  | ||||
| static LINE_TYPE matrix_col_pins[MATRIX_COLS] = MATRIX_COL_PINS; | ||||
| static LINE_TYPE matrix_row_pins[MATRIX_ROWS] = MATRIX_ROW_PINS; | ||||
|  | ||||
| __attribute__ ((weak)) | ||||
| void matrix_init_user(void) {} | ||||
|  | ||||
| __attribute__ ((weak)) | ||||
| void matrix_scan_user(void) {} | ||||
|  | ||||
| __attribute__ ((weak)) | ||||
| void matrix_init_kb(void) { | ||||
|   matrix_init_user(); | ||||
| } | ||||
|  | ||||
| __attribute__ ((weak)) | ||||
| void matrix_scan_kb(void) { | ||||
|   matrix_scan_user(); | ||||
| } | ||||
|  | ||||
| void matrix_init(void) { | ||||
|     printf("matrix init\n"); | ||||
|     //debug_matrix = true; | ||||
|  | ||||
|     // actual matrix setup | ||||
|     for (int i = 0; i < MATRIX_COLS; i++) { | ||||
|       setPadMode(matrix_col_pins[i], PAL_MODE_OUTPUT_PUSHPULL); | ||||
|     } | ||||
|  | ||||
|     for (int i = 0; i < MATRIX_ROWS; i++) { | ||||
|       setPadMode(matrix_row_pins[i], PAL_MODE_INPUT_PULLDOWN); | ||||
|     } | ||||
|  | ||||
|     memset(matrix, 0, MATRIX_ROWS * sizeof(matrix_row_t)); | ||||
|     memset(matrix_debouncing, 0, MATRIX_COLS * sizeof(matrix_row_t)); | ||||
|  | ||||
|     matrix_init_quantum(); | ||||
| } | ||||
|  | ||||
| uint8_t matrix_scan(void) { | ||||
|  | ||||
|  | ||||
|     // actual matrix | ||||
|     for (int col = 0; col < MATRIX_COLS; col++) { | ||||
|         matrix_row_t data = 0; | ||||
|  | ||||
|         setPad(matrix_col_pins[col]); | ||||
|  | ||||
|         // need wait to settle pin state | ||||
|         wait_us(20); | ||||
|  | ||||
|         for (int row = 0; row < MATRIX_ROWS; row++) { | ||||
|           data |= (readPad(matrix_row_pins[row]) << row); | ||||
|         } | ||||
|  | ||||
|         clearPad(matrix_col_pins[col]); | ||||
|  | ||||
|         if (matrix_debouncing[col] != data) { | ||||
|             matrix_debouncing[col] = data; | ||||
|             debouncing = true; | ||||
|             debouncing_time = timer_read(); | ||||
|         } | ||||
|     } | ||||
|  | ||||
|     if (debouncing && timer_elapsed(debouncing_time) > DEBOUNCE) { | ||||
|         for (int row = 0; row < MATRIX_ROWS; row++) { | ||||
|             matrix[row] = 0; | ||||
|             for (int col = 0; col < MATRIX_COLS; col++) { | ||||
|                 matrix[row] |= ((matrix_debouncing[col] & (1 << row) ? 1 : 0) << col); | ||||
|             } | ||||
|         } | ||||
|         debouncing = false; | ||||
|     } | ||||
|  | ||||
|     matrix_scan_quantum(); | ||||
|  | ||||
|     return 1; | ||||
| } | ||||
|  | ||||
| bool matrix_is_on(uint8_t row, uint8_t col) { | ||||
|     return (matrix[row] & (1<<col)); | ||||
| } | ||||
|  | ||||
| matrix_row_t matrix_get_row(uint8_t row) { | ||||
|     return matrix[row]; | ||||
| } | ||||
|  | ||||
| void matrix_print(void) { | ||||
|     printf("\nr/c 01234567\n"); | ||||
|     for (uint8_t row = 0; row < MATRIX_ROWS; row++) { | ||||
|         printf("%X0: ", row); | ||||
|         matrix_row_t data = matrix_get_row(row); | ||||
|         for (int col = 0; col < MATRIX_COLS; col++) { | ||||
|             if (data & (1<<col)) | ||||
|                 printf("1"); | ||||
|             else | ||||
|                 printf("0"); | ||||
|         } | ||||
|         printf("\n"); | ||||
|     } | ||||
| } | ||||
							
								
								
									
										257
									
								
								keyboards/muon_light/mcuconf.h
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										257
									
								
								keyboards/muon_light/mcuconf.h
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,257 @@ | ||||
| /* | ||||
|     ChibiOS - Copyright (C) 2006..2016 Giovanni Di Sirio | ||||
|  | ||||
|     Licensed under the Apache License, Version 2.0 (the "License"); | ||||
|     you may not use this file except in compliance with the License. | ||||
|     You may obtain a copy of the License at | ||||
|  | ||||
|         http://www.apache.org/licenses/LICENSE-2.0 | ||||
|  | ||||
|     Unless required by applicable law or agreed to in writing, software | ||||
|     distributed under the License is distributed on an "AS IS" BASIS, | ||||
|     WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. | ||||
|     See the License for the specific language governing permissions and | ||||
|     limitations under the License. | ||||
| */ | ||||
|  | ||||
| #ifndef MCUCONF_H | ||||
| #define MCUCONF_H | ||||
|  | ||||
| /* | ||||
|  * STM32F3xx drivers configuration. | ||||
|  * The following settings override the default settings present in | ||||
|  * the various device driver implementation headers. | ||||
|  * Note that the settings for each driver only have effect if the whole | ||||
|  * driver is enabled in halconf.h. | ||||
|  * | ||||
|  * IRQ priorities: | ||||
|  * 15...0       Lowest...Highest. | ||||
|  * | ||||
|  * DMA priorities: | ||||
|  * 0...3        Lowest...Highest. | ||||
|  */ | ||||
|  | ||||
| #define STM32F3xx_MCUCONF | ||||
|  | ||||
| /* | ||||
|  * HAL driver system settings. | ||||
|  */ | ||||
| #define STM32_NO_INIT                       FALSE | ||||
| #define STM32_PVD_ENABLE                    FALSE | ||||
| #define STM32_PLS                           STM32_PLS_LEV0 | ||||
| #define STM32_HSI_ENABLED                   TRUE | ||||
| #define STM32_LSI_ENABLED                   TRUE | ||||
| #define STM32_HSE_ENABLED                   TRUE | ||||
| #define STM32_LSE_ENABLED                   FALSE | ||||
| #define STM32_SW                            STM32_SW_PLL | ||||
| #define STM32_PLLSRC                        STM32_PLLSRC_HSE | ||||
| #define STM32_PREDIV_VALUE                  1 | ||||
| #define STM32_PLLMUL_VALUE                  9 | ||||
| #define STM32_HPRE                          STM32_HPRE_DIV1 | ||||
| #define STM32_PPRE1                         STM32_PPRE1_DIV2 | ||||
| #define STM32_PPRE2                         STM32_PPRE2_DIV2 | ||||
| #define STM32_MCOSEL                        STM32_MCOSEL_NOCLOCK | ||||
| #define STM32_ADC12PRES                     STM32_ADC12PRES_DIV1 | ||||
| #define STM32_ADC34PRES                     STM32_ADC34PRES_DIV1 | ||||
| #define STM32_USART1SW                      STM32_USART1SW_PCLK | ||||
| #define STM32_USART2SW                      STM32_USART2SW_PCLK | ||||
| #define STM32_USART3SW                      STM32_USART3SW_PCLK | ||||
| #define STM32_UART4SW                       STM32_UART4SW_PCLK | ||||
| #define STM32_UART5SW                       STM32_UART5SW_PCLK | ||||
| #define STM32_I2C1SW                        STM32_I2C1SW_SYSCLK | ||||
| #define STM32_I2C2SW                        STM32_I2C2SW_SYSCLK | ||||
| #define STM32_TIM1SW                        STM32_TIM1SW_PCLK2 | ||||
| #define STM32_TIM8SW                        STM32_TIM8SW_PCLK2 | ||||
| #define STM32_RTCSEL                        STM32_RTCSEL_LSI | ||||
| #define STM32_USB_CLOCK_REQUIRED            TRUE | ||||
| #define STM32_USBPRE                        STM32_USBPRE_DIV1P5 | ||||
|  | ||||
| #undef STM32_HSE_BYPASS | ||||
| // #error "oh no" | ||||
| // #endif | ||||
|  | ||||
| /* | ||||
|  * ADC driver system settings. | ||||
|  */ | ||||
| #define STM32_ADC_DUAL_MODE                 FALSE | ||||
| #define STM32_ADC_COMPACT_SAMPLES           FALSE | ||||
| #define STM32_ADC_USE_ADC1                  FALSE | ||||
| #define STM32_ADC_USE_ADC2                  FALSE | ||||
| #define STM32_ADC_USE_ADC3                  FALSE | ||||
| #define STM32_ADC_USE_ADC4                  FALSE | ||||
| #define STM32_ADC_ADC1_DMA_STREAM           STM32_DMA_STREAM_ID(1, 1) | ||||
| #define STM32_ADC_ADC2_DMA_STREAM           STM32_DMA_STREAM_ID(2, 1) | ||||
| #define STM32_ADC_ADC3_DMA_STREAM           STM32_DMA_STREAM_ID(2, 5) | ||||
| #define STM32_ADC_ADC4_DMA_STREAM           STM32_DMA_STREAM_ID(2, 2) | ||||
| #define STM32_ADC_ADC1_DMA_PRIORITY         2 | ||||
| #define STM32_ADC_ADC2_DMA_PRIORITY         2 | ||||
| #define STM32_ADC_ADC3_DMA_PRIORITY         2 | ||||
| #define STM32_ADC_ADC4_DMA_PRIORITY         2 | ||||
| #define STM32_ADC_ADC12_IRQ_PRIORITY        5 | ||||
| #define STM32_ADC_ADC3_IRQ_PRIORITY         5 | ||||
| #define STM32_ADC_ADC4_IRQ_PRIORITY         5 | ||||
| #define STM32_ADC_ADC1_DMA_IRQ_PRIORITY     5 | ||||
| #define STM32_ADC_ADC2_DMA_IRQ_PRIORITY     5 | ||||
| #define STM32_ADC_ADC3_DMA_IRQ_PRIORITY     5 | ||||
| #define STM32_ADC_ADC4_DMA_IRQ_PRIORITY     5 | ||||
| #define STM32_ADC_ADC12_CLOCK_MODE          ADC_CCR_CKMODE_AHB_DIV1 | ||||
| #define STM32_ADC_ADC34_CLOCK_MODE          ADC_CCR_CKMODE_AHB_DIV1 | ||||
|  | ||||
| /* | ||||
|  * CAN driver system settings. | ||||
|  */ | ||||
| #define STM32_CAN_USE_CAN1                  FALSE | ||||
| #define STM32_CAN_CAN1_IRQ_PRIORITY         11 | ||||
|  | ||||
| /* | ||||
|  * DAC driver system settings. | ||||
|  */ | ||||
| #define STM32_DAC_DUAL_MODE                 FALSE | ||||
| #define STM32_DAC_USE_DAC1_CH1              TRUE | ||||
| #define STM32_DAC_USE_DAC1_CH2              TRUE | ||||
| #define STM32_DAC_DAC1_CH1_IRQ_PRIORITY     10 | ||||
| #define STM32_DAC_DAC1_CH2_IRQ_PRIORITY     10 | ||||
| #define STM32_DAC_DAC1_CH1_DMA_PRIORITY     2 | ||||
| #define STM32_DAC_DAC1_CH2_DMA_PRIORITY     2 | ||||
|  | ||||
| /* | ||||
|  * EXT driver system settings. | ||||
|  */ | ||||
| #define STM32_EXT_EXTI0_IRQ_PRIORITY        6 | ||||
| #define STM32_EXT_EXTI1_IRQ_PRIORITY        6 | ||||
| #define STM32_EXT_EXTI2_IRQ_PRIORITY        6 | ||||
| #define STM32_EXT_EXTI3_IRQ_PRIORITY        6 | ||||
| #define STM32_EXT_EXTI4_IRQ_PRIORITY        6 | ||||
| #define STM32_EXT_EXTI5_9_IRQ_PRIORITY      6 | ||||
| #define STM32_EXT_EXTI10_15_IRQ_PRIORITY    6 | ||||
| #define STM32_EXT_EXTI16_IRQ_PRIORITY       6 | ||||
| #define STM32_EXT_EXTI17_IRQ_PRIORITY       6 | ||||
| #define STM32_EXT_EXTI18_IRQ_PRIORITY       6 | ||||
| #define STM32_EXT_EXTI19_IRQ_PRIORITY       6 | ||||
| #define STM32_EXT_EXTI20_IRQ_PRIORITY       6 | ||||
| #define STM32_EXT_EXTI21_22_29_IRQ_PRIORITY 6 | ||||
| #define STM32_EXT_EXTI30_32_IRQ_PRIORITY    6 | ||||
| #define STM32_EXT_EXTI33_IRQ_PRIORITY       6 | ||||
|  | ||||
| /* | ||||
|  * GPT driver system settings. | ||||
|  */ | ||||
| #define STM32_GPT_USE_TIM1                  FALSE | ||||
| #define STM32_GPT_USE_TIM2                  FALSE | ||||
| #define STM32_GPT_USE_TIM3                  FALSE | ||||
| #define STM32_GPT_USE_TIM4                  FALSE | ||||
| #define STM32_GPT_USE_TIM6                  TRUE | ||||
| #define STM32_GPT_USE_TIM7                  TRUE | ||||
| #define STM32_GPT_USE_TIM8                  TRUE | ||||
| #define STM32_GPT_TIM1_IRQ_PRIORITY         7 | ||||
| #define STM32_GPT_TIM2_IRQ_PRIORITY         7 | ||||
| #define STM32_GPT_TIM3_IRQ_PRIORITY         7 | ||||
| #define STM32_GPT_TIM4_IRQ_PRIORITY         7 | ||||
| #define STM32_GPT_TIM6_IRQ_PRIORITY         7 | ||||
| #define STM32_GPT_TIM7_IRQ_PRIORITY         7 | ||||
| #define STM32_GPT_TIM8_IRQ_PRIORITY         7 | ||||
|  | ||||
| /* | ||||
|  * I2C driver system settings. | ||||
|  */ | ||||
| #define STM32_I2C_USE_I2C1                  TRUE | ||||
| #define STM32_I2C_USE_I2C2                  FALSE | ||||
| #define STM32_I2C_BUSY_TIMEOUT              50 | ||||
| #define STM32_I2C_I2C1_IRQ_PRIORITY         10 | ||||
| #define STM32_I2C_I2C2_IRQ_PRIORITY         10 | ||||
| #define STM32_I2C_USE_DMA                   TRUE | ||||
| #define STM32_I2C_I2C1_DMA_PRIORITY         1 | ||||
| #define STM32_I2C_I2C2_DMA_PRIORITY         1 | ||||
| #define STM32_I2C_DMA_ERROR_HOOK(i2cp)      osalSysHalt("DMA failure") | ||||
|  | ||||
| /* | ||||
|  * ICU driver system settings. | ||||
|  */ | ||||
| #define STM32_ICU_USE_TIM1                  FALSE | ||||
| #define STM32_ICU_USE_TIM2                  FALSE | ||||
| #define STM32_ICU_USE_TIM3                  FALSE | ||||
| #define STM32_ICU_USE_TIM4                  FALSE | ||||
| #define STM32_ICU_USE_TIM8                  FALSE | ||||
| #define STM32_ICU_TIM1_IRQ_PRIORITY         7 | ||||
| #define STM32_ICU_TIM2_IRQ_PRIORITY         7 | ||||
| #define STM32_ICU_TIM3_IRQ_PRIORITY         7 | ||||
| #define STM32_ICU_TIM4_IRQ_PRIORITY         7 | ||||
| #define STM32_ICU_TIM8_IRQ_PRIORITY         7 | ||||
|  | ||||
| /* | ||||
|  * PWM driver system settings. | ||||
|  */ | ||||
| #define STM32_PWM_USE_ADVANCED              FALSE | ||||
| #define STM32_PWM_USE_TIM1                  FALSE | ||||
| #define STM32_PWM_USE_TIM2                  FALSE | ||||
| #define STM32_PWM_USE_TIM3                  FALSE | ||||
| #define STM32_PWM_USE_TIM4                  FALSE | ||||
| #define STM32_PWM_USE_TIM8                  FALSE | ||||
| #define STM32_PWM_TIM1_IRQ_PRIORITY         7 | ||||
| #define STM32_PWM_TIM2_IRQ_PRIORITY         7 | ||||
| #define STM32_PWM_TIM3_IRQ_PRIORITY         7 | ||||
| #define STM32_PWM_TIM4_IRQ_PRIORITY         7 | ||||
| #define STM32_PWM_TIM8_IRQ_PRIORITY         7 | ||||
|  | ||||
| /* | ||||
|  * SERIAL driver system settings. | ||||
|  */ | ||||
| #define STM32_SERIAL_USE_USART1             FALSE | ||||
| #define STM32_SERIAL_USE_USART2             TRUE | ||||
| #define STM32_SERIAL_USE_USART3             FALSE | ||||
| #define STM32_SERIAL_USE_UART4              FALSE | ||||
| #define STM32_SERIAL_USE_UART5              FALSE | ||||
| #define STM32_SERIAL_USART1_PRIORITY        12 | ||||
| #define STM32_SERIAL_USART2_PRIORITY        12 | ||||
| #define STM32_SERIAL_USART3_PRIORITY        12 | ||||
| #define STM32_SERIAL_UART4_PRIORITY         12 | ||||
| #define STM32_SERIAL_UART5_PRIORITY         12 | ||||
|  | ||||
| /* | ||||
|  * SPI driver system settings. | ||||
|  */ | ||||
| #define STM32_SPI_USE_SPI1                  FALSE | ||||
| #define STM32_SPI_USE_SPI2                  FALSE | ||||
| #define STM32_SPI_USE_SPI3                  FALSE | ||||
| #define STM32_SPI_SPI1_DMA_PRIORITY         1 | ||||
| #define STM32_SPI_SPI2_DMA_PRIORITY         1 | ||||
| #define STM32_SPI_SPI3_DMA_PRIORITY         1 | ||||
| #define STM32_SPI_SPI1_IRQ_PRIORITY         10 | ||||
| #define STM32_SPI_SPI2_IRQ_PRIORITY         10 | ||||
| #define STM32_SPI_SPI3_IRQ_PRIORITY         10 | ||||
| #define STM32_SPI_DMA_ERROR_HOOK(spip)      osalSysHalt("DMA failure") | ||||
|  | ||||
| /* | ||||
|  * ST driver system settings. | ||||
|  */ | ||||
| #define STM32_ST_IRQ_PRIORITY               8 | ||||
| #define STM32_ST_USE_TIMER                  2 | ||||
|  | ||||
| /* | ||||
|  * UART driver system settings. | ||||
|  */ | ||||
| #define STM32_UART_USE_USART1               FALSE | ||||
| #define STM32_UART_USE_USART2               FALSE | ||||
| #define STM32_UART_USE_USART3               FALSE | ||||
| #define STM32_UART_USART1_IRQ_PRIORITY      12 | ||||
| #define STM32_UART_USART2_IRQ_PRIORITY      12 | ||||
| #define STM32_UART_USART3_IRQ_PRIORITY      12 | ||||
| #define STM32_UART_USART1_DMA_PRIORITY      0 | ||||
| #define STM32_UART_USART2_DMA_PRIORITY      0 | ||||
| #define STM32_UART_USART3_DMA_PRIORITY      0 | ||||
| #define STM32_UART_DMA_ERROR_HOOK(uartp)    osalSysHalt("DMA failure") | ||||
|  | ||||
| /* | ||||
|  * USB driver system settings. | ||||
|  */ | ||||
| #define STM32_USB_USE_USB1                  TRUE | ||||
| #define STM32_USB_LOW_POWER_ON_SUSPEND      FALSE | ||||
| #define STM32_USB_USB1_HP_IRQ_PRIORITY      13 | ||||
| #define STM32_USB_USB1_LP_IRQ_PRIORITY      14 | ||||
|  | ||||
| /* | ||||
|  * WDG driver system settings. | ||||
|  */ | ||||
| #define STM32_WDG_USE_IWDG                  FALSE | ||||
|  | ||||
| #endif /* MCUCONF_H */ | ||||
							
								
								
									
										115
									
								
								keyboards/muon_light/muon_light.c
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										115
									
								
								keyboards/muon_light/muon_light.c
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,115 @@ | ||||
| /* Copyright 2018 Jack Humbert | ||||
|  * | ||||
|  * 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/>. | ||||
|  */ | ||||
|  | ||||
| #include "muon_light.h" | ||||
|  | ||||
| void matrix_init_kb(void) { | ||||
| 	matrix_init_user(); | ||||
| } | ||||
|  | ||||
| bool process_record_kb(uint16_t keycode, keyrecord_t *record) { | ||||
|   return process_record_user(keycode, record); | ||||
| } | ||||
|  | ||||
| void matrix_scan_kb(void) { | ||||
|   matrix_scan_user(); | ||||
| } | ||||
|  | ||||
| // void suspend_power_down_kb(void) { | ||||
| //   rgb_matrix_set_suspend_state(true); | ||||
| // } | ||||
|  | ||||
| // void suspend_wakeup_init_kb(void) { | ||||
| //   rgb_matrix_set_suspend_state(false); | ||||
| // } | ||||
|  | ||||
| const uint8_t music_map[MATRIX_ROWS][MATRIX_COLS] = LAYOUT_ortho_4x6( | ||||
|   18, 19, 20, 21, 22, 23, | ||||
|   12, 13, 14, 15, 16, 17, | ||||
|   6,  7,  8,  9,  10, 11, | ||||
|   0,  1,  2,  3,  4,  5 | ||||
| ); | ||||
|  | ||||
| // const is31_led g_is31_leds[DRIVER_LED_TOTAL] = { | ||||
| // /* Refer to IS31 manual for these locations | ||||
| //  *   driver | ||||
| //  *   |  R location | ||||
| //  *   |  |      G location | ||||
| //  *   |  |      |      B location | ||||
| //  *   |  |      |      | */ | ||||
| //     {0, C1_3,  C2_3,  C3_3}, | ||||
| //     {0, C1_4,  C2_4,  C3_4}, | ||||
| //     {0, C1_5,  C2_5,  C3_5}, | ||||
| //     {0, C1_11, C2_11, C3_11}, | ||||
| //     {0, C1_12, C2_12, C3_12}, | ||||
| //     {0, C1_13, C2_13, C3_13}, | ||||
|  | ||||
| //     {0, C1_6,  C2_6,  C3_6}, | ||||
| //     {0, C1_7,  C2_7,  C3_7}, | ||||
| //     {0, C1_8,  C2_8,  C3_8}, | ||||
| //     {0, C1_14, C2_14, C3_14}, | ||||
| //     {0, C1_15, C2_15, C3_15}, | ||||
| //     {0, C1_16, C2_16, C3_16}, | ||||
|  | ||||
| //     {0, C9_1,  C8_1,  C7_1}, | ||||
| //     {0, C9_2,  C8_2,  C7_2}, | ||||
| //     {0, C9_3,  C8_3,  C7_3}, | ||||
| //     {0, C9_9,  C8_9,  C7_9}, | ||||
| //     {0, C9_10, C8_10, C7_10}, | ||||
| //     {0, C9_11, C8_11, C7_11}, | ||||
|  | ||||
| //     {0, C9_4,  C8_4,  C7_4}, | ||||
| //     {0, C9_5,  C8_5,  C7_5}, | ||||
| //     {0, C9_6,  C8_6,  C7_6}, | ||||
| //     {0, C9_12, C8_12, C7_12}, | ||||
| //     {0, C9_13, C8_13, C7_13}, | ||||
| //     {0, C9_14, C8_14, C7_14} | ||||
| // }; | ||||
|  | ||||
| // const rgb_led g_rgb_leds[DRIVER_LED_TOTAL] = { | ||||
|  | ||||
| //     {row | col << 4} | ||||
| //       |             {x=0..224, y=0..64} | ||||
| //       |              |                 modifier | ||||
| //       |              |                 | | ||||
| //     {{0|(0<<4)},   {20.36*0, 21.33*0}, 1}, | ||||
| //     {{0|(1<<4)},   {20.36*1, 21.33*0}, 0}, | ||||
| //     {{0|(2<<4)},   {20.36*2, 21.33*0}, 0}, | ||||
| //     {{0|(3<<4)},   {20.36*3, 21.33*0}, 0}, | ||||
| //     {{0|(4<<4)},   {20.36*4, 21.33*0}, 0}, | ||||
| //     {{0|(5<<4)},   {20.36*5, 21.33*0}, 0}, | ||||
|  | ||||
| //     {{1|(0<<4)},   {20.36*0, 21.33*1}, 1}, | ||||
| //     {{1|(1<<4)},   {20.36*1, 21.33*1}, 0}, | ||||
| //     {{1|(2<<4)},   {20.36*2, 21.33*1}, 0}, | ||||
| //     {{1|(3<<4)},   {20.36*3, 21.33*1}, 0}, | ||||
| //     {{1|(4<<4)},   {20.36*4, 21.33*1}, 0}, | ||||
| //     {{1|(5<<4)},   {20.36*5, 21.33*1}, 0}, | ||||
|  | ||||
| //     {{2|(0<<4)},   {20.36*0, 21.33*2}, 1}, | ||||
| //     {{2|(1<<4)},   {20.36*1, 21.33*2}, 0}, | ||||
| //     {{2|(2<<4)},   {20.36*2, 21.33*2}, 0}, | ||||
| //     {{2|(3<<4)},   {20.36*3, 21.33*2}, 0}, | ||||
| //     {{2|(4<<4)},   {20.36*4, 21.33*2}, 0}, | ||||
| //     {{2|(5<<4)},   {20.36*5, 21.33*2}, 0}, | ||||
|  | ||||
| //     {{3|(0<<4)},   {20.36*0, 21.33*3}, 1}, | ||||
| //     {{3|(1<<4)},   {20.36*1, 21.33*3}, 1}, | ||||
| //     {{3|(2<<4)},   {20.36*2, 21.33*3}, 1}, | ||||
| //     {{3|(3<<4)},   {20.36*3, 21.33*3}, 1}, | ||||
| //     {{3|(4<<4)},   {20.36*4, 21.33*3}, 1}, | ||||
| //     {{3|(5<<4)},   {20.36*5, 21.33*3}, 0} | ||||
| // }; | ||||
							
								
								
									
										35
									
								
								keyboards/muon_light/muon_light.h
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										35
									
								
								keyboards/muon_light/muon_light.h
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,35 @@ | ||||
| /* Copyright 2018 Jack Humbert | ||||
|  * | ||||
|  * 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/>. | ||||
|  */ | ||||
|  | ||||
| #ifndef MUON_LIGHT_H | ||||
| #define MUON_LIGHT_H | ||||
|  | ||||
| #include "quantum.h" | ||||
|  | ||||
| #define LAYOUT_ortho_4x6( \ | ||||
| 	k00, k01, k02, k03, k04, k05, \ | ||||
| 	k10, k11, k12, k13, k14, k15, \ | ||||
| 	k20, k21, k22, k23, k24, k25, \ | ||||
| 	k30, k31, k32, k33, k34, k35 \ | ||||
| ) \ | ||||
| { \ | ||||
| 	{ k00, k01, k02, k03, k04, k05 }, \ | ||||
| 	{ k10, k11, k12, k13, k14, k15 }, \ | ||||
| 	{ k20, k21, k22, k23, k24, k25 }, \ | ||||
| 	{ k30, k31, k32, k33, k34, k35 } \ | ||||
| } | ||||
|  | ||||
| #endif | ||||
							
								
								
									
										16
									
								
								keyboards/muon_light/readme.md
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										16
									
								
								keyboards/muon_light/readme.md
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,16 @@ | ||||
| Planck | ||||
| === | ||||
|  | ||||
|  | ||||
|  | ||||
| A compact 40% (12x4) ortholinear keyboard kit made and sold by OLKB and Massdrop. [More info on qmk.fm](http://qmk.fm/planck/) | ||||
|  | ||||
| Keyboard Maintainer: [Jack Humbert](https://github.com/jackhumbert) | ||||
| Hardware Supported: Planck PCB rev1, rev2, rev3, rev4, Teensy 2.0 | ||||
| Hardware Availability: [OLKB.com](https://olkb.com), [Massdrop](https://www.massdrop.com/buy/planck-mechanical-keyboard?mode=guest_open) | ||||
|  | ||||
| Make example for this keyboard (after setting up your build environment): | ||||
|  | ||||
|     make planck/rev4:default | ||||
|  | ||||
| See [build environment setup](https://docs.qmk.fm/build_environment_setup.html) then the [make instructions](https://docs.qmk.fm/make_instructions.html) for more information. | ||||
							
								
								
									
										63
									
								
								keyboards/muon_light/rules.mk
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										63
									
								
								keyboards/muon_light/rules.mk
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,63 @@ | ||||
| # project specific files | ||||
| SRC = matrix.c | ||||
|  | ||||
| ## chip/board settings | ||||
| # - the next two should match the directories in | ||||
| #   <chibios>/os/hal/ports/$(MCU_FAMILY)/$(MCU_SERIES) | ||||
| MCU_FAMILY = STM32 | ||||
| MCU_SERIES = STM32F3xx | ||||
|  | ||||
| # Linker script to use | ||||
| # - it should exist either in <chibios>/os/common/ports/ARMCMx/compilers/GCC/ld/ | ||||
| #   or <this_dir>/ld/ | ||||
| MCU_LDSCRIPT = STM32F303xC | ||||
|  | ||||
| # Startup code to use | ||||
| #  - it should exist in <chibios>/os/common/startup/ARMCMx/compilers/GCC/mk/ | ||||
| MCU_STARTUP = stm32f3xx | ||||
|  | ||||
| # Board: it should exist either in <chibios>/os/hal/boards/ | ||||
| #  or <this_dir>/boards | ||||
| BOARD = GENERIC_STM32_F303XC | ||||
|  | ||||
| # Cortex version | ||||
| MCU  = cortex-m4 | ||||
|  | ||||
| # ARM version, CORTEX-M0/M1 are 6, CORTEX-M3/M4/M7 are 7 | ||||
| ARMV = 7 | ||||
|  | ||||
| USE_FPU = yes | ||||
|  | ||||
| # Vector table for application | ||||
| # 0x00000000-0x00001000 area is occupied by bootlaoder.*/ | ||||
| # The CORTEX_VTOR... is needed only for MCHCK/Infinity KB | ||||
| # OPT_DEFS = -DCORTEX_VTOR_INIT=0x08005000 | ||||
| OPT_DEFS = | ||||
|  | ||||
| # Options to pass to dfu-util when flashing | ||||
| DFU_ARGS = -d 0483:df11 -a 0 -s 0x08000000:leave | ||||
|  | ||||
| # Build Options | ||||
| #   comment out to disable the options. | ||||
| # | ||||
| BACKLIGHT_ENABLE = no | ||||
| BOOTMAGIC_ENABLE = yes  # Virtual DIP switch configuration | ||||
| ## (Note that for BOOTMAGIC on Teensy LC you have to use a custom .ld script.) | ||||
| MOUSEKEY_ENABLE = yes # Mouse keys | ||||
| EXTRAKEY_ENABLE = yes # Audio control and System control | ||||
| CONSOLE_ENABLE = yes  # Console for debug | ||||
| COMMAND_ENABLE = yes    # Commands for debug and configuration | ||||
| #SLEEP_LED_ENABLE = yes  # Breathing sleep LED during USB suspend | ||||
| NKRO_ENABLE = yes     # USB Nkey Rollover | ||||
| CUSTOM_MATRIX = yes # Custom matrix file | ||||
| AUDIO_ENABLE = yes | ||||
| # RGB_MATRIX_ENABLE = yes | ||||
| # ENCODER_ENABLE = yes | ||||
| # SERIAL_LINK_ENABLE = yes | ||||
| I2C_SLAVE_ENABLE = yes | ||||
| QWIIC_KEYBOARD_ENABLE = yes | ||||
|  | ||||
| # Do not enable SLEEP_LED_ENABLE. it uses the same timer as BACKLIGHT_ENABLE | ||||
| SLEEP_LED_ENABLE = no    # Breathing sleep LED during USB suspend | ||||
|  | ||||
| LAYOUTS = ortho_4x6 | ||||
| @@ -37,4 +37,7 @@ | ||||
| /* override number of MIDI tone keycodes (each octave adds 12 keycodes and allocates 12 bytes) */ | ||||
| //#define MIDI_TONE_KEYCODE_OCTAVES 2 | ||||
|  | ||||
| // Most tactile encoders have detents every 4 stages | ||||
| #define ENCODER_RESOLUTION 4 | ||||
|  | ||||
| #endif | ||||
|   | ||||
| @@ -16,6 +16,7 @@ | ||||
|  | ||||
| #include "planck.h" | ||||
| #include "action_layer.h" | ||||
| #include "muse.h" | ||||
|  | ||||
| extern keymap_config_t keymap_config; | ||||
|  | ||||
| @@ -54,12 +55,12 @@ const uint16_t PROGMEM keymaps[][MATRIX_ROWS][MATRIX_COLS] = { | ||||
|  * | Brite| Ctrl | Alt  | GUI  |Lower |    Space    |Raise | Left | Down |  Up  |Right | | ||||
|  * `-----------------------------------------------------------------------------------' | ||||
|  */ | ||||
| [_QWERTY] = { | ||||
|   {KC_TAB,  KC_Q,    KC_W,    KC_E,    KC_R,    KC_T,    KC_Y,    KC_U,    KC_I,    KC_O,    KC_P,    KC_BSPC}, | ||||
|   {KC_ESC,  KC_A,    KC_S,    KC_D,    KC_F,    KC_G,    KC_H,    KC_J,    KC_K,    KC_L,    KC_SCLN, KC_QUOT}, | ||||
|   {KC_LSFT, KC_Z,    KC_X,    KC_C,    KC_V,    KC_B,    KC_N,    KC_M,    KC_COMM, KC_DOT,  KC_SLSH, KC_ENT }, | ||||
|   {BACKLIT, KC_LCTL, KC_LALT, KC_LGUI, LOWER,   KC_SPC,  KC_SPC,  RAISE,   KC_LEFT, KC_DOWN, KC_UP,   KC_RGHT} | ||||
| }, | ||||
| [_QWERTY] = LAYOUT_planck_grid( | ||||
|     KC_TAB,  KC_Q,    KC_W,    KC_E,    KC_R,    KC_T,    KC_Y,    KC_U,    KC_I,    KC_O,    KC_P,    KC_BSPC, | ||||
|     KC_ESC,  KC_A,    KC_S,    KC_D,    KC_F,    KC_G,    KC_H,    KC_J,    KC_K,    KC_L,    KC_SCLN, KC_QUOT, | ||||
|     KC_LSFT, KC_Z,    KC_X,    KC_C,    KC_V,    KC_B,    KC_N,    KC_M,    KC_COMM, KC_DOT,  KC_SLSH, KC_ENT , | ||||
|     BACKLIT, KC_LCTL, KC_LALT, KC_LGUI, LOWER,   KC_SPC,  KC_SPC,  RAISE,   KC_LEFT, KC_DOWN, KC_UP,   KC_RGHT | ||||
| ), | ||||
|  | ||||
| /* Colemak | ||||
|  * ,-----------------------------------------------------------------------------------. | ||||
| @@ -72,12 +73,12 @@ const uint16_t PROGMEM keymaps[][MATRIX_ROWS][MATRIX_COLS] = { | ||||
|  * | Brite| Ctrl | Alt  | GUI  |Lower |    Space    |Raise | Left | Down |  Up  |Right | | ||||
|  * `-----------------------------------------------------------------------------------' | ||||
|  */ | ||||
| [_COLEMAK] = { | ||||
|   {KC_TAB,  KC_Q,    KC_W,    KC_F,    KC_P,    KC_G,    KC_J,    KC_L,    KC_U,    KC_Y,    KC_SCLN, KC_BSPC}, | ||||
|   {KC_ESC,  KC_A,    KC_R,    KC_S,    KC_T,    KC_D,    KC_H,    KC_N,    KC_E,    KC_I,    KC_O,    KC_QUOT}, | ||||
|   {KC_LSFT, KC_Z,    KC_X,    KC_C,    KC_V,    KC_B,    KC_K,    KC_M,    KC_COMM, KC_DOT,  KC_SLSH, KC_ENT }, | ||||
|   {BACKLIT, KC_LCTL, KC_LALT, KC_LGUI, LOWER,   KC_SPC,  KC_SPC,  RAISE,   KC_LEFT, KC_DOWN, KC_UP,   KC_RGHT} | ||||
| }, | ||||
| [_COLEMAK] = LAYOUT_planck_grid( | ||||
|     KC_TAB,  KC_Q,    KC_W,    KC_F,    KC_P,    KC_G,    KC_J,    KC_L,    KC_U,    KC_Y,    KC_SCLN, KC_BSPC, | ||||
|     KC_ESC,  KC_A,    KC_R,    KC_S,    KC_T,    KC_D,    KC_H,    KC_N,    KC_E,    KC_I,    KC_O,    KC_QUOT, | ||||
|     KC_LSFT, KC_Z,    KC_X,    KC_C,    KC_V,    KC_B,    KC_K,    KC_M,    KC_COMM, KC_DOT,  KC_SLSH, KC_ENT , | ||||
|     BACKLIT, KC_LCTL, KC_LALT, KC_LGUI, LOWER,   KC_SPC,  KC_SPC,  RAISE,   KC_LEFT, KC_DOWN, KC_UP,   KC_RGHT | ||||
| ), | ||||
|  | ||||
| /* Dvorak | ||||
|  * ,-----------------------------------------------------------------------------------. | ||||
| @@ -90,12 +91,12 @@ const uint16_t PROGMEM keymaps[][MATRIX_ROWS][MATRIX_COLS] = { | ||||
|  * | Brite| Ctrl | Alt  | GUI  |Lower |    Space    |Raise | Left | Down |  Up  |Right | | ||||
|  * `-----------------------------------------------------------------------------------' | ||||
|  */ | ||||
| [_DVORAK] = { | ||||
|   {KC_TAB,  KC_QUOT, KC_COMM, KC_DOT,  KC_P,    KC_Y,    KC_F,    KC_G,    KC_C,    KC_R,    KC_L,    KC_BSPC}, | ||||
|   {KC_ESC,  KC_A,    KC_O,    KC_E,    KC_U,    KC_I,    KC_D,    KC_H,    KC_T,    KC_N,    KC_S,    KC_SLSH}, | ||||
|   {KC_LSFT, KC_SCLN, KC_Q,    KC_J,    KC_K,    KC_X,    KC_B,    KC_M,    KC_W,    KC_V,    KC_Z,    KC_ENT }, | ||||
|   {BACKLIT, KC_LCTL, KC_LALT, KC_LGUI, LOWER,   KC_SPC,  KC_SPC,  RAISE,   KC_LEFT, KC_DOWN, KC_UP,   KC_RGHT} | ||||
| }, | ||||
| [_DVORAK] = LAYOUT_planck_grid( | ||||
|     KC_TAB,  KC_QUOT, KC_COMM, KC_DOT,  KC_P,    KC_Y,    KC_F,    KC_G,    KC_C,    KC_R,    KC_L,    KC_BSPC, | ||||
|     KC_ESC,  KC_A,    KC_O,    KC_E,    KC_U,    KC_I,    KC_D,    KC_H,    KC_T,    KC_N,    KC_S,    KC_SLSH, | ||||
|     KC_LSFT, KC_SCLN, KC_Q,    KC_J,    KC_K,    KC_X,    KC_B,    KC_M,    KC_W,    KC_V,    KC_Z,    KC_ENT , | ||||
|     BACKLIT, KC_LCTL, KC_LALT, KC_LGUI, LOWER,   KC_SPC,  KC_SPC,  RAISE,   KC_LEFT, KC_DOWN, KC_UP,   KC_RGHT | ||||
| ), | ||||
|  | ||||
| /* Lower | ||||
|  * ,-----------------------------------------------------------------------------------. | ||||
| @@ -108,12 +109,12 @@ const uint16_t PROGMEM keymaps[][MATRIX_ROWS][MATRIX_COLS] = { | ||||
|  * |      |      |      |      |      |             |      | Next | Vol- | Vol+ | Play | | ||||
|  * `-----------------------------------------------------------------------------------' | ||||
|  */ | ||||
| [_LOWER] = { | ||||
|   {KC_TILD, KC_EXLM, KC_AT,   KC_HASH, KC_DLR,  KC_PERC, KC_CIRC, KC_AMPR,    KC_ASTR,    KC_LPRN, KC_RPRN, KC_BSPC}, | ||||
|   {KC_DEL,  KC_F1,   KC_F2,   KC_F3,   KC_F4,   KC_F5,   KC_F6,   KC_UNDS,    KC_PLUS,    KC_LCBR, KC_RCBR, KC_PIPE}, | ||||
|   {_______, KC_F7,   KC_F8,   KC_F9,   KC_F10,  KC_F11,  KC_F12,  S(KC_NUHS), S(KC_NUBS), KC_HOME, KC_END,  _______}, | ||||
|   {_______, _______, _______, _______, _______, _______, _______, _______,    KC_MNXT,    KC_VOLD, KC_VOLU, KC_MPLY} | ||||
| }, | ||||
| [_LOWER] = LAYOUT_planck_grid( | ||||
|     KC_TILD, KC_EXLM, KC_AT,   KC_HASH, KC_DLR,  KC_PERC, KC_CIRC, KC_AMPR,    KC_ASTR,    KC_LPRN, KC_RPRN, KC_BSPC, | ||||
|     KC_DEL,  KC_F1,   KC_F2,   KC_F3,   KC_F4,   KC_F5,   KC_F6,   KC_UNDS,    KC_PLUS,    KC_LCBR, KC_RCBR, KC_PIPE, | ||||
|     _______, KC_F7,   KC_F8,   KC_F9,   KC_F10,  KC_F11,  KC_F12,  S(KC_NUHS), S(KC_NUBS), KC_HOME, KC_END,  _______, | ||||
|     _______, _______, _______, _______, _______, _______, _______, _______,    KC_MNXT,    KC_VOLD, KC_VOLU, KC_MPLY | ||||
| ), | ||||
|  | ||||
| /* Raise | ||||
|  * ,-----------------------------------------------------------------------------------. | ||||
| @@ -126,12 +127,12 @@ const uint16_t PROGMEM keymaps[][MATRIX_ROWS][MATRIX_COLS] = { | ||||
|  * |      |      |      |      |      |             |      | Next | Vol- | Vol+ | Play | | ||||
|  * `-----------------------------------------------------------------------------------' | ||||
|  */ | ||||
| [_RAISE] = { | ||||
|   {KC_GRV,  KC_1,    KC_2,    KC_3,    KC_4,    KC_5,    KC_6,    KC_7,    KC_8,    KC_9,    KC_0,    KC_BSPC}, | ||||
|   {KC_DEL,  KC_F1,   KC_F2,   KC_F3,   KC_F4,   KC_F5,   KC_F6,   KC_MINS, KC_EQL,  KC_LBRC, KC_RBRC, KC_BSLS}, | ||||
|   {_______, KC_F7,   KC_F8,   KC_F9,   KC_F10,  KC_F11,  KC_F12,  KC_NUHS, KC_NUBS, KC_PGUP, KC_PGDN, _______}, | ||||
|   {_______, _______, _______, _______, _______, _______, _______, _______, KC_MNXT, KC_VOLD, KC_VOLU, KC_MPLY} | ||||
| }, | ||||
| [_RAISE] = LAYOUT_planck_grid( | ||||
|     KC_GRV,  KC_1,    KC_2,    KC_3,    KC_4,    KC_5,    KC_6,    KC_7,    KC_8,    KC_9,    KC_0,    KC_BSPC, | ||||
|     KC_DEL,  KC_F1,   KC_F2,   KC_F3,   KC_F4,   KC_F5,   KC_F6,   KC_MINS, KC_EQL,  KC_LBRC, KC_RBRC, KC_BSLS, | ||||
|     _______, KC_F7,   KC_F8,   KC_F9,   KC_F10,  KC_F11,  KC_F12,  KC_NUHS, KC_NUBS, KC_PGUP, KC_PGDN, _______, | ||||
|     _______, _______, _______, _______, _______, _______, _______, _______, KC_MNXT, KC_VOLD, KC_VOLU, KC_MPLY | ||||
| ), | ||||
|  | ||||
| /* Plover layer (http://opensteno.org) | ||||
|  * ,-----------------------------------------------------------------------------------. | ||||
| @@ -145,12 +146,12 @@ const uint16_t PROGMEM keymaps[][MATRIX_ROWS][MATRIX_COLS] = { | ||||
|  * `-----------------------------------------------------------------------------------' | ||||
|  */ | ||||
|  | ||||
| [_PLOVER] = { | ||||
|   {KC_1,    KC_1,    KC_1,    KC_1,    KC_1,    KC_1,    KC_1,    KC_1,    KC_1,    KC_1,    KC_1,    KC_1   }, | ||||
|   {XXXXXXX, KC_Q,    KC_W,    KC_E,    KC_R,    KC_T,    KC_Y,    KC_U,    KC_I,    KC_O,    KC_P,    KC_LBRC}, | ||||
|   {XXXXXXX, KC_A,    KC_S,    KC_D,    KC_F,    KC_G,    KC_H,    KC_J,    KC_K,    KC_L,    KC_SCLN, KC_QUOT}, | ||||
|   {EXT_PLV, XXXXXXX, XXXXXXX, KC_C,    KC_V,    XXXXXXX, XXXXXXX, KC_N,    KC_M,    XXXXXXX, XXXXXXX, XXXXXXX} | ||||
| }, | ||||
| [_PLOVER] = LAYOUT_planck_grid( | ||||
|     KC_1,    KC_1,    KC_1,    KC_1,    KC_1,    KC_1,    KC_1,    KC_1,    KC_1,    KC_1,    KC_1,    KC_1   , | ||||
|     XXXXXXX, KC_Q,    KC_W,    KC_E,    KC_R,    KC_T,    KC_Y,    KC_U,    KC_I,    KC_O,    KC_P,    KC_LBRC, | ||||
|     XXXXXXX, KC_A,    KC_S,    KC_D,    KC_F,    KC_G,    KC_H,    KC_J,    KC_K,    KC_L,    KC_SCLN, KC_QUOT, | ||||
|     EXT_PLV, XXXXXXX, XXXXXXX, KC_C,    KC_V,    XXXXXXX, XXXXXXX, KC_N,    KC_M,    XXXXXXX, XXXXXXX, XXXXXXX | ||||
| ), | ||||
|  | ||||
| /* Adjust (Lower + Raise) | ||||
|  * ,-----------------------------------------------------------------------------------. | ||||
| @@ -163,12 +164,12 @@ const uint16_t PROGMEM keymaps[][MATRIX_ROWS][MATRIX_COLS] = { | ||||
|  * |      |      |      |      |      |             |      |      |      |      |      | | ||||
|  * `-----------------------------------------------------------------------------------' | ||||
|  */ | ||||
| [_ADJUST] = { | ||||
|   {_______, RESET,   DEBUG,    RGB_TOG, RGB_MOD, RGB_HUI, RGB_HUD, RGB_SAI, RGB_SAD, RGB_VAI, RGB_VAD, KC_DEL }, | ||||
|   {_______, _______, MU_MOD,  AU_ON,   AU_OFF,  AG_NORM, AG_SWAP, QWERTY,  COLEMAK, DVORAK,  PLOVER,  _______}, | ||||
|   {_______, MUV_DE,  MUV_IN,  MU_ON,   MU_OFF,  MI_ON,   MI_OFF,  TERM_ON, TERM_OFF, _______, _______, _______}, | ||||
|   {_______, _______, _______, _______, _______, _______, _______, _______, _______, _______, _______, _______} | ||||
| } | ||||
| [_ADJUST] = LAYOUT_planck_grid( | ||||
|     _______, RESET,   DEBUG,    RGB_TOG, RGB_MOD, RGB_HUI, RGB_HUD, RGB_SAI, RGB_SAD, RGB_VAI, RGB_VAD, KC_DEL , | ||||
|     _______, _______, MU_MOD,  AU_ON,   AU_OFF,  AG_NORM, AG_SWAP, QWERTY,  COLEMAK, DVORAK,  PLOVER,  _______, | ||||
|     _______, MUV_DE,  MUV_IN,  MU_ON,   MU_OFF,  MI_ON,   MI_OFF,  TERM_ON, TERM_OFF, _______, _______, _______, | ||||
|     _______, _______, _______, _______, _______, _______, _______, _______, _______, _______, _______, _______ | ||||
| ) | ||||
|  | ||||
|  | ||||
| }; | ||||
| @@ -209,10 +210,14 @@ bool process_record_user(uint16_t keycode, keyrecord_t *record) { | ||||
|         #ifdef BACKLIGHT_ENABLE | ||||
|           backlight_step(); | ||||
|         #endif | ||||
|         #ifdef __AVR__ | ||||
|         PORTE &= ~(1<<6); | ||||
|         #endif | ||||
|       } else { | ||||
|         unregister_code(KC_RSFT); | ||||
|         #ifdef __AVR__ | ||||
|         PORTE |= (1<<6); | ||||
|         #endif | ||||
|       } | ||||
|       return false; | ||||
|       break; | ||||
| @@ -248,6 +253,81 @@ bool process_record_user(uint16_t keycode, keyrecord_t *record) { | ||||
|   return true; | ||||
| } | ||||
|  | ||||
| bool muse_mode = false; | ||||
| uint8_t last_muse_note = 0; | ||||
| uint16_t muse_counter = 0; | ||||
| uint8_t muse_offset = 70; | ||||
| uint16_t muse_tempo = 50; | ||||
|  | ||||
| void encoder_update_user(int8_t index, bool clockwise) { | ||||
|   if (muse_mode) { | ||||
|     if (IS_LAYER_ON(_RAISE)) { | ||||
|       if (clockwise) { | ||||
|         muse_offset++; | ||||
|       } else { | ||||
|         muse_offset--; | ||||
|       } | ||||
|     } else { | ||||
|       if (clockwise) { | ||||
|         muse_tempo+=1; | ||||
|       } else { | ||||
|         muse_tempo-=1; | ||||
|       } | ||||
|     } | ||||
|   } else { | ||||
|     if (clockwise) { | ||||
|       register_code(KC_MS_WH_DOWN); | ||||
|       unregister_code(KC_MS_WH_DOWN); | ||||
|     } else { | ||||
|       register_code(KC_MS_WH_UP); | ||||
|       unregister_code(KC_MS_WH_UP); | ||||
|     } | ||||
|   } | ||||
| } | ||||
|  | ||||
| void dip_update(uint8_t index, bool active) { | ||||
|   switch (index) { | ||||
|     case 0: | ||||
|       if (active) { | ||||
|         #ifdef AUDIO_ENABLE | ||||
|           PLAY_SONG(plover_song); | ||||
|         #endif | ||||
|         layer_on(_ADJUST); | ||||
|       } else { | ||||
|         #ifdef AUDIO_ENABLE | ||||
|           PLAY_SONG(plover_gb_song); | ||||
|         #endif | ||||
|         layer_off(_ADJUST); | ||||
|       } | ||||
|       break; | ||||
|     case 1: | ||||
|       if (active) { | ||||
|         muse_mode = true; | ||||
|       } else { | ||||
|         muse_mode = false; | ||||
|         #ifdef AUDIO_ENABLE | ||||
|           stop_all_notes(); | ||||
|         #endif | ||||
|       } | ||||
|    } | ||||
| } | ||||
|  | ||||
| void matrix_scan_user(void) { | ||||
|   #ifdef AUDIO_ENABLE | ||||
|     if (muse_mode) { | ||||
|       if (muse_counter == 0) { | ||||
|         uint8_t muse_note = muse_offset + SCALE[muse_clock_pulse()]; | ||||
|         if (muse_note != last_muse_note) { | ||||
|           stop_note(compute_freq_for_midi_note(last_muse_note)); | ||||
|           play_note(compute_freq_for_midi_note(muse_note), 0xF); | ||||
|           last_muse_note = muse_note; | ||||
|         } | ||||
|       } | ||||
|       muse_counter = (muse_counter + 1) % muse_tempo; | ||||
|     } | ||||
|   #endif | ||||
| } | ||||
|  | ||||
| bool music_mask_user(uint16_t keycode) { | ||||
|   switch (keycode) { | ||||
|     case RAISE: | ||||
|   | ||||
| @@ -0,0 +1 @@ | ||||
| SRC += muse.c | ||||
|   | ||||
| @@ -140,8 +140,10 @@ const rgb_led g_rgb_leds[DRIVER_LED_TOTAL] = { | ||||
| void matrix_init_kb(void) { | ||||
|  | ||||
|     // Turn status LED on | ||||
|     #ifdef KEYBOARD_planck_light_rev1 | ||||
|     DDRD |= (1<<6); | ||||
|     PORTD |= (1<<6); | ||||
|     #endif | ||||
|  | ||||
|     matrix_init_user(); | ||||
| } | ||||
|   | ||||
| @@ -41,5 +41,8 @@ | ||||
| #define DRIVER_2_LED_TOTAL 24 | ||||
| #define DRIVER_LED_TOTAL DRIVER_1_LED_TOTAL + DRIVER_2_LED_TOTAL | ||||
| 
 | ||||
| #define NUMBER_OF_ENCODERS 1 | ||||
| #define ENCODERS_PAD_A { F6 } | ||||
| #define ENCODERS_PAD_B { F7 } | ||||
| 
 | ||||
| #endif | ||||
| @@ -1,5 +1,6 @@ | ||||
| MIDI_ENABLE = yes | ||||
| AUDIO_ENABLE = yes           # Audio output on port C6 | ||||
| RGB_MATRIX_ENABLE = yes | ||||
| ENCODER_ENABLE = yes | ||||
| 
 | ||||
| MCU = at90usb1286 | ||||
							
								
								
									
										126
									
								
								keyboards/planck/light/rev2/boards/GENERIC_STM32_F303XC/board.c
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										126
									
								
								keyboards/planck/light/rev2/boards/GENERIC_STM32_F303XC/board.c
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,126 @@ | ||||
| /* | ||||
|     ChibiOS - Copyright (C) 2006..2016 Giovanni Di Sirio | ||||
|  | ||||
|     Licensed under the Apache License, Version 2.0 (the "License"); | ||||
|     you may not use this file except in compliance with the License. | ||||
|     You may obtain a copy of the License at | ||||
|  | ||||
|         http://www.apache.org/licenses/LICENSE-2.0 | ||||
|  | ||||
|     Unless required by applicable law or agreed to in writing, software | ||||
|     distributed under the License is distributed on an "AS IS" BASIS, | ||||
|     WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. | ||||
|     See the License for the specific language governing permissions and | ||||
|     limitations under the License. | ||||
| */ | ||||
|  | ||||
| #include "hal.h" | ||||
|  | ||||
| #if HAL_USE_PAL || defined(__DOXYGEN__) | ||||
| /** | ||||
|  * @brief   PAL setup. | ||||
|  * @details Digital I/O ports static configuration as defined in @p board.h. | ||||
|  *          This variable is used by the HAL when initializing the PAL driver. | ||||
|  */ | ||||
| const PALConfig pal_default_config = { | ||||
| #if STM32_HAS_GPIOA | ||||
|   {VAL_GPIOA_MODER, VAL_GPIOA_OTYPER, VAL_GPIOA_OSPEEDR, VAL_GPIOA_PUPDR, | ||||
|    VAL_GPIOA_ODR,   VAL_GPIOA_AFRL,   VAL_GPIOA_AFRH}, | ||||
| #endif | ||||
| #if STM32_HAS_GPIOB | ||||
|   {VAL_GPIOB_MODER, VAL_GPIOB_OTYPER, VAL_GPIOB_OSPEEDR, VAL_GPIOB_PUPDR, | ||||
|    VAL_GPIOB_ODR,   VAL_GPIOB_AFRL,   VAL_GPIOB_AFRH}, | ||||
| #endif | ||||
| #if STM32_HAS_GPIOC | ||||
|   {VAL_GPIOC_MODER, VAL_GPIOC_OTYPER, VAL_GPIOC_OSPEEDR, VAL_GPIOC_PUPDR, | ||||
|    VAL_GPIOC_ODR,   VAL_GPIOC_AFRL,   VAL_GPIOC_AFRH}, | ||||
| #endif | ||||
| #if STM32_HAS_GPIOD | ||||
|   {VAL_GPIOD_MODER, VAL_GPIOD_OTYPER, VAL_GPIOD_OSPEEDR, VAL_GPIOD_PUPDR, | ||||
|    VAL_GPIOD_ODR,   VAL_GPIOD_AFRL,   VAL_GPIOD_AFRH}, | ||||
| #endif | ||||
| #if STM32_HAS_GPIOE | ||||
|   {VAL_GPIOE_MODER, VAL_GPIOE_OTYPER, VAL_GPIOE_OSPEEDR, VAL_GPIOE_PUPDR, | ||||
|    VAL_GPIOE_ODR,   VAL_GPIOE_AFRL,   VAL_GPIOE_AFRH}, | ||||
| #endif | ||||
| #if STM32_HAS_GPIOF | ||||
|   {VAL_GPIOF_MODER, VAL_GPIOF_OTYPER, VAL_GPIOF_OSPEEDR, VAL_GPIOF_PUPDR, | ||||
|    VAL_GPIOF_ODR,   VAL_GPIOF_AFRL,   VAL_GPIOF_AFRH}, | ||||
| #endif | ||||
| #if STM32_HAS_GPIOG | ||||
|   {VAL_GPIOG_MODER, VAL_GPIOG_OTYPER, VAL_GPIOG_OSPEEDR, VAL_GPIOG_PUPDR, | ||||
|    VAL_GPIOG_ODR,   VAL_GPIOG_AFRL,   VAL_GPIOG_AFRH}, | ||||
| #endif | ||||
| #if STM32_HAS_GPIOH | ||||
|   {VAL_GPIOH_MODER, VAL_GPIOH_OTYPER, VAL_GPIOH_OSPEEDR, VAL_GPIOH_PUPDR, | ||||
|    VAL_GPIOH_ODR,   VAL_GPIOH_AFRL,   VAL_GPIOH_AFRH}, | ||||
| #endif | ||||
| #if STM32_HAS_GPIOI | ||||
|   {VAL_GPIOI_MODER, VAL_GPIOI_OTYPER, VAL_GPIOI_OSPEEDR, VAL_GPIOI_PUPDR, | ||||
|    VAL_GPIOI_ODR,   VAL_GPIOI_AFRL,   VAL_GPIOI_AFRH} | ||||
| #endif | ||||
| }; | ||||
| #endif | ||||
|  | ||||
| void enter_bootloader_mode_if_requested(void); | ||||
|  | ||||
| /** | ||||
|  * @brief   Early initialization code. | ||||
|  * @details This initialization must be performed just after stack setup | ||||
|  *          and before any other initialization. | ||||
|  */ | ||||
| void __early_init(void) { | ||||
|   enter_bootloader_mode_if_requested(); | ||||
|   stm32_clock_init(); | ||||
| } | ||||
|  | ||||
| #if HAL_USE_SDC || defined(__DOXYGEN__) | ||||
| /** | ||||
|  * @brief   SDC card detection. | ||||
|  */ | ||||
| bool sdc_lld_is_card_inserted(SDCDriver *sdcp) { | ||||
|  | ||||
|   (void)sdcp; | ||||
|   /* TODO: Fill the implementation.*/ | ||||
|   return true; | ||||
| } | ||||
|  | ||||
| /** | ||||
|  * @brief   SDC card write protection detection. | ||||
|  */ | ||||
| bool sdc_lld_is_write_protected(SDCDriver *sdcp) { | ||||
|  | ||||
|   (void)sdcp; | ||||
|   /* TODO: Fill the implementation.*/ | ||||
|   return false; | ||||
| } | ||||
| #endif /* HAL_USE_SDC */ | ||||
|  | ||||
| #if HAL_USE_MMC_SPI || defined(__DOXYGEN__) | ||||
| /** | ||||
|  * @brief   MMC_SPI card detection. | ||||
|  */ | ||||
| bool mmc_lld_is_card_inserted(MMCDriver *mmcp) { | ||||
|  | ||||
|   (void)mmcp; | ||||
|   /* TODO: Fill the implementation.*/ | ||||
|   return true; | ||||
| } | ||||
|  | ||||
| /** | ||||
|  * @brief   MMC_SPI card write protection detection. | ||||
|  */ | ||||
| bool mmc_lld_is_write_protected(MMCDriver *mmcp) { | ||||
|  | ||||
|   (void)mmcp; | ||||
|   /* TODO: Fill the implementation.*/ | ||||
|   return false; | ||||
| } | ||||
| #endif | ||||
|  | ||||
| /** | ||||
|  * @brief   Board-specific initialization code. | ||||
|  * @todo    Add your board-specific code, if any. | ||||
|  */ | ||||
| void boardInit(void) { | ||||
| } | ||||
							
								
								
									
										1187
									
								
								keyboards/planck/light/rev2/boards/GENERIC_STM32_F303XC/board.h
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										1187
									
								
								keyboards/planck/light/rev2/boards/GENERIC_STM32_F303XC/board.h
									
									
									
									
									
										Normal file
									
								
							
										
											
												File diff suppressed because it is too large
												Load Diff
											
										
									
								
							| @@ -0,0 +1,5 @@ | ||||
| # List of all the board related files. | ||||
| BOARDSRC = $(BOARD_PATH)/boards/GENERIC_STM32_F303XC/board.c | ||||
|  | ||||
| # Required include directories | ||||
| BOARDINC = $(BOARD_PATH)/boards/GENERIC_STM32_F303XC | ||||
							
								
								
									
										7
									
								
								keyboards/planck/light/rev2/bootloader_defs.h
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										7
									
								
								keyboards/planck/light/rev2/bootloader_defs.h
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,7 @@ | ||||
| /* Address for jumping to bootloader on STM32 chips. */ | ||||
| /* It is chip dependent, the correct number can be looked up here: | ||||
|  * http://www.st.com/web/en/resource/technical/document/application_note/CD00167594.pdf | ||||
|  * This also requires a patch to chibios: | ||||
|  *  <tmk_dir>/tmk_core/tool/chibios/ch-bootloader-jump.patch | ||||
|  */ | ||||
| #define STM32_BOOTLOADER_ADDRESS 0x1FFFD800 | ||||
							
								
								
									
										520
									
								
								keyboards/planck/light/rev2/chconf.h
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										520
									
								
								keyboards/planck/light/rev2/chconf.h
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,520 @@ | ||||
| /* | ||||
|     ChibiOS - Copyright (C) 2006..2016 Giovanni Di Sirio | ||||
|  | ||||
|     Licensed under the Apache License, Version 2.0 (the "License"); | ||||
|     you may not use this file except in compliance with the License. | ||||
|     You may obtain a copy of the License at | ||||
|  | ||||
|         http://www.apache.org/licenses/LICENSE-2.0 | ||||
|  | ||||
|     Unless required by applicable law or agreed to in writing, software | ||||
|     distributed under the License is distributed on an "AS IS" BASIS, | ||||
|     WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. | ||||
|     See the License for the specific language governing permissions and | ||||
|     limitations under the License. | ||||
| */ | ||||
|  | ||||
| /** | ||||
|  * @file    templates/chconf.h | ||||
|  * @brief   Configuration file template. | ||||
|  * @details A copy of this file must be placed in each project directory, it | ||||
|  *          contains the application specific kernel settings. | ||||
|  * | ||||
|  * @addtogroup config | ||||
|  * @details Kernel related settings and hooks. | ||||
|  * @{ | ||||
|  */ | ||||
|  | ||||
| #ifndef CHCONF_H | ||||
| #define CHCONF_H | ||||
|  | ||||
| #define _CHIBIOS_RT_CONF_ | ||||
|  | ||||
| /*===========================================================================*/ | ||||
| /** | ||||
|  * @name System timers settings | ||||
|  * @{ | ||||
|  */ | ||||
| /*===========================================================================*/ | ||||
|  | ||||
| /** | ||||
|  * @brief   System time counter resolution. | ||||
|  * @note    Allowed values are 16 or 32 bits. | ||||
|  */ | ||||
| #define CH_CFG_ST_RESOLUTION                32 | ||||
|  | ||||
| /** | ||||
|  * @brief   System tick frequency. | ||||
|  * @details Frequency of the system timer that drives the system ticks. This | ||||
|  *          setting also defines the system tick time unit. | ||||
|  */ | ||||
| #define CH_CFG_ST_FREQUENCY                 10000 | ||||
|  | ||||
| /** | ||||
|  * @brief   Time delta constant for the tick-less mode. | ||||
|  * @note    If this value is zero then the system uses the classic | ||||
|  *          periodic tick. This value represents the minimum number | ||||
|  *          of ticks that is safe to specify in a timeout directive. | ||||
|  *          The value one is not valid, timeouts are rounded up to | ||||
|  *          this value. | ||||
|  */ | ||||
| #define CH_CFG_ST_TIMEDELTA                 2 | ||||
|  | ||||
| /** @} */ | ||||
|  | ||||
| /*===========================================================================*/ | ||||
| /** | ||||
|  * @name Kernel parameters and options | ||||
|  * @{ | ||||
|  */ | ||||
| /*===========================================================================*/ | ||||
|  | ||||
| /** | ||||
|  * @brief   Round robin interval. | ||||
|  * @details This constant is the number of system ticks allowed for the | ||||
|  *          threads before preemption occurs. Setting this value to zero | ||||
|  *          disables the preemption for threads with equal priority and the | ||||
|  *          round robin becomes cooperative. Note that higher priority | ||||
|  *          threads can still preempt, the kernel is always preemptive. | ||||
|  * @note    Disabling the round robin preemption makes the kernel more compact | ||||
|  *          and generally faster. | ||||
|  * @note    The round robin preemption is not supported in tickless mode and | ||||
|  *          must be set to zero in that case. | ||||
|  */ | ||||
| #define CH_CFG_TIME_QUANTUM                 0 | ||||
|  | ||||
| /** | ||||
|  * @brief   Managed RAM size. | ||||
|  * @details Size of the RAM area to be managed by the OS. If set to zero | ||||
|  *          then the whole available RAM is used. The core memory is made | ||||
|  *          available to the heap allocator and/or can be used directly through | ||||
|  *          the simplified core memory allocator. | ||||
|  * | ||||
|  * @note    In order to let the OS manage the whole RAM the linker script must | ||||
|  *          provide the @p __heap_base__ and @p __heap_end__ symbols. | ||||
|  * @note    Requires @p CH_CFG_USE_MEMCORE. | ||||
|  */ | ||||
| #define CH_CFG_MEMCORE_SIZE                 0 | ||||
|  | ||||
| /** | ||||
|  * @brief   Idle thread automatic spawn suppression. | ||||
|  * @details When this option is activated the function @p chSysInit() | ||||
|  *          does not spawn the idle thread. The application @p main() | ||||
|  *          function becomes the idle thread and must implement an | ||||
|  *          infinite loop. | ||||
|  */ | ||||
| #define CH_CFG_NO_IDLE_THREAD               FALSE | ||||
|  | ||||
| /** @} */ | ||||
|  | ||||
| /*===========================================================================*/ | ||||
| /** | ||||
|  * @name Performance options | ||||
|  * @{ | ||||
|  */ | ||||
| /*===========================================================================*/ | ||||
|  | ||||
| /** | ||||
|  * @brief   OS optimization. | ||||
|  * @details If enabled then time efficient rather than space efficient code | ||||
|  *          is used when two possible implementations exist. | ||||
|  * | ||||
|  * @note    This is not related to the compiler optimization options. | ||||
|  * @note    The default is @p TRUE. | ||||
|  */ | ||||
| #define CH_CFG_OPTIMIZE_SPEED               TRUE | ||||
|  | ||||
| /** @} */ | ||||
|  | ||||
| /*===========================================================================*/ | ||||
| /** | ||||
|  * @name Subsystem options | ||||
|  * @{ | ||||
|  */ | ||||
| /*===========================================================================*/ | ||||
|  | ||||
| /** | ||||
|  * @brief   Time Measurement APIs. | ||||
|  * @details If enabled then the time measurement APIs are included in | ||||
|  *          the kernel. | ||||
|  * | ||||
|  * @note    The default is @p TRUE. | ||||
|  */ | ||||
| #define CH_CFG_USE_TM                       TRUE | ||||
|  | ||||
| /** | ||||
|  * @brief   Threads registry APIs. | ||||
|  * @details If enabled then the registry APIs are included in the kernel. | ||||
|  * | ||||
|  * @note    The default is @p TRUE. | ||||
|  */ | ||||
| #define CH_CFG_USE_REGISTRY                 TRUE | ||||
|  | ||||
| /** | ||||
|  * @brief   Threads synchronization APIs. | ||||
|  * @details If enabled then the @p chThdWait() function is included in | ||||
|  *          the kernel. | ||||
|  * | ||||
|  * @note    The default is @p TRUE. | ||||
|  */ | ||||
| #define CH_CFG_USE_WAITEXIT                 TRUE | ||||
|  | ||||
| /** | ||||
|  * @brief   Semaphores APIs. | ||||
|  * @details If enabled then the Semaphores APIs are included in the kernel. | ||||
|  * | ||||
|  * @note    The default is @p TRUE. | ||||
|  */ | ||||
| #define CH_CFG_USE_SEMAPHORES               TRUE | ||||
|  | ||||
| /** | ||||
|  * @brief   Semaphores queuing mode. | ||||
|  * @details If enabled then the threads are enqueued on semaphores by | ||||
|  *          priority rather than in FIFO order. | ||||
|  * | ||||
|  * @note    The default is @p FALSE. Enable this if you have special | ||||
|  *          requirements. | ||||
|  * @note    Requires @p CH_CFG_USE_SEMAPHORES. | ||||
|  */ | ||||
| #define CH_CFG_USE_SEMAPHORES_PRIORITY      FALSE | ||||
|  | ||||
| /** | ||||
|  * @brief   Mutexes APIs. | ||||
|  * @details If enabled then the mutexes APIs are included in the kernel. | ||||
|  * | ||||
|  * @note    The default is @p TRUE. | ||||
|  */ | ||||
| #define CH_CFG_USE_MUTEXES                  TRUE | ||||
|  | ||||
| /** | ||||
|  * @brief   Enables recursive behavior on mutexes. | ||||
|  * @note    Recursive mutexes are heavier and have an increased | ||||
|  *          memory footprint. | ||||
|  * | ||||
|  * @note    The default is @p FALSE. | ||||
|  * @note    Requires @p CH_CFG_USE_MUTEXES. | ||||
|  */ | ||||
| #define CH_CFG_USE_MUTEXES_RECURSIVE        FALSE | ||||
|  | ||||
| /** | ||||
|  * @brief   Conditional Variables APIs. | ||||
|  * @details If enabled then the conditional variables APIs are included | ||||
|  *          in the kernel. | ||||
|  * | ||||
|  * @note    The default is @p TRUE. | ||||
|  * @note    Requires @p CH_CFG_USE_MUTEXES. | ||||
|  */ | ||||
| #define CH_CFG_USE_CONDVARS                 TRUE | ||||
|  | ||||
| /** | ||||
|  * @brief   Conditional Variables APIs with timeout. | ||||
|  * @details If enabled then the conditional variables APIs with timeout | ||||
|  *          specification are included in the kernel. | ||||
|  * | ||||
|  * @note    The default is @p TRUE. | ||||
|  * @note    Requires @p CH_CFG_USE_CONDVARS. | ||||
|  */ | ||||
| #define CH_CFG_USE_CONDVARS_TIMEOUT         TRUE | ||||
|  | ||||
| /** | ||||
|  * @brief   Events Flags APIs. | ||||
|  * @details If enabled then the event flags APIs are included in the kernel. | ||||
|  * | ||||
|  * @note    The default is @p TRUE. | ||||
|  */ | ||||
| #define CH_CFG_USE_EVENTS                   TRUE | ||||
|  | ||||
| /** | ||||
|  * @brief   Events Flags APIs with timeout. | ||||
|  * @details If enabled then the events APIs with timeout specification | ||||
|  *          are included in the kernel. | ||||
|  * | ||||
|  * @note    The default is @p TRUE. | ||||
|  * @note    Requires @p CH_CFG_USE_EVENTS. | ||||
|  */ | ||||
| #define CH_CFG_USE_EVENTS_TIMEOUT           TRUE | ||||
|  | ||||
| /** | ||||
|  * @brief   Synchronous Messages APIs. | ||||
|  * @details If enabled then the synchronous messages APIs are included | ||||
|  *          in the kernel. | ||||
|  * | ||||
|  * @note    The default is @p TRUE. | ||||
|  */ | ||||
| #define CH_CFG_USE_MESSAGES                 TRUE | ||||
|  | ||||
| /** | ||||
|  * @brief   Synchronous Messages queuing mode. | ||||
|  * @details If enabled then messages are served by priority rather than in | ||||
|  *          FIFO order. | ||||
|  * | ||||
|  * @note    The default is @p FALSE. Enable this if you have special | ||||
|  *          requirements. | ||||
|  * @note    Requires @p CH_CFG_USE_MESSAGES. | ||||
|  */ | ||||
| #define CH_CFG_USE_MESSAGES_PRIORITY        TRUE | ||||
|  | ||||
| /** | ||||
|  * @brief   Mailboxes APIs. | ||||
|  * @details If enabled then the asynchronous messages (mailboxes) APIs are | ||||
|  *          included in the kernel. | ||||
|  * | ||||
|  * @note    The default is @p TRUE. | ||||
|  * @note    Requires @p CH_CFG_USE_SEMAPHORES. | ||||
|  */ | ||||
| #define CH_CFG_USE_MAILBOXES                TRUE | ||||
|  | ||||
| /** | ||||
|  * @brief   Core Memory Manager APIs. | ||||
|  * @details If enabled then the core memory manager APIs are included | ||||
|  *          in the kernel. | ||||
|  * | ||||
|  * @note    The default is @p TRUE. | ||||
|  */ | ||||
| #define CH_CFG_USE_MEMCORE                  TRUE | ||||
|  | ||||
| /** | ||||
|  * @brief   Heap Allocator APIs. | ||||
|  * @details If enabled then the memory heap allocator APIs are included | ||||
|  *          in the kernel. | ||||
|  * | ||||
|  * @note    The default is @p TRUE. | ||||
|  * @note    Requires @p CH_CFG_USE_MEMCORE and either @p CH_CFG_USE_MUTEXES or | ||||
|  *          @p CH_CFG_USE_SEMAPHORES. | ||||
|  * @note    Mutexes are recommended. | ||||
|  */ | ||||
| #define CH_CFG_USE_HEAP                     TRUE | ||||
|  | ||||
| /** | ||||
|  * @brief   Memory Pools Allocator APIs. | ||||
|  * @details If enabled then the memory pools allocator APIs are included | ||||
|  *          in the kernel. | ||||
|  * | ||||
|  * @note    The default is @p TRUE. | ||||
|  */ | ||||
| #define CH_CFG_USE_MEMPOOLS                 TRUE | ||||
|  | ||||
| /** | ||||
|  * @brief   Dynamic Threads APIs. | ||||
|  * @details If enabled then the dynamic threads creation APIs are included | ||||
|  *          in the kernel. | ||||
|  * | ||||
|  * @note    The default is @p TRUE. | ||||
|  * @note    Requires @p CH_CFG_USE_WAITEXIT. | ||||
|  * @note    Requires @p CH_CFG_USE_HEAP and/or @p CH_CFG_USE_MEMPOOLS. | ||||
|  */ | ||||
| #define CH_CFG_USE_DYNAMIC                  TRUE | ||||
|  | ||||
| /** @} */ | ||||
|  | ||||
| /*===========================================================================*/ | ||||
| /** | ||||
|  * @name Debug options | ||||
|  * @{ | ||||
|  */ | ||||
| /*===========================================================================*/ | ||||
|  | ||||
| /** | ||||
|  * @brief   Debug option, kernel statistics. | ||||
|  * | ||||
|  * @note    The default is @p FALSE. | ||||
|  */ | ||||
| #define CH_DBG_STATISTICS                   FALSE | ||||
|  | ||||
| /** | ||||
|  * @brief   Debug option, system state check. | ||||
|  * @details If enabled the correct call protocol for system APIs is checked | ||||
|  *          at runtime. | ||||
|  * | ||||
|  * @note    The default is @p FALSE. | ||||
|  */ | ||||
| #define CH_DBG_SYSTEM_STATE_CHECK           FALSE | ||||
|  | ||||
| /** | ||||
|  * @brief   Debug option, parameters checks. | ||||
|  * @details If enabled then the checks on the API functions input | ||||
|  *          parameters are activated. | ||||
|  * | ||||
|  * @note    The default is @p FALSE. | ||||
|  */ | ||||
| #define CH_DBG_ENABLE_CHECKS                FALSE | ||||
|  | ||||
| /** | ||||
|  * @brief   Debug option, consistency checks. | ||||
|  * @details If enabled then all the assertions in the kernel code are | ||||
|  *          activated. This includes consistency checks inside the kernel, | ||||
|  *          runtime anomalies and port-defined checks. | ||||
|  * | ||||
|  * @note    The default is @p FALSE. | ||||
|  */ | ||||
| #define CH_DBG_ENABLE_ASSERTS               FALSE | ||||
|  | ||||
| /** | ||||
|  * @brief   Debug option, trace buffer. | ||||
|  * @details If enabled then the trace buffer is activated. | ||||
|  * | ||||
|  * @note    The default is @p CH_DBG_TRACE_MASK_DISABLED. | ||||
|  */ | ||||
| #define CH_DBG_TRACE_MASK                   CH_DBG_TRACE_MASK_DISABLED | ||||
|  | ||||
| /** | ||||
|  * @brief   Trace buffer entries. | ||||
|  * @note    The trace buffer is only allocated if @p CH_DBG_TRACE_MASK is | ||||
|  *          different from @p CH_DBG_TRACE_MASK_DISABLED. | ||||
|  */ | ||||
| #define CH_DBG_TRACE_BUFFER_SIZE            128 | ||||
|  | ||||
| /** | ||||
|  * @brief   Debug option, stack checks. | ||||
|  * @details If enabled then a runtime stack check is performed. | ||||
|  * | ||||
|  * @note    The default is @p FALSE. | ||||
|  * @note    The stack check is performed in a architecture/port dependent way. | ||||
|  *          It may not be implemented or some ports. | ||||
|  * @note    The default failure mode is to halt the system with the global | ||||
|  *          @p panic_msg variable set to @p NULL. | ||||
|  */ | ||||
| #define CH_DBG_ENABLE_STACK_CHECK           TRUE | ||||
|  | ||||
| /** | ||||
|  * @brief   Debug option, stacks initialization. | ||||
|  * @details If enabled then the threads working area is filled with a byte | ||||
|  *          value when a thread is created. This can be useful for the | ||||
|  *          runtime measurement of the used stack. | ||||
|  * | ||||
|  * @note    The default is @p FALSE. | ||||
|  */ | ||||
| #define CH_DBG_FILL_THREADS                 FALSE | ||||
|  | ||||
| /** | ||||
|  * @brief   Debug option, threads profiling. | ||||
|  * @details If enabled then a field is added to the @p thread_t structure that | ||||
|  *          counts the system ticks occurred while executing the thread. | ||||
|  * | ||||
|  * @note    The default is @p FALSE. | ||||
|  * @note    This debug option is not currently compatible with the | ||||
|  *          tickless mode. | ||||
|  */ | ||||
| #define CH_DBG_THREADS_PROFILING            FALSE | ||||
|  | ||||
| /** @} */ | ||||
|  | ||||
| /*===========================================================================*/ | ||||
| /** | ||||
|  * @name Kernel hooks | ||||
|  * @{ | ||||
|  */ | ||||
| /*===========================================================================*/ | ||||
|  | ||||
| /** | ||||
|  * @brief   Threads descriptor structure extension. | ||||
|  * @details User fields added to the end of the @p thread_t structure. | ||||
|  */ | ||||
| #define CH_CFG_THREAD_EXTRA_FIELDS                                          \ | ||||
|   /* Add threads custom fields here.*/ | ||||
|  | ||||
| /** | ||||
|  * @brief   Threads initialization hook. | ||||
|  * @details User initialization code added to the @p chThdInit() API. | ||||
|  * | ||||
|  * @note    It is invoked from within @p chThdInit() and implicitly from all | ||||
|  *          the threads creation APIs. | ||||
|  */ | ||||
| #define CH_CFG_THREAD_INIT_HOOK(tp) {                                       \ | ||||
|   /* Add threads initialization code here.*/                                \ | ||||
| } | ||||
|  | ||||
| /** | ||||
|  * @brief   Threads finalization hook. | ||||
|  * @details User finalization code added to the @p chThdExit() API. | ||||
|  */ | ||||
| #define CH_CFG_THREAD_EXIT_HOOK(tp) {                                       \ | ||||
|   /* Add threads finalization code here.*/                                  \ | ||||
| } | ||||
|  | ||||
| /** | ||||
|  * @brief   Context switch hook. | ||||
|  * @details This hook is invoked just before switching between threads. | ||||
|  */ | ||||
| #define CH_CFG_CONTEXT_SWITCH_HOOK(ntp, otp) {                              \ | ||||
|   /* Context switch code here.*/                                            \ | ||||
| } | ||||
|  | ||||
| /** | ||||
|  * @brief   ISR enter hook. | ||||
|  */ | ||||
| #define CH_CFG_IRQ_PROLOGUE_HOOK() {                                        \ | ||||
|   /* IRQ prologue code here.*/                                              \ | ||||
| } | ||||
|  | ||||
| /** | ||||
|  * @brief   ISR exit hook. | ||||
|  */ | ||||
| #define CH_CFG_IRQ_EPILOGUE_HOOK() {                                        \ | ||||
|   /* IRQ epilogue code here.*/                                              \ | ||||
| } | ||||
|  | ||||
| /** | ||||
|  * @brief   Idle thread enter hook. | ||||
|  * @note    This hook is invoked within a critical zone, no OS functions | ||||
|  *          should be invoked from here. | ||||
|  * @note    This macro can be used to activate a power saving mode. | ||||
|  */ | ||||
| #define CH_CFG_IDLE_ENTER_HOOK() {                                          \ | ||||
|   /* Idle-enter code here.*/                                                \ | ||||
| } | ||||
|  | ||||
| /** | ||||
|  * @brief   Idle thread leave hook. | ||||
|  * @note    This hook is invoked within a critical zone, no OS functions | ||||
|  *          should be invoked from here. | ||||
|  * @note    This macro can be used to deactivate a power saving mode. | ||||
|  */ | ||||
| #define CH_CFG_IDLE_LEAVE_HOOK() {                                          \ | ||||
|   /* Idle-leave code here.*/                                                \ | ||||
| } | ||||
|  | ||||
| /** | ||||
|  * @brief   Idle Loop hook. | ||||
|  * @details This hook is continuously invoked by the idle thread loop. | ||||
|  */ | ||||
| #define CH_CFG_IDLE_LOOP_HOOK() {                                           \ | ||||
|   /* Idle loop code here.*/                                                 \ | ||||
| } | ||||
|  | ||||
| /** | ||||
|  * @brief   System tick event hook. | ||||
|  * @details This hook is invoked in the system tick handler immediately | ||||
|  *          after processing the virtual timers queue. | ||||
|  */ | ||||
| #define CH_CFG_SYSTEM_TICK_HOOK() {                                         \ | ||||
|   /* System tick event code here.*/                                         \ | ||||
| } | ||||
|  | ||||
| /** | ||||
|  * @brief   System halt hook. | ||||
|  * @details This hook is invoked in case to a system halting error before | ||||
|  *          the system is halted. | ||||
|  */ | ||||
| #define CH_CFG_SYSTEM_HALT_HOOK(reason) {                                   \ | ||||
|   /* System halt code here.*/                                               \ | ||||
| } | ||||
|  | ||||
| /** | ||||
|  * @brief   Trace hook. | ||||
|  * @details This hook is invoked each time a new record is written in the | ||||
|  *          trace buffer. | ||||
|  */ | ||||
| #define CH_CFG_TRACE_HOOK(tep) {                                            \ | ||||
|   /* Trace code here.*/                                                     \ | ||||
| } | ||||
|  | ||||
| /** @} */ | ||||
|  | ||||
| /*===========================================================================*/ | ||||
| /* Port-specific settings (override port settings defaulted in chcore.h).    */ | ||||
| /*===========================================================================*/ | ||||
|  | ||||
| #endif  /* CHCONF_H */ | ||||
|  | ||||
| /** @} */ | ||||
							
								
								
									
										152
									
								
								keyboards/planck/light/rev2/config.h
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										152
									
								
								keyboards/planck/light/rev2/config.h
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,152 @@ | ||||
| /* | ||||
|  * Copyright 2018 Jack Humbert <jack.humb@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 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/>. | ||||
|  */ | ||||
|  | ||||
| #ifndef REV6_CONFIG_H | ||||
| #define REV6_CONFIG_H | ||||
|  | ||||
| #include "config_common.h" | ||||
|  | ||||
| /* USB Device descriptor parameter */ | ||||
| #undef PRODUCT | ||||
| #define PRODUCT Planck Light | ||||
| #undef PRODUCT_ID | ||||
| #define PRODUCT_ID 0x6065 | ||||
| #define DEVICE_VER 0x0002 | ||||
|  | ||||
| #undef MATRIX_ROWS | ||||
| #undef MATRIX_COLS | ||||
| /* key matrix size */ | ||||
| #define MATRIX_ROWS 4 | ||||
| #define MATRIX_COLS 12 | ||||
|  | ||||
| /* | ||||
|  * Keyboard Matrix Assignments | ||||
|  * | ||||
|  * Change this to how you wired your keyboard | ||||
|  * COLS: AVR pins used for columns, left to right | ||||
|  * ROWS: AVR pins used for rows, top to bottom | ||||
|  * DIODE_DIRECTION: COL2ROW = COL = Anode (+), ROW = Cathode (-, marked on diode) | ||||
|  *                  ROW2COL = ROW = Anode (+), COL = Cathode (-, marked on diode) | ||||
|  * | ||||
| */ | ||||
| #undef MATRIX_ROW_PINS | ||||
| #undef MATRIX_COL_PINS | ||||
| #define MATRIX_ROW_PINS { B5, B10, A9, A8 } | ||||
| #define MATRIX_COL_PINS { A10, B2, A15, A0, A1, A2, B0, B1, C13, A6, A7, A3 } | ||||
|  | ||||
| #define MUSIC_MAP | ||||
| #undef AUDIO_VOICES | ||||
| #undef C6_AUDIO | ||||
|  | ||||
| #define NUMBER_OF_ENCODERS 1 | ||||
| #define ENCODERS_PAD_A { B12 } | ||||
| #define ENCODERS_PAD_B { B13 } | ||||
|  | ||||
| /* Debounce reduces chatter (unintended double-presses) - set 0 if debouncing is not needed */ | ||||
| #define DEBOUNCE 0 | ||||
|  | ||||
| /* Prevent modifiers from being stuck on after layer changes. */ | ||||
| #define PREVENT_STUCK_MODIFIERS | ||||
|  | ||||
| /* Mechanical locking support. Use KC_LCAP, KC_LNUM or KC_LSCR instead in keymap */ | ||||
| //#define LOCKING_SUPPORT_ENABLE | ||||
| /* Locking resynchronize hack */ | ||||
| //#define LOCKING_RESYNC_ENABLE | ||||
|  | ||||
| /* | ||||
|  * Force NKRO | ||||
|  * | ||||
|  * Force NKRO (nKey Rollover) to be enabled by default, regardless of the saved | ||||
|  * state in the bootmagic EEPROM settings. (Note that NKRO must be enabled in the | ||||
|  * makefile for this to work.) | ||||
|  * | ||||
|  * If forced on, NKRO can be disabled via magic key (default = LShift+RShift+N) | ||||
|  * until the next keyboard reset. | ||||
|  * | ||||
|  * NKRO may prevent your keystrokes from being detected in the BIOS, but it is | ||||
|  * fully operational during normal computer usage. | ||||
|  * | ||||
|  * For a less heavy-handed approach, enable NKRO via magic key (LShift+RShift+N) | ||||
|  * or via bootmagic (hold SPACE+N while plugging in the keyboard). Once set by | ||||
|  * bootmagic, NKRO mode will always be enabled until it is toggled again during a | ||||
|  * power-up. | ||||
|  * | ||||
|  */ | ||||
| //#define FORCE_NKRO | ||||
|  | ||||
| /* key combination for magic key command */ | ||||
| #define IS_COMMAND() ( \ | ||||
| 	keyboard_report->mods == (MOD_BIT(KC_LSHIFT) | MOD_BIT(KC_RSHIFT)) \ | ||||
| ) | ||||
|  | ||||
| /* | ||||
|  * Feature disable options | ||||
|  *  These options are also useful to firmware size reduction. | ||||
|  */ | ||||
|  | ||||
| /* disable debug print */ | ||||
| //#define NO_DEBUG | ||||
|  | ||||
| /* disable print */ | ||||
| //#define NO_PRINT | ||||
|  | ||||
| /* disable action features */ | ||||
| //#define NO_ACTION_LAYER | ||||
| //#define NO_ACTION_TAPPING | ||||
| //#define NO_ACTION_ONESHOT | ||||
| //#define NO_ACTION_MACRO | ||||
| //#define NO_ACTION_FUNCTION | ||||
|  | ||||
| /* | ||||
|  * MIDI options | ||||
|  */ | ||||
|  | ||||
| /* Prevent use of disabled MIDI features in the keymap */ | ||||
| //#define MIDI_ENABLE_STRICT 1 | ||||
|  | ||||
| /* enable basic MIDI features: | ||||
|    - MIDI notes can be sent when in Music mode is on | ||||
| */ | ||||
| //#define MIDI_BASIC | ||||
|  | ||||
| /* enable advanced MIDI features: | ||||
|    - MIDI notes can be added to the keymap | ||||
|    - Octave shift and transpose | ||||
|    - Virtual sustain, portamento, and modulation wheel | ||||
|    - etc. | ||||
| */ | ||||
| //#define MIDI_ADVANCED | ||||
|  | ||||
| /* override number of MIDI tone keycodes (each octave adds 12 keycodes and allocates 12 bytes) */ | ||||
| //#define MIDI_TONE_KEYCODE_OCTAVES 1 | ||||
|  | ||||
| // This is a 7-bit address, that gets left-shifted and bit 0 | ||||
| // set to 0 for write, 1 for read (as per I2C protocol) | ||||
| // The address will vary depending on your wiring: | ||||
| // 0b1110100 AD <-> GND | ||||
| // 0b1110111 AD <-> VCC | ||||
| // 0b1110101 AD <-> SCL | ||||
| // 0b1110110 AD <-> SDA | ||||
| #define DRIVER_ADDR_1 0b1110100 | ||||
| #define DRIVER_ADDR_2 0b1110110 | ||||
|  | ||||
| #define DRIVER_COUNT 2 | ||||
| #define DRIVER_1_LED_TOTAL 25 | ||||
| #define DRIVER_2_LED_TOTAL 24 | ||||
| #define DRIVER_LED_TOTAL DRIVER_1_LED_TOTAL + DRIVER_2_LED_TOTAL | ||||
|  | ||||
| #endif | ||||
							
								
								
									
										388
									
								
								keyboards/planck/light/rev2/halconf.h
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										388
									
								
								keyboards/planck/light/rev2/halconf.h
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,388 @@ | ||||
| /* | ||||
|     ChibiOS - Copyright (C) 2006..2016 Giovanni Di Sirio | ||||
|  | ||||
|     Licensed under the Apache License, Version 2.0 (the "License"); | ||||
|     you may not use this file except in compliance with the License. | ||||
|     You may obtain a copy of the License at | ||||
|  | ||||
|         http://www.apache.org/licenses/LICENSE-2.0 | ||||
|  | ||||
|     Unless required by applicable law or agreed to in writing, software | ||||
|     distributed under the License is distributed on an "AS IS" BASIS, | ||||
|     WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. | ||||
|     See the License for the specific language governing permissions and | ||||
|     limitations under the License. | ||||
| */ | ||||
|  | ||||
| /** | ||||
|  * @file    templates/halconf.h | ||||
|  * @brief   HAL configuration header. | ||||
|  * @details HAL configuration file, this file allows to enable or disable the | ||||
|  *          various device drivers from your application. You may also use | ||||
|  *          this file in order to override the device drivers default settings. | ||||
|  * | ||||
|  * @addtogroup HAL_CONF | ||||
|  * @{ | ||||
|  */ | ||||
|  | ||||
| #ifndef HALCONF_H | ||||
| #define HALCONF_H | ||||
|  | ||||
| #include "mcuconf.h" | ||||
|  | ||||
| /** | ||||
|  * @brief   Enables the PAL subsystem. | ||||
|  */ | ||||
| #if !defined(HAL_USE_PAL) || defined(__DOXYGEN__) | ||||
| #define HAL_USE_PAL                 TRUE | ||||
| #endif | ||||
|  | ||||
| /** | ||||
|  * @brief   Enables the ADC subsystem. | ||||
|  */ | ||||
| #if !defined(HAL_USE_ADC) || defined(__DOXYGEN__) | ||||
| #define HAL_USE_ADC                 FALSE | ||||
| #endif | ||||
|  | ||||
| /** | ||||
|  * @brief   Enables the CAN subsystem. | ||||
|  */ | ||||
| #if !defined(HAL_USE_CAN) || defined(__DOXYGEN__) | ||||
| #define HAL_USE_CAN                 FALSE | ||||
| #endif | ||||
|  | ||||
| /** | ||||
|  * @brief   Enables the DAC subsystem. | ||||
|  */ | ||||
| #if !defined(HAL_USE_DAC) || defined(__DOXYGEN__) | ||||
| #define HAL_USE_DAC                 TRUE | ||||
| #endif | ||||
|  | ||||
| /** | ||||
|  * @brief   Enables the EXT subsystem. | ||||
|  */ | ||||
| #if !defined(HAL_USE_EXT) || defined(__DOXYGEN__) | ||||
| #define HAL_USE_EXT                 FALSE | ||||
| #endif | ||||
|  | ||||
| /** | ||||
|  * @brief   Enables the GPT subsystem. | ||||
|  */ | ||||
| #if !defined(HAL_USE_GPT) || defined(__DOXYGEN__) | ||||
| #define HAL_USE_GPT                 TRUE | ||||
| #endif | ||||
|  | ||||
| /** | ||||
|  * @brief   Enables the I2C subsystem. | ||||
|  */ | ||||
| #if !defined(HAL_USE_I2C) || defined(__DOXYGEN__) | ||||
| #define HAL_USE_I2C                 TRUE | ||||
| #endif | ||||
|  | ||||
| /** | ||||
|  * @brief   Enables the I2S subsystem. | ||||
|  */ | ||||
| #if !defined(HAL_USE_I2S) || defined(__DOXYGEN__) | ||||
| #define HAL_USE_I2S                 FALSE | ||||
| #endif | ||||
|  | ||||
| /** | ||||
|  * @brief   Enables the ICU subsystem. | ||||
|  */ | ||||
| #if !defined(HAL_USE_ICU) || defined(__DOXYGEN__) | ||||
| #define HAL_USE_ICU                 FALSE | ||||
| #endif | ||||
|  | ||||
| /** | ||||
|  * @brief   Enables the MAC subsystem. | ||||
|  */ | ||||
| #if !defined(HAL_USE_MAC) || defined(__DOXYGEN__) | ||||
| #define HAL_USE_MAC                 FALSE | ||||
| #endif | ||||
|  | ||||
| /** | ||||
|  * @brief   Enables the MMC_SPI subsystem. | ||||
|  */ | ||||
| #if !defined(HAL_USE_MMC_SPI) || defined(__DOXYGEN__) | ||||
| #define HAL_USE_MMC_SPI             FALSE | ||||
| #endif | ||||
|  | ||||
| /** | ||||
|  * @brief   Enables the PWM subsystem. | ||||
|  */ | ||||
| #if !defined(HAL_USE_PWM) || defined(__DOXYGEN__) | ||||
| #define HAL_USE_PWM                 FALSE | ||||
| #endif | ||||
|  | ||||
| /** | ||||
|  * @brief   Enables the QSPI subsystem. | ||||
|  */ | ||||
| #if !defined(HAL_USE_QSPI) || defined(__DOXYGEN__) | ||||
| #define HAL_USE_QSPI                FALSE | ||||
| #endif | ||||
|  | ||||
| /** | ||||
|  * @brief   Enables the RTC subsystem. | ||||
|  */ | ||||
| #if !defined(HAL_USE_RTC) || defined(__DOXYGEN__) | ||||
| #define HAL_USE_RTC                 FALSE | ||||
| #endif | ||||
|  | ||||
| /** | ||||
|  * @brief   Enables the SDC subsystem. | ||||
|  */ | ||||
| #if !defined(HAL_USE_SDC) || defined(__DOXYGEN__) | ||||
| #define HAL_USE_SDC                 FALSE | ||||
| #endif | ||||
|  | ||||
| /** | ||||
|  * @brief   Enables the SERIAL subsystem. | ||||
|  */ | ||||
| #if !defined(HAL_USE_SERIAL) || defined(__DOXYGEN__) | ||||
| #define HAL_USE_SERIAL              FALSE | ||||
| #endif | ||||
|  | ||||
| /** | ||||
|  * @brief   Enables the SERIAL over USB subsystem. | ||||
|  */ | ||||
| #if !defined(HAL_USE_SERIAL_USB) || defined(__DOXYGEN__) | ||||
| #define HAL_USE_SERIAL_USB          TRUE | ||||
| #endif | ||||
|  | ||||
| /** | ||||
|  * @brief   Enables the SPI subsystem. | ||||
|  */ | ||||
| #if !defined(HAL_USE_SPI) || defined(__DOXYGEN__) | ||||
| #define HAL_USE_SPI                 FALSE | ||||
| #endif | ||||
|  | ||||
| /** | ||||
|  * @brief   Enables the UART subsystem. | ||||
|  */ | ||||
| #if !defined(HAL_USE_UART) || defined(__DOXYGEN__) | ||||
| #define HAL_USE_UART                FALSE | ||||
| #endif | ||||
|  | ||||
| /** | ||||
|  * @brief   Enables the USB subsystem. | ||||
|  */ | ||||
| #if !defined(HAL_USE_USB) || defined(__DOXYGEN__) | ||||
| #define HAL_USE_USB                 TRUE | ||||
| #endif | ||||
|  | ||||
| /** | ||||
|  * @brief   Enables the WDG subsystem. | ||||
|  */ | ||||
| #if !defined(HAL_USE_WDG) || defined(__DOXYGEN__) | ||||
| #define HAL_USE_WDG                 FALSE | ||||
| #endif | ||||
|  | ||||
| /*===========================================================================*/ | ||||
| /* ADC driver related settings.                                              */ | ||||
| /*===========================================================================*/ | ||||
|  | ||||
| /** | ||||
|  * @brief   Enables synchronous APIs. | ||||
|  * @note    Disabling this option saves both code and data space. | ||||
|  */ | ||||
| #if !defined(ADC_USE_WAIT) || defined(__DOXYGEN__) | ||||
| #define ADC_USE_WAIT                TRUE | ||||
| #endif | ||||
|  | ||||
| /** | ||||
|  * @brief   Enables the @p adcAcquireBus() and @p adcReleaseBus() APIs. | ||||
|  * @note    Disabling this option saves both code and data space. | ||||
|  */ | ||||
| #if !defined(ADC_USE_MUTUAL_EXCLUSION) || defined(__DOXYGEN__) | ||||
| #define ADC_USE_MUTUAL_EXCLUSION    TRUE | ||||
| #endif | ||||
|  | ||||
| /*===========================================================================*/ | ||||
| /* CAN driver related settings.                                              */ | ||||
| /*===========================================================================*/ | ||||
|  | ||||
| /** | ||||
|  * @brief   Sleep mode related APIs inclusion switch. | ||||
|  */ | ||||
| #if !defined(CAN_USE_SLEEP_MODE) || defined(__DOXYGEN__) | ||||
| #define CAN_USE_SLEEP_MODE          TRUE | ||||
| #endif | ||||
|  | ||||
| /*===========================================================================*/ | ||||
| /* I2C driver related settings.                                              */ | ||||
| /*===========================================================================*/ | ||||
|  | ||||
| /** | ||||
|  * @brief   Enables the mutual exclusion APIs on the I2C bus. | ||||
|  */ | ||||
| #if !defined(I2C_USE_MUTUAL_EXCLUSION) || defined(__DOXYGEN__) | ||||
| #define I2C_USE_MUTUAL_EXCLUSION    TRUE | ||||
| #endif | ||||
|  | ||||
| /*===========================================================================*/ | ||||
| /* MAC driver related settings.                                              */ | ||||
| /*===========================================================================*/ | ||||
|  | ||||
| /** | ||||
|  * @brief   Enables an event sources for incoming packets. | ||||
|  */ | ||||
| #if !defined(MAC_USE_ZERO_COPY) || defined(__DOXYGEN__) | ||||
| #define MAC_USE_ZERO_COPY           FALSE | ||||
| #endif | ||||
|  | ||||
| /** | ||||
|  * @brief   Enables an event sources for incoming packets. | ||||
|  */ | ||||
| #if !defined(MAC_USE_EVENTS) || defined(__DOXYGEN__) | ||||
| #define MAC_USE_EVENTS              TRUE | ||||
| #endif | ||||
|  | ||||
| /*===========================================================================*/ | ||||
| /* MMC_SPI driver related settings.                                          */ | ||||
| /*===========================================================================*/ | ||||
|  | ||||
| /** | ||||
|  * @brief   Delays insertions. | ||||
|  * @details If enabled this options inserts delays into the MMC waiting | ||||
|  *          routines releasing some extra CPU time for the threads with | ||||
|  *          lower priority, this may slow down the driver a bit however. | ||||
|  *          This option is recommended also if the SPI driver does not | ||||
|  *          use a DMA channel and heavily loads the CPU. | ||||
|  */ | ||||
| #if !defined(MMC_NICE_WAITING) || defined(__DOXYGEN__) | ||||
| #define MMC_NICE_WAITING            TRUE | ||||
| #endif | ||||
|  | ||||
| /*===========================================================================*/ | ||||
| /* SDC driver related settings.                                              */ | ||||
| /*===========================================================================*/ | ||||
|  | ||||
| /** | ||||
|  * @brief   Number of initialization attempts before rejecting the card. | ||||
|  * @note    Attempts are performed at 10mS intervals. | ||||
|  */ | ||||
| #if !defined(SDC_INIT_RETRY) || defined(__DOXYGEN__) | ||||
| #define SDC_INIT_RETRY              100 | ||||
| #endif | ||||
|  | ||||
| /** | ||||
|  * @brief   Include support for MMC cards. | ||||
|  * @note    MMC support is not yet implemented so this option must be kept | ||||
|  *          at @p FALSE. | ||||
|  */ | ||||
| #if !defined(SDC_MMC_SUPPORT) || defined(__DOXYGEN__) | ||||
| #define SDC_MMC_SUPPORT             FALSE | ||||
| #endif | ||||
|  | ||||
| /** | ||||
|  * @brief   Delays insertions. | ||||
|  * @details If enabled this options inserts delays into the MMC waiting | ||||
|  *          routines releasing some extra CPU time for the threads with | ||||
|  *          lower priority, this may slow down the driver a bit however. | ||||
|  */ | ||||
| #if !defined(SDC_NICE_WAITING) || defined(__DOXYGEN__) | ||||
| #define SDC_NICE_WAITING            TRUE | ||||
| #endif | ||||
|  | ||||
| /*===========================================================================*/ | ||||
| /* SERIAL driver related settings.                                           */ | ||||
| /*===========================================================================*/ | ||||
|  | ||||
| /** | ||||
|  * @brief   Default bit rate. | ||||
|  * @details Configuration parameter, this is the baud rate selected for the | ||||
|  *          default configuration. | ||||
|  */ | ||||
| #if !defined(SERIAL_DEFAULT_BITRATE) || defined(__DOXYGEN__) | ||||
| #define SERIAL_DEFAULT_BITRATE      38400 | ||||
| #endif | ||||
|  | ||||
| /** | ||||
|  * @brief   Serial buffers size. | ||||
|  * @details Configuration parameter, you can change the depth of the queue | ||||
|  *          buffers depending on the requirements of your application. | ||||
|  * @note    The default is 16 bytes for both the transmission and receive | ||||
|  *          buffers. | ||||
|  */ | ||||
| #if !defined(SERIAL_BUFFERS_SIZE) || defined(__DOXYGEN__) | ||||
| #define SERIAL_BUFFERS_SIZE         16 | ||||
| #endif | ||||
|  | ||||
| /*===========================================================================*/ | ||||
| /* SERIAL_USB driver related setting.                                        */ | ||||
| /*===========================================================================*/ | ||||
|  | ||||
| /** | ||||
|  * @brief   Serial over USB buffers size. | ||||
|  * @details Configuration parameter, the buffer size must be a multiple of | ||||
|  *          the USB data endpoint maximum packet size. | ||||
|  * @note    The default is 256 bytes for both the transmission and receive | ||||
|  *          buffers. | ||||
|  */ | ||||
| #if !defined(SERIAL_USB_BUFFERS_SIZE) || defined(__DOXYGEN__) | ||||
| #define SERIAL_USB_BUFFERS_SIZE     1 | ||||
| #endif | ||||
|  | ||||
| /** | ||||
|  * @brief   Serial over USB number of buffers. | ||||
|  * @note    The default is 2 buffers. | ||||
|  */ | ||||
| #if !defined(SERIAL_USB_BUFFERS_NUMBER) || defined(__DOXYGEN__) | ||||
| #define SERIAL_USB_BUFFERS_NUMBER   2 | ||||
| #endif | ||||
|  | ||||
| /*===========================================================================*/ | ||||
| /* SPI driver related settings.                                              */ | ||||
| /*===========================================================================*/ | ||||
|  | ||||
| /** | ||||
|  * @brief   Enables synchronous APIs. | ||||
|  * @note    Disabling this option saves both code and data space. | ||||
|  */ | ||||
| #if !defined(SPI_USE_WAIT) || defined(__DOXYGEN__) | ||||
| #define SPI_USE_WAIT                TRUE | ||||
| #endif | ||||
|  | ||||
| /** | ||||
|  * @brief   Enables the @p spiAcquireBus() and @p spiReleaseBus() APIs. | ||||
|  * @note    Disabling this option saves both code and data space. | ||||
|  */ | ||||
| #if !defined(SPI_USE_MUTUAL_EXCLUSION) || defined(__DOXYGEN__) | ||||
| #define SPI_USE_MUTUAL_EXCLUSION    TRUE | ||||
| #endif | ||||
|  | ||||
| /*===========================================================================*/ | ||||
| /* UART driver related settings.                                             */ | ||||
| /*===========================================================================*/ | ||||
|  | ||||
| /** | ||||
|  * @brief   Enables synchronous APIs. | ||||
|  * @note    Disabling this option saves both code and data space. | ||||
|  */ | ||||
| #if !defined(UART_USE_WAIT) || defined(__DOXYGEN__) | ||||
| #define UART_USE_WAIT               FALSE | ||||
| #endif | ||||
|  | ||||
| /** | ||||
|  * @brief   Enables the @p uartAcquireBus() and @p uartReleaseBus() APIs. | ||||
|  * @note    Disabling this option saves both code and data space. | ||||
|  */ | ||||
| #if !defined(UART_USE_MUTUAL_EXCLUSION) || defined(__DOXYGEN__) | ||||
| #define UART_USE_MUTUAL_EXCLUSION   FALSE | ||||
| #endif | ||||
|  | ||||
| /*===========================================================================*/ | ||||
| /* USB driver related settings.                                              */ | ||||
| /*===========================================================================*/ | ||||
|  | ||||
| /** | ||||
|  * @brief   Enables synchronous APIs. | ||||
|  * @note    Disabling this option saves both code and data space. | ||||
|  */ | ||||
| #if !defined(USB_USE_WAIT) || defined(__DOXYGEN__) | ||||
| #define USB_USE_WAIT                TRUE | ||||
| #endif | ||||
|  | ||||
| #endif /* HALCONF_H */ | ||||
|  | ||||
| /** @} */ | ||||
							
								
								
									
										124
									
								
								keyboards/planck/light/rev2/matrix.c
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										124
									
								
								keyboards/planck/light/rev2/matrix.c
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,124 @@ | ||||
| #include <stdint.h> | ||||
| #include <stdbool.h> | ||||
| #include <string.h> | ||||
| #include "hal.h" | ||||
| #include "timer.h" | ||||
| #include "wait.h" | ||||
| #include "printf.h" | ||||
| #include "backlight.h" | ||||
| #include "matrix.h" | ||||
| #include "action.h" | ||||
| #include "keycode.h" | ||||
| #include <string.h> | ||||
| #include "quantum.h" | ||||
|  | ||||
| /* | ||||
|  *     col: { A10, B2, A15, A0, A1, A2, B0, B1, C13, A6, A7, A3 } | ||||
|  *     row: { B5, B10, A9, A8 } | ||||
|  */ | ||||
| /* matrix state(1:on, 0:off) */ | ||||
| static matrix_row_t matrix[MATRIX_ROWS]; | ||||
| static matrix_row_t matrix_debouncing[MATRIX_COLS]; | ||||
| static bool debouncing = false; | ||||
| static uint16_t debouncing_time = 0; | ||||
|  | ||||
| static LINE_TYPE matrix_col_pins[MATRIX_COLS] = MATRIX_COL_PINS; | ||||
| static LINE_TYPE matrix_row_pins[MATRIX_ROWS] = MATRIX_ROW_PINS; | ||||
|  | ||||
| __attribute__ ((weak)) | ||||
| void matrix_init_user(void) {} | ||||
|  | ||||
| __attribute__ ((weak)) | ||||
| void matrix_scan_user(void) {} | ||||
|  | ||||
| __attribute__ ((weak)) | ||||
| void matrix_init_kb(void) { | ||||
|   matrix_init_user(); | ||||
| } | ||||
|  | ||||
| __attribute__ ((weak)) | ||||
| void matrix_scan_kb(void) { | ||||
|   matrix_scan_user(); | ||||
| } | ||||
|  | ||||
| void matrix_init(void) { | ||||
|     printf("matrix init\n"); | ||||
|     //debug_matrix = true; | ||||
|  | ||||
|     // actual matrix setup | ||||
|     for (int i = 0; i < MATRIX_COLS; i++) { | ||||
|       setPadMode(matrix_col_pins[i], PAL_MODE_OUTPUT_PUSHPULL); | ||||
|     } | ||||
|  | ||||
|     for (int i = 0; i < MATRIX_ROWS; i++) { | ||||
|       setPadMode(matrix_row_pins[i], PAL_MODE_INPUT_PULLDOWN); | ||||
|     } | ||||
|  | ||||
|     memset(matrix, 0, MATRIX_ROWS * sizeof(matrix_row_t)); | ||||
|     memset(matrix_debouncing, 0, MATRIX_COLS * sizeof(matrix_row_t)); | ||||
|  | ||||
|     matrix_init_quantum(); | ||||
| } | ||||
|  | ||||
| uint8_t matrix_scan(void) { | ||||
|  | ||||
|  | ||||
|     // actual matrix | ||||
|     for (int col = 0; col < MATRIX_COLS; col++) { | ||||
|         matrix_row_t data = 0; | ||||
|  | ||||
|         setPad(matrix_col_pins[col]); | ||||
|  | ||||
|         // need wait to settle pin state | ||||
|         wait_us(20); | ||||
|  | ||||
|         for (int row = 0; row < MATRIX_ROWS; row++) { | ||||
|           data |= (readPad(matrix_row_pins[row]) << row); | ||||
|         } | ||||
|  | ||||
|         clearPad(matrix_col_pins[col]); | ||||
|  | ||||
|         if (matrix_debouncing[col] != data) { | ||||
|             matrix_debouncing[col] = data; | ||||
|             debouncing = true; | ||||
|             debouncing_time = timer_read(); | ||||
|         } | ||||
|     } | ||||
|  | ||||
|     if (debouncing && timer_elapsed(debouncing_time) > DEBOUNCE) { | ||||
|         for (int row = 0; row < MATRIX_ROWS; row++) { | ||||
|             matrix[row] = 0; | ||||
|             for (int col = 0; col < MATRIX_COLS; col++) { | ||||
|                 matrix[row] |= ((matrix_debouncing[col] & (1 << row) ? 1 : 0) << col); | ||||
|             } | ||||
|         } | ||||
|         debouncing = false; | ||||
|     } | ||||
|  | ||||
|     matrix_scan_quantum(); | ||||
|  | ||||
|     return 1; | ||||
| } | ||||
|  | ||||
| bool matrix_is_on(uint8_t row, uint8_t col) { | ||||
|     return (matrix[row] & (1<<col)); | ||||
| } | ||||
|  | ||||
| matrix_row_t matrix_get_row(uint8_t row) { | ||||
|     return matrix[row]; | ||||
| } | ||||
|  | ||||
| void matrix_print(void) { | ||||
|     printf("\nr/c 01234567\n"); | ||||
|     for (uint8_t row = 0; row < MATRIX_ROWS; row++) { | ||||
|         printf("%X0: ", row); | ||||
|         matrix_row_t data = matrix_get_row(row); | ||||
|         for (int col = 0; col < MATRIX_COLS; col++) { | ||||
|             if (data & (1<<col)) | ||||
|                 printf("1"); | ||||
|             else | ||||
|                 printf("0"); | ||||
|         } | ||||
|         printf("\n"); | ||||
|     } | ||||
| } | ||||
							
								
								
									
										257
									
								
								keyboards/planck/light/rev2/mcuconf.h
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										257
									
								
								keyboards/planck/light/rev2/mcuconf.h
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,257 @@ | ||||
| /* | ||||
|     ChibiOS - Copyright (C) 2006..2016 Giovanni Di Sirio | ||||
|  | ||||
|     Licensed under the Apache License, Version 2.0 (the "License"); | ||||
|     you may not use this file except in compliance with the License. | ||||
|     You may obtain a copy of the License at | ||||
|  | ||||
|         http://www.apache.org/licenses/LICENSE-2.0 | ||||
|  | ||||
|     Unless required by applicable law or agreed to in writing, software | ||||
|     distributed under the License is distributed on an "AS IS" BASIS, | ||||
|     WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. | ||||
|     See the License for the specific language governing permissions and | ||||
|     limitations under the License. | ||||
| */ | ||||
|  | ||||
| #ifndef MCUCONF_H | ||||
| #define MCUCONF_H | ||||
|  | ||||
| /* | ||||
|  * STM32F3xx drivers configuration. | ||||
|  * The following settings override the default settings present in | ||||
|  * the various device driver implementation headers. | ||||
|  * Note that the settings for each driver only have effect if the whole | ||||
|  * driver is enabled in halconf.h. | ||||
|  * | ||||
|  * IRQ priorities: | ||||
|  * 15...0       Lowest...Highest. | ||||
|  * | ||||
|  * DMA priorities: | ||||
|  * 0...3        Lowest...Highest. | ||||
|  */ | ||||
|  | ||||
| #define STM32F3xx_MCUCONF | ||||
|  | ||||
| /* | ||||
|  * HAL driver system settings. | ||||
|  */ | ||||
| #define STM32_NO_INIT                       FALSE | ||||
| #define STM32_PVD_ENABLE                    FALSE | ||||
| #define STM32_PLS                           STM32_PLS_LEV0 | ||||
| #define STM32_HSI_ENABLED                   TRUE | ||||
| #define STM32_LSI_ENABLED                   TRUE | ||||
| #define STM32_HSE_ENABLED                   TRUE | ||||
| #define STM32_LSE_ENABLED                   FALSE | ||||
| #define STM32_SW                            STM32_SW_PLL | ||||
| #define STM32_PLLSRC                        STM32_PLLSRC_HSE | ||||
| #define STM32_PREDIV_VALUE                  1 | ||||
| #define STM32_PLLMUL_VALUE                  9 | ||||
| #define STM32_HPRE                          STM32_HPRE_DIV1 | ||||
| #define STM32_PPRE1                         STM32_PPRE1_DIV2 | ||||
| #define STM32_PPRE2                         STM32_PPRE2_DIV2 | ||||
| #define STM32_MCOSEL                        STM32_MCOSEL_NOCLOCK | ||||
| #define STM32_ADC12PRES                     STM32_ADC12PRES_DIV1 | ||||
| #define STM32_ADC34PRES                     STM32_ADC34PRES_DIV1 | ||||
| #define STM32_USART1SW                      STM32_USART1SW_PCLK | ||||
| #define STM32_USART2SW                      STM32_USART2SW_PCLK | ||||
| #define STM32_USART3SW                      STM32_USART3SW_PCLK | ||||
| #define STM32_UART4SW                       STM32_UART4SW_PCLK | ||||
| #define STM32_UART5SW                       STM32_UART5SW_PCLK | ||||
| #define STM32_I2C1SW                        STM32_I2C1SW_SYSCLK | ||||
| #define STM32_I2C2SW                        STM32_I2C2SW_SYSCLK | ||||
| #define STM32_TIM1SW                        STM32_TIM1SW_PCLK2 | ||||
| #define STM32_TIM8SW                        STM32_TIM8SW_PCLK2 | ||||
| #define STM32_RTCSEL                        STM32_RTCSEL_LSI | ||||
| #define STM32_USB_CLOCK_REQUIRED            TRUE | ||||
| #define STM32_USBPRE                        STM32_USBPRE_DIV1P5 | ||||
|  | ||||
| #undef STM32_HSE_BYPASS | ||||
| // #error "oh no" | ||||
| // #endif | ||||
|  | ||||
| /* | ||||
|  * ADC driver system settings. | ||||
|  */ | ||||
| #define STM32_ADC_DUAL_MODE                 FALSE | ||||
| #define STM32_ADC_COMPACT_SAMPLES           FALSE | ||||
| #define STM32_ADC_USE_ADC1                  FALSE | ||||
| #define STM32_ADC_USE_ADC2                  FALSE | ||||
| #define STM32_ADC_USE_ADC3                  FALSE | ||||
| #define STM32_ADC_USE_ADC4                  FALSE | ||||
| #define STM32_ADC_ADC1_DMA_STREAM           STM32_DMA_STREAM_ID(1, 1) | ||||
| #define STM32_ADC_ADC2_DMA_STREAM           STM32_DMA_STREAM_ID(2, 1) | ||||
| #define STM32_ADC_ADC3_DMA_STREAM           STM32_DMA_STREAM_ID(2, 5) | ||||
| #define STM32_ADC_ADC4_DMA_STREAM           STM32_DMA_STREAM_ID(2, 2) | ||||
| #define STM32_ADC_ADC1_DMA_PRIORITY         2 | ||||
| #define STM32_ADC_ADC2_DMA_PRIORITY         2 | ||||
| #define STM32_ADC_ADC3_DMA_PRIORITY         2 | ||||
| #define STM32_ADC_ADC4_DMA_PRIORITY         2 | ||||
| #define STM32_ADC_ADC12_IRQ_PRIORITY        5 | ||||
| #define STM32_ADC_ADC3_IRQ_PRIORITY         5 | ||||
| #define STM32_ADC_ADC4_IRQ_PRIORITY         5 | ||||
| #define STM32_ADC_ADC1_DMA_IRQ_PRIORITY     5 | ||||
| #define STM32_ADC_ADC2_DMA_IRQ_PRIORITY     5 | ||||
| #define STM32_ADC_ADC3_DMA_IRQ_PRIORITY     5 | ||||
| #define STM32_ADC_ADC4_DMA_IRQ_PRIORITY     5 | ||||
| #define STM32_ADC_ADC12_CLOCK_MODE          ADC_CCR_CKMODE_AHB_DIV1 | ||||
| #define STM32_ADC_ADC34_CLOCK_MODE          ADC_CCR_CKMODE_AHB_DIV1 | ||||
|  | ||||
| /* | ||||
|  * CAN driver system settings. | ||||
|  */ | ||||
| #define STM32_CAN_USE_CAN1                  FALSE | ||||
| #define STM32_CAN_CAN1_IRQ_PRIORITY         11 | ||||
|  | ||||
| /* | ||||
|  * DAC driver system settings. | ||||
|  */ | ||||
| #define STM32_DAC_DUAL_MODE                 FALSE | ||||
| #define STM32_DAC_USE_DAC1_CH1              TRUE | ||||
| #define STM32_DAC_USE_DAC1_CH2              TRUE | ||||
| #define STM32_DAC_DAC1_CH1_IRQ_PRIORITY     10 | ||||
| #define STM32_DAC_DAC1_CH2_IRQ_PRIORITY     10 | ||||
| #define STM32_DAC_DAC1_CH1_DMA_PRIORITY     2 | ||||
| #define STM32_DAC_DAC1_CH2_DMA_PRIORITY     2 | ||||
|  | ||||
| /* | ||||
|  * EXT driver system settings. | ||||
|  */ | ||||
| #define STM32_EXT_EXTI0_IRQ_PRIORITY        6 | ||||
| #define STM32_EXT_EXTI1_IRQ_PRIORITY        6 | ||||
| #define STM32_EXT_EXTI2_IRQ_PRIORITY        6 | ||||
| #define STM32_EXT_EXTI3_IRQ_PRIORITY        6 | ||||
| #define STM32_EXT_EXTI4_IRQ_PRIORITY        6 | ||||
| #define STM32_EXT_EXTI5_9_IRQ_PRIORITY      6 | ||||
| #define STM32_EXT_EXTI10_15_IRQ_PRIORITY    6 | ||||
| #define STM32_EXT_EXTI16_IRQ_PRIORITY       6 | ||||
| #define STM32_EXT_EXTI17_IRQ_PRIORITY       6 | ||||
| #define STM32_EXT_EXTI18_IRQ_PRIORITY       6 | ||||
| #define STM32_EXT_EXTI19_IRQ_PRIORITY       6 | ||||
| #define STM32_EXT_EXTI20_IRQ_PRIORITY       6 | ||||
| #define STM32_EXT_EXTI21_22_29_IRQ_PRIORITY 6 | ||||
| #define STM32_EXT_EXTI30_32_IRQ_PRIORITY    6 | ||||
| #define STM32_EXT_EXTI33_IRQ_PRIORITY       6 | ||||
|  | ||||
| /* | ||||
|  * GPT driver system settings. | ||||
|  */ | ||||
| #define STM32_GPT_USE_TIM1                  FALSE | ||||
| #define STM32_GPT_USE_TIM2                  FALSE | ||||
| #define STM32_GPT_USE_TIM3                  FALSE | ||||
| #define STM32_GPT_USE_TIM4                  FALSE | ||||
| #define STM32_GPT_USE_TIM6                  TRUE | ||||
| #define STM32_GPT_USE_TIM7                  TRUE | ||||
| #define STM32_GPT_USE_TIM8                  TRUE | ||||
| #define STM32_GPT_TIM1_IRQ_PRIORITY         7 | ||||
| #define STM32_GPT_TIM2_IRQ_PRIORITY         7 | ||||
| #define STM32_GPT_TIM3_IRQ_PRIORITY         7 | ||||
| #define STM32_GPT_TIM4_IRQ_PRIORITY         7 | ||||
| #define STM32_GPT_TIM6_IRQ_PRIORITY         7 | ||||
| #define STM32_GPT_TIM7_IRQ_PRIORITY         7 | ||||
| #define STM32_GPT_TIM8_IRQ_PRIORITY         7 | ||||
|  | ||||
| /* | ||||
|  * I2C driver system settings. | ||||
|  */ | ||||
| #define STM32_I2C_USE_I2C1                  TRUE | ||||
| #define STM32_I2C_USE_I2C2                  FALSE | ||||
| #define STM32_I2C_BUSY_TIMEOUT              50 | ||||
| #define STM32_I2C_I2C1_IRQ_PRIORITY         10 | ||||
| #define STM32_I2C_I2C2_IRQ_PRIORITY         10 | ||||
| #define STM32_I2C_USE_DMA                   TRUE | ||||
| #define STM32_I2C_I2C1_DMA_PRIORITY         1 | ||||
| #define STM32_I2C_I2C2_DMA_PRIORITY         1 | ||||
| #define STM32_I2C_DMA_ERROR_HOOK(i2cp)      osalSysHalt("DMA failure") | ||||
|  | ||||
| /* | ||||
|  * ICU driver system settings. | ||||
|  */ | ||||
| #define STM32_ICU_USE_TIM1                  FALSE | ||||
| #define STM32_ICU_USE_TIM2                  FALSE | ||||
| #define STM32_ICU_USE_TIM3                  FALSE | ||||
| #define STM32_ICU_USE_TIM4                  FALSE | ||||
| #define STM32_ICU_USE_TIM8                  FALSE | ||||
| #define STM32_ICU_TIM1_IRQ_PRIORITY         7 | ||||
| #define STM32_ICU_TIM2_IRQ_PRIORITY         7 | ||||
| #define STM32_ICU_TIM3_IRQ_PRIORITY         7 | ||||
| #define STM32_ICU_TIM4_IRQ_PRIORITY         7 | ||||
| #define STM32_ICU_TIM8_IRQ_PRIORITY         7 | ||||
|  | ||||
| /* | ||||
|  * PWM driver system settings. | ||||
|  */ | ||||
| #define STM32_PWM_USE_ADVANCED              FALSE | ||||
| #define STM32_PWM_USE_TIM1                  FALSE | ||||
| #define STM32_PWM_USE_TIM2                  FALSE | ||||
| #define STM32_PWM_USE_TIM3                  FALSE | ||||
| #define STM32_PWM_USE_TIM4                  FALSE | ||||
| #define STM32_PWM_USE_TIM8                  FALSE | ||||
| #define STM32_PWM_TIM1_IRQ_PRIORITY         7 | ||||
| #define STM32_PWM_TIM2_IRQ_PRIORITY         7 | ||||
| #define STM32_PWM_TIM3_IRQ_PRIORITY         7 | ||||
| #define STM32_PWM_TIM4_IRQ_PRIORITY         7 | ||||
| #define STM32_PWM_TIM8_IRQ_PRIORITY         7 | ||||
|  | ||||
| /* | ||||
|  * SERIAL driver system settings. | ||||
|  */ | ||||
| #define STM32_SERIAL_USE_USART1             FALSE | ||||
| #define STM32_SERIAL_USE_USART2             TRUE | ||||
| #define STM32_SERIAL_USE_USART3             FALSE | ||||
| #define STM32_SERIAL_USE_UART4              FALSE | ||||
| #define STM32_SERIAL_USE_UART5              FALSE | ||||
| #define STM32_SERIAL_USART1_PRIORITY        12 | ||||
| #define STM32_SERIAL_USART2_PRIORITY        12 | ||||
| #define STM32_SERIAL_USART3_PRIORITY        12 | ||||
| #define STM32_SERIAL_UART4_PRIORITY         12 | ||||
| #define STM32_SERIAL_UART5_PRIORITY         12 | ||||
|  | ||||
| /* | ||||
|  * SPI driver system settings. | ||||
|  */ | ||||
| #define STM32_SPI_USE_SPI1                  FALSE | ||||
| #define STM32_SPI_USE_SPI2                  FALSE | ||||
| #define STM32_SPI_USE_SPI3                  FALSE | ||||
| #define STM32_SPI_SPI1_DMA_PRIORITY         1 | ||||
| #define STM32_SPI_SPI2_DMA_PRIORITY         1 | ||||
| #define STM32_SPI_SPI3_DMA_PRIORITY         1 | ||||
| #define STM32_SPI_SPI1_IRQ_PRIORITY         10 | ||||
| #define STM32_SPI_SPI2_IRQ_PRIORITY         10 | ||||
| #define STM32_SPI_SPI3_IRQ_PRIORITY         10 | ||||
| #define STM32_SPI_DMA_ERROR_HOOK(spip)      osalSysHalt("DMA failure") | ||||
|  | ||||
| /* | ||||
|  * ST driver system settings. | ||||
|  */ | ||||
| #define STM32_ST_IRQ_PRIORITY               8 | ||||
| #define STM32_ST_USE_TIMER                  2 | ||||
|  | ||||
| /* | ||||
|  * UART driver system settings. | ||||
|  */ | ||||
| #define STM32_UART_USE_USART1               FALSE | ||||
| #define STM32_UART_USE_USART2               FALSE | ||||
| #define STM32_UART_USE_USART3               FALSE | ||||
| #define STM32_UART_USART1_IRQ_PRIORITY      12 | ||||
| #define STM32_UART_USART2_IRQ_PRIORITY      12 | ||||
| #define STM32_UART_USART3_IRQ_PRIORITY      12 | ||||
| #define STM32_UART_USART1_DMA_PRIORITY      0 | ||||
| #define STM32_UART_USART2_DMA_PRIORITY      0 | ||||
| #define STM32_UART_USART3_DMA_PRIORITY      0 | ||||
| #define STM32_UART_DMA_ERROR_HOOK(uartp)    osalSysHalt("DMA failure") | ||||
|  | ||||
| /* | ||||
|  * USB driver system settings. | ||||
|  */ | ||||
| #define STM32_USB_USE_USB1                  TRUE | ||||
| #define STM32_USB_LOW_POWER_ON_SUSPEND      FALSE | ||||
| #define STM32_USB_USB1_HP_IRQ_PRIORITY      13 | ||||
| #define STM32_USB_USB1_LP_IRQ_PRIORITY      14 | ||||
|  | ||||
| /* | ||||
|  * WDG driver system settings. | ||||
|  */ | ||||
| #define STM32_WDG_USE_IWDG                  FALSE | ||||
|  | ||||
| #endif /* MCUCONF_H */ | ||||
							
								
								
									
										16
									
								
								keyboards/planck/light/rev2/rev2.c
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										16
									
								
								keyboards/planck/light/rev2/rev2.c
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,16 @@ | ||||
| /* Copyright 2018 Jack Humbert <jack.humb@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 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 "rev2.h" | ||||
							
								
								
									
										21
									
								
								keyboards/planck/light/rev2/rev2.h
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										21
									
								
								keyboards/planck/light/rev2/rev2.h
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,21 @@ | ||||
| /* Copyright 2018 Jack Humbert <jack.humb@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 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/>. | ||||
|  */ | ||||
| #ifndef REV2_H | ||||
| #define REV2_H | ||||
|  | ||||
| #include QMK_KEYBOARD_H | ||||
|  | ||||
| #endif | ||||
							
								
								
									
										57
									
								
								keyboards/planck/light/rev2/rules.mk
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										57
									
								
								keyboards/planck/light/rev2/rules.mk
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,57 @@ | ||||
| # project specific files | ||||
| SRC =	matrix.c | ||||
| LAYOUTS += ortho_4x12 | ||||
|  | ||||
| ## chip/board settings | ||||
| # - the next two should match the directories in | ||||
| #   <chibios>/os/hal/ports/$(MCU_FAMILY)/$(MCU_SERIES) | ||||
| MCU_FAMILY = STM32 | ||||
| MCU_SERIES = STM32F3xx | ||||
|  | ||||
| # Linker script to use | ||||
| # - it should exist either in <chibios>/os/common/ports/ARMCMx/compilers/GCC/ld/ | ||||
| #   or <this_dir>/ld/ | ||||
| MCU_LDSCRIPT = STM32F303xC | ||||
|  | ||||
| # Startup code to use | ||||
| #  - it should exist in <chibios>/os/common/startup/ARMCMx/compilers/GCC/mk/ | ||||
| MCU_STARTUP = stm32f3xx | ||||
|  | ||||
| # Board: it should exist either in <chibios>/os/hal/boards/ | ||||
| #  or <this_dir>/boards | ||||
| BOARD = GENERIC_STM32_F303XC | ||||
|  | ||||
| # Cortex version | ||||
| MCU  = cortex-m4 | ||||
|  | ||||
| # ARM version, CORTEX-M0/M1 are 6, CORTEX-M3/M4/M7 are 7 | ||||
| ARMV = 7 | ||||
|  | ||||
| USE_FPU = yes | ||||
|  | ||||
| # Vector table for application | ||||
| # 0x00000000-0x00001000 area is occupied by bootlaoder.*/ | ||||
| # The CORTEX_VTOR... is needed only for MCHCK/Infinity KB | ||||
| # OPT_DEFS = -DCORTEX_VTOR_INIT=0x08005000 | ||||
| OPT_DEFS = | ||||
|  | ||||
| # Options to pass to dfu-util when flashing | ||||
| DFU_ARGS = -d 0483:df11 -a 0 -s 0x08000000:leave | ||||
|  | ||||
| # Build Options | ||||
| #   comment out to disable the options. | ||||
| # | ||||
| BACKLIGHT_ENABLE = no | ||||
| BOOTMAGIC_ENABLE = yes	# Virtual DIP switch configuration | ||||
| ## (Note that for BOOTMAGIC on Teensy LC you have to use a custom .ld script.) | ||||
| MOUSEKEY_ENABLE = yes	# Mouse keys | ||||
| EXTRAKEY_ENABLE = yes	# Audio control and System control | ||||
| CONSOLE_ENABLE = yes	# Console for debug | ||||
| COMMAND_ENABLE = yes    # Commands for debug and configuration | ||||
| #SLEEP_LED_ENABLE = yes  # Breathing sleep LED during USB suspend | ||||
| NKRO_ENABLE = yes	    # USB Nkey Rollover | ||||
| CUSTOM_MATRIX = yes # Custom matrix file | ||||
| AUDIO_ENABLE = yes | ||||
| RGB_MATRIX_ENABLE = yes | ||||
| ENCODER_ENABLE = yes | ||||
| # SERIAL_LINK_ENABLE = yes | ||||
| @@ -13,8 +13,17 @@ const keypos_t hand_swap_config[MATRIX_ROWS][MATRIX_COLS] = { | ||||
| __attribute__ ((weak)) | ||||
| void matrix_init_kb(void) { | ||||
| 	// Turn status LED on | ||||
| 	#ifdef __AVR__ | ||||
| 	DDRE |= (1<<6); | ||||
| 	PORTE |= (1<<6); | ||||
| 	#endif | ||||
|  | ||||
| 	matrix_init_user(); | ||||
| } | ||||
|  | ||||
| const uint8_t music_map[MATRIX_ROWS][MATRIX_COLS] = LAYOUT_planck_grid( | ||||
| 	36, 37, 38, 39, 40, 41, 42, 43, 44, 45, 46, 47, | ||||
| 	24, 25, 26, 27, 28, 29, 30, 31, 32, 33, 34, 35, | ||||
| 	12, 13, 14, 15, 16, 17, 18, 19, 20, 21, 22, 23, | ||||
| 	 0,  1,  2,  3,  4,  5,  6,  7,  8,  9, 10, 11 | ||||
| ); | ||||
| @@ -3,6 +3,7 @@ | ||||
|  | ||||
| #include "quantum.h" | ||||
|  | ||||
| #if defined(__AVR__) || defined (KEYBOARD_planck_light_rev2) | ||||
| #define LAYOUT_planck_mit( \ | ||||
| 	k00, k01, k02, k03, k04, k05, k06, k07, k08, k09, k0a, k0b, \ | ||||
| 	k10, k11, k12, k13, k14, k15, k16, k17, k18, k19, k1a, k1b, \ | ||||
| @@ -47,4 +48,97 @@ | ||||
| #define LAYOUT_ortho_4x12 LAYOUT_planck_grid | ||||
| #define KC_LAYOUT_ortho_4x12 KC_KEYMAP | ||||
|  | ||||
| #else | ||||
|  | ||||
| 	#define LAYOUT_planck_1x2uC( \ | ||||
|     k00, k01, k02, k03, k04, k05, k06, k07, k08, k09, k0a, k0b, \ | ||||
|     k10, k11, k12, k13, k14, k15, k16, k17, k18, k19, k1a, k1b, \ | ||||
|     k20, k21, k22, k23, k24, k25, k26, k27, k28, k29, k2a, k2b, \ | ||||
|     k30, k31, k32, k33, k34,    k35,   k37, k38, k39, k3a, k3b \ | ||||
| ) \ | ||||
| { \ | ||||
|     { k00, k01, k02, k03, k04, k05 }, \ | ||||
|     { k10, k11, k12, k13, k14, k15 }, \ | ||||
|     { k20, k21, k22, k23, k24, k25 }, \ | ||||
|     { k30, k31, k32, k39, k3a, k3b }, \ | ||||
|     { k06, k07, k08, k09, k0a, k0b }, \ | ||||
|     { k16, k17, k18, k19, k1a, k1b }, \ | ||||
|     { k26, k27, k28, k29, k2a, k2b }, \ | ||||
|     { k36, k37, k38, k33, k34, k35 } \ | ||||
| } | ||||
|  | ||||
| #define LAYOUT_planck_1x2uR( \ | ||||
|     k00, k01, k02, k03, k04, k05, k06, k07, k08, k09, k0a, k0b, \ | ||||
|     k10, k11, k12, k13, k14, k15, k16, k17, k18, k19, k1a, k1b, \ | ||||
|     k20, k21, k22, k23, k24, k25, k26, k27, k28, k29, k2a, k2b, \ | ||||
|     k30, k31, k32, k33, k34, k35,   k37,    k38, k39, k3a, k3b \ | ||||
| ) \ | ||||
| { \ | ||||
|     { k00, k01, k02, k03, k04, k05 }, \ | ||||
|     { k10, k11, k12, k13, k14, k15 }, \ | ||||
|     { k20, k21, k22, k23, k24, k25 }, \ | ||||
|     { k30, k31, k32, k39, k3a, k3b }, \ | ||||
|     { k06, k07, k08, k09, k0a, k0b }, \ | ||||
|     { k16, k17, k18, k19, k1a, k1b }, \ | ||||
|     { k26, k27, k28, k29, k2a, k2b }, \ | ||||
|     { k36, k37, k38, k33, k34, k35 } \ | ||||
| } | ||||
|  | ||||
| #define LAYOUT_planck_1x2uL( \ | ||||
|     k00, k01, k02, k03, k04, k05, k06, k07, k08, k09, k0a, k0b, \ | ||||
|     k10, k11, k12, k13, k14, k15, k16, k17, k18, k19, k1a, k1b, \ | ||||
|     k20, k21, k22, k23, k24, k25, k26, k27, k28, k29, k2a, k2b, \ | ||||
|     k30, k31, k32, k33,   k34,    k36, k37, k38, k39, k3a, k3b \ | ||||
| ) \ | ||||
| { \ | ||||
|     { k00, k01, k02, k03, k04, k05 }, \ | ||||
|     { k10, k11, k12, k13, k14, k15 }, \ | ||||
|     { k20, k21, k22, k23, k24, k25 }, \ | ||||
|     { k30, k31, k32, k39, k3a, k3b }, \ | ||||
|     { k06, k07, k08, k09, k0a, k0b }, \ | ||||
|     { k16, k17, k18, k19, k1a, k1b }, \ | ||||
|     { k26, k27, k28, k29, k2a, k2b }, \ | ||||
|     { k36, k37, k38, k33, k34, k35 } \ | ||||
| } | ||||
|  | ||||
| #define LAYOUT_planck_2x2u( \ | ||||
|     k00, k01, k02, k03, k04, k05, k06, k07, k08, k09, k0a, k0b, \ | ||||
|     k10, k11, k12, k13, k14, k15, k16, k17, k18, k19, k1a, k1b, \ | ||||
|     k20, k21, k22, k23, k24, k25, k26, k27, k28, k29, k2a, k2b, \ | ||||
|     k30, k31, k32, k33,   k34,      k36,    k38, k39, k3a, k3b \ | ||||
| ) \ | ||||
| { \ | ||||
|     { k00, k01, k02, k03, k04, k05 }, \ | ||||
|     { k10, k11, k12, k13, k14, k15 }, \ | ||||
|     { k20, k21, k22, k23, k24, k25 }, \ | ||||
|     { k30, k31, k32, k39, k3a, k3b }, \ | ||||
|     { k06, k07, k08, k09, k0a, k0b }, \ | ||||
|     { k16, k17, k18, k19, k1a, k1b }, \ | ||||
|     { k26, k27, k28, k29, k2a, k2b }, \ | ||||
|     { k36, k37, k38, k33, k34, k35 } \ | ||||
| } | ||||
|  | ||||
| #define LAYOUT_planck_grid( \ | ||||
|     k00, k01, k02, k03, k04, k05, k06, k07, k08, k09, k0a, k0b, \ | ||||
|     k10, k11, k12, k13, k14, k15, k16, k17, k18, k19, k1a, k1b, \ | ||||
|     k20, k21, k22, k23, k24, k25, k26, k27, k28, k29, k2a, k2b, \ | ||||
|     k30, k31, k32, k33, k34, k35, k36, k37, k38, k39, k3a, k3b \ | ||||
| ) \ | ||||
| { \ | ||||
|     { k00, k01, k02, k03, k04, k05 }, \ | ||||
|     { k10, k11, k12, k13, k14, k15 }, \ | ||||
|     { k20, k21, k22, k23, k24, k25 }, \ | ||||
|     { k30, k31, k32, k39, k3a, k3b }, \ | ||||
|     { k06, k07, k08, k09, k0a, k0b }, \ | ||||
|     { k16, k17, k18, k19, k1a, k1b }, \ | ||||
|     { k26, k27, k28, k29, k2a, k2b }, \ | ||||
|     { k36, k37, k38, k33, k34, k35 } \ | ||||
| } | ||||
|  | ||||
| #define KEYMAP LAYOUT_planck_grid | ||||
| #define LAYOUT_ortho_4x12 LAYOUT_planck_grid | ||||
| #define KC_LAYOUT_ortho_4x12 KC_KEYMAP | ||||
|  | ||||
| #endif | ||||
|  | ||||
| #endif | ||||
|   | ||||
							
								
								
									
										126
									
								
								keyboards/planck/rev6/boards/GENERIC_STM32_F303XC/board.c
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										126
									
								
								keyboards/planck/rev6/boards/GENERIC_STM32_F303XC/board.c
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,126 @@ | ||||
| /* | ||||
|     ChibiOS - Copyright (C) 2006..2016 Giovanni Di Sirio | ||||
|  | ||||
|     Licensed under the Apache License, Version 2.0 (the "License"); | ||||
|     you may not use this file except in compliance with the License. | ||||
|     You may obtain a copy of the License at | ||||
|  | ||||
|         http://www.apache.org/licenses/LICENSE-2.0 | ||||
|  | ||||
|     Unless required by applicable law or agreed to in writing, software | ||||
|     distributed under the License is distributed on an "AS IS" BASIS, | ||||
|     WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. | ||||
|     See the License for the specific language governing permissions and | ||||
|     limitations under the License. | ||||
| */ | ||||
|  | ||||
| #include "hal.h" | ||||
|  | ||||
| #if HAL_USE_PAL || defined(__DOXYGEN__) | ||||
| /** | ||||
|  * @brief   PAL setup. | ||||
|  * @details Digital I/O ports static configuration as defined in @p board.h. | ||||
|  *          This variable is used by the HAL when initializing the PAL driver. | ||||
|  */ | ||||
| const PALConfig pal_default_config = { | ||||
| #if STM32_HAS_GPIOA | ||||
|   {VAL_GPIOA_MODER, VAL_GPIOA_OTYPER, VAL_GPIOA_OSPEEDR, VAL_GPIOA_PUPDR, | ||||
|    VAL_GPIOA_ODR,   VAL_GPIOA_AFRL,   VAL_GPIOA_AFRH}, | ||||
| #endif | ||||
| #if STM32_HAS_GPIOB | ||||
|   {VAL_GPIOB_MODER, VAL_GPIOB_OTYPER, VAL_GPIOB_OSPEEDR, VAL_GPIOB_PUPDR, | ||||
|    VAL_GPIOB_ODR,   VAL_GPIOB_AFRL,   VAL_GPIOB_AFRH}, | ||||
| #endif | ||||
| #if STM32_HAS_GPIOC | ||||
|   {VAL_GPIOC_MODER, VAL_GPIOC_OTYPER, VAL_GPIOC_OSPEEDR, VAL_GPIOC_PUPDR, | ||||
|    VAL_GPIOC_ODR,   VAL_GPIOC_AFRL,   VAL_GPIOC_AFRH}, | ||||
| #endif | ||||
| #if STM32_HAS_GPIOD | ||||
|   {VAL_GPIOD_MODER, VAL_GPIOD_OTYPER, VAL_GPIOD_OSPEEDR, VAL_GPIOD_PUPDR, | ||||
|    VAL_GPIOD_ODR,   VAL_GPIOD_AFRL,   VAL_GPIOD_AFRH}, | ||||
| #endif | ||||
| #if STM32_HAS_GPIOE | ||||
|   {VAL_GPIOE_MODER, VAL_GPIOE_OTYPER, VAL_GPIOE_OSPEEDR, VAL_GPIOE_PUPDR, | ||||
|    VAL_GPIOE_ODR,   VAL_GPIOE_AFRL,   VAL_GPIOE_AFRH}, | ||||
| #endif | ||||
| #if STM32_HAS_GPIOF | ||||
|   {VAL_GPIOF_MODER, VAL_GPIOF_OTYPER, VAL_GPIOF_OSPEEDR, VAL_GPIOF_PUPDR, | ||||
|    VAL_GPIOF_ODR,   VAL_GPIOF_AFRL,   VAL_GPIOF_AFRH}, | ||||
| #endif | ||||
| #if STM32_HAS_GPIOG | ||||
|   {VAL_GPIOG_MODER, VAL_GPIOG_OTYPER, VAL_GPIOG_OSPEEDR, VAL_GPIOG_PUPDR, | ||||
|    VAL_GPIOG_ODR,   VAL_GPIOG_AFRL,   VAL_GPIOG_AFRH}, | ||||
| #endif | ||||
| #if STM32_HAS_GPIOH | ||||
|   {VAL_GPIOH_MODER, VAL_GPIOH_OTYPER, VAL_GPIOH_OSPEEDR, VAL_GPIOH_PUPDR, | ||||
|    VAL_GPIOH_ODR,   VAL_GPIOH_AFRL,   VAL_GPIOH_AFRH}, | ||||
| #endif | ||||
| #if STM32_HAS_GPIOI | ||||
|   {VAL_GPIOI_MODER, VAL_GPIOI_OTYPER, VAL_GPIOI_OSPEEDR, VAL_GPIOI_PUPDR, | ||||
|    VAL_GPIOI_ODR,   VAL_GPIOI_AFRL,   VAL_GPIOI_AFRH} | ||||
| #endif | ||||
| }; | ||||
| #endif | ||||
|  | ||||
| void enter_bootloader_mode_if_requested(void); | ||||
|  | ||||
| /** | ||||
|  * @brief   Early initialization code. | ||||
|  * @details This initialization must be performed just after stack setup | ||||
|  *          and before any other initialization. | ||||
|  */ | ||||
| void __early_init(void) { | ||||
|   enter_bootloader_mode_if_requested(); | ||||
|   stm32_clock_init(); | ||||
| } | ||||
|  | ||||
| #if HAL_USE_SDC || defined(__DOXYGEN__) | ||||
| /** | ||||
|  * @brief   SDC card detection. | ||||
|  */ | ||||
| bool sdc_lld_is_card_inserted(SDCDriver *sdcp) { | ||||
|  | ||||
|   (void)sdcp; | ||||
|   /* TODO: Fill the implementation.*/ | ||||
|   return true; | ||||
| } | ||||
|  | ||||
| /** | ||||
|  * @brief   SDC card write protection detection. | ||||
|  */ | ||||
| bool sdc_lld_is_write_protected(SDCDriver *sdcp) { | ||||
|  | ||||
|   (void)sdcp; | ||||
|   /* TODO: Fill the implementation.*/ | ||||
|   return false; | ||||
| } | ||||
| #endif /* HAL_USE_SDC */ | ||||
|  | ||||
| #if HAL_USE_MMC_SPI || defined(__DOXYGEN__) | ||||
| /** | ||||
|  * @brief   MMC_SPI card detection. | ||||
|  */ | ||||
| bool mmc_lld_is_card_inserted(MMCDriver *mmcp) { | ||||
|  | ||||
|   (void)mmcp; | ||||
|   /* TODO: Fill the implementation.*/ | ||||
|   return true; | ||||
| } | ||||
|  | ||||
| /** | ||||
|  * @brief   MMC_SPI card write protection detection. | ||||
|  */ | ||||
| bool mmc_lld_is_write_protected(MMCDriver *mmcp) { | ||||
|  | ||||
|   (void)mmcp; | ||||
|   /* TODO: Fill the implementation.*/ | ||||
|   return false; | ||||
| } | ||||
| #endif | ||||
|  | ||||
| /** | ||||
|  * @brief   Board-specific initialization code. | ||||
|  * @todo    Add your board-specific code, if any. | ||||
|  */ | ||||
| void boardInit(void) { | ||||
| } | ||||
							
								
								
									
										1187
									
								
								keyboards/planck/rev6/boards/GENERIC_STM32_F303XC/board.h
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										1187
									
								
								keyboards/planck/rev6/boards/GENERIC_STM32_F303XC/board.h
									
									
									
									
									
										Normal file
									
								
							
										
											
												File diff suppressed because it is too large
												Load Diff
											
										
									
								
							| @@ -0,0 +1,5 @@ | ||||
| # List of all the board related files. | ||||
| BOARDSRC = $(BOARD_PATH)/boards/GENERIC_STM32_F303XC/board.c | ||||
|  | ||||
| # Required include directories | ||||
| BOARDINC = $(BOARD_PATH)/boards/GENERIC_STM32_F303XC | ||||
							
								
								
									
										7
									
								
								keyboards/planck/rev6/bootloader_defs.h
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										7
									
								
								keyboards/planck/rev6/bootloader_defs.h
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,7 @@ | ||||
| /* Address for jumping to bootloader on STM32 chips. */ | ||||
| /* It is chip dependent, the correct number can be looked up here: | ||||
|  * http://www.st.com/web/en/resource/technical/document/application_note/CD00167594.pdf | ||||
|  * This also requires a patch to chibios: | ||||
|  *  <tmk_dir>/tmk_core/tool/chibios/ch-bootloader-jump.patch | ||||
|  */ | ||||
| #define STM32_BOOTLOADER_ADDRESS 0x1FFFD800 | ||||
							
								
								
									
										520
									
								
								keyboards/planck/rev6/chconf.h
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										520
									
								
								keyboards/planck/rev6/chconf.h
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,520 @@ | ||||
| /* | ||||
|     ChibiOS - Copyright (C) 2006..2016 Giovanni Di Sirio | ||||
|  | ||||
|     Licensed under the Apache License, Version 2.0 (the "License"); | ||||
|     you may not use this file except in compliance with the License. | ||||
|     You may obtain a copy of the License at | ||||
|  | ||||
|         http://www.apache.org/licenses/LICENSE-2.0 | ||||
|  | ||||
|     Unless required by applicable law or agreed to in writing, software | ||||
|     distributed under the License is distributed on an "AS IS" BASIS, | ||||
|     WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. | ||||
|     See the License for the specific language governing permissions and | ||||
|     limitations under the License. | ||||
| */ | ||||
|  | ||||
| /** | ||||
|  * @file    templates/chconf.h | ||||
|  * @brief   Configuration file template. | ||||
|  * @details A copy of this file must be placed in each project directory, it | ||||
|  *          contains the application specific kernel settings. | ||||
|  * | ||||
|  * @addtogroup config | ||||
|  * @details Kernel related settings and hooks. | ||||
|  * @{ | ||||
|  */ | ||||
|  | ||||
| #ifndef CHCONF_H | ||||
| #define CHCONF_H | ||||
|  | ||||
| #define _CHIBIOS_RT_CONF_ | ||||
|  | ||||
| /*===========================================================================*/ | ||||
| /** | ||||
|  * @name System timers settings | ||||
|  * @{ | ||||
|  */ | ||||
| /*===========================================================================*/ | ||||
|  | ||||
| /** | ||||
|  * @brief   System time counter resolution. | ||||
|  * @note    Allowed values are 16 or 32 bits. | ||||
|  */ | ||||
| #define CH_CFG_ST_RESOLUTION                16 | ||||
|  | ||||
| /** | ||||
|  * @brief   System tick frequency. | ||||
|  * @details Frequency of the system timer that drives the system ticks. This | ||||
|  *          setting also defines the system tick time unit. | ||||
|  */ | ||||
| #define CH_CFG_ST_FREQUENCY                 10000 | ||||
|  | ||||
| /** | ||||
|  * @brief   Time delta constant for the tick-less mode. | ||||
|  * @note    If this value is zero then the system uses the classic | ||||
|  *          periodic tick. This value represents the minimum number | ||||
|  *          of ticks that is safe to specify in a timeout directive. | ||||
|  *          The value one is not valid, timeouts are rounded up to | ||||
|  *          this value. | ||||
|  */ | ||||
| #define CH_CFG_ST_TIMEDELTA                 2 | ||||
|  | ||||
| /** @} */ | ||||
|  | ||||
| /*===========================================================================*/ | ||||
| /** | ||||
|  * @name Kernel parameters and options | ||||
|  * @{ | ||||
|  */ | ||||
| /*===========================================================================*/ | ||||
|  | ||||
| /** | ||||
|  * @brief   Round robin interval. | ||||
|  * @details This constant is the number of system ticks allowed for the | ||||
|  *          threads before preemption occurs. Setting this value to zero | ||||
|  *          disables the preemption for threads with equal priority and the | ||||
|  *          round robin becomes cooperative. Note that higher priority | ||||
|  *          threads can still preempt, the kernel is always preemptive. | ||||
|  * @note    Disabling the round robin preemption makes the kernel more compact | ||||
|  *          and generally faster. | ||||
|  * @note    The round robin preemption is not supported in tickless mode and | ||||
|  *          must be set to zero in that case. | ||||
|  */ | ||||
| #define CH_CFG_TIME_QUANTUM                 0 | ||||
|  | ||||
| /** | ||||
|  * @brief   Managed RAM size. | ||||
|  * @details Size of the RAM area to be managed by the OS. If set to zero | ||||
|  *          then the whole available RAM is used. The core memory is made | ||||
|  *          available to the heap allocator and/or can be used directly through | ||||
|  *          the simplified core memory allocator. | ||||
|  * | ||||
|  * @note    In order to let the OS manage the whole RAM the linker script must | ||||
|  *          provide the @p __heap_base__ and @p __heap_end__ symbols. | ||||
|  * @note    Requires @p CH_CFG_USE_MEMCORE. | ||||
|  */ | ||||
| #define CH_CFG_MEMCORE_SIZE                 0 | ||||
|  | ||||
| /** | ||||
|  * @brief   Idle thread automatic spawn suppression. | ||||
|  * @details When this option is activated the function @p chSysInit() | ||||
|  *          does not spawn the idle thread. The application @p main() | ||||
|  *          function becomes the idle thread and must implement an | ||||
|  *          infinite loop. | ||||
|  */ | ||||
| #define CH_CFG_NO_IDLE_THREAD               FALSE | ||||
|  | ||||
| /** @} */ | ||||
|  | ||||
| /*===========================================================================*/ | ||||
| /** | ||||
|  * @name Performance options | ||||
|  * @{ | ||||
|  */ | ||||
| /*===========================================================================*/ | ||||
|  | ||||
| /** | ||||
|  * @brief   OS optimization. | ||||
|  * @details If enabled then time efficient rather than space efficient code | ||||
|  *          is used when two possible implementations exist. | ||||
|  * | ||||
|  * @note    This is not related to the compiler optimization options. | ||||
|  * @note    The default is @p TRUE. | ||||
|  */ | ||||
| #define CH_CFG_OPTIMIZE_SPEED               TRUE | ||||
|  | ||||
| /** @} */ | ||||
|  | ||||
| /*===========================================================================*/ | ||||
| /** | ||||
|  * @name Subsystem options | ||||
|  * @{ | ||||
|  */ | ||||
| /*===========================================================================*/ | ||||
|  | ||||
| /** | ||||
|  * @brief   Time Measurement APIs. | ||||
|  * @details If enabled then the time measurement APIs are included in | ||||
|  *          the kernel. | ||||
|  * | ||||
|  * @note    The default is @p TRUE. | ||||
|  */ | ||||
| #define CH_CFG_USE_TM                       TRUE | ||||
|  | ||||
| /** | ||||
|  * @brief   Threads registry APIs. | ||||
|  * @details If enabled then the registry APIs are included in the kernel. | ||||
|  * | ||||
|  * @note    The default is @p TRUE. | ||||
|  */ | ||||
| #define CH_CFG_USE_REGISTRY                 TRUE | ||||
|  | ||||
| /** | ||||
|  * @brief   Threads synchronization APIs. | ||||
|  * @details If enabled then the @p chThdWait() function is included in | ||||
|  *          the kernel. | ||||
|  * | ||||
|  * @note    The default is @p TRUE. | ||||
|  */ | ||||
| #define CH_CFG_USE_WAITEXIT                 TRUE | ||||
|  | ||||
| /** | ||||
|  * @brief   Semaphores APIs. | ||||
|  * @details If enabled then the Semaphores APIs are included in the kernel. | ||||
|  * | ||||
|  * @note    The default is @p TRUE. | ||||
|  */ | ||||
| #define CH_CFG_USE_SEMAPHORES               TRUE | ||||
|  | ||||
| /** | ||||
|  * @brief   Semaphores queuing mode. | ||||
|  * @details If enabled then the threads are enqueued on semaphores by | ||||
|  *          priority rather than in FIFO order. | ||||
|  * | ||||
|  * @note    The default is @p FALSE. Enable this if you have special | ||||
|  *          requirements. | ||||
|  * @note    Requires @p CH_CFG_USE_SEMAPHORES. | ||||
|  */ | ||||
| #define CH_CFG_USE_SEMAPHORES_PRIORITY      FALSE | ||||
|  | ||||
| /** | ||||
|  * @brief   Mutexes APIs. | ||||
|  * @details If enabled then the mutexes APIs are included in the kernel. | ||||
|  * | ||||
|  * @note    The default is @p TRUE. | ||||
|  */ | ||||
| #define CH_CFG_USE_MUTEXES                  TRUE | ||||
|  | ||||
| /** | ||||
|  * @brief   Enables recursive behavior on mutexes. | ||||
|  * @note    Recursive mutexes are heavier and have an increased | ||||
|  *          memory footprint. | ||||
|  * | ||||
|  * @note    The default is @p FALSE. | ||||
|  * @note    Requires @p CH_CFG_USE_MUTEXES. | ||||
|  */ | ||||
| #define CH_CFG_USE_MUTEXES_RECURSIVE        FALSE | ||||
|  | ||||
| /** | ||||
|  * @brief   Conditional Variables APIs. | ||||
|  * @details If enabled then the conditional variables APIs are included | ||||
|  *          in the kernel. | ||||
|  * | ||||
|  * @note    The default is @p TRUE. | ||||
|  * @note    Requires @p CH_CFG_USE_MUTEXES. | ||||
|  */ | ||||
| #define CH_CFG_USE_CONDVARS                 TRUE | ||||
|  | ||||
| /** | ||||
|  * @brief   Conditional Variables APIs with timeout. | ||||
|  * @details If enabled then the conditional variables APIs with timeout | ||||
|  *          specification are included in the kernel. | ||||
|  * | ||||
|  * @note    The default is @p TRUE. | ||||
|  * @note    Requires @p CH_CFG_USE_CONDVARS. | ||||
|  */ | ||||
| #define CH_CFG_USE_CONDVARS_TIMEOUT         TRUE | ||||
|  | ||||
| /** | ||||
|  * @brief   Events Flags APIs. | ||||
|  * @details If enabled then the event flags APIs are included in the kernel. | ||||
|  * | ||||
|  * @note    The default is @p TRUE. | ||||
|  */ | ||||
| #define CH_CFG_USE_EVENTS                   TRUE | ||||
|  | ||||
| /** | ||||
|  * @brief   Events Flags APIs with timeout. | ||||
|  * @details If enabled then the events APIs with timeout specification | ||||
|  *          are included in the kernel. | ||||
|  * | ||||
|  * @note    The default is @p TRUE. | ||||
|  * @note    Requires @p CH_CFG_USE_EVENTS. | ||||
|  */ | ||||
| #define CH_CFG_USE_EVENTS_TIMEOUT           TRUE | ||||
|  | ||||
| /** | ||||
|  * @brief   Synchronous Messages APIs. | ||||
|  * @details If enabled then the synchronous messages APIs are included | ||||
|  *          in the kernel. | ||||
|  * | ||||
|  * @note    The default is @p TRUE. | ||||
|  */ | ||||
| #define CH_CFG_USE_MESSAGES                 TRUE | ||||
|  | ||||
| /** | ||||
|  * @brief   Synchronous Messages queuing mode. | ||||
|  * @details If enabled then messages are served by priority rather than in | ||||
|  *          FIFO order. | ||||
|  * | ||||
|  * @note    The default is @p FALSE. Enable this if you have special | ||||
|  *          requirements. | ||||
|  * @note    Requires @p CH_CFG_USE_MESSAGES. | ||||
|  */ | ||||
| #define CH_CFG_USE_MESSAGES_PRIORITY        TRUE | ||||
|  | ||||
| /** | ||||
|  * @brief   Mailboxes APIs. | ||||
|  * @details If enabled then the asynchronous messages (mailboxes) APIs are | ||||
|  *          included in the kernel. | ||||
|  * | ||||
|  * @note    The default is @p TRUE. | ||||
|  * @note    Requires @p CH_CFG_USE_SEMAPHORES. | ||||
|  */ | ||||
| #define CH_CFG_USE_MAILBOXES                TRUE | ||||
|  | ||||
| /** | ||||
|  * @brief   Core Memory Manager APIs. | ||||
|  * @details If enabled then the core memory manager APIs are included | ||||
|  *          in the kernel. | ||||
|  * | ||||
|  * @note    The default is @p TRUE. | ||||
|  */ | ||||
| #define CH_CFG_USE_MEMCORE                  TRUE | ||||
|  | ||||
| /** | ||||
|  * @brief   Heap Allocator APIs. | ||||
|  * @details If enabled then the memory heap allocator APIs are included | ||||
|  *          in the kernel. | ||||
|  * | ||||
|  * @note    The default is @p TRUE. | ||||
|  * @note    Requires @p CH_CFG_USE_MEMCORE and either @p CH_CFG_USE_MUTEXES or | ||||
|  *          @p CH_CFG_USE_SEMAPHORES. | ||||
|  * @note    Mutexes are recommended. | ||||
|  */ | ||||
| #define CH_CFG_USE_HEAP                     TRUE | ||||
|  | ||||
| /** | ||||
|  * @brief   Memory Pools Allocator APIs. | ||||
|  * @details If enabled then the memory pools allocator APIs are included | ||||
|  *          in the kernel. | ||||
|  * | ||||
|  * @note    The default is @p TRUE. | ||||
|  */ | ||||
| #define CH_CFG_USE_MEMPOOLS                 TRUE | ||||
|  | ||||
| /** | ||||
|  * @brief   Dynamic Threads APIs. | ||||
|  * @details If enabled then the dynamic threads creation APIs are included | ||||
|  *          in the kernel. | ||||
|  * | ||||
|  * @note    The default is @p TRUE. | ||||
|  * @note    Requires @p CH_CFG_USE_WAITEXIT. | ||||
|  * @note    Requires @p CH_CFG_USE_HEAP and/or @p CH_CFG_USE_MEMPOOLS. | ||||
|  */ | ||||
| #define CH_CFG_USE_DYNAMIC                  TRUE | ||||
|  | ||||
| /** @} */ | ||||
|  | ||||
| /*===========================================================================*/ | ||||
| /** | ||||
|  * @name Debug options | ||||
|  * @{ | ||||
|  */ | ||||
| /*===========================================================================*/ | ||||
|  | ||||
| /** | ||||
|  * @brief   Debug option, kernel statistics. | ||||
|  * | ||||
|  * @note    The default is @p FALSE. | ||||
|  */ | ||||
| #define CH_DBG_STATISTICS                   FALSE | ||||
|  | ||||
| /** | ||||
|  * @brief   Debug option, system state check. | ||||
|  * @details If enabled the correct call protocol for system APIs is checked | ||||
|  *          at runtime. | ||||
|  * | ||||
|  * @note    The default is @p FALSE. | ||||
|  */ | ||||
| #define CH_DBG_SYSTEM_STATE_CHECK           FALSE | ||||
|  | ||||
| /** | ||||
|  * @brief   Debug option, parameters checks. | ||||
|  * @details If enabled then the checks on the API functions input | ||||
|  *          parameters are activated. | ||||
|  * | ||||
|  * @note    The default is @p FALSE. | ||||
|  */ | ||||
| #define CH_DBG_ENABLE_CHECKS                FALSE | ||||
|  | ||||
| /** | ||||
|  * @brief   Debug option, consistency checks. | ||||
|  * @details If enabled then all the assertions in the kernel code are | ||||
|  *          activated. This includes consistency checks inside the kernel, | ||||
|  *          runtime anomalies and port-defined checks. | ||||
|  * | ||||
|  * @note    The default is @p FALSE. | ||||
|  */ | ||||
| #define CH_DBG_ENABLE_ASSERTS               FALSE | ||||
|  | ||||
| /** | ||||
|  * @brief   Debug option, trace buffer. | ||||
|  * @details If enabled then the trace buffer is activated. | ||||
|  * | ||||
|  * @note    The default is @p CH_DBG_TRACE_MASK_DISABLED. | ||||
|  */ | ||||
| #define CH_DBG_TRACE_MASK                   CH_DBG_TRACE_MASK_DISABLED | ||||
|  | ||||
| /** | ||||
|  * @brief   Trace buffer entries. | ||||
|  * @note    The trace buffer is only allocated if @p CH_DBG_TRACE_MASK is | ||||
|  *          different from @p CH_DBG_TRACE_MASK_DISABLED. | ||||
|  */ | ||||
| #define CH_DBG_TRACE_BUFFER_SIZE            128 | ||||
|  | ||||
| /** | ||||
|  * @brief   Debug option, stack checks. | ||||
|  * @details If enabled then a runtime stack check is performed. | ||||
|  * | ||||
|  * @note    The default is @p FALSE. | ||||
|  * @note    The stack check is performed in a architecture/port dependent way. | ||||
|  *          It may not be implemented or some ports. | ||||
|  * @note    The default failure mode is to halt the system with the global | ||||
|  *          @p panic_msg variable set to @p NULL. | ||||
|  */ | ||||
| #define CH_DBG_ENABLE_STACK_CHECK           TRUE | ||||
|  | ||||
| /** | ||||
|  * @brief   Debug option, stacks initialization. | ||||
|  * @details If enabled then the threads working area is filled with a byte | ||||
|  *          value when a thread is created. This can be useful for the | ||||
|  *          runtime measurement of the used stack. | ||||
|  * | ||||
|  * @note    The default is @p FALSE. | ||||
|  */ | ||||
| #define CH_DBG_FILL_THREADS                 FALSE | ||||
|  | ||||
| /** | ||||
|  * @brief   Debug option, threads profiling. | ||||
|  * @details If enabled then a field is added to the @p thread_t structure that | ||||
|  *          counts the system ticks occurred while executing the thread. | ||||
|  * | ||||
|  * @note    The default is @p FALSE. | ||||
|  * @note    This debug option is not currently compatible with the | ||||
|  *          tickless mode. | ||||
|  */ | ||||
| #define CH_DBG_THREADS_PROFILING            FALSE | ||||
|  | ||||
| /** @} */ | ||||
|  | ||||
| /*===========================================================================*/ | ||||
| /** | ||||
|  * @name Kernel hooks | ||||
|  * @{ | ||||
|  */ | ||||
| /*===========================================================================*/ | ||||
|  | ||||
| /** | ||||
|  * @brief   Threads descriptor structure extension. | ||||
|  * @details User fields added to the end of the @p thread_t structure. | ||||
|  */ | ||||
| #define CH_CFG_THREAD_EXTRA_FIELDS                                          \ | ||||
|   /* Add threads custom fields here.*/ | ||||
|  | ||||
| /** | ||||
|  * @brief   Threads initialization hook. | ||||
|  * @details User initialization code added to the @p chThdInit() API. | ||||
|  * | ||||
|  * @note    It is invoked from within @p chThdInit() and implicitly from all | ||||
|  *          the threads creation APIs. | ||||
|  */ | ||||
| #define CH_CFG_THREAD_INIT_HOOK(tp) {                                       \ | ||||
|   /* Add threads initialization code here.*/                                \ | ||||
| } | ||||
|  | ||||
| /** | ||||
|  * @brief   Threads finalization hook. | ||||
|  * @details User finalization code added to the @p chThdExit() API. | ||||
|  */ | ||||
| #define CH_CFG_THREAD_EXIT_HOOK(tp) {                                       \ | ||||
|   /* Add threads finalization code here.*/                                  \ | ||||
| } | ||||
|  | ||||
| /** | ||||
|  * @brief   Context switch hook. | ||||
|  * @details This hook is invoked just before switching between threads. | ||||
|  */ | ||||
| #define CH_CFG_CONTEXT_SWITCH_HOOK(ntp, otp) {                              \ | ||||
|   /* Context switch code here.*/                                            \ | ||||
| } | ||||
|  | ||||
| /** | ||||
|  * @brief   ISR enter hook. | ||||
|  */ | ||||
| #define CH_CFG_IRQ_PROLOGUE_HOOK() {                                        \ | ||||
|   /* IRQ prologue code here.*/                                              \ | ||||
| } | ||||
|  | ||||
| /** | ||||
|  * @brief   ISR exit hook. | ||||
|  */ | ||||
| #define CH_CFG_IRQ_EPILOGUE_HOOK() {                                        \ | ||||
|   /* IRQ epilogue code here.*/                                              \ | ||||
| } | ||||
|  | ||||
| /** | ||||
|  * @brief   Idle thread enter hook. | ||||
|  * @note    This hook is invoked within a critical zone, no OS functions | ||||
|  *          should be invoked from here. | ||||
|  * @note    This macro can be used to activate a power saving mode. | ||||
|  */ | ||||
| #define CH_CFG_IDLE_ENTER_HOOK() {                                          \ | ||||
|   /* Idle-enter code here.*/                                                \ | ||||
| } | ||||
|  | ||||
| /** | ||||
|  * @brief   Idle thread leave hook. | ||||
|  * @note    This hook is invoked within a critical zone, no OS functions | ||||
|  *          should be invoked from here. | ||||
|  * @note    This macro can be used to deactivate a power saving mode. | ||||
|  */ | ||||
| #define CH_CFG_IDLE_LEAVE_HOOK() {                                          \ | ||||
|   /* Idle-leave code here.*/                                                \ | ||||
| } | ||||
|  | ||||
| /** | ||||
|  * @brief   Idle Loop hook. | ||||
|  * @details This hook is continuously invoked by the idle thread loop. | ||||
|  */ | ||||
| #define CH_CFG_IDLE_LOOP_HOOK() {                                           \ | ||||
|   /* Idle loop code here.*/                                                 \ | ||||
| } | ||||
|  | ||||
| /** | ||||
|  * @brief   System tick event hook. | ||||
|  * @details This hook is invoked in the system tick handler immediately | ||||
|  *          after processing the virtual timers queue. | ||||
|  */ | ||||
| #define CH_CFG_SYSTEM_TICK_HOOK() {                                         \ | ||||
|   /* System tick event code here.*/                                         \ | ||||
| } | ||||
|  | ||||
| /** | ||||
|  * @brief   System halt hook. | ||||
|  * @details This hook is invoked in case to a system halting error before | ||||
|  *          the system is halted. | ||||
|  */ | ||||
| #define CH_CFG_SYSTEM_HALT_HOOK(reason) {                                   \ | ||||
|   /* System halt code here.*/                                               \ | ||||
| } | ||||
|  | ||||
| /** | ||||
|  * @brief   Trace hook. | ||||
|  * @details This hook is invoked each time a new record is written in the | ||||
|  *          trace buffer. | ||||
|  */ | ||||
| #define CH_CFG_TRACE_HOOK(tep) {                                            \ | ||||
|   /* Trace code here.*/                                                     \ | ||||
| } | ||||
|  | ||||
| /** @} */ | ||||
|  | ||||
| /*===========================================================================*/ | ||||
| /* Port-specific settings (override port settings defaulted in chcore.h).    */ | ||||
| /*===========================================================================*/ | ||||
|  | ||||
| #endif  /* CHCONF_H */ | ||||
|  | ||||
| /** @} */ | ||||
							
								
								
									
										138
									
								
								keyboards/planck/rev6/config.h
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										138
									
								
								keyboards/planck/rev6/config.h
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,138 @@ | ||||
| /* | ||||
|  * Copyright 2018 Jack Humbert <jack.humb@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 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/>. | ||||
|  */ | ||||
|  | ||||
| #ifndef REV6_CONFIG_H | ||||
| #define REV6_CONFIG_H | ||||
|  | ||||
| /* USB Device descriptor parameter */ | ||||
| #define DEVICE_VER 0x0006 | ||||
|  | ||||
| #undef MATRIX_ROWS | ||||
| #undef MATRIX_COLS | ||||
| /* key matrix size */ | ||||
| #define MATRIX_ROWS 8 | ||||
| #define MATRIX_COLS 6 | ||||
|  | ||||
| /* | ||||
|  * Keyboard Matrix Assignments | ||||
|  * | ||||
|  * Change this to how you wired your keyboard | ||||
|  * COLS: AVR pins used for columns, left to right | ||||
|  * ROWS: AVR pins used for rows, top to bottom | ||||
|  * DIODE_DIRECTION: COL2ROW = COL = Anode (+), ROW = Cathode (-, marked on diode) | ||||
|  *                  ROW2COL = ROW = Anode (+), COL = Cathode (-, marked on diode) | ||||
|  * | ||||
| */ | ||||
| /* Note: These are not used for arm boards. They're here purely as documentation. | ||||
|  * #define MATRIX_ROW_PINS { PB0, PB1, PB2, PA15, PA10 } | ||||
|  * #define MATRIX_COL_PINS { PA2, PA3, PA6, PB14, PB15, PA8, PA9, PA7, PB3, PB4, PC14, PC15, PC13, PB5, PB6 } | ||||
|  * #define UNUSED_PINS | ||||
|  */ | ||||
|  | ||||
| #define MUSIC_MAP | ||||
| #undef AUDIO_VOICES | ||||
| #undef C6_AUDIO | ||||
|  | ||||
| /* Debounce reduces chatter (unintended double-presses) - set 0 if debouncing is not needed */ | ||||
| #define DEBOUNCE 6 | ||||
|  | ||||
| /* Prevent modifiers from being stuck on after layer changes. */ | ||||
| #define PREVENT_STUCK_MODIFIERS | ||||
|  | ||||
| /* Mechanical locking support. Use KC_LCAP, KC_LNUM or KC_LSCR instead in keymap */ | ||||
| //#define LOCKING_SUPPORT_ENABLE | ||||
| /* Locking resynchronize hack */ | ||||
| //#define LOCKING_RESYNC_ENABLE | ||||
|  | ||||
| /* | ||||
|  * Force NKRO | ||||
|  * | ||||
|  * Force NKRO (nKey Rollover) to be enabled by default, regardless of the saved | ||||
|  * state in the bootmagic EEPROM settings. (Note that NKRO must be enabled in the | ||||
|  * makefile for this to work.) | ||||
|  * | ||||
|  * If forced on, NKRO can be disabled via magic key (default = LShift+RShift+N) | ||||
|  * until the next keyboard reset. | ||||
|  * | ||||
|  * NKRO may prevent your keystrokes from being detected in the BIOS, but it is | ||||
|  * fully operational during normal computer usage. | ||||
|  * | ||||
|  * For a less heavy-handed approach, enable NKRO via magic key (LShift+RShift+N) | ||||
|  * or via bootmagic (hold SPACE+N while plugging in the keyboard). Once set by | ||||
|  * bootmagic, NKRO mode will always be enabled until it is toggled again during a | ||||
|  * power-up. | ||||
|  * | ||||
|  */ | ||||
| //#define FORCE_NKRO | ||||
|  | ||||
| /* key combination for magic key command */ | ||||
| #define IS_COMMAND() ( \ | ||||
| 	keyboard_report->mods == (MOD_BIT(KC_LSHIFT) | MOD_BIT(KC_RSHIFT)) \ | ||||
| ) | ||||
|  | ||||
| /* | ||||
|  * Feature disable options | ||||
|  *  These options are also useful to firmware size reduction. | ||||
|  */ | ||||
|  | ||||
| /* disable debug print */ | ||||
| //#define NO_DEBUG | ||||
|  | ||||
| /* disable print */ | ||||
| //#define NO_PRINT | ||||
|  | ||||
| /* disable action features */ | ||||
| //#define NO_ACTION_LAYER | ||||
| //#define NO_ACTION_TAPPING | ||||
| //#define NO_ACTION_ONESHOT | ||||
| //#define NO_ACTION_MACRO | ||||
| //#define NO_ACTION_FUNCTION | ||||
|  | ||||
| /* | ||||
|  * MIDI options | ||||
|  */ | ||||
|  | ||||
| /* Prevent use of disabled MIDI features in the keymap */ | ||||
| //#define MIDI_ENABLE_STRICT 1 | ||||
|  | ||||
| /* enable basic MIDI features: | ||||
|    - MIDI notes can be sent when in Music mode is on | ||||
| */ | ||||
| //#define MIDI_BASIC | ||||
|  | ||||
| /* enable advanced MIDI features: | ||||
|    - MIDI notes can be added to the keymap | ||||
|    - Octave shift and transpose | ||||
|    - Virtual sustain, portamento, and modulation wheel | ||||
|    - etc. | ||||
| */ | ||||
| //#define MIDI_ADVANCED | ||||
|  | ||||
| /* override number of MIDI tone keycodes (each octave adds 12 keycodes and allocates 12 bytes) */ | ||||
| //#define MIDI_TONE_KEYCODE_OCTAVES 1 | ||||
|  | ||||
| #define WS2812_LED_N 2 | ||||
| #define RGBLED_NUM WS2812_LED_N | ||||
| #define WS2812_TIM_N 2 | ||||
| #define WS2812_TIM_CH 2 | ||||
| #define PORT_WS2812     GPIOA | ||||
| #define PIN_WS2812      1 | ||||
| #define WS2812_DMA_STREAM STM32_DMA1_STREAM2  // DMA stream for TIMx_UP (look up in reference manual under DMA Channel selection) | ||||
| //#define WS2812_DMA_CHANNEL 7                  // DMA channel for TIMx_UP | ||||
| //#define WS2812_EXTERNAL_PULLUP | ||||
|  | ||||
| #endif | ||||
							
								
								
									
										388
									
								
								keyboards/planck/rev6/halconf.h
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										388
									
								
								keyboards/planck/rev6/halconf.h
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,388 @@ | ||||
| /* | ||||
|     ChibiOS - Copyright (C) 2006..2016 Giovanni Di Sirio | ||||
|  | ||||
|     Licensed under the Apache License, Version 2.0 (the "License"); | ||||
|     you may not use this file except in compliance with the License. | ||||
|     You may obtain a copy of the License at | ||||
|  | ||||
|         http://www.apache.org/licenses/LICENSE-2.0 | ||||
|  | ||||
|     Unless required by applicable law or agreed to in writing, software | ||||
|     distributed under the License is distributed on an "AS IS" BASIS, | ||||
|     WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. | ||||
|     See the License for the specific language governing permissions and | ||||
|     limitations under the License. | ||||
| */ | ||||
|  | ||||
| /** | ||||
|  * @file    templates/halconf.h | ||||
|  * @brief   HAL configuration header. | ||||
|  * @details HAL configuration file, this file allows to enable or disable the | ||||
|  *          various device drivers from your application. You may also use | ||||
|  *          this file in order to override the device drivers default settings. | ||||
|  * | ||||
|  * @addtogroup HAL_CONF | ||||
|  * @{ | ||||
|  */ | ||||
|  | ||||
| #ifndef HALCONF_H | ||||
| #define HALCONF_H | ||||
|  | ||||
| #include "mcuconf.h" | ||||
|  | ||||
| /** | ||||
|  * @brief   Enables the PAL subsystem. | ||||
|  */ | ||||
| #if !defined(HAL_USE_PAL) || defined(__DOXYGEN__) | ||||
| #define HAL_USE_PAL                 TRUE | ||||
| #endif | ||||
|  | ||||
| /** | ||||
|  * @brief   Enables the ADC subsystem. | ||||
|  */ | ||||
| #if !defined(HAL_USE_ADC) || defined(__DOXYGEN__) | ||||
| #define HAL_USE_ADC                 FALSE | ||||
| #endif | ||||
|  | ||||
| /** | ||||
|  * @brief   Enables the CAN subsystem. | ||||
|  */ | ||||
| #if !defined(HAL_USE_CAN) || defined(__DOXYGEN__) | ||||
| #define HAL_USE_CAN                 FALSE | ||||
| #endif | ||||
|  | ||||
| /** | ||||
|  * @brief   Enables the DAC subsystem. | ||||
|  */ | ||||
| #if !defined(HAL_USE_DAC) || defined(__DOXYGEN__) | ||||
| #define HAL_USE_DAC                 TRUE | ||||
| #endif | ||||
|  | ||||
| /** | ||||
|  * @brief   Enables the EXT subsystem. | ||||
|  */ | ||||
| #if !defined(HAL_USE_EXT) || defined(__DOXYGEN__) | ||||
| #define HAL_USE_EXT                 FALSE | ||||
| #endif | ||||
|  | ||||
| /** | ||||
|  * @brief   Enables the GPT subsystem. | ||||
|  */ | ||||
| #if !defined(HAL_USE_GPT) || defined(__DOXYGEN__) | ||||
| #define HAL_USE_GPT                 TRUE | ||||
| #endif | ||||
|  | ||||
| /** | ||||
|  * @brief   Enables the I2C subsystem. | ||||
|  */ | ||||
| #if !defined(HAL_USE_I2C) || defined(__DOXYGEN__) | ||||
| #define HAL_USE_I2C                 FALSE | ||||
| #endif | ||||
|  | ||||
| /** | ||||
|  * @brief   Enables the I2S subsystem. | ||||
|  */ | ||||
| #if !defined(HAL_USE_I2S) || defined(__DOXYGEN__) | ||||
| #define HAL_USE_I2S                 FALSE | ||||
| #endif | ||||
|  | ||||
| /** | ||||
|  * @brief   Enables the ICU subsystem. | ||||
|  */ | ||||
| #if !defined(HAL_USE_ICU) || defined(__DOXYGEN__) | ||||
| #define HAL_USE_ICU                 FALSE | ||||
| #endif | ||||
|  | ||||
| /** | ||||
|  * @brief   Enables the MAC subsystem. | ||||
|  */ | ||||
| #if !defined(HAL_USE_MAC) || defined(__DOXYGEN__) | ||||
| #define HAL_USE_MAC                 FALSE | ||||
| #endif | ||||
|  | ||||
| /** | ||||
|  * @brief   Enables the MMC_SPI subsystem. | ||||
|  */ | ||||
| #if !defined(HAL_USE_MMC_SPI) || defined(__DOXYGEN__) | ||||
| #define HAL_USE_MMC_SPI             FALSE | ||||
| #endif | ||||
|  | ||||
| /** | ||||
|  * @brief   Enables the PWM subsystem. | ||||
|  */ | ||||
| #if !defined(HAL_USE_PWM) || defined(__DOXYGEN__) | ||||
| #define HAL_USE_PWM                 TRUE | ||||
| #endif | ||||
|  | ||||
| /** | ||||
|  * @brief   Enables the QSPI subsystem. | ||||
|  */ | ||||
| #if !defined(HAL_USE_QSPI) || defined(__DOXYGEN__) | ||||
| #define HAL_USE_QSPI                FALSE | ||||
| #endif | ||||
|  | ||||
| /** | ||||
|  * @brief   Enables the RTC subsystem. | ||||
|  */ | ||||
| #if !defined(HAL_USE_RTC) || defined(__DOXYGEN__) | ||||
| #define HAL_USE_RTC                 FALSE | ||||
| #endif | ||||
|  | ||||
| /** | ||||
|  * @brief   Enables the SDC subsystem. | ||||
|  */ | ||||
| #if !defined(HAL_USE_SDC) || defined(__DOXYGEN__) | ||||
| #define HAL_USE_SDC                 FALSE | ||||
| #endif | ||||
|  | ||||
| /** | ||||
|  * @brief   Enables the SERIAL subsystem. | ||||
|  */ | ||||
| #if !defined(HAL_USE_SERIAL) || defined(__DOXYGEN__) | ||||
| #define HAL_USE_SERIAL              FALSE | ||||
| #endif | ||||
|  | ||||
| /** | ||||
|  * @brief   Enables the SERIAL over USB subsystem. | ||||
|  */ | ||||
| #if !defined(HAL_USE_SERIAL_USB) || defined(__DOXYGEN__) | ||||
| #define HAL_USE_SERIAL_USB          TRUE | ||||
| #endif | ||||
|  | ||||
| /** | ||||
|  * @brief   Enables the SPI subsystem. | ||||
|  */ | ||||
| #if !defined(HAL_USE_SPI) || defined(__DOXYGEN__) | ||||
| #define HAL_USE_SPI                 FALSE | ||||
| #endif | ||||
|  | ||||
| /** | ||||
|  * @brief   Enables the UART subsystem. | ||||
|  */ | ||||
| #if !defined(HAL_USE_UART) || defined(__DOXYGEN__) | ||||
| #define HAL_USE_UART                FALSE | ||||
| #endif | ||||
|  | ||||
| /** | ||||
|  * @brief   Enables the USB subsystem. | ||||
|  */ | ||||
| #if !defined(HAL_USE_USB) || defined(__DOXYGEN__) | ||||
| #define HAL_USE_USB                 TRUE | ||||
| #endif | ||||
|  | ||||
| /** | ||||
|  * @brief   Enables the WDG subsystem. | ||||
|  */ | ||||
| #if !defined(HAL_USE_WDG) || defined(__DOXYGEN__) | ||||
| #define HAL_USE_WDG                 FALSE | ||||
| #endif | ||||
|  | ||||
| /*===========================================================================*/ | ||||
| /* ADC driver related settings.                                              */ | ||||
| /*===========================================================================*/ | ||||
|  | ||||
| /** | ||||
|  * @brief   Enables synchronous APIs. | ||||
|  * @note    Disabling this option saves both code and data space. | ||||
|  */ | ||||
| #if !defined(ADC_USE_WAIT) || defined(__DOXYGEN__) | ||||
| #define ADC_USE_WAIT                TRUE | ||||
| #endif | ||||
|  | ||||
| /** | ||||
|  * @brief   Enables the @p adcAcquireBus() and @p adcReleaseBus() APIs. | ||||
|  * @note    Disabling this option saves both code and data space. | ||||
|  */ | ||||
| #if !defined(ADC_USE_MUTUAL_EXCLUSION) || defined(__DOXYGEN__) | ||||
| #define ADC_USE_MUTUAL_EXCLUSION    TRUE | ||||
| #endif | ||||
|  | ||||
| /*===========================================================================*/ | ||||
| /* CAN driver related settings.                                              */ | ||||
| /*===========================================================================*/ | ||||
|  | ||||
| /** | ||||
|  * @brief   Sleep mode related APIs inclusion switch. | ||||
|  */ | ||||
| #if !defined(CAN_USE_SLEEP_MODE) || defined(__DOXYGEN__) | ||||
| #define CAN_USE_SLEEP_MODE          TRUE | ||||
| #endif | ||||
|  | ||||
| /*===========================================================================*/ | ||||
| /* I2C driver related settings.                                              */ | ||||
| /*===========================================================================*/ | ||||
|  | ||||
| /** | ||||
|  * @brief   Enables the mutual exclusion APIs on the I2C bus. | ||||
|  */ | ||||
| #if !defined(I2C_USE_MUTUAL_EXCLUSION) || defined(__DOXYGEN__) | ||||
| #define I2C_USE_MUTUAL_EXCLUSION    TRUE | ||||
| #endif | ||||
|  | ||||
| /*===========================================================================*/ | ||||
| /* MAC driver related settings.                                              */ | ||||
| /*===========================================================================*/ | ||||
|  | ||||
| /** | ||||
|  * @brief   Enables an event sources for incoming packets. | ||||
|  */ | ||||
| #if !defined(MAC_USE_ZERO_COPY) || defined(__DOXYGEN__) | ||||
| #define MAC_USE_ZERO_COPY           FALSE | ||||
| #endif | ||||
|  | ||||
| /** | ||||
|  * @brief   Enables an event sources for incoming packets. | ||||
|  */ | ||||
| #if !defined(MAC_USE_EVENTS) || defined(__DOXYGEN__) | ||||
| #define MAC_USE_EVENTS              TRUE | ||||
| #endif | ||||
|  | ||||
| /*===========================================================================*/ | ||||
| /* MMC_SPI driver related settings.                                          */ | ||||
| /*===========================================================================*/ | ||||
|  | ||||
| /** | ||||
|  * @brief   Delays insertions. | ||||
|  * @details If enabled this options inserts delays into the MMC waiting | ||||
|  *          routines releasing some extra CPU time for the threads with | ||||
|  *          lower priority, this may slow down the driver a bit however. | ||||
|  *          This option is recommended also if the SPI driver does not | ||||
|  *          use a DMA channel and heavily loads the CPU. | ||||
|  */ | ||||
| #if !defined(MMC_NICE_WAITING) || defined(__DOXYGEN__) | ||||
| #define MMC_NICE_WAITING            TRUE | ||||
| #endif | ||||
|  | ||||
| /*===========================================================================*/ | ||||
| /* SDC driver related settings.                                              */ | ||||
| /*===========================================================================*/ | ||||
|  | ||||
| /** | ||||
|  * @brief   Number of initialization attempts before rejecting the card. | ||||
|  * @note    Attempts are performed at 10mS intervals. | ||||
|  */ | ||||
| #if !defined(SDC_INIT_RETRY) || defined(__DOXYGEN__) | ||||
| #define SDC_INIT_RETRY              100 | ||||
| #endif | ||||
|  | ||||
| /** | ||||
|  * @brief   Include support for MMC cards. | ||||
|  * @note    MMC support is not yet implemented so this option must be kept | ||||
|  *          at @p FALSE. | ||||
|  */ | ||||
| #if !defined(SDC_MMC_SUPPORT) || defined(__DOXYGEN__) | ||||
| #define SDC_MMC_SUPPORT             FALSE | ||||
| #endif | ||||
|  | ||||
| /** | ||||
|  * @brief   Delays insertions. | ||||
|  * @details If enabled this options inserts delays into the MMC waiting | ||||
|  *          routines releasing some extra CPU time for the threads with | ||||
|  *          lower priority, this may slow down the driver a bit however. | ||||
|  */ | ||||
| #if !defined(SDC_NICE_WAITING) || defined(__DOXYGEN__) | ||||
| #define SDC_NICE_WAITING            TRUE | ||||
| #endif | ||||
|  | ||||
| /*===========================================================================*/ | ||||
| /* SERIAL driver related settings.                                           */ | ||||
| /*===========================================================================*/ | ||||
|  | ||||
| /** | ||||
|  * @brief   Default bit rate. | ||||
|  * @details Configuration parameter, this is the baud rate selected for the | ||||
|  *          default configuration. | ||||
|  */ | ||||
| #if !defined(SERIAL_DEFAULT_BITRATE) || defined(__DOXYGEN__) | ||||
| #define SERIAL_DEFAULT_BITRATE      38400 | ||||
| #endif | ||||
|  | ||||
| /** | ||||
|  * @brief   Serial buffers size. | ||||
|  * @details Configuration parameter, you can change the depth of the queue | ||||
|  *          buffers depending on the requirements of your application. | ||||
|  * @note    The default is 16 bytes for both the transmission and receive | ||||
|  *          buffers. | ||||
|  */ | ||||
| #if !defined(SERIAL_BUFFERS_SIZE) || defined(__DOXYGEN__) | ||||
| #define SERIAL_BUFFERS_SIZE         16 | ||||
| #endif | ||||
|  | ||||
| /*===========================================================================*/ | ||||
| /* SERIAL_USB driver related setting.                                        */ | ||||
| /*===========================================================================*/ | ||||
|  | ||||
| /** | ||||
|  * @brief   Serial over USB buffers size. | ||||
|  * @details Configuration parameter, the buffer size must be a multiple of | ||||
|  *          the USB data endpoint maximum packet size. | ||||
|  * @note    The default is 256 bytes for both the transmission and receive | ||||
|  *          buffers. | ||||
|  */ | ||||
| #if !defined(SERIAL_USB_BUFFERS_SIZE) || defined(__DOXYGEN__) | ||||
| #define SERIAL_USB_BUFFERS_SIZE     1 | ||||
| #endif | ||||
|  | ||||
| /** | ||||
|  * @brief   Serial over USB number of buffers. | ||||
|  * @note    The default is 2 buffers. | ||||
|  */ | ||||
| #if !defined(SERIAL_USB_BUFFERS_NUMBER) || defined(__DOXYGEN__) | ||||
| #define SERIAL_USB_BUFFERS_NUMBER   2 | ||||
| #endif | ||||
|  | ||||
| /*===========================================================================*/ | ||||
| /* SPI driver related settings.                                              */ | ||||
| /*===========================================================================*/ | ||||
|  | ||||
| /** | ||||
|  * @brief   Enables synchronous APIs. | ||||
|  * @note    Disabling this option saves both code and data space. | ||||
|  */ | ||||
| #if !defined(SPI_USE_WAIT) || defined(__DOXYGEN__) | ||||
| #define SPI_USE_WAIT                TRUE | ||||
| #endif | ||||
|  | ||||
| /** | ||||
|  * @brief   Enables the @p spiAcquireBus() and @p spiReleaseBus() APIs. | ||||
|  * @note    Disabling this option saves both code and data space. | ||||
|  */ | ||||
| #if !defined(SPI_USE_MUTUAL_EXCLUSION) || defined(__DOXYGEN__) | ||||
| #define SPI_USE_MUTUAL_EXCLUSION    TRUE | ||||
| #endif | ||||
|  | ||||
| /*===========================================================================*/ | ||||
| /* UART driver related settings.                                             */ | ||||
| /*===========================================================================*/ | ||||
|  | ||||
| /** | ||||
|  * @brief   Enables synchronous APIs. | ||||
|  * @note    Disabling this option saves both code and data space. | ||||
|  */ | ||||
| #if !defined(UART_USE_WAIT) || defined(__DOXYGEN__) | ||||
| #define UART_USE_WAIT               FALSE | ||||
| #endif | ||||
|  | ||||
| /** | ||||
|  * @brief   Enables the @p uartAcquireBus() and @p uartReleaseBus() APIs. | ||||
|  * @note    Disabling this option saves both code and data space. | ||||
|  */ | ||||
| #if !defined(UART_USE_MUTUAL_EXCLUSION) || defined(__DOXYGEN__) | ||||
| #define UART_USE_MUTUAL_EXCLUSION   FALSE | ||||
| #endif | ||||
|  | ||||
| /*===========================================================================*/ | ||||
| /* USB driver related settings.                                              */ | ||||
| /*===========================================================================*/ | ||||
|  | ||||
| /** | ||||
|  * @brief   Enables synchronous APIs. | ||||
|  * @note    Disabling this option saves both code and data space. | ||||
|  */ | ||||
| #if !defined(USB_USE_WAIT) || defined(__DOXYGEN__) | ||||
| #define USB_USE_WAIT                TRUE | ||||
| #endif | ||||
|  | ||||
| #endif /* HALCONF_H */ | ||||
|  | ||||
| /** @} */ | ||||
							
								
								
									
										208
									
								
								keyboards/planck/rev6/matrix.c
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										208
									
								
								keyboards/planck/rev6/matrix.c
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,208 @@ | ||||
| #include <stdint.h> | ||||
| #include <stdbool.h> | ||||
| #include <string.h> | ||||
| #include "hal.h" | ||||
| #include "timer.h" | ||||
| #include "wait.h" | ||||
| #include "printf.h" | ||||
| #include "backlight.h" | ||||
| #include "matrix.h" | ||||
| #include "action.h" | ||||
| #include "keycode.h" | ||||
| #include <string.h> | ||||
|  | ||||
| /* | ||||
|  *     col: { B11, B10, B2, B1, A7, B0 } | ||||
|  *     row: { A10, A9, A8, B15, C13, C14, C15, A2 } | ||||
|  */ | ||||
| /* matrix state(1:on, 0:off) */ | ||||
| static matrix_row_t matrix[MATRIX_ROWS]; | ||||
| static matrix_row_t matrix_debouncing[MATRIX_COLS]; | ||||
| static bool debouncing = false; | ||||
| static uint16_t debouncing_time = 0; | ||||
|  | ||||
| static uint8_t encoder_state = 0; | ||||
| static int8_t encoder_value = 0; | ||||
| static int8_t encoder_LUT[] = { 0, -1, 1, 0, 1, 0, 0, -1, -1, 0, 0, 1, 0, 1, -1, 0 }; | ||||
|  | ||||
| static bool dip_switch[4] = {0, 0, 0, 0}; | ||||
|  | ||||
| __attribute__ ((weak)) | ||||
| void matrix_init_user(void) {} | ||||
|  | ||||
| __attribute__ ((weak)) | ||||
| void matrix_scan_user(void) {} | ||||
|  | ||||
| __attribute__ ((weak)) | ||||
| void matrix_init_kb(void) { | ||||
|   matrix_init_user(); | ||||
| } | ||||
|  | ||||
| __attribute__ ((weak)) | ||||
| void matrix_scan_kb(void) { | ||||
|   matrix_scan_user(); | ||||
| } | ||||
|  | ||||
| void matrix_init(void) { | ||||
|     printf("matrix init\n"); | ||||
|     //debug_matrix = true; | ||||
|  | ||||
|     // dip switch setup | ||||
|     palSetPadMode(GPIOB, 14, PAL_MODE_INPUT_PULLUP); | ||||
|     palSetPadMode(GPIOA, 15, PAL_MODE_INPUT_PULLUP); | ||||
|     palSetPadMode(GPIOA, 10, PAL_MODE_INPUT_PULLUP); | ||||
|     palSetPadMode(GPIOB, 9,  PAL_MODE_INPUT_PULLUP); | ||||
|  | ||||
|     // encoder setup | ||||
|     palSetPadMode(GPIOB, 12, PAL_MODE_INPUT_PULLUP); | ||||
|     palSetPadMode(GPIOB, 13, PAL_MODE_INPUT_PULLUP); | ||||
|  | ||||
|     encoder_state = (palReadPad(GPIOB, 12) << 0) | (palReadPad(GPIOB, 13) << 1); | ||||
|  | ||||
|     // actual matrix setup | ||||
|     palSetPadMode(GPIOB, 11, PAL_MODE_OUTPUT_PUSHPULL); | ||||
|     palSetPadMode(GPIOB, 10, PAL_MODE_OUTPUT_PUSHPULL); | ||||
|     palSetPadMode(GPIOB, 2,  PAL_MODE_OUTPUT_PUSHPULL); | ||||
|     palSetPadMode(GPIOB, 1,  PAL_MODE_OUTPUT_PUSHPULL); | ||||
|     palSetPadMode(GPIOA, 7,  PAL_MODE_OUTPUT_PUSHPULL); | ||||
|     palSetPadMode(GPIOB, 0,  PAL_MODE_OUTPUT_PUSHPULL); | ||||
|  | ||||
|     palSetPadMode(GPIOA, 10, PAL_MODE_INPUT_PULLDOWN); | ||||
|     palSetPadMode(GPIOA, 9,  PAL_MODE_INPUT_PULLDOWN); | ||||
|     palSetPadMode(GPIOA, 8,  PAL_MODE_INPUT_PULLDOWN); | ||||
|     palSetPadMode(GPIOB, 15, PAL_MODE_INPUT_PULLDOWN); | ||||
|     palSetPadMode(GPIOC, 13, PAL_MODE_INPUT_PULLDOWN); | ||||
|     palSetPadMode(GPIOC, 14, PAL_MODE_INPUT_PULLDOWN); | ||||
|     palSetPadMode(GPIOC, 15, PAL_MODE_INPUT_PULLDOWN); | ||||
|     palSetPadMode(GPIOA, 2,  PAL_MODE_INPUT_PULLDOWN); | ||||
|  | ||||
|  | ||||
|     memset(matrix, 0, MATRIX_ROWS * sizeof(matrix_row_t)); | ||||
|     memset(matrix_debouncing, 0, MATRIX_COLS * sizeof(matrix_row_t)); | ||||
|  | ||||
|  | ||||
|     matrix_init_quantum(); | ||||
| } | ||||
|  | ||||
| __attribute__ ((weak)) | ||||
| void dip_update(uint8_t index, bool active) { } | ||||
|  | ||||
| __attribute__ ((weak)) | ||||
| void encoder_update(bool clockwise) { } | ||||
|  | ||||
| bool last_dip_switch[4] = {0}; | ||||
|  | ||||
| #ifndef ENCODER_RESOLUTION | ||||
|   #define ENCODER_RESOLUTION 4 | ||||
| #endif | ||||
|  | ||||
| #define COUNTRECLOCKWISE 0 | ||||
| #define CLOCKWISE 1 | ||||
|  | ||||
| uint8_t matrix_scan(void) { | ||||
|     // dip switch | ||||
|     dip_switch[0] = !palReadPad(GPIOB, 14); | ||||
|     dip_switch[1] = !palReadPad(GPIOA, 15); | ||||
|     dip_switch[2] = !palReadPad(GPIOA, 10); | ||||
|     dip_switch[3] = !palReadPad(GPIOB, 9); | ||||
|     for (uint8_t i = 0; i < 4; i++) { | ||||
|       if (last_dip_switch[i] ^ dip_switch[i]) | ||||
|         dip_update(i, dip_switch[i]); | ||||
|     } | ||||
|     memcpy(last_dip_switch, dip_switch, sizeof(&dip_switch)); | ||||
|  | ||||
|     // encoder on B12 and B13 | ||||
|     encoder_state <<= 2; | ||||
|     encoder_state |= (palReadPad(GPIOB, 12) << 0) | (palReadPad(GPIOB, 13) << 1); | ||||
|     encoder_value += encoder_LUT[encoder_state & 0xF]; | ||||
|     if (encoder_value >= ENCODER_RESOLUTION) { | ||||
|         encoder_update(COUNTRECLOCKWISE); | ||||
|     } | ||||
|     if (encoder_value <= -ENCODER_RESOLUTION) { // direction is arbitrary here, but this clockwise | ||||
|         encoder_update(CLOCKWISE); | ||||
|     } | ||||
|     encoder_value %= ENCODER_RESOLUTION; | ||||
|  | ||||
|     // actual matrix | ||||
|     for (int col = 0; col < MATRIX_COLS; col++) { | ||||
|         matrix_row_t data = 0; | ||||
|  | ||||
|         // strobe col { B11, B10, B2, B1, A7, B0 } | ||||
|         switch (col) { | ||||
|             case 0: palSetPad(GPIOB, 11); break; | ||||
|             case 1: palSetPad(GPIOB, 10); break; | ||||
|             case 2: palSetPad(GPIOB, 2); break; | ||||
|             case 3: palSetPad(GPIOB, 1); break; | ||||
|             case 4: palSetPad(GPIOA, 7); break; | ||||
|             case 5: palSetPad(GPIOB, 0); break; | ||||
|         } | ||||
|  | ||||
|         // need wait to settle pin state | ||||
|         wait_us(20); | ||||
|  | ||||
|         // read row data { A10, A9, A8, B15, C13, C14, C15, A2 } | ||||
|         data = ( | ||||
|             (palReadPad(GPIOA, 10) << 0 ) | | ||||
|             (palReadPad(GPIOA, 9)  << 1 ) | | ||||
|             (palReadPad(GPIOA, 8)  << 2 ) | | ||||
|             (palReadPad(GPIOB, 15) << 3 ) | | ||||
|             (palReadPad(GPIOC, 13) << 4 ) | | ||||
|             (palReadPad(GPIOC, 14) << 5 ) | | ||||
|             (palReadPad(GPIOC, 15) << 6 ) | | ||||
|             (palReadPad(GPIOA, 2)  << 7 ) | ||||
|         ); | ||||
|  | ||||
|         // unstrobe  col { B11, B10, B2, B1, A7, B0 } | ||||
|         switch (col) { | ||||
|             case 0: palClearPad(GPIOB, 11); break; | ||||
|             case 1: palClearPad(GPIOB, 10); break; | ||||
|             case 2: palClearPad(GPIOB, 2); break; | ||||
|             case 3: palClearPad(GPIOB, 1); break; | ||||
|             case 4: palClearPad(GPIOA, 7); break; | ||||
|             case 5: palClearPad(GPIOB, 0); break; | ||||
|         } | ||||
|  | ||||
|         if (matrix_debouncing[col] != data) { | ||||
|             matrix_debouncing[col] = data; | ||||
|             debouncing = true; | ||||
|             debouncing_time = timer_read(); | ||||
|         } | ||||
|     } | ||||
|  | ||||
|     if (debouncing && timer_elapsed(debouncing_time) > DEBOUNCE) { | ||||
|         for (int row = 0; row < MATRIX_ROWS; row++) { | ||||
|             matrix[row] = 0; | ||||
|             for (int col = 0; col < MATRIX_COLS; col++) { | ||||
|                 matrix[row] |= ((matrix_debouncing[col] & (1 << row) ? 1 : 0) << col); | ||||
|             } | ||||
|         } | ||||
|         debouncing = false; | ||||
|     } | ||||
|  | ||||
|     matrix_scan_quantum(); | ||||
|  | ||||
|     return 1; | ||||
| } | ||||
|  | ||||
| bool matrix_is_on(uint8_t row, uint8_t col) { | ||||
|     return (matrix[row] & (1<<col)); | ||||
| } | ||||
|  | ||||
| matrix_row_t matrix_get_row(uint8_t row) { | ||||
|     return matrix[row]; | ||||
| } | ||||
|  | ||||
| void matrix_print(void) { | ||||
|     printf("\nr/c 01234567\n"); | ||||
|     for (uint8_t row = 0; row < MATRIX_ROWS; row++) { | ||||
|         printf("%X0: ", row); | ||||
|         matrix_row_t data = matrix_get_row(row); | ||||
|         for (int col = 0; col < MATRIX_COLS; col++) { | ||||
|             if (data & (1<<col)) | ||||
|                 printf("1"); | ||||
|             else | ||||
|                 printf("0"); | ||||
|         } | ||||
|         printf("\n"); | ||||
|     } | ||||
| } | ||||
							
								
								
									
										257
									
								
								keyboards/planck/rev6/mcuconf.h
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										257
									
								
								keyboards/planck/rev6/mcuconf.h
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,257 @@ | ||||
| /* | ||||
|     ChibiOS - Copyright (C) 2006..2016 Giovanni Di Sirio | ||||
|  | ||||
|     Licensed under the Apache License, Version 2.0 (the "License"); | ||||
|     you may not use this file except in compliance with the License. | ||||
|     You may obtain a copy of the License at | ||||
|  | ||||
|         http://www.apache.org/licenses/LICENSE-2.0 | ||||
|  | ||||
|     Unless required by applicable law or agreed to in writing, software | ||||
|     distributed under the License is distributed on an "AS IS" BASIS, | ||||
|     WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. | ||||
|     See the License for the specific language governing permissions and | ||||
|     limitations under the License. | ||||
| */ | ||||
|  | ||||
| #ifndef MCUCONF_H | ||||
| #define MCUCONF_H | ||||
|  | ||||
| /* | ||||
|  * STM32F3xx drivers configuration. | ||||
|  * The following settings override the default settings present in | ||||
|  * the various device driver implementation headers. | ||||
|  * Note that the settings for each driver only have effect if the whole | ||||
|  * driver is enabled in halconf.h. | ||||
|  * | ||||
|  * IRQ priorities: | ||||
|  * 15...0       Lowest...Highest. | ||||
|  * | ||||
|  * DMA priorities: | ||||
|  * 0...3        Lowest...Highest. | ||||
|  */ | ||||
|  | ||||
| #define STM32F3xx_MCUCONF | ||||
|  | ||||
| /* | ||||
|  * HAL driver system settings. | ||||
|  */ | ||||
| #define STM32_NO_INIT                       FALSE | ||||
| #define STM32_PVD_ENABLE                    FALSE | ||||
| #define STM32_PLS                           STM32_PLS_LEV0 | ||||
| #define STM32_HSI_ENABLED                   TRUE | ||||
| #define STM32_LSI_ENABLED                   TRUE | ||||
| #define STM32_HSE_ENABLED                   TRUE | ||||
| #define STM32_LSE_ENABLED                   FALSE | ||||
| #define STM32_SW                            STM32_SW_PLL | ||||
| #define STM32_PLLSRC                        STM32_PLLSRC_HSE | ||||
| #define STM32_PREDIV_VALUE                  1 | ||||
| #define STM32_PLLMUL_VALUE                  9 | ||||
| #define STM32_HPRE                          STM32_HPRE_DIV1 | ||||
| #define STM32_PPRE1                         STM32_PPRE1_DIV2 | ||||
| #define STM32_PPRE2                         STM32_PPRE2_DIV2 | ||||
| #define STM32_MCOSEL                        STM32_MCOSEL_NOCLOCK | ||||
| #define STM32_ADC12PRES                     STM32_ADC12PRES_DIV1 | ||||
| #define STM32_ADC34PRES                     STM32_ADC34PRES_DIV1 | ||||
| #define STM32_USART1SW                      STM32_USART1SW_PCLK | ||||
| #define STM32_USART2SW                      STM32_USART2SW_PCLK | ||||
| #define STM32_USART3SW                      STM32_USART3SW_PCLK | ||||
| #define STM32_UART4SW                       STM32_UART4SW_PCLK | ||||
| #define STM32_UART5SW                       STM32_UART5SW_PCLK | ||||
| #define STM32_I2C1SW                        STM32_I2C1SW_SYSCLK | ||||
| #define STM32_I2C2SW                        STM32_I2C2SW_SYSCLK | ||||
| #define STM32_TIM1SW                        STM32_TIM1SW_PCLK2 | ||||
| #define STM32_TIM8SW                        STM32_TIM8SW_PCLK2 | ||||
| #define STM32_RTCSEL                        STM32_RTCSEL_LSI | ||||
| #define STM32_USB_CLOCK_REQUIRED            TRUE | ||||
| #define STM32_USBPRE                        STM32_USBPRE_DIV1P5 | ||||
|  | ||||
| #undef STM32_HSE_BYPASS | ||||
| // #error "oh no" | ||||
| // #endif | ||||
|  | ||||
| /* | ||||
|  * ADC driver system settings. | ||||
|  */ | ||||
| #define STM32_ADC_DUAL_MODE                 FALSE | ||||
| #define STM32_ADC_COMPACT_SAMPLES           FALSE | ||||
| #define STM32_ADC_USE_ADC1                  FALSE | ||||
| #define STM32_ADC_USE_ADC2                  FALSE | ||||
| #define STM32_ADC_USE_ADC3                  FALSE | ||||
| #define STM32_ADC_USE_ADC4                  FALSE | ||||
| #define STM32_ADC_ADC1_DMA_STREAM           STM32_DMA_STREAM_ID(1, 1) | ||||
| #define STM32_ADC_ADC2_DMA_STREAM           STM32_DMA_STREAM_ID(2, 1) | ||||
| #define STM32_ADC_ADC3_DMA_STREAM           STM32_DMA_STREAM_ID(2, 5) | ||||
| #define STM32_ADC_ADC4_DMA_STREAM           STM32_DMA_STREAM_ID(2, 2) | ||||
| #define STM32_ADC_ADC1_DMA_PRIORITY         2 | ||||
| #define STM32_ADC_ADC2_DMA_PRIORITY         2 | ||||
| #define STM32_ADC_ADC3_DMA_PRIORITY         2 | ||||
| #define STM32_ADC_ADC4_DMA_PRIORITY         2 | ||||
| #define STM32_ADC_ADC12_IRQ_PRIORITY        5 | ||||
| #define STM32_ADC_ADC3_IRQ_PRIORITY         5 | ||||
| #define STM32_ADC_ADC4_IRQ_PRIORITY         5 | ||||
| #define STM32_ADC_ADC1_DMA_IRQ_PRIORITY     5 | ||||
| #define STM32_ADC_ADC2_DMA_IRQ_PRIORITY     5 | ||||
| #define STM32_ADC_ADC3_DMA_IRQ_PRIORITY     5 | ||||
| #define STM32_ADC_ADC4_DMA_IRQ_PRIORITY     5 | ||||
| #define STM32_ADC_ADC12_CLOCK_MODE          ADC_CCR_CKMODE_AHB_DIV1 | ||||
| #define STM32_ADC_ADC34_CLOCK_MODE          ADC_CCR_CKMODE_AHB_DIV1 | ||||
|  | ||||
| /* | ||||
|  * CAN driver system settings. | ||||
|  */ | ||||
| #define STM32_CAN_USE_CAN1                  FALSE | ||||
| #define STM32_CAN_CAN1_IRQ_PRIORITY         11 | ||||
|  | ||||
| /* | ||||
|  * DAC driver system settings. | ||||
|  */ | ||||
| #define STM32_DAC_DUAL_MODE                 FALSE | ||||
| #define STM32_DAC_USE_DAC1_CH1              TRUE | ||||
| #define STM32_DAC_USE_DAC1_CH2              TRUE | ||||
| #define STM32_DAC_DAC1_CH1_IRQ_PRIORITY     10 | ||||
| #define STM32_DAC_DAC1_CH2_IRQ_PRIORITY     10 | ||||
| #define STM32_DAC_DAC1_CH1_DMA_PRIORITY     2 | ||||
| #define STM32_DAC_DAC1_CH2_DMA_PRIORITY     2 | ||||
|  | ||||
| /* | ||||
|  * EXT driver system settings. | ||||
|  */ | ||||
| #define STM32_EXT_EXTI0_IRQ_PRIORITY        6 | ||||
| #define STM32_EXT_EXTI1_IRQ_PRIORITY        6 | ||||
| #define STM32_EXT_EXTI2_IRQ_PRIORITY        6 | ||||
| #define STM32_EXT_EXTI3_IRQ_PRIORITY        6 | ||||
| #define STM32_EXT_EXTI4_IRQ_PRIORITY        6 | ||||
| #define STM32_EXT_EXTI5_9_IRQ_PRIORITY      6 | ||||
| #define STM32_EXT_EXTI10_15_IRQ_PRIORITY    6 | ||||
| #define STM32_EXT_EXTI16_IRQ_PRIORITY       6 | ||||
| #define STM32_EXT_EXTI17_IRQ_PRIORITY       6 | ||||
| #define STM32_EXT_EXTI18_IRQ_PRIORITY       6 | ||||
| #define STM32_EXT_EXTI19_IRQ_PRIORITY       6 | ||||
| #define STM32_EXT_EXTI20_IRQ_PRIORITY       6 | ||||
| #define STM32_EXT_EXTI21_22_29_IRQ_PRIORITY 6 | ||||
| #define STM32_EXT_EXTI30_32_IRQ_PRIORITY    6 | ||||
| #define STM32_EXT_EXTI33_IRQ_PRIORITY       6 | ||||
|  | ||||
| /* | ||||
|  * GPT driver system settings. | ||||
|  */ | ||||
| #define STM32_GPT_USE_TIM1                  FALSE | ||||
| #define STM32_GPT_USE_TIM2                  FALSE | ||||
| #define STM32_GPT_USE_TIM3                  FALSE | ||||
| #define STM32_GPT_USE_TIM4                  FALSE | ||||
| #define STM32_GPT_USE_TIM6                  TRUE | ||||
| #define STM32_GPT_USE_TIM7                  TRUE | ||||
| #define STM32_GPT_USE_TIM8                  TRUE | ||||
| #define STM32_GPT_TIM1_IRQ_PRIORITY         7 | ||||
| #define STM32_GPT_TIM2_IRQ_PRIORITY         7 | ||||
| #define STM32_GPT_TIM3_IRQ_PRIORITY         7 | ||||
| #define STM32_GPT_TIM4_IRQ_PRIORITY         7 | ||||
| #define STM32_GPT_TIM6_IRQ_PRIORITY         7 | ||||
| #define STM32_GPT_TIM7_IRQ_PRIORITY         7 | ||||
| #define STM32_GPT_TIM8_IRQ_PRIORITY         7 | ||||
|  | ||||
| /* | ||||
|  * I2C driver system settings. | ||||
|  */ | ||||
| #define STM32_I2C_USE_I2C1                  FALSE | ||||
| #define STM32_I2C_USE_I2C2                  FALSE | ||||
| #define STM32_I2C_BUSY_TIMEOUT              50 | ||||
| #define STM32_I2C_I2C1_IRQ_PRIORITY         10 | ||||
| #define STM32_I2C_I2C2_IRQ_PRIORITY         10 | ||||
| #define STM32_I2C_USE_DMA                   TRUE | ||||
| #define STM32_I2C_I2C1_DMA_PRIORITY         1 | ||||
| #define STM32_I2C_I2C2_DMA_PRIORITY         1 | ||||
| #define STM32_I2C_DMA_ERROR_HOOK(i2cp)      osalSysHalt("DMA failure") | ||||
|  | ||||
| /* | ||||
|  * ICU driver system settings. | ||||
|  */ | ||||
| #define STM32_ICU_USE_TIM1                  FALSE | ||||
| #define STM32_ICU_USE_TIM2                  FALSE | ||||
| #define STM32_ICU_USE_TIM3                  FALSE | ||||
| #define STM32_ICU_USE_TIM4                  FALSE | ||||
| #define STM32_ICU_USE_TIM8                  FALSE | ||||
| #define STM32_ICU_TIM1_IRQ_PRIORITY         7 | ||||
| #define STM32_ICU_TIM2_IRQ_PRIORITY         7 | ||||
| #define STM32_ICU_TIM3_IRQ_PRIORITY         7 | ||||
| #define STM32_ICU_TIM4_IRQ_PRIORITY         7 | ||||
| #define STM32_ICU_TIM8_IRQ_PRIORITY         7 | ||||
|  | ||||
| /* | ||||
|  * PWM driver system settings. | ||||
|  */ | ||||
| #define STM32_PWM_USE_ADVANCED              FALSE | ||||
| #define STM32_PWM_USE_TIM1                  FALSE | ||||
| #define STM32_PWM_USE_TIM2                  TRUE | ||||
| #define STM32_PWM_USE_TIM3                  TRUE | ||||
| #define STM32_PWM_USE_TIM4                  FALSE | ||||
| #define STM32_PWM_USE_TIM8                  FALSE | ||||
| #define STM32_PWM_TIM1_IRQ_PRIORITY         7 | ||||
| #define STM32_PWM_TIM2_IRQ_PRIORITY         7 | ||||
| #define STM32_PWM_TIM3_IRQ_PRIORITY         7 | ||||
| #define STM32_PWM_TIM4_IRQ_PRIORITY         7 | ||||
| #define STM32_PWM_TIM8_IRQ_PRIORITY         7 | ||||
|  | ||||
| /* | ||||
|  * SERIAL driver system settings. | ||||
|  */ | ||||
| #define STM32_SERIAL_USE_USART1             FALSE | ||||
| #define STM32_SERIAL_USE_USART2             TRUE | ||||
| #define STM32_SERIAL_USE_USART3             FALSE | ||||
| #define STM32_SERIAL_USE_UART4              FALSE | ||||
| #define STM32_SERIAL_USE_UART5              FALSE | ||||
| #define STM32_SERIAL_USART1_PRIORITY        12 | ||||
| #define STM32_SERIAL_USART2_PRIORITY        12 | ||||
| #define STM32_SERIAL_USART3_PRIORITY        12 | ||||
| #define STM32_SERIAL_UART4_PRIORITY         12 | ||||
| #define STM32_SERIAL_UART5_PRIORITY         12 | ||||
|  | ||||
| /* | ||||
|  * SPI driver system settings. | ||||
|  */ | ||||
| #define STM32_SPI_USE_SPI1                  FALSE | ||||
| #define STM32_SPI_USE_SPI2                  FALSE | ||||
| #define STM32_SPI_USE_SPI3                  FALSE | ||||
| #define STM32_SPI_SPI1_DMA_PRIORITY         1 | ||||
| #define STM32_SPI_SPI2_DMA_PRIORITY         1 | ||||
| #define STM32_SPI_SPI3_DMA_PRIORITY         1 | ||||
| #define STM32_SPI_SPI1_IRQ_PRIORITY         10 | ||||
| #define STM32_SPI_SPI2_IRQ_PRIORITY         10 | ||||
| #define STM32_SPI_SPI3_IRQ_PRIORITY         10 | ||||
| #define STM32_SPI_DMA_ERROR_HOOK(spip)      osalSysHalt("DMA failure") | ||||
|  | ||||
| /* | ||||
|  * ST driver system settings. | ||||
|  */ | ||||
| #define STM32_ST_IRQ_PRIORITY               8 | ||||
| #define STM32_ST_USE_TIMER                  4 | ||||
|  | ||||
| /* | ||||
|  * UART driver system settings. | ||||
|  */ | ||||
| #define STM32_UART_USE_USART1               FALSE | ||||
| #define STM32_UART_USE_USART2               FALSE | ||||
| #define STM32_UART_USE_USART3               FALSE | ||||
| #define STM32_UART_USART1_IRQ_PRIORITY      12 | ||||
| #define STM32_UART_USART2_IRQ_PRIORITY      12 | ||||
| #define STM32_UART_USART3_IRQ_PRIORITY      12 | ||||
| #define STM32_UART_USART1_DMA_PRIORITY      0 | ||||
| #define STM32_UART_USART2_DMA_PRIORITY      0 | ||||
| #define STM32_UART_USART3_DMA_PRIORITY      0 | ||||
| #define STM32_UART_DMA_ERROR_HOOK(uartp)    osalSysHalt("DMA failure") | ||||
|  | ||||
| /* | ||||
|  * USB driver system settings. | ||||
|  */ | ||||
| #define STM32_USB_USE_USB1                  TRUE | ||||
| #define STM32_USB_LOW_POWER_ON_SUSPEND      FALSE | ||||
| #define STM32_USB_USB1_HP_IRQ_PRIORITY      13 | ||||
| #define STM32_USB_USB1_LP_IRQ_PRIORITY      14 | ||||
|  | ||||
| /* | ||||
|  * WDG driver system settings. | ||||
|  */ | ||||
| #define STM32_WDG_USE_IWDG                  FALSE | ||||
|  | ||||
| #endif /* MCUCONF_H */ | ||||
							
								
								
									
										35
									
								
								keyboards/planck/rev6/rev6.c
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										35
									
								
								keyboards/planck/rev6/rev6.c
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,35 @@ | ||||
| /* Copyright 2018 Jack Humbert <jack.humb@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 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 "rev6.h" | ||||
| #include "rgblight.h" | ||||
|  | ||||
|   uint8_t *o_fb; | ||||
|  | ||||
| void matrix_init_kb(void) { | ||||
|   // rgblight_enable(); | ||||
|   // rgblight_mode(1); | ||||
|   // rgblight_setrgb(0xFF, 0xFF, 0xFF); | ||||
|  | ||||
|   ledDriverInit(2, GPIOA, 0b00000010, &o_fb); | ||||
|   testPatternFB(o_fb); | ||||
|  | ||||
| 	matrix_init_user(); | ||||
| } | ||||
|  | ||||
| void matrix_scan_kb(void) { | ||||
| 	matrix_scan_user(); | ||||
|   testPatternFB(o_fb); | ||||
| } | ||||
							
								
								
									
										21
									
								
								keyboards/planck/rev6/rev6.h
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										21
									
								
								keyboards/planck/rev6/rev6.h
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,21 @@ | ||||
| /* Copyright 2018 Jack Humbert <jack.humb@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 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/>. | ||||
|  */ | ||||
| #ifndef REV6_H | ||||
| #define REV6_H | ||||
|  | ||||
| #include "planck.h" | ||||
|  | ||||
| #endif | ||||
							
								
								
									
										56
									
								
								keyboards/planck/rev6/rules.mk
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										56
									
								
								keyboards/planck/rev6/rules.mk
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,56 @@ | ||||
| # project specific files | ||||
| SRC =	matrix.c | ||||
| LAYOUTS += ortho_4x12 | ||||
|  | ||||
| ## chip/board settings | ||||
| # - the next two should match the directories in | ||||
| #   <chibios>/os/hal/ports/$(MCU_FAMILY)/$(MCU_SERIES) | ||||
| MCU_FAMILY = STM32 | ||||
| MCU_SERIES = STM32F3xx | ||||
|  | ||||
| # Linker script to use | ||||
| # - it should exist either in <chibios>/os/common/ports/ARMCMx/compilers/GCC/ld/ | ||||
| #   or <this_dir>/ld/ | ||||
| MCU_LDSCRIPT = STM32F303xC | ||||
|  | ||||
| # Startup code to use | ||||
| #  - it should exist in <chibios>/os/common/startup/ARMCMx/compilers/GCC/mk/ | ||||
| MCU_STARTUP = stm32f3xx | ||||
|  | ||||
| # Board: it should exist either in <chibios>/os/hal/boards/ | ||||
| #  or <this_dir>/boards | ||||
| BOARD = GENERIC_STM32_F303XC | ||||
|  | ||||
| # Cortex version | ||||
| MCU  = cortex-m4 | ||||
|  | ||||
| # ARM version, CORTEX-M0/M1 are 6, CORTEX-M3/M4/M7 are 7 | ||||
| ARMV = 7 | ||||
|  | ||||
| USE_FPU = yes | ||||
|  | ||||
| # Vector table for application | ||||
| # 0x00000000-0x00001000 area is occupied by bootlaoder.*/ | ||||
| # The CORTEX_VTOR... is needed only for MCHCK/Infinity KB | ||||
| # OPT_DEFS = -DCORTEX_VTOR_INIT=0x08005000 | ||||
| OPT_DEFS = | ||||
|  | ||||
| # Options to pass to dfu-util when flashing | ||||
| DFU_ARGS = -d 0483:df11 -a 0 -s 0x08000000:leave | ||||
|  | ||||
| # Build Options | ||||
| #   comment out to disable the options. | ||||
| # | ||||
| BACKLIGHT_ENABLE = no | ||||
| BOOTMAGIC_ENABLE = yes	# Virtual DIP switch configuration | ||||
| ## (Note that for BOOTMAGIC on Teensy LC you have to use a custom .ld script.) | ||||
| MOUSEKEY_ENABLE = yes	# Mouse keys | ||||
| EXTRAKEY_ENABLE = yes	# Audio control and System control | ||||
| CONSOLE_ENABLE = yes	# Console for debug | ||||
| COMMAND_ENABLE = yes    # Commands for debug and configuration | ||||
| #SLEEP_LED_ENABLE = yes  # Breathing sleep LED during USB suspend | ||||
| NKRO_ENABLE = yes	    # USB Nkey Rollover | ||||
| CUSTOM_MATRIX = yes # Custom matrix file | ||||
| AUDIO_ENABLE = yes | ||||
| RGBLIGHT_ENABLE = yes | ||||
| # SERIAL_LINK_ENABLE = yes | ||||
							
								
								
									
										126
									
								
								keyboards/proton_c/boards/GENERIC_STM32_F303XC/board.c
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										126
									
								
								keyboards/proton_c/boards/GENERIC_STM32_F303XC/board.c
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,126 @@ | ||||
| /* | ||||
|     ChibiOS - Copyright (C) 2006..2016 Giovanni Di Sirio | ||||
|  | ||||
|     Licensed under the Apache License, Version 2.0 (the "License"); | ||||
|     you may not use this file except in compliance with the License. | ||||
|     You may obtain a copy of the License at | ||||
|  | ||||
|         http://www.apache.org/licenses/LICENSE-2.0 | ||||
|  | ||||
|     Unless required by applicable law or agreed to in writing, software | ||||
|     distributed under the License is distributed on an "AS IS" BASIS, | ||||
|     WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. | ||||
|     See the License for the specific language governing permissions and | ||||
|     limitations under the License. | ||||
| */ | ||||
|  | ||||
| #include "hal.h" | ||||
|  | ||||
| #if HAL_USE_PAL || defined(__DOXYGEN__) | ||||
| /** | ||||
|  * @brief   PAL setup. | ||||
|  * @details Digital I/O ports static configuration as defined in @p board.h. | ||||
|  *          This variable is used by the HAL when initializing the PAL driver. | ||||
|  */ | ||||
| const PALConfig pal_default_config = { | ||||
| #if STM32_HAS_GPIOA | ||||
|   {VAL_GPIOA_MODER, VAL_GPIOA_OTYPER, VAL_GPIOA_OSPEEDR, VAL_GPIOA_PUPDR, | ||||
|    VAL_GPIOA_ODR,   VAL_GPIOA_AFRL,   VAL_GPIOA_AFRH}, | ||||
| #endif | ||||
| #if STM32_HAS_GPIOB | ||||
|   {VAL_GPIOB_MODER, VAL_GPIOB_OTYPER, VAL_GPIOB_OSPEEDR, VAL_GPIOB_PUPDR, | ||||
|    VAL_GPIOB_ODR,   VAL_GPIOB_AFRL,   VAL_GPIOB_AFRH}, | ||||
| #endif | ||||
| #if STM32_HAS_GPIOC | ||||
|   {VAL_GPIOC_MODER, VAL_GPIOC_OTYPER, VAL_GPIOC_OSPEEDR, VAL_GPIOC_PUPDR, | ||||
|    VAL_GPIOC_ODR,   VAL_GPIOC_AFRL,   VAL_GPIOC_AFRH}, | ||||
| #endif | ||||
| #if STM32_HAS_GPIOD | ||||
|   {VAL_GPIOD_MODER, VAL_GPIOD_OTYPER, VAL_GPIOD_OSPEEDR, VAL_GPIOD_PUPDR, | ||||
|    VAL_GPIOD_ODR,   VAL_GPIOD_AFRL,   VAL_GPIOD_AFRH}, | ||||
| #endif | ||||
| #if STM32_HAS_GPIOE | ||||
|   {VAL_GPIOE_MODER, VAL_GPIOE_OTYPER, VAL_GPIOE_OSPEEDR, VAL_GPIOE_PUPDR, | ||||
|    VAL_GPIOE_ODR,   VAL_GPIOE_AFRL,   VAL_GPIOE_AFRH}, | ||||
| #endif | ||||
| #if STM32_HAS_GPIOF | ||||
|   {VAL_GPIOF_MODER, VAL_GPIOF_OTYPER, VAL_GPIOF_OSPEEDR, VAL_GPIOF_PUPDR, | ||||
|    VAL_GPIOF_ODR,   VAL_GPIOF_AFRL,   VAL_GPIOF_AFRH}, | ||||
| #endif | ||||
| #if STM32_HAS_GPIOG | ||||
|   {VAL_GPIOG_MODER, VAL_GPIOG_OTYPER, VAL_GPIOG_OSPEEDR, VAL_GPIOG_PUPDR, | ||||
|    VAL_GPIOG_ODR,   VAL_GPIOG_AFRL,   VAL_GPIOG_AFRH}, | ||||
| #endif | ||||
| #if STM32_HAS_GPIOH | ||||
|   {VAL_GPIOH_MODER, VAL_GPIOH_OTYPER, VAL_GPIOH_OSPEEDR, VAL_GPIOH_PUPDR, | ||||
|    VAL_GPIOH_ODR,   VAL_GPIOH_AFRL,   VAL_GPIOH_AFRH}, | ||||
| #endif | ||||
| #if STM32_HAS_GPIOI | ||||
|   {VAL_GPIOI_MODER, VAL_GPIOI_OTYPER, VAL_GPIOI_OSPEEDR, VAL_GPIOI_PUPDR, | ||||
|    VAL_GPIOI_ODR,   VAL_GPIOI_AFRL,   VAL_GPIOI_AFRH} | ||||
| #endif | ||||
| }; | ||||
| #endif | ||||
|  | ||||
| void enter_bootloader_mode_if_requested(void); | ||||
|  | ||||
| /** | ||||
|  * @brief   Early initialization code. | ||||
|  * @details This initialization must be performed just after stack setup | ||||
|  *          and before any other initialization. | ||||
|  */ | ||||
| void __early_init(void) { | ||||
|   enter_bootloader_mode_if_requested(); | ||||
|   stm32_clock_init(); | ||||
| } | ||||
|  | ||||
| #if HAL_USE_SDC || defined(__DOXYGEN__) | ||||
| /** | ||||
|  * @brief   SDC card detection. | ||||
|  */ | ||||
| bool sdc_lld_is_card_inserted(SDCDriver *sdcp) { | ||||
|  | ||||
|   (void)sdcp; | ||||
|   /* TODO: Fill the implementation.*/ | ||||
|   return true; | ||||
| } | ||||
|  | ||||
| /** | ||||
|  * @brief   SDC card write protection detection. | ||||
|  */ | ||||
| bool sdc_lld_is_write_protected(SDCDriver *sdcp) { | ||||
|  | ||||
|   (void)sdcp; | ||||
|   /* TODO: Fill the implementation.*/ | ||||
|   return false; | ||||
| } | ||||
| #endif /* HAL_USE_SDC */ | ||||
|  | ||||
| #if HAL_USE_MMC_SPI || defined(__DOXYGEN__) | ||||
| /** | ||||
|  * @brief   MMC_SPI card detection. | ||||
|  */ | ||||
| bool mmc_lld_is_card_inserted(MMCDriver *mmcp) { | ||||
|  | ||||
|   (void)mmcp; | ||||
|   /* TODO: Fill the implementation.*/ | ||||
|   return true; | ||||
| } | ||||
|  | ||||
| /** | ||||
|  * @brief   MMC_SPI card write protection detection. | ||||
|  */ | ||||
| bool mmc_lld_is_write_protected(MMCDriver *mmcp) { | ||||
|  | ||||
|   (void)mmcp; | ||||
|   /* TODO: Fill the implementation.*/ | ||||
|   return false; | ||||
| } | ||||
| #endif | ||||
|  | ||||
| /** | ||||
|  * @brief   Board-specific initialization code. | ||||
|  * @todo    Add your board-specific code, if any. | ||||
|  */ | ||||
| void boardInit(void) { | ||||
| } | ||||
							
								
								
									
										1187
									
								
								keyboards/proton_c/boards/GENERIC_STM32_F303XC/board.h
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										1187
									
								
								keyboards/proton_c/boards/GENERIC_STM32_F303XC/board.h
									
									
									
									
									
										Normal file
									
								
							
										
											
												File diff suppressed because it is too large
												Load Diff
											
										
									
								
							
							
								
								
									
										5
									
								
								keyboards/proton_c/boards/GENERIC_STM32_F303XC/board.mk
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										5
									
								
								keyboards/proton_c/boards/GENERIC_STM32_F303XC/board.mk
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,5 @@ | ||||
| # List of all the board related files. | ||||
| BOARDSRC = $(BOARD_PATH)/boards/GENERIC_STM32_F303XC/board.c | ||||
|  | ||||
| # Required include directories | ||||
| BOARDINC = $(BOARD_PATH)/boards/GENERIC_STM32_F303XC | ||||
							
								
								
									
										7
									
								
								keyboards/proton_c/bootloader_defs.h
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										7
									
								
								keyboards/proton_c/bootloader_defs.h
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,7 @@ | ||||
| /* Address for jumping to bootloader on STM32 chips. */ | ||||
| /* It is chip dependent, the correct number can be looked up here: | ||||
|  * http://www.st.com/web/en/resource/technical/document/application_note/CD00167594.pdf | ||||
|  * This also requires a patch to chibios: | ||||
|  *  <tmk_dir>/tmk_core/tool/chibios/ch-bootloader-jump.patch | ||||
|  */ | ||||
| #define STM32_BOOTLOADER_ADDRESS 0x1FFFD800 | ||||
							
								
								
									
										520
									
								
								keyboards/proton_c/chconf.h
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										520
									
								
								keyboards/proton_c/chconf.h
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,520 @@ | ||||
| /* | ||||
|     ChibiOS - Copyright (C) 2006..2016 Giovanni Di Sirio | ||||
|  | ||||
|     Licensed under the Apache License, Version 2.0 (the "License"); | ||||
|     you may not use this file except in compliance with the License. | ||||
|     You may obtain a copy of the License at | ||||
|  | ||||
|         http://www.apache.org/licenses/LICENSE-2.0 | ||||
|  | ||||
|     Unless required by applicable law or agreed to in writing, software | ||||
|     distributed under the License is distributed on an "AS IS" BASIS, | ||||
|     WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. | ||||
|     See the License for the specific language governing permissions and | ||||
|     limitations under the License. | ||||
| */ | ||||
|  | ||||
| /** | ||||
|  * @file    templates/chconf.h | ||||
|  * @brief   Configuration file template. | ||||
|  * @details A copy of this file must be placed in each project directory, it | ||||
|  *          contains the application specific kernel settings. | ||||
|  * | ||||
|  * @addtogroup config | ||||
|  * @details Kernel related settings and hooks. | ||||
|  * @{ | ||||
|  */ | ||||
|  | ||||
| #ifndef CHCONF_H | ||||
| #define CHCONF_H | ||||
|  | ||||
| #define _CHIBIOS_RT_CONF_ | ||||
|  | ||||
| /*===========================================================================*/ | ||||
| /** | ||||
|  * @name System timers settings | ||||
|  * @{ | ||||
|  */ | ||||
| /*===========================================================================*/ | ||||
|  | ||||
| /** | ||||
|  * @brief   System time counter resolution. | ||||
|  * @note    Allowed values are 16 or 32 bits. | ||||
|  */ | ||||
| #define CH_CFG_ST_RESOLUTION                32 | ||||
|  | ||||
| /** | ||||
|  * @brief   System tick frequency. | ||||
|  * @details Frequency of the system timer that drives the system ticks. This | ||||
|  *          setting also defines the system tick time unit. | ||||
|  */ | ||||
| #define CH_CFG_ST_FREQUENCY                 10000 | ||||
|  | ||||
| /** | ||||
|  * @brief   Time delta constant for the tick-less mode. | ||||
|  * @note    If this value is zero then the system uses the classic | ||||
|  *          periodic tick. This value represents the minimum number | ||||
|  *          of ticks that is safe to specify in a timeout directive. | ||||
|  *          The value one is not valid, timeouts are rounded up to | ||||
|  *          this value. | ||||
|  */ | ||||
| #define CH_CFG_ST_TIMEDELTA                 2 | ||||
|  | ||||
| /** @} */ | ||||
|  | ||||
| /*===========================================================================*/ | ||||
| /** | ||||
|  * @name Kernel parameters and options | ||||
|  * @{ | ||||
|  */ | ||||
| /*===========================================================================*/ | ||||
|  | ||||
| /** | ||||
|  * @brief   Round robin interval. | ||||
|  * @details This constant is the number of system ticks allowed for the | ||||
|  *          threads before preemption occurs. Setting this value to zero | ||||
|  *          disables the preemption for threads with equal priority and the | ||||
|  *          round robin becomes cooperative. Note that higher priority | ||||
|  *          threads can still preempt, the kernel is always preemptive. | ||||
|  * @note    Disabling the round robin preemption makes the kernel more compact | ||||
|  *          and generally faster. | ||||
|  * @note    The round robin preemption is not supported in tickless mode and | ||||
|  *          must be set to zero in that case. | ||||
|  */ | ||||
| #define CH_CFG_TIME_QUANTUM                 0 | ||||
|  | ||||
| /** | ||||
|  * @brief   Managed RAM size. | ||||
|  * @details Size of the RAM area to be managed by the OS. If set to zero | ||||
|  *          then the whole available RAM is used. The core memory is made | ||||
|  *          available to the heap allocator and/or can be used directly through | ||||
|  *          the simplified core memory allocator. | ||||
|  * | ||||
|  * @note    In order to let the OS manage the whole RAM the linker script must | ||||
|  *          provide the @p __heap_base__ and @p __heap_end__ symbols. | ||||
|  * @note    Requires @p CH_CFG_USE_MEMCORE. | ||||
|  */ | ||||
| #define CH_CFG_MEMCORE_SIZE                 0 | ||||
|  | ||||
| /** | ||||
|  * @brief   Idle thread automatic spawn suppression. | ||||
|  * @details When this option is activated the function @p chSysInit() | ||||
|  *          does not spawn the idle thread. The application @p main() | ||||
|  *          function becomes the idle thread and must implement an | ||||
|  *          infinite loop. | ||||
|  */ | ||||
| #define CH_CFG_NO_IDLE_THREAD               FALSE | ||||
|  | ||||
| /** @} */ | ||||
|  | ||||
| /*===========================================================================*/ | ||||
| /** | ||||
|  * @name Performance options | ||||
|  * @{ | ||||
|  */ | ||||
| /*===========================================================================*/ | ||||
|  | ||||
| /** | ||||
|  * @brief   OS optimization. | ||||
|  * @details If enabled then time efficient rather than space efficient code | ||||
|  *          is used when two possible implementations exist. | ||||
|  * | ||||
|  * @note    This is not related to the compiler optimization options. | ||||
|  * @note    The default is @p TRUE. | ||||
|  */ | ||||
| #define CH_CFG_OPTIMIZE_SPEED               TRUE | ||||
|  | ||||
| /** @} */ | ||||
|  | ||||
| /*===========================================================================*/ | ||||
| /** | ||||
|  * @name Subsystem options | ||||
|  * @{ | ||||
|  */ | ||||
| /*===========================================================================*/ | ||||
|  | ||||
| /** | ||||
|  * @brief   Time Measurement APIs. | ||||
|  * @details If enabled then the time measurement APIs are included in | ||||
|  *          the kernel. | ||||
|  * | ||||
|  * @note    The default is @p TRUE. | ||||
|  */ | ||||
| #define CH_CFG_USE_TM                       TRUE | ||||
|  | ||||
| /** | ||||
|  * @brief   Threads registry APIs. | ||||
|  * @details If enabled then the registry APIs are included in the kernel. | ||||
|  * | ||||
|  * @note    The default is @p TRUE. | ||||
|  */ | ||||
| #define CH_CFG_USE_REGISTRY                 TRUE | ||||
|  | ||||
| /** | ||||
|  * @brief   Threads synchronization APIs. | ||||
|  * @details If enabled then the @p chThdWait() function is included in | ||||
|  *          the kernel. | ||||
|  * | ||||
|  * @note    The default is @p TRUE. | ||||
|  */ | ||||
| #define CH_CFG_USE_WAITEXIT                 TRUE | ||||
|  | ||||
| /** | ||||
|  * @brief   Semaphores APIs. | ||||
|  * @details If enabled then the Semaphores APIs are included in the kernel. | ||||
|  * | ||||
|  * @note    The default is @p TRUE. | ||||
|  */ | ||||
| #define CH_CFG_USE_SEMAPHORES               TRUE | ||||
|  | ||||
| /** | ||||
|  * @brief   Semaphores queuing mode. | ||||
|  * @details If enabled then the threads are enqueued on semaphores by | ||||
|  *          priority rather than in FIFO order. | ||||
|  * | ||||
|  * @note    The default is @p FALSE. Enable this if you have special | ||||
|  *          requirements. | ||||
|  * @note    Requires @p CH_CFG_USE_SEMAPHORES. | ||||
|  */ | ||||
| #define CH_CFG_USE_SEMAPHORES_PRIORITY      FALSE | ||||
|  | ||||
| /** | ||||
|  * @brief   Mutexes APIs. | ||||
|  * @details If enabled then the mutexes APIs are included in the kernel. | ||||
|  * | ||||
|  * @note    The default is @p TRUE. | ||||
|  */ | ||||
| #define CH_CFG_USE_MUTEXES                  TRUE | ||||
|  | ||||
| /** | ||||
|  * @brief   Enables recursive behavior on mutexes. | ||||
|  * @note    Recursive mutexes are heavier and have an increased | ||||
|  *          memory footprint. | ||||
|  * | ||||
|  * @note    The default is @p FALSE. | ||||
|  * @note    Requires @p CH_CFG_USE_MUTEXES. | ||||
|  */ | ||||
| #define CH_CFG_USE_MUTEXES_RECURSIVE        FALSE | ||||
|  | ||||
| /** | ||||
|  * @brief   Conditional Variables APIs. | ||||
|  * @details If enabled then the conditional variables APIs are included | ||||
|  *          in the kernel. | ||||
|  * | ||||
|  * @note    The default is @p TRUE. | ||||
|  * @note    Requires @p CH_CFG_USE_MUTEXES. | ||||
|  */ | ||||
| #define CH_CFG_USE_CONDVARS                 TRUE | ||||
|  | ||||
| /** | ||||
|  * @brief   Conditional Variables APIs with timeout. | ||||
|  * @details If enabled then the conditional variables APIs with timeout | ||||
|  *          specification are included in the kernel. | ||||
|  * | ||||
|  * @note    The default is @p TRUE. | ||||
|  * @note    Requires @p CH_CFG_USE_CONDVARS. | ||||
|  */ | ||||
| #define CH_CFG_USE_CONDVARS_TIMEOUT         TRUE | ||||
|  | ||||
| /** | ||||
|  * @brief   Events Flags APIs. | ||||
|  * @details If enabled then the event flags APIs are included in the kernel. | ||||
|  * | ||||
|  * @note    The default is @p TRUE. | ||||
|  */ | ||||
| #define CH_CFG_USE_EVENTS                   TRUE | ||||
|  | ||||
| /** | ||||
|  * @brief   Events Flags APIs with timeout. | ||||
|  * @details If enabled then the events APIs with timeout specification | ||||
|  *          are included in the kernel. | ||||
|  * | ||||
|  * @note    The default is @p TRUE. | ||||
|  * @note    Requires @p CH_CFG_USE_EVENTS. | ||||
|  */ | ||||
| #define CH_CFG_USE_EVENTS_TIMEOUT           TRUE | ||||
|  | ||||
| /** | ||||
|  * @brief   Synchronous Messages APIs. | ||||
|  * @details If enabled then the synchronous messages APIs are included | ||||
|  *          in the kernel. | ||||
|  * | ||||
|  * @note    The default is @p TRUE. | ||||
|  */ | ||||
| #define CH_CFG_USE_MESSAGES                 TRUE | ||||
|  | ||||
| /** | ||||
|  * @brief   Synchronous Messages queuing mode. | ||||
|  * @details If enabled then messages are served by priority rather than in | ||||
|  *          FIFO order. | ||||
|  * | ||||
|  * @note    The default is @p FALSE. Enable this if you have special | ||||
|  *          requirements. | ||||
|  * @note    Requires @p CH_CFG_USE_MESSAGES. | ||||
|  */ | ||||
| #define CH_CFG_USE_MESSAGES_PRIORITY        TRUE | ||||
|  | ||||
| /** | ||||
|  * @brief   Mailboxes APIs. | ||||
|  * @details If enabled then the asynchronous messages (mailboxes) APIs are | ||||
|  *          included in the kernel. | ||||
|  * | ||||
|  * @note    The default is @p TRUE. | ||||
|  * @note    Requires @p CH_CFG_USE_SEMAPHORES. | ||||
|  */ | ||||
| #define CH_CFG_USE_MAILBOXES                TRUE | ||||
|  | ||||
| /** | ||||
|  * @brief   Core Memory Manager APIs. | ||||
|  * @details If enabled then the core memory manager APIs are included | ||||
|  *          in the kernel. | ||||
|  * | ||||
|  * @note    The default is @p TRUE. | ||||
|  */ | ||||
| #define CH_CFG_USE_MEMCORE                  TRUE | ||||
|  | ||||
| /** | ||||
|  * @brief   Heap Allocator APIs. | ||||
|  * @details If enabled then the memory heap allocator APIs are included | ||||
|  *          in the kernel. | ||||
|  * | ||||
|  * @note    The default is @p TRUE. | ||||
|  * @note    Requires @p CH_CFG_USE_MEMCORE and either @p CH_CFG_USE_MUTEXES or | ||||
|  *          @p CH_CFG_USE_SEMAPHORES. | ||||
|  * @note    Mutexes are recommended. | ||||
|  */ | ||||
| #define CH_CFG_USE_HEAP                     TRUE | ||||
|  | ||||
| /** | ||||
|  * @brief   Memory Pools Allocator APIs. | ||||
|  * @details If enabled then the memory pools allocator APIs are included | ||||
|  *          in the kernel. | ||||
|  * | ||||
|  * @note    The default is @p TRUE. | ||||
|  */ | ||||
| #define CH_CFG_USE_MEMPOOLS                 TRUE | ||||
|  | ||||
| /** | ||||
|  * @brief   Dynamic Threads APIs. | ||||
|  * @details If enabled then the dynamic threads creation APIs are included | ||||
|  *          in the kernel. | ||||
|  * | ||||
|  * @note    The default is @p TRUE. | ||||
|  * @note    Requires @p CH_CFG_USE_WAITEXIT. | ||||
|  * @note    Requires @p CH_CFG_USE_HEAP and/or @p CH_CFG_USE_MEMPOOLS. | ||||
|  */ | ||||
| #define CH_CFG_USE_DYNAMIC                  TRUE | ||||
|  | ||||
| /** @} */ | ||||
|  | ||||
| /*===========================================================================*/ | ||||
| /** | ||||
|  * @name Debug options | ||||
|  * @{ | ||||
|  */ | ||||
| /*===========================================================================*/ | ||||
|  | ||||
| /** | ||||
|  * @brief   Debug option, kernel statistics. | ||||
|  * | ||||
|  * @note    The default is @p FALSE. | ||||
|  */ | ||||
| #define CH_DBG_STATISTICS                   FALSE | ||||
|  | ||||
| /** | ||||
|  * @brief   Debug option, system state check. | ||||
|  * @details If enabled the correct call protocol for system APIs is checked | ||||
|  *          at runtime. | ||||
|  * | ||||
|  * @note    The default is @p FALSE. | ||||
|  */ | ||||
| #define CH_DBG_SYSTEM_STATE_CHECK           FALSE | ||||
|  | ||||
| /** | ||||
|  * @brief   Debug option, parameters checks. | ||||
|  * @details If enabled then the checks on the API functions input | ||||
|  *          parameters are activated. | ||||
|  * | ||||
|  * @note    The default is @p FALSE. | ||||
|  */ | ||||
| #define CH_DBG_ENABLE_CHECKS                FALSE | ||||
|  | ||||
| /** | ||||
|  * @brief   Debug option, consistency checks. | ||||
|  * @details If enabled then all the assertions in the kernel code are | ||||
|  *          activated. This includes consistency checks inside the kernel, | ||||
|  *          runtime anomalies and port-defined checks. | ||||
|  * | ||||
|  * @note    The default is @p FALSE. | ||||
|  */ | ||||
| #define CH_DBG_ENABLE_ASSERTS               FALSE | ||||
|  | ||||
| /** | ||||
|  * @brief   Debug option, trace buffer. | ||||
|  * @details If enabled then the trace buffer is activated. | ||||
|  * | ||||
|  * @note    The default is @p CH_DBG_TRACE_MASK_DISABLED. | ||||
|  */ | ||||
| #define CH_DBG_TRACE_MASK                   CH_DBG_TRACE_MASK_DISABLED | ||||
|  | ||||
| /** | ||||
|  * @brief   Trace buffer entries. | ||||
|  * @note    The trace buffer is only allocated if @p CH_DBG_TRACE_MASK is | ||||
|  *          different from @p CH_DBG_TRACE_MASK_DISABLED. | ||||
|  */ | ||||
| #define CH_DBG_TRACE_BUFFER_SIZE            128 | ||||
|  | ||||
| /** | ||||
|  * @brief   Debug option, stack checks. | ||||
|  * @details If enabled then a runtime stack check is performed. | ||||
|  * | ||||
|  * @note    The default is @p FALSE. | ||||
|  * @note    The stack check is performed in a architecture/port dependent way. | ||||
|  *          It may not be implemented or some ports. | ||||
|  * @note    The default failure mode is to halt the system with the global | ||||
|  *          @p panic_msg variable set to @p NULL. | ||||
|  */ | ||||
| #define CH_DBG_ENABLE_STACK_CHECK           TRUE | ||||
|  | ||||
| /** | ||||
|  * @brief   Debug option, stacks initialization. | ||||
|  * @details If enabled then the threads working area is filled with a byte | ||||
|  *          value when a thread is created. This can be useful for the | ||||
|  *          runtime measurement of the used stack. | ||||
|  * | ||||
|  * @note    The default is @p FALSE. | ||||
|  */ | ||||
| #define CH_DBG_FILL_THREADS                 FALSE | ||||
|  | ||||
| /** | ||||
|  * @brief   Debug option, threads profiling. | ||||
|  * @details If enabled then a field is added to the @p thread_t structure that | ||||
|  *          counts the system ticks occurred while executing the thread. | ||||
|  * | ||||
|  * @note    The default is @p FALSE. | ||||
|  * @note    This debug option is not currently compatible with the | ||||
|  *          tickless mode. | ||||
|  */ | ||||
| #define CH_DBG_THREADS_PROFILING            FALSE | ||||
|  | ||||
| /** @} */ | ||||
|  | ||||
| /*===========================================================================*/ | ||||
| /** | ||||
|  * @name Kernel hooks | ||||
|  * @{ | ||||
|  */ | ||||
| /*===========================================================================*/ | ||||
|  | ||||
| /** | ||||
|  * @brief   Threads descriptor structure extension. | ||||
|  * @details User fields added to the end of the @p thread_t structure. | ||||
|  */ | ||||
| #define CH_CFG_THREAD_EXTRA_FIELDS                                          \ | ||||
|   /* Add threads custom fields here.*/ | ||||
|  | ||||
| /** | ||||
|  * @brief   Threads initialization hook. | ||||
|  * @details User initialization code added to the @p chThdInit() API. | ||||
|  * | ||||
|  * @note    It is invoked from within @p chThdInit() and implicitly from all | ||||
|  *          the threads creation APIs. | ||||
|  */ | ||||
| #define CH_CFG_THREAD_INIT_HOOK(tp) {                                       \ | ||||
|   /* Add threads initialization code here.*/                                \ | ||||
| } | ||||
|  | ||||
| /** | ||||
|  * @brief   Threads finalization hook. | ||||
|  * @details User finalization code added to the @p chThdExit() API. | ||||
|  */ | ||||
| #define CH_CFG_THREAD_EXIT_HOOK(tp) {                                       \ | ||||
|   /* Add threads finalization code here.*/                                  \ | ||||
| } | ||||
|  | ||||
| /** | ||||
|  * @brief   Context switch hook. | ||||
|  * @details This hook is invoked just before switching between threads. | ||||
|  */ | ||||
| #define CH_CFG_CONTEXT_SWITCH_HOOK(ntp, otp) {                              \ | ||||
|   /* Context switch code here.*/                                            \ | ||||
| } | ||||
|  | ||||
| /** | ||||
|  * @brief   ISR enter hook. | ||||
|  */ | ||||
| #define CH_CFG_IRQ_PROLOGUE_HOOK() {                                        \ | ||||
|   /* IRQ prologue code here.*/                                              \ | ||||
| } | ||||
|  | ||||
| /** | ||||
|  * @brief   ISR exit hook. | ||||
|  */ | ||||
| #define CH_CFG_IRQ_EPILOGUE_HOOK() {                                        \ | ||||
|   /* IRQ epilogue code here.*/                                              \ | ||||
| } | ||||
|  | ||||
| /** | ||||
|  * @brief   Idle thread enter hook. | ||||
|  * @note    This hook is invoked within a critical zone, no OS functions | ||||
|  *          should be invoked from here. | ||||
|  * @note    This macro can be used to activate a power saving mode. | ||||
|  */ | ||||
| #define CH_CFG_IDLE_ENTER_HOOK() {                                          \ | ||||
|   /* Idle-enter code here.*/                                                \ | ||||
| } | ||||
|  | ||||
| /** | ||||
|  * @brief   Idle thread leave hook. | ||||
|  * @note    This hook is invoked within a critical zone, no OS functions | ||||
|  *          should be invoked from here. | ||||
|  * @note    This macro can be used to deactivate a power saving mode. | ||||
|  */ | ||||
| #define CH_CFG_IDLE_LEAVE_HOOK() {                                          \ | ||||
|   /* Idle-leave code here.*/                                                \ | ||||
| } | ||||
|  | ||||
| /** | ||||
|  * @brief   Idle Loop hook. | ||||
|  * @details This hook is continuously invoked by the idle thread loop. | ||||
|  */ | ||||
| #define CH_CFG_IDLE_LOOP_HOOK() {                                           \ | ||||
|   /* Idle loop code here.*/                                                 \ | ||||
| } | ||||
|  | ||||
| /** | ||||
|  * @brief   System tick event hook. | ||||
|  * @details This hook is invoked in the system tick handler immediately | ||||
|  *          after processing the virtual timers queue. | ||||
|  */ | ||||
| #define CH_CFG_SYSTEM_TICK_HOOK() {                                         \ | ||||
|   /* System tick event code here.*/                                         \ | ||||
| } | ||||
|  | ||||
| /** | ||||
|  * @brief   System halt hook. | ||||
|  * @details This hook is invoked in case to a system halting error before | ||||
|  *          the system is halted. | ||||
|  */ | ||||
| #define CH_CFG_SYSTEM_HALT_HOOK(reason) {                                   \ | ||||
|   /* System halt code here.*/                                               \ | ||||
| } | ||||
|  | ||||
| /** | ||||
|  * @brief   Trace hook. | ||||
|  * @details This hook is invoked each time a new record is written in the | ||||
|  *          trace buffer. | ||||
|  */ | ||||
| #define CH_CFG_TRACE_HOOK(tep) {                                            \ | ||||
|   /* Trace code here.*/                                                     \ | ||||
| } | ||||
|  | ||||
| /** @} */ | ||||
|  | ||||
| /*===========================================================================*/ | ||||
| /* Port-specific settings (override port settings defaulted in chcore.h).    */ | ||||
| /*===========================================================================*/ | ||||
|  | ||||
| #endif  /* CHCONF_H */ | ||||
|  | ||||
| /** @} */ | ||||
							
								
								
									
										134
									
								
								keyboards/proton_c/config.h
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										134
									
								
								keyboards/proton_c/config.h
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,134 @@ | ||||
| /* | ||||
|  * Copyright 2017 skully <skullydazed@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 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/>. | ||||
|  */ | ||||
|  | ||||
| #ifndef CONFIG_H | ||||
| #define CONFIG_H | ||||
|  | ||||
| /* USB Device descriptor parameter */ | ||||
| #define VENDOR_ID       0x125A | ||||
| #define PRODUCT_ID      0x1770 | ||||
| #define DEVICE_VER      0x0001 | ||||
| #define MANUFACTURER    QMK | ||||
| #define PRODUCT         Proton C | ||||
| #define DESCRIPTION     "Proton C protoboard" | ||||
|  | ||||
| /* key matrix size */ | ||||
| #define MATRIX_ROWS 12 | ||||
| #define MATRIX_COLS 7 | ||||
|  | ||||
| /* | ||||
|  * Keyboard Matrix Assignments | ||||
|  * | ||||
|  * Change this to how you wired your keyboard | ||||
|  * COLS: AVR pins used for columns, left to right | ||||
|  * ROWS: AVR pins used for rows, top to bottom | ||||
|  * DIODE_DIRECTION: COL2ROW = COL = Anode (+), ROW = Cathode (-, marked on diode) | ||||
|  *                  ROW2COL = ROW = Anode (+), COL = Cathode (-, marked on diode) | ||||
|  * | ||||
| */ | ||||
| /* Note: These are not used for arm boards. They're here purely as documentation. | ||||
|  * #define MATRIX_ROW_PINS { PB0, PB1, PB2, PA15, PA10 } | ||||
|  * #define MATRIX_COL_PINS { PA2, PA3, PA6, PB14, PB15, PA8, PA9, PA7, PB3, PB4, PC14, PC15, PC13, PB5, PB6 } | ||||
|  * #define UNUSED_PINS | ||||
|  */ | ||||
|  | ||||
| /* Debounce reduces chatter (unintended double-presses) - set 0 if debouncing is not needed */ | ||||
| #define DEBOUNCE 6 | ||||
|  | ||||
| /* Prevent modifiers from being stuck on after layer changes. */ | ||||
| #define PREVENT_STUCK_MODIFIERS | ||||
|  | ||||
| /* Mechanical locking support. Use KC_LCAP, KC_LNUM or KC_LSCR instead in keymap */ | ||||
| //#define LOCKING_SUPPORT_ENABLE | ||||
| /* Locking resynchronize hack */ | ||||
| //#define LOCKING_RESYNC_ENABLE | ||||
|  | ||||
| /* | ||||
|  * Force NKRO | ||||
|  * | ||||
|  * Force NKRO (nKey Rollover) to be enabled by default, regardless of the saved | ||||
|  * state in the bootmagic EEPROM settings. (Note that NKRO must be enabled in the | ||||
|  * makefile for this to work.) | ||||
|  * | ||||
|  * If forced on, NKRO can be disabled via magic key (default = LShift+RShift+N) | ||||
|  * until the next keyboard reset. | ||||
|  * | ||||
|  * NKRO may prevent your keystrokes from being detected in the BIOS, but it is | ||||
|  * fully operational during normal computer usage. | ||||
|  * | ||||
|  * For a less heavy-handed approach, enable NKRO via magic key (LShift+RShift+N) | ||||
|  * or via bootmagic (hold SPACE+N while plugging in the keyboard). Once set by | ||||
|  * bootmagic, NKRO mode will always be enabled until it is toggled again during a | ||||
|  * power-up. | ||||
|  * | ||||
|  */ | ||||
| //#define FORCE_NKRO | ||||
|  | ||||
| /* key combination for magic key command */ | ||||
| #define IS_COMMAND() ( \ | ||||
| 	keyboard_report->mods == (MOD_BIT(KC_LSHIFT) | MOD_BIT(KC_RSHIFT)) \ | ||||
| ) | ||||
|  | ||||
| /* | ||||
|  * Feature disable options | ||||
|  *  These options are also useful to firmware size reduction. | ||||
|  */ | ||||
|  | ||||
| /* disable debug print */ | ||||
| //#define NO_DEBUG | ||||
|  | ||||
| /* disable print */ | ||||
| //#define NO_PRINT | ||||
|  | ||||
| /* disable action features */ | ||||
| //#define NO_ACTION_LAYER | ||||
| //#define NO_ACTION_TAPPING | ||||
| //#define NO_ACTION_ONESHOT | ||||
| //#define NO_ACTION_MACRO | ||||
| //#define NO_ACTION_FUNCTION | ||||
|  | ||||
| /* | ||||
|  * MIDI options | ||||
|  */ | ||||
|  | ||||
| /* Prevent use of disabled MIDI features in the keymap */ | ||||
| //#define MIDI_ENABLE_STRICT 1 | ||||
|  | ||||
| /* enable basic MIDI features: | ||||
|    - MIDI notes can be sent when in Music mode is on | ||||
| */ | ||||
| //#define MIDI_BASIC | ||||
|  | ||||
| /* enable advanced MIDI features: | ||||
|    - MIDI notes can be added to the keymap | ||||
|    - Octave shift and transpose | ||||
|    - Virtual sustain, portamento, and modulation wheel | ||||
|    - etc. | ||||
| */ | ||||
| //#define MIDI_ADVANCED | ||||
|  | ||||
| /* override number of MIDI tone keycodes (each octave adds 12 keycodes and allocates 12 bytes) */ | ||||
| //#define MIDI_TONE_KEYCODE_OCTAVES 1 | ||||
|  | ||||
|  /* Backlight configuration | ||||
|  */ | ||||
| #define BACKLIGHT_LEVELS 1 | ||||
|  | ||||
| #define NO_USB_STARTUP_CHECK | ||||
|  | ||||
| #endif | ||||
|  | ||||
							
								
								
									
										395
									
								
								keyboards/proton_c/halconf.h
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										395
									
								
								keyboards/proton_c/halconf.h
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,395 @@ | ||||
| /* | ||||
|     ChibiOS - Copyright (C) 2006..2016 Giovanni Di Sirio | ||||
|  | ||||
|     Licensed under the Apache License, Version 2.0 (the "License"); | ||||
|     you may not use this file except in compliance with the License. | ||||
|     You may obtain a copy of the License at | ||||
|  | ||||
|         http://www.apache.org/licenses/LICENSE-2.0 | ||||
|  | ||||
|     Unless required by applicable law or agreed to in writing, software | ||||
|     distributed under the License is distributed on an "AS IS" BASIS, | ||||
|     WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. | ||||
|     See the License for the specific language governing permissions and | ||||
|     limitations under the License. | ||||
| */ | ||||
|  | ||||
| /** | ||||
|  * @file    templates/halconf.h | ||||
|  * @brief   HAL configuration header. | ||||
|  * @details HAL configuration file, this file allows to enable or disable the | ||||
|  *          various device drivers from your application. You may also use | ||||
|  *          this file in order to override the device drivers default settings. | ||||
|  * | ||||
|  * @addtogroup HAL_CONF | ||||
|  * @{ | ||||
|  */ | ||||
|  | ||||
| #ifndef HALCONF_H | ||||
| #define HALCONF_H | ||||
|  | ||||
| #include "mcuconf.h" | ||||
|  | ||||
| /** | ||||
|  * @brief   Enables the PAL subsystem. | ||||
|  */ | ||||
| #if !defined(HAL_USE_PAL) || defined(__DOXYGEN__) | ||||
| #define HAL_USE_PAL                 TRUE | ||||
| #endif | ||||
|  | ||||
| /** | ||||
|  * @brief   Enables the ADC subsystem. | ||||
|  */ | ||||
| #if !defined(HAL_USE_ADC) || defined(__DOXYGEN__) | ||||
| #define HAL_USE_ADC                 FALSE | ||||
| #endif | ||||
|  | ||||
| /** | ||||
|  * @brief   Enables the CAN subsystem. | ||||
|  */ | ||||
| #if !defined(HAL_USE_CAN) || defined(__DOXYGEN__) | ||||
| #define HAL_USE_CAN                 FALSE | ||||
| #endif | ||||
|  | ||||
| /** | ||||
|  * @brief   Enables the DAC subsystem. | ||||
|  */ | ||||
| #if !defined(HAL_USE_DAC) || defined(__DOXYGEN__) | ||||
| #define HAL_USE_DAC                 TRUE | ||||
| #endif | ||||
|  | ||||
| /** | ||||
|  * @brief   Enables the EXT subsystem. | ||||
|  */ | ||||
| #if !defined(HAL_USE_EXT) || defined(__DOXYGEN__) | ||||
| #define HAL_USE_EXT                 FALSE | ||||
| #endif | ||||
|  | ||||
| /** | ||||
|  * @brief   Enables the GPT subsystem. | ||||
|  */ | ||||
| #if !defined(HAL_USE_GPT) || defined(__DOXYGEN__) | ||||
| #define HAL_USE_GPT                 TRUE | ||||
| #endif | ||||
|  | ||||
| /** | ||||
|  * @brief   Enables the I2C subsystem. | ||||
|  */ | ||||
| #if !defined(HAL_USE_I2C) || defined(__DOXYGEN__) | ||||
| #define HAL_USE_I2C                 TRUE | ||||
| #endif | ||||
|  | ||||
| /** | ||||
|  * @brief   Enables the I2C Slave subsystem. | ||||
|  */ | ||||
| #if !defined(HAL_USE_I2C_SLAVE) || defined(__DOXYGEN__) | ||||
| #define HAL_USE_I2C_SLAVE           TRUE | ||||
| #endif | ||||
|  | ||||
| /** | ||||
|  * @brief   Enables the I2S subsystem. | ||||
|  */ | ||||
| #if !defined(HAL_USE_I2S) || defined(__DOXYGEN__) | ||||
| #define HAL_USE_I2S                 FALSE | ||||
| #endif | ||||
|  | ||||
| /** | ||||
|  * @brief   Enables the ICU subsystem. | ||||
|  */ | ||||
| #if !defined(HAL_USE_ICU) || defined(__DOXYGEN__) | ||||
| #define HAL_USE_ICU                 FALSE | ||||
| #endif | ||||
|  | ||||
| /** | ||||
|  * @brief   Enables the MAC subsystem. | ||||
|  */ | ||||
| #if !defined(HAL_USE_MAC) || defined(__DOXYGEN__) | ||||
| #define HAL_USE_MAC                 FALSE | ||||
| #endif | ||||
|  | ||||
| /** | ||||
|  * @brief   Enables the MMC_SPI subsystem. | ||||
|  */ | ||||
| #if !defined(HAL_USE_MMC_SPI) || defined(__DOXYGEN__) | ||||
| #define HAL_USE_MMC_SPI             FALSE | ||||
| #endif | ||||
|  | ||||
| /** | ||||
|  * @brief   Enables the PWM subsystem. | ||||
|  */ | ||||
| #if !defined(HAL_USE_PWM) || defined(__DOXYGEN__) | ||||
| #define HAL_USE_PWM                 FALSE | ||||
| #endif | ||||
|  | ||||
| /** | ||||
|  * @brief   Enables the QSPI subsystem. | ||||
|  */ | ||||
| #if !defined(HAL_USE_QSPI) || defined(__DOXYGEN__) | ||||
| #define HAL_USE_QSPI                FALSE | ||||
| #endif | ||||
|  | ||||
| /** | ||||
|  * @brief   Enables the RTC subsystem. | ||||
|  */ | ||||
| #if !defined(HAL_USE_RTC) || defined(__DOXYGEN__) | ||||
| #define HAL_USE_RTC                 FALSE | ||||
| #endif | ||||
|  | ||||
| /** | ||||
|  * @brief   Enables the SDC subsystem. | ||||
|  */ | ||||
| #if !defined(HAL_USE_SDC) || defined(__DOXYGEN__) | ||||
| #define HAL_USE_SDC                 FALSE | ||||
| #endif | ||||
|  | ||||
| /** | ||||
|  * @brief   Enables the SERIAL subsystem. | ||||
|  */ | ||||
| #if !defined(HAL_USE_SERIAL) || defined(__DOXYGEN__) | ||||
| #define HAL_USE_SERIAL              FALSE | ||||
| #endif | ||||
|  | ||||
| /** | ||||
|  * @brief   Enables the SERIAL over USB subsystem. | ||||
|  */ | ||||
| #if !defined(HAL_USE_SERIAL_USB) || defined(__DOXYGEN__) | ||||
| #define HAL_USE_SERIAL_USB          TRUE | ||||
| #endif | ||||
|  | ||||
| /** | ||||
|  * @brief   Enables the SPI subsystem. | ||||
|  */ | ||||
| #if !defined(HAL_USE_SPI) || defined(__DOXYGEN__) | ||||
| #define HAL_USE_SPI                 FALSE | ||||
| #endif | ||||
|  | ||||
| /** | ||||
|  * @brief   Enables the UART subsystem. | ||||
|  */ | ||||
| #if !defined(HAL_USE_UART) || defined(__DOXYGEN__) | ||||
| #define HAL_USE_UART                FALSE | ||||
| #endif | ||||
|  | ||||
| /** | ||||
|  * @brief   Enables the USB subsystem. | ||||
|  */ | ||||
| #if !defined(HAL_USE_USB) || defined(__DOXYGEN__) | ||||
| #define HAL_USE_USB                 TRUE | ||||
| #endif | ||||
|  | ||||
| /** | ||||
|  * @brief   Enables the WDG subsystem. | ||||
|  */ | ||||
| #if !defined(HAL_USE_WDG) || defined(__DOXYGEN__) | ||||
| #define HAL_USE_WDG                 FALSE | ||||
| #endif | ||||
|  | ||||
| /*===========================================================================*/ | ||||
| /* ADC driver related settings.                                              */ | ||||
| /*===========================================================================*/ | ||||
|  | ||||
| /** | ||||
|  * @brief   Enables synchronous APIs. | ||||
|  * @note    Disabling this option saves both code and data space. | ||||
|  */ | ||||
| #if !defined(ADC_USE_WAIT) || defined(__DOXYGEN__) | ||||
| #define ADC_USE_WAIT                TRUE | ||||
| #endif | ||||
|  | ||||
| /** | ||||
|  * @brief   Enables the @p adcAcquireBus() and @p adcReleaseBus() APIs. | ||||
|  * @note    Disabling this option saves both code and data space. | ||||
|  */ | ||||
| #if !defined(ADC_USE_MUTUAL_EXCLUSION) || defined(__DOXYGEN__) | ||||
| #define ADC_USE_MUTUAL_EXCLUSION    TRUE | ||||
| #endif | ||||
|  | ||||
| /*===========================================================================*/ | ||||
| /* CAN driver related settings.                                              */ | ||||
| /*===========================================================================*/ | ||||
|  | ||||
| /** | ||||
|  * @brief   Sleep mode related APIs inclusion switch. | ||||
|  */ | ||||
| #if !defined(CAN_USE_SLEEP_MODE) || defined(__DOXYGEN__) | ||||
| #define CAN_USE_SLEEP_MODE          TRUE | ||||
| #endif | ||||
|  | ||||
| /*===========================================================================*/ | ||||
| /* I2C driver related settings.                                              */ | ||||
| /*===========================================================================*/ | ||||
|  | ||||
| /** | ||||
|  * @brief   Enables the mutual exclusion APIs on the I2C bus. | ||||
|  */ | ||||
| #if !defined(I2C_USE_MUTUAL_EXCLUSION) || defined(__DOXYGEN__) | ||||
| #define I2C_USE_MUTUAL_EXCLUSION    TRUE | ||||
| #endif | ||||
|  | ||||
| /*===========================================================================*/ | ||||
| /* MAC driver related settings.                                              */ | ||||
| /*===========================================================================*/ | ||||
|  | ||||
| /** | ||||
|  * @brief   Enables an event sources for incoming packets. | ||||
|  */ | ||||
| #if !defined(MAC_USE_ZERO_COPY) || defined(__DOXYGEN__) | ||||
| #define MAC_USE_ZERO_COPY           FALSE | ||||
| #endif | ||||
|  | ||||
| /** | ||||
|  * @brief   Enables an event sources for incoming packets. | ||||
|  */ | ||||
| #if !defined(MAC_USE_EVENTS) || defined(__DOXYGEN__) | ||||
| #define MAC_USE_EVENTS              TRUE | ||||
| #endif | ||||
|  | ||||
| /*===========================================================================*/ | ||||
| /* MMC_SPI driver related settings.                                          */ | ||||
| /*===========================================================================*/ | ||||
|  | ||||
| /** | ||||
|  * @brief   Delays insertions. | ||||
|  * @details If enabled this options inserts delays into the MMC waiting | ||||
|  *          routines releasing some extra CPU time for the threads with | ||||
|  *          lower priority, this may slow down the driver a bit however. | ||||
|  *          This option is recommended also if the SPI driver does not | ||||
|  *          use a DMA channel and heavily loads the CPU. | ||||
|  */ | ||||
| #if !defined(MMC_NICE_WAITING) || defined(__DOXYGEN__) | ||||
| #define MMC_NICE_WAITING            TRUE | ||||
| #endif | ||||
|  | ||||
| /*===========================================================================*/ | ||||
| /* SDC driver related settings.                                              */ | ||||
| /*===========================================================================*/ | ||||
|  | ||||
| /** | ||||
|  * @brief   Number of initialization attempts before rejecting the card. | ||||
|  * @note    Attempts are performed at 10mS intervals. | ||||
|  */ | ||||
| #if !defined(SDC_INIT_RETRY) || defined(__DOXYGEN__) | ||||
| #define SDC_INIT_RETRY              100 | ||||
| #endif | ||||
|  | ||||
| /** | ||||
|  * @brief   Include support for MMC cards. | ||||
|  * @note    MMC support is not yet implemented so this option must be kept | ||||
|  *          at @p FALSE. | ||||
|  */ | ||||
| #if !defined(SDC_MMC_SUPPORT) || defined(__DOXYGEN__) | ||||
| #define SDC_MMC_SUPPORT             FALSE | ||||
| #endif | ||||
|  | ||||
| /** | ||||
|  * @brief   Delays insertions. | ||||
|  * @details If enabled this options inserts delays into the MMC waiting | ||||
|  *          routines releasing some extra CPU time for the threads with | ||||
|  *          lower priority, this may slow down the driver a bit however. | ||||
|  */ | ||||
| #if !defined(SDC_NICE_WAITING) || defined(__DOXYGEN__) | ||||
| #define SDC_NICE_WAITING            TRUE | ||||
| #endif | ||||
|  | ||||
| /*===========================================================================*/ | ||||
| /* SERIAL driver related settings.                                           */ | ||||
| /*===========================================================================*/ | ||||
|  | ||||
| /** | ||||
|  * @brief   Default bit rate. | ||||
|  * @details Configuration parameter, this is the baud rate selected for the | ||||
|  *          default configuration. | ||||
|  */ | ||||
| #if !defined(SERIAL_DEFAULT_BITRATE) || defined(__DOXYGEN__) | ||||
| #define SERIAL_DEFAULT_BITRATE      38400 | ||||
| #endif | ||||
|  | ||||
| /** | ||||
|  * @brief   Serial buffers size. | ||||
|  * @details Configuration parameter, you can change the depth of the queue | ||||
|  *          buffers depending on the requirements of your application. | ||||
|  * @note    The default is 16 bytes for both the transmission and receive | ||||
|  *          buffers. | ||||
|  */ | ||||
| #if !defined(SERIAL_BUFFERS_SIZE) || defined(__DOXYGEN__) | ||||
| #define SERIAL_BUFFERS_SIZE         16 | ||||
| #endif | ||||
|  | ||||
| /*===========================================================================*/ | ||||
| /* SERIAL_USB driver related setting.                                        */ | ||||
| /*===========================================================================*/ | ||||
|  | ||||
| /** | ||||
|  * @brief   Serial over USB buffers size. | ||||
|  * @details Configuration parameter, the buffer size must be a multiple of | ||||
|  *          the USB data endpoint maximum packet size. | ||||
|  * @note    The default is 256 bytes for both the transmission and receive | ||||
|  *          buffers. | ||||
|  */ | ||||
| #if !defined(SERIAL_USB_BUFFERS_SIZE) || defined(__DOXYGEN__) | ||||
| #define SERIAL_USB_BUFFERS_SIZE     256 | ||||
| #endif | ||||
|  | ||||
| /** | ||||
|  * @brief   Serial over USB number of buffers. | ||||
|  * @note    The default is 2 buffers. | ||||
|  */ | ||||
| #if !defined(SERIAL_USB_BUFFERS_NUMBER) || defined(__DOXYGEN__) | ||||
| #define SERIAL_USB_BUFFERS_NUMBER   2 | ||||
| #endif | ||||
|  | ||||
| /*===========================================================================*/ | ||||
| /* SPI driver related settings.                                              */ | ||||
| /*===========================================================================*/ | ||||
|  | ||||
| /** | ||||
|  * @brief   Enables synchronous APIs. | ||||
|  * @note    Disabling this option saves both code and data space. | ||||
|  */ | ||||
| #if !defined(SPI_USE_WAIT) || defined(__DOXYGEN__) | ||||
| #define SPI_USE_WAIT                TRUE | ||||
| #endif | ||||
|  | ||||
| /** | ||||
|  * @brief   Enables the @p spiAcquireBus() and @p spiReleaseBus() APIs. | ||||
|  * @note    Disabling this option saves both code and data space. | ||||
|  */ | ||||
| #if !defined(SPI_USE_MUTUAL_EXCLUSION) || defined(__DOXYGEN__) | ||||
| #define SPI_USE_MUTUAL_EXCLUSION    TRUE | ||||
| #endif | ||||
|  | ||||
| /*===========================================================================*/ | ||||
| /* UART driver related settings.                                             */ | ||||
| /*===========================================================================*/ | ||||
|  | ||||
| /** | ||||
|  * @brief   Enables synchronous APIs. | ||||
|  * @note    Disabling this option saves both code and data space. | ||||
|  */ | ||||
| #if !defined(UART_USE_WAIT) || defined(__DOXYGEN__) | ||||
| #define UART_USE_WAIT               FALSE | ||||
| #endif | ||||
|  | ||||
| /** | ||||
|  * @brief   Enables the @p uartAcquireBus() and @p uartReleaseBus() APIs. | ||||
|  * @note    Disabling this option saves both code and data space. | ||||
|  */ | ||||
| #if !defined(UART_USE_MUTUAL_EXCLUSION) || defined(__DOXYGEN__) | ||||
| #define UART_USE_MUTUAL_EXCLUSION   FALSE | ||||
| #endif | ||||
|  | ||||
| /*===========================================================================*/ | ||||
| /* USB driver related settings.                                              */ | ||||
| /*===========================================================================*/ | ||||
|  | ||||
| /** | ||||
|  * @brief   Enables synchronous APIs. | ||||
|  * @note    Disabling this option saves both code and data space. | ||||
|  */ | ||||
| #if !defined(USB_USE_WAIT) || defined(__DOXYGEN__) | ||||
| #define USB_USE_WAIT                TRUE | ||||
| #endif | ||||
|  | ||||
| #endif /* HALCONF_H */ | ||||
|  | ||||
| /** @} */ | ||||
							
								
								
									
										126
									
								
								keyboards/proton_c/keymaps/default/keymap.c
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										126
									
								
								keyboards/proton_c/keymaps/default/keymap.c
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,126 @@ | ||||
| #include QMK_KEYBOARD_H | ||||
|  | ||||
| #define _______ KC_TRNS | ||||
|  | ||||
| enum keyboard_layers { | ||||
|     _BL, | ||||
|     _FL, | ||||
|     _CL | ||||
| }; | ||||
|  | ||||
| enum custom_keycodes { | ||||
|     S_BSKTC = SAFE_RANGE, | ||||
|     S_ODEJY, | ||||
|     S_RCKBY, | ||||
|     S_DOEDR, | ||||
|     S_SCALE, | ||||
|     S_ONEUP, | ||||
|     S_COIN, | ||||
|     S_SONIC, | ||||
|     S_ZELDA | ||||
| }; | ||||
|  | ||||
| #ifdef AUDIO_ENABLE | ||||
|   float song_basketcase[][2] = SONG(BASKET_CASE); | ||||
|   float song_ode_to_joy[][2]  = SONG(ODE_TO_JOY); | ||||
|   float song_rock_a_bye_baby[][2]  = SONG(ROCK_A_BYE_BABY); | ||||
|   float song_doe_a_deer[][2]  = SONG(DOE_A_DEER); | ||||
|   float song_scale[][2]  = SONG(MUSIC_SCALE_SOUND); | ||||
|   float song_coin[][2]  = SONG(COIN_SOUND); | ||||
|   float song_one_up[][2]  = SONG(ONE_UP_SOUND); | ||||
|   float song_sonic_ring[][2]  = SONG(SONIC_RING); | ||||
|   float song_zelda_puzzle[][2]  = SONG(ZELDA_PUZZLE); | ||||
| #endif | ||||
|  | ||||
| const uint16_t keymaps[][MATRIX_ROWS][MATRIX_COLS] = { | ||||
|     [0] = KEYMAP( | ||||
|       KC_GRV,  KC_1,    KC_2,    KC_3,    KC_4,    KC_5,    KC_DEL, | ||||
|       KC_TAB,  KC_Q,    KC_W,    KC_E,    KC_R,    KC_T,    KC_HOME, | ||||
|       KC_ESC,  KC_A,    KC_S,    KC_D,    KC_F,    KC_G,    KC_END, | ||||
|       KC_LSFT, KC_Z,    KC_X,    KC_C,    KC_V,    KC_N, | ||||
|       KC_NO,   KC_LCTL, KC_LALT, KC_LGUI, MO(1), | ||||
|                                           KC_SPC, MO(1), RESET, | ||||
|  | ||||
|       KC_INS,  KC_6,    KC_7,    KC_8,    KC_9,    KC_0,    KC_BSPC, | ||||
|       KC_PGUP, KC_Y,    KC_U,    KC_I,    KC_O,    KC_P,    KC_DEL, | ||||
|       KC_PGDN, KC_H,    KC_J,    KC_K,    KC_L,    KC_COLN, KC_QUOT, | ||||
|                KC_N,    KC_M,    KC_COMM, KC_DOT,  KC_SLSH, KC_ENT, | ||||
|                         KC_RCTL, KC_LEFT, KC_DOWN, KC_UP,   KC_RGHT, | ||||
|       RESET, MO(2), KC_SPC | ||||
|     ) | ||||
|     // [0] = KEYMAP( | ||||
|     //   KC_GRV,  KC_1,    KC_2,    KC_3,    KC_4,    KC_5,    KC_DEL, | ||||
|     //   KC_TAB,  KC_Q,    KC_W,    KC_F,    KC_P,    KC_G,    KC_HOME, | ||||
|     //   KC_ESC,  KC_A,    KC_R,    KC_S,    KC_T,    KC_D,    KC_END, | ||||
|     //   KC_LSFT, KC_Z,    KC_X,    KC_C,    KC_V,    KC_B, | ||||
|     //   KC_NO,   KC_LCTL, KC_LALT, KC_LGUI, MO(1), | ||||
|     //                                       KC_SPC, MO(1), RESET, | ||||
|  | ||||
|     //   KC_INS,  KC_6,    KC_7,    KC_8,    KC_9,    KC_0,    KC_BSPC, | ||||
|     //   KC_PGUP, KC_J,    KC_L,    KC_U,    KC_Y,    KC_COLN, KC_DEL, | ||||
|     //   KC_PGDN, KC_H,    KC_N,    KC_E,    KC_I,    KC_O,    KC_QUOT, | ||||
|     //            KC_K,    KC_M,    KC_COMM, KC_DOT,  KC_SLSH, KC_ENT, | ||||
|     //                     KC_RGUI, KC_LEFT, KC_DOWN, KC_UP,   KC_RGHT, | ||||
|     //   RESET, MO(2), KC_SPC | ||||
|     // ) | ||||
| }; | ||||
|  | ||||
| bool process_record_user(uint16_t keycode, keyrecord_t *record) { | ||||
|     switch (keycode) { | ||||
|         case S_BSKTC: | ||||
|             if (record->event.pressed) { | ||||
|                 stop_all_notes(); | ||||
|                 PLAY_SONG(song_basketcase); | ||||
|             } | ||||
|             return false; | ||||
|         case S_ODEJY: | ||||
|             if (record->event.pressed) { | ||||
|                 stop_all_notes(); | ||||
|                 PLAY_SONG(song_ode_to_joy); | ||||
|             } | ||||
|             return false; | ||||
|         case S_RCKBY: | ||||
|             if (record->event.pressed) { | ||||
|                 stop_all_notes(); | ||||
|                 PLAY_SONG(song_rock_a_bye_baby); | ||||
|             } | ||||
|             return false; | ||||
|         case S_DOEDR: | ||||
|             if (record->event.pressed) { | ||||
|                 stop_all_notes(); | ||||
|                 PLAY_SONG(song_doe_a_deer); | ||||
|             } | ||||
|             return false; | ||||
|         case S_SCALE: | ||||
|             if (record->event.pressed) { | ||||
|                 stop_all_notes(); | ||||
|                 PLAY_SONG(song_scale); | ||||
|             } | ||||
|             return false; | ||||
|         case S_ONEUP: | ||||
|             if (record->event.pressed) { | ||||
|                 stop_all_notes(); | ||||
|                 PLAY_SONG(song_one_up); | ||||
|             } | ||||
|             return false; | ||||
|         case S_COIN: | ||||
|             if (record->event.pressed) { | ||||
|                 stop_all_notes(); | ||||
|                 PLAY_SONG(song_coin); | ||||
|             } | ||||
|             return false; | ||||
|         case S_SONIC: | ||||
|             if (record->event.pressed) { | ||||
|                 stop_all_notes(); | ||||
|                 PLAY_SONG(song_sonic_ring); | ||||
|             } | ||||
|             return false; | ||||
|         case S_ZELDA: | ||||
|             if (record->event.pressed) { | ||||
|                 stop_all_notes(); | ||||
|                 PLAY_SONG(song_zelda_puzzle); | ||||
|             } | ||||
|             return false; | ||||
|     } | ||||
|     return true; | ||||
| } | ||||
							
								
								
									
										1
									
								
								keyboards/proton_c/keymaps/default/readme.md
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										1
									
								
								keyboards/proton_c/keymaps/default/readme.md
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1 @@ | ||||
| # The default keymap for the Proton C | ||||
							
								
								
									
										53
									
								
								keyboards/proton_c/led.c
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										53
									
								
								keyboards/proton_c/led.c
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,53 @@ | ||||
| /* | ||||
|  * Copyright 2017 skully <skullydazed@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 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 "hal.h" | ||||
| #include "backlight.h" | ||||
| #include "led.h" | ||||
| #include "printf.h" | ||||
|  | ||||
| void backlight_init_ports(void) { | ||||
|     printf("backlight_init_ports()\n"); | ||||
|     #ifdef BACKLIGHT_ENABLE | ||||
|     // palSetPadMode(GPIOB, 8, PAL_MODE_OUTPUT_PUSHPULL); | ||||
|     // palSetPad(GPIOB, 8); | ||||
|     #endif | ||||
| } | ||||
|  | ||||
| void backlight_set(uint8_t level) { | ||||
|     printf("backlight_set(%d)\n", level); | ||||
|     #ifdef BACKLIGHT_ENABLE | ||||
|     if (level == 0) { | ||||
|         // Turn backlight off | ||||
|         // palSetPad(GPIOB, 8); | ||||
|     } else { | ||||
|         // Turn backlight on | ||||
|         // palClearPad(GPIOB, 8); | ||||
|     } | ||||
|     #endif | ||||
| } | ||||
|  | ||||
| void led_set_kb(uint8_t usb_led) { | ||||
|     printf("led_set_kb(%d)\n", usb_led); | ||||
|     if (usb_led & (1<<USB_LED_CAPS_LOCK)) { | ||||
|         // Turn capslock on | ||||
|         // palSetPad(GPIOB, 7); | ||||
|     } else { | ||||
|         // Turn capslock off | ||||
|         // palClearPad(GPIOB, 7); | ||||
|     } | ||||
| } | ||||
							
								
								
									
										222
									
								
								keyboards/proton_c/matrix.c
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										222
									
								
								keyboards/proton_c/matrix.c
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,222 @@ | ||||
| #include <stdint.h> | ||||
| #include <stdbool.h> | ||||
| #include <string.h> | ||||
| #include "hal.h" | ||||
| #include "timer.h" | ||||
| #include "wait.h" | ||||
| #include "printf.h" | ||||
| #include "backlight.h" | ||||
| #include "matrix.h" | ||||
|  | ||||
| #include "usb_main.h" | ||||
| #include "twi2c.h" | ||||
|  | ||||
| /* QMK Handwire | ||||
|  * | ||||
|  * Column pins are input with internal pull-down. | ||||
|  * Row pins are output and strobe with high. | ||||
|  * Key is high or 1 when it turns on. | ||||
|  * | ||||
|  *     col: { A13, A14, A15, B3, B4, B5, B6 } | ||||
|  *     row: { B10, B2, B1, B0, A7, A6 } | ||||
|  */ | ||||
| /* matrix state(1:on, 0:off) */ | ||||
| static matrix_row_t matrix[MATRIX_ROWS]; | ||||
| static matrix_row_t matrix_debouncing[MATRIX_ROWS]; | ||||
| static bool debouncing = false; | ||||
| static uint16_t debouncing_time = 0; | ||||
|  | ||||
| static bool master = false; | ||||
| static bool right_hand = false; | ||||
|  | ||||
| __attribute__ ((weak)) | ||||
| void matrix_init_user(void) {} | ||||
|  | ||||
| __attribute__ ((weak)) | ||||
| void matrix_scan_user(void) {} | ||||
|  | ||||
| __attribute__ ((weak)) | ||||
| void matrix_init_kb(void) { | ||||
|   matrix_init_user(); | ||||
| } | ||||
|  | ||||
| __attribute__ ((weak)) | ||||
| void matrix_scan_kb(void) { | ||||
|   matrix_scan_user(); | ||||
| } | ||||
|  | ||||
| void matrix_init(void) { | ||||
|     printf("matrix init\n"); | ||||
|     // debug_matrix = true; | ||||
|  | ||||
|     // C13 is connected to VCC on the right hand | ||||
|     palSetPadMode(GPIOC, 13, PAL_MODE_INPUT); | ||||
|     wait_us(20); | ||||
|     right_hand = palReadPad(GPIOC, 13); | ||||
|  | ||||
|     // if USB is active, this is the master | ||||
|     // master = usbGetDriverStateI(&USB_DRIVER) == USB_ACTIVE; | ||||
|     master = right_hand; | ||||
|  | ||||
|     if (master) { | ||||
|       twi2c_init(); | ||||
|     } else { | ||||
|       twi2c_slave_init(); | ||||
|     } | ||||
|  | ||||
|     /* Column(sense) */ | ||||
|     palSetPadMode(GPIOA, 13, PAL_MODE_INPUT_PULLDOWN); | ||||
|     palSetPadMode(GPIOA, 14, PAL_MODE_INPUT_PULLDOWN); | ||||
|     palSetPadMode(GPIOA, 15, PAL_MODE_INPUT_PULLDOWN); | ||||
|     palSetPadMode(GPIOB, 3,  PAL_MODE_INPUT_PULLDOWN); | ||||
|     palSetPadMode(GPIOB, 4,  PAL_MODE_INPUT_PULLDOWN); | ||||
|     palSetPadMode(GPIOB, 5,  PAL_MODE_INPUT_PULLDOWN); | ||||
|     palSetPadMode(GPIOB, 6,  PAL_MODE_INPUT_PULLDOWN); | ||||
|  | ||||
|     /* Row(strobe) */ | ||||
|     palSetPadMode(GPIOB, 10, PAL_MODE_OUTPUT_PUSHPULL); | ||||
|     palSetPadMode(GPIOB, 2,  PAL_MODE_OUTPUT_PUSHPULL); | ||||
|     palSetPadMode(GPIOB, 1,  PAL_MODE_OUTPUT_PUSHPULL); | ||||
|     palSetPadMode(GPIOB, 0,  PAL_MODE_OUTPUT_PUSHPULL); | ||||
|     palSetPadMode(GPIOA, 7,  PAL_MODE_OUTPUT_PUSHPULL); | ||||
|     palSetPadMode(GPIOA, 6,  PAL_MODE_OUTPUT_PUSHPULL); | ||||
|  | ||||
|     memset(matrix, 0, MATRIX_ROWS * sizeof(matrix_row_t)); | ||||
|     memset(matrix_debouncing, 0, MATRIX_ROWS * sizeof(matrix_row_t)); | ||||
|  | ||||
|     // palClearPad(GPIOB, 7);  // Turn off capslock | ||||
|     matrix_init_quantum(); | ||||
| } | ||||
|  | ||||
| matrix_row_t matrix_scan_common(uint8_t row) { | ||||
|   matrix_row_t data; | ||||
|  | ||||
|   // strobe row { A6, A7, B0, B1, B2, B10 } | ||||
|   switch (row) { | ||||
|       case 5: palSetPad(GPIOA, 6); break; | ||||
|       case 4: palSetPad(GPIOA, 7); break; | ||||
|       case 3: palSetPad(GPIOB, 0); break; | ||||
|       case 2: palSetPad(GPIOB, 1); break; | ||||
|       case 1: palSetPad(GPIOB, 2); break; | ||||
|       case 0: palSetPad(GPIOB, 10); break; | ||||
|   } | ||||
|  | ||||
|   // need wait to settle pin state | ||||
|   wait_us(20); | ||||
|  | ||||
|   // read col data {  B6, B5, B4, B3, A15, A14, A13 } | ||||
|   data = ( | ||||
|       (palReadPad(GPIOB, 6)  << 6 ) | | ||||
|       (palReadPad(GPIOB, 5)  << 5 ) | | ||||
|       (palReadPad(GPIOB, 4)  << 4 ) | | ||||
|       (palReadPad(GPIOB, 3)  << 3 ) | | ||||
|       (palReadPad(GPIOA, 15) << 2 ) | | ||||
|       (palReadPad(GPIOA, 14) << 1 ) | | ||||
|       (palReadPad(GPIOA, 13) << 0 ) | ||||
|   ); | ||||
|  | ||||
|   // unstrobe row { A6, A7, B0, B1, B2, B10 } | ||||
|   switch (row) { | ||||
|       case 5: palClearPad(GPIOA, 6); break; | ||||
|       case 4: palClearPad(GPIOA, 7); break; | ||||
|       case 3: palClearPad(GPIOB, 0); break; | ||||
|       case 2: palClearPad(GPIOB, 1); break; | ||||
|       case 1: palClearPad(GPIOB, 2); break; | ||||
|       case 0: palClearPad(GPIOB, 10); break; | ||||
|   } | ||||
|  | ||||
|   return data; | ||||
| } | ||||
|  | ||||
| const uint8_t command[2] = { 0x01, 0x00 }; | ||||
| uint8_t other_matrix[MATRIX_ROWS] = { 0 }; | ||||
|  | ||||
| void matrix_scan_master(void) { | ||||
|  | ||||
|   msg_t resp; | ||||
|   // resp = twi2c_master_send(slaveI2Caddress/2, command, 2, other_matrix, US2ST(100)); | ||||
|   resp = i2cMasterTransmitTimeout(&I2C_DRIVER, slaveI2Caddress/2, command, 2, other_matrix, MATRIX_ROWS / 2, MS2ST(100)); | ||||
|   // resp = i2cMasterReceiveTimeout(&I2C_DRIVER, slaveI2Caddress/2, other_matrix, MATRIX_ROWS / 2, US2ST(100)); | ||||
|   // printf("%x\n", resp); | ||||
|   // if (resp != MSG_OK) { | ||||
|   //   for (i = 0; i < MATRIX_ROWS / 2; i++) { | ||||
|   //     resp = i2cMasterReceiveTimeout(&I2C_DRIVER, slaveI2Caddress/2, other_matrix, MATRIX_ROWS / 2, US2ST(100)); | ||||
|   //   } | ||||
|   // } | ||||
|  | ||||
|   if (resp == MSG_OK) { | ||||
|     uint8_t * matrix_pointer; | ||||
|     if (right_hand) { | ||||
|       matrix_pointer = matrix; | ||||
|     } else { | ||||
|       matrix_pointer = matrix + (MATRIX_ROWS / 2); | ||||
|     } | ||||
|  | ||||
|     memcpy(matrix_pointer, other_matrix, MATRIX_ROWS / 2); | ||||
|   } | ||||
| } | ||||
|  | ||||
| uint8_t matrix_scan(void) { | ||||
|  | ||||
|     for (int row = 0; row < MATRIX_ROWS; row++) { | ||||
|         matrix_row_t data = 0; | ||||
|  | ||||
|         if ((right_hand && row >= 6) || (!right_hand && row < 6)) { | ||||
|           data = matrix_scan_common(row % 6); | ||||
|         } | ||||
|  | ||||
|         if (matrix_debouncing[row] != data) { | ||||
|             matrix_debouncing[row] = data; | ||||
|             debouncing = true; | ||||
|             debouncing_time = timer_read(); | ||||
|         } | ||||
|     } | ||||
|  | ||||
|     if (debouncing && timer_elapsed(debouncing_time) > DEBOUNCE) { | ||||
|         for (int row = 0; row < MATRIX_ROWS; row++) { | ||||
|             matrix[row] = matrix_debouncing[row]; | ||||
|         } | ||||
|         debouncing = false; | ||||
|     } | ||||
|  | ||||
|     if (master) { | ||||
|       matrix_scan_master(); | ||||
|     } | ||||
|  | ||||
|     matrix_scan_quantum(); | ||||
|  | ||||
|     return 1; | ||||
| } | ||||
|  | ||||
| bool matrix_is_on(uint8_t row, uint8_t col) { | ||||
|     return (matrix[row] & (1<<col)); | ||||
| } | ||||
|  | ||||
| matrix_row_t matrix_get_row(uint8_t row) { | ||||
|     return matrix[row]; | ||||
| } | ||||
|  | ||||
| void matrix_copy(matrix_row_t * copy) { | ||||
|   uint8_t * matrix_pointer; | ||||
|   if (right_hand) { | ||||
|     matrix_pointer = matrix + (MATRIX_ROWS / 2); | ||||
|   } else { | ||||
|     matrix_pointer = matrix; | ||||
|   } | ||||
|   memcpy(copy, matrix_pointer, MATRIX_ROWS / 2); | ||||
| } | ||||
|  | ||||
| void matrix_print(void) { | ||||
|     printf("\nr/c 01234567\n"); | ||||
|     for (uint8_t row = 0; row < MATRIX_ROWS; row++) { | ||||
|         printf("%X0: ", row); | ||||
|         matrix_row_t data = matrix_get_row(row); | ||||
|         for (int col = 0; col < MATRIX_COLS; col++) { | ||||
|             if (data & (1<<col)) | ||||
|                 printf("1"); | ||||
|             else | ||||
|                 printf("0"); | ||||
|         } | ||||
|         printf("\n"); | ||||
|     } | ||||
| } | ||||
							
								
								
									
										257
									
								
								keyboards/proton_c/mcuconf.h
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										257
									
								
								keyboards/proton_c/mcuconf.h
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,257 @@ | ||||
| /* | ||||
|     ChibiOS - Copyright (C) 2006..2016 Giovanni Di Sirio | ||||
|  | ||||
|     Licensed under the Apache License, Version 2.0 (the "License"); | ||||
|     you may not use this file except in compliance with the License. | ||||
|     You may obtain a copy of the License at | ||||
|  | ||||
|         http://www.apache.org/licenses/LICENSE-2.0 | ||||
|  | ||||
|     Unless required by applicable law or agreed to in writing, software | ||||
|     distributed under the License is distributed on an "AS IS" BASIS, | ||||
|     WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. | ||||
|     See the License for the specific language governing permissions and | ||||
|     limitations under the License. | ||||
| */ | ||||
|  | ||||
| #ifndef MCUCONF_H | ||||
| #define MCUCONF_H | ||||
|  | ||||
| /* | ||||
|  * STM32F3xx drivers configuration. | ||||
|  * The following settings override the default settings present in | ||||
|  * the various device driver implementation headers. | ||||
|  * Note that the settings for each driver only have effect if the whole | ||||
|  * driver is enabled in halconf.h. | ||||
|  * | ||||
|  * IRQ priorities: | ||||
|  * 15...0       Lowest...Highest. | ||||
|  * | ||||
|  * DMA priorities: | ||||
|  * 0...3        Lowest...Highest. | ||||
|  */ | ||||
|  | ||||
| #define STM32F3xx_MCUCONF | ||||
|  | ||||
| /* | ||||
|  * HAL driver system settings. | ||||
|  */ | ||||
| #define STM32_NO_INIT                       FALSE | ||||
| #define STM32_PVD_ENABLE                    FALSE | ||||
| #define STM32_PLS                           STM32_PLS_LEV0 | ||||
| #define STM32_HSI_ENABLED                   TRUE | ||||
| #define STM32_LSI_ENABLED                   TRUE | ||||
| #define STM32_HSE_ENABLED                   TRUE | ||||
| #define STM32_LSE_ENABLED                   FALSE | ||||
| #define STM32_SW                            STM32_SW_PLL | ||||
| #define STM32_PLLSRC                        STM32_PLLSRC_HSE | ||||
| #define STM32_PREDIV_VALUE                  1 | ||||
| #define STM32_PLLMUL_VALUE                  9 | ||||
| #define STM32_HPRE                          STM32_HPRE_DIV1 | ||||
| #define STM32_PPRE1                         STM32_PPRE1_DIV2 | ||||
| #define STM32_PPRE2                         STM32_PPRE2_DIV2 | ||||
| #define STM32_MCOSEL                        STM32_MCOSEL_NOCLOCK | ||||
| #define STM32_ADC12PRES                     STM32_ADC12PRES_DIV1 | ||||
| #define STM32_ADC34PRES                     STM32_ADC34PRES_DIV1 | ||||
| #define STM32_USART1SW                      STM32_USART1SW_PCLK | ||||
| #define STM32_USART2SW                      STM32_USART2SW_PCLK | ||||
| #define STM32_USART3SW                      STM32_USART3SW_PCLK | ||||
| #define STM32_UART4SW                       STM32_UART4SW_PCLK | ||||
| #define STM32_UART5SW                       STM32_UART5SW_PCLK | ||||
| #define STM32_I2C1SW                        STM32_I2C1SW_SYSCLK | ||||
| #define STM32_I2C2SW                        STM32_I2C2SW_SYSCLK | ||||
| #define STM32_TIM1SW                        STM32_TIM1SW_PCLK2 | ||||
| #define STM32_TIM8SW                        STM32_TIM8SW_PCLK2 | ||||
| #define STM32_RTCSEL                        STM32_RTCSEL_LSI | ||||
| #define STM32_USB_CLOCK_REQUIRED            TRUE | ||||
| #define STM32_USBPRE                        STM32_USBPRE_DIV1P5 | ||||
|  | ||||
| #undef STM32_HSE_BYPASS | ||||
| // #error "oh no" | ||||
| // #endif | ||||
|  | ||||
| /* | ||||
|  * ADC driver system settings. | ||||
|  */ | ||||
| #define STM32_ADC_DUAL_MODE                 FALSE | ||||
| #define STM32_ADC_COMPACT_SAMPLES           FALSE | ||||
| #define STM32_ADC_USE_ADC1                  FALSE | ||||
| #define STM32_ADC_USE_ADC2                  FALSE | ||||
| #define STM32_ADC_USE_ADC3                  FALSE | ||||
| #define STM32_ADC_USE_ADC4                  FALSE | ||||
| #define STM32_ADC_ADC1_DMA_STREAM           STM32_DMA_STREAM_ID(1, 1) | ||||
| #define STM32_ADC_ADC2_DMA_STREAM           STM32_DMA_STREAM_ID(2, 1) | ||||
| #define STM32_ADC_ADC3_DMA_STREAM           STM32_DMA_STREAM_ID(2, 5) | ||||
| #define STM32_ADC_ADC4_DMA_STREAM           STM32_DMA_STREAM_ID(2, 2) | ||||
| #define STM32_ADC_ADC1_DMA_PRIORITY         2 | ||||
| #define STM32_ADC_ADC2_DMA_PRIORITY         2 | ||||
| #define STM32_ADC_ADC3_DMA_PRIORITY         2 | ||||
| #define STM32_ADC_ADC4_DMA_PRIORITY         2 | ||||
| #define STM32_ADC_ADC12_IRQ_PRIORITY        5 | ||||
| #define STM32_ADC_ADC3_IRQ_PRIORITY         5 | ||||
| #define STM32_ADC_ADC4_IRQ_PRIORITY         5 | ||||
| #define STM32_ADC_ADC1_DMA_IRQ_PRIORITY     5 | ||||
| #define STM32_ADC_ADC2_DMA_IRQ_PRIORITY     5 | ||||
| #define STM32_ADC_ADC3_DMA_IRQ_PRIORITY     5 | ||||
| #define STM32_ADC_ADC4_DMA_IRQ_PRIORITY     5 | ||||
| #define STM32_ADC_ADC12_CLOCK_MODE          ADC_CCR_CKMODE_AHB_DIV1 | ||||
| #define STM32_ADC_ADC34_CLOCK_MODE          ADC_CCR_CKMODE_AHB_DIV1 | ||||
|  | ||||
| /* | ||||
|  * CAN driver system settings. | ||||
|  */ | ||||
| #define STM32_CAN_USE_CAN1                  FALSE | ||||
| #define STM32_CAN_CAN1_IRQ_PRIORITY         11 | ||||
|  | ||||
| /* | ||||
|  * DAC driver system settings. | ||||
|  */ | ||||
| #define STM32_DAC_DUAL_MODE                 FALSE | ||||
| #define STM32_DAC_USE_DAC1_CH1              TRUE | ||||
| #define STM32_DAC_USE_DAC1_CH2              TRUE | ||||
| #define STM32_DAC_DAC1_CH1_IRQ_PRIORITY     10 | ||||
| #define STM32_DAC_DAC1_CH2_IRQ_PRIORITY     10 | ||||
| #define STM32_DAC_DAC1_CH1_DMA_PRIORITY     2 | ||||
| #define STM32_DAC_DAC1_CH2_DMA_PRIORITY     2 | ||||
|  | ||||
| /* | ||||
|  * EXT driver system settings. | ||||
|  */ | ||||
| #define STM32_EXT_EXTI0_IRQ_PRIORITY        6 | ||||
| #define STM32_EXT_EXTI1_IRQ_PRIORITY        6 | ||||
| #define STM32_EXT_EXTI2_IRQ_PRIORITY        6 | ||||
| #define STM32_EXT_EXTI3_IRQ_PRIORITY        6 | ||||
| #define STM32_EXT_EXTI4_IRQ_PRIORITY        6 | ||||
| #define STM32_EXT_EXTI5_9_IRQ_PRIORITY      6 | ||||
| #define STM32_EXT_EXTI10_15_IRQ_PRIORITY    6 | ||||
| #define STM32_EXT_EXTI16_IRQ_PRIORITY       6 | ||||
| #define STM32_EXT_EXTI17_IRQ_PRIORITY       6 | ||||
| #define STM32_EXT_EXTI18_IRQ_PRIORITY       6 | ||||
| #define STM32_EXT_EXTI19_IRQ_PRIORITY       6 | ||||
| #define STM32_EXT_EXTI20_IRQ_PRIORITY       6 | ||||
| #define STM32_EXT_EXTI21_22_29_IRQ_PRIORITY 6 | ||||
| #define STM32_EXT_EXTI30_32_IRQ_PRIORITY    6 | ||||
| #define STM32_EXT_EXTI33_IRQ_PRIORITY       6 | ||||
|  | ||||
| /* | ||||
|  * GPT driver system settings. | ||||
|  */ | ||||
| #define STM32_GPT_USE_TIM1                  FALSE | ||||
| #define STM32_GPT_USE_TIM2                  FALSE | ||||
| #define STM32_GPT_USE_TIM3                  FALSE | ||||
| #define STM32_GPT_USE_TIM4                  FALSE | ||||
| #define STM32_GPT_USE_TIM6                  TRUE | ||||
| #define STM32_GPT_USE_TIM7                  TRUE | ||||
| #define STM32_GPT_USE_TIM8                  TRUE | ||||
| #define STM32_GPT_TIM1_IRQ_PRIORITY         7 | ||||
| #define STM32_GPT_TIM2_IRQ_PRIORITY         7 | ||||
| #define STM32_GPT_TIM3_IRQ_PRIORITY         7 | ||||
| #define STM32_GPT_TIM4_IRQ_PRIORITY         7 | ||||
| #define STM32_GPT_TIM6_IRQ_PRIORITY         7 | ||||
| #define STM32_GPT_TIM7_IRQ_PRIORITY         7 | ||||
| #define STM32_GPT_TIM8_IRQ_PRIORITY         7 | ||||
|  | ||||
| /* | ||||
|  * I2C driver system settings. | ||||
|  */ | ||||
| #define STM32_I2C_USE_I2C1                  TRUE | ||||
| #define STM32_I2C_USE_I2C2                  FALSE | ||||
| #define STM32_I2C_BUSY_TIMEOUT              50 | ||||
| #define STM32_I2C_I2C1_IRQ_PRIORITY         10 | ||||
| #define STM32_I2C_I2C2_IRQ_PRIORITY         10 | ||||
| #define STM32_I2C_USE_DMA                   TRUE | ||||
| #define STM32_I2C_I2C1_DMA_PRIORITY         1 | ||||
| #define STM32_I2C_I2C2_DMA_PRIORITY         1 | ||||
| #define STM32_I2C_DMA_ERROR_HOOK(i2cp)      osalSysHalt("DMA failure") | ||||
|  | ||||
| /* | ||||
|  * ICU driver system settings. | ||||
|  */ | ||||
| #define STM32_ICU_USE_TIM1                  FALSE | ||||
| #define STM32_ICU_USE_TIM2                  FALSE | ||||
| #define STM32_ICU_USE_TIM3                  FALSE | ||||
| #define STM32_ICU_USE_TIM4                  FALSE | ||||
| #define STM32_ICU_USE_TIM8                  FALSE | ||||
| #define STM32_ICU_TIM1_IRQ_PRIORITY         7 | ||||
| #define STM32_ICU_TIM2_IRQ_PRIORITY         7 | ||||
| #define STM32_ICU_TIM3_IRQ_PRIORITY         7 | ||||
| #define STM32_ICU_TIM4_IRQ_PRIORITY         7 | ||||
| #define STM32_ICU_TIM8_IRQ_PRIORITY         7 | ||||
|  | ||||
| /* | ||||
|  * PWM driver system settings. | ||||
|  */ | ||||
| #define STM32_PWM_USE_ADVANCED              FALSE | ||||
| #define STM32_PWM_USE_TIM1                  FALSE | ||||
| #define STM32_PWM_USE_TIM2                  FALSE | ||||
| #define STM32_PWM_USE_TIM3                  FALSE | ||||
| #define STM32_PWM_USE_TIM4                  FALSE | ||||
| #define STM32_PWM_USE_TIM8                  FALSE | ||||
| #define STM32_PWM_TIM1_IRQ_PRIORITY         7 | ||||
| #define STM32_PWM_TIM2_IRQ_PRIORITY         7 | ||||
| #define STM32_PWM_TIM3_IRQ_PRIORITY         7 | ||||
| #define STM32_PWM_TIM4_IRQ_PRIORITY         7 | ||||
| #define STM32_PWM_TIM8_IRQ_PRIORITY         7 | ||||
|  | ||||
| /* | ||||
|  * SERIAL driver system settings. | ||||
|  */ | ||||
| #define STM32_SERIAL_USE_USART1             FALSE | ||||
| #define STM32_SERIAL_USE_USART2             FALSE | ||||
| #define STM32_SERIAL_USE_USART3             FALSE | ||||
| #define STM32_SERIAL_USE_UART4              FALSE | ||||
| #define STM32_SERIAL_USE_UART5              FALSE | ||||
| #define STM32_SERIAL_USART1_PRIORITY        12 | ||||
| #define STM32_SERIAL_USART2_PRIORITY        12 | ||||
| #define STM32_SERIAL_USART3_PRIORITY        12 | ||||
| #define STM32_SERIAL_UART4_PRIORITY         12 | ||||
| #define STM32_SERIAL_UART5_PRIORITY         12 | ||||
|  | ||||
| /* | ||||
|  * SPI driver system settings. | ||||
|  */ | ||||
| #define STM32_SPI_USE_SPI1                  FALSE | ||||
| #define STM32_SPI_USE_SPI2                  FALSE | ||||
| #define STM32_SPI_USE_SPI3                  FALSE | ||||
| #define STM32_SPI_SPI1_DMA_PRIORITY         1 | ||||
| #define STM32_SPI_SPI2_DMA_PRIORITY         1 | ||||
| #define STM32_SPI_SPI3_DMA_PRIORITY         1 | ||||
| #define STM32_SPI_SPI1_IRQ_PRIORITY         10 | ||||
| #define STM32_SPI_SPI2_IRQ_PRIORITY         10 | ||||
| #define STM32_SPI_SPI3_IRQ_PRIORITY         10 | ||||
| #define STM32_SPI_DMA_ERROR_HOOK(spip)      osalSysHalt("DMA failure") | ||||
|  | ||||
| /* | ||||
|  * ST driver system settings. | ||||
|  */ | ||||
| #define STM32_ST_IRQ_PRIORITY               8 | ||||
| #define STM32_ST_USE_TIMER                  2 | ||||
|  | ||||
| /* | ||||
|  * UART driver system settings. | ||||
|  */ | ||||
| #define STM32_UART_USE_USART1               FALSE | ||||
| #define STM32_UART_USE_USART2               FALSE | ||||
| #define STM32_UART_USE_USART3               FALSE | ||||
| #define STM32_UART_USART1_IRQ_PRIORITY      12 | ||||
| #define STM32_UART_USART2_IRQ_PRIORITY      12 | ||||
| #define STM32_UART_USART3_IRQ_PRIORITY      12 | ||||
| #define STM32_UART_USART1_DMA_PRIORITY      0 | ||||
| #define STM32_UART_USART2_DMA_PRIORITY      0 | ||||
| #define STM32_UART_USART3_DMA_PRIORITY      0 | ||||
| #define STM32_UART_DMA_ERROR_HOOK(uartp)    osalSysHalt("DMA failure") | ||||
|  | ||||
| /* | ||||
|  * USB driver system settings. | ||||
|  */ | ||||
| #define STM32_USB_USE_USB1                  TRUE | ||||
| #define STM32_USB_LOW_POWER_ON_SUSPEND      FALSE | ||||
| #define STM32_USB_USB1_HP_IRQ_PRIORITY      13 | ||||
| #define STM32_USB_USB1_LP_IRQ_PRIORITY      14 | ||||
|  | ||||
| /* | ||||
|  * WDG driver system settings. | ||||
|  */ | ||||
| #define STM32_WDG_USE_IWDG                  FALSE | ||||
|  | ||||
| #endif /* MCUCONF_H */ | ||||
							
								
								
									
										25
									
								
								keyboards/proton_c/proton_c.c
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										25
									
								
								keyboards/proton_c/proton_c.c
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,25 @@ | ||||
| /* Copyright 2017 skully <skullydazed@gmail.com> | ||||
|  *           2018 Jack Humbert <jack.humb@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 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 "proton_c.h" | ||||
|  | ||||
| void matrix_init_kb(void) { | ||||
|  | ||||
| } | ||||
|  | ||||
| void matrix_scan_kb(void) { | ||||
|  | ||||
| } | ||||
							
								
								
									
										59
									
								
								keyboards/proton_c/proton_c.h
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										59
									
								
								keyboards/proton_c/proton_c.h
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,59 @@ | ||||
| /* Copyright 2017 skully <skullydazed@gmail.com> | ||||
|  *           2018 Jack Humbert <jack.humb@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 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/>. | ||||
|  */ | ||||
| #ifndef PROTON_C_H | ||||
| #define PROTON_C_H | ||||
|  | ||||
| #include "quantum.h" | ||||
|  | ||||
| /* | ||||
|  * These are shortcuts to help you work with the various layout options. If your | ||||
|  * keymap works with one of the LAYOUT_...() macros you are encouraged to use that | ||||
|  * and to contribute your keymap to the corresponding layout in | ||||
|  * `qmk_firmware/layouts/community`. | ||||
|  */ | ||||
|  | ||||
| /* The fully-featured KEYMAP() that has every single key available in the matrix. | ||||
|  */ | ||||
| #define KEYMAP(\ | ||||
|     j00, j01, j02, j03, j04, j05, j06, \ | ||||
|     j10, j11, j12, j13, j14, j15, j16, \ | ||||
|     j20, j21, j22, j23, j24, j25, j26, \ | ||||
|     j30, j31, j32, j33, j34, j35, \ | ||||
|     j40, j41, j42, j43, j44, \ | ||||
|                         j54, j55, j56, \ | ||||
|     k00, k01, k02, k03, k04, k05, k06, \ | ||||
|     k10, k11, k12, k13, k14, k15, k16, \ | ||||
|     k20, k21, k22, k23, k24, k25, k26, \ | ||||
|          k31, k32, k33, k34, k35, k36, \ | ||||
|               k42, k43, k44, k45, k46, \ | ||||
|     k50, k51, k52 \ | ||||
| ) { \ | ||||
|     { j00, j01, j02, j03, j04, j05, j06 }, \ | ||||
|     { j10, j11, j12, j13, j14, j15, j16 }, \ | ||||
|     { j20, j21, j22, j23, j24, j25, j26 }, \ | ||||
|     { j30, j31, j32, j33, j34, j35, 0   }, \ | ||||
|     { j40, j41, j42, j43, j44, 0,   0   }, \ | ||||
|     { 0,   0,   0,   0,   j54, j55, j56 }, \ | ||||
|     { k00, k01, k02, k03, k04, k05, k06 }, \ | ||||
|     { k10, k11, k12, k13, k14, k15, k16 }, \ | ||||
|     { k20, k21, k22, k23, k24, k25, k26 }, \ | ||||
|     { 0,   k31, k32, k33, k34, k35, k36 }, \ | ||||
|     { 0,   0,   k42, k43, k44, k45, k46 }, \ | ||||
|     { k50, k51, k52, 0,   0,   0,   0   } \ | ||||
| } | ||||
|  | ||||
| #endif | ||||
							
								
								
									
										14
									
								
								keyboards/proton_c/readme.md
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										14
									
								
								keyboards/proton_c/readme.md
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,14 @@ | ||||
| # Proton C | ||||
|  | ||||
| An Arm-based handwire board. | ||||
|  | ||||
| * Keyboard Maintainer: [Jack Humbert](https://github.com/jackhumbert) | ||||
| * Hardware Supported: QMK Proton C | ||||
|   * rev1 (1.0) | ||||
| * Hardware Availability: [qmk.fm](https://qmk.fm/) | ||||
|  | ||||
| Make example for this keyboard (after setting up your build environment): | ||||
|  | ||||
|     make proton_c:default | ||||
|  | ||||
| See [build environment setup](https://docs.qmk.fm/build_environment_setup.html) then the [make instructions](https://docs.qmk.fm/make_instructions.html) for more information. | ||||
							
								
								
									
										56
									
								
								keyboards/proton_c/rules.mk
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										56
									
								
								keyboards/proton_c/rules.mk
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,56 @@ | ||||
| # project specific files | ||||
| SRC =	matrix.c \ | ||||
| 	led.c | ||||
|  | ||||
| ## chip/board settings | ||||
| # - the next two should match the directories in | ||||
| #   <chibios>/os/hal/ports/$(MCU_FAMILY)/$(MCU_SERIES) | ||||
| MCU_FAMILY = STM32 | ||||
| MCU_SERIES = STM32F3xx | ||||
|  | ||||
| # Linker script to use | ||||
| # - it should exist either in <chibios>/os/common/ports/ARMCMx/compilers/GCC/ld/ | ||||
| #   or <this_dir>/ld/ | ||||
| MCU_LDSCRIPT = STM32F303xC | ||||
|  | ||||
| # Startup code to use | ||||
| #  - it should exist in <chibios>/os/common/startup/ARMCMx/compilers/GCC/mk/ | ||||
| MCU_STARTUP = stm32f3xx | ||||
|  | ||||
| # Board: it should exist either in <chibios>/os/hal/boards/ | ||||
| #  or <this_dir>/boards | ||||
| BOARD = GENERIC_STM32_F303XC | ||||
|  | ||||
| # Cortex version | ||||
| MCU  = cortex-m4 | ||||
|  | ||||
| # ARM version, CORTEX-M0/M1 are 6, CORTEX-M3/M4/M7 are 7 | ||||
| ARMV = 7 | ||||
|  | ||||
| USE_FPU = yes | ||||
|  | ||||
| # Vector table for application | ||||
| # 0x00000000-0x00001000 area is occupied by bootlaoder.*/ | ||||
| # The CORTEX_VTOR... is needed only for MCHCK/Infinity KB | ||||
| # OPT_DEFS = -DCORTEX_VTOR_INIT=0x08005000 | ||||
| OPT_DEFS = | ||||
|  | ||||
| # Options to pass to dfu-util when flashing | ||||
| DFU_ARGS = -d 0483:df11 -a 0 -s 0x08000000:leave | ||||
|  | ||||
| # Build Options | ||||
| #   comment out to disable the options. | ||||
| # | ||||
| BACKLIGHT_ENABLE = no | ||||
| BOOTMAGIC_ENABLE = yes	# Virtual DIP switch configuration | ||||
| ## (Note that for BOOTMAGIC on Teensy LC you have to use a custom .ld script.) | ||||
| MOUSEKEY_ENABLE = yes	# Mouse keys | ||||
| EXTRAKEY_ENABLE = yes	# Audio control and System control | ||||
| CONSOLE_ENABLE = yes	# Console for debug | ||||
| COMMAND_ENABLE = yes    # Commands for debug and configuration | ||||
| #SLEEP_LED_ENABLE = yes  # Breathing sleep LED during USB suspend | ||||
| NKRO_ENABLE = yes	    # USB Nkey Rollover | ||||
| CUSTOM_MATRIX = yes # Custom matrix file | ||||
| AUDIO_ENABLE = yes | ||||
| # SERIAL_LINK_ENABLE = yes | ||||
| I2C_SLAVE_ENABLE = yes | ||||
 Submodule lib/chibios updated: 587968d6cb...c846437e39
									
								
							| @@ -79,7 +79,7 @@ float startup_song[][2] = STARTUP_SONG; | ||||
|  | ||||
| static void gpt_cb8(GPTDriver *gptp); | ||||
|  | ||||
| #define DAC_BUFFER_SIZE 360 | ||||
| #define DAC_BUFFER_SIZE 720 | ||||
|  | ||||
| #define START_CHANNEL_1() gptStart(&GPTD6, &gpt6cfg1); \ | ||||
|     gptStartContinuous(&GPTD6, 2U) | ||||
| @@ -167,6 +167,39 @@ GPTConfig gpt8cfg1 = { | ||||
| //   1622, 1657, 1692, 1727, 1763, 1798, 1834, 1869, 1905, 1940, 1976, 2012 | ||||
| // }; | ||||
|  | ||||
| // static const dacsample_t dac_buffer_2[DAC_BUFFER_SIZE] = { | ||||
| //     12,    8,    5,    3,    2,    1,    0,    1,    2,    3,    5,    8, | ||||
| //     12,   16,   20,   26,   32,   38,   45,   53,   61,   70,   80,   90, | ||||
| //    101,  112,  124,  136,  150,  163,  177,  192,  208,  224,  240,  257, | ||||
| //    275,  293,  312,  331,  350,  371,  391,  413,  434,  457,  479,  503, | ||||
| //    526,  550,  575,  600,  626,  651,  678,  705,  732,  759,  787,  816, | ||||
| //    844,  873,  903,  933,  963,  993, 1024, 1055, 1086, 1118, 1150, 1182, | ||||
| //   1215, 1248, 1281, 1314, 1347, 1381, 1415, 1449, 1483, 1518, 1552, 1587, | ||||
| //   1622, 1657, 1692, 1727, 1763, 1798, 1834, 1869, 1905, 1940, 1976, 2012, | ||||
| //   2047, 2082, 2118, 2154, 2189, 2225, 2260, 2296, 2331, 2367, 2402, 2437, | ||||
| //   2472, 2507, 2542, 2576, 2611, 2645, 2679, 2713, 2747, 2780, 2813, 2846, | ||||
| //   2879, 2912, 2944, 2976, 3008, 3039, 3070, 3101, 3131, 3161, 3191, 3221, | ||||
| //   3250, 3278, 3307, 3335, 3362, 3389, 3416, 3443, 3468, 3494, 3519, 3544, | ||||
| //   3568, 3591, 3615, 3637, 3660, 3681, 3703, 3723, 3744, 3763, 3782, 3801, | ||||
| //   3819, 3837, 3854, 3870, 3886, 3902, 3917, 3931, 3944, 3958, 3970, 3982, | ||||
| //   3993, 4004, 4014, 4024, 4033, 4041, 4049, 4056, 4062, 4068, 4074, 4078, | ||||
| //   4082, 4086, 4089, 4091, 4092, 4093, 4094, 4093, 4092, 4091, 4089, 4086, | ||||
| //   4082, 4078, 4074, 4068, 4062, 4056, 4049, 4041, 4033, 4024, 4014, 4004, | ||||
| //   3993, 3982, 3970, 3958, 3944, 3931, 3917, 3902, 3886, 3870, 3854, 3837, | ||||
| //   3819, 3801, 3782, 3763, 3744, 3723, 3703, 3681, 3660, 3637, 3615, 3591, | ||||
| //   3568, 3544, 3519, 3494, 3468, 3443, 3416, 3389, 3362, 3335, 3307, 3278, | ||||
| //   3250, 3221, 3191, 3161, 3131, 3101, 3070, 3039, 3008, 2976, 2944, 2912, | ||||
| //   2879, 2846, 2813, 2780, 2747, 2713, 2679, 2645, 2611, 2576, 2542, 2507, | ||||
| //   2472, 2437, 2402, 2367, 2331, 2296, 2260, 2225, 2189, 2154, 2118, 2082, | ||||
| //   2047, 2012, 1976, 1940, 1905, 1869, 1834, 1798, 1763, 1727, 1692, 1657, | ||||
| //   1622, 1587, 1552, 1518, 1483, 1449, 1415, 1381, 1347, 1314, 1281, 1248, | ||||
| //   1215, 1182, 1150, 1118, 1086, 1055, 1024,  993,  963,  933,  903,  873, | ||||
| //    844,  816,  787,  759,  732,  705,  678,  651,  626,  600,  575,  550, | ||||
| //    526,  503,  479,  457,  434,  413,  391,  371,  350,  331,  312,  293, | ||||
| //    275,  257,  240,  224,  208,  192,  177,  163,  150,  136,  124,  112, | ||||
| //    101,   90,   80,   70,   61,   53,   45,   38,   32,   26,   20,   16 | ||||
| // }; | ||||
|  | ||||
| // squarewave | ||||
| static const dacsample_t dac_buffer[DAC_BUFFER_SIZE] = { | ||||
|   2047, 2047, 2047, 2047, 2047, 2047, 2047, 2047, 2047, 2047, 2047, 2047, | ||||
| @@ -184,7 +217,37 @@ static const dacsample_t dac_buffer[DAC_BUFFER_SIZE] = { | ||||
|   2047, 2047, 2047, 2047, 2047, 2047, 2047, 2047, 2047, 2047, 2047, 2047, | ||||
|   2047, 2047, 2047, 2047, 2047, 2047, 2047, 2047, 2047, 2047, 2047, 2047, | ||||
|   2047, 2047, 2047, 2047, 2047, 2047, 2047, 2047, 2047, 2047, 2047, 2047, | ||||
|   2047, 2047, 2047, 2047, 2047, 2047, 2047, 2047, 2047, 2047, 2047, 2047, | ||||
|   2047, 2047, 2047, 2047, 2047, 2047, 2047, 2047, 2047, 2047, 2047, 2047, | ||||
|   2047, 2047, 2047, 2047, 2047, 2047, 2047, 2047, 2047, 2047, 2047, 2047, | ||||
|   2047, 2047, 2047, 2047, 2047, 2047, 2047, 2047, 2047, 2047, 2047, 2047, | ||||
|   2047, 2047, 2047, 2047, 2047, 2047, 2047, 2047, 2047, 2047, 2047, 2047, | ||||
|   2047, 2047, 2047, 2047, 2047, 2047, 2047, 2047, 2047, 2047, 2047, 2047, | ||||
|   2047, 2047, 2047, 2047, 2047, 2047, 2047, 2047, 2047, 2047, 2047, 2047, | ||||
|   2047, 2047, 2047, 2047, 2047, 2047, 2047, 2047, 2047, 2047, 2047, 2047, | ||||
|   2047, 2047, 2047, 2047, 2047, 2047, 2047, 2047, 2047, 2047, 2047, 2047, | ||||
|   2047, 2047, 2047, 2047, 2047, 2047, 2047, 2047, 2047, 2047, 2047, 2047, | ||||
|   2047, 2047, 2047, 2047, 2047, 2047, 2047, 2047, 2047, 2047, 2047, 2047, | ||||
|   2047, 2047, 2047, 2047, 2047, 2047, 2047, 2047, 2047, 2047, 2047, 2047, | ||||
|   2047, 2047, 2047, 2047, 2047, 2047, 2047, 2047, 2047, 2047, 2047, 2047, | ||||
|   2047, 2047, 2047, 2047, 2047, 2047, 2047, 2047, 2047, 2047, 2047, 2047, | ||||
|   2047, 2047, 2047, 2047, 2047, 2047, 2047, 2047, 2047, 2047, 2047, 2047, | ||||
|  | ||||
|   0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, | ||||
|   0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, | ||||
|   0, 0, 0, 0, 0, 0, 0,  0,  0,  0,  0,  0, | ||||
|    0,  0,  0,  0,  0,  0,  0,  0,  0,  0,  0,  0, | ||||
|    0,  0,  0,  0,  0,  0,  0,  0,  0,  0,  0,  0, | ||||
|    0,  0,  0,  0,  0,  0,  0,  0,  0,  0,  0,  0, | ||||
|    0,   0,   0,   0,   0,   0,   0,   0,   0,   0,   0,   0, | ||||
|     0,    0,    0,    0,    0,    0,    0,    0,    0,    0,    0,    0, | ||||
|     0,   0,   0,   0,   0,   0,   0,   0,   0,   0,   0,   0, | ||||
|    0,  0,  0,  0,  0,  0,  0,  0,  0,  0,  0,  0, | ||||
|    0,  0,  0,  0,  0,  0,  0,  0,  0,  0,  0,  0, | ||||
|    0,  0,  0,  0,  0,  0,  0,  0,  0,  0,  0,  0, | ||||
|    0,  0,  0,  0,  0,  0, 0, 0, 0, 0, 0, 0, | ||||
|   0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, | ||||
|   0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, | ||||
|   0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, | ||||
|   0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, | ||||
|   0, 0, 0, 0, 0, 0, 0,  0,  0,  0,  0,  0, | ||||
| @@ -204,21 +267,6 @@ static const dacsample_t dac_buffer[DAC_BUFFER_SIZE] = { | ||||
|  | ||||
| // squarewave | ||||
| static const dacsample_t dac_buffer_2[DAC_BUFFER_SIZE] = { | ||||
|   2047, 2047, 2047, 2047, 2047, 2047, 2047, 2047, 2047, 2047, 2047, 2047, | ||||
|   2047, 2047, 2047, 2047, 2047, 2047, 2047, 2047, 2047, 2047, 2047, 2047, | ||||
|   2047, 2047, 2047, 2047, 2047, 2047, 2047, 2047, 2047, 2047, 2047, 2047, | ||||
|   2047, 2047, 2047, 2047, 2047, 2047, 2047, 2047, 2047, 2047, 2047, 2047, | ||||
|   2047, 2047, 2047, 2047, 2047, 2047, 2047, 2047, 2047, 2047, 2047, 2047, | ||||
|   2047, 2047, 2047, 2047, 2047, 2047, 2047, 2047, 2047, 2047, 2047, 2047, | ||||
|   2047, 2047, 2047, 2047, 2047, 2047, 2047, 2047, 2047, 2047, 2047, 2047, | ||||
|   2047, 2047, 2047, 2047, 2047, 2047, 2047, 2047, 2047, 2047, 2047, 2047, | ||||
|   2047, 2047, 2047, 2047, 2047, 2047, 2047, 2047, 2047, 2047, 2047, 2047, | ||||
|   2047, 2047, 2047, 2047, 2047, 2047, 2047, 2047, 2047, 2047, 2047, 2047, | ||||
|   2047, 2047, 2047, 2047, 2047, 2047, 2047, 2047, 2047, 2047, 2047, 2047, | ||||
|   2047, 2047, 2047, 2047, 2047, 2047, 2047, 2047, 2047, 2047, 2047, 2047, | ||||
|   2047, 2047, 2047, 2047, 2047, 2047, 2047, 2047, 2047, 2047, 2047, 2047, | ||||
|   2047, 2047, 2047, 2047, 2047, 2047, 2047, 2047, 2047, 2047, 2047, 2047, | ||||
|   2047, 2047, 2047, 2047, 2047, 2047, 2047, 2047, 2047, 2047, 2047, 2047, | ||||
|  | ||||
|   0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, | ||||
|   0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, | ||||
| @@ -234,7 +282,52 @@ static const dacsample_t dac_buffer_2[DAC_BUFFER_SIZE] = { | ||||
|    0,  0,  0,  0,  0,  0,  0,  0,  0,  0,  0,  0, | ||||
|    0,  0,  0,  0,  0,  0, 0, 0, 0, 0, 0, 0, | ||||
|   0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, | ||||
|   0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0 | ||||
|   0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, | ||||
|   0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, | ||||
|   0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, | ||||
|   0, 0, 0, 0, 0, 0, 0,  0,  0,  0,  0,  0, | ||||
|    0,  0,  0,  0,  0,  0,  0,  0,  0,  0,  0,  0, | ||||
|    0,  0,  0,  0,  0,  0,  0,  0,  0,  0,  0,  0, | ||||
|    0,  0,  0,  0,  0,  0,  0,  0,  0,  0,  0,  0, | ||||
|    0,   0,   0,   0,   0,   0,   0,   0,   0,   0,   0,   0, | ||||
|     0,    0,    0,    0,    0,    0,    0,    0,    0,    0,    0,    0, | ||||
|     0,   0,   0,   0,   0,   0,   0,   0,   0,   0,   0,   0, | ||||
|    0,  0,  0,  0,  0,  0,  0,  0,  0,  0,  0,  0, | ||||
|    0,  0,  0,  0,  0,  0,  0,  0,  0,  0,  0,  0, | ||||
|    0,  0,  0,  0,  0,  0,  0,  0,  0,  0,  0,  0, | ||||
|    0,  0,  0,  0,  0,  0, 0, 0, 0, 0, 0, 0, | ||||
|   0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, | ||||
|   0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, | ||||
|   2047, 2047, 2047, 2047, 2047, 2047, 2047, 2047, 2047, 2047, 2047, 2047, | ||||
|   2047, 2047, 2047, 2047, 2047, 2047, 2047, 2047, 2047, 2047, 2047, 2047, | ||||
|   2047, 2047, 2047, 2047, 2047, 2047, 2047, 2047, 2047, 2047, 2047, 2047, | ||||
|   2047, 2047, 2047, 2047, 2047, 2047, 2047, 2047, 2047, 2047, 2047, 2047, | ||||
|   2047, 2047, 2047, 2047, 2047, 2047, 2047, 2047, 2047, 2047, 2047, 2047, | ||||
|   2047, 2047, 2047, 2047, 2047, 2047, 2047, 2047, 2047, 2047, 2047, 2047, | ||||
|   2047, 2047, 2047, 2047, 2047, 2047, 2047, 2047, 2047, 2047, 2047, 2047, | ||||
|   2047, 2047, 2047, 2047, 2047, 2047, 2047, 2047, 2047, 2047, 2047, 2047, | ||||
|   2047, 2047, 2047, 2047, 2047, 2047, 2047, 2047, 2047, 2047, 2047, 2047, | ||||
|   2047, 2047, 2047, 2047, 2047, 2047, 2047, 2047, 2047, 2047, 2047, 2047, | ||||
|   2047, 2047, 2047, 2047, 2047, 2047, 2047, 2047, 2047, 2047, 2047, 2047, | ||||
|   2047, 2047, 2047, 2047, 2047, 2047, 2047, 2047, 2047, 2047, 2047, 2047, | ||||
|   2047, 2047, 2047, 2047, 2047, 2047, 2047, 2047, 2047, 2047, 2047, 2047, | ||||
|   2047, 2047, 2047, 2047, 2047, 2047, 2047, 2047, 2047, 2047, 2047, 2047, | ||||
|   2047, 2047, 2047, 2047, 2047, 2047, 2047, 2047, 2047, 2047, 2047, 2047, | ||||
|   2047, 2047, 2047, 2047, 2047, 2047, 2047, 2047, 2047, 2047, 2047, 2047, | ||||
|   2047, 2047, 2047, 2047, 2047, 2047, 2047, 2047, 2047, 2047, 2047, 2047, | ||||
|   2047, 2047, 2047, 2047, 2047, 2047, 2047, 2047, 2047, 2047, 2047, 2047, | ||||
|   2047, 2047, 2047, 2047, 2047, 2047, 2047, 2047, 2047, 2047, 2047, 2047, | ||||
|   2047, 2047, 2047, 2047, 2047, 2047, 2047, 2047, 2047, 2047, 2047, 2047, | ||||
|   2047, 2047, 2047, 2047, 2047, 2047, 2047, 2047, 2047, 2047, 2047, 2047, | ||||
|   2047, 2047, 2047, 2047, 2047, 2047, 2047, 2047, 2047, 2047, 2047, 2047, | ||||
|   2047, 2047, 2047, 2047, 2047, 2047, 2047, 2047, 2047, 2047, 2047, 2047, | ||||
|   2047, 2047, 2047, 2047, 2047, 2047, 2047, 2047, 2047, 2047, 2047, 2047, | ||||
|   2047, 2047, 2047, 2047, 2047, 2047, 2047, 2047, 2047, 2047, 2047, 2047, | ||||
|   2047, 2047, 2047, 2047, 2047, 2047, 2047, 2047, 2047, 2047, 2047, 2047, | ||||
|   2047, 2047, 2047, 2047, 2047, 2047, 2047, 2047, 2047, 2047, 2047, 2047, | ||||
|   2047, 2047, 2047, 2047, 2047, 2047, 2047, 2047, 2047, 2047, 2047, 2047, | ||||
|   2047, 2047, 2047, 2047, 2047, 2047, 2047, 2047, 2047, 2047, 2047, 2047, | ||||
|   2047, 2047, 2047, 2047, 2047, 2047, 2047, 2047, 2047, 2047, 2047, 2047 | ||||
| }; | ||||
|  | ||||
| /* | ||||
| @@ -317,7 +410,7 @@ void audio_init() | ||||
|   dacStart(&DACD2, &dac1cfg2); | ||||
|  | ||||
|   /* | ||||
|    * Starting GPT6 driver, it is used for triggering the DAC. | ||||
|    * Starting GPT6/7 driver, it is used for triggering the DAC. | ||||
|    */ | ||||
|   START_CHANNEL_1(); | ||||
|   START_CHANNEL_2(); | ||||
| @@ -325,12 +418,8 @@ void audio_init() | ||||
|   /* | ||||
|    * Starting a continuous conversion. | ||||
|    */ | ||||
|   dacStartConversion(&DACD1, &dacgrpcfg1, | ||||
|                      (dacsample_t *)dac_buffer, DAC_BUFFER_SIZE); | ||||
|   dacStartConversion(&DACD2, &dacgrpcfg2, | ||||
|                      (dacsample_t *)dac_buffer_2, DAC_BUFFER_SIZE); | ||||
|   // gptStartContinuous(&GPTD6, 2U); | ||||
|  | ||||
|   dacStartConversion(&DACD1, &dacgrpcfg1, (dacsample_t *)dac_buffer, DAC_BUFFER_SIZE); | ||||
|   dacStartConversion(&DACD2, &dacgrpcfg2, (dacsample_t *)dac_buffer_2, DAC_BUFFER_SIZE); | ||||
|  | ||||
|     audio_initialized = true; | ||||
|  | ||||
| @@ -469,6 +558,8 @@ static void gpt_cb8(GPTDriver *gptp) { | ||||
|  | ||||
|                     if (GET_CHANNEL_2_FREQ != (uint16_t)freq_alt) { | ||||
|                         UPDATE_CHANNEL_2_FREQ(freq_alt); | ||||
|                     } else { | ||||
|                         RESTART_CHANNEL_2(); | ||||
|                     } | ||||
|                     //note_timbre; | ||||
|                 } | ||||
| @@ -528,6 +619,8 @@ static void gpt_cb8(GPTDriver *gptp) { | ||||
|  | ||||
|             if (GET_CHANNEL_1_FREQ != (uint16_t)freq) { | ||||
|                 UPDATE_CHANNEL_1_FREQ(freq); | ||||
|             } else { | ||||
|                 RESTART_CHANNEL_1(); | ||||
|             } | ||||
|             //note_timbre; | ||||
|         } | ||||
| @@ -565,11 +658,11 @@ static void gpt_cb8(GPTDriver *gptp) { | ||||
|         bool end_of_note = false; | ||||
|         if (GET_CHANNEL_1_FREQ > 0) { | ||||
|             if (!note_resting) | ||||
|                 end_of_note = (note_position >= (note_length*16 - 1)); | ||||
|                 end_of_note = (note_position >= (note_length*8 - 1)); | ||||
|             else | ||||
|                 end_of_note = (note_position >= (note_length*16)); | ||||
|                 end_of_note = (note_position >= (note_length*8)); | ||||
|         } else { | ||||
|             end_of_note = (note_position >= (note_length*16)); | ||||
|             end_of_note = (note_position >= (note_length*8)); | ||||
|         } | ||||
|  | ||||
|         if (end_of_note) { | ||||
| @@ -622,6 +715,7 @@ void play_note(float freq, int vol) { | ||||
|  | ||||
|     if (audio_config.enable && voices < 8) { | ||||
|  | ||||
|  | ||||
|         // Cancel notes if notes are playing | ||||
|         if (playing_notes) | ||||
|             stop_all_notes(); | ||||
|   | ||||
							
								
								
									
										111
									
								
								quantum/audio/muse.c
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										111
									
								
								quantum/audio/muse.c
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,111 @@ | ||||
| #include "muse.h" | ||||
|  | ||||
| enum { | ||||
|   MUSE_OFF, | ||||
|   MUSE_ON, | ||||
|   MUSE_C_1_2, | ||||
|   MUSE_C1, | ||||
|   MUSE_C2, | ||||
|   MUSE_C4, | ||||
|   MUSE_C8, | ||||
|   MUSE_C3, | ||||
|   MUSE_C6, | ||||
|   MUSE_B1, | ||||
|   MUSE_B2, | ||||
|   MUSE_B3, | ||||
|   MUSE_B4, | ||||
|   MUSE_B5, | ||||
|   MUSE_B6, | ||||
|   MUSE_B7, | ||||
|   MUSE_B8, | ||||
|   MUSE_B9, | ||||
|   MUSE_B10, | ||||
|   MUSE_B11, | ||||
|   MUSE_B12, | ||||
|   MUSE_B13, | ||||
|   MUSE_B14, | ||||
|   MUSE_B15, | ||||
|   MUSE_B16, | ||||
|   MUSE_B17, | ||||
|   MUSE_B18, | ||||
|   MUSE_B19, | ||||
|   MUSE_B20, | ||||
|   MUSE_B21, | ||||
|   MUSE_B22, | ||||
|   MUSE_B23, | ||||
|   MUSE_B24, | ||||
|   MUSE_B25, | ||||
|   MUSE_B26, | ||||
|   MUSE_B27, | ||||
|   MUSE_B28, | ||||
|   MUSE_B29, | ||||
|   MUSE_B30, | ||||
|   MUSE_B31 | ||||
| }; | ||||
|  | ||||
| bool number_of_ones_to_bool[16] = { | ||||
|   1, 0, 0, 1, 0, 1, 1, 0, | ||||
|   0, 1, 1, 0, 1, 0, 0, 1 | ||||
| }; | ||||
|  | ||||
| uint8_t muse_interval[4] = {MUSE_B7,  MUSE_B19, MUSE_B3,  MUSE_B28}; | ||||
| uint8_t muse_theme[4]    = {MUSE_B8, MUSE_B23, MUSE_B18, MUSE_B17}; | ||||
|  | ||||
| bool muse_timer_1bit = 0; | ||||
| uint8_t muse_timer_2bit = 0; | ||||
| uint8_t muse_timer_2bit_counter = 0; | ||||
| uint8_t muse_timer_4bit = 0; | ||||
| uint32_t muse_timer_31bit = 0; | ||||
|  | ||||
| bool bit_for_value(uint8_t value) { | ||||
|   switch (value) { | ||||
|     case MUSE_OFF: | ||||
|       return 0; | ||||
|     case MUSE_ON: | ||||
|       return 1; | ||||
|     case MUSE_C_1_2: | ||||
|       return muse_timer_1bit; | ||||
|     case MUSE_C1: | ||||
|       return (muse_timer_4bit & 1); | ||||
|     case MUSE_C2: | ||||
|       return (muse_timer_4bit & 2); | ||||
|     case MUSE_C4: | ||||
|       return (muse_timer_4bit & 4); | ||||
|     case MUSE_C8: | ||||
|       return (muse_timer_4bit & 8); | ||||
|     case MUSE_C3: | ||||
|       return (muse_timer_2bit & 1); | ||||
|     case MUSE_C6: | ||||
|       return (muse_timer_2bit & 2); | ||||
|     default: | ||||
|       return muse_timer_31bit & (1UL << (value - MUSE_B1)); | ||||
|   } | ||||
| } | ||||
|  | ||||
| uint8_t muse_clock_pulse(void) { | ||||
|  | ||||
|   bool top = number_of_ones_to_bool[ | ||||
|     bit_for_value(muse_theme[0]) + | ||||
|     (bit_for_value(muse_theme[1]) << 1) + | ||||
|     (bit_for_value(muse_theme[2]) << 2) + | ||||
|     (bit_for_value(muse_theme[3]) << 3) | ||||
|   ]; | ||||
|  | ||||
|   if (muse_timer_1bit == 0) { | ||||
|     if (muse_timer_2bit_counter == 0) { | ||||
|       muse_timer_2bit = (muse_timer_2bit + 1) % 4; | ||||
|     } | ||||
|     muse_timer_2bit_counter = (muse_timer_2bit_counter + 1) % 3; | ||||
|     muse_timer_4bit = (muse_timer_4bit + 1) % 16; | ||||
|     muse_timer_31bit = (muse_timer_31bit << 1) + top; | ||||
|   } | ||||
|  | ||||
|   muse_timer_1bit = (muse_timer_1bit + 1) % 2; | ||||
|  | ||||
|   return | ||||
|     bit_for_value(muse_interval[0]) + | ||||
|     (bit_for_value(muse_interval[1]) << 1) + | ||||
|     (bit_for_value(muse_interval[2]) << 2) + | ||||
|     (bit_for_value(muse_interval[3]) << 3); | ||||
|  | ||||
| } | ||||
							
								
								
									
										9
									
								
								quantum/audio/muse.h
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										9
									
								
								quantum/audio/muse.h
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,9 @@ | ||||
| #ifndef MUSE_H | ||||
| #define MUSE_H | ||||
|  | ||||
| #include "quantum.h" | ||||
| #include "process_audio.h" | ||||
|  | ||||
| uint8_t muse_clock_pulse(void); | ||||
|  | ||||
| #endif | ||||
| @@ -1,4 +1,4 @@ | ||||
| /* Copyright 2015-2017 Jack Humbert | ||||
| /* Copyright 2015-2018 Jack Humbert | ||||
|  * | ||||
|  * 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 | ||||
| @@ -22,8 +22,10 @@ | ||||
| #define ROW2COL       1 | ||||
| #define CUSTOM_MATRIX 2 /* Disables built-in matrix scanning code */ | ||||
|  | ||||
| /* I/O pins */ | ||||
| #ifndef F0 | ||||
| #ifdef __AVR__ | ||||
|  | ||||
|   /* I/O pins */ | ||||
|   #ifndef F0 | ||||
|       #define B0 0x30 | ||||
|       #define B1 0x31 | ||||
|       #define B2 0x32 | ||||
| @@ -72,8 +74,111 @@ | ||||
|       #define A5 0x05 | ||||
|       #define A6 0x06 | ||||
|       #define A7 0x07 | ||||
|   #endif | ||||
|  | ||||
|  | ||||
| #elif defined(__arm__) | ||||
|  | ||||
|   #define A0  PAL_LINE(GPIOA, 0) | ||||
|   #define A1  PAL_LINE(GPIOA, 1) | ||||
|   #define A2  PAL_LINE(GPIOA, 2) | ||||
|   #define A3  PAL_LINE(GPIOA, 3) | ||||
|   #define A4  PAL_LINE(GPIOA, 4) | ||||
|   #define A5  PAL_LINE(GPIOA, 5) | ||||
|   #define A6  PAL_LINE(GPIOA, 6) | ||||
|   #define A7  PAL_LINE(GPIOA, 7) | ||||
|   #define A8  PAL_LINE(GPIOA, 8) | ||||
|   #define A9  PAL_LINE(GPIOA, 9) | ||||
|   #define A10 PAL_LINE(GPIOA, 10) | ||||
|   #define A11 PAL_LINE(GPIOA, 11) | ||||
|   #define A12 PAL_LINE(GPIOA, 12) | ||||
|   #define A13 PAL_LINE(GPIOA, 13) | ||||
|   #define A14 PAL_LINE(GPIOA, 14) | ||||
|   #define A15 PAL_LINE(GPIOA, 15) | ||||
|   #define B0  PAL_LINE(GPIOB, 0) | ||||
|   #define B1  PAL_LINE(GPIOB, 1) | ||||
|   #define B2  PAL_LINE(GPIOB, 2) | ||||
|   #define B3  PAL_LINE(GPIOB, 3) | ||||
|   #define B4  PAL_LINE(GPIOB, 4) | ||||
|   #define B5  PAL_LINE(GPIOB, 5) | ||||
|   #define B6  PAL_LINE(GPIOB, 6) | ||||
|   #define B7  PAL_LINE(GPIOB, 7) | ||||
|   #define B8  PAL_LINE(GPIOB, 8) | ||||
|   #define B9  PAL_LINE(GPIOB, 9) | ||||
|   #define B10 PAL_LINE(GPIOB, 10) | ||||
|   #define B11 PAL_LINE(GPIOB, 11) | ||||
|   #define B12 PAL_LINE(GPIOB, 12) | ||||
|   #define B13 PAL_LINE(GPIOB, 13) | ||||
|   #define B14 PAL_LINE(GPIOB, 14) | ||||
|   #define B15 PAL_LINE(GPIOB, 15) | ||||
|   #define C0  PAL_LINE(GPIOC, 0) | ||||
|   #define C1  PAL_LINE(GPIOC, 1) | ||||
|   #define C2  PAL_LINE(GPIOC, 2) | ||||
|   #define C3  PAL_LINE(GPIOC, 3) | ||||
|   #define C4  PAL_LINE(GPIOC, 4) | ||||
|   #define C5  PAL_LINE(GPIOC, 5) | ||||
|   #define C6  PAL_LINE(GPIOC, 6) | ||||
|   #define C7  PAL_LINE(GPIOC, 7) | ||||
|   #define C8  PAL_LINE(GPIOC, 8) | ||||
|   #define C9  PAL_LINE(GPIOC, 9) | ||||
|   #define C10 PAL_LINE(GPIOC, 10) | ||||
|   #define C11 PAL_LINE(GPIOC, 11) | ||||
|   #define C12 PAL_LINE(GPIOC, 12) | ||||
|   #define C13 PAL_LINE(GPIOC, 13) | ||||
|   #define C14 PAL_LINE(GPIOC, 14) | ||||
|   #define C15 PAL_LINE(GPIOC, 15) | ||||
|   #define D0  PAL_LINE(GPIOD, 0) | ||||
|   #define D1  PAL_LINE(GPIOD, 1) | ||||
|   #define D2  PAL_LINE(GPIOD, 2) | ||||
|   #define D3  PAL_LINE(GPIOD, 3) | ||||
|   #define D4  PAL_LINE(GPIOD, 4) | ||||
|   #define D5  PAL_LINE(GPIOD, 5) | ||||
|   #define D6  PAL_LINE(GPIOD, 6) | ||||
|   #define D7  PAL_LINE(GPIOD, 7) | ||||
|   #define D8  PAL_LINE(GPIOD, 8) | ||||
|   #define D9  PAL_LINE(GPIOD, 9) | ||||
|   #define D10 PAL_LINE(GPIOD, 10) | ||||
|   #define D11 PAL_LINE(GPIOD, 11) | ||||
|   #define D12 PAL_LINE(GPIOD, 12) | ||||
|   #define D13 PAL_LINE(GPIOD, 13) | ||||
|   #define D14 PAL_LINE(GPIOD, 14) | ||||
|   #define D15 PAL_LINE(GPIOD, 15) | ||||
|   #define E0  PAL_LINE(GPIOE, 0) | ||||
|   #define E1  PAL_LINE(GPIOE, 1) | ||||
|   #define E2  PAL_LINE(GPIOE, 2) | ||||
|   #define E3  PAL_LINE(GPIOE, 3) | ||||
|   #define E4  PAL_LINE(GPIOE, 4) | ||||
|   #define E5  PAL_LINE(GPIOE, 5) | ||||
|   #define E6  PAL_LINE(GPIOE, 6) | ||||
|   #define E7  PAL_LINE(GPIOE, 7) | ||||
|   #define E8  PAL_LINE(GPIOE, 8) | ||||
|   #define E9  PAL_LINE(GPIOE, 9) | ||||
|   #define E10 PAL_LINE(GPIOE, 10) | ||||
|   #define E11 PAL_LINE(GPIOE, 11) | ||||
|   #define E12 PAL_LINE(GPIOE, 12) | ||||
|   #define E13 PAL_LINE(GPIOE, 13) | ||||
|   #define E14 PAL_LINE(GPIOE, 14) | ||||
|   #define E15 PAL_LINE(GPIOE, 15) | ||||
|   #define F0  PAL_LINE(GPIOF, 0) | ||||
|   #define F1  PAL_LINE(GPIOF, 1) | ||||
|   #define F2  PAL_LINE(GPIOF, 2) | ||||
|   #define F3  PAL_LINE(GPIOF, 3) | ||||
|   #define F4  PAL_LINE(GPIOF, 4) | ||||
|   #define F5  PAL_LINE(GPIOF, 5) | ||||
|   #define F6  PAL_LINE(GPIOF, 6) | ||||
|   #define F7  PAL_LINE(GPIOF, 7) | ||||
|   #define F8  PAL_LINE(GPIOF, 8) | ||||
|   #define F9  PAL_LINE(GPIOF, 9) | ||||
|   #define F10 PAL_LINE(GPIOF, 10) | ||||
|   #define F11 PAL_LINE(GPIOF, 11) | ||||
|   #define F12 PAL_LINE(GPIOF, 12) | ||||
|   #define F13 PAL_LINE(GPIOF, 13) | ||||
|   #define F14 PAL_LINE(GPIOF, 14) | ||||
|   #define F15 PAL_LINE(GPIOF, 15) | ||||
|  | ||||
| #endif | ||||
|  | ||||
|  | ||||
| /* USART configuration */ | ||||
| #ifdef BLUETOOTH_ENABLE | ||||
| #   ifdef __AVR_ATmega32U4__ | ||||
|   | ||||
							
								
								
									
										67
									
								
								quantum/encoder.c
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										67
									
								
								quantum/encoder.c
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,67 @@ | ||||
| /* | ||||
|  * Copyright 2018 Jack Humbert <jack.humb@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 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 "encoder.h" | ||||
| #include "quantum.h" | ||||
|  | ||||
| #ifndef ENCODER_RESOLUTION | ||||
|   #define ENCODER_RESOLUTION 4 | ||||
| #endif | ||||
|  | ||||
| #if !defined(ENCODERS_PAD_A) || !defined(ENCODERS_PAD_B) | ||||
|   #error "No encoder pads defined by ENCODERS_PAD_A and ENCODERS_PAD_B" | ||||
| #endif | ||||
|  | ||||
| static LINE_TYPE encoders_pad_a[NUMBER_OF_ENCODERS] = ENCODERS_PAD_A; | ||||
| static LINE_TYPE encoders_pad_b[NUMBER_OF_ENCODERS] = ENCODERS_PAD_B; | ||||
|  | ||||
| static int8_t encoder_LUT[] = { 0, -1, 1, 0, 1, 0, 0, -1, -1, 0, 0, 1, 0, 1, -1, 0 }; | ||||
|  | ||||
| static uint8_t encoder_state[NUMBER_OF_ENCODERS] = {0}; | ||||
| static int8_t encoder_value[NUMBER_OF_ENCODERS] = {0}; | ||||
|  | ||||
| __attribute__ ((weak)) | ||||
| void encoder_update_user(int8_t index, bool clockwise) { } | ||||
|  | ||||
| __attribute__ ((weak)) | ||||
| void encoder_update_kb(int8_t index, bool clockwise) { | ||||
|   encoder_update_user(index, clockwise); | ||||
| } | ||||
|  | ||||
| void encoder_init(void) { | ||||
|   for (int i = 0; i < NUMBER_OF_ENCODERS; i++) { | ||||
|     setPadMode(encoders_pad_a[i], PAD_MODE_INPUT); | ||||
|     setPadMode(encoders_pad_b[i], PAD_MODE_INPUT); | ||||
|  | ||||
|     encoder_state[i] = (readPad(encoders_pad_a[i]) << 0) | (readPad(encoders_pad_b[i]) << 1); | ||||
|   } | ||||
| } | ||||
|  | ||||
| void encoder_read(void) { | ||||
|   for (int i = 0; i < NUMBER_OF_ENCODERS; i++) { | ||||
|     encoder_state[i] <<= 2; | ||||
|     encoder_state[i] |= (readPad(encoders_pad_a[i]) << 0) | (readPad(encoders_pad_b[i]) << 1); | ||||
|     encoder_value[i] += encoder_LUT[encoder_state[i] & 0xF]; | ||||
|     if (encoder_value[i] >= ENCODER_RESOLUTION) { | ||||
|         encoder_update_kb(i, COUNTRECLOCKWISE); | ||||
|     } | ||||
|     if (encoder_value[i] <= -ENCODER_RESOLUTION) { // direction is arbitrary here, but this clockwise | ||||
|         encoder_update_kb(i, CLOCKWISE); | ||||
|     } | ||||
|     encoder_value[i] %= ENCODER_RESOLUTION; | ||||
|   } | ||||
| } | ||||
							
								
								
									
										27
									
								
								quantum/encoder.h
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										27
									
								
								quantum/encoder.h
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,27 @@ | ||||
| /* | ||||
|  * Copyright 2018 Jack Humbert <jack.humb@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 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/>. | ||||
|  */ | ||||
|  | ||||
| #ifndef ENCODER_H | ||||
| #define ENCODER_H | ||||
|  | ||||
| #define COUNTRECLOCKWISE 0 | ||||
| #define CLOCKWISE 1 | ||||
|  | ||||
| void encoder_init(void); | ||||
| void encoder_read(void); | ||||
|  | ||||
| #endif | ||||
| @@ -10,9 +10,7 @@ float voice_change_song[][2] = VOICE_CHANGE_SONG; | ||||
|     #define PITCH_STANDARD_A 440.0f | ||||
| #endif | ||||
|  | ||||
|  | ||||
|  | ||||
| static float compute_freq_for_midi_note(uint8_t note) | ||||
| float compute_freq_for_midi_note(uint8_t note) | ||||
| { | ||||
|     // https://en.wikipedia.org/wiki/MIDI_tuning_standard | ||||
|     return pow(2.0, (note - 69) / 12.0) * PITCH_STANDARD_A; | ||||
|   | ||||
| @@ -1,6 +1,8 @@ | ||||
| #ifndef PROCESS_AUDIO_H | ||||
| #define PROCESS_AUDIO_H | ||||
|  | ||||
| float compute_freq_for_midi_note(uint8_t note); | ||||
|  | ||||
| bool process_audio(uint16_t keycode, keyrecord_t *record); | ||||
| void process_audio_noteon(uint8_t note); | ||||
| void process_audio_noteoff(uint8_t note); | ||||
|   | ||||
| @@ -197,7 +197,15 @@ bool process_music(uint16_t keycode, keyrecord_t *record) { | ||||
|         } | ||||
|       } | ||||
|  | ||||
|       uint8_t note; | ||||
|       uint8_t note = 36; | ||||
|       #ifdef MUSIC_MAP | ||||
|         if (music_mode == MUSIC_MODE_CHROMATIC) { | ||||
|           note = music_starting_note + music_offset + 36 + music_map[record->event.key.row][record->event.key.col]; | ||||
|         } else { | ||||
|           uint8_t position = music_map[record->event.key.row][record->event.key.col]; | ||||
|           note = music_starting_note + music_offset + 36 + SCALE[position % 12] + (position / 12)*12; | ||||
|         } | ||||
|       #else | ||||
|         if (music_mode == MUSIC_MODE_CHROMATIC) | ||||
|           note = (music_starting_note + record->event.key.col + music_offset - 3)+12*(MATRIX_ROWS - record->event.key.row); | ||||
|         else if (music_mode == MUSIC_MODE_GUITAR) | ||||
| @@ -208,6 +216,7 @@ bool process_music(uint16_t keycode, keyrecord_t *record) { | ||||
|           note = (music_starting_note + SCALE[record->event.key.col + music_offset] - 3)+12*(MATRIX_ROWS - record->event.key.row); | ||||
|         else | ||||
|           note = music_starting_note; | ||||
|       #endif | ||||
|  | ||||
|       if (record->event.pressed) { | ||||
|         music_noteon(note); | ||||
|   | ||||
| @@ -29,6 +29,11 @@ enum music_modes { | ||||
|   NUMBER_OF_MODES | ||||
| }; | ||||
|  | ||||
|  | ||||
| #ifdef MUSIC_MAP | ||||
| 	extern const uint8_t music_map[MATRIX_ROWS][MATRIX_COLS]; | ||||
| #endif | ||||
|  | ||||
| bool process_music(uint16_t keycode, keyrecord_t *record); | ||||
|  | ||||
| bool is_music_on(void); | ||||
|   | ||||
| @@ -851,6 +851,9 @@ void matrix_init_quantum() { | ||||
|   #ifdef RGB_MATRIX_ENABLE | ||||
|     rgb_matrix_init_drivers(); | ||||
|   #endif | ||||
|   #ifdef ENCODER_ENABLE | ||||
|     encoder_init(); | ||||
|   #endif | ||||
|   matrix_init_kb(); | ||||
| } | ||||
|  | ||||
| @@ -885,6 +888,10 @@ void matrix_scan_quantum() { | ||||
|     rgb_matrix_task_counter = ((rgb_matrix_task_counter + 1) % (RGB_MATRIX_SKIP_FRAMES + 1)); | ||||
|   #endif | ||||
|  | ||||
|   #ifdef ENCODER_ENABLE | ||||
|     encoder_read(); | ||||
|   #endif | ||||
|  | ||||
|   matrix_scan_kb(); | ||||
| } | ||||
| #if defined(BACKLIGHT_ENABLE) && defined(BACKLIGHT_PIN) | ||||
|   | ||||
| @@ -17,10 +17,11 @@ | ||||
| #define QUANTUM_H | ||||
|  | ||||
| #if defined(__AVR__) | ||||
| #include <avr/pgmspace.h> | ||||
| #include <avr/io.h> | ||||
| #include <avr/interrupt.h> | ||||
|   #include <avr/pgmspace.h> | ||||
|   #include <avr/io.h> | ||||
|   #include <avr/interrupt.h> | ||||
| #endif | ||||
|  | ||||
| #include "wait.h" | ||||
| #include "matrix.h" | ||||
| #include "keymap.h" | ||||
| @@ -121,6 +122,39 @@ extern uint32_t default_layer_state; | ||||
| 	#include "process_terminal_nop.h" | ||||
| #endif | ||||
|  | ||||
| #ifdef ENCODER_ENABLE | ||||
|   #include "encoder.h" | ||||
| #endif | ||||
|  | ||||
| #ifndef MIN | ||||
|   #define MAX(x, y) (((x) > (y)) ? (x) : (y)) | ||||
|   #define MIN(x, y) (((x) < (y)) ? (x) : (y)) | ||||
| #endif | ||||
|  | ||||
|  | ||||
| #ifdef __AVR__ | ||||
|   #include <avr/io.h> | ||||
|   #define LINE_TYPE uint8_t | ||||
|  | ||||
|   #define setPadMode(line, mode) _SFR_IO8((line >> 4) + 1) mode _BV(line & 0xF) | ||||
|   #define setPad(line) _SFR_IO8((line >> 4) + 2) |=  _BV(line & 0xF) | ||||
|   #define clearPad(line) _SFR_IO8((line >> 4) + 2) &= ~_BV(line & 0xF) | ||||
|   #define readPad(line) (_SFR_IO8(line >> 4) & _BV(line & 0xF)) | ||||
|  | ||||
|   #define PAD_MODE_INPUT &= ~ | ||||
|   #define PAD_MODE_OUTPUT |= | ||||
| #elif defined(__arm__) | ||||
|   #include "hal.h" | ||||
|   #define LINE_TYPE ioline_t | ||||
|  | ||||
|   #define setPadMode(line, mode) palSetPadMode(PAL_PORT(line), PAL_PAD(line), mode) | ||||
|   #define setPad(line) palSetPad(PAL_PORT(line), PAL_PAD(line)) | ||||
|   #define clearPad(line) palClearPad(PAL_PORT(line), PAL_PAD(line)) | ||||
|   #define readPad(line) palReadPad(PAL_PORT(line), PAL_PAD(line)) | ||||
|  | ||||
|   #define PAD_MODE_INPUT PAL_MODE_INPUT_PULLUP | ||||
| #endif | ||||
|  | ||||
| #define STRINGIZE(z) #z | ||||
| #define ADD_SLASH_X(y) STRINGIZE(\x ## y) | ||||
| #define SYMBOL_STR(x) ADD_SLASH_X(x) | ||||
|   | ||||
| @@ -17,14 +17,14 @@ | ||||
|  | ||||
|  | ||||
| #include "rgb_matrix.h" | ||||
| #include <avr/io.h> | ||||
| #include "i2c_master.h" | ||||
| #include <util/delay.h> | ||||
| #include <avr/interrupt.h> | ||||
| //#include <avr/io.h> | ||||
| #include "twi2c.h" | ||||
| #include "wait.h" | ||||
| //#include <avr/interrupt.h> | ||||
| #include "progmem.h" | ||||
| #include "config.h" | ||||
| #include "eeprom.h" | ||||
| #include "lufa.h" | ||||
| //#include "lufa.h" | ||||
| #include <math.h> | ||||
|  | ||||
| rgb_config_t rgb_matrix_config; | ||||
| @@ -723,7 +723,7 @@ void rgb_matrix_indicators_user(void) {} | ||||
|  | ||||
| void rgb_matrix_init_drivers(void) { | ||||
|     // Initialize TWI | ||||
|     i2c_init(); | ||||
|     twi2c_init(); | ||||
|     IS31FL3731_init( DRIVER_ADDR_1 ); | ||||
|     IS31FL3731_init( DRIVER_ADDR_2 ); | ||||
|  | ||||
|   | ||||
Some files were not shown because too many files have changed in this diff Show More
		Reference in New Issue
	
	Block a user