# Interfacing the DP8441 and the 68040

National Semiconductor Application Note 901 Atilio Canessa June 1993



nterfacing the DP8441 and the 68040

This application notes assumes that the reader is familiar with the modes of operation of the DP8441 DRAM controller and the 68040 microprocessor. The nature of this application note is to give the system designer an idea of a possible memory configuration. After reading this application note, the system designer must do an analysis for his particular application.

The design's operating frequency is 33 MHz and the design supports page and burst accesses. The design constitutes a complete 128 Megabytes memory system in a 2 bank configuration. The memory array uses 70 ns DRAMs in a 16 Megx1 architecture. Different or more compact memory arrays can be achieved if different DRAMs are used.

The DP8441 performs all housekeeping required by DRAMs. The controller will refresh the memory and it will guarantee precharge times after accesses or refresh cycles. The DP8441 also arbitrates between accesses, refreshes and precharge. The DRAM controller will insert wait states into an access cycle to allow refresh or precharge to take place. The controller will delay a refresh to allow an access in progress to finish.

The DP8441 supports byte, word or double-word writing. This is done through decoding the 68040's A0, A1, SIZ0 and SIZ1 outputs and connect the appropriate  $\overline{BE}$  (byte enables) to the ECAS inputs in the DP8441. ECAS controls the CASs to the DRAMs.The DP8441 also supports the 68040 Read-Modify-Write (LOCKED cycle), this is done by connecting the LOCK output from the 68040 to DISRFSH input on the DP8441. This guarantees that a refresh will not brake a Read-Modify-Write cycle.

#### RESET AND PROGRAMMING

Resetting the DRAM controller is accomplished by asserting low the RESET input for at least 16 clock cycles. The DP8441 must be programmed before accessing the memory. Programming can be done by writing to an I/O address equal to the programming selection. Programming can also be accomplished during the first memory write. In the latter case the CPU writes to an address equal to the programming selection during the first write cycle after power up.

After  $\overline{\text{ML}}$  negates during the programming cycle, the DP8441 enters a 60 ms initialization period. This period is when the Phase Lock Loop (PLL) locks into place.

The system must wait at least 70 ms before accessing the memory. During this time the DRAM controller performs refreshes to the memory, this makes further "warm up" cycles unnecessary.

### **OPENING ACCESS**

A memory access begins when the 68040 outputs a valid address and asserts  $\overline{\text{ADS}}$ . For this design at 33 MHz, the address, the B0 (bank select) and the  $\overline{\text{ADS}}$  inputs meet the set up times required by the DRAM controller. Three address lines are used to do DRAM  $\overline{\text{CS}}$ . The  $\overline{\text{CS}}$  setup time is also met.

The DP8441 will split the address from the CPU and will output the row address to the DRAMs. The appropriate RAS,

as decoded by B0, will assert from the next rising clock edge latching the row address into the DRAM. The programmed  $t_{\rm RAH}$  will be guaranteed by the controller before switching the internal multiplexor to the column address. The controller latches the column address into the DRAM after meeting the  $t_{\rm CSC}$ . The  $t_{\rm RAH}, t_{\rm CSC}$  and the time when the controller switches the row address to the column address is guaranteed by the on board delay line based on the PLL.

The controller asserts  $\overline{\text{DTACK}}$  after the programmed number of wait states to indicate to the CPU that the access can finish. In this design,  $\overline{\text{DTACK}}$  asserts from the 3rd rising clock edge. The  $\overline{\text{DTACK}}$  setup time required by the CPU is easily met. At the end of the fourth clock the 68040 will either latch the data into its registers in the case of a read cycle, or it will take the data of the bus in the case of a write cycle. For every access,  $\overline{\text{DTACK}}$  asserts for one clock period, and  $\overline{\text{CAS}}$  negates from the same clock edge that  $\overline{\text{DTACK}}$  negates.

## PAGE ACCESSES

Every access finishes when DTACK asserts. In this application note, the DRAM controller is programmed in page mode, thus when DTACK negates, only CAS negate and RAS stays asserted. When the CPU requests a new access (a new address and a new ADS), if this new access is within the same page as the previous access (same row address), a page hit is detected by the on-board page comparator. When there is a page hit, RAS stays asserted and the controller outputs the new column address and asserts CAS from the next rising clock edge. In cases when there is a page miss, the DP8441 negates RAS, meets the programmed number of clock cycles for precharge, and then asserts RAS to latch the new row address into memory. In either case DTACK will assert and negate after the appropriate number of programmed wait states (DATCK for page accesses or for opening accesses).

