Sunday 24 February 2019

Commodore 16 64K Upgrades

The Commodore 16 was always the nicest looking of the TED series of computers, and had the best case, a black version of the VIC20/C64 breadbin case, and best keyboard, a grey version of the VIC20/C64 keyboard. But it was the weaker of the two main TED machines in that it lacked several things. It didn't have a user port (although that wasn't used much it would have been nice), it didn't have the built in software suite (again, would be nice, but I'll manage without it), the main issue was it only had 16K of RAM.

Many game developers aimed for the lower common denominator and produced 16K titles that would run on the Commodore 16 and the plus/4, but there were quite a few titles that only ran on the plus/4 with it's 64K of RAM. It would seem the best combination you can have then is a Commodore 16 that has been upgraded to 64K (by the way, I've checked, and a C16 upgraded to 64K doesn't make a C64). I've seen many ways of doing this, and have tried to find the best one. The aim was to find a nice easy way that a C16 could be upgraded, in a plug and play sort of way.

First off, I've been through this all sorts of different ways, and concluded that it's just not going to be possible to do this as a cartridge without modifying the C16 board internally in some way. That's rather disappointing, but it boils down to this, the TED chip generates the RAM select lines, and this is the same chip used on the plus/4, so it generates these over the whole 64K range. The RAM chips themselves are wired up to know nothing of the upper two address lines, so the 16K RAM is mirrored four times in the 64K address space. No getting around that. The 4416 RAM chips are soldered to the board on every C16 I've seen, and are enabled over the whole address space. So as far as I can see it, there's no way to add a full 64K of RAM to the C16 without somehow disabling the onboard RAM, which is going to have to involve a soldering iron or something sharp and pointy.

But there are C16 64K RAM cartridges, how do they do it? Well, unless I've missed something, I can't see how it can be done without disabling the internal 16K RAM. I did find one cartridge from the 80s that had instructions (in German) which included a diagram instructing you to cut a track, this is the RAS line from the CPU, so will stop the RAM being selected.

Another cartridge (also in German) suggests cutting pin 9 of the two RAM chips, that is the 5V supply (yes, I know it's in an unusual place on that, carried over from the 4116 pinout), which should also disable them (although parasitic power could still be a problem, I wouldn't recommend that method). It also means you always have to have the cartridge installed as the internal RAM doesn't work any more.

Those seems to have been lost in the mists of time, and various clones of the C16 64K cart are on sale at the moment that don't appear to mention this. Without that, you get the internal 16K and the first 16K in the external cartridge running in parallel. That's not great, but both should be writing the same data to the bus. The problem comes when you access above 16K. The onboard RAM is mirroring the lower 16K, but the cartridge has different data, so both try to drive the data lines. The one closest the CPU wins, but eventually bad things happen to the other RAM chips, things get hot, things fail. It's not a good idea.

The technical bit

The TMS4416 RAM chips used are 4 bits by 16K. These are dynamic RAM, and so are addressed in two parts, a row and then a column. The row is setup first using the eight address inputs, A0-A7. The column then follows, but this only uses the A1-A6 pins, switched using 74LS257 multiplexor chips to A8-A13. This gives it a 14 bit address range, 0000-3FFF or 16K in total. A14 and A15 are not referenced, so the same RAM will also appear in the memory map at 4000-7FFF, 8000-BFFF and C000-FFFF. This means if you try to add any RAM to the system in the 4000-FFFF range, it will conflict with this onboard RAM. And that's the issue really. It may pass memory tests and appear to work, but it really shouldn't.

The plus/4 has a similar arrangement (although the style of the schematic is a little different). The key things to note here, is the 4164 chips used here (1 bit by 64K) have A0-A7 on the RAS selection, and A8-A15 on the CAS. These chips are driven by the same RAS and CAS signals from the same TED chip, so are active over the whole address range, but in this case, provide valid data over that range with no mirroring.

It may be clearer to look at the last version of the Commodore 64 mainboard. That used two 4464 RAM chips rather than eight 4164 as the earlier versions and the plus/4. Here you can see it is pretty much the same, other than the address lines are A0-A7 and A8-A15 and the RAM chips are 4x64K instead of 4x16K.

