post

The story of the KIM-1

The story of the KIM-1 (from Ch.1.5 of “On the Edge: the Spectacular Rise and Fall of Commodore”)

MOS Technology developed a second system concurrently with the TIM. This computer was slightly more user friendly – at least by 1975 standards. Rather than a chip and some instructions, this system arrived fully assembled, except for the power supply. It was a true development system.
The inspiration for the new computer came from Don McLaughlin, MOS Technology founder and engineering manager of the project. Peddle recalls, “McLaughlin said, ‘Listen, I think this is a product that will help sell the [6502]’. They thought it was a good idea because they were calculator guys.” Peddle and a programming manager named Bob Winterhalt agreed with the idea and the three men began the design.
According to MOS Technology employee Al Charpentier, his friend and fellow engineer performed the actual hands-on design work of the system. “That was done by a guy by the name of John May,” recalls Charpentier. “He was sort of the primary mover on that project.”
At this early stage in microcomputer development, user-friendly personal computers were barely on the horizon. Niceties like a video monitor, keyboard, software, power supply, or an enclosure were not part of most designs. The recently released Altair relied on switches for input and blinking lights for output. Any other interfaces had to be added by the user. By today’s standards, it was comically impossible for most people to contemplate using these machines.
This new sibling of TIM would share similarities, but differ in a few areas. As with the TIM, this unit would contain a 6502 processor running at one megahertz. However, McLaughlin advanced TIM’s basic design slightly, branching out in a unique direction. Instead of reading data from a row of flashing lights, the new computer would contain a six-digit display. Each digit in the display had seven segments, which could display numbers and letters. The primitive display was a step up from tiny lights representing binary digits used on most other systems. McLaughlin also improved on the basic input method for personal computers at the time. Rather than a row of switches for binary input, McLaughlin specified a keypad. John May eventually selected a black keypad with 23-buttons. This was a remarkable improvement over other microcomputers of the time, allowing users to enter code more easily.

Both the keypad and the LED display reside directly on the surface of the printed circuit board (PCB), along with over a hundred precariously exposed components. The lack of a case or a power supply for the new computer clearly indicated MOS Technology was not targeting the machine for the mass market. A careless user could easily damage the machine..
Little TIM provided a paltry 256 bytes of memory, hardly enough to store three lines of characters on an 80-character computer display. TIM’s bigger brother would contain a full kilobyte of memory, comprised of eight MOS Technology 6102 memory chips. At the time, 1024 bytes was a generous amount. There was even room for expansion. Two 44-pin edge connectors made data and control signals available to the builder for additional functionality.

Prototype KIM-1
On team6502  I found a photo of a prototype KIM-1 at MOS Technologies, Terry Holdt has this in his office.
The layout is different from the final product, everything seems to be present on this prototype.

Although the two development teams were separate, they shared as much code as possible. To support a teletype machine, John May used the code from the TIM system. The 2-kilobyte program, also named TIM, contained the code to operate a cassette tape unit for storage, drive the alphanumeric display, and accept input from the 23 keys of the keypad. It also contained a monitor program, which allowed users to view memory contents and change code. A tiny bootstrap program would automatically start the monitor on reset. This was the pinnacle of user friendliness in 1975.
The name for this new computer followed the tradition set by TIM. The TIM allowed input from a terminal, hence Terminal Input Monitor. The new system allowed input from a tiny black keyboard, so McLaughlin dubbed it the Keyboard Input Monitor, or KIM. They also added a number after the computer name, a practice later continued by Commodore. It contained one kilobyte of memory, hence KIM-1. 2
Former MOS Technology engineer Robert Yannes owns the first KIM-1. “I have a very rare thing that I scavenged out of scrap heap at MOS Technology: the original prototype KIM-1, and it still works. It’s a little bit different than what went into production,” he says.

