data:image/s3,"s3://crabby-images/fa4b2/fa4b20b2a130eda133724ca3cd9e26d123a23620" alt=""
Testing DRAM Using an Arduino
data:image/s3,"s3://crabby-images/cc40f/cc40fa7796ace3e4840032d7650de99686f148d9" alt=""
The IIgs has an Applied Engineering GS~RAM Plus in it with 3 megabytes of RAM. The RAM is divided up into 1 meg banks, and each bank is made of eight 1M x 1 DRAM chips. I figured if I could narrow down which chip was bad I could replace it or the entire bank. There are lots of different makes of DRAM chips which are compatible, Hitachi labels theirs HM511000 & HM511001, OKI has MSM411000RS & MSM411001RS, and NEC has D421000C & D421001C. As it turned out an old ISA RAM card I got from a garage sale a year or two ago was filled with Toshiba TC511001 chips so I had plenty of spares.
My first thought was to test the chips in the TL866CS, but it doesn’t support them. What to do? Well why not build something with an Arduino to test the DRAM? I wasn’t sure how easy that would be since DRAM is trickier than SRAM because it requires a periodic refresh to keep the bits from fading. Looking around to see if anyone had done such a thing before I found this post where Len Page had done something similar using smaller 256k x 1 chips that were in his PDP 11.
I bought a bunch of Zero Insertion Force (ZIF) sockets a while back thinking I might make some cartridge boards for my Atari 800 or Atari 2600 that would let me easily swap out an EPROM, but of course they had been sitting in one of my electronics parts bins since then. I wasn’t sure how hard it would be to wire up a ZIF socket to an Arduino but then I also discovered I had some proto shields sitting around unused.
data:image/s3,"s3://crabby-images/2f332/2f3325ec00dfb35246515f3aea8d1093d374e4a6" alt=""
What makes DRAM seem tricky is that it has to be periodically refreshed because it’s made of capacitors. As long as you access each row within the refresh time, the RAM won’t lose data. Reading or writing a row will refresh all the columns in that row, or a separate refresh cycle can be used. CAS before RAS is a timesaving trick to let the chip decide which row to update so that the address lines don’t need to be set. Since my tester would be spending all its time reading and writing I didn’t need to worry about a refresh cycle. It doesn’t take very long to cycle through 1024 rows so keeping the DRAM refreshed is not a problem.
Really the only tricky part is how the address bus is multiplexed. There’s 20 bits of address but only 10 pins which means you load half of the address and latch it, then load the other half.
data:image/s3,"s3://crabby-images/e4280/e4280e839226cdaa0d45a8959b2192578cd03b8e" alt=""
If you've got some DRAM you need to test and want to use my work as a starting point, I've uploaded the Arduino software and schematic to github.
Unfortunately the problem with the IIgs seems to be not as simple as bad RAM. All 24 chips tested just fine in my Arduino DRAM tester. After putting them back in the IIgs I ran MegaMemoryTest again and on the first try it said the RAM had failed, but when I tried to repeat the test it passed. I’m now wondering if maybe one of the support chips on the GS~RAM Plus is going bad, or if it’s a deeper problem with something on the IIgs motherboard. Hopefully it’s a chip I can replace but I wonder if one of the GALs on the GS~RAM Plus might be failing.
Links:
+1 Posted by toybuilder • Mar.15.2016 at 07.32 • Reply
Sometimes. it's not the chips at all, but the supply rail (or the caps on the rails) going bad.
+1 Posted by Dagen • Mar.15.2016 at 16.27 • Reply
I have a more full featured memory testing program that might help. You can also specify which banks to test so it might make it easier to pin down a problem area.
Good luck!
https://github.com/digarok/mmt