# Interfacing the DP8408A/09A To Various Microprocessors

High storage density and low cost have made dynamic RAMs the designer's choice in most memory applications. However, the major drawback of dynamic RAMs is the complex timing involved. First, a RAS must occur with the row address previously set up on the multiplexed address bus. After the row address has been held for some minimum time after RAS (namely the row address hold time of the dynamic RAMs,  $t_{RAH}$ ), the column address is set up and then CAS occurs. In addition, refreshing must be done periodically to keep all memory cells charged.

With the introduction of the DP8408A Dynamic RAM Controller/Driver, the above complexities are simplified. The DP8408A is housed in a 48-pin package with eight multiplexed address outputs (Q0-7) and six control outputs (RAS0-3, CAS, WE). It consists of two 8-bit address latches and an 8-bit refresh counter. All the output drivers are capable of driving 500 pF loads.

The following discussion demonstrates a typical application of the DP8408A Dynamic RAM Controller/Driver in Z8000TM- and Z80®-based systems. The DP8408A basically has six modes of operation: Externally Controlled Refresh, Externally Controlled All-RAS Write, Externally Controlled Access, Auto Access (slow t<sub>RAH</sub>), Auto Access (fast t<sub>RAH</sub>) and Set End of Count.

The DP8408A, operating in the auto access mode, requires only RASIN to initiate a memory access cycle because all the dynamic RAM's control signals are automatically delayed from this input. (Refer to *Figure 1* for the auto access timing sequence.)

In the following applications, the DP8408A operates in either mode 5 or mode 6 Auto Access and mode 1 or 2 Externally Controlled Refresh to provide minimum additional logic.

# The DP8408A and Z8000 Interface

## MEMORY ACCESS CYCLE

Figure 2a shows the detailed block diagram of Z8000 and the DP8408A interface. Consider a memory cycle of the Z8000; first, the memory address is output on the Address and Data multiplexed bus (AD0–15) during T1 and is latched to the DP8408A by  $\overline{AS}$ . Simultaneously,  $\overline{MREQ}$  goes low and is used to provide  $\overline{RASIN}$  to initiate a memory transaction cycle. Then the selected  $\overline{RAS}$  output, row address hold time (t<sub>RAH</sub>), column address set up time (t<sub>ASC</sub>) and  $\overline{CAS}$  output will follow  $\overline{RASIN}$  as determined by the auto access modes. A maximum of one wait state is required for 6 MHz and 10 MHz CPUs. This wait state is automatically inserted by the  $\overline{CAS}$  output of the DP8408A. For systems using byte-writing, the DM74S158 provides two separate  $\overline{CAS}$  outputs for accessing the low and high byte of memo-

National Semiconductor Application Note 309 Chuck Pham, Webster (Rusty) Meier May 1986



ry. Note that  $\overline{\text{DS}}$  from the Z8000 is also gated with the DP8408A's CAS output to generate  $\overline{\text{CASL}}$  and  $\overline{\text{CASH}}$ . This guarantees the valid data from the Z8000 being written into memory during memory write cycles. Refer to *Figure 3* for the detailed memory transaction cycle timing.

The following formula allows the designer to determine the proper memory speed in terms of  $t_{\mbox{CAC}}$  (access time from  $\overline{\mbox{CAS}})$ :

$$\label{eq:tcac} \begin{split} t_{CAC} \mbox{ max.} = & 3 \times t_{cC} - tdc(\mbox{MR}) - t_{RICL} - t_{CASdly} - \\ & t_{sDR}(\mbox{C}) - 15. \end{split}$$

The Z8000 parameters:

t<sub>cC</sub>: clock cycle time

 $t_{sDR}$ (C): read data to clock  $\downarrow$  set up time tdc(MR): clock to MBEQ delay

The DP8408A, 74S158 and 74LS245 parameters:

 $t_{\mbox{RICL}}$ : RASIN to CAS delay

t<sub>CASdly</sub>: the propagation delay of the 74S158 15 ns: the propagation delay of the 74LS245 (at 50 pF load)

For the 10 MHz CPU and the DP8408A:

t<sub>CAC</sub> max.=300 - 40 - 131 - 14 - 10 - 15=90 ns.

t<sub>BICI</sub> max. (mode 6) = 131 ns at 15 pF load.

• t<sub>CASdlv</sub> max. = 14 ns at 50 pF load.

Since  $\overline{\text{MREQ}}$  is connected directly to  $\overline{\text{RASIN}}$ ,  $t_{RP}$  ( $\overline{\text{RAS}}$  precharge time) and  $t_{RAS}$  ( $\overline{\text{RAS}}$  pulse width) are determined by  $\overline{\text{MREQ}}$  high and low, respectively.

# MEMORY REFRESH CYCLE

