2 Copyright 2011,2012 Jun Wako <wakojun@gmail.com>
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.
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.
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/>.
19 * Keycodes based on HID Keyboard/Keypad Usage Page (0x07) plus media keys from Generic Desktop Page (0x01) and Consumer Page (0x0C)
21 * See https://web.archive.org/web/20060218214400/http://www.usb.org/developers/devclass_docs/Hut1_12.pdf
22 * or http://www.usb.org/developers/hidpage/Hut1_12v2.pdf (older)
27 /* FIXME: Add doxygen comments here */
29 #define IS_ERROR(code) (KC_ROLL_OVER <= (code) && (code) <= KC_UNDEFINED)
30 #define IS_ANY(code) (KC_A <= (code) && (code) <= 0xFF)
31 #define IS_KEY(code) (KC_A <= (code) && (code) <= KC_EXSEL)
32 #define IS_MOD(code) (KC_LCTRL <= (code) && (code) <= KC_RGUI)
34 #define IS_SPECIAL(code) ((0xA5 <= (code) && (code) <= 0xDF) || (0xE8 <= (code) && (code) <= 0xFF))
35 #define IS_SYSTEM(code) (KC_PWR <= (code) && (code) <= KC_WAKE)
36 #define IS_CONSUMER(code) (KC_MUTE <= (code) && (code) <= KC_MRWD)
38 #define IS_FN(code) (KC_FN0 <= (code) && (code) <= KC_FN31)
40 #define IS_MOUSEKEY(code) (KC_MS_UP <= (code) && (code) <= KC_MS_ACCEL2)
41 #define IS_MOUSEKEY_MOVE(code) (KC_MS_UP <= (code) && (code) <= KC_MS_RIGHT)
42 #define IS_MOUSEKEY_BUTTON(code) (KC_MS_BTN1 <= (code) && (code) <= KC_MS_BTN5)
43 #define IS_MOUSEKEY_WHEEL(code) (KC_MS_WH_UP <= (code) && (code) <= KC_MS_WH_RIGHT)
44 #define IS_MOUSEKEY_ACCEL(code) (KC_MS_ACCEL0 <= (code) && (code) <= KC_MS_ACCEL2)
46 #define MOD_BIT(code) (1 << MOD_INDEX(code))
47 #define MOD_INDEX(code) ((code) & 0x07)
49 #define FN_BIT(code) (1 << FN_INDEX(code))
50 #define FN_INDEX(code) ((code) - KC_FN0)
52 #define FN_MAX KC_FN31
55 * Short names for ease of definition of keymap
58 #define KC_TRANSPARENT 0x01
59 #define KC_TRNS KC_TRANSPARENT
62 #define KC_ENT KC_ENTER
63 #define KC_ESC KC_ESCAPE
64 #define KC_BSPC KC_BSPACE
65 #define KC_SPC KC_SPACE
66 #define KC_MINS KC_MINUS
67 #define KC_EQL KC_EQUAL
68 #define KC_LBRC KC_LBRACKET
69 #define KC_RBRC KC_RBRACKET
70 #define KC_BSLS KC_BSLASH
71 #define KC_NUHS KC_NONUS_HASH
72 #define KC_SCLN KC_SCOLON
73 #define KC_QUOT KC_QUOTE
74 #define KC_GRV KC_GRAVE
75 #define KC_COMM KC_COMMA
76 #define KC_SLSH KC_SLASH
77 #define KC_NUBS KC_NONUS_BSLASH
80 #define KC_CLCK KC_CAPSLOCK
81 #define KC_CAPS KC_CAPSLOCK
82 #define KC_SLCK KC_SCROLLLOCK
83 #define KC_NLCK KC_NUMLOCK
84 #define KC_LCAP KC_LOCKING_CAPS
85 #define KC_LNUM KC_LOCKING_NUM
86 #define KC_LSCR KC_LOCKING_SCROLL
89 #define KC_PSCR KC_PSCREEN
90 #define KC_PAUS KC_PAUSE
91 #define KC_BRK KC_PAUSE
92 #define KC_INS KC_INSERT
93 #define KC_DEL KC_DELETE
94 #define KC_PGDN KC_PGDOWN
95 #define KC_RGHT KC_RIGHT
96 #define KC_APP KC_APPLICATION
97 #define KC_EXEC KC_EXECUTE
98 #define KC_SLCT KC_SELECT
99 #define KC_AGIN KC_AGAIN
100 #define KC_PSTE KC_PASTE
101 #define KC_ERAS KC_ALT_ERASE
102 #define KC_CLR KC_CLEAR
105 #define KC_PSLS KC_KP_SLASH
106 #define KC_PAST KC_KP_ASTERISK
107 #define KC_PMNS KC_KP_MINUS
108 #define KC_PPLS KC_KP_PLUS
109 #define KC_PENT KC_KP_ENTER
110 #define KC_P1 KC_KP_1
111 #define KC_P2 KC_KP_2
112 #define KC_P3 KC_KP_3
113 #define KC_P4 KC_KP_4
114 #define KC_P5 KC_KP_5
115 #define KC_P6 KC_KP_6
116 #define KC_P7 KC_KP_7
117 #define KC_P8 KC_KP_8
118 #define KC_P9 KC_KP_9
119 #define KC_P0 KC_KP_0
120 #define KC_PDOT KC_KP_DOT
121 #define KC_PEQL KC_KP_EQUAL
122 #define KC_PCMM KC_KP_COMMA
124 /* Japanese specific */
125 #define KC_ZKHK KC_GRAVE
126 #define KC_RO KC_INT1
127 #define KC_KANA KC_INT2
128 #define KC_JYEN KC_INT3
129 #define KC_HENK KC_INT4
130 #define KC_MHEN KC_INT5
132 /* Korean specific */
133 #define KC_HAEN KC_LANG1
134 #define KC_HANJ KC_LANG2
137 #define KC_LCTL KC_LCTRL
138 #define KC_LSFT KC_LSHIFT
139 #define KC_LCMD KC_LGUI
140 #define KC_LWIN KC_LGUI
141 #define KC_RCTL KC_RCTRL
142 #define KC_RSFT KC_RSHIFT
143 #define KC_RCMD KC_RGUI
144 #define KC_RWIN KC_RGUI
146 /* Generic Desktop Page (0x01) */
147 #define KC_PWR KC_SYSTEM_POWER
148 #define KC_SLEP KC_SYSTEM_SLEEP
149 #define KC_WAKE KC_SYSTEM_WAKE
151 /* Consumer Page (0x0C) */
152 #define KC_MUTE KC_AUDIO_MUTE
153 #define KC_VOLU KC_AUDIO_VOL_UP
154 #define KC_VOLD KC_AUDIO_VOL_DOWN
155 #define KC_MNXT KC_MEDIA_NEXT_TRACK
156 #define KC_MPRV KC_MEDIA_PREV_TRACK
157 #define KC_MSTP KC_MEDIA_STOP
158 #define KC_MPLY KC_MEDIA_PLAY_PAUSE
159 #define KC_MSEL KC_MEDIA_SELECT
160 #define KC_EJCT KC_MEDIA_EJECT
161 #define KC_MAIL KC_MAIL
162 #define KC_CALC KC_CALCULATOR
163 #define KC_MYCM KC_MY_COMPUTER
164 #define KC_WSCH KC_WWW_SEARCH
165 #define KC_WHOM KC_WWW_HOME
166 #define KC_WBAK KC_WWW_BACK
167 #define KC_WFWD KC_WWW_FORWARD
168 #define KC_WSTP KC_WWW_STOP
169 #define KC_WREF KC_WWW_REFRESH
170 #define KC_WFAV KC_WWW_FAVORITES
171 #define KC_MFFD KC_MEDIA_FAST_FORWARD
172 #define KC_MRWD KC_MEDIA_REWIND
175 #define KC_MS_U KC_MS_UP
176 #define KC_MS_D KC_MS_DOWN
177 #define KC_MS_L KC_MS_LEFT
178 #define KC_MS_R KC_MS_RIGHT
179 #define KC_BTN1 KC_MS_BTN1
180 #define KC_BTN2 KC_MS_BTN2
181 #define KC_BTN3 KC_MS_BTN3
182 #define KC_BTN4 KC_MS_BTN4
183 #define KC_BTN5 KC_MS_BTN5
184 #define KC_WH_U KC_MS_WH_UP
185 #define KC_WH_D KC_MS_WH_DOWN
186 #define KC_WH_L KC_MS_WH_LEFT
187 #define KC_WH_R KC_MS_WH_RIGHT
188 #define KC_ACL0 KC_MS_ACCEL0
189 #define KC_ACL1 KC_MS_ACCEL1
190 #define KC_ACL2 KC_MS_ACCEL2
192 /* Keyboard/Keypad Page (0x07) */
193 enum hid_keyboard_keypad_usage {
361 // ***************************************************************
362 // These keycodes are present in the HID spec, but are *
363 // nonfunctional on modern OSes. QMK uses this range (0xA5-0xDF) *
364 // for the media and function keys instead - see below. *
365 // ***************************************************************
369 KC_THOUSANDS_SEPARATOR,
370 KC_DECIMAL_SEPARATOR,
372 KC_CURRENCY_SUB_UNIT,
399 KC_KP_MEM_STORE, //0xD0
425 // **********************************************
426 // * 0xF0-0xFF are unallocated in the HID spec. *
427 // * QMK uses these for Mouse Keys - see below. *
428 // **********************************************
431 /* Media and Function keys */
432 enum internal_special_keycodes {
433 /* Generic Desktop Page (0x01) */
434 KC_SYSTEM_POWER = 0xA5,
438 /* Consumer Page (0x0C) */
447 KC_MEDIA_EJECT, //0xB0
458 KC_MEDIA_FAST_FORWARD,