GRAM/4D - 4MB geoRAM Compatible RAM Expansion for Commodore 64/128

Project Status: 
work in progress

geoRAMThe geoRAM is a 512KB memory expansion for the Commodore 64 and 128 designed by Berkeley Softworks for use with GEOS. While not as fast as the Commodore REU due to its lack of DMA capabilities, it still provides a significant performance boost. GRAM/4D is a 4MB geoRAM compatible cartridge based on a two 4Mx4 DRAM devices.

The geoRAM is a banked system. The registers at $dfff and $dffe select which 256 bytes page is visible in the $de00-$deff range. The $dfff register selects a 16KB block out of the total memory, the register at $dffe selects the actual 256 bytes page within the selected block. Valid values for a standard geoRAM are 0-31 for the block register and 0-63 for the window register. This design extends the block register to the full 8-bit to create a 4MB geoRAM.

The schematics is based on the 1MB GRAM/1D-C01. It replaces the 6-bit LS174 flip flops with with 8-bit LS574 to extend the block register. U1 is used to implement the block register and U3 implements the window register.
Changing the LS174 for the window register is not necessary but to simplify the BOM it has been changed as well.

Similarly to the 1MB version a 16V8 PLD is used to generate the control signals for the two registers and the control signals for the DRAM. The 74LS157 multiplexers (U6-U8) multiplex the address into rows and columns required by the DRAM chips.

Testing

Testing has been performed using the geo/neo RAM memory test and running GEOS.
It is important to note that GEOS 2.0r (which was originally shipped with the geoRAM) required to use any geoRAM style expansion. Also GEOS 2.0r is limited to 2MB expansion.
To take advantage of the full 4MB in the GEOS environment GEOS MP3 or Wheels are required.

geoRAM

Design Files
Schematics: 
Filed under: