Kenneth Aloysius eba4cb7a04 RGB underglow support for JJ40, clean up redundant code in Mechmini keymap ()
* Cleanup Mechmini keymap. Once the custom RGB function is defined, there is no need to manually handle RGB code.

* Change default to KEYMAP_MIT, not KEYMAP_OFFSET

* Add custom RGB code for JJ40

* Reset Mechmini advertised power draw to 500. Will have to test actual maximum power draw later.

* RGB working on JJ40.

* Fix: saturation increase/decrease flipped

* Add new directory for my custom keymap with RGB keycodes

* Swap LAlt and LGUI

* Update JJ40 max power draw with measured value

* Update: fun40 rules.mk to enable underglow; earlier failed Travis CI
..
keymaps RGB underglow support for JJ40, clean up redundant code in Mechmini keymap ()
tools Add multiple layout support and Linux flash utility to JJ40 ()
README.md Fixed bootloader access key
config.h RGB underglow support for JJ40, clean up redundant code in Mechmini keymap ()
i2c.c Add support for the JJ40 Keyboard ()
i2c.h Add support for the JJ40 Keyboard ()
jj40.c RGB underglow support for JJ40, clean up redundant code in Mechmini keymap ()
jj40.h RGB underglow support for JJ40, clean up redundant code in Mechmini keymap ()
matrix.c Add support for the JJ40 Keyboard ()
rules.mk RGB underglow support for JJ40, clean up redundant code in Mechmini keymap ()
usbconfig.h RGB underglow support for JJ40, clean up redundant code in Mechmini keymap ()

README.md

jj40

jj40

A compact 40% (12x4) ortholinear keyboard kit made and KPRepublic on AliExpress.

Keyboard Maintainer: QMK Community
Hardware Supported: Atmega32A
Hardware Availability: AliExpress

Make example for this keyboard (after setting up your build environment):

make jj40:default:program

See build environment setup then the make instructions 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 bootloadHID if you boot the board while holding down Backspace (Top Right Key) to keep it in the bootloader:

$ make jj40
$ bootloadHID -r jj40_default.hex

Troubleshooting

  1. Try plugging the board in while pressing Backspace (Top Right Key). This will force it 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.
  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.