Open-source keyboard firmware for Atmel AVR and Arm USB families Including hardware based encryption
Go to file
tmk b0b6c33332 ad hoc fix for IDLE bug which affects on Mac only. 2011-05-04 13:42:34 +09:00
adb_usb FIX: send last report when idle timeouts. (pjrc) 2011-03-10 11:17:54 +09:00
hhkb minor fix for HHKB Makefile and doc 2011-05-04 08:12:27 +09:00
macway fixed macway to comply new API. 2011-02-22 03:09:21 +09:00
pjrc ad hoc fix for IDLE bug which affects on Mac only. 2011-05-04 13:42:34 +09:00
ps2_usb fix for ps2_usb Makefile and circuit 2011-05-04 08:16:26 +09:00
vusb FIX: send last report when idle timeouts. (pjrc) 2011-03-10 11:17:54 +09:00
.gitignore add mouse function. 2010-09-30 14:50:23 +09:00
Makefile.common host interface for pjrc 2011-02-22 03:09:05 +09:00
Makefile.pjrc host interface for pjrc 2011-02-22 03:09:05 +09:00
Makefile.rules integrate V-USB support into ps2_usb 2011-02-22 03:09:14 +09:00
Makefile.vusb host interface for pjrc 2011-02-22 03:09:05 +09:00
README v3.0 cleanse files 2011-02-22 03:49:02 +09:00
USB_NKRO.txt Add PS/2 mouse support to connect TrackPoint Unit. 2011-01-02 23:52:13 +09:00
adb.c FIX: send last report when idle timeouts. (pjrc) 2011-03-10 11:17:54 +09:00
adb.h ADB keyboard LEDs support 2011-01-13 22:46:57 +09:00
command.c FIX: send last report when idle timeouts. (pjrc) 2011-03-10 11:17:54 +09:00
command.h host interface for pjrc 2011-02-22 03:09:05 +09:00
controller_teensy.h ADD: keymap macro for human to read easier 2010-10-26 21:32:45 +09:00
debug.h improve layer switching 2010-10-30 01:16:47 +09:00
host.h fixed hhkb to comply new API. 2011-02-22 03:09:23 +09:00
keyboard.c integrate V-USB support into ps2_usb 2011-02-22 03:09:14 +09:00
keyboard.h host interface for pjrc 2011-02-22 03:09:05 +09:00
keymap.h integrate V-USB support into ps2_usb 2011-02-22 03:09:14 +09:00
layer.c integrate V-USB support into ps2_usb 2011-02-22 03:09:14 +09:00
layer.h refactor keyboard.h, host.h 2011-02-22 03:09:02 +09:00
led.h added protocol stack: pjrc, vusb 2011-02-22 03:08:59 +09:00
main_pjrc.c integrate V-USB support into ps2_usb 2011-02-22 03:09:14 +09:00
matrix.h integrate V-USB support into ps2_usb 2011-02-22 03:09:14 +09:00
mousekey.c host interface for pjrc 2011-02-22 03:09:05 +09:00
mousekey.c.bak refactor keyboard.h, host.h 2011-02-22 03:09:02 +09:00
mousekey.h refactor keyboard.h, host.h 2011-02-22 03:09:02 +09:00
mousekey.h.bak refactor keyboard.h, host.h 2011-02-22 03:09:02 +09:00
print.c added PS/2 to USB converter use V-USB as protocol stack 2011-02-22 03:08:49 +09:00
print.h added PS/2 to USB converter use V-USB as protocol stack 2011-02-22 03:08:49 +09:00
ps2.c integrate V-USB support into ps2_usb 2011-02-22 03:09:14 +09:00
ps2.h Synchronous USART support for PS/2 on V-USB stack 2011-02-22 03:09:12 +09:00
ps2_mouse.c refactor keyboard.h, host.h 2011-02-22 03:09:02 +09:00
ps2_mouse.h add error handling to ps2_mouse 2011-01-04 20:30:23 +09:00
sendchar.h added PS/2 to USB converter use V-USB as protocol stack 2011-02-22 03:08:49 +09:00
timer.c added PS/2 to USB converter use V-USB as protocol stack 2011-02-22 03:08:49 +09:00
timer.h added PS/2 to USB converter use V-USB as protocol stack 2011-02-22 03:08:49 +09:00
usb_keycodes.h added some short keycode names for ISO and JIS keyboard. 2011-02-17 13:29:50 +09:00
util.c add build option: NKRO_ENABLE(remove: USB_12KRO) 2010-12-08 01:57:55 +09:00
util.h new build method for macway 2010-10-27 22:56:01 +09:00

README

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
     USB_EXTRA_ENABLE = yes	# Enhanced feature for Windows(Audio control and System control)
     USB_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