## Interfacing the DP8420A/21A/22A to the Z280/Z80000/Z8000 Microprocessor





## **I INTRODUCTION**

This application note describes how to interface the Z280 microprocessor to the DP8422A DRAM controller (also applicable to DP8420A/21A). It is assumed that the reader is already familiar with Z280 and the DP8422A modes of operation. The interface to the Z80000 and Z8000 is similar to the interface described in this application note.

## II DESCRIPTION OF DESIGN, ALLOWING OPERATION AT 10 MHz (AND ABOVE) WITH 1 WAIT STATE IN NOR-MAL ACCESSES AND 1 WAIT STATE DURING BURST ACCESSES

The block diagram of this design is shown driving two banks of DRAM, each bank being 16 bits in width, giving a maximum memory capacity of up to 16 Mbytes (using 4 M-bit  $\times$  1 DRAMs). By choosing a different RAS and CAS configuration mode (see programming mode bits section of DP8422A data sheet) this application can support 4 banks of DRAM, giving a memory capacity of up to 32 Mbytes (using 4 M-bit  $\times$  1 DRAMs).

The memory banks are interleaved on every four word (16-bit word) boundry. This means that the address bit (A3) is tied to the bank select input of the DP8422A (B1).

Address bits A2,1 are tied to the most significant row and column address inputs (R9,C9 for 1 Mbit DRAMs) to support burst accesses using static column mode DRAMs. Since this application assumes the use of static column DRAMs the column address strobe ( $\overline{CAS}$ ) is left low throughout the entire burst access. If the user desires to use nibble mode or page mode DRAMs the  $\overline{CAS}$  outputs must be toggled, the ECAS inputs the DP8422A can be used for this purpose ( $\overline{DS}$  of the Z280 could be "OR"ed with the current ECAS inputs). If nibble mode DRAMs are used the COLINC input of the DP8422A need not be driven.

Address bit A0 is used to produce the two byte select data strobes along with the byte/word signal (B/W). These byte selects (Byte 0  $\overline{\text{ECAS}}$  and Byte 1  $\overline{\text{ECAS}}$ ) are used in byte reads and writes as well as selects for the transceivers.

If the majority of accesses made by the Z280 are sequential, the Z280 can be doing burst accesses most of the time. Each burst of four words can alternate memory banks, allowing one memory bank to be precharging (RAS precharge) while the other bank is being accessed (Bank select, B1, tied to address A3). This is a higher performance memory system then a non-interleaved memory system (bank select on the higher address bits). Each separate memory access to the same memory bank may require extra wait states to be inserted into the CPU access cycles to allow for the RAS precharge time, if two periods or more of RAS precharge were programmed.

This application allows 1 or more wait states to be inserted in normal accesses and 1 or more wait states to be inserted during burst accesses of the Z280. The number of wait states can be adjusted through the WAITIN input of the DP8422A.

The logic shown in this application note forms a complete Z280 memory sub-system, no other logic is needed. This sub-system automatically takes care of:

- A. arbitration between Port A, Port B, and refreshing the DRAM;
- B. the insertion of wait states to the processor (Port A and Port B) when needed (i.e., if RAS precharge is needed, refresh is happening during a memory access, the other Port is currently doing an access . . .etc);
- C. performing byte writes and reads to the 16-bit words in memory;
- D. normal and burst access operations.

The external wait logic (U1, U2, U3, U4; see *Figure 1*) is needed to support burst accesses of the Z280. During burst accesses the Z280 WAIT input is sampled every falling clock edge. What is worse is that the WAIT input needs one half clock period setup time and the DS signal (used to toggle ECAS0-3 and thereby toggle the DP8422A WAIT output) takes close to one half of a clock period to transition high. This leaves no time for the DP8422A WAIT output to transition between states. The external flip-flop is used to provide extra fast response time for normal access wait states and to toggle when doing a burst mode access. If the user is not going to do burst accesses the WAIT output can be tied directly to the WAIT input of the Z280 (U1, U2, U3, U4 would not be needed). Also all this logic could easily be put into a PAL® if desired.

