127 lines
		
	
	
	
		
			4.3 KiB
		
	
	
	
		
			C
		
	
	
	
	
	
			
		
		
	
	
			127 lines
		
	
	
	
		
			4.3 KiB
		
	
	
	
		
			C
		
	
	
	
	
	
| /*
 | |
| Copyright 2015 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/>.
 | |
| */
 | |
| 
 | |
| #pragma once
 | |
| 
 | |
| #include "config_common.h"
 | |
| 
 | |
| /* USB Device descriptor parameter */
 | |
| #define VENDOR_ID           0x04D8
 | |
| #define PRODUCT_ID          0xEED2
 | |
| #define DEVICE_VER          0x0101
 | |
| 
 | |
| #define MANUFACTURER        "Massdrop Inc."
 | |
| #define PRODUCT             "CTRL Keyboard"
 | |
| #define SERIAL_NUM          "Unavailable"
 | |
| 
 | |
| /* key matrix size */
 | |
| #define MATRIX_ROWS 11
 | |
| #define MATRIX_COLS 8
 | |
| 
 | |
| /* MCU Port name definitions */
 | |
| #define PA 0
 | |
| #define PB 1
 | |
| 
 | |
| /* Port and Pin definition of key row hardware configuration */
 | |
| #define MATRIX_ROW_PORTS PB, PB, PB, PB, PB, PB, PA, PA, PB, PB, PB
 | |
| #define MATRIX_ROW_PINS   4,  5,  6,  7,  8,  9, 10, 11, 10, 11, 12
 | |
| 
 | |
| /* Port and Pin definition of key column hardware configuration */
 | |
| #define MATRIX_COL_PORTS PA, PA, PA, PA, PA, PA, PA, PA
 | |
| #define MATRIX_COL_PINS   0,  1,  2,  3,  4,  5,  6,  7
 | |
| 
 | |
| /* This Shift Register expands available hardware output lines to control additional peripherals */
 | |
| /* It uses four lines from the MCU to provide 16 output lines */
 | |
| /* Shift Register Clock configuration (MCU to ShiftRegister.RCLK) */
 | |
| #define SR_EXP_RCLK_PORT            PB
 | |
| #define SR_EXP_RCLK_PIN             14
 | |
| /* Shift Register Output Enable configuration (MCU to ShiftRegister.OE_N) */
 | |
| #define SR_EXP_OE_N_PORT            PB
 | |
| #define SR_EXP_OE_N_PIN             15
 | |
| /* SERCOM port to use for Shift Register SPI */
 | |
| /* DATAOUT and SCLK must be configured to use hardware pins of this port */
 | |
| #define SR_EXP_SERCOM               SERCOM2
 | |
| /* Shift Register SPI Data Out configuration (MCU.SERCOMx.PAD[0] to ShiftRegister.SER) */
 | |
| #define SR_EXP_DATAOUT_PORT         PA
 | |
| #define SR_EXP_DATAOUT_PIN          12
 | |
| #define SR_EXP_DATAOUT_MUX          2
 | |
| /* Shift Register SPI Serial Clock configuration (MCU.SERCOMx.PAD[1] to ShiftRegister.SRCLK) */
 | |
| #define SR_EXP_SCLK_PORT            PA
 | |
| #define SR_EXP_SCLK_PIN             13
 | |
| #define SR_EXP_SCLK_MUX             2
 | |
| 
 | |
| /* Debug LED (Small LED Located near MCU) */
 | |
| #define DEBUG_LED_ENABLE            1
 | |
| #define DEBUG_LED_PORT              PA
 | |
| #define DEBUG_LED_PIN               27
 | |
| 
 | |
| /* Additional debugging ports */
 | |
| /* PCB M21 */
 | |
| #define DEBUG_PORT1_ENABLE          1
 | |
| #define DEBUG_PORT1_PORT            PB
 | |
| #define DEBUG_PORT1_PIN             3
 | |
| /* PCB M23 */
 | |
| #define DEBUG_PORT2_ENABLE          1
 | |
| #define DEBUG_PORT2_PORT            PB
 | |
| #define DEBUG_PORT2_PIN             17
 | |
| /* PCB M25 */
 | |
| #define DEBUG_PORT3_ENABLE          1
 | |
| #define DEBUG_PORT3_PORT            PA
 | |
| #define DEBUG_PORT3_PIN             20
 | |
| 
 | |
| /* Debug Boot Tracing - During boot sequence, ground this pin to halt and display debug code using Debug LED */
 | |
| /* This is useful in determining which hardware device may have malfunctioned or is improperly configured */
 | |
| /* Feature is automatically disabled after successful boot */
 | |
| /* PCB M27 */
 | |
| #define DEBUG_BOOT_TRACING_ENABLE   1
 | |
| #define DEBUG_BOOT_TRACING_PORT     PB
 | |
| #define DEBUG_BOOT_TRACING_PIN      23
 | |
| 
 | |
| /* Debounce reduces chatter (unintended double-presses) - set 0 if debouncing is not needed */
 | |
| #define DEBOUNCE 5
 | |
| 
 | |
| /* 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 boot in NKRO mode */
 | |
| //#define FORCE_NKRO
 | |
| 
 | |
| /*
 | |
|  * 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
 | |
| 
 | |
| #define RGB_MATRIX_KEYPRESSES
 | |
| #define RGB_MATRIX_LED_PROCESS_LIMIT 15
 | |
| #define RGB_MATRIX_LED_FLUSH_LIMIT 10
 | |
| 
 | |
| #include "config_led.h"
 | 
