@ -1,151 +0,0 @@ |
||||
t.m.k. Keyboard Firmware |
||||
======================== |
||||
This is keyboard firmware for Teensy(AVR USB MCU) and V-USB board. |
||||
|
||||
source code repository: |
||||
http://github.com/tmk/tmk_keyboard |
||||
|
||||
This firmware is used in following projects: |
||||
HHKB mod: http://geekhack.org/showwiki.php?title=Island:12047 |
||||
Macway mod: http://geekhack.org/showwiki.php?title=Island:11930 |
||||
PS2 to USB: http://geekhack.org/showwiki.php?title=Island:14618 |
||||
ADB to USB: http://geekhack.org/showwiki.php?title=Island:14290 |
||||
|
||||
The project is heavily based on PJRC USB Keyboard/Mouse Example and |
||||
owes a debt to preceding keyboard firmware projects. |
||||
http://www.pjrc.com/teensy |
||||
|
||||
|
||||
Features |
||||
-------- |
||||
Mouse key |
||||
control mouse cursor from keyboard. |
||||
System Control Key |
||||
Power Down, Sleep, Wake Up & USB Remote Wake up |
||||
Media Control Key |
||||
Volume Down/Up, Mute |
||||
USB NKRO |
||||
send 120 keys(+ 8 modifiers) at most simultaneously. |
||||
PS/2 mouse support |
||||
integrate PS/2 mouse(TrackPoint) into keyboard as composite device. |
||||
|
||||
|
||||
Limitations |
||||
----------- |
||||
|
||||
|
||||
Files & Directories |
||||
------------------- |
||||
Target: |
||||
hhkb/ keyboard controller for PFU HHKB pro |
||||
macway/ keyboard controller for Macway mod |
||||
ps2_usb/ PS2 to USB keyboard converter |
||||
adb_usb/ ADB to USB keyboard converter |
||||
|
||||
USB Protocol Stack: |
||||
pjrc/ PJRC USB stack |
||||
vusb/ V-USB USB stack |
||||
ps2.[ch] PS/2 protocol |
||||
adb.[ch] ADB protocol |
||||
|
||||
|
||||
Build |
||||
----- |
||||
To compile needs AVR GCC, AVR Libc and GNU make. |
||||
You can use WinAVR on Windows. http://winavr.sourceforge.net/ |
||||
|
||||
$ cd <target> |
||||
$ make |
||||
|
||||
The firmware will be compiled as a file tmk_<target>.hex. |
||||
|
||||
|
||||
Build your own firmware |
||||
----------------------- |
||||
Copying exsistent target(macway) is easy way. |
||||
1. Copy contens of macway/ to your own target directory. |
||||
2. Edit Makefile. See next section. |
||||
3. Edit config.h. See next section. |
||||
4. Edit matrix.c. You will need to fix followings at least. |
||||
matrix_init() |
||||
matrix_scan() |
||||
read_col() |
||||
unselect_rows() |
||||
select_row() |
||||
5. Edit keymap.c. NOTE: It is not final design and a bit messy. |
||||
You will need to fix followings at least. |
||||
KEYMAP |
||||
fn_layer[] |
||||
fn_keycode[] |
||||
keymaps[] |
||||
6. Build. |
||||
|
||||
If you have a build error like following, comment out "--relax" option in Makefile.common. |
||||
(.vectors+0x30): relocation truncated to fit: R_AVR_13_PCREL against symbol `__vector_12' |
||||
|
||||
|
||||
Build Options |
||||
------------- |
||||
<target>/Makefile: |
||||
1. Set target name for your firmware. |
||||
TARGET = tmk_<target> |
||||
2. Choose a MCU and its frequency. |
||||
MCU = atmega32u4 # Teensy 2.0 |
||||
#MCU = at90usb1286 # Teensy++ 2.0 |
||||
F_CPU = 16000000 |
||||
3. Choose optional modules as needed. Comment out to disable optional modules. |
||||
MOUSEKEY_ENABLE = yes # Mouse keys |
||||
PS2_MOUSE_ENABLE = yes # PS/2 mouse(TrackPoint) support |
||||
EXTRAKEY_ENABLE = yes # Enhanced feature for Windows(Audio control and System control) |
||||
NKRO_ENABLE = yes # USB Nkey Rollover |
||||
|
||||
<target>/config.h: |
||||
1. USB vendor/product ID and device description |
||||
#define VENDOR_ID 0xFEED |
||||
#define PRODUCT_ID 0xBEEF |
||||
/* device description */ |
||||
#define MANUFACTURER t.m.k. |
||||
#define PRODUCT Macway mod |
||||
#define DESCRIPTION t.m.k. keyboard firmware for Macway mod |
||||
2. Keyboard matrix configuration |
||||
#define MATRIX_ROWS 8 |
||||
#define MATRIX_COLS 8 |
||||
#define MATRIX_HAS_GHOST |
||||
3. Mouse keys configuration if needed. |
||||
4. PS/2 mouse configuration if needed. |
||||
|
||||
|
||||
Debuging & Rescue |
||||
----------------- |
||||
Use PJRC's hid_listen.exe to see debug messages. |
||||
Press <COMMAND> + H to debug menu. |
||||
(see config.h for <COMMAND> key combination.) |
||||
|
||||
Pressing any 3 keys when connected enables debug output. |
||||
Pressing any 4 keys when connected makes bootloader comes up. |
||||
|
||||
|
||||
Projects related |
||||
---------------- |
||||
PJRC USB Keyboard/Mouse Example |
||||
http://www.pjrc.com/teensy/usb_keyboard.html |
||||
http://www.pjrc.com/teensy/usb_mouse.html |
||||
kbupgrade |
||||
http://github.com/rhomann/kbupgrade |
||||
http://geekhack.org/showwiki.php?title=Island:8406 |
||||
c64key |
||||
http://symlink.dk/projects/c64key/ |
||||
rump |
||||
http://mg8.org/rump/ |
||||
http://github.com/clee/rump |
||||
dulcimer |
||||
http://www.schatenseite.de/dulcimer.html |
||||
humblehacker-keyboard |
||||
http://github.com/humblehacker |
||||
http://www.humblehacker.com/keyboard/ |
||||
http://geekhack.org/showwiki.php?title=Island:6292 |
||||
ps2avr |
||||
http://sourceforge.net/projects/ps2avr/ |
||||
|
||||
|
||||
EOF |
@ -0,0 +1,175 @@ |
||||
t.m.k. Keyboard Firmware Collection |
||||
==================================== |
||||
This is a keyboard firmware with some features for Atmel AVR controller. |
||||
|
||||
Source code is available here: <http://github.com/tmk/tmk_keyboard> |
||||
|
||||
|
||||
Features |
||||
-------- |
||||
* Mouse key - Mouse control by keyboard |
||||
* System Control Key - Power Down, Sleep, Wake Up and USB Remote Wake up |
||||
* Media Control Key - Volume Down/Up, Mute, Next/Prev track, Play, Stop and etc. |
||||
* USB NKRO - Can send 120 keys(+ 8 modifiers) simultaneously. |
||||
* PS/2 mouse support - integrate PS/2 mouse(TrackPoint) into keyboard as composite device. |
||||
|
||||
|
||||
Projects |
||||
-------- |
||||
### converter |
||||
* ps2_usb - PS/2 keyboard to USB |
||||
* adb_usb - ADB keyboard to USB |
||||
* m0110_usb - Machintosh 128K/512K/Plus keyboard to USB |
||||
* terminal_usb - IBM Model M terminal keyboard(PS/2 scancode set3) to USB |
||||
* sony_usb - Sony NEWS keyboard to USB |
||||
* x68k_usb - Sharp X68000 keyboard to USB |
||||
|
||||
### keyboard |
||||
* hhkb - Happy Hacking Keyboard professional |
||||
* macway - Compact keyboard mod |
||||
* hbk - Happy Buckling sprint keyboard(IBM Model M mod) |
||||
|
||||
[GH_macway]: http://geekhack.org/showwiki.php?title=Island:11930 |
||||
[GH_hhkb]: http://geekhack.org/showwiki.php?title=Island:12047 |
||||
[GH_ps2]: http://geekhack.org/showwiki.php?title=Island:14618 |
||||
[GH_adb]: http://geekhack.org/showwiki.php?title=Island:14290 |
||||
[GH_hhkb_bt]: http://geekhack.org/showwiki.php?title=Island:20851 |
||||
[GH_m0110]: http://geekhack.org/showwiki.php?title=Island:24965 |
||||
[GH_sony]: http://geekhack.org/showwiki.php?title=Island:25759 |
||||
[GH_terminal]: http://geekhack.org/showwiki.php?title=Island:27272 |
||||
[GH_x68k]: http://geekhack.org/showwiki.php?title=Island:29060 |
||||
[GH_hbk]: http://geekhack.org/showwiki.php?title=Island:29483 |
||||
|
||||
|
||||
|
||||
Files & Directories |
||||
------------------- |
||||
### Top |
||||
* common/ common codes |
||||
* protocol/ keyboard protocol support |
||||
* keyboard/ keyboard projects |
||||
* converter/ protocol converter projects |
||||
* doc/ documents |
||||
|
||||
### Keyboard Protocols |
||||
* pjrc/ PJRC USB stack |
||||
* vusb/ Objective Development V-USB |
||||
* iwrap/ Bluetooth HID for Bluegiga iWRAP |
||||
* ps2 PS/2 protocol |
||||
* adb Apple Desktop Bus protocol |
||||
* m0110 Macintosh 128K/512K/Plus keyboard protocol |
||||
* news Sony NEWS keyboard protocol |
||||
* x68k Sharp X68000 keyboard protocol |
||||
|
||||
|
||||
Build & Program |
||||
--------------- |
||||
### Build firmware |
||||
To compile you need `AVR GCC`, `AVR Libc` and `GNU make`. |
||||
You can use [WinAVR][1] on Windows and [CrossPack][2] on Mac. |
||||
|
||||
$ cd <project> |
||||
$ make |
||||
|
||||
The firmware will be compiled as a file tmk_<project>.hex. |
||||
|
||||
[1]: http://winavr.sourceforge.net/ |
||||
[2]: http://www.obdev.at/products/crosspack/index.html |
||||
|
||||
### Program Controller |
||||
If you have proper program command in Makefile just type this. |
||||
|
||||
$ make program |
||||
|
||||
As for `Teensy` you can use `PJRC's loader` to program hex file. <http://www.pjrc.com/teensy/loader.html> |
||||
|
||||
|
||||
|
||||
Build Options |
||||
------------- |
||||
### `Makefile` |
||||
#### 1. MCU and Frequency. |
||||
MCU = atmega32u4 # Teensy 2.0 |
||||
#MCU = at90usb1286 # Teensy++ 2.0 |
||||
F_CPU = 16000000 |
||||
|
||||
#### 2. Features |
||||
Note that ***comment out*** to disable them. |
||||
MOUSEKEY_ENABLE = yes # Mouse keys |
||||
PS2_MOUSE_ENABLE = yes # PS/2 mouse(TrackPoint) support |
||||
EXTRAKEY_ENABLE = yes # Enhanced feature for Windows(Audio control and System control) |
||||
NKRO_ENABLE = yes # USB Nkey Rollover |
||||
|
||||
#### 3. Programmer |
||||
Set proper command for your controller, bootloader and programmer. |
||||
# for PJRC Teensy |
||||
PROGRAM_CMD = teensy_loader_cli -mmcu=$(MCU) -w -v $(TARGET).hex |
||||
|
||||
# for Atmel AT90USBKEY |
||||
PROGRAM_CMD = dfu-programmer $(MCU) flash $(TARGET).hex |
||||
|
||||
# avrdude |
||||
PROGRAM_CMD = avrdude -p $(MCU) -c avrispmkII -P USB -U flash:w:$(TARGET).hex |
||||
PROGRAM_CMD = avrdude -p $(MCU) -c usbasp -U flash:w:$(TARGET).hex |
||||
PROGRAM_CMD = avrdude -p $(MCU) -c arduino -P COM1 -b 57600 -U flash:w:$(TARGET).hex |
||||
|
||||
### `config.h` |
||||
#### 1. USB vendor/product ID and device description |
||||
#define VENDOR_ID 0xFEED |
||||
#define PRODUCT_ID 0xBEEF |
||||
/* device description */ |
||||
#define MANUFACTURER t.m.k. |
||||
#define PRODUCT Macway mod |
||||
#define DESCRIPTION t.m.k. keyboard firmware for Macway mod |
||||
|
||||
#### 2. Keyboard matrix configuration |
||||
#define MATRIX_ROWS 8 |
||||
#define MATRIX_COLS 8 |
||||
#define MATRIX_HAS_GHOST |
||||
|
||||
### 3. Mouse keys configuration |
||||
|
||||
### 4. PS/2 mouse configuration |
||||
|
||||
|
||||
Keymap |
||||
------ |
||||
|
||||
|
||||
Build your own firmware |
||||
----------------------- |
||||
|
||||
|
||||
Debuging |
||||
-------- |
||||
Use PJRC's `hid_listen` to see debug messages and press `<COMMAND> + H` to debug menu. |
||||
See `config.h` for definition of `<COMMAND>` key combination. |
||||
|
||||
|
||||
Other Keyboard Projects |
||||
----------------------- |
||||
### PJRC USB Keyboard/Mouse Example |
||||
- <http://www.pjrc.com/teensy/usb_keyboard.html> |
||||
- <http://www.pjrc.com/teensy/usb_mouse.html> |
||||
|
||||
### kbupgrade |
||||
- <http://github.com/rhomann/kbupgrade> |
||||
- <http://geekhack.org/showwiki.php?title=Island:8406> |
||||
|
||||
### c64key |
||||
- <http://symlink.dk/projects/c64key/> |
||||
|
||||
### rump |
||||
- <http://mg8.org/rump/> |
||||
- <http://github.com/clee/rump> |
||||
|
||||
### dulcimer |
||||
- <http://www.schatenseite.de/dulcimer.html> |
||||
|
||||
### humblehacker-keyboard |
||||
- <http://github.com/humblehacker> |
||||
- <http://www.humblehacker.com/keyboard/> |
||||
- <http://geekhack.org/showwiki.php?title=Island:6292> |
||||
|
||||
### ps2avr |
||||
- <http://sourceforge.net/projects/ps2avr/> |
Before Width: | Height: | Size: 48 KiB After Width: | Height: | Size: 48 KiB |
Before Width: | Height: | Size: 49 KiB After Width: | Height: | Size: 49 KiB |
Before Width: | Height: | Size: 490 KiB After Width: | Height: | Size: 490 KiB |
Before Width: | Height: | Size: 146 KiB After Width: | Height: | Size: 146 KiB |
Before Width: | Height: | Size: 152 KiB After Width: | Height: | Size: 152 KiB |
Before Width: | Height: | Size: 145 KiB After Width: | Height: | Size: 145 KiB |
Before Width: | Height: | Size: 189 KiB After Width: | Height: | Size: 189 KiB |
Before Width: | Height: | Size: 132 KiB After Width: | Height: | Size: 132 KiB |
Before Width: | Height: | Size: 168 KiB After Width: | Height: | Size: 168 KiB |
Before Width: | Height: | Size: 188 KiB After Width: | Height: | Size: 188 KiB |
Before Width: | Height: | Size: 166 KiB After Width: | Height: | Size: 166 KiB |
Before Width: | Height: | Size: 204 KiB After Width: | Height: | Size: 204 KiB |
Before Width: | Height: | Size: 133 KiB After Width: | Height: | Size: 133 KiB |
Before Width: | Height: | Size: 151 KiB After Width: | Height: | Size: 151 KiB |
Before Width: | Height: | Size: 119 KiB After Width: | Height: | Size: 119 KiB |
Before Width: | Height: | Size: 143 KiB After Width: | Height: | Size: 143 KiB |
Before Width: | Height: | Size: 114 KiB After Width: | Height: | Size: 114 KiB |
Before Width: | Height: | Size: 107 KiB After Width: | Height: | Size: 107 KiB |
Before Width: | Height: | Size: 113 KiB After Width: | Height: | Size: 113 KiB |
Before Width: | Height: | Size: 162 KiB After Width: | Height: | Size: 162 KiB |
Before Width: | Height: | Size: 162 KiB After Width: | Height: | Size: 162 KiB |
Before Width: | Height: | Size: 149 KiB After Width: | Height: | Size: 149 KiB |
Before Width: | Height: | Size: 116 KiB After Width: | Height: | Size: 116 KiB |
@ -0,0 +1,2 @@ |
||||
# Search Path
|
||||
VPATH += $(TOP_DIR)/protocol
|