qmk

QMK Firmware
git clone git://git.z3bra.org/qmk.git
Log | Files | Refs | Submodules | LICENSE

config.h (7055B)


      1 /*
      2 Copyright 2019 Elliot Powell
      3 
      4 This program is free software: you can redistribute it and/or modify
      5 it under the terms of the GNU General Public License as published by
      6 the Free Software Foundation, either version 2 of the License, or
      7 (at your option) any later version.
      8 
      9 This program is distributed in the hope that it will be useful,
     10 but WITHOUT ANY WARRANTY; without even the implied warranty of
     11 MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
     12 GNU General Public License for more details.
     13 
     14 You should have received a copy of the GNU General Public License
     15 along with this program.  If not, see <http://www.gnu.org/licenses/>.
     16 */
     17 
     18 #pragma once
     19 
     20 #include "config_common.h"
     21 
     22 /* USB Device descriptor parameter */
     23 #define VENDOR_ID 0xFEED
     24 #define PRODUCT_ID 0x9696
     25 #define DEVICE_VER 0x0001
     26 #define MANUFACTURER Elliot Powell
     27 #define PRODUCT mollydooker
     28 #define DESCRIPTION Custom southpaw replacement PCB
     29 
     30 /* key matrix size */
     31 #define MATRIX_ROWS 5
     32 #define MATRIX_COLS 19
     33 
     34 /*
     35  * Keyboard Matrix Assignments
     36  *
     37  * Change this to how you wired your keyboard
     38  * COLS: AVR pins used for columns, left to right
     39  * ROWS: AVR pins used for rows, top to bottom
     40  * DIODE_DIRECTION: COL2ROW = COL = Anode (+), ROW = Cathode (-, marked on diode)
     41  *                  ROW2COL = ROW = Anode (+), COL = Cathode (-, marked on diode)
     42  *
     43  */
     44 #define MATRIX_ROW_PINS \
     45   { F4, F5, F6, F7, D2 }
     46 #define MATRIX_COL_PINS \
     47   { B1, B2, B3, E6, B7, F1, F0, D0, D1, D7, D5, D4, D6, B4, B5, D3, B6, C6, C7 }
     48 #define UNUSED_PINS
     49 
     50 /* COL2ROW, ROW2COL, or CUSTOM_MATRIX */
     51 #define DIODE_DIRECTION COL2ROW
     52 
     53 // #endif
     54 
     55 /* Debounce reduces chatter (unintended double-presses) - set 0 if debouncing is not needed */
     56 #define DEBOUNCE 5
     57 
     58 /* define if matrix has ghost (lacks anti-ghosting diodes) */
     59 //#define MATRIX_HAS_GHOST
     60 
     61 /* Mechanical locking support. Use KC_LCAP, KC_LNUM or KC_LSCR instead in keymap */
     62 #define LOCKING_SUPPORT_ENABLE
     63 /* Locking resynchronize hack */
     64 #define LOCKING_RESYNC_ENABLE
     65 
     66 /* If defined, GRAVE_ESC will always act as ESC when CTRL is held.
     67  * This is userful for the Windows task manager shortcut (ctrl+shift+esc).
     68  */
     69 // #define GRAVE_ESC_CTRL_OVERRIDE
     70 #define RGB_DI_PIN B0
     71 #define RGBLIGHT_ANIMATIONS
     72 #define RGBLED_NUM 84
     73 #define RGBLIGHT_LIMIT_VAL 35
     74 #define RGBLIGHT_HUE_STEP 10
     75 #define RGBLIGHT_SAT_STEP 17
     76 #define RGBLIGHT_VAL_STEP 17
     77 
     78 /*
     79  * Force NKRO
     80  *
     81  * Force NKRO (nKey Rollover) to be enabled by default, regardless of the saved
     82  * state in the bootmagic EEPROM settings. (Note that NKRO must be enabled in the
     83  * makefile for this to work.)
     84  *
     85  * If forced on, NKRO can be disabled via magic key (default = LShift+RShift+N)
     86  * until the next keyboard reset.
     87  *
     88  * NKRO may prevent your keystrokes from being detected in the BIOS, but it is
     89  * fully operational during normal computer usage.
     90  *
     91  * For a less heavy-handed approach, enable NKRO via magic key (LShift+RShift+N)
     92  * or via bootmagic (hold SPACE+N while plugging in the keyboard). Once set by
     93  * bootmagic, NKRO mode will always be enabled until it is toggled again during a
     94  * power-up.
     95  *
     96  */
     97 //#define FORCE_NKRO
     98 
     99 /*
    100  * Magic Key Options
    101  *
    102  * Magic keys are hotkey commands that allow control over firmware functions of
    103  * the keyboard. They are best used in combination with the HID Listen program,
    104  * found here: https://www.pjrc.com/teensy/hid_listen.html
    105  *
    106  * The options below allow the magic key functionality to be changed. This is
    107  * useful if your keyboard/keypad is missing keys and you want magic key support.
    108  *
    109  */
    110 
    111 /* control how magic key switches layers */
    112 //#define MAGIC_KEY_SWITCH_LAYER_WITH_FKEYS  true
    113 //#define MAGIC_KEY_SWITCH_LAYER_WITH_NKEYS  true
    114 //#define MAGIC_KEY_SWITCH_LAYER_WITH_CUSTOM false
    115 
    116 /* override magic key keymap */
    117 //#define MAGIC_KEY_SWITCH_LAYER_WITH_FKEYS
    118 //#define MAGIC_KEY_SWITCH_LAYER_WITH_NKEYS
    119 //#define MAGIC_KEY_SWITCH_LAYER_WITH_CUSTOM
    120 //#define MAGIC_KEY_HELP1          H
    121 //#define MAGIC_KEY_HELP2          SLASH
    122 //#define MAGIC_KEY_DEBUG          D
    123 //#define MAGIC_KEY_DEBUG_MATRIX   X
    124 //#define MAGIC_KEY_DEBUG_KBD      K
    125 //#define MAGIC_KEY_DEBUG_MOUSE    M
    126 //#define MAGIC_KEY_VERSION        V
    127 //#define MAGIC_KEY_STATUS         S
    128 //#define MAGIC_KEY_CONSOLE        C
    129 //#define MAGIC_KEY_LAYER0_ALT1    ESC
    130 //#define MAGIC_KEY_LAYER0_ALT2    GRAVE
    131 //#define MAGIC_KEY_LAYER0         0
    132 //#define MAGIC_KEY_LAYER1         1
    133 //#define MAGIC_KEY_LAYER2         2
    134 //#define MAGIC_KEY_LAYER3         3
    135 //#define MAGIC_KEY_LAYER4         4
    136 //#define MAGIC_KEY_LAYER5         5
    137 //#define MAGIC_KEY_LAYER6         6
    138 //#define MAGIC_KEY_LAYER7         7
    139 //#define MAGIC_KEY_LAYER8         8
    140 //#define MAGIC_KEY_LAYER9         9
    141 //#define MAGIC_KEY_BOOTLOADER     PAUSE
    142 //#define MAGIC_KEY_LOCK           CAPS
    143 //#define MAGIC_KEY_EEPROM         E
    144 //#define MAGIC_KEY_NKRO           N
    145 //#define MAGIC_KEY_SLEEP_LED      Z
    146 
    147 /*
    148  * Feature disable options
    149  *  These options are also useful to firmware size reduction.
    150  */
    151 
    152 /* disable debug print */
    153 //#define NO_DEBUG
    154 
    155 /* disable print */
    156 //#define NO_PRINT
    157 
    158 /* disable action features */
    159 //#define NO_ACTION_LAYER
    160 //#define NO_ACTION_TAPPING
    161 //#define NO_ACTION_ONESHOT
    162 //#define NO_ACTION_MACRO
    163 //#define NO_ACTION_FUNCTION
    164 
    165 /*
    166  * MIDI options
    167  */
    168 
    169 /* Prevent use of disabled MIDI features in the keymap */
    170 //#define MIDI_ENABLE_STRICT 1
    171 
    172 /* enable basic MIDI features:
    173    - MIDI notes can be sent when in Music mode is on
    174 */
    175 //#define MIDI_BASIC
    176 
    177 /* enable advanced MIDI features:
    178    - MIDI notes can be added to the keymap
    179    - Octave shift and transpose
    180    - Virtual sustain, portamento, and modulation wheel
    181    - etc.
    182 */
    183 //#define MIDI_ADVANCED
    184 
    185 /* override number of MIDI tone keycodes (each octave adds 12 keycodes and allocates 12 bytes) */
    186 //#define MIDI_TONE_KEYCODE_OCTAVES 1
    187 
    188 /*
    189  * HD44780 LCD Display Configuration
    190  */
    191 /*
    192 #define LCD_LINES           2     //< number of visible lines of the display
    193 #define LCD_DISP_LENGTH    16     //< visibles characters per line of the display
    194 
    195 #define LCD_IO_MODE      1            //< 0: memory mapped mode, 1: IO port mode
    196 
    197 #if LCD_IO_MODE
    198 #define LCD_PORT         PORTB        //< port for the LCD lines
    199 #define LCD_DATA0_PORT   LCD_PORT     //< port for 4bit data bit 0
    200 #define LCD_DATA1_PORT   LCD_PORT     //< port for 4bit data bit 1
    201 #define LCD_DATA2_PORT   LCD_PORT     //< port for 4bit data bit 2
    202 #define LCD_DATA3_PORT   LCD_PORT     //< port for 4bit data bit 3
    203 #define LCD_DATA0_PIN    4            //< pin for 4bit data bit 0
    204 #define LCD_DATA1_PIN    5            //< pin for 4bit data bit 1
    205 #define LCD_DATA2_PIN    6            //< pin for 4bit data bit 2
    206 #define LCD_DATA3_PIN    7            //< pin for 4bit data bit 3
    207 #define LCD_RS_PORT      LCD_PORT     //< port for RS line
    208 #define LCD_RS_PIN       3            //< pin  for RS line
    209 #define LCD_RW_PORT      LCD_PORT     //< port for RW line
    210 #define LCD_RW_PIN       2            //< pin  for RW line
    211 #define LCD_E_PORT       LCD_PORT     //< port for Enable line
    212 #define LCD_E_PIN        1            //< pin  for Enable line
    213 #endif
    214 */