KIM Clone Motherboard
![]() |
KIM Clone Motherboard User Manual |
![]() |
KIM Clone Motherboard schematic |
About small SBC systems
KIM Clone Motherboard
![]() |
KIM Clone Motherboard User Manual |
![]() |
KIM Clone Motherboard schematic |
KIM Clone I/O board
![]() |
KIM Clone I/O Board Manual |
The KIM Clone and the 6530 replacement boards both use a 6532 to replace the non-existent 6530-2 and 6530-3 chips that were used on the original KIM-1. These chips haven’t been made by any reputable source in decades, so everyone ends up buying from unknown sources on the internet, usually floor sweepings from China. It takes about 10 minutes to thoroughly test a single chip, so I was looking for a fully automated way to do the testing for me.
Given the expansion bus on the KIM Clone, I designed a really simple little board that takes 256 bytes of otherwise unused memory and maps in a known good 68B21 PIA, a 68B21 under test and a 6532 under test. Add a bit of clever software and all pieces of either the 6832 or 6532 can be tested in a matter of seconds!
This is revision 1 of the board:
It uses one chip to decode the address to see if the address is for this board or not, then another chip to decode which chip on the board is being addressed. As you can see, a third chip was tacked on once it was obvious I had missed something. The lowest chip is the known good 68B21. The empty socket is for a 6821 being tested, and the top socket is a 6532 being tested. The two test sockets were supposed to be ZIF (Zero Insertion Force) sockets but I didn’t make the holes large enough and was forced to use standard 40 pin IC sockets. Both the missing chip and the wrong size holes have been fixed on the rev 2 boards.
There is a separate power switch for the board so I can turn it off and swap chips for testing.
The code is very simple and is just over 1K in size. It tests the RAM and I/O ports fairly well, but the timer section is a bit weak and needs more work. I’m a software person by profession, so once the hardware is solid I can spend an infinite amount of time putzing around optimizing the software.
Let me talk about adding I/O devices that don’t need much address space. On the KIM-1, the space from 1400-17FF is grouped into the K0 block but only 17xx are used, leaving 1400-16FF open for use. To decode that range into four blocks of 256 bytes is easy using a single chip and a few signals from the KIM Clone expansion bus:
Everyone has a 74LS138 in their parts collection, so just connect a few signals from the expansion bus and use one of the three signals from the 138 to decode which block you want to use. Use the A0-A7 address lines to decode into smaller pieces.
Like the original KIM-1, there are 16 I/O lines on the KIM Clone that can be used for your own projects. They are brought to the connector labeled “SD SYSTEM” along the top edge of the board and were meant to plug into one of our SD Card Systems for program storage. However, they are general purpose I/O lines which can be freely used for other things if the SD system is not used.
This is a portion of the schematic showing which pins on the 6532 are connected to which pins on the connector:
Don’t worry about the signal names associated with the various lines, they are the names of those signals when an SD Card System is attached.
As you can see, there are 16 IO lines, 2 ground lines, and 2 lines with +7.5… if you want to draw power from this connector for TTL/CMOS circuits then you need to add your own +5 volt regulator! D2 prevents back-feeding power from the connector back into the KIM Clone.
On the circuit board, pins 1 and 2 are labeled but are covered by the connector, so here is a reference:
All of the odd numbered pins are on the “bottom” row while even numbered pins are on the top. Ie, the top row has pins 2, 4, 6, etc, while the bottom row has 1, 3, 5, etc. Displaying the circuit board traces on the bottom layer of the board you can clearly see the ground and power lines connected to the pins on the far right:
The datasheet for the 6532 RIOT chip is readily available on the internet, but here is an easy one:
http://archive.6502.org/datasheets/mos_6532_riot.pdf
To program the chip you basically need to set the direction of each pin of the I/O port of interest (Port A or Port B), then set the data or read the data. The base address of the chip is 1700 (hex). There are four registers:
Address | Use |
1700 | Data register A |
1701 | Data direction register A. Setting a bit to 1 makes it an output bit, 0 makes it an input. |
1702 | Data register B |
1703 | Data direction register B. Setting a bit to 1 makes it an output bit, 0 makes it an input. |
I needed to test experimental address decoder logic and found it was easier to just plug it into the I/O ports and write some code on the KIM Clone to simulate the addresses and display what the decoder logic did:
Port A simulates address lines A11-A16 and port B has the three decoder outputs (/RAM, /IO, /EEPROM). A small program simulates all possible values of the five address bits, displays the address, reads the decoder inputs and then displays which are active. In about an hour I was able to fix one minor bug in the decoder design and perform a full unit test on how it works. Certainly not a fancy example of using I/O ports, but sometimes it far faster to build a small circuit and use software to test it rather than building a lot of hardware and manually debugging it all.
After building a few dozen KIM Clone boards, I’ve gotten pretty good at optimizing my time at the bench so as to reduce the amount of debugging necessary if a board does not come up the first time. If you want to use my hard-earned advice, feel free to follow my suggestions.
But first…
Do not install all the parts before testing!!!
It is worth repeating…
Do not install all the parts before testing!!!
And yet again in case you missed the previous two warnings…
Do not install all the parts before testing!!!
I am an engineer by profession, and we never, ever, just write thousands of lines of code or build an entire product without testing sub-assemblies, so please follow the advice from someone who has built a lot of KIM Clone boards. One of my many jobs over the years was at a DoD project and they had a motto that is excellent: “Build a little, test a little, learn a lot.”
The thumb drive included with the bare board has a user manual with a BOM (bill of materials). Some parts are very generic, like 1/4 watt resistors, while others are very specific, like the 7 segment LEDs. Unless you are willing to try experiments, I suggest you get the exact components called out. I have provided the manufacturer’s part number and usually a Digikey part number. If you swap components it might work, but I can’t offer much help if it doesn’t.
Capacitors are all .1″ (2.54mm) lead spacing.
All resistors are 1/4 watt.
The first steps are to bring up the power section.
At this point, you should have a functioning KIM Clone! I’d recommend starting a memory test and letting it run at least 30 minutes. So let’s start the memory test by typing an X (all KIM Clone commands are capital letters), then an M, then “2000” and “CFFF”. Sit back, make sure it completes one pass, then go relax. It’s time for a beer.
Now that the base system is running, it’s time to disconnect from power and the USB and start installing the LEDs.
At this point you can actually play a game! Press 1800 on the keypad, then GO. Lunar Lander is running.
You are finished! Go have some fun!
Fix for KIM Clone Single-Step Problem
Rev 1B and rev 2 boards have a problem where single-step mode does not work. It works for old 6502s but not for newer ones nor 65C02. The solution was very simple: add a .001 uf capacitor across U16 pins 7 and 8. All assembled KIM Clones now have the modification and future revisions of the board will have the capacitor on the motherboard.
KIM Clone I/O Not Receiving Serial Data
While testing the KIM Clone I/O Board I was using a real ASCII terminal and everything was working exactly as it should. After the board was in product a dedicated tool was written to run complete tests of the board and the serial port was no longer receiving data.
As it turns out, it is possible to set the various jumpers on the board so that the DCD line on the 6850 is floating, and it tends to float to a state where it ignores incoming data. My test jig simply loops back pins 2 and 3, leaving DCD unconnected.
The easiest solution is to pull the jumper off JP8, then place it between pins 6 and 7 on JP10. This forces the DCD to ground, which allows the receiver to work as expected.
Depending on your application, whatever is connected to the DB-9 might pull DCD to the active state which also allows the receiver to work properly.
Future revisions of the board will have a pull-down resistor on both DCD and CTS so unconnected inputs will default to the proper levels for normal operation of the ACIA.
After almost a year (2019)of on-again, off-again, development we finally have a new revision of the KIM Clone.
It has everything the previous versions have, but with a few improvements people have asked for (or I wanted):
Expansion bus connectors! This was widely requested. Includes most processor signals, address and data buses, along with bank decoding lines. This is intended to plug into either a prototype board (more on this later) or a motherboard (in the works).
More jumpers to enable/disable blocks of RAM from being decoded. K1-K4 each have jumpers, and 8K blocks for the entire memory map have another set of jumpers. This allows blocks to be disabled on-board, then mapped to a user-supplied circuit.
Power on reset. Not a major feature, but I didn’t like having to press RS every time I turned on my KIM-1.
Power connector and the power switch moved to the top edge of the board.
![]() |
KIM-1 Clone Rev 5 User manual |
![]() |
KIM-1 Clone Rev 5 User manual, other version |
The first version that support expansion connectors.
![]() |
KIM-1 Clone Rev 4 User manual |
Changes between Revision 2 and Revision 3 Boards
Revision 3 boards had a number of minor changes to fix know issues on Revision 2 boards. No new features or capabilities were added.
– IC19 was removed
–IC18 changed from 74AVC1T45 to 74LVC1T45
– IC16 changed to 74LS00
– IC7 and IC8 changed to 74LS145
– R37 and R38 changed to 470 ohms
– C18 was added
– IC17 had power routing fixed
![]() |
KIM-1 Clone Rev 3 User manual |