In the middle of 1975, MOS Technology began selling the KIM-1. Buyers who sent away for their KIM-1 were pleasantly surprised to have a rectangular cardboard box arrive from “MOS Microcomputers”, a short-lived division of MOS Technology. The KIM-1 circuit board arrived sealed in a black static-proof bag, surrounded by thick foam padding with manuals and documentation on top. The documentation included with the KIM-1 went beyond other computers of the day. There were three manuals – a 200-page 6502 programming manual (written by Peddle under duress), a 100-page KIM-1 user manual, and a 150-page hardware manual. The writing was friendly, concise, and detailed. Most importantly, it did not assume the user knew everything about computers already. The KIM-1 user manual promised, “You should be able to achieve initial operation of your KIM-1 module within a few minutes.” Of course, this assumed you had access to a 5 volt, 1.5 ampere power supply. A 12 volt supply was required if the cassette tape was to be used. For those in doubt, the manual contained complete instructions and a parts list for building a power supply. Once the power supply dilemma was solved, the user hit the RS (reset) key to start using the system. This started the TIM monitor program running from ROM, which displayed numbers and accepted input from the keypad. Unlike today’s systems, the KIM-1 contained no on-off switch.
Users then began the exacting process of entering code into the machine in order to make KIM do something. After entering all the data, it was simple to run the program – just set the computer to the address where the program began and hit the GO button. If the program misbehaved, the KIM-1 also had a switch on the keypad labeled SST (single step). This would cause the computer to execute the program one instruction at a time. Users appreciated this important feature, which greatly assisted in debugging.
The built in cassette-tape interface of the KIM-1 proved indispensable for early hobbyists because it allowed them to save and load their work. In contrast, users of the MITS Altair had no way to save programs with their basic system. They would sit in front of their machine, laboriously flipping switches to enter their program into memory. If someone happened to trip on the power cord, the programmer had to start all over again.
The tape-interface alone made many KIM-1 owners fall in love with the computer, and many praised it for its reliability. Tape storage was the perfect medium for a 1-kilobyte computer. Programs loaded and saved rapidly, and dozens of programs fit onto a single cassette. Of course, a cassette recorder was not included with the KIM-1, so it was up to the user to find one. It was also up to the user to connect it to the KIM-1 by interfacing the microphone input and speaker output jacks to the gold-plated IO pins of the KIM-1.
Another advanced feature of the KIM-1 was its ability to connect directly to a Teletype machine or computer terminal through a built-in serial interface. Teletype machines were large electromechanical devices with the ability to enter data through a keyboard, print hard copy, and load and save data via punched paper tape. A noteworthy feature of the KIM-1 was its ability to automatically adjust to the speed of the teletype connected to it. People were amazed to see the tiny KIM-1 operating a massive piece of hardware normally connected to minicomputers or mainframes. This helped to convince skeptics that microcomputers were true computers. As it turned out, however, many people preferred using the LED display and keypad to the noisy, messy, and costly teletype machines.

The KIM-1 debuted during Wescon in Chuck Peddle’s hotel suite, along with the 6502 and other development systems. Users received the small computer enthusiastically. Al Charpentier recalls, “They sold a lot of those. It was sort of the first fully packaged microcomputer that you could take out of the box, throw a power supply on, and do something with. It was hell, but it educated people on the processor.”
Engineer Robert Yannes recalls KIM-1 engineer John May showing the machine at his college. “I had a lot of familiarity with the KIM-1,” says Yannes. “The guy who designed that was actually a friend of Al Charpentier’s, and he was a Villanova graduate too. He had brought it to Villanova University when it first came out and I had gone to that presentation. They had KIM-1’s at Villanova too, so I ended up playing with them.”
“The KIM-1 had one characteristic that everybody always commented on,” says Peddle. “It was a packaged, complete, plug-it-in-and-start-using-it product. You could sit down and learn to program using my manuals.”

Early Competition

In December 1975, the coveted inside front cover of BYTE magazine contained a two-page advertisement for ‘the world’s lowest cost computer system’. Though it contained a 6502 microprocessor, it was not the KIM-1. It was the Jolt computer, sold by Microcomputer Associates either as a kit for $249 or fully assembled and tested for $348. Jolt, named after Rod Holt who helped develop the TIM and KIM-1 code, was technically similar to the TIM computer. Although Jolt competed with the KIM-1, Peddle did not object. “Manny just said, ‘We want to do this board of our own’, and I said ‘great’”, explains Peddle. “I was looking for anything that would help customers design with the [6502] product. We gave these guys the license.” Nonetheless, Jolt did not have lasting popularity with the hobbyist market. Jolt’s most notable achievement lies in its use as the platform for the Atari 2600 VCS prototype system.
The Jolt advertisement in Byte did much to influence MOS Technology. A few months later, in the April 1976 issue of BYTE Magazine, a new product announcement appeared for the KIM-1 titled, ‘What’s New, KIM-o-sabee?’ There was also an advertisement from MOS Technology itself. The low-key ad, stating the features in KIM-1 in point form, included a clip-out order form for a $245 KIM-1 microcomputer system. Anyone who understood computers recognized the potential immediately.
The advertisement in BYTE caught the attention of the hobbyist market. A month later, BYTE ran a feature article titled, ‘A Date with KIM’. Byte contributor Richard Simpson gushed about the low price and quality of the feature-packed KIM-1. He accurately identified it as the ideal system for anyone who did not want to assemble a kit. The KIM-1 subsequently became a favorite of BYTE and other popular homebrew publications, such as Dr. Dobbs Journal, Kilobaud, and Interface Age. Articles and projects appeared in these magazines well into 1979.

Advertisement for KIM-1 in BYTE Magazine.

