mirror of
https://github.com/osiweb/unified_retro_keyboard.git
synced 2025-01-02 14:32:20 +00:00
124 lines
5.3 KiB
Markdown
124 lines
5.3 KiB
Markdown
# ASCII Interface - Atmega328p
|
|
|
|
This is is a key scanner module with parallel output, and optional serial
|
|
output, supporting keyboards of up to 16 rows X 8 columns.
|
|
|
|
The ATMega 328P was selected for the sole reason that it is an architecture
|
|
familiar to many hobbyists, with an accessible programming environment and
|
|
ecosystem, in a DIP format that fits the retro look and is easy to solder for
|
|
most hobbyists. All of the ICs, other than the microcontroller, are only present
|
|
to compensate for the limited number of GPIO lines on this small 28-pin
|
|
microcontroller. Using a bigger chip would greatly simplify the hardware and
|
|
even slightly simplify the hardware layer of the firmware.
|
|
|
|
<img alt="Assembly Rendering" src="images/PCB-assembly-rendering.png" height=75% width=75%>
|
|
|
|
## Features
|
|
- Parallel or serial output
|
|
- Up to 8 configuration settings via an up-to-8 position DIP switch
|
|
- Apple 1, Apple 2, and SOL-20 compatible outputs. Other configurations can be
|
|
supported by making a custom cable.
|
|
- Can decode arbitrary keyboards up 16 rows by 8 columns.
|
|
- Supports up to 3 keyboard LEDs
|
|
- Supports up to 3 "special" host outputs, such as RESET, SCREEN_CLEAR, BREAK, etc.
|
|
|
|
## Overview
|
|
- The keyboard rows are driven by a pair of 74LS138 decoders, allowing 4 GPIO
|
|
lines to drive 16 rows.
|
|
- The columns are read in via an 8-bit shift register, controlled by 3 GPIO lines.
|
|
- One 8-bit port is used for the parallel ASCII output.
|
|
- Three GPIO lines are used to generate special outputs to the host. These could
|
|
be RESET, BREAK, CLEAR, etc. Two of these may be configured as emulated
|
|
open-collector drivers.
|
|
- Three GPIO lines are used to control keyboard LEDs.
|
|
- The DIP switch is wired into row 8 (of 0-15) to reduce RAM usage and speed up
|
|
key scanning.
|
|
|
|
- The top two parallel I/O bits can also be configured as UART I/O. This could
|
|
be used to provide serial output instead or parallel output, to support a
|
|
bootloader, or even to accept a serial input stream from another computer to
|
|
send to the host as parallel ASCII data. This last application would require
|
|
careful timing to avoid conflicts.
|
|
|
|
## Assembly Notes
|
|
|
|
A typical build includes:
|
|
1. the Microcontroller (U1)
|
|
1. the 74LS166 shift register (U2)
|
|
1. both 74LS138 decoder (U3)
|
|
1. Diodes D17-D24 and D25-D27.
|
|
1. The two resistors R3 and R4. If you are using the keyboard in only a parallel
|
|
configuration or only a serial configuration, then you can jumper these
|
|
resistors with a piece of wire.
|
|
1. The resistor network RN1
|
|
1. The DIP switch SW1
|
|
1. The 40-pin keyboard connector (2x20 0.1" pin header)
|
|
1. At least one output connector (Apple 1, Apple 2, or Sol-20)
|
|
1. The 6-pin programming header J5.
|
|
|
|
The MINIMUM functioning circuit includes
|
|
1. the Microcontroller (U1)
|
|
1. the 74LS166 shift register (U2)
|
|
1. One 74LS138 decoder (U3). Without the second decoder, the DIP switch is not
|
|
supported, so only one keymap must be assigned as keymap 0 at compile time.
|
|
1. The resistor network RN1
|
|
1. The two resistors R3 and R4. If you are using the keyboard in only a parallel
|
|
configuration or only a serial configuration, then you can jumper these
|
|
resistors with a piece of wire.
|
|
1. Any connectors required.
|
|
|
|
## Optional components
|
|
### Diodes D1-D16
|
|
NOT NORMALLY POPULATED.
|
|
|
|
These diodes are intended to prevent conflicts between
|
|
high and low keyboard driver outputs. They allow the row drivers to pull rows
|
|
low, but not high, emulating open collector outputs.
|
|
|
|
If you are attaching a keyboard with no diodes, then you only need to populate
|
|
the diodes corresponding to rows on the keyboard. If the keyboard has 8 rows,
|
|
then you may want to install 8 diodes corresponding to those rows.
|
|
|
|
Note that the footprints for these diodes include a copper jumper on the TOP
|
|
copper layer. If you install any of these diodes, you should cut the jumpers for
|
|
those diodes. Otherwise the diodes would do nothing.
|
|
|
|
If you are attaching a keyboard with a diode per key, then the diodes on the
|
|
keys perform the same function, in addition to preventing "ghosting", so the
|
|
per-row diodes do not need to be installed.
|
|
|
|
### DIP switch and associated diodes
|
|
TYPICALLY INSTALLED.
|
|
|
|
If you don't want to select keymaps or options via the DIP
|
|
switch, then you may omit the DIP switch and diodes. If you do this, then you
|
|
will have to set the keymap and all preferences in the firmware. DIP switches,
|
|
you can set all your preferences in the firmware, or just accept the default
|
|
behavior, and skip the DIP switch and Diodes D17-D20 and D24-D27.
|
|
|
|
### Second 74LS138 multiplexer (U4)
|
|
TYPICALLY INSTALLED.
|
|
|
|
You may omit this if
|
|
1. your keyboard matrix has 8 rows or fewer
|
|
1. AND you don't want any DIP options
|
|
1. AND you only want one pre-compiled keymap.
|
|
|
|
|
|
### The 74LS07 hex buffer (U5) and pullup R6
|
|
TYPICALLY INSTALLED.
|
|
|
|
The 74LS07 is needed if you are using LED2 or LED3 on the keyboard, or the OUT2
|
|
open collector output. If OUT2 is not open collector, then use a 74LS04 instead.
|
|
|
|
### Diodes D21, D22, D23
|
|
TYPICALLY INSTALLED.
|
|
|
|
Some keyboards may not wire all keys into the matrix. For example, some other
|
|
interface modules may assign special hardware functions to certain keys. Those
|
|
keys are brought directly to the keyboard connector. For the classic keyboard,
|
|
the POWER key, the '@' key, and the RUBOUT key are not directly wired. This
|
|
module wires them into the matrix via D21, D22, and D23, respectively. For
|
|
keyboards with no separately wired keys, these diodes may be omitted.
|
|
|