- 
                Notifications
    You must be signed in to change notification settings 
- Fork 1.7k
Home
Welcome to the tmk_keyboard wiki!
You can buy here to support this project.
TMK Keyboard Service @ Geekhack.org
- HHKB Alt Controllers
- Converters(USB-USB, PS/2, ADB, NeXT, M0110, IBM4704, SUN, X68K...)
- Alps64 PCB(60% keyboard for Alps SKCM/SKCL)
- FC660C Alt Controller
- FC980C Alt Controller
- Keymap - internal details
- FAQ Keymap
- Keymap examples - share ideas
- Keymap: Custom Key Action
- Keycode
Keymap editor is available for TMK products. You can edit keymap and download firmware with web browser, you don't have to build firmware from source code.
You can flash firmware direclty in web browser using Flash on Web feature.
Use git clone to get codes in this repo. 'Download ZIP' link won't work because you need to git submodule to get libraries.
$ git clone https://github.com/tmk/tmk_keyboard.git
$ cd tmk_keyboard
$ git submodule init
$ git submodule update
Move to project directory.
$ {keyboard, converter}/<project_name>
Build with proper makefile such as Makefile.unimap.
$ make clean -f Makefile.unimap
$ make all   -f Makefile.unimap
You will see firmware HEX file in current directory, for example <project_name>_unimap.hex.
To build with your custom keymap file you need to add KEYMAP=<keymap_name> to the commands.
<keymap_name> is hasu if your kemap file is unimap_hasu.c, for example.
$ make clean -f Makefile.unimap KEYMAP=<keymap_name>
$ make all   -f Makefile.unimap KEYMAP=<keymap_name> 
Cofirmed that AVR GCC 5.4.0(ubuntu) and 7.3.0(Microchip/Atmel) works.
Use toolchain provided by Microchip/Atmel if you have problem with newer versions of GCC.
- With GCC 8 and newer ibmpc_usb converter has firmware size issue. #741
GCC Release Notes: https://gcc.gnu.org/releases.html
Don't use WinAVR with TMK anymore unless you know what you are doing and can help yourself. Instead use one of methods below.
You can setup tools for AVR with Homebrew by following commands. And refer to build doc.
brew tap osx-cross/avr
brew install avr-gcc
brew install dfu-programmer
MacPorts, CrossPack or Build on VirtualBox may be option if you want.
If you are on Ubuntu or similar distribution you will need to install following packages.
git unzip build-essential make
for AVR microcntroller:
gcc-avr avr-libc binutils-avr dfu-programmer
for ARM Cortex-M:
binutils-arm-none-eabi gcc-arm-none-eabi libnewlib-arm-none-eabi libstdc++-arm-none-eabi-newlib dfu-util
To flash firmware you can use one of following tools.
If you are familiar with command line interface dfu-programmer is recommended. Newer version of avrdude can be used also.
If you prefer graphical inteface you can try QMK Toolbox or Atmel FLIP.
- dfu-programmer
- avrdude
- QMK Toolbox
- Atmel FLIP
You can flash AVR microcontroller direclty in web browser at Keymap Editor or here.
- Turn your microcontroller into flash/programming mode by pressing button on converter/controller device
- Select firmware Hex file
- Click 'Flash on Web' button
- Select your device in dialog
This freature is supported on Chromium-based browsers like Google Chrome, Brave or Microsoft Edge, not on Firefox and Safari unfortunately.
Note that this support only AVR with Atmel proprietary bootloader. This is not for Arduino Leonardo and Pro Micro. All TMK products should be supported.
On Linux you need to install udev rules file to get permission.
On Windows you need to install WinUSB driver refering to this instruction, or you can just use Zadig instead.
Tested on Chrome on ubuntu, Chrome and Edge on Windows 11.
https://github.com/tmk/AVRFlashOnWeb
Install dfu-programmer with package manager like Brew, Mac Port, pacman, apt or anything. Or you can just download prebuilt binary file from here.
For Windows see this also.
- 
Boot your device into Flash(Programming) mode before flashing. Usually you can start the mode by pressing button on the device. 
- 
To flash firmware run three commands in terminal(cmd.exe for Windows/Terminal.app for Mac). 
dfu-programmer <controller> erase --force
dfu-programmer <controller> flash <your_firmware.hex>
dfu-programmer <controller> reset
- 
Remove --forceif you use older 0.6.x version.
- 
<controller>part will be atmega32u4(for HHKB/FC660C/FC980C Alt Controllers and USB-USB Conveter) or atmega32u2(for other Converters and Alps64).
- 
<your_firmware.hex>part should be file path to firmware hex file. You can copy file path by draging the firmware file from Finder or Explorer into terminal window like this.
On Linux and Mac OSX you will need proper permission to program a microcontroller and you can use sudo command for this purpose probably. On Linux you also can configure udev rules to set permission.
Newer versoins supports AVR DFU protocol.
https://manpages.debian.org/testing/avrdude/avrdude.1.en.html
You can use this command like below:
$ avrdude -patmega32u2 -cflip1 -Uflash:w:example.hex
This probably works for TMK also. https://github.com/qmk/qmk_toolbox
You can download from: https://github.com/qmk/qmk_toolbox/releases
This is official tool realeased by chip manufacturer and available for Linux and Windows.
You can download from: https://www.microchip.com/developmenttools/ProductDetails/FLIP
Check this for usage.
Refer to FAQ#debug-console also.
Use hid_listen command line tool to see debug outputs. Run hid_listen from command line interface such as Terminal.app or Command Prompt.
Download:
- Linux: hid_listen.linux
- Mac: hid_listen.mac64
- Windwos: hid_listen.exe
For Mac users, you will need run commands below in Terminal once after download hid_listen.mac64.
$ chmod +x hid_listen.mac64
$ xattr -c hid_listen.mac64
Note: You can't use QMK Toolbox for serious debug. It misses debug outputs for some reason as of 2021-09. Use hid_listen directly from cmd.exe, PowerShell or Terminal.
You can use xprintf() to show values on debug console. You will need to include print.h.
#include "print.h"
xprintf("key: %02X\n", key);
Refer to this for format of xprintf() on AVR.
%[flag][width][size]type
flag
  A '0' means filled with '0' when output is shorter than width.
  ' ' is used in default. This is effective only numeral type.
width
  Minimum width in decimal number. This is effective only numeral type.
  Default width is zero.
size
  A 'l' means the argument is long(32bit). Default is short(16bit).
  This is effective only numeral type.
type
  'c' : Character, argument is the value
  's' : String placed on the RAM, argument is the pointer
  'S' : String placed on the ROM, argument is the pointer
  'd' : Signed decimal, argument is the value
  'u' : Unsigned decimal, argument is the value
  'X' : Hexdecimal, argument is the value
  'b' : Binary, argument is the value
  '%' : '%'
Magic keybind is LShift + RShift on many keyboards and Power key on ADB converter by default.
But Magic keybind can be vary on each project, check config.h in project directory.
- 
Magic + HHelp
- 
Magic + VVersion and build options
- 
Magic + DGeneral debug print
- 
Magic + KKeyboard report
- 
Magic + XMatrix state
To change magic keybind you have to change it in config.h and build firmware. You can't change in Keymap Editor.
#define IS_COMMAND() ( \
    keyboard_report->mods == (MOD_BIT(KC_LSHIFT) | MOD_BIT(KC_RSHIFT)) || \
    keyboard_report->mods == (MOD_BIT(KC_LALT) | MOD_BIT(KC_RALT)) \
)