MOS Technology released the KIM-1 in 1975, the same year as the Altair 8800 computer. The Altair has come to be known as the first computer system in North America to herald the new microcomputer revolution. The differences between the KIM-1 and the Altair computer illustrate a split in design philosophy within the computer world. The KIM-1 was a single-board computer, with all components mounted on a single printed-circuit board. It had room for expansion, but there were no slots to insert adapter cards. This design philosophy reduced production costs and thus gave the KIM-1 a major pricing advantage over the Altair. Commodore computers would follow this tradition of containing everything on a single board, with specialized user ports for peripherals. The Altair 8800 used an Intel 8080 chip, which retailed for $360, but Ed Roberts was able to negotiate the price down to $75 each in bulk. Still, he needed to sell his computers for $439 in kit form, and $621 assembled to make a profit. MOS Technology was able to profitably sell KIM-1 systems for $245.
Though it was not a true personal computer, MOS Technology soon discovered the KIM-1 had a large market. “That was one of the things that took MOS by surprise,” recalls Bob Yannes. “Throughout the early days of computers, one of the most successful computers introduced in that timeframe was the KIM-1.
“They had developed the KIM-1 as a sort of sales tool for the 6502 processor. They would say, ‘Here’s a development system for you, you can design your own computer system and develop your software on the KIM-1 and help understand the hardware architecture and so forth.’ And people would use them and say, ‘Why do we want to design our own computer? We have one right here and it’s only [$245], which is cheaper than we can build it for.’ They would just buy KIM-1’s and bury them in their products.”
Hobbyists began enthusiastically calling and writing for the kit. Though the goal had been to drum up interest in the 6502 chip, it soon became apparent that microcomputers would also be a valuable source of revenue for the company. According to Kilobaud magazine, MOS Technology sold over seven thousand KIM-1 computers by June 1977. At $245 each, revenue was in the millions, which helped MOS pull through a tough financial period. “They sold a lot,” says Charpentier. “By God, they sold thousands of them – ten thousand or something like that. It was a big number of processors back then.” There was an obvious demand for computers.
The appeal of the KIM-1 was not lost on Chuck Peddle. “It was a complete package, and there are a lot of people who bought it just for that reason and learned something, and then said ‘Okay, that’s all I can do.’ But we were seeing those people and talking to them and getting feedback.”

The Seeds of the Software Industry

While the early microcomputer industry focused on hardware, very few people focused on software, with the notable exception of Bill Gates. As a result, there was a conspicuous absence of quality microcomputer software. Byte magazine noted this in December 1975, describing the situation as a “software vacuum”.
But when it came to software, the KIM-1 had an advantage over other microcomputers. The single board design resulted in a homogenous population of computers, which guaranteed programs would work from one system to the next. The simple operating system put all KIM-1 users on equal footing, so programmers knew their programs would run on all standard KIM-1 computers. Distributing the programs was also easy due to the standard tape-interface. Soon, programmers began copying and distributing their code on low cost audio tapes.

MOS Technology sold one of the earliest KIM-1 software packages at a time when no one knew what might appeal to users. One obvious application was number crunching. The 6502, like all chips at the time, could not perform many mathematical functions – it could add and subtract numbers; all other operations were iterations of these two functions and had to be coded by the developer. MOS Technology developed a program called KIMATH, which effectively transformed the KIM-1 into a full-function calculator. KIMATH also added the capability to handle decimal numbers with high precision. As usual, the MOS Technology documentation included with the software was outstanding, complete with a manual and assembler source code.

Another early favorite of development was music. Since the KIM-1 did not contain a native sound device, users connected a small piezoelectric speaker to a few pins on the IO port. Other hackers found a way to play music by recording beeps to the cassette tape. Once they recorded the music, they ejected the tape and played it back in an audio cassette player.
The seventies was the age of hardware hacking (hacking is used here in its original positive sense – describing experimentation in the pure spirit of inquiry), and hardware projects proved popular among KIM-1 users. One gifted 12-year-old hacker, Tod Loofbourrow, created a 70 pound, six foot tall robot using the KIM-1. Hayden Publishing approached Loofbourrow to write a book about his robot, which he subsequently wrote on yellow-lined paper. He titled his book, How to Build a Computer Controlled Robot, and it went on to become a successful publication.3

The calculator-like KIM display would seem to be a poor candidate for playing games, but games were among the most popular programs for the KIM-1. Most game adaptations were simple pen and paper mind-challenges, which ranged from the well known (Tic-Tac-Toe, Hangman, Mastermind, Maze) to the obscure (Hunt the Wumpus, NIM, Shooting Stars).
Programmers had to design their games for the minimal KIM-1 display which meant that they often had to rely on the imagination of the player. In Maze, the player could only see the walls directly surrounding the small blinking avatar. Hunt the Wumpus required the player to use a pencil and paper for working out a strategy. With such concessions, most mind games were easily adapted.
Gambling and card games were also especially well suited to the limited display. Programmers learning their craft created Blackjack, Craps, Bandit (Slot Machines), and a horseracing game.
Surprisingly, programmers even tried action games. These primitive games went by such names as Duel, Farmer Brown, Ping-Pong, and Asteroid. Duel was notable as being one of the earliest two-player games on a microcomputer. It was a simple but fun reflex game where each player watched the display and tried to hit their button first when a character appeared.
No one attempted to sell any of this early software. Programmers shared their games, copied them to tape, and widely distributed them to whoever wanted a copy. They saw games as a way to learn about programming while creating something fun. Most of these early games lived on in more advanced computers years later.
One of the earliest KIM-1 users enjoying these primitive games was Chris Crawford. Crawford delighted in the choices these games allowed and eventually programmed his first computer game using a KIM-1. Years later, Crawford developed famous games for Atari and became influential in game design theory.

