Z80 Project

Nathan's Z80 Project Mark 2: Memory

Last updated: Aug. 17, 2009, 11:23 p.m.

The memory part of my Mark 2 system is extremely simple. There are two 32K SRAM chips (actually FRAM because I had them lying around, but there isn't any significant difference in this application). These are selected with the logical OR of the MREQ signal and A15 (or inverse of A15 for the upper chip). Because the boot code for the Z80 is held by the PIC and the PIC can control the whole address bus while it holds the Z80 in reset the boot code is written to normal RAM after power-on. This provides the advantage of less decode logic, and no ROM chip, as well as allowing the whole of the memory space to be used by whatever application is running as there are no "unwriteable" regions.

The actual logic I used to generate the select signals is not OR gates, as there were none of these on the board, but NAND and NOT gates as I had spare of these from various other functions. The translation is based on De Morgan's Laws about equivalence of inverted operators. Basically if I invert both inputs and output of an and gate it becomes an or gate. However since I have a NAND gate the output is already inverted, so inverting the inputs will make the output equivalent to my OR gate truth table. This actually only requires one extra gate as I would have to invert A15 anyway, the inverted version is just used in the select for the other chip now, and the extra gate is a NOT gate on the MREQ signal.

For a more comprehensible explanation see the circuit diagram:

Circuit diagram of the memory sub circuit of the Z80 project

I've mentioned here that I'm using FRAM chips. I currently don't plan to use them for storage of data however, as I have found them somewhat "temperamental" in home made circuits in the past. If you are interested in storing data in them through power-cycles, it's worth noting that somewhere in the data sheet it suggests using a pull-up resistor on the chip select pin, this avoids any glitches during power-on that could destroy data in the memory. I've used a 10K, or possibly even a 4K7 in the past, and noticed much improved resilience, so even if you don't think your system should be doing anything while power isn't fully on or off, it's worth adding that pull up.

Datasheets FM1808 32K x 8 FRAM.

Z80 Project
Z80 Mark 2


Posting comments is not currently possible. If you want to discuss this article you can reach me on twitter or via email.


Email: nathan@nathandumont.com

Mastodon: @hairymnstr@mastodon.social