72fd49b1 |
1 | /* |
2 | Copyright 2018 Yiancar |
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 0x1011 |
25 | #define DEVICE_VER 0x0001 |
26 | #define MANUFACTURER Mechboards |
27 | #define PRODUCT DC01 Right |
28 | #define DESCRIPTION Right half of DC01 keyboard |
29 | |
30 | /* key matrix size */ |
31 | #define MATRIX_ROWS 5 |
32 | #define MATRIX_COLS 8 |
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 { C7, C6, B6, B5, B4 } |
45 | #define MATRIX_COL_PINS { F1, E6, F6, F5, F4, D4, D6, D7 } |
46 | #define UNUSED_PINS |
47 | |
fc069869 |
48 | /* COL2ROW, ROW2COL*/ |
72fd49b1 |
49 | #define DIODE_DIRECTION COL2ROW |
50 | |
51 | // #define BACKLIGHT_PIN B7 |
52 | // #define BACKLIGHT_BREATHING |
53 | // #define BACKLIGHT_LEVELS 3 |
54 | |
72fd49b1 |
55 | /* Debounce reduces chatter (unintended double-presses) - set 0 if debouncing is not needed */ |
56 | #define DEBOUNCING_DELAY 5 |
57 | |
58 | /* define if matrix has ghost (lacks anti-ghosting diodes) */ |
59 | //#define MATRIX_HAS_GHOST |
60 | |
61 | /* number of backlight levels */ |
62 | |
63 | /* Mechanical locking support. Use KC_LCAP, KC_LNUM or KC_LSCR instead in keymap */ |
64 | #define LOCKING_SUPPORT_ENABLE |
65 | /* Locking resynchronize hack */ |
66 | #define LOCKING_RESYNC_ENABLE |
67 | |
68 | /* If defined, GRAVE_ESC will always act as ESC when CTRL is held. |
69 | * This is userful for the Windows task manager shortcut (ctrl+shift+esc). |
70 | */ |
71 | // #define GRAVE_ESC_CTRL_OVERRIDE |
72 | |
73 | /* |
74 | * Force NKRO |
75 | * |
76 | * Force NKRO (nKey Rollover) to be enabled by default, regardless of the saved |
77 | * state in the bootmagic EEPROM settings. (Note that NKRO must be enabled in the |
78 | * makefile for this to work.) |
79 | * |
80 | * If forced on, NKRO can be disabled via magic key (default = LShift+RShift+N) |
81 | * until the next keyboard reset. |
82 | * |
83 | * NKRO may prevent your keystrokes from being detected in the BIOS, but it is |
84 | * fully operational during normal computer usage. |
85 | * |
86 | * For a less heavy-handed approach, enable NKRO via magic key (LShift+RShift+N) |
87 | * or via bootmagic (hold SPACE+N while plugging in the keyboard). Once set by |
88 | * bootmagic, NKRO mode will always be enabled until it is toggled again during a |
89 | * power-up. |
90 | * |
91 | */ |
92 | //#define FORCE_NKRO |
93 | |
94 | /* |
95 | * Magic Key Options |
96 | * |
97 | * Magic keys are hotkey commands that allow control over firmware functions of |
98 | * the keyboard. They are best used in combination with the HID Listen program, |
99 | * found here: https://www.pjrc.com/teensy/hid_listen.html |
100 | * |
101 | * The options below allow the magic key functionality to be changed. This is |
102 | * useful if your keyboard/keypad is missing keys and you want magic key support. |
103 | * |
104 | */ |
105 | |
72fd49b1 |
106 | /* |
107 | * Feature disable options |
108 | * These options are also useful to firmware size reduction. |
109 | */ |
110 | |
111 | /* disable debug print */ |
112 | //#define NO_DEBUG |
113 | |
114 | /* disable print */ |
115 | //#define NO_PRINT |
116 | |
117 | /* disable action features */ |
118 | //#define NO_ACTION_LAYER |
119 | //#define NO_ACTION_TAPPING |
120 | //#define NO_ACTION_ONESHOT |
121 | //#define NO_ACTION_MACRO |
122 | //#define NO_ACTION_FUNCTION |
123 | |
124 | /* |
125 | * MIDI options |
126 | */ |
127 | |
128 | /* Prevent use of disabled MIDI features in the keymap */ |
129 | //#define MIDI_ENABLE_STRICT 1 |
130 | |
131 | /* enable basic MIDI features: |
132 | - MIDI notes can be sent when in Music mode is on |
133 | */ |
134 | //#define MIDI_BASIC |
135 | |
136 | /* enable advanced MIDI features: |
137 | - MIDI notes can be added to the keymap |
138 | - Octave shift and transpose |
139 | - Virtual sustain, portamento, and modulation wheel |
140 | - etc. |
141 | */ |
142 | //#define MIDI_ADVANCED |
143 | |
144 | /* override number of MIDI tone keycodes (each octave adds 12 keycodes and allocates 12 bytes) */ |
145 | //#define MIDI_TONE_KEYCODE_OCTAVES 1 |