Another early programmer who would gain recognition in the industry was Jim Butterfield. For Butterfield, using a KIM-1 was an adventure in exploration. His goal was to uncover the hidden secrets of the KIM-1 and pass that knowledge on to other users. Jim has the rare ability to understand complex subjects and describe them in simple terms. One of the biggest barriers to learning about microcomputers in those days was the problem of communicating knowledge since the average hacker seemed to be speaking a different language. Butterfield allowed those on the outside to enter the world of programming in comfort.
At gatherings with other KIM-1 users in his native city of Toronto, Butterfield presented his new finds to an attentive audience seeking to unlock the mysteries of the computer. One of his most popular programs was a game. The Apollo moon missions had always been closely associated with computers and the vivid pictures were still in Jim’s mind in the mid-seventies. This inspired him to write Lunar Lander, a simulation of landing on the moon. The game started with the user at the controls of a lunar module 4500 feet above the moon’s surface, and slowly descending. Players used the number keys to control the throttle. To add a sense of urgency, there were only 500 units of fuel to expend. If a player set the throttle too high, the rocket soon used all its fuel and crashed into the surface..
Rather than try to represent the scenario graphically, Jim chose to display the altitude, fuel, and rate of decent as numbers. Anyone playing would have to imagine himself huddled in a capsule with only the instrument readings to guide him. Four glowing red LED digits displayed the altitude and the right two digits represented the rate of descent.
Lunar Lander might seem primitive by today’s standards, but back in 1975 board games were the most popular games available. Snakes and Ladders, Monopoly, and Checkers were the pinnacle of gaming, so something like Lunar Lander was futuristic by comparison. Lunar Lander was a hit at conventions and gatherings, where it fascinated hobbyists. Part of the appeal was the adventure element. Individual landings could last five minutes or more, so players could become deeply engaged in a single game. For a grueling stretch while the lander descended, a player would intently study the rate of decent versus the altitude, and occasionally glimpse the fuel gauge. After four minutes, the lander would be close to the surface, and tension began to mount. If everything went just right, the player was rewarded with a SAFE message. More often, fuel ran out and the module went crashing into the lunar surface as the dreaded DEAD message flashed onto the screen.4

Jim Butterfield also created a small utility called Hypertape, which had an impact on the KIM-1 user community. Butterfield was having lunch with a friend who also owned a KIM-1, and mentioned that the unusual circuitry of the KIM-1’s cassette tape input would make it possible to enhance the speed of tape reading. “You don’t need all those 1’s and 0’s written on the tape,” he said. The friend, Julien Dubé, asked how that could be accomplished and Jim outlined his approach. The next day, Julien reported a speedup of three times. Feeling that this was a challenge, Jim looked more closely at the code, and found extra ways to accelerate the format. The final version of the program allowed data to be written six times faster. A full one-kilobyte program now only took 20 seconds to load with the standard KIM-1 system, as opposed to the regular two minutes.

Commodore Chessmate: a 6530 computer

The Chessmate is a 6530 – KIM-1 like computer. Keyboard, LED display are used as in the KIM-1. Peter Jennings, who designed this chess computer with Commodore, build upon his Microchess 1. from the KIM-1, and used the extra ROM space to enhance it to Microchess 1.5: more chess features, a chess clock, sounds, dedicated keys, status LEDs.

The 6530-024 delivers the I/O and timer and RAM used by the Chessmate, the RRIOT ROM is not used by the main ROM. The dumped ROM of the 6530 (see below) contains no recognizable data or program,

It will not be that difficult to ‘clone’ this chess computer with the information here. A 6532 can easily take the role of the 6530. A 6502 instead of a 6504, same SRAM< a 2732 or similar ROM. The ROMs  are dumped, both for an Chessmate and a Novag Chess Champion MK I

Schematic, user manual, dumped ROMs here.

Commodore Chessmate: 6530-024 RRIOT

The Chessmate is a 6530 – KIM-1 like computer. Keyboard, LED display are used as in the KIM-1. Peter Jennings, who designed this chess computer with Commodore, build upon his Microchess 1. from the KIM-1, and used the extra ROM space to enhance it to Microchess 1.5: more chess features, a chess clock, sounds, dedicated keys, status LEDs.

The 6530-024 delivers the I/O and timer and RAM used by the Chessmate, the RRIOT ROM is used by the main ROM as a Chess openings book.

It will not be that difficult to ‘clone’ this chess computer with the information here. A 6532 can easily take the role of the 6530. A 6502 instead of a 6504, some SRAM, a 2732 or similar ROM. The ROMs are dumped, see below.

On this page:

My Chessmate