Here is the relevant area on the Commodore 16 board. The two RAM chips, bottom right are U5 and U6, and the two multiplexor chips are U7 and U8. So to upgrade the Commodore 16 to 64K, we need to remove the two RAM chips and replace them with 4464 chips, and rewire one pin on each of the 74LS257 mux chips, disconnecting 5V and attaching A14 and A15 (it doesn't actually matter which way around they go as long as they are both connected up).

This is where it gets to the choices. There are several ways this can be done, and I present here a selection of those. Each have pros and cons. All involve desoldering the chips, so should not be undertaken without suitable experience and equipment.

Method 1 - Permanent install

This is the way I normally do these modifications, it is permanent in that tracks have to be cut, but that's fine if you don't plan to go back to 16K at any point. Step one is to remove U5-U8. I use a desoldering gun and lots of flux, going slowly and carefully trying not to damage the board or the chips. If done properly, the chips will just drop out. No levering should ever be required,

Time for the modifications, first is U7.

Pin 2 is connected to 5V, this needs to be cut and connected to A14.

To do that, cut the track on the top of the board between pins 16 and 2. See later for alternatives if you don't like the idea of cutting tracks.

Next is U8.

Here pin 14 needs to be disconnected from 5V and connected to A15.

That is under the board, and the track is cut between the large 5V rail and pin 14.

That could have been done without removing the chip, but the 74LS257 (and particularly the MOS version of the 257, the 7708) are all common failures in machines of this era, so as I was removing the other three, it always seems a good opportunity to replace both 74LS257 chips.

A14 and A15 can be found in various locations, pins 36 and 37 of the TED chip, pins 21 and 22 of the 7501/8501 CPU, or I use two vias near by, just check for continuity with the above pins.

You can test first with the original RAM chips, just to make sure everything is OK, they should still operate as 16K.

Yes, still working. Time to fit the 4464 RAM chips.

And switch on.

Excellent, you now have a 64K Commodore 16 (which you are not allowed to call a Commodore 64). It's usually a good time to give the machine a bit of a test, one of the new Diag 264 cartridges with shinny gold plated edge connector. (2023 update - these are no longer available as the author has revoked permission for pre-programmed cartridges to be sold)

I left that running for a while and all the tests passed (other than the ones needing human input or loopbacks which I wasn't concerned about).

And now, time to try out some of those plus/4 only titles on my new Commodore 64 64K Commodore 16.

Method 2 - Mod board

This was a machine that was sent in for repair. The owner had problems installing this 64K upgrade. Have you spotted the problem yet?

It is an alternative way of doing the same thing as above. The board plugs into two sockets fitted where the 74LS257s chips were and connects two new 74LS257 chips in their place, apart from the two pins that need to be redirected. It connects those via a switch to a two pin header, and a short cable connects that to another two pin header installed on the board where there are convenient A14 and A15 vias next to the modulator.

To install this, the four chips need to be removed and sockets fitted, and this is where the problems had happened. Cutting chip pins and then pulling them out one by one is not a method I would recommend, and in this case, had done a bit of damage. The repairs on the back, well, I'll let you judge.

I thought it best to remove the sockets to see what the board was like underneath, so I could repair the two missing tracks (you did spot those on the first picture didn't you?) and any other damage.

With the sockets removed and the board cleaned up, it wasn't that bad, and I was able to repair the places where the through hole plating had been lost, the two tracked that had been pulled up and lost, and the one that was hanging on by a thread.

With new sockets fitted and the tracks repaired on the back of the board, the module could be reinstalled and tested.

It's quite a neat solution, but not for the novice solderer. A nice feature of that board is the switch which returns it to a 16K machine by switching the two address pins back to 5V.

Method 3 - Reversible version

Whilst using a board like that above does give a neat solution, I did try a third method, sort of a combination of both of the other methods.

Remove all four chips, U5-U8 and fit sockets.

At any point, you can reinstall the original chips if you want to go back to the original Commodore 16. You could maybe use less good sockets that would look more like the type they may have originally fitted if you like, but I prefer to stick with the turned pin versions.

No tracks have been cut, so to connect the higher address lines to the mux chips, I fitted new 74LS257s and bent up the two legs, pin 2 on U7 and pin 14 on U8 and attached some wires.

Those two wires then needed to be connected to A14 and A15, so I used the same trick the plug in board had used and fitted a two pin header to the leftmost two vias in the row of six by the modulator.

That gives a fairly neat install, it is fixed as 64K, but no tracks have been cut, so you can go back to 16K if you wish using the original chips you carefully removed before (you did carefully remove them didn't you? no cutting legs or prying out here please).

This last one is the Commdore 16 I recently fitted an internal SD2IEC to.

So there's a few different ways to do a 64K upgrade to a Commodore 16. Sorry there isn't a solderless method, address all complaints to the marketing division of Commodore in around 1984.


Update

I have designed a new version which plugs into the sockets of the two RAM chips and two mux chips and gives 64K or 16K switchable. Available form my SellMyRetro store.

More info in a blog post


Patreon

You can support me via Patreon, and get access to advance previews of posts like this and behind the scenes updates. These are often in more detail than I can fit in here, and some of these posts contain bits from several Patreon posts.

This also includes access to my Patreon only Discord server for even more regular updates.

https://www.patreon.com/tynemouthsoftware