By using the "output control" pins of some external latches (74ALS373's), this application can easily be used in a dual access application. The addresses could be TRI-STATE® through these latches, the write input (WIN), lock input (LOCK), and ECAS0-3 inputs must also be able to be TRI-STATE (a 74AS244 could be used for this purpose). By multiplexing the above inputs (through the use of the above parts and similar parts for Port B) the DP8422A can be used in a dual access application. If this design is used in a dual access application. If this design is used in a dual access time required by the DRAM) will have to be recalculated since the time to RAS and CAS is longer for the dual access application (see TIMING section of this application note).

nterfacing the DP8420A/21A/22A to the Z280/Z80000/Z8000 Microprocessor

**AN-**546

PAL® is a registered trademark of and is used under license from Monolithic Memories, Inc. TRI-STATE® is a registered trademark of National Semiconductor Corporation.

© 1995 National Semiconductor Corporation TL/F/9740

RRD-B30M115/Printed in U. S. A

III Z280 DESIGN, 10 MHz WITH 1 WAIT STATE DURING NORMAL ACCESSES AND 1 WAIT STATE DURING BURST ACCESSES, PROGRAMMING MODE BITS

| rogramming<br>Bits    | Description                                          |
|-----------------------|------------------------------------------------------|
| 0 = 0                 | RAS low two clocks, RAS precharge                    |
| R1 = 1                | of two clocks, this setup                            |
|                       | will only guarantee 93.5 ns RAS                      |
|                       | precharge (at 10 MHz) from refresh                   |
|                       | RAS high to access RAS low. If more                  |
|                       | RAS precharge is desired the user                    |
|                       | should program three periods of RAS                  |
|                       | precharge.                                           |
| R2 = 0                | DTACK one half is chosen. DTACK                      |
| R3 = 1                | low first rising CLK edge                            |
|                       | after access RAS is low.                             |
| 4 = 0                 | No WAIT states during burst accesses                 |
| 5 = 0                 | 6                                                    |
| R6 = 0                | If $\overline{\text{WAITIN}} = 0$ , add one clock to |
|                       | DTACK. WAITIN may be tied high or                    |
|                       | low in this application depending upon               |
|                       | the number of wait states the user                   |
|                       | desires to insert into the access.                   |
| 7 = 1                 | Select DTACK                                         |
| 8 = 1                 | Non-interleaved Mode                                 |
| 9 = X                 |                                                      |
| 0 = X                 | Select based upon the input                          |
| X = X                 | "DELCLK" frequency. Example: if the                  |
| C2 = X                | input clock frequency is 10 MHz then                 |
|                       | choose $C0,1,2 = 1,0,1$ (divide by five,             |
|                       | this will give a frequency of 2 MHz).                |
| C3 = X                | ····· ····· g···· ··· ···· ··· ··· ····· ·····       |
| 4 = 0                 | RAS groups selected by "B1". This                    |
| 5 = 0                 | mode allows two RAS outputs to go                    |
| C6 = 1                | low during an access, and allows byte                |
|                       | writing in 16- or 32-bit words.                      |
| 27 = 1                | Column address setup time of 0 ns                    |
| C8 = 1                | Row address hold time of 15 ns                       |
| 9 = 1                 | Delay CAS during write accesses to                   |
| 30 = 0                | one clock after RAS transitions low                  |
|                       | Latches latch on ALE input low                       |
| 31 = 0                | Access mode 0                                        |
| $\overline{CAS}0 = 0$ | CASn not extended beyond RASn                        |
|                       | vith low voltage level                               |
| •                     | vith high voltage level                              |
| •                     | with either high or low voltage level                |
| •                     | e condition)                                         |
| (uon i car            | o condition)                                         |

## 10 MHz WITH 1 WAIT STATE DURING NORMAL ACCESSES AND 1 WAIT STATE DURING BURST ACCESSES

