qmk-keychron-q3-colemak-dh/keyboards/mechmini/v1
Drashna Jaelre b05c0e46c6 Adds a default value for IS_COMMAND for COMMAND feature ()
* Add default value for IS_COMMAND for COMMAND feature

* Cleanup and consistency

* Update Templates to reflect change

* Fix IS_COMMAND in template

* Fix IS_COMMAND define

* Use consistent IS_COMMAND block in templates

* Remove unnecessary `#undef IS_COMMAND` directives

* Fix compile issue on orthodox

* Reomve IS_COMMAND option for newer boards

* Remove all existing definitions of IS_COMMAND if they use default LSHIFT and RSHIFT setting

* Remove a couple of additional IS_COMMAND defines

* Remove remaining redundant IS_COMMAND definitions

* Remove #undef IS_COMMAND from orthodox:drashna and whitefox:konstantin

* Remove multiple empty lines in modified config.h files

* Update additional boards

* Reomve IS_COMMAND from newer boards

* Update Alice keyboard

* Remove IS_COMMAND from additional boards

Jan 24th edition
2019-01-26 15:49:45 -08:00
..
keymaps Keyboard: Adding Split Space support for Mechmini 1 () 2018-10-03 12:14:36 -07:00
config.h Adds a default value for IS_COMMAND for COMMAND feature () 2019-01-26 15:49:45 -08:00
i2c.c Added Mechmini 2.0 to Mechmini keyboard folder 2018-01-03 10:32:53 -05:00
i2c.h Added Mechmini 2.0 to Mechmini keyboard folder 2018-01-03 10:32:53 -05:00
matrix.c Updated matrix.c for some PS2AVRGB boards and templates for new_project script () 2018-05-31 08:32:05 -07:00
README.md Modified URLs to point to new locations 2019-01-13 09:11:18 -08:00
rules.mk Added Mechmini 2.0 to Mechmini keyboard folder 2018-01-03 10:32:53 -05:00
usbconfig.h Added Mechmini 2.0 to Mechmini keyboard folder 2018-01-03 10:32:53 -05:00
v1.c Updated matrix.c for some PS2AVRGB boards and templates for new_project script () 2018-05-31 08:32:05 -07:00
v1.h Keyboard: Adding Split Space support for Mechmini 1 () 2018-10-03 12:14:36 -07:00

Mechmini V1

A 40% ortholinear/staggered keyboard, that was originally bootmapper and can be ported to QMK following this readme. This version is no longer in production More info on MECHKEYS.

Keyboard Maintainer: QMK Community Hardware Supported: Mechmini 1 PCB
Hardware Availability: Version 1 (Bootmapper) no longer in production MECHKEYS

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

make mechmini/v1:default

See build environment setup then the make instructions for more information.

Mechmini Notes

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.

Installing

First, install the requirements. These commands are for OSX, but all you need is 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

Then, with the keyboard plugged in, simply run this command from the qmk_firmware directory:

$ make mechmini:program

If you prefer, you can just build it and flash the firmware directly with bootloadHID if you boot the board while holding down L_Ctrl to keep it in the bootloader:

$ make mechmini
$ bootloadHID -r mechmini_default.hex

Troubleshooting

From my experience, it's really hard to brick these boards. But these tricks have been useful when it got stuck in a weird scenario.

  1. Try plugging the board in while pressing L_Ctrl. 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 errors happen with ./tmk_core/common/avr/suspend.c it is likely you implemented a RGB underglow sleep setting previously. Simply comment out the following code found under void suspend_wakeup_init(void):
ifdef RGBLIGHT_ANIMATIONS
    rgblight_timer_enable();
    _delay_ms(50);
    rgblight_set();
#endif

So that the resulting code should know reflect:

/*#ifdef RGBLIGHT_ANIMATIONS
    rgblight_timer_enable();
    _delay_ms(50);
    rgblight_set();
#endif*/