keyboard_pcb/keyplus_mini/README.md

190 lines
7.1 KiB
Markdown
Raw Normal View History

2017-09-17 01:53:57 -05:00
# keyplus mini beta
## Errata rev2
The SS and MO pins are mislabeled. The SS pin should be MO, and the MO pin
should be SS.
## Wiring
### Wiring key matrix
The key matrix should be wired to the ROW and COL pins on the PCB. Wiring of the
2017-09-20 04:05:00 -05:00
ROW and COL pins should start from the lowest number pin (i.e. `ROW0`
2017-09-17 01:53:57 -05:00
and `COL0`) and work up in consecutive order. The diodes in the key matrix should
point from the COL to ROW pins (other scan modes not implemented yet).
2017-09-20 04:05:00 -05:00
2017-09-17 01:53:57 -05:00
The `COL15, COL14, COL13, COL12` pins (underlined on the PCB) may also be used
as `ROW` pins. They map to the following row pins:
* ROW6: COL15
* ROW7: COL14
* ROW8: COL13
* ROW9: COL12
Thus it is possible to have up to 120 keys connected using a 10x12 matrix.
### Wired split with I2C
To connect to boards with I2C for wired split, connect the 5V, SDA, SCL, and
2017-09-20 04:05:00 -05:00
GND pins between devices. You can connect several devices in this manner. They
2017-09-17 01:53:57 -05:00
just need to share 5V, SDA, SCL and GND pins.
2017-09-20 04:05:00 -05:00
I would recommend **NOT** using TRRS connectors for wired split. While
connecting and disconnecting the cabel, the contacts inside the TRRS cable can
short to one another. Instead, I would recommend using micro USB ports, or
another connector that doesn't short it's contacts when it is
plugged/unplugged. Then you will be able to take advantage of the
wireless/wired hot plugging functionality without worrying about damaging the
hardware. You can find male-to-male micro USB cables online with a bit of
searching.
2017-09-17 01:53:57 -05:00
### Wireless with nRF24L01+
To use wireless mode, you will need a battery and a nRF24L01+ module. The
battery should be 3V. Some options for the battery are 1xCR2032, 2xAA/AAA, or
1xAA/AAA with a boost converter. Note the keyplus mini controller does not
support any sort of charging of the batteries. When there is no USB connecting
the device will run off battery power. When the USB is plugged in, it will
automatically switch to run off USB power. To connect the battery connect:
* BAT -> positive battery terminal
* GND -> negative battery terminal
To connect an nRF24L01+ module you will need to connect these pins:
* xmega -> nRF24L01+
* R0 -> CE
* R1 -> IRQ
* MO -> MO / MOSI (Note: rev2 PCB use SS instead)
* MI -> MI / MISO
* SS -> SS / CSN (Note: rev2 PCB use MO instead)
* SCK -> SCK
2017-09-20 04:05:00 -05:00
* GND -> GND
* 3V -> 3.3V
2017-09-17 01:53:57 -05:00
![surface mount nRF24L01+ module pin out](https://raw.githubusercontent.com/ahtn/keyplus/master/notes/mini-nrf24l01-smd.jpg)
Note: currently the IRQ pin is not used in the code, but I'll add code to take advantage of it soon.
### PCB schematic for rev 2
[Schematic for keyplus mini](https://rawgit.com/ahtn/keyboard_pcb/bb20b354216aa1858254db9946aa67aa8df67bfd/keyplus_mini/rev2/keyplus_mini.pdf)
### Mechanical information for rev 2
![keyplus mini mechanical information](https://rawgit.com/ahtn/keyboard_pcb/bb20b354216aa1858254db9946aa67aa8df67bfd/keyplus_mini/rev2/mechanical.png)
## Layout file format and programming
TODO
For [prebuilt versions of the loader and firmware](https://github.com/ahtn/keyplus/releases).
For the mean time, refer to the
[example layouts](https://github.com/ahtn/keyplus/tree/master/layouts), and the
[list of available keycodes](https://github.com/ahtn/keyplus/blob/master/host-software/layout/mapped_keycodes.py#L8).
## Current firmware limitations
Firmware is still in beta and several features are not completely
finished yet. Some prominent ones:
* Macro and hold keycodes can't be used in the layout config file yet.
* No LED support yet (including indicators)
2017-09-20 05:42:38 -05:00
* Pairing Unifying mouse is not exposed to devices yet
2017-09-17 01:53:57 -05:00
## Testing key matrix
The firmware supports a mode where it will pass the raw keyboard matrix data to
the PC. This can be used to check the row and column pairs in your key matrix.
Currently, this can only be used on the command line using a python script
[`keyplus/host-software/keyplus_cli.py`](https://github.com/ahtn/keyplus/blob/master/host-software/keyplus_cli.py).
To use the keyboard matrix passthrough mode, run `./keyplus_cli.py passthrough`
and you should see output like this:
```
$$ ./keyplus_cli.py passthrough
r3c5
r3c0
r1c0
r0c1
r0c1 r1c1
r1c1
r1c1 r3c3
r3c3
```
Where each line shows which keys in the matrix are currently being pressed.
Note only devices directly connected by USB will report key presses using
passthrough mode.
2017-09-20 04:05:00 -05:00
2017-09-20 05:42:38 -05:00
## Unifying flasher
First working version of the Unifying flashing script can be
[found here](https://github.com/ahtn/keyplus/tree/master/host-software/uniflash).
Currently this script has only been tested on Linux.
There are two types of Unifying receivers that use different microcontrollers:
nRF24LU1+ and CC2544.
Only Unifying receivers that use the nRF24LU1+ are supported.
You can check which kind you have by looking at the firmware version number
of the receiver in Logitech's Unifying Software (or Solaar on Linux). If your
receiver has a firmware number that starts with 12 (e.g. `012.005.00028`), then
it uses the nRF24LU1+. If it starts with 24, then it uses the CC2544.
You can find Unifying receivers on aliexpress. I've tried a few different types
and they have all used the nRF24LU1+.
### How to add dongle to layout file
To be able to use the dongle, you need to add it to your layout file:
```yaml
devices:
nrf_dongle:
id: 7 # unique id that is not used by any of your other devices
scan_mode: # rf dongle, so don't need a matrix
mode: no_matrix # options: col_row, pins, no_matrix
```
Then you need to load the layout file and RF configuration file to the device.
2017-09-17 01:53:57 -05:00
## xusb bootloader
The bootloader installed on the ATxmega is the [xusb bootloader](https://github.com/ahtn/xusb-boot).
To enter bootloader mode press the reset button (or short the RST and GND
contacts) once when the USB cable is plugged in. The device will remain in
bootloader mode until it is programmed, or until the reset button is pressed a
second time. For a more detailed explanation of the bootloader, [see
here](https://github.com/ahtn/xusb-boot#ways-to-enter-the-bootloader).
The lock bits on the ATxmega have been set to disable reading from flash by an
external programmer. This is done to protect the encryption keys that are
stored in flash. Also, for security reasons the bootloader will wipe SRAM on
power up.
2017-09-20 05:42:38 -05:00
## Trouble shooting and known issues
2017-09-17 01:53:57 -05:00
* Make sure that the battery contacts have a firm connection. I've had issues
sometimes with my homemade CR2032 holders where vibrations from typing would
cause the contacts to be unreliable.
2017-09-20 05:42:38 -05:00
* When using the xmega+nRF24L01+ as the wireless receiver, it will sometimes
drop packets [due to this issue](https://github.com/ahtn/keyplus/issues/3).
Should be fixed soon. The nRF24LU1+ implementation doesn't have this problem.
* If you load broken firmware onto the xmega, it won't be visible to the GUI
2017-09-20 05:42:38 -05:00
loader or flashing scripts. In this case you will need to enter it's bootloader
manually by shorting the RST pin to GND while it is connected via USB. The
bootloader is stored in a protected region of flash, so the bootloader should
be unbrickable.
* Currently if you have multiple devices acting as wireless receivers at the
same time, they will interfere with each other. This will be fixed later.