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