Ok, I admit it: I lost a bit of focus the last few days. I should have been buckling down and describing the circuit board more, and well, working on getting the machine up and running. Instead I have been using my non-work, non-family time to… … program. In my defense, writing is hard work. “Programming is hard, too!”, you say. Perhaps. They are certainly both activities that take more time than you think they will. “Oh, I’ll just fix this little routine here…” Famous last words, as they say.
In my defense, I should probably point out that I’ve been working on a game for the CBM II series, in 6502 assembly. Definitely not something I’ll be able to finish before the end of the April RetroChallenge, but, unlike hardware, something I can make progress against each time I touch it.
Back to the hardware…
ROMS, ROMS, Everywhere
In the last update, we looked at the set of ROM chips identified as item #4 in the photo of the CBM 710 motherboard. Today we’ll look at items 2 and 3, and (maybe) fix something.
Item #3: Programmable Logic Array Chip
I highlighted this item because the label was hand-written. “Is it some kind of homemade hack?” “What happened to whatever chip it would have shipped with?” “What is that, anyway?”.
It is a bit hard to see in the photo, but this is U75 on the motherboard. The schematics on Zimmers.net are also a bit hard to make out, but this chip is apparently an “82S100 PLA”, whatever that is. Of course, Google is your friend, as they say.
The CBM II series makes use of a kind of chip called a Programmable Logic Array, or PLA. According to the C-64 Wiki:
The Programmable Logic Array (PLA) is a hardware programmable chip in the C64 which only contains combinatorial logic.
Designed by Dave DiOrio, the PLA is used to create chip select signals received from various other signals. These signals control which chip is to be connected to the data bus. Therefore the PLA is responsible for dictating the memory map of the C64 and enables the implementation of bank switching. Commodore engineer James Redfield said it was the “glue logic to tie everything together”.
Interestingly enough, that Wiki shows a photo of a PLA labeled “906114-01”. Presumably, the C-64 version is related in at least some way to the 906114-05 chip found in the CBM 710.
Steve Gray’s page on 6502.org lists 906114-05 as the final revision for the 128K high profile machines (of which the CBM 710 is one):
MACHINE CODE |
BASIC-LO | BASIC-HI | KERNAL | CHAR | PLA |
BL1 | 901243-04 | 901242-04 | 901244-04 | 901237-01 | 906114-04 |
BL2 | 901241-04 | 901240-04 | 901244-04 | 901237-01 | 906114-04 |
BH1 | 901243-04 | 901242-04 | 901244-04 | 901232-01 | 906114-05 |
BH2 | 901241-04 | 901240-04 | 901244-04 | 901232-01 | 906114-05 |
PL1 | 901236-02 | 901235-02 | 901234-02 | 901225-01 | 906114-02 906114-03 |
(B)=Business (P)=Professional (L)=Low Profile (H)=High Profile (1)=128K RAM (2)=256K RAM
So this does appear to be the correct chip for this computer. No explanation for the hand-written nature of the label, but perhaps it was never populated on this machine, and the previous owner reached out to someone for help and got a manually programmed version.
Item #2: ROM, Oh ROM, Wherefore Art Thou?
The next highlighted item on the motherboard, #2, is an empty chip socket. Uh-oh!
Checking with the schematics again, it appears that U41 is described as 2332A, “Character ROM”. Other Commodore computers such as the C-64 and C-128, had character ROMs as well. The character ROM would contain the data that described the pixels for each character the computer could render. I’m not actually sure how they are arranged in there, but I if you are using the VICE emulator, for example, you can swap in different character ROMs in at least some of the emulated machines, so it probably isn’t too hard to make your own character set and bake it into a ROM chip.
One of my fears with this machine was that it would have a German character set, with umlauts and things where there should be honest-to-goodness Commodore PETSCII. Oh, the horror! Luckily for me, it seems I needn’t have worried: my machine has no character (ROM) at all!
Do I need one? I believe the answer is: “only if I want to be able to use the machine”. On the CBM II series, the character generator was hooked directly to the 6545 video chip. Unlike the C-64 and C-128, the character ROM data could not be loaded into RAM, modified, and used by the video chip. This is one of the reasons that bit-mapped style graphics are not possible with the CBM II series. You can’t make a custom character set to be your player, monsters, background tiles, etc. Some high-resolution graphics cards for the CBM II series did apparently achieve bitmapped graphics by inserting substitute character “ROMs” between the the computer at the video chip. Presumably they allowed the programmer to dynamically change the character data on the fly, and the 6545 happily displayed it, not knowing the difference. I have never seen one of these in action, but there are a few around. Perhaps someone will chime in?
I’ll have to wrap up here. In the next episode, I’ll describe how to burn your own Commodore ROM onto an EEPROM chip.
Although the CharRom is responsible for how the font looks, it’s the Kernal that controls the keyboard layout and that surely differ between different language versions.
I’d say that it’s probably more annoying to have an unfamiliar keyboard layout than a few characters replaced by äöüÄÖÜß :)
That’s a good point. If I ever get this machine up, one of my “someday” projects will be to reorganize the keyboard so I have a standard cursor layout where the keypad is. My daily home keyboard is a IBM AT (“F”) keyboard, with that layout, and I think with an EEPROM writer it should be possible to rewire the keyboard. The keycaps I have are not good for me anyway, as they are all German layout, and my fingers know things that the keycaps don’t! So, err, if anyone has a full set of US key caps for a B-series, just let me know…