

# **DRAM Controller**

November 11, 1997



NMI Electronics Ltd. Fountain House Great Cornbow Halesowen West Midlands B63 3BL United Kingdom Phone: +44 (0) 121 585 5979 Fax: +44 (0) 121 585 5764 E-mail: ip@nmi.co.uk URL: www.nmi.co.uk

# **Features**

- Single-chip DRAM controller in a Xilinx XC9500 CPLD
  - Easy to use and modify due to predictable XC9500 timing
- Designed for high speed, high performance applications
- Support for burst mode CPU's
- Utilizes fast page mode or EDO DRAM's
- CAS before RAS refresh
- Supports multiple DRAM types
- Available in source code format for ease of customization
- Compatible with industry standard 72 pin SIMM's

# **Applications**

- Embedded systems in industrial, telecommunications, test or point-of-sale applications
- · High performance peripheral equipment, e.g. printers

**Product Specification** 

| AllianceCORE™ Facts                   |                                                                   |                      |  |  |
|---------------------------------------|-------------------------------------------------------------------|----------------------|--|--|
| Core Specifics                        |                                                                   |                      |  |  |
| Device Family                         |                                                                   | XC9500               |  |  |
| Macrocells Used                       | 75 <sup>1,4</sup>                                                 |                      |  |  |
| IOBs Used                             |                                                                   | 58 <sup>1</sup>      |  |  |
| System Clock fmax                     |                                                                   | 50+ MHz <sup>2</sup> |  |  |
| Device Features<br>Used               | GCLK                                                              |                      |  |  |
| Supported Dev                         | vices/Resources                                                   | Remaining            |  |  |
|                                       | I/O                                                               | Macrocells           |  |  |
| XC95216-15<br>HQ208C <sup>3</sup>     | 110 <sup>1</sup>                                                  | 141 <sup>1</sup>     |  |  |
| Pro                                   | vided with Core                                                   |                      |  |  |
| Documentation                         | Design User Guide<br>Sample files for top level module in<br>VHDL |                      |  |  |
| Design File Formats                   | VHDL source code                                                  |                      |  |  |
| Verification Tool                     | Viewlogic ViewSim                                                 |                      |  |  |
| Schematic Symbols                     |                                                                   | None                 |  |  |
| Evaluation Model                      | Evaluation Board available extra                                  |                      |  |  |
| Reference designs & application notes | Application notes included in<br>Design User Guide                |                      |  |  |
| Additional Items                      | TimingDesigner™ design file                                       |                      |  |  |
| Desigr                                | Tool Requireme                                                    | nts                  |  |  |
| Xilinx Core Tools                     | XACTstep M1.3                                                     |                      |  |  |
| Entry/Verification<br>Tool            | Viewlogic Workview Office™7.4                                     |                      |  |  |
|                                       | Support                                                           |                      |  |  |
| 90 days e-mail and te                 | lenhone support fr                                                | om NMI Electron      |  |  |

90 days e-mail and telephone support from NMI Electronics included in the Core price. Support does not cover user core modifications; please refer to "Core Modifications" section. Maintenance contracts available.

#### Notes:

- 1. Assumes default configuration, see Functional Description.
- Depends on device speed selected and other system device speeds. 50MHz operation has been verified with the i486DX4<sup>™</sup> and XC95216-15. 40MHz operation has been verified with the same system and XC95216-20.
- 3. The core has been proven in this device but will work in any XC9500 device with sufficient resources.
- 4. This number can vary slightly due to device utilization and fitter settings. Typically the number of macrocells varies between 70 and 75 but may be higher in devices with a high utilization and/or speed requirement.



Figure 1: DRAM Controller Block Diagram

# **General Description**

The DRAM Controller is extremely flexible and can be configured to be used with most DRAM types, most microprocessors and many other applications, see Core Modifications.

# **Functional Description**

The DRAM Controller is supplied as a single, VHDL source code module. The functional blocks shown in Figure 1 are for descriptive purposes only.

The default configuration of the DRAM Controller is as follows:

- i486<sup>™</sup>-like CPU interface, including burst mode
- Two bank, 32 bit wide, 72 pin SIMM compatible DRAM control signals
- Support for 256K, 1M and 4M bit deep DRAM's

#### Synchronous CPU Interface

In order to achieve maximum performance the DRAM Controller utilizes a fully synchronous interface to its host CPU or control logic. This does not, however, prevent the user from adding extra logic to create an asynchronous interface.

### **Main State Machine**

The DRAM Controller is state machine driven. The state machine, along with the input clock frequency, controls the timing of the DRAM signals.

#### **Refresh Synchronization**

Refresh requests are not automatically generated by the DRAM Controller as these can often be generated using other, lower frequency clocks which are available in many typical system designs. Due to this fact, the DRAM Controller fully supports asynchronous refresh request inputs.

### **DRAM Control Signals**

The DRAM control signals RAS, CAS and WE are synchronously generated from the state machine outputs. Burst mode is supported using page mode, refresh utilizes CASbefore-RAS, while writes use "early write" mode.

#### **DRAM Address Multiplexer**

The DRAM address multiplexer can be configured to support most DRAM sizes and organizations. The Design User Guide describes this process in detail.

#### **Table 1: Core Signal Pinout**