The Z8000 CPU contains a refresh rate counter for automatic memory refresh. This counter should be programmed during the processor initialization to determine the refresh rate. Since memory refresh is automatically inserted by the Z8000, there is no additional refresh arbitration logic allowed. The CPU's STATUS 3 (ST3) output can be directly connected to the M2 (RFSH) pin of the DP8408A. During the memory refresh cycle, ST3 goes low, setting the DP8408A in the external control refresh mode (mode 2). Then all four RAS outputs will follow MREQ to strobe the DP8408A's refresh address to all memory banks (the Z8000 refresh address is ignored). As MREQ goes high again, the DP8408A increments its refresh counter, preparing it for the next refresh cycle. Refer to Figure 4 for the refresh cycle timing. Note that ST3 also goes low during the internal cycle. I/O reference cycle and interrupt acknowledge cycle, but the memory will not be refreshed because MREQ is not active during these cycles. The DP8408A on-chip refresh counter will not be incremented when M2 goes low unless MREQ is inserted.

nterfacing the DP8408A/09A To Various Microprocessors

AN-309

PAL® and PALASM™ are trademarks of and are used under license from Monolithic Memories, Inc Z80® and Z80A® are registered trademarks of Zilog Corp. Z8000™ is a trademark of Zilog Corp.

© 1995 National Semiconductor Corporation TL/F/5040

RRD-B30M115/Printed in U. S. A





FIGURE 2b. CASH and CASL Decoder

When the processor is in either halt state (by executing the privileged HALT instruction) or single-stepping mode (when STOP) input is low), it introduces memory refresh cycles. However, care should be taken when the CPU is in either a WAIT state or a Bus Acknowledge cycle, that the dynamic RAM refresh will not take place. If these conditions occur over a long period of time, a burst refresh is recommended. This can be done by toggling RASIN while keeping M2 low, until all the rows of the dynamic RAM have been refreshed, then the CPU can resume its operations.

# The DP8408A and Z80A® Interface

#### INSTRUCTION FETCH CYCLE

*Figure 5* shows the detailed interconnections between the DP8408A, the Z80 and the Dynamic RAMs. *Figure 6* shows the timing during an M1 cycle (op code fetch). The program counter is output on the address bus at the beginning of the M1 cycle. One-half clock later MREQ goes active. This input is used to provide RASIN to the DP8408A to access the dynamic memory. Subsequently, the selected RAS output,

Row to Column Select and then CAS output will automatically follow RASIN as determined by the Auto Access modes of the DP8408A. The RD line also goes active to indicate a memory read cycle is in progress. After t<sub>CAC</sub> (access time from CAS), read data becomes valid. This data is sampled on the rising edge of T3, then both MREQ and RD go inactive. Immediately following this, RFSH goes low, putting the DP8408A in the Externally Controlled Refresh mode. The MREQ goes active causing all four RAS outputs to go active to perform a refresh to all the banks of the dynamic RAMs. Note that during memory refresh cycles, the refresh address from the CPU is output on the address bus. However, the contents of the DP8408A on-chip refresh counter are used instead to provide the row address to the dynamic memory array. Since the Z80 provides only a 7-bit refresh address, it is an advantage to use the DP8408A 8-bit refresh counter to support 64k dynamic RAMs directly. The DP8408A refresh counter is incremented as MREQ returns high, ending the memory refresh. The RFSH goes inactive returning the DP8408A back to the Auto Access mode, preparing it for the next access cycle.









## MEMORY ACCESS CYCLE

Figure 7 shows the timing of the memory read and memory write cycle other than for the M1 op code fetch cycle. Similar to the op code fetch cycle, MREQ is used to provide RASIN. MREQ goes active after the address to the memory has had time to stabilize. Again, RAS output, Row to Column Select and then CAS output will automatically follow RASIN to access the specified memory location. For a memory read cycle, both MREQ and RD go active, and as a result, WIN remains high (refer to *Figure 5*), which allows a memory read operation to occur. On the other hand, only MREQ goes active during a write cycle, which forces WIN low, indicating an early write cycle. It should be noted that the CAS output to the memory array will not go low until WR goes low during memory write cycles as this guarantees the valid CPU data will be written into memory.

It is worth mentioning that the Z80 CPU provides powerful block transfer instructions. An example is the LDIR (load, increment and repeat); using only this instruction, the programmer can move any block of data from the location pointed to by the D and E registers. This operation is repeated until the byte counter (B and C registers) reaches zero. Thus, this single instruction can move any block of data from one location to any other. Due to the fact that this instruction is refetched after each data byte transfer, the memory refresh cycle always takes place even though a transfer of up to 64k bytes of data may be performed. Furthermore, when the CPU has executed the software HALT instruction and is waiting for an interrupt before normal CPU operations can resume, the CPU executes NOP instructions to maintain memory refresh activity.

However, care should be taken when the CPU is in either WAIT state or a Bus Acknowledge cycle, the dynamic RAM refresh will not take place. If these conditions occur long enough, a burst refresh is recommended, and it can be done by toggling  $\overrightarrow{RASIN}$  while keeping M2 low until all the rows of the dynamic RAM have been refreshed before the CPU can resume its operation.



The following formulas allow designers to select the appropriate dynamic memory, based on different CPU and DP8408A speed versions, to allow the CPU full speed of operation: max. t\_{CAC}: 1.5  $\times$  t\_{Cmin} - t\_{DL\varphi}(MR) - tRICL  $t_{CASDLY} - t_{S\phi}(D)$ min. t<sub>BP</sub>: tw(MRH) = tw( $\phi$ H) + t<sub>f</sub> - 20 min.  $t_{BAS}$ : tw(MRL) - 20 =  $t_{C}$  - 50 **Dynamic RAM Parameters:**  $t_{CAC}$ : access time from  $\overline{CAS}$ t<sub>RP</sub>: RAS precharge time tRAS: RAS pulse width Z80 Parameters: t<sub>C</sub>: clock period tw( $\phi$ H): clock pulse width, clock high tf: clock fall time  $t_{DL\varphi}(MR)$ : MREQ delay from falling edge of clock, MREQ low  $t_{S\phi}(D)$ : Data set up time to rising edge of clock during M1 cycle DP8408A and 74S00 Parameters: t<sub>BICL</sub>: RASIN to CAS output delay  $t_{CASDLY}$ : propagation delay of the two 74S00 NAND gates For example, if the Z80A (4 MHz) and the DP8408A are used then. max.  $t_{CAC}$ : 1.5(250) - 85 - 132 - 13 - 50=95 ns min.  $t_{BP}$ : 110 + 20 - 20 = 110 ns min.  $t_{\text{RAS}}\!\!:t_{\text{C}}$  - 50 = 200 ns t<sub>RICL</sub> max.

(mode 6): 132 ns at 15 pF load

t<sub>CASDLY</sub> max.: 13 ns at 50 pF load

Therefore, in this case, the designer should choose a dynamic memory which has maximum  $t_{CAC}$  of 95 ns, minimum  $t_{RP}$  of 110 ns and minimum  $t_{RAS}$  of 200 ns.

# DP8409A and MC68B09E Interface

#### DP8409A OVERVIEW

The DP8409A Dynamic RAM Controller/Driver is designed to control all multiplexed-address dynamic RAMs. It consists of two 9-bit address latches and a 9-bit refresh counter, thus allowing control of all 16k, 64k, and the coming generation 256k dynamic RAMs. More important, all the DP8409A outputs are capable of driving 500 pF loads.

The DP8409A basically has eight modes of operation: Externally Controlled Refresh, Automatic Forced Refresh, Internal Auto Burst Refresh, All  $\overline{\text{RAS}}$  Auto Write, Externally Controlled Access, Auto Access (slow t<sub>RAH</sub> and with hidden refresh), Fast Auto Access (fast t<sub>RAH</sub>) and Set End of Count. Of all these modes, Auto Access (mode 5) and Auto Forced Refresh (mode 1) are the most popular and will be used throughout this application. Mode 5 requires only RASIN to initiate a memory access cycle, because all the

dynamic RAM's control signals are automatically delayed from this input, as shown in *Figure 1*. To attain maximum system throughput, it is obviously advantageous to perform refreshes without interrupting the system. The DP8409A can do this by monitoring the  $\overline{CS}$  input to see if it is high. If  $\overline{CS}$  is high, the RAMs are not being accessed. If  $\overline{CS}$  is high for one cycle, the DP8409A performs a hidden refresh during this cycle, and stops in time for the system to start another access. But if a hidden refresh does not occur in a specific time slot, a refresh must be forced and this can be done by using Mode 1, Automatic Forced Refresh.

To perform automatic forced refresh, the DP8409A must receive two clock signals: the refresh period clock, RFCK, and RGCK, the RAS-generator clock; RGCK can be the microprocessor clock. It takes approximately four RGCK clock periods to perform this automatic forced refresh. The DP8409A gives preference to hidden refresh using RFCK as a level reference. The refresh time slot commences as RFCK goes high. If  $\overline{\rm CS}$  goes high while RFCK is high, the refresh counter is enabled in the address outputs. All four RAS outputs follow RASIN; so to perform a hidden refresh, RASIN must be set low and the refresh counter gets incremented as RASIN goes high. The DP8409A allows only one such hidden refresh to occur with a clock cycle of RFCK to minimize power consumption.

If a hidden refresh does not occur the DP8409A must force a refresh before RFCK begins a new cycle on a low-to-high transition. Therefore, as RFCK goes low (and a hidden refresh has not occurred), RF I/O (Refresh Request) goes low, requesting that a refresh be performed. When the system acknowledges the request, it sets M2 low, and prevents further access to the DP8409A. Then two RGCK negative edges after M2 has gone low, all four  $\overline{\rm RAS}$  outputs go low and remain low for two RGCK clock periods. After all four  $\overline{\rm RAS}$  outputs have gone low, M2 can go high any time to end the Automatic Forced Refresh. The DP8409A allows only one automatic refresh to occur within a clock cycle of BFCK

#### MEMORY ACCESS

The MC68B09E starts a memory access cycle when E goes low, then the memory address becomes valid on the Address Bus A0-15. This address is decoded to provide Chip Select (CS) to the DP8409A. Then Q goes high and sets RASIN low from the PAL® Control Logic as shown in Figure 12. Note that  $\overline{CS}$  must go low for a minimum of 10 ns before the assertion of RASIN for a proper memory access. This is important because a false hidden refresh may take place when this 10 ns minimum setup time is not met. RASIN goes low initiating the auto access sequence as shown in Figure 1. Mode 5 guarantees a 30 ns minimum for row address hold time and a minimum of 8 ns column address set up time. RASIN remains low until E goes low at the end of the current access cycle. Using the 16R6A Programmable Array Logic (25 ns PAL), the maximum access time from CAS of the selected dynamic RAM is determined as follows:

Max. t<sub>CAC</sub>:  $3 \times 125 - 25 - 160 - 40 = 150$  ns 8409A t<sub>CAC</sub>:  $3 \times 125 - 25 - 130 - 40 = 180$  ns 8409A-2 Q high to

E low:  $3 \times 125$  ns (8 MHz clock) = 375 ns

### Q high to

RASIN low: 25 ns (16R6 A PAL Parameter) RASIN to CAS Output low: 160 ns (DP8409A's  $t_{\mbox{RICL}},$  Mode 5, at 500

pF load) 130 ns (DP8409A-2's t<sub>RICL</sub>)

Read data setup

time (before E

going low): 40 ns

# MEMORY REFRESH

As described above, **RASIN** goes active when Q and/or E are high. This scheme, therefore, maximizes chances for hidden refresh because  $\overline{\text{CS}}$  is high during nondynamic memory cycle. For example, when the CPU is executing internal operation or the CPU is accessing ROM or I/O, CS is high during these times. The DP8409A therefore performs a hidden refresh as RASIN goes low, assuming that RFCK is high.

However, if no hidden refresh occurs while RFCK was high, RF I/O goes low immediately after the RFCK high-to-low transition requests a forced refresh. The PAL Control Logic samples RF I/O, when E and Q are high and low respectively, to set M2 (RFSH) low, as shown in Figure 13. Once M2 has gone low, a forced refresh automatically occurs (as described in the DP8409A Overview). M2 remains low for four system clock periods to allow for this forced refresh. If the current microprocessor cycle is a nondynamic memory cycle (CS is high), this refresh is transparent to the microprocessor and STRETCH remains high (E and Q are not stretched). Nevertheless, if the current cycle is a dynamic memory access cycle, STRETCH goes low stretching E and Q for a maximum of four system clocks. RASIN for the pending access will be issued a full system clock after M2 has gone high; this is to allow some RAS precharge time for the dynamic RAM. After this, memory will be accessed in the manner as described in the Memory Access Cycle.



FIGURE 8. NSC800 and DP8408A Interface











## 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:

- 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.
- 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<br>Corporation | National Semiconductor<br>Europe    | National Semiconductor<br>Hong Kong Ltd. | National Semiconductor<br>Japan Ltd. |
|---------------------------------------|-------------------------------------|------------------------------------------|--------------------------------------|
| 1111 West Bardin Road                 | Fax: (+49) 0-180-530 85 86          | 13th Floor, Straight Block,              | Tel: 81-043-299-2309                 |
| Arlington, TX 76017                   | Email: cnjwge@tevm2.nsc.com         | Ocean Centre, 5 Canton Rd.               | Fax: 81-043-299-2408                 |
| Tel: 1(800) 272-9959                  | Deutsch Tel: (+49) 0-180-530 85 85  | Tsimshatsui, Kowloon                     |                                      |
| Fax: 1(800) 737-7018                  | English Tel: (+49) 0-180-532 78 32  | Hong Kong                                |                                      |
|                                       | Francais Tel: (+49) 0-180-532 93 58 | Tel: (852) 2737-1600                     |                                      |
|                                       | Italiano Tel: (+49) 0-180-534 16 80 | Fax: (852) 2736-9960                     |                                      |

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.