You can not select more than 25 topics Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.

75 lines
3.1 KiB

  1. MiniDox
  2. =====
  3. ![MiniDox](http://i.imgur.com/iWb3yO0.jpg)
  4. A compact version of the ErgoDox
  5. Keyboard Maintainer: That-Canadian
  6. Hardware Supported: MiniDox PCB rev1 Pro Micro
  7. Make example for this keyboard (after setting up your build environment):
  8. make minidox/rev1:default
  9. 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.
  10. ## Build Guide
  11. A build guide for putting together the MiniDox v1 can be found here: [MiniDox Build Log / Guide](http://imgur.com/a/vImo6)
  12. Flashing
  13. -------
  14. Note: Most of this is copied from the Let's Split readme, because it is awesome
  15. From the root directory run `make PROJECT:KEYMAP:avrdude` for automatic serial port resolution and flashing.
  16. Example: `make minidox/rev1:default:avrdude`
  17. Choosing which board to plug the USB cable into (choosing Master)
  18. --------
  19. Because the two boards are identical, the firmware has logic to differentiate the left and right board.
  20. It uses two strategies to figure things out: look at the EEPROM (memory on the chip) or looks if the current board has the usb cable.
  21. The EEPROM approach requires additional setup (flashing the eeeprom) but allows you to swap the usb cable to either side.
  22. The USB cable approach is easier to setup and if you just want the usb cable on the left board, you do not need to do anything extra.
  23. ### Setting the left hand as master
  24. If you always plug the usb cable into the left board, nothing extra is needed as this is the default. Comment out `EE_HANDS` and comment out `I2C_MASTER_RIGHT` or `MASTER_RIGHT` if for some reason it was set.
  25. ### Setting the right hand as master
  26. If you always plug the usb cable into the right board, add an extra flag to your `config.h`
  27. ```
  28. #define MASTER_RIGHT
  29. ```
  30. ### Setting EE_hands to use either hands as master
  31. If you define `EE_HANDS` in your `config.h`, you will need to set the
  32. EEPROM for the left and right halves.
  33. The EEPROM is used to store whether the
  34. half is left handed or right handed. This makes it so that the same firmware
  35. file will run on both hands instead of having to flash left and right handed
  36. versions of the firmware to each half. To flash the EEPROM file for the left
  37. half run:
  38. ```
  39. avrdude -p atmega32u4 -P $(COM_PORT) -c avr109 -U eeprom:w:"./quantum/split_common/eeprom-lefthand.eep"
  40. // or the equivalent in dfu-programmer
  41. ```
  42. and similarly for right half
  43. ```
  44. avrdude -p atmega32u4 -P $(COM_PORT) -c avr109 -U eeprom:w:"./quantum/split_common/eeprom-righthand.eep"
  45. // or the equivalent in dfu-programmer
  46. ```
  47. NOTE: replace `$(COM_PORT)` with the port of your device (e.g. `/dev/ttyACM0`)
  48. After you have flashed the EEPROM, you then need to set `EE_HANDS` in your config.h, rebuild the hex files and reflash.
  49. Note that you need to program both halves, but you have the option of using
  50. different keymaps for each half. You could program the left half with a QWERTY
  51. layout and the right half with a Colemak layout using bootmagic's default layout option.
  52. Then if you connect the left half to a computer by USB the keyboard will use QWERTY and Colemak when the
  53. right half is connected.