- Minimum ALE high setup time to CLOCK high if using the on-chip latches and more then one RAS bank (DP8422A-20 needs 29 ns, #301b): \_\_\_\_\_
  - 100 ns (one clock period) 20 ns ( $\overline{\rm AS}$  valid maximum delay, #3 of Z280 data sheet) 11 ns (74ALS04B max delay) = 69 ns

needs 3 ns, #306):
25 ns (address setup to AS high, #20 Z280 data sheet) + 1 ns (74ALS04B min delay) = 26 ns
28. Minimum address hold time to ALE low (DP8422A-20 needs 10 ns, #305):
20 ns (address hold from AS high, #22 of Z280 data sheet) + 1 ns (74ALS04B min delay) = 21 ns
20. Minimum address setup to CLOCK high (DP8422A-20 needs bank address setup to CLOCK of 20 ns, #303): 100 ns (one clock period) - 20 ns (max clock to address valid, Z280 data sheet #2) = 80 ns
3. Minimum CS setup time to clock high (DP8422A-20 needs 14 ns, #300): 80 ns (#2C above) - 22 ns (max 74ALS138 decoder) = 58 ns

2A. Minimum address setup time to ALE low (DP8422A-20

- Determining t<sub>RAC</sub> during a normal access (RAS access time needed by the DRAM):
   250 ns (two and one half clock periods to do the ac-
  - 230 ins two and one half clock periods to do the access) -32 ns (CLK to RAS low max, DP8422A-20 #307) -30 ns (Z280 data setup time, #9) -10 ns (74ALS245A max delay) = 178 ns Therefore the t<sub>RAC</sub> of the DRAM must be 178 ns or less. (One can see that if zero wait states would have been programmed the t<sub>RAC</sub> would have been 84 ns (us-
  - ing DP8422A-25, has faster CLK to RAS low of 26 ns) 184–100 (one clock)). Determining  $t_{CAC}$  during a normal access (CAS access
- time) and column address access time needed by the DRAM: 250 ns - 89 ns (CLK to CAS low on DP8422A-20,
  - #308a) 30 ns 10 ns = 121 ns Therefore the  $t_{CAC}$  of the DRAM must be 121 ns or

less.

- Determining the column address access time needed during a static column mode burst access:
   20 ns (two clocks to do the access, Ex. mid T3 to mid TBW to mid T4) - 35 ns (DS high, Z280 parameter #8)
   43 ns (COLINC asserted to address outputs of DP8420A-20 incremented, #27) - 30 ns (Z280 data setup time, #9) - 10 ns (74ALS245A max delay) = 82
  - ns Therefore the column address access time of the DRAM must be 82 ns or less. (One can see that if zero wait states would have been programmed the column address access time would have been less then 0 ns (82 - 100 (one clock))).
- Maximum time to DTACK one half low (74ALS374 D type flip-flop needs 10 ns setup to CLK):

100 ns (One clock, mid T2 in mid TW) - 33 ns (DTACK one half low from CLK high on DP8422A-20, #18) - 12 ns (max delay on 74ALS02 = 55 ns

 Minimum WAIT setup time to CLK low (Z280 WAIT input needs 50 ns, #14):

100 ns (one clock period) - 16 ns (74ALS374 max delay) - 14 ns (74ALS08 max delay) = 70 ns

9. Minimum RAS precharge (DP8422A programmed with 2 clock periods of RAS precharge):

Since the  $\overline{AREQ}$  input of the DP8422A will go high from DS and  $\overline{IE}$  both being high the  $\overline{AREQ}$  high setup to clock rising edge (DP8422A parameter #29b, 19 ns) parameter is violated. This means that the rising clock edge following  $\overline{AREQ}$  high may or may not be counted.

Since that first rising clock edge could be counted, and would give less  $\overline{\text{RAS}}$  precharge time, we must assume this condition in the calculation of the minimum  $\overline{\text{RAS}}$  precharge. Therefore:

200 ns (2 clock periods) - 50 ns (half clock period before both  $\overline{IE}$  and  $\overline{DS}$  transition high) - 35 ns ( $\overline{IE}$  and  $\overline{DS}$  high, Z280 parameters #8 and #19) - 5.5 ns (74AS08 max delay) - 16 ns (DP8422A  $\overline{RAS}$  high to  $\overline{RAS}$  low difference parameter #50) = 93.5 ns

Therefore, the user should guarantee that the DRAM he is using needs a  $\overline{\text{RAS}}$  precharge time of 93.5 ns or less. If more  $\overline{\text{RAS}}$  precharge time is needed the user should program the DP8422A with 3 periods of  $\overline{\text{RAS}}$  precharge (R0, R1) during programming.

Note: Calculations can be performed for different frequencies and/or different combinations of wait states by substatuting the appropriate values into the above equations.





**AN-546** 



National does not assume any responsibility for use of any circuitry described, no circuit patent licenses are implied and National reserves the right at any time without notice to change said circuitry and specifications