Technical specifications

  • MOS MPS 6504 1 MHz 4 KB ROM 320 bytes RAM total
  • 6530-0024 RRIOT (of which I/O lines, timer and 64 bytes RAM are used, ROM has data as chess openings book
  • 256 SRAM (2x 2111)
  • 4K ROM (6332), early models have 2x 2K ROMs
  • Display: Four 7 Segment LED type (which indicates either the move or the time)
  • 19 membrane keys
  • LEDs for Check, Chessmate, or whether the computer is playing black or white
  • Eight skill levels
  • Piezo loudspeaker for 14 Electronic sounds
  • Built-in chess clock
  • The computer has 32 International standard openings in its memory and tries to follow them for 16 moves
  • Chessmate plays black or white
  • Can verify position of pieces at any stage of the game
  • En passant and castling
  • Playing strength (DWZ/ELO): ca. 1050

Related, identical specifications and hardware, and the same software, images below:

  • Novag Chess Champion MK II (A)
  • Novag Chess Champion MK II (B)
  • TEC Schachcomputer

Memory map (deduced from disassembled source and hardware schematic, note that for the 6504 this is collapsed to the smaller address space 0000-1FFF. The software is written for the 6502 though!
$0000 – $01FF RAM 256 bytes, stack and zeropage mirrored
$8B00 – RRIOT I/O
$8B80 – RRIOT RAM 64 byte
$8C00 – $8FFF RRIOT ROM
$F000 – $FFFF Main ROM

Manuals and ROM dumps

Commodore Chessmate manual
Another Commodore Chessmate manual
ROMs of early Commodore Chessmate, in two 2K parts
and later main 4k ROM and the 630 024 RRIOT ROM
ROMs of Novag Chess Champion MK II
(Main 4k ROM and 630 024 RRIOT ROM, identical to Commodore ROMs!
Novag Chess Champion MKII manual
Partially commented source by me of the ROM of the Chessmate


Notes on the 6530 024 RRIOT

Michael Gardi helped me discover the following about the use of the RRIOT in the Chessmate, comments added to the source:
1. The timer is used for the random selection of openings.
CKINT = $8B0E
F38D AD 0E 8B LDA CKINT
2. The openings are stored in the RRIOT 1K ROM at $8C00
3. The RRIOT Timer is also used to implement the CHESSmate chess clock mode, see the source.

Opening book deciphered

The Chessmate chooses at random an opening from the opening book, which is in the 1K ROM of the 6530 024 RRIOT.
The first thing that pops out is that 28 of the 32 openings start with either D2-D4 (10) or E2-E4 (18). That explains the very high percentage of the time that these occur when openings are randomly selected. The Operation Instructions explicitly states that CHESSmate chooses one opening at random and tries to follow it for 16 moves

Micheal Gardi deciphered the coding of the openings:
There are 32 bytes for each opening representing 16 moves. Even bytes represent start positions and odd bytes represent end positions. A pair of bytes make a move. Moves alternate between white and black starting with white. Each byte represents a position on the chess board. The high nibble is the rank (row 1-8) and the low nibble the is the file (column A-H).


col_table = ['H','G','F','E','D','C','B','A']
row_table = ['1','2','3','4','5','6','7','8']

with open("Opening Book.bin", 'rb') as f:
    buffer = f.read()
   
    # For each line.
    ent_file = []
    even = 0
    address = 0x8C00
    for i in range(0,len(buffer),2):
        if i % 32 == 0:
            ent_file.append("\n")
            ent_file.append(hex(address))
            ent_file.append(": ")
            address += 32
        # Assume bytes are contiguous.
        if (even % 2) == 0:
            ent_file.append(col_table[buffer[i]&0x0F]+row_table[buffer[i]>>4]+"-"+
                            col_table[buffer[i+1]&0x0F]+row_table[buffer[i+1]>>4] +", ")   
        else:
            ent_file.append(col_table[7-(buffer[i]&0x0F)]+row_table[7-(buffer[i]>>4)]+"-"+
                            col_table[7-(buffer[i+1]&0x0F)]+row_table[7-(buffer[i+1]>>4)] +", ")
        even += 1     
    ent_file.append('\n')
    
    # Output the result.
    with open("Opening Book Dump.txt", 'w') as f:
        f.write(''.join(ent_file))

Running that code delivers this

8c00: E2-E4, E7-E5, G1-F3, B8-C6, B1-C3, G8-F6, F1-B5, F8-B4, E1-G1, E8-G8, D2-D3, D7-D6, C1-G5, B4-C3, B2-C3, D8-E7
8c20: D2-D4, D7-D5, C2-C4, D5-C4, G1-F3, G8-F6, E2-E3, E7-E6, F1-C4, C7-C5, E1-G1, A7-A6, D1-E2, B8-C6, B1-C3, C5-D4 
8c40: F2-F4, D7-D5, E2-E3, G8-F6, G1-F3, C7-C5, B2-B3, E7-E6, C1-B2, B8-C6, F1-B5, C8-D7, E1-G1, F8-D6, D2-D3, D8-C7 
8c60: E2-E4, E7-E5, F1-C4, G8-F6, D2-D4, E5-D4, G1-F3, F6-E4, D1-D4, E4-F6, C1-G5, F8-E7, B1-C3, C7-C6, E1-C1, D7-D5 
8c80: E2-E4, C7-C5, G1-F3, B8-C6, D2-D4, C5-D4, F3-D4, G8-F6, B1-C3, D7-D6, F1-E2, G7-G6, C1-E3, F8-G7, E1-G1, E8-G8 
8ca0: E2-E4, C7-C5, B1-C3, B8-C6, G2-G3, G7-G6, F1-G2, F8-G7, D2-D3, E7-E6, C1-E3, D7-D6, G1-E2, C6-D4, E1-G1, G8-E7
8cc0: E2-E4, E7-E5, G1-F3, B8-C6, F1-C4, F8-C5, C2-C3, G8-F6, D2-D4, E5-D4, C3-D4, C5-B4, B1-C3, F6-E4, E1-G1, E4-C3 
8ce0: G1-F3, G8-F6, C2-C4, C7-C5, D2-D4, C5-D4, F3-D4, E7-E6, B1-C3, F8-B4, C1-D2, E8-G8, E2-E3, B8-C6, F1-E2, D7-D5 
8d00: E2-E4, E7-E5, G1-F3, G8-F6, F3-E5, D7-D6, E5-F3, F6-E4, D2-D4, D6-D5, F1-D3, F8-D6, E1-G1, E8-G8, C2-C4, C7-C6 
8d20: D2-D4, G8-F6, C2-C4, E7-E6, G2-G3, D7-D5, F1-G2, D5-C4, D1-A4, B8-D7, A4-C4, A7-A6, G1-F3, B7-B5, C4-C6, A8-A7
8d40: E2-E4, G8-F6, E4-E5, F6-D5, D2-D4, D7-D6, C2-C4, D5-B6, F2-F4, D6-E5, F4-E5, B8-C6, C1-E3, C8-F5, B1-C3, E7-E6 
8d60: D2-D4, F7-F5, C2-C4, E7-E6, G1-F3, G8-F6, G2-G3, F8-E7, F1-G2, E8-G8, E1-G1, D7-D5, B1-C3, C7-C6, C1-F4, D8-E8 
8d80: E2-E4, E7-E5, G1-F3, B8-C6, F1-C4, G8-F6, D2-D4, E5-D4, E1-G1, F6-E4, F1-E1, D7-D5, C4-D5, D8-D5, B1-C3, D5-A5 
8da0: D2-D4, G8-F6, C2-C4, E7-E6, B1-C3, F8-B4, D1-C2, B8-C6, G1-F3, D7-D6, C1-D2, E6-E5, A2-A3, B4-C3, D2-C3, D8-E7 
8dc0: E2-E4, B8-C6, D2-D4, D7-D5, E4-D5, D8-D5, G1-F3, E7-E5, B1-C3, F8-B4, C1-E3, C8-G4, F1-E2, E8-C8, E1-G1, D5-A5 
8de0: D2-D4, D7-D5, C2-C4, E7-E6, B1-C3, G8-F6, C1-G5, B8-D7, G1-F3, F8-B4, C4-D5, E6-D5, E2-E3, C7-C5, F1-D3, D8-A5
8e00: D2-D4, D7-D5, C2-C4, C7-C6, G1-F3, G8-F6, B1-C3, D5-C4, A2-A4, C8-F5, F3-E5, B8-D7, E5-C4, D8-C7, G2-G3, E7-E5
8e20: E2-E4, E7-E5, G1-F3, B8-C6, F1-B5, D7-D6, D2-D4, C8-D7, B1-C3, G8-F6, E1-G1, F8-E7, F1-E1, E5-D4, F3-D4, E8-G8 
8e40: D2-D4, D7-D5, C2-C4, E7-E6, B1-C3, C7-C5, C4-D5, E6-D5, G1-F3, B8-C6, G2-G3, G8-F6, F1-G2, C5-D4, F3-D4, F8-C5 
8e60: E2-E4, E7-E5, G1-F3, B8-C6, F1-B5, A7-A6, B5-C6, D7-C6, D2-D4, E5-D4, D1-D4, D8-D4, F3-D4, C8-D7, B1-C3, E8-C8 
8e80: D2-D4, C7-C5, D4-D5, D7-D6, C2-C4, G7-G6, B1-C3, F8-G7, E2-E4, G8-F6, F1-E2, E7-E6, C1-G5, E8-G8, G1-F3, E6-D5 
8ea0: E2-E4, E7-E5, G1-F3, B8-C6, D2-D4, E5-D4, F3-D4, G8-F6, B1-C3, F8-B4, D4-C6, B7-C6, F1-D3, D7-D5, E4-D5, C6-D5 
8ec0: D2-D4, G8-F6, C2-C4, G7-G6, B1-C3, F8-G7, E2-E4, D7-D6, F2-F3, E7-E5, D4-D5, E8-G8, C1-G5, H7-H6, G5-E3, F6-H5 
8ee0: E2-E4, C7-C6, D2-D4, D7-D5, B1-C3, D5-E4, C3-E4, C8-F5, E4-G3, F5-G6, H2-H4, H7-H6, G1-F3, B8-D7, F1-D3, G6-D3 
8f00: D2-D4, G8-F6, C2-C4, E7-E6, G1-F3, B7-B6, G2-G3, C8-B7, F1-G2, F8-E7, E1-G1, E8-G8, B1-C3, F6-E4, D1-C2, E4-C3 
8f20: C2-C4, G8-F6, B1-C3, E7-E6, E2-E4, C7-C5, G1-F3, B8-C6, D2-D4, C5-D4, F3-D4, F8-B4, D4-C6, D7-C6, D1-D8, E8-D8 
8f40: E2-E4, E7-E5, G1-F3, B8-C6, F1-B5, G8-F6, E1-G1, F6-E4, D2-D4, F8-E7, D1-E2, E4-D6, B5-C6, B7-C6, D4-E5, D6-B7 
8f60: E2-E4, E7-E6, D2-D4, D7-D5, B1-C3, G8-F6, C1-G5, F8-E7, E4-E5, F6-D7, G5-E7, D8-E7, D1-D2, E8-G8, F2-F4, C7-C5
8f80: E2-E4, E7-E5, D2-D4, E5-D4, D1-D4, B8-C6, D4-E3, G8-F6, B1-C3, F8-B4, C1-D2, E8-G8, E1-C1, F8-E8, F1-C4, D7-D6 
8fa0: E2-E4, E7-E5, D2-D4, E5-D4, C2-C3, D4-C3, F1-C4, C3-B2, C1-B2, G8-F6, B1-C3, B8-C6, G1-F3, F8-B4, D1-C2, D7-D6 
8fc0: C2-C4, E7-E5, B1-C3, G8-F6, G1-F3, B8-C6, E2-E3, D7-D5, C4-D5, F6-D5, F1-B5, D5-C3, B2-C3, F8-D6, D2-D4, C8-D7 
8fe0: E2-E4, E7-E5, G1-F3, B8-C6, F1-B5, A7-A6, B5-A4, B7-B5, A4-B3, C6-A5, B3-F7, E8-F7, F3-E5, F7-E7, D2-D4, G8-F6

Chessmate emulator by Stephen Crane

An emulator with the look and feel of the Chessmate by Michael Gardi

Images of Chessmates

My Commodore Chessmate.

My Chessmate


Photo by Commodore International Historical Society on twitter @commodoreihs

Photo by Commodore International Historical Society on twitter @commodoreihs

On this early Chessmate two ROMs were used, each 2K. The TTL IC on the top right was added manually and wire wrapped, the wires running from it to the ROM selection inputs.

Boxes

Photo by Michael Gardi

Novag Chess Champion MK II A and B


TEC Schachcomputer

KIM-1 revisions

Update 24 march 2022: added KIM-1 Re v photos from HomeComputerMuseum (thanks Bart!)

The KIM-1 went trough several revisions without any change to the specifications. The first revisions appeared as MOS Technology products, the label MOS in in the front top right corner. When Commodore took over MOS late 1976 the label changed to Commodore C MOS.

MOS did three versions, the unnamed first one, a Revision A and a Rev B. I have never seen a Rev C.
Commodore MOS did Rev D to G, starting in 1977 and well into the 80ties. Many KIM-1s were sold, first to industry and later to education and hobbyists. Nowadays KIM-1s are not rare but have become quite expensive, collectors value especially the early ones with a white 6502 IC. The KIM-1 was an OEM product by Rockwell, with its Rockwell branded documentation and a Rockwell sticker at the right top part covering the Commodore MOS label. I know of at least two versions by Rockwell, a Rev D and my Rev F.

See this page for images of the revisions known to me.

post

KIM-1 revisions

The KIM-1 went trough several revisions without any change to the specifications. The first revisions appeared as MOS Technology products, the label MOS in in the front top right corner. When Commodore took over MOS late 1976 the label (Rev D) changed to Commodore C MOS.

MOS did three versions, the unnamed first one, a Revision A and a Rev B. I have never seen a Rev C.
Commodore MOS did Rev D to G, starting in 1977 and well into the 80ties. Many KIM-1s were sold, first to industry and later to education and hobbyists. Nowadays KIM-1s are not rare but have become quite expensive, collectors value especially the early ones with a white 6502 IC.
The KIM-1 was an OEM product by Rockwell, with its Rockwell branded documentation and a Rockwell sticker at the right top part covering the Commodore MOS label. I know of at least two versions by Rockwell, a Rev D and my Rev F.
Some companies made KIM-1 clones with the same specifications but with more modern SRAM (2114), see the KIM-1 related page.

The visible changes were cosmetic: color of PCB,  label MOS first and Commodore later, and housing of ICs used (white and violet ceramic to black on the later revisions.).
Early on in the Rev A period the 6502 with defective ROR instruction was replaced with the repaired 6502, this NMOS IC continued to be the CPU to the latest revision.

A real change was the keyboard. A different one was used by Commodore, with the SST switch moved to the other side of the top row. See the page about the differences and how to repair.

Components used were of course the NMOS 6502 CPU and the RRIOTs 6530-002 and -003. I see many manufacturing dates, from 1975 to 1980 on the IC’s. It seems RRIOTs were not made after that date and enough stock was available to build the Rev F. The SRAMs were in the beginning MOS 6102s, later the equivalent (and more reliable) 2102 took its place. LED displays, TTL and transistors came from the then current manufacturers and varied a lot. The capacitors were mainly the distinct yellow axial type.

Serial numbers (thanks Dave McMurtrie for this information) appear on many KIM-1s. Not all, perhaps the handwriting wears off. Early ones (to ReV B) go without a prefix (most) or a ‘M’. On later Rev’s, the Commodore ones, numbers have a prefix PA or SC. SC stands for Santa Clara, PA for Norristown, Pennsylvania, production locations of Commodore at that time. Perhaps the number on that Rev G SC38488 means there are at least that many KIM-1s produced in Santa Clara? A Rev F with PA9047? If that is really a sequence number, how many KIM-1’s were produced? 50000? or more?

Here after are shown images of the revisions, some from photos by myself, others from the internet. I have tried to name the origin, if I failed and you are the origin, please report it.
If available, both front and back are shown.

Prototype KIM-1
On team6502  I found a photo of a prototype KIM-1 at MOS Technologies, Terry Holdt has this in his office.
The layout is different from the final product, everything seems to be present on this prototype.

No revision, 1976

From pagetable.com

From pagetable.com

Rev A


KIM-1 enthousiast


KIM-1 enthousiast


Rev A, photo by Guido Lehwalder


Rev A, photo by Guido Lehwalder

Rev B

 

Rev C

None found!

Rev D

Chuck Hutchins

Chuck Hutchins

Chuck Hutchins

Dave Dunfield

Dave Dunfield

Rev E

Stephan Slabihoud

Rev F

My original KIM-1

My original KIM-1

KIM-1 enthousiast

KIM-1 enthousiast

From HomeComputerMuseum.nl

From HomeComputerMuseum.nl

Rev G

Stephan Slabihoud

Dick Dral

KIM-1 related updates

KIM-1s, not made by Commodore but nearly identical.

More photos at the KIM-1 related page

KIM-1 keyboard repair

The KIM-1 keyboard is a special one. Made especiallyfor the KIM-1, as you can see in the SST switch. It shows its age in the design, and looks quite familiar to the keyboards hand-held calculators of the 70ties.

In those days replacement keyboards could be bought. I have repaired several KIM-1s with it. The older revisions were worse than what appeared on later revisions.

See also this page about KIM-1 keyboard repair, local copy here.

Original KIM-1 version, SST switch on the right.

KIM-1 Rev D, SST switch on the left.

The keyboard is connected to the mainboard with two screws, as you can see on the next image, and the solder connections on the front of the motherboard to the top of the keyboard.
You also see seven holes with access to screws on the bottom of the keyboard. Those keys hold the top of the keyboard connected to the bottom part. Unscrew those seven to get inside the keyboard. Leave the two screws not in a hole alone!

Over time the keyboard may develop problems like stick keys and non-responsive keys. Due to wear or dirty contacts.

A post in the vcfed.org forum may be helpful to fix some of these problems.

User Mindwalker posted this:

I (mindwalker) remember cleaning the keyboard at one point and I found this picture from my archives.
It seems the key membrane connects to the PCB over four contacts right on the bottom row, you probably have a bad contact there. Cleaning and (carefully) tightening the screws may cure it! Just be careful with the membrane.

Or you could replace the keyboard with other keypads:

An article in KIM User Notes 10/11 has this advice for the first Revisions key (No Revision, Rev A, Rev B):

Construction of a nearly exact KIM-1 replica keyboard.

Original version: Design, images and original text in German by Ralf (ralf02, forum64.de), from the KIM-1 Aufbau anleitung, and KIM-1 Keypad by user hackup, October 30, 2022 on thingiverse

Circuit diagram of the Keyboard PCB

For the keyboard construction you need the following parts:

  • 1 3D printed keyboard frame, STL from thingiverse
  • 2 keypads with 16 keys each as shown (actually, you just need 1 1/2)
  • 1 keypad PCB, see the gerber file
  • 1 SPDT slide switch, 2.54mm pitch
  • 1 female pinheader connector, 15 pins, preferably low profile
  • 1 male pinheader, 15 pins to match the female one
  • 6 self tapping screws, 2x6mm
  • labels printed white on black for the keys E, F, AD, DA, PC, +, GO, ST, RS
  • double sided adhesive tape to glue the clips to the motherboard

The keyboard PCB has to be gold plated (ENIG). With tin-plated PCBs the contact from the keys is not reliable.

Downloads made available by Ralf:

First dismantle the two keyboards and cut the two rubber contact mats as seen in the next picture. Keys 0-0 and A-D have the right lettering, make the other with a letter printer white on black.

Place the keycaps in the 3D printed case:

Now solder the slide switch and the pinheader on the PCB. Cut the rubber mat on the location of the slide swithc. Put the mat in the 3d printed case and fix with 6 screws:

Next place the four M3 screws in the holes in the PCB and the parts in the case. Now place the PCB on the 1 pin pinheader and fix the four screws with washers from the bottom.



The two red wires are only for decoration, to make it look like as on the KIM-1.

KIM-1 keyboard repair

The KIM-1 keyboard is a special one. Made especially for the KIM-1, as you can see in the SST switch. It shows its age in the design, and looks quite familiar to the keyboards hand-held calculators of the 70ties.

In those days replacement keyboards could be bought. I have repaired several KIM-1s with it. The older revisions were worse than what appeared on later revisions.\
Read this page how to repair some common problems.

Scanned book: Anwendungsbeispiele für den Mikroprozessor 6502

Anwendungsbeispiele für den Mikroprozessor 6502
Herwig Feichtinger

Hardware-Tips und nützliche Programmierbeispeile in Maschinensprache


KIM-1 Simulator V1.1.2

Updates for the KIM-1 Simulator, now V1.1.2
– KIMDLe runs, with free running timer for randomizer (first step towards working timer emulation) and fix of KIM Keyboard return value of No key $15
– Fixes for console keyboard handling, German and International settings and uppercase/lowercase handling, width character font now 1 pixel different for Linux and Windows
– Testkeydown first line bug

Executables for Windows, Ubuntu and Raspberry PI OS, sources for Lazarus