forked from mfulz_github/qmk_firmware
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 DEBOUNCING_DELAY 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
|
|
|
|
/* key combination for command */
|
|
#define IS_COMMAND() ( \
|
|
keyboard_report->mods == (MOD_BIT(KC_LSHIFT) | MOD_BIT(KC_RSHIFT)) \
|
|
)
|
|
|
|
/* 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
|