2017-10-13 20:20:56 +00:00
# jj40
![jj40 ](https://ae01.alicdn.com/kf/HTB18bq6bOERMeJjSspiq6zZLFXar.jpg?size=359506&height=562&width=750&hash=663a22d0109e2416ec8f54a7658686da )
A compact 40% (12x4) ortholinear keyboard kit made and KPRepublic on AliExpress.
Keyboard Maintainer: [QMK Community ](https://github.com/qmk )
Hardware Supported: Atmega32A
Hardware Availability: [AliExpress ](https://www.aliexpress.com/store/product/jj40-Custom-Mechanical-Keyboard-40-PCB-programmed-40-planck-layouts-bface-firmware-gh40/3034003_32828781103.html )
Make example for this keyboard (after setting up your build environment):
2017-10-14 21:32:19 +00:00
make jj40:default:program
2017-10-13 20:20:56 +00:00
See [build environment setup ](https://docs.qmk.fm/build_environment_setup.html ) then the [make instructions ](https://docs.qmk.fm/make_instructions.html ) for more information.
Note that this is a complete replacement for the firmware, so you won't be
using Bootmapper Client to change any keyboard settings, since not all the
USB report options are supported.
In addition you may need the AVR toolchain and `bootloadHID` for flashing:
```
$ brew cask install crosspack-avr
$ brew install --HEAD https://raw.githubusercontent.com/robertgzr/homebrew-tap/master/bootloadhid.rb
```
In order to use the `./program` script, which can reboot the board into
the bootloader, you'll need Python 2 with PyUSB installed:
```
$ pip install pyusb
```
If you prefer, you can just build it and flash the firmware directly with
2017-11-26 06:26:03 +00:00
`bootloadHID` if you boot the board while holding down `Backspace` (`Top Right Key`) to keep it
2017-10-13 20:20:56 +00:00
in the bootloader:
```
$ make jj40
$ bootloadHID -r jj40_default.hex
```
## Troubleshooting
2017-11-26 06:26:03 +00:00
1. Try plugging the board in while pressing `Backspace` (`Top Right Key`). This will force it
2017-10-13 20:20:56 +00:00
to boot only the bootloader without loading the firmware. Once this is
done, just reflash the board with the original firmware.
2. Sometimes USB hubs can act weird, so try connecting the board directly
to your computer or plugging/unplugging the USB hub.
2017-10-14 05:04:36 +00:00
3. If you get an error such as "Resource Unavailable" when attemting to flash
on Linux, you may want to compile and run `tools/usb_detach.c` . See `tools/README.md`
for more info.