

ARCHIVED BY FREESCALE SEMICONDUCTOR, INC. 200 Order this document by

Date: 11/12/98

# **Preliminary**

# Application Note 16bit SRAM Interface

#### INTRODUCTION

This note describes the method of interfacing a 16bit SRAM to DragonBall-EZ (MC68EZ328). The interface is simply constructed by discrete logic gates.

In this note, the EZ68328ADS was used as a development platform and the TOSHIBA TC554161FTL-85 16bit Static Ram was used as an example. The TC554161FTL is 4,194,304 bits static random access memory organized as 262,144 words by 16 bits.

# **HARDWARE**

Figure 1 shows a functional block diagram of the 16 bit SRAM interface.



Figure 1. Block Diagram of the 16 bit SRAM interface

This document contains information on a product under development. Motorola reserves the right to change or discontinue this product without notice.



The logic implemented between the DragonBall -EZ and 16 bit SRAM is shown as following tables:

|                  | *UDS | *LWE | *UWE |
|------------------|------|------|------|
| Write word       | 0    | 0    | 0    |
| Write Upper Byte | 0    | 1    | 0    |
| Write Lower Byte | 1    | 0    | 1    |
| Read             | 0    | 1    | 1    |

Table 1. Logic table for \*UDS

|                  | *LDS | *LWE | *UWE |
|------------------|------|------|------|
| Write word       | 0    | 0    | 0    |
| Write Upper Byte | 1    | 1    | 0    |
| Write Lower Byte | 0    | 0    | 1    |
| Read             | 0    | 1    | 1    |

Table 2. Logic table for \*LDS

| *UWE | *LWE | *OE | R/*W |
|------|------|-----|------|
| 0    | 0    | 0   | 1    |
| 0    | 1    | 0   | 1    |
| 1    | 0    | 0   | 1    |
| 1    | 1    | 0   | 1    |
| 0    | 0    | 1   | 0    |
| 0    | 1    | 1   | 0    |
| 1    | 0    | 1   | 0    |
| 1    | 1    | 1   | 1    |

Table 3. Logic table for R/\*W

4 AND gates and 4 NOT gates are used to implement the above logic. The following schematic shows how to use one 74HC04 and one 74HC08 to implement the logic.





### Note:

Form the schematics and block diagram, we can see that A0 from the SRAM is connected to A18 from the DragonBallEZ. This connection is because of word addressing in 16 bit SRAM.

|    | D15D8 | D7D0 |
|----|-------|------|
| 00 | ab    | cd   |
| 02 |       |      |
| 04 |       |      |
| 06 |       |      |
|    |       |      |

DragonBall-EZ

|     | D15D0 |
|-----|-------|
| 00  | abcd  |
| 001 |       |
| 002 |       |
| 003 |       |
| 004 |       |

16 bit SRAM

As shown in the above, the addressing in DragonBall-EZ and 16 bit SRAM is different. Connecting A0 to A18 can solve this problem. By connecting A0 to A18, the address is always even in 16 bit SRAM. Upper Byte Write and Lower Byte Write only depends on the \*UDS and \*LDS. When write to lower Byte, \*LDS asserts while \*UDS asserts when writing upper byte. For the read operation, \*UDS and \*LDS always assert since reading Lower Byte or Upper Byte depends on DragonBall-EZ only. DragonBall can select to read D0-D7 or D8-D15 itself.

Let us consider the following example, after connecting A0 to A18, the addressing in SRAM becomes:

|     | D15D0       | 0 |
|-----|-------------|---|
| 00  | abcd        |   |
| 002 |             |   |
| 004 |             |   |
| 006 |             |   |
|     |             |   |
|     | 16 bit SRAM |   |

As shown in the above table, there is no odd address, therefore the address line A0-A17 in SRAM is the same when accessing upper byte (0xab)and lower byte(0xcd). But the difference is when write to upper byte \*UDS asserts while \*LDS asserts when write to lower byte.



# INITIALIZATION

Finally here is the source code for initialization.

#### SOURCE CODE

\*\*\*\*\*\*\*\*\*\* \*This program is to initialize 16 bit SRAM \*\*\*\*\*\*\*\*\* M328\_GRPBASEC EQU \$fff104 M328 CSC EQU \$fff114 M328\_CSD \$fff116 EQU M328\_PCSEL EQU \$fff40B M328 DRAMCONT EQU \$fffc02 M328 EXTWE EQU \$fff150

SECTION code

START:

MOVE.W #\$400,M328\_GRPBASEC ;Set CSB Group Base Address
MOVE.W #\$89,M328\_CSC ;Set Chip Select C Register
MOVE.W #\$9d,M328\_CSD ;Disable DRAM
ANDI.B #\$7f,M328\_DRAMCONT ;Disable DRAM controller
ANDI.B #\$fb,M328\_PCSEL ;Enable Chip Select CSC0
ANDI.B #\$7f,M328\_EXTWE ;Extend \*LWE and \*UWE

END