## N-537

# Interfacing the DP8420A/21A/22A to the 68030 Microprocessor

National Semiconductor Application Note 537 Webster (Rusty) Meier Jr. and Joe Tate July 1989



### I. INTRODUCTION

This application note describes how to interface the 68030 microprocessor to the DP8422A DRAM controller (also applicable to DP8420A/21A). It is assumed that the reader is already familiar with 68030 and the DP8422A modes of operation

### II. DESCRIPTION OF DESIGN, ALLOWING UP TO 25 MHz OPERATION WITH 2, 3 OR 4 WAIT STATES IN NORMAL ACCESSES AND 1 OR 2 WAIT STATES DURING BURST ACCESSES

This design drives two banks of DRAM, each bank being 32 bits in width, giving a maximum memory capacity of 32 Mbytes (using 4 Mbit x 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 64 Mbytes (using 4 Mbit x 1 DRAMs, NOTE that when driving 64 Mbytes the timing calculations will have to be adjusted to the greater capacitive load).

The memory banks are interleaved on every four word (32-bit word) boundry. This means that the address bit (A4) is tied to the bank select input of the DP8422A (B1). Address bits A3, 2 are tied to the highest row and column address inputs to support nibble mode burst accesses (using nibble mode DRAMs). Address bits A1, 0 are used to produce the four byte select data strobes, used in byte reads and writes. If the majority of accesses made by the 68030 are sequential, the 68030 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. 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 will generally require extra wait states to be inserted into the CPU access cycles to allow for the RAS precharge time.

This design supports the 68030 in its synchronous mode of operation. All DRAM accesses are terminated through the 68030 STERM input. The burst mode transfer operations are also supported using the synchronous mode of operation. To support these operations nibble mode DRAMs must be used. Nibble mode DRAMs are necessary to support wrap-around during a burst access.

This application allows 2, 3 or 4 wait states to be inserted in normal synchronous accesses and 1 or 2 wait states to be inserted during burst accesses of the 68030. The number of wait states can be adjusted through the  $\overline{\text{WAITIN}}$  input of the

DP8422A and the ADDW input of the PAL®, see the table below (the first two rows of the table can also be seen in the timing simulations that appear at the end of this application note):

|  | WAITIN | ADDW | Number of Wait States In |              |
|--|--------|------|--------------------------|--------------|
|  |        |      | Normal Access            | Burst Access |
|  | 0      | 0    | 4                        | 2            |
|  | 0      | 1    | 3                        | 1            |
|  | 1      | 0    | 3                        | 2            |
|  | 1      | 1    | 2                        | 1            |

The PAL has an input called "EXST" that allows the user to setup the STERM for any other system peripheral to this PAL. This PAL will synchronize EXST to the system clock by gating it with a low logic level on the CLK input (for more information see the PAL equations in Section V). This allows one device to produce STERM to the 68030.

The logic shown in this application note forms a complete 68030 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  $\overline{\text{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 32-bit words in memory:
- d. Normal and burst access operations.

By making use of the enable input on the 74AS244 buffer, this application can easily be used in a dual access application. The addresses and chip select are tri-stated through this buffer, the write input  $(\overline{\text{WIN}})$ , lock input  $(\overline{\text{LOCK}})$ , and  $\overline{\text{ECAS0}}-3$  inputs must also be able to be tri-stated (another 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 at 25 MHz the  $t_{RAC}$  and  $t_{CAC}$  (require  $\overline{RAS}$  and  $\overline{CAS}$  access time required by the DRAM) will have to be recalculated since the time to  $\overline{RAS}$  and  $\overline{CAS}$  is longer for the dual access application (See TIMING Section of this application note).

### III. 68030 DESIGN, UP TO 25 MHz WITH 2, 3 OR 4 WAIT STATES DURING NORMAL ACCESSES AND 1 OR 2 WAIT STATES DURING BURST ACCESSES, PROGRAM-MING MODE BITS

#### **Programming**

| Bits                                | Description                                                                                                                                                                                                                                |  |  |
|-------------------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|
| R0 = 1                              | RAS low four clocks, RAS precharge of three clocks                                                                                                                                                                                         |  |  |
| R1 = 1                              |                                                                                                                                                                                                                                            |  |  |
| R2 = 1                              | DTACK1 is chosen. DTACK low first rising CLK edge after access RAS is low.                                                                                                                                                                 |  |  |
| R4 = 0                              | No WAIT states during burst accesses                                                                                                                                                                                                       |  |  |
| R5 = 0                              |                                                                                                                                                                                                                                            |  |  |
| R6 = 0                              | If $\overline{\text{WAITIN}}=0$ , add one clock to $\overline{\text{DTACK}}$ . $\overline{\text{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. |  |  |
| R7 = 1                              | Select DTACK                                                                                                                                                                                                                               |  |  |
| R8 = 1                              | Non-Interleaved Mode                                                                                                                                                                                                                       |  |  |
| R9 = X                              |                                                                                                                                                                                                                                            |  |  |
|                                     |                                                                                                                                                                                                                                            |  |  |
| C0 = X<br>C1 = X<br>C2 = X          | Select based upon the input "DELCLK" frequency. Example: if the input clock frequency is 20 MHz then choose C0, 1, 2 = 0, 0, 0 (divide by ten, this will give a frequency of 2 MHz). If using the DP8422A over 20 MHz do                   |  |  |
|                                     | an initial divide by two externally and then run that output into the DELCLK input and choose the correct divider.                                                                                                                         |  |  |
| C3 = X                              |                                                                                                                                                                                                                                            |  |  |
| C4 = 0                              | RAS groups selected by "B1". This mode al-                                                                                                                                                                                                 |  |  |
| C5 = 0                              | lows two RAS outputs to go low during an                                                                                                                                                                                                   |  |  |
| C6 = 1                              | access, and allows byte writing in 32-bit words.                                                                                                                                                                                           |  |  |
| C7 = 1                              | Column address setup time of 0 ns.                                                                                                                                                                                                         |  |  |
| C8 = 1                              | Row address hold time of 15 ns.                                                                                                                                                                                                            |  |  |
| C9 = 1                              | Delay $\overline{\text{CAS}}$ during write accesses to one clock after $\overline{\text{RAS}}$ transitions low                                                                                                                             |  |  |
| B0 = 1                              | Fall-thru latches                                                                                                                                                                                                                          |  |  |
| B1 = 1                              | Access mode 1                                                                                                                                                                                                                              |  |  |
| $\overline{\text{ECASO}} = 0$       | CAS not extended beyond RAS                                                                                                                                                                                                                |  |  |
| 0 = Program with low voltage level  |                                                                                                                                                                                                                                            |  |  |
| 1 = Program with high voltage level |                                                                                                                                                                                                                                            |  |  |

### IV. 68030 TIMING CALCULATIONS FOR DESIGN AT 25 MHz WITH 4 WAIT STATES DURING THE NORMAL ACCESSES AND 2 WAIT STATES DURING BURST ACCESSES

X = Program with either high or low voltage level

(don't care condition)

Minimum ADS low setup time to CLOCK high for DTACK logic to work correctly (DP8422A-25 needs 25 ns):
 40 ns (one clock period) — 10 ns (PAL16R4D combinational output max) = 30 ns

- 2A. Minimum address setup time to  $\overline{ADS}$  low (DP8422A-25 needs 14 ns):
  - 40 ns (one clock period) 20 ns (assumed 68030 max time to address valid from CLK high) 6.2 ns (74AS244 buffer delay max) + 2.5 ns (minimum PAL16R4D combinational output delay) = 16.3 ns
- 2B. Minimum address setup time to CLK high (used in #3B calculation below):
  - 40 ns (one clock period) 20 ns (assumed 68030 max time to address valid from CLK high) 6.2 ns (74AS244 buffer delay max) = 13.8 ns
- 3A. Minimum  $\overline{\text{CS}}$  setup time to  $\overline{\text{ADS}}$  low (DP8422A-25 needs 5 ns):
  - 16.3 ns (#2A) 9 ns (max 74AS138 decoder) = 7.3 ns
- 3B. Minimum  $\overline{\text{CS}}$  setup time to CLK high (PAL equations need 0 ns):
  - 13.8 ns (#2B) 9 ns (max 74AS138 decoder) = 4 8 ns
- 4. Determining  $t_{\mbox{RAC}}$  during a normal access (RAS access time needed by the DRAM):
  - 180 ns (four and one half clock periods to do the access) 10 ns (PAL16R4D combinational output,  $\overline{ADS})-29$  ns ( $\overline{ADS}$  to  $\overline{RAS}$  low) 5 ns (68030 data setup time) 7 ns (74F245) = 129 ns.

Therefore the  $t_{RAC}$  of the DRAM must be 129 ns or less.

- Determining t<sub>CAC</sub> during a normal access (<del>CAS</del> access time) and column address access time needed by the DRAM:
  - 180 ns 10 ns 5 ns 7 ns 75 ns ( $\overline{ADS}$  to  $\overline{CAS}$  low on DP8422A-25, 50 pF spec) -12 ns [74AS32, 6 ns plus 6 ns extra, taken from lab data on the 74AS32, for driving a 22 $\Omega$  damping resister and 150 pF of capacitance associated with driving 16 DRAM  $\overline{CAS}$  inputs (per  $\overline{CAS}$  output)] = 71 ns.

Therefore the  $t_{\mbox{\footnotesize{CAC}}}$  of the DRAM must be 71 ns or less.

- Determining the nibble mode access time needed during a burst access:
  - 120 ns (three clock periods to do the burst) 20 ns (one half clock period during which  $\overline{\text{CAS}}$  is high from the previous access) 20 ns (the data is sampled on a faling clock edge) 10 ns (PAL16R4D combinational output from CLK input falling edge,  $\overline{\text{ENCAS}})$  12 ns (74AS32 delay to produce  $\overline{\text{CAS}}$  from the  $\overline{\text{ENCAS}}$  input, see discription from #5) 5 ns (68030 data setup time) 7 ns (74F245) = 46 ns.
  - Therefore the nibble mode access time of the DRAM must be 46 ns or less.
- 7. Maximum time to DTACK2 low (PAL16RD needs 10 ns setup to CLK):
  - 40 ns (One clock) 28 ns ( $\overline{\text{DTACK2}}$  low from CLK high on DP8422A-25) = 12 ns
- 8. Minimum STERM setup time to CLK (0 ns to CLK rising edge is needed by the 68030):
  - 20 ns (one half clock period) 10 ns (PAL16R4D combinational output maximum) = 10 ns
- \*\* Note: That calculations can be performed for different frequencies and/ or different combinations of wait states by substituting the appropriate values into the above equations.

### V. 68030 Design, PAL Equations Written in National Semiconductor PLAN™ Format

PAL16R4D

OE STERM DC NC3 DB DA NC4 ENCAS AREQ VCC

IF (VCC) 
$$\overline{AREQ} = \overline{AS} * \overline{CS} * CLK$$

IF (VCC) 
$$\overline{\text{ENCAS}} = \overline{\text{AREQ}} * \overline{\text{CS}} * DC$$

IF (VCC) 
$$\overline{DC} = \overline{AS} * \overline{CS} * \overline{DB} * \overline{CLK}$$

+ 
$$\overline{\text{AS}}$$
 \*  $\overline{\text{CS}}$  \*  $\overline{\text{DC}}$  \*  $\text{CLK}$ 

IF (VCC) 
$$\overline{\mathtt{STERM}}$$
 =  $\overline{\mathtt{AS}}$  \*  $\overline{\mathtt{CS}}$  \*  $\overline{\mathtt{DA}}$  \* DB \*  $\overline{\mathtt{CLK}}$  \*  $\overline{\mathtt{ADDW}}$ 

+ 
$$\overline{\text{AS}}$$
 \*  $\overline{\text{CS}}$  \*  $\overline{\text{DTACK}}$  \* DB \*  $\overline{\text{CLK}}$  \* ADDW

\*\*\* ''IF  $(\overline{CS})$   $\overline{STERM}$ '' could be used if the user desires to wire ''OR''  $\overline{STERM}$  outputs together from other peripherals.

$$\overline{\text{DA}}$$
: =  $\overline{\text{AREQ}}$  \*  $\overline{\text{CS}}$  \*  $\overline{\text{DTACK}}$  \* DB \*  $\overline{\text{ADDW}}$ 

$$\overline{\text{DB}}$$
: =  $\overline{\text{AREQ}}$  \*  $\overline{\text{CS}}$  \*  $\overline{\text{DTACK}}$  \*  $\overline{\text{DA}}$  \*  $\overline{\text{DB}}$  \*  $\overline{\text{ADDW}}$ 

### **KEY: READING PAL EQUATIONS WRITTEN IN PLAN**

EXAMPLE EQUATIONS: IF (VCC) 
$$\overline{\text{DC}}$$
 =  $\overline{\text{AS}}$  \*  $\overline{\text{CS}}$  \*  $\overline{\text{DB}}$  \*  $\overline{\text{CLK}}$ 

+ 
$$\overline{\text{AS}}$$
 \*  $\overline{\text{CS}}$  \*  $\overline{\text{DC}}$  \* CLK

This example reads: the output " $\overline{DC}$ " will transition low given that one of the following conditions are valid:

- 1. The input "AS" low AND the input "CS" is low AND the output "DB" is low and the input "CLK" is low, OR
- 2. The input "AS" is low AND the input "CS" is low AND the output "DC" is low and the input "CLK" is high.









### **DRAM Speed Versus Processor Speed (DRAM Speed** References the RAS Access Time, tRAC, of the DRAM **Using DP8422A-25 Timing Specifications)**



Lit. # 100537

### LIFE SUPPORT POLICY

NATIONAL'S PRODUCTS ARE NOT AUTHORIZED FOR USE AS CRITICAL COMPONENTS IN LIFE SUPPORT DEVICES OR SYSTEMS WITHOUT THE EXPRESS WRITTEN APPROVAL OF THE PRESIDENT OF NATIONAL SEMICONDUCTOR CORPORATION. As used herein:

- 1. Life support devices or systems are devices or systems which, (a) are intended for surgical implant into the body, or (b) support or sustain life, and whose failure to perform, when properly used in accordance with instructions for use provided in the labeling, can be reasonably expected to result in a significant injury to the user.
- 2. A critical component is any component of a life support device or system whose failure to perform can be reasonably expected to cause the failure of the life support device or system, or to affect its safety or effectiveness.

**National Semiconductor** 

National Semiconducto Corporation 1111 West Bardin Road Arlington, TX 76017 Tel: 1(800) 272-9959 Fax: 1(800) 737-7018

**National Semiconductor** Europe

Fax: (+49) 0-180-530 85 86 Fax: (+49) 0-180-530 tb so estimated in the properties of the pro National Semiconductor Hong Kong Ltd.
13th Floor, Straight Block,
Ocean Centre, 5 Canton Rd.

Tsimshatsui, Kowloon Hong Kong Tel: (852) 2737-1600 Fax: (852) 2736-9960

National Semiconductor Japan Ltd.
Tel: 81-043-299-2309
Fax: 81-043-299-2408