| Signal                | Signal<br>Direction | Description                                                                                                                                                                                                           |
|-----------------------|---------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| CLOCK                 | Input               | Primary system clock; rising edge triggered.                                                                                                                                                                          |
| SYNC_RES <sup>1</sup> | Input               | System reset, synchronous to CLOCK; active High.                                                                                                                                                                      |
| BS                    | Input               | Bus cycle start signal; active<br>High. One CLOCK period<br>wide. Identical to inverse of<br>i486 <sup>™</sup> ADS signal.                                                                                            |
| W_R <sup>1</sup>      | Input               | System read or write cycle<br>indicator. Cannot change<br>state during whole bus cycle,<br>or during a complete burst<br>sequence;<br>0=read<br>1=write.                                                              |
| BLAST <sup>1</sup>    | Input               | Burst last indicator. Active<br>High for last bus cycle in a<br>burst sequence.                                                                                                                                       |
| BE[3:0]1              | Input               | Byte enable signals for de-<br>fault, 32 bit configuration.<br>Writes are gated by state of<br>byte enables; however all<br>reads return 32 bit data; ac-<br>tive Low.                                                |
| DRAM_CS <sup>1</sup>  | Input               | Select signal for DRAM Con-<br>troller; active High. Must be<br>active while BS is active for<br>DRAM Controller to respond<br>to a bus cycle. Usually driven<br>by an address decode.                                |
| A[24:2] <sup>1</sup>  | Input               | System address lines for de-<br>fault, 32 bit configuration; ac-<br>tive High.                                                                                                                                        |
| SIZE[1:0]             | Input               | DRAM module size selection<br>inputs. These should not be<br>changed during normal sys-<br>tem operation. For default<br>configuration these are:<br>00 - 256 KBit DRAM's<br>01 - 1 MBit DRAM's<br>1x - 4 MBit DRAM's |
| REFREQ                | Input               | Refresh request input; active<br>High. May be asynchronous<br>to CLOCK, and is rising edge<br>triggered. Typical period is<br>15.625 microseconds maxi-<br>mum.                                                       |

| Signal   | Signal<br>Direction | Description                                                                                                                                                                                                                                                   |
|----------|---------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| RAS[3:0] | Output              | DRAM RAS outputs; active<br>Low. To be compatible with<br>standard 72 pin SIMM's,<br>RAS0 and RAS1 are func-<br>tionally identical and drive<br>half of the first bank of<br>DRAM's each. RAS2 and<br>RAS3 drive half of the sec-<br>ond bank of DRAM's each. |
| CAS[3:0] | Output              | DRAM CAS outputs; active<br>Low; Configured for fast<br>page mode operation by de-<br>fault and used in early-write<br>mode, when CAS activation<br>is gated by their respective<br>BE's.                                                                     |
| WE       | Output              | DRAM WE output; active<br>Low. DRAM Controller uses<br>early-write mode, so WE is<br>used as an indicator only.                                                                                                                                               |
| MA[10:0] | Output              | Multiplexed row and column<br>address outputs; active High.<br>Multiplexing scheme deter-<br>mined by state of SIZE in-<br>puts.                                                                                                                              |
| READY    | Output              | System Ready output; active<br>High. Default configuration is<br>for i486 <sup>™</sup> microprocessor.<br>Output is usually system host<br>specific.                                                                                                          |
| RDYOE    | Output              | System Ready 3-state en-<br>able output; active High. De-<br>fault configuration utilizes a<br>3-state driver for System<br>Ready. Output is usually sys-<br>tem host specific.                                                                               |

Note:

1. These signals must be applied synchronously to CLOCK.

# **Core Modifications**

As supplied, the DRAM Controller is designed for optimum performance in the 40MHz to 50MHz range, using 70ns fast-page-mode DRAM's. The system interface is i486<sup>TM</sup>-like.

Many system designs will require that the core be modified before it can be used, especially with regard to the system interface. For this reason the core is supplied in source code format, and has been written with modification in mind.

The Design User Guide supplied with the core describes in detail how the core can be modified for different system

interfaces, different clock speeds and different DRAM types and speeds.

Please note that NMI support does not cover user core modifications. NMI offers design services, including core modifications, for additional cost.

### **Pinout**

The pin functions of the DRAM Controller core in its default configuration are shown in Table 1. The pinout is not fixed to any specific CPLD I/O, and can generally be modified to suit the user's application.

Signal names are provided in the block diagram shown in Figure 1, and described in Table 1.

# **Verification Methods**

Both functional and timing simulation have been carried out using ViewSim under Viewlogic Workview Office<sup>™</sup>. Simulation vectors used for verification are provided with the core in the form of ViewSim command files.

The core has been extensively tested on target hardware using an NMI developed evaluation card.

# **Recommended Design Experience**

Users should be familiar with VHDL and Xilinx design flows. Experience with microprocessor or similar system design is recommended. The core can easily be integrated into hierarchical VHDL designs.

# **Available Support Products**

NMI has developed a Xilinx core evaluation card and this will be available, at additional cost, in the near future.

# **Ordering Information**

To make further enquiries or purchase the DRAM Controller Core, please contact NMI directly at the location detailed on the front page. NMI also offers core integration and design services, the latter covering not only CPLD and FPGA design but also complete systems design.

NMI cores are purchased under a Licence Agreement, copies of which are available on request.

### **Related Information**

#### Xilinx Programmable Logic

For information on Xilinx programmable logic or development system software, contact your local Xilinx sales office, or:

Xilinx, Inc. 2100 Logic Drive San Jose, CA 95124 Phone: +1 408-559-7778 Fax: +1 408-559-7114 URL: www.xilinx.com

For general Xilinx literature, contact:

| Phone:  | +1 800-231-3386 (inside the US)  |
|---------|----------------------------------|
|         | +1 408-879-5017 (outside the US) |
| E-mail: | literature@xilinx.com            |

For AllianceCORE<sup>TM</sup> specific information, contact:

| Phone: | +1 | 408-879-5381 |
|--------|----|--------------|
|--------|----|--------------|

URL: www.xilinx.com/products/logicore/alliance/ tblpart.htm