]> git.gir.st - tmk_keyboard.git/blob - converter/next_usb/config.h
Add TMK converter support to Next converter
[tmk_keyboard.git] / converter / next_usb / config.h
1 /*
2 NeXT non-ADB Keyboard USB Converter
3
4 Copyright 2013, Benjamin Gould (bgould@github.com)
5
6 Based on:
7 TMK firmware code Copyright 2011,2012 Jun WAKO <wakojun@gmail.com>
8 Arduino code by "Ladyada" Limor Fried (http://ladyada.net/, http://adafruit.com/), released under BSD license
9
10 Timing reference thanks to http://m0115.web.fc2.com/ (dead link), http://cfile7.uf.tistory.com/image/14448E464F410BF22380BB
11 Pinouts thanks to http://www.68k.org/~degs/nextkeyboard.html
12 Keycodes from http://ftp.netbsd.org/pub/NetBSD/NetBSD-release-6/src/sys/arch/next68k/dev/
13
14 This software is licensed with a Modified BSD License.
15 All of this is supposed to be Free Software, Open Source, DFSG-free,
16 GPL-compatible, and OK to use in both free and proprietary applications.
17 Additions and corrections to this file are welcome.
18
19 Redistribution and use in source and binary forms, with or without
20 modification, are permitted provided that the following conditions are met:
21
22 * Redistributions of source code must retain the above copyright
23 notice, this list of conditions and the following disclaimer.
24
25 * Redistributions in binary form must reproduce the above copyright
26 notice, this list of conditions and the following disclaimer in
27 the documentation and/or other materials provided with the
28 distribution.
29
30 * Neither the name of the copyright holders nor the names of
31 contributors may be used to endorse or promote products derived
32 from this software without specific prior written permission.
33
34 THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS "AS IS"
35 AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE
36 IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE
37 ARE DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT OWNER OR CONTRIBUTORS BE
38 LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR
39 CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF
40 SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS
41 INTERRUPTION) HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN
42 CONTRACT, STRICT LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE)
43 ARISING IN ANY WAY OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE
44 POSSIBILITY OF SUCH DAMAGE.
45
46 */
47
48 #define VENDOR_ID 0xBCBC
49 #define PRODUCT_ID 0xBCBC
50 #define DEVICE_VER 0x0500
51 #define MANUFACTURER t.m.k.
52 #define PRODUCT NeXT Keyboard to USB converter
53 #define DESCRIPTION USB converter for NeXT non-ADB Keyboard
54
55 /* matrix size */
56 #define MATRIX_ROWS 12 // keycode bit: 3-0
57 #define MATRIX_COLS 8 // keycode bit: 6-4
58
59 //#define DEBUG_ON_INIT 1
60
61 //#define TEENSY_CONFIG 1
62 #define PRO_MICRO_CONFIG 1
63 //#define TMK_CONFIG 1
64
65 // comment out if you don't want the keyboard's LEDs to flash upon initialization
66 #define NEXT_KBD_INIT_FLASH_LEDS
67
68 //============= Start of Arduino Pro Micro Configuration ==============
69 #ifdef PRO_MICRO_CONFIG
70
71 // this is the debugging LED that flashes when a key is being pressed
72 // comment out in order to disable debugging LED
73 #define NEXT_KBD_LED1_PORT PORTD
74 #define NEXT_KBD_LED1_PIN PIND
75 #define NEXT_KBD_LED1_DDR DDRD
76 #define NEXT_KBD_LED1_BIT 5
77
78 #define NEXT_KBD_LED1_ON NEXT_KBD_LED1_PORT &= ~(1<<NEXT_KBD_LED1_BIT);
79 #define NEXT_KBD_LED1_OFF NEXT_KBD_LED1_PORT |= (1<<NEXT_KBD_LED1_BIT);
80
81 // reserved for future use
82 #define NEXT_KBD_LED2_PORT PORTB
83 #define NEXT_KBD_LED2_PIN PINB
84 #define NEXT_KBD_LED2_DDR DDRB
85 #define NEXT_KBD_LED2_BIT 6
86
87 #define NEXT_KBD_LED2_ON NEXT_KBD_LED2_PORT &= ~(1<<NEXT_KBD_LED2_BIT);
88 #define NEXT_KBD_LED2_OFF NEXT_KBD_LED2_PORT |= (1<<NEXT_KBD_LED2_BIT);
89
90 // corresponds to the Keyboard In wire on the NeXT connector
91 // (red wire in NeXT connector) - pin 2 on the Pro Micro
92 #define NEXT_KBD_OUT_PORT PORTD
93 #define NEXT_KBD_OUT_PIN PIND
94 #define NEXT_KBD_OUT_DDR DDRD
95 #define NEXT_KBD_OUT_BIT 1
96
97 // corresponds to the Keyboard Out wire on the NeXT connector
98 // (orange wire in NeXT connector) - pin 3 on the Pro Micro
99 #define NEXT_KBD_IN_PORT PORTD
100 #define NEXT_KBD_IN_PIN PIND
101 #define NEXT_KBD_IN_DDR DDRD
102 #define NEXT_KBD_IN_BIT 0
103
104 // this pin is an input for the power key on the NeXT keyboard
105 // as the keyboard is powered on this should be normally high;
106 // if it is pulled low it means the power button is being preseed
107 // (yellow wire in NeXT connector) - pin 4 on the Pro Micro
108 #define NEXT_KBD_PWR_PORT PORTD
109 #define NEXT_KBD_PWR_PIN PIND
110 #define NEXT_KBD_PWR_DDR DDRD
111 #define NEXT_KBD_PWR_BIT 4
112
113 #endif
114 //============== End of Arduino Pro Micro Configuration ===============
115
116
117 //================ Start of Teensy 2.0 Configuration =================
118 #ifdef TEENSY_CONFIG
119
120 // this is the debugging LED that flashes when a key is being pressed
121 // comment out in order to disable debugging LED
122 #define NEXT_KBD_LED_PORT PORTD
123 #define NEXT_KBD_LED_PIN PIND
124 #define NEXT_KBD_LED_DDR DDRD
125 #define NEXT_KBD_LED_BIT 6
126
127 #define NEXT_KBD_LED_ON NEXT_KBD_LED_PORT |= (1<<NEXT_KBD_LED_BIT);
128 #define NEXT_KBD_LED_OFF NEXT_KBD_LED_PORT &= ~(1<<NEXT_KBD_LED_BIT);
129
130 // corresponds to the Keyboard In wire on the NeXT connector
131 // (red wire in NeXT connector)
132 #define NEXT_KBD_OUT_PORT PORTB
133 #define NEXT_KBD_OUT_PIN PINB
134 #define NEXT_KBD_OUT_DDR DDRB
135 #define NEXT_KBD_OUT_BIT 1
136
137 // corresponds to the Keyboard Out wire on the NeXT connector
138 // (orange wire in NeXT connector)
139 #define NEXT_KBD_IN_PORT PORTB
140 #define NEXT_KBD_IN_PIN PINB
141 #define NEXT_KBD_IN_DDR DDRB
142 #define NEXT_KBD_IN_BIT 0
143
144 #endif
145 //================= End of Teensy 2.0 Configuration ==================
146
147
148 //================ Start of TMK converter Configuration =================
149 #ifdef TMK_CONFIG
150
151 // this is the debugging LED that flashes when a key is being pressed
152 // comment out in order to disable debugging LED
153 #define NEXT_KBD_LED1_PORT PORTD
154 #define NEXT_KBD_LED1_PIN PIND
155 #define NEXT_KBD_LED1_DDR DDRD
156 #define NEXT_KBD_LED1_BIT 6
157
158 #define NEXT_KBD_LED1_ON NEXT_KBD_LED1_PORT |= (1<<NEXT_KBD_LED1_BIT);
159 #define NEXT_KBD_LED1_OFF NEXT_KBD_LED1_PORT &= ~(1<<NEXT_KBD_LED1_BIT);
160
161 // corresponds to the Keyboard In wire on the NeXT connector
162 #define NEXT_KBD_OUT_PORT PORTD
163 #define NEXT_KBD_OUT_PIN PIND
164 #define NEXT_KBD_OUT_DDR DDRD
165 #define NEXT_KBD_OUT_BIT 1
166
167 // corresponds to the Keyboard Out wire on the NeXT connector
168 #define NEXT_KBD_IN_PORT PORTD
169 #define NEXT_KBD_IN_PIN PIND
170 #define NEXT_KBD_IN_DDR DDRD
171 #define NEXT_KBD_IN_BIT 0
172
173 // this pin is an input for the power key on the NeXT keyboard
174 // as the keyboard is powered on this should be normally high;
175 // if it is pulled low it means the power button is being preseed
176 #define NEXT_KBD_PWR_PORT PORTD
177 #define NEXT_KBD_PWR_PIN PIND
178 #define NEXT_KBD_PWR_DDR DDRD
179 #define NEXT_KBD_PWR_BIT 4
180
181 #endif
182 //================= End of TMK converter Configuration ==================
183
184 /* key combination for command */
185 #define IS_COMMAND() ( \
186 (keyboard_report->mods == (MOD_BIT(KC_LSHIFT) | MOD_BIT(KC_RSHIFT)))|| \
187 (keyboard_report->mods == (MOD_BIT(KC_RALT) | MOD_BIT(KC_RCTL))) \
188 )
Imprint / Impressum