# **BURST ACCESSES**

The 68040 indicates that it wants to burst when the attributes SIZ0 and SIZ1 are both 1. The system's glue logic decodes SIZ0 and SIZ1 and generates BSTREQ (a simple AND gate is used). BSTREQ asserted makes the DRAM controller to increment the column address every time  $\overline{\text{DTACK}}$  negates. The DRAM controller will automatically assert  $\overline{\text{CAS}}$  to latch the new column address into memory.  $\overline{\text{CAS}}$  precharge is guaranteed by the on-board delay line, and in this design it is programmed to be 10 ns minimum. The DP8441 will burst for as long as BSTREQ is asserted. Every burst access finishes with the assertion and negation of  $\overline{\text{DTACK}}$ .

### **REFRESH AND PRECHARGE**

The DP844I will request a memory refresh every 15  $\mu s.$  During refresh, RAS will be low for 3 clock periods. The controller will also guarantee precharge of 3 clock periods. These timings are enough for 70 ns DRAMs. If the controller is in the middle of a page mode access (RAS asserted but no

AN-90

real access may be in progress) the controller will keep track of all missed refresh requests. When there is an access out of page, the DRAM controller will burst refresh the memory the number of refresh requests missed. If the inpage access is idle and there is a sixth refresh request, the DRAM controller will automatically finish the access, meet the precharge time, and burst refresh the memory six times.

# PROGRAMMING BITS

| TABLE I.                     |                                                                                                                           |  |
|------------------------------|---------------------------------------------------------------------------------------------------------------------------|--|
| R1, R0<br>0, 1               | RAS Low and Precharge Time<br>3Ts                                                                                         |  |
| R3, R2<br>0, 1               | DTACK during Opening Access Will<br>Assert after RAS<br>2Ts                                                               |  |
| R5, R4<br>0, 1               | DTACK during Burst Access Will<br>Toggle with CAS<br>1T                                                                   |  |
| R7, R6<br>0, 1               | DTACK during Page Access Will<br>Assert after CAS<br>1T                                                                   |  |
| R8, R9<br>1, 1               | Page Size Select to 4096 for<br>16 Meg DRAMs                                                                              |  |
| R11, R10<br>0, 1             | Wrap around Size Select 4<br>(00 01 10 11)                                                                                |  |
| C3, C2, C1, C0<br>0, 1, 0, 0 | Divisor Select for DELCLK to Get<br>Close to 2 MHz<br>15(30/16 = 2)                                                       |  |
| C5, C4<br>1, 1               | B0 Is Not Used. Staggered Refresh<br>B1 = 1 $\rightarrow$ RAS 0,1 CAS 0,1,4,5<br>B1 = 1 $\rightarrow$ RAS 2,3 CAS 2,3,6,7 |  |

| TABLE I. (Continued) |                                                                                |  |
|----------------------|--------------------------------------------------------------------------------|--|
| C6<br>0              | Staggered Refresh Selected                                                     |  |
| C7<br>0              | $t_{RAH} = 10 \text{ ns}$                                                      |  |
| C8<br>1              | Page Miss Output Selected                                                      |  |
| C9<br>0              | CAS Precharge Time during Burst<br>1/2T during Read and 1T during Write        |  |
| C10<br>0             | RAS Only Refresh Selected                                                      |  |
| C11<br>0             | 15 $\mu$ s Refresh Period                                                      |  |
| B0<br>1              | DTACK Rising Edge Increments the<br>Column Counter                             |  |
| B1                   | Page Mode Selected                                                             |  |
| ECAS0<br>0           | Latch Mode Selected to Be Able to<br>Increment the Column Counter during Burst |  |
| ECAS1<br>1           | Burst Request Select Is Active High                                            |  |
| ECAS2<br>0           | CAS and DTACK Clock Edge Select Is the<br>Rising Clock Edge                    |  |

| ТІМ  | IINGS FOR THE 68040 AND THE DP8440/41 INTERFACE DRAM CONTROLLER RUNNING AT 33 MHz                                                                            |
|------|--------------------------------------------------------------------------------------------------------------------------------------------------------------|
| (1)  | Minimum ADS Low Setup Time to CLK High.                                                                                                                      |
|      | 1 CLK Period $-$ CLK High to $\overline{TS}$ Asserted (68040)                                                                                                |
|      | 30.3 ns - 19 ns                                                                                                                                              |
|      | 11.3 ns The DP8440/41 need only 6 ns                                                                                                                         |
| (2)  | Minimum Address Valid Setup Time to CLK High.                                                                                                                |
|      | 1 CLK Period – CLK High to Address Valid (68040)                                                                                                             |
|      | 30.3 ns - 19 ns                                                                                                                                              |
|      | 11.3 ns The DP8440/41 need only 10 ns                                                                                                                        |
| (3)  | Minimum CS Asserted Setup Time to CLK High.                                                                                                                  |
| . ,  | 1 CLK Period – (CLK High to Address Valid + Decoder Delay)                                                                                                   |
|      | 30.3 ns - (19 ns + 7 ns)                                                                                                                                     |
|      | 30.3 ns - 26 ns                                                                                                                                              |
|      | 4.3 ns The DP8440/41 need only 4 ns                                                                                                                          |
| (4)  | Wait States through TA during Opening Accesses.                                                                                                              |
| (.)  | (4a) Access Time from RAS                                                                                                                                    |
|      | 1 CLK Period + CLK High to RAS Asserted (DP8440/41) + DRAM t <sub>RAC</sub> + Data Setup Time (68040)                                                        |
|      | 30.3  ns + 15  ns + 70  ns + 5  ns                                                                                                                           |
|      | $120.3 \rightarrow 4$ CLK Periods (121.2 ns)                                                                                                                 |
|      | (4b) Access Time from CAS                                                                                                                                    |
|      | 1 CLK Period + CLK to CAS Asserted (DP8440/41) + DRAM t <sub>CAC</sub> + Data Setup Time (68040)                                                             |
|      | 30.3  ns + 55  ns + 20  ns + 5  ns                                                                                                                           |
|      | 110.3 ns $\rightarrow$ 4 CLK Periods (121.2 ns)                                                                                                              |
|      | (4c) Access Time from Column Address Valid                                                                                                                   |
|      | 1 CLK Period + CLK High to Column Address Valid (DP8440/41) + DRAM t <sub>AA</sub> + Data Setup Time (68040)                                                 |
|      | 30.3 ns + 51 ns + 35 ns + 5 ns                                                                                                                               |
|      | 121.3 ns $\rightarrow$ 4 CLK Periods (121.2 ns)                                                                                                              |
| Fro  | m 4a, 4b and 4c, DTACK should assert from the 3rd rising CLK edge. Therefore program DTACK during opening accesses                                           |
| as 2 |                                                                                                                                                              |
|      | TA Setup Time (68040)                                                                                                                                        |
| (-)  | 1 CLK Period – DTACK Asserted from CLK High                                                                                                                  |
|      | 30.3 ns - 12 ns                                                                                                                                              |
|      | 18.3 ns The 68040 needs only 10 ns                                                                                                                           |
| (6)  | /CAS Precharge during Burst Accesses                                                                                                                         |
| (-)  | Program the DP8440/41 for 1/2T of CAS precharge. It will guarantee a minimum of 10 ns.                                                                       |
| (7)  | Wait States through TA during Burst Accesses.                                                                                                                |
| (,,) | CLK High to CAS Negated + Max CAS Precharge ( $\frac{1}{2}$ T) + DRAM t <sub>CAC</sub> + Data Setup Time (68040)                                             |
|      | 12  ns + 14  ns + 20  ns + 5  ns                                                                                                                             |
|      | 41 ns $\rightarrow$ 2 CLK Periods (60.6 ns), needs 1 Wait State                                                                                              |
| (8)  | Wait States through TA during Page Accesses                                                                                                                  |
| (0)  | 1 CLK Period – (CLK High to CAS Asserted + DRAM t <sub>CAC</sub> + Data Setup)                                                                               |
|      | 30.3  ns - (12  ns + 20  ns + 5  ns)                                                                                                                         |
|      | $-6.7 \text{ ns} \rightarrow 1$ Wait State. Page Accesses take 3 CLKs                                                                                        |
| (9)  | RAS Low during Refresh                                                                                                                                       |
| (0)  | Program the DP8440/41 for 3T of refresh to guarantee 70 ns t <sub>RAS</sub> . Same number of CLKs for precharge.                                             |
| Note | The timing analysis was done with preliminary AC specs, prior to final characterization of the DP8440/41. The reader is required to check AC timing from the |
|      | latest DP8440/41 data sheet.                                                                                                                                 |
|      |                                                                                                                                                              |
|      |                                                                                                                                                              |
|      |                                                                                                                                                              |
|      |                                                                                                                                                              |
|      |                                                                                                                                                              |
|      |                                                                                                                                                              |
|      |                                                                                                                                                              |
|      |                                                                                                                                                              |
|      |                                                                                                                                                              |







Interfacing the DP8441 and the 68040

AN-901



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.