-
Notifications
You must be signed in to change notification settings - Fork 1.7k
Sun Keyboard Protocol
Prebuilt converter is available here: https://geekhack.org/index.php?topic=72052.0
https://github.com/tmk/tmk_keyboard/tree/master/converter/sun_usb
https://geekhack.org/index.php?topic=105671.0
Modern Type 4 and 5 keyboards uses 8Pin mini DIN.
___ ___
/ |_| \
/ 8 7 6 \
| 5 4 3 |
\_ 2 1 _/
\_____/
(receptacle)
Wiring:
Pin mini DIN MCU
----------------------------------
1 GND GND
2 GND GND
3 5V
4 Mouse RX/TX PD4
5 Keyboard RX PD2
6 Keyboard TX PD3
7 GND GND
8 5V VCC
For ATmega32U4 you will have to use other pin than PD4 for Mouse pin.
Signal: Asynchronous, Negative logic, 1200baud, No Flow control
Frame format:
1-Start bit, 8-Data bits, No-Parity, 1-Stop bit
0 ___ ___ ___ ___ ___ ___ ___ ___ ___
1 ____/ \___X___X___X___X___X___X___X___\_______
S 0 1 2 3 4 5 6 7 S
AVR USART engine expects positive logic while Sun keyboard signal is negative. To use AVR UART engine you need external inverter in front of RX and TX pin. Otherwise you can use software serial to communicate the keyboard.
This firmware uses software serial by default, so you don't need any inverter. It can be still built with 'make HARDWARE_SERIAL=y' to enable hardware serial if you have inverter. You can use 74LS04 for example.
0x01 Reset
Keyboard responds with following byte sequence:
Success: 0xFF 0x04
Fail: 0x7E 0x01
0x02 Bell On
0x03 Bell Off
0x0A Click On
0x0B Click Off
0x0E LED
followed by LED status byte:
bit: 3 2 1 0
LED: CapsLk ScrLk Compose NumLk
0x0F Layout(DIP switch)
Keyboard responds with 0xFE 0xXX
bit: 7 6 5 4 3 2 1 0
DIP: x 2 3 4 5 6 7 8(DIP-SW1 is always 0 on Type-5)
- Type-5 keyboard including SHORT TYPE at least starts sending key events without Reset command.
- SHORT TYPE KEYBOARD has no DIP switch and replies fixed value 0x22 as layout.
0xFF sent after power up
0x7F Idle(no keys are pressed)
0xFE Layout(DIP switch) Response
0xFF 0x04 Reset Response(success)
0x7E 0x01 Reset Response(failure)
Signal: Asynchronous, Negative logic, 1200baud, No Flow control
Frame format:
1-Start bit, 8-Data bits, No-Parity, 1-Stop bit
0 ___ ___ ___ ___ ___ ___ ___ ___ ___
1 ____/ \___X___X___X___X___X___X___X___\_______
S 0 1 2 3 4 5 6 7 S
Data Format:
Bit | 7 6 5 4 3 2 1 0
-----+------------------------
Byte1| 1 0 0 0 0 L M R
Byte2| x7 x6 x5 x4 x3 x2 x1 x0
Byte3| y7 y6 y5 y4 y3 y2 y1 y0
Byte4| X7 X6 X5 X4 X3 X2 X1 X0
Byte5| Y7 Y6 Y5 Y4 Y3 Y2 Y1 Y0
X/Y indicates movement recorded after x/y movement occured. In the end you can get total mouse movement by adding like x+X/y+Y.
Sun mouse protcol is compatible with MouseSystems 5-byte mouse protocol.
Confirmed with ball mouse COMPACT 1 model made by Logitech(FCCID:DZLNSUN1).
Tadpole Sparcbook 3GX uses 3-byte format. It is a laptop computer with integrated pointing device. TMK converter won't support this format.
Bit | 7 6 5 4 3 2 1 0
-----+------------------------
Byte1| 1 x 0 0 1 L M R
Byte2| x7 x6 x5 x4 x3 x2 x1 x0
Byte3| y7 y6 y5 y4 y3 y2 y1 y0
- https://github.com/IIJ-NetBSD/netbsd-src/commit/6ced885fb6245db5570929dc7ccfd9bca768dfd6
- https://github.com/IIJ-NetBSD/netbsd-src/commit/468f643f64588ae32a1739982f3fd89e876bd8ed
- http://cvsweb.netbsd.org/bsdweb.cgi/src/sys/dev/sun/ms.c?rev=1.40&content-type=text/x-cvsweb-markup&only_with_tag=MAIN
The converter revision 2.8 or later has mouse suport.
For revision 2.7 or sooner you have to conect two pads with small wire like this pic.
,-------. ,---, ,---------------. ,---------------. ,---------------. ,-----------. ,---------------.
| 76 | | 0F| | 05| 06| 08| 0A| | 0C| 0E| 10| 11| | 12| 07| 09| 0B| | 16| 17| 15| | 2D| 02| 04| 30|
`-------' `---' `---------------' `---------------' `---------------' `-----------' `---------------'
,-------. ,-----------------------------------------------------------. ,-----------. ,---------------.
| 01| 03| | 1D| 1E| 1F| 20| 21| 22| 23| 24| 25| 26| 27| 28| 29| 58| 2A| | 2C| 34| 60| | 62| 2E| 2F| 47|
|-------| |-----------------------------------------------------------| |------------ |---------------|
| 19| 1A| | 35 | 36| 37| 38| 39| 3A| 3B| 3C| 3D| 3E| 3F| 40| 41| 2B | | 42| 4A| 7B| | 44| 45| 46| |
|-------| |-----------------------------------------------------------| `-----------' |-----------| 7D|
| 31| 33| | 4C | 4D| 4E| 4F| 50| 51| 52| 53| 54| 55| 56| 57|+58| 59 | | 5B| 5C| 5D| |
|-------| |-----------------------------------------------------------| ,---. |-----------|---|
| 48| 49| | 63 |+7C| 64| 65| 66| 67| 68| 69| 6A| 6B| 6C| 6D|*6F| 6E | | 14| | 70| 71| 72| |
|-------| |-----------------------------------------------------------| .-----------. |-----------| 5A|
| 5F| 61| | 77 | 13| 78 |*73 | 79 |*74 |*75| 7A | 43| 0D| | 18| 1B| 1C| | 5E | 32| |
`-------' `-----------------------------------------------------------' `-----------' `---------------'
- Japanese specific keys*, ISO key+: https://vtda.org/docs/computing/Sun/hardware/800-6802-12_Type5KeyboardandMouseProductNotes_RevA_Oct93.pdf
https://archive.org/details/bitsavers_sunsparcSPationVer11999_166667/
http://kentie.net/article/sunkbd/page2.htm
https://codeberg.org/xelalexv/suniversal
http://www.rosenau-ka.de/ps2sun/
with Japanese layout support http://shikasan.net/sunkey/sunkey_e.html