/* Copyright 2020 QMK * * 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 /* USB Device descriptor parameter */ #undef VENDOR_ID #define VENDOR_ID 0x1209 #undef PRODUCT_ID #define PRODUCT_ID 0x345C #undef DEVICE_VER #define DEVICE_VER 0x0001 #undef MANUFACTURER #define MANUFACTURER "https://github.com/stapelberg" #undef PRODUCT #define PRODUCT "kinT (kintlc)" /* key matrix size */ #define MATRIX_ROWS 15 #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) * */ #define MATRIX_ROW_PINS \ { \ LINE_PIN8, /* ROW_EQL */ \ LINE_PIN9, /* ROW_1 */ \ LINE_PIN10, /* ROW_2 */ \ LINE_PIN11, /* ROW_3 */ \ LINE_PIN7, /* ROW_4 */ \ LINE_PIN16, /* ROW_5 */ \ LINE_PIN5, /* ROW_6 */ \ LINE_PIN3, /* ROW_7 */ \ LINE_PIN4, /* ROW_8 */ \ LINE_PIN1, /* ROW_9 */ \ LINE_PIN0, /* ROW_0 */ \ LINE_PIN2, /* ROW_MIN */ \ LINE_PIN17, /* ROW_ESC */ \ LINE_PIN23, /* ROW_F1 */ \ LINE_PIN21 /* ROW_F2 */ \ } #define MATRIX_COL_PINS \ { \ LINE_PIN18, /* COL_0 */ \ LINE_PIN14, /* COL_1 */ \ LINE_PIN15, /* COL_2 */ \ LINE_PIN20, /* COL_3 */ \ LINE_PIN22, /* COL_4 */ \ LINE_PIN19, /* COL_5 */ \ LINE_PIN6 /* COL_6 */ \ } /* COL2ROW or ROW2COL */ #define DIODE_DIRECTION COL2ROW /* Well-worn Cherry MX key switches can bounce for up to 20ms, despite the * Cherry data sheet specifying 5ms. Because we use the sym_eager_pk debounce * algorithm, this debounce latency only affects key releases (not key * presses). */ #undef DEBOUNCE #define DEBOUNCE 20 #define IGNORE_MOD_TAP_INTERRUPT // The Teensy LC power consumption is unknown as per // https://www.pjrc.com/store/teensylc.html but since // https://www.pjrc.com/store/teensy41.html says 100mA, let's go with half. #define USB_MAX_POWER_CONSUMPTION 50 /* We use the i.MX RT1060 high-speed GPIOs (GPIO6-9) which are connected to the * AHB bus (AHB_CLK_ROOT), which runs at the same speed as the ARM Core Clock, * i.e. 600 MHz. See MIMXRT1062, page 949, 12.1 Chip-specific GPIO information. * No additional delay is necessary. */ // in clock cycles #define GPIO_INPUT_PIN_DELAY 0 // The default "1" results in LEDs being on when they should be off and // the other way around. #define LED_PIN_ON_STATE 0 // Discussion about which Teensy LC pins can be used for driving staus LEDs: // https://github.com/kinx-project/kint/issues/55 // Discussion about using Neopixel LEDs: // https://github.com/kinx-project/kint/issues/32 // Available pins can be seen in: // /lib/chibios-contrib/os/hal/boards/PJRC_TEENSY_LC/board.h #define LED_CAPS_LOCK_PIN LINE_PIN12 #define LED_SCROLL_LOCK_PIN LINE_PIN25 #define LED_COMPOSE_PIN LINE_PIN24