

# 2. TriMatrix Embedded Memory Blocks in Stratix II and Stratix II GX Devices

SII52002-4.5

## Introduction

Stratix<sup>®</sup> II and Stratix II GX devices feature the TriMatrix<sup>TM</sup> memory structure, consisting of three sizes of embedded RAM blocks that efficiently address the memory needs of FPGA designs.

TriMatrix memory includes 512-bit M512 blocks, 4-Kbit M4K blocks, and 512-Kbit M-RAM blocks, which are each configurable to support many features. TriMatrix memory provides up to 9 megabits of RAM at up to 550 MHz operation, and up to 16 terabits per second of total memory bandwidth per device. This chapter describes TriMatrix memory blocks, modes, and features.

# TriMatrix Memory Overview

The TriMatrix architecture provides complex memory functions for different applications in FPGA designs. For example, M512 blocks are used for first-in first-out (FIFO) functions and clock domain buffering where memory bandwidth is critical; M4K blocks are ideal for applications requiring medium-sized memory, such as asynchronous transfer mode (ATM) cell processing; and M-RAM blocks are suitable for large buffering applications, such as internet protocol (IP) packet buffering and system cache.

The TriMatrix memory blocks support various memory configurations, including single-port, simple dual-port, true dual-port (also known as bidirectional dual-port), shift register, and read-only memory (ROM) modes. The TriMatrix memory architecture also includes advanced features and capabilities, such as parity-bit support, byte enable support, pack mode support, address clock enable support, mixed port width support, and mixed clock mode support.

When applied to input registers, the asynchronous clear signal for the TriMatrix embedded memory immediately clears the input registers. However, the output of the memory block does not show the effects until the next clock edge. When applied to output registers, the asynchronous clear signal clears the output registers and the effects are seen immediately.

Table 2–1 summarizes the features supported by the three sizes of TriMatrix memory.

| Feature Feature                        | M512 Blocks                               | M4K Blocks                                | M-RAM Blocks                              |
|----------------------------------------|-------------------------------------------|-------------------------------------------|-------------------------------------------|
| Maximum performance                    | 500 MHz                                   | 550 MHz                                   | 420 MHz                                   |
| Total RAM bits (including parity bits) | 576                                       | 4,608                                     | 589,824                                   |
| Configurations                         | 512 × 1                                   | 4K × 1                                    | 64K × 8                                   |
| oomigaration:                          | 256 × 2                                   | 2K × 2                                    | 64K × 9                                   |
|                                        | 128 × 4                                   | 1K × 4                                    | 32K × 16                                  |
|                                        | 64 × 8                                    | 512 × 8                                   | 32K × 18                                  |
|                                        | 64 × 9                                    | 512 × 9                                   | 16K × 32                                  |
|                                        | 32 × 16                                   | 256 × 16                                  | 8K × 64                                   |
|                                        | 32 × 18                                   | 256 × 18                                  | 8K × 72                                   |
|                                        |                                           | 128 × 32                                  | 4K × 128                                  |
|                                        |                                           | 128 × 36                                  | 4K × 144                                  |
| Parity bits                            | ✓                                         | ✓                                         | ✓                                         |
| Byte enable                            | <b>✓</b>                                  | <b>✓</b>                                  | <b>✓</b>                                  |
| Pack mode                              |                                           | <b>✓</b>                                  | <b>✓</b>                                  |
| Address clock enable                   |                                           | <b>✓</b>                                  | <b>✓</b>                                  |
| Single-port memory                     | ✓                                         | <b>✓</b>                                  | ~                                         |
| Simple dual-port memory                | ✓                                         | ✓                                         | <b>✓</b>                                  |
| True dual-port memory                  |                                           | <b>✓</b>                                  | <b>✓</b>                                  |
| Embedded shift register                | <b>✓</b>                                  | <b>✓</b>                                  |                                           |
| ROM                                    | ✓                                         | <b>✓</b>                                  |                                           |
| FIFO buffer                            | <b>✓</b>                                  | <b>✓</b>                                  | <b>✓</b>                                  |
| Simple dual-port mixed width support   | <b>✓</b>                                  | <b>✓</b>                                  | <b>✓</b>                                  |
| True dual-port mixed width support     |                                           | <b>✓</b>                                  | <b>✓</b>                                  |
| Memory initialization file (.mif)      | <b>✓</b>                                  | <b>✓</b>                                  |                                           |
| Mixed-clock mode                       | ✓                                         | <b>✓</b>                                  | ~                                         |
| Power-up condition                     | Outputs cleared                           | Outputs cleared                           | Outputs unknown                           |
| Register clears                        | Output registers only                     | Output registers only                     | Output registers only                     |
| Same-port read-during-write            | New data available at positive clock edge | New data available at positive clock edge | New data available at positive clock edge |
| Mixed-port read-during-write           | Outputs set to unknown or old data        | Outputs set to unknown or old data        | Unknown output                            |

Tables 2–2 and 2–3 show the capacity and distribution of the TriMatrix memory blocks in each Stratix II and Stratix II GX family member, respectively.

| Table 2–2. TriMatrix Memory Capacity and Distribution in Stratix II Devices |                        |                       |                 |                |  |  |
|-----------------------------------------------------------------------------|------------------------|-----------------------|-----------------|----------------|--|--|
| Device                                                                      | M512<br>Columns/Blocks | M4K<br>Columns/Blocks | M-RAM<br>Blocks | Total RAM Bits |  |  |
| EP2S15                                                                      | 4/104                  | 3/78                  | 0               | 419,328        |  |  |
| EP2S30                                                                      | 6/202                  | 4/144                 | 1               | 1,369,728      |  |  |
| EP2S60                                                                      | 7/329                  | 5/255                 | 2               | 2,544,192      |  |  |
| EP2S90                                                                      | 8/488                  | 6/408                 | 4               | 4,520,448      |  |  |
| EP2S130                                                                     | 9/699                  | 7/609                 | 6               | 6,747,840      |  |  |
| EP2S180                                                                     | 11/930                 | 8/768                 | 9               | 9,383,040      |  |  |

| Table 2–3. Tri<br>Devices           | Matrix Memory Ca       | pacity and Distribu   | ution in St     | ratix II GX    |
|-------------------------------------|------------------------|-----------------------|-----------------|----------------|
| Device                              | M512<br>Columns/Blocks | M4K<br>Columns/Blocks | M-RAM<br>Blocks | Total RAM Bits |
| EP2SGX30C<br>EP2SGX30D              | 6/202                  | 4/144                 | 1               | 1,369,728      |
| EP2SGX60C<br>EP2SGX60D<br>EP2SGX60E | 7/329                  | 5/255                 | 2               | 2,544,192      |
| EP2SGX90E<br>EP2SGX90F              | 8/488                  | 6/408                 | 4               | 4,520,448      |
| EP2SGX130G                          | 9/699                  | 7/609                 | 6               | 6,747,840      |

## **Parity Bit Support**

All TriMatrix memory blocks (M512, M4K, and M-RAM) support one parity bit for each byte.

Parity bits add to the amount of memory in each random access memory (RAM) block. For example, the M512 block has 576 bits, 64 of which are optionally used for parity bit storage. The parity bit, along with logic implemented in adaptive logic modules (ALMs), implements parity checking for error detection to ensure data integrity. Parity-size data words can also be used for other purposes such as storing user-specified control bits.



Refer to the *Using Parity to Detect Memory Errors* white paper for more information on using the parity bit to detect memory errors.

## **Byte Enable Support**

All TriMatrix memory blocks support byte enables that mask the input data so that only specific bytes, nibbles, or bits of data are written. The unwritten bytes or bits retain the previous written value. The write enable (wren) signals, along with the byte enable (byteena) signals, control the RAM blocks' write operations. The default value for the byte enable signals is high (enabled), in which case writing is controlled only by the write enable signals. There is no clear port to the byte enable registers.

#### M512 Blocks

M512 blocks support byte enables for data widths of 16 and 18 bits only. For memory block configurations with widths of less than two bytes ( $\times 16/\times 18$ ), the byte-enable feature is not supported. For memory configurations less than two bytes wide, the write enable or clock enable signals can optionally be used to control the write operation. Table 2–4 summarizes the byte selection.

| Table 2–4. Byte Enable for Stratix II and Str | atix II GX M512 Bi | locks Note (1) |
|-----------------------------------------------|--------------------|----------------|
| byteena[10]                                   | data ×16           | data ×18       |
| [0] = 1                                       | [70]               | [80]           |
| [1] = 1                                       | [158]              | [179]          |

Note to Table 2-4:

(1) Any combination of byte enables is possible.

#### M4K Blocks

M4K blocks support byte enables for any combination of data widths of 16, 18, 32, and 36 bits only. For memory block configurations with widths of less than two bytes ( $\times 16/\times 18$ ), the byte-enable feature is not supported. For memory configurations less than two bytes wide, the write enable or clock enable signals can optionally be used to control the write operation.

Table 2–5 summarizes the byte selection.

| Table 2–5. Byte Enable for Stratix II and Stratix II GX M4K Blocks Note (1) |                                     |       |        |        |  |  |  |
|-----------------------------------------------------------------------------|-------------------------------------|-------|--------|--------|--|--|--|
| byteena<br>[30]                                                             | data ×16 data ×18 data ×32 data ×36 |       |        |        |  |  |  |
| [0] = 1                                                                     | [70]                                | [80]  | [70]   | [80]   |  |  |  |
| [1] = 1                                                                     | [158]                               | [179] | [158]  | [179]  |  |  |  |
| [2] = 1                                                                     | -                                   | ı     | [2316] | [2618] |  |  |  |
| [3] = 1                                                                     | -                                   | ı     | [3124] | [3527] |  |  |  |

*Note to Table 2–5:* 

#### M-RAM Blocks

M-RAM blocks support byte enables for any combination of data widths of 16, 18, 32, 36, 64, and 72 bits. For memory block configurations with widths of less than two bytes ( $\times 16/\times 18$ ), the byte-enable feature is not supported. In the  $\times 128$  and  $\times 144$  simple dual-port modes, the two sets of byte enable signals (byteena\_a and byteena\_b) combine to form the necessary 16 byte enables. In  $\times 128$  and  $\times 144$  modes, byte enables are only supported when using single clock mode. However, the Quartus II software can implement byte enables in other clocking modes for  $\times 128$  or  $\times 144$  widths but will use twice as many M-RAM resources. If clock enables are used in  $\times 128$  or  $\times 144$  mode, you must use the same clock enable setting for both the A and B ports. Table 2–6 summarizes the byte selection for M-RAM blocks.

| Table 2–6. Byt | te Enable for Stra | tix II and Stratix | II GX M-RAM BI | ocks Note (1, | )        |          |
|----------------|--------------------|--------------------|----------------|---------------|----------|----------|
| byteena        | data ×16           | data ×18           | data ×32       | data ×36      | data ×64 | data ×72 |
| [0] = 1        | [70]               | [80]               | [70]           | [80]          | [70]     | [80]     |
| [1] = 1        | [158]              | [179]              | [158]          | [179]         | [158]    | [179]    |
| [2] = 1        | _                  | -                  | [2316]         | [2618]        | [2316]   | [2618]   |
| [3] = 1        | _                  | -                  | [3124]         | [3527]        | [3124]   | [3527]   |
| [4] = 1        | _                  | -                  | -              | -             | [3932]   | [4436]   |
| [5] = 1        | _                  | -                  | -              | -             | [4740]   | [5345]   |
| [6] = 1        | -                  | -                  | -              | -             | [5548]   | [6254]   |
| [7] = 1        | _                  | -                  | -              | -             | [6356]   | [7163]   |

Note to Table 2-6:

<sup>(1)</sup> Any combination of byte enables is possible.

<sup>(1)</sup> Any combination of byte enables is possible.

Table 2–7 summarizes the byte selection for  $\times 144$  mode.

| Table 2–7. Stratix II al<br>×144 Mode Note (1) | nd Stratix II GX M-RAM Comi | bined Byte Selection for |
|------------------------------------------------|-----------------------------|--------------------------|
| byteena                                        | data ×128                   | data ×144                |
| [0] = 1                                        | [70]                        | [80]                     |
| [1] = 1                                        | [158]                       | [179]                    |
| [2] = 1                                        | [2316]                      | [2618]                   |
| [3] = 1                                        | [3124]                      | [3527]                   |
| [4] = 1                                        | [3932]                      | [4436]                   |
| [5] = 1                                        | [4740]                      | [5345]                   |
| [6] = 1                                        | [5548]                      | [6254]                   |
| [7] = 1                                        | [6356]                      | [7163]                   |
| [8] = 1                                        | [7164]                      | [8072]                   |
| [9] = 1                                        | [7972]                      | [8973]                   |
| [10] = 1                                       | [8780]                      | [9890]                   |
| [11] = 1                                       | [9588]                      | [10799]                  |
| [12] = 1                                       | [10396]                     | [116108]                 |
| [13] = 1                                       | [111104]                    | [125117]                 |
| [14] = 1                                       | [119112]                    | [134126]                 |
| [15] = 1                                       | [127120]                    | [143135]                 |

*Note to Table 2–7:* 

#### Byte Enable Functional Waveform

Figure 2–1 shows how the write enable (wren) and byte enable (byteena) signals control the operations of the RAM.

When a byte enable bit is de-asserted during a write cycle, the corresponding data byte output appears as a "don't care" or unknown value. When a byte enable bit is asserted during a write cycle, the corresponding data byte output will be the newly written data.

<sup>(1)</sup> Any combination of byte enables is possible.



Figure 2–1. Stratix II and Stratix II GX Byte Enable Functional Waveform

For more information about MRAM and byte enable for the Stratix II device family, refer to the *Stratix II FPGA Errata Sheet* at the Altera web site at www.altera.com.

## **Pack Mode Support**

Stratix II and Stratix II GX M4K and M-RAM memory blocks support pack mode. In M4K and M-RAM memory blocks, two single-port memory blocks can be implemented in a single block under the following conditions:

- Each of the two independent block sizes is equal to or less than half of the M4K or M-RAM block size.
- Each of the single-port memory blocks is configured in single-clock mode.

Thus, each of the single-port memory blocks access up to half of the M4K or M-RAM memory resources such as clock, clock enables, and asynchronous clear signals.

Refer to "Single-Port Mode" on page 2–10 and "Single-Clock Mode" on page 2–28 for more information.

#### **Address Clock Enable Support**

Stratix II and Stratix II GX M4K and M-RAM memory blocks support address clock enable, which is used to hold the previous address value for as long as the signal is enabled. When the memory blocks are configured in dual-port mode, each port has its own independent address clock enable.

Figure 2–2 shows an address clock enable block diagram. Placed in the address register, the address signal output by the address register is fed back to the input of the register via a multiplexer. The multiplexer output is selected by the address clock enable (addressstall) signal. Address latching is enabled when the addressstall signal turns high. The output of the address register is then continuously fed into the input of the register; therefore, the address value can be held until the addressstall signal turns low.



Figure 2–2. Stratix II and Stratix II GX Address Clock Enable Block Diagram

Address clock enable is typically used for cache memory applications, which require one port for read and another port for write. The default value for the address clock enable signals is low (disabled). Figures 2–3 and 2–4 show the address clock enable waveform during the read and write cycles, respectively.



Figure 2-3. Stratix II and Stratix II GX Address Clock Enable During Read Cycle Waveform

Figure 2-4. Stratix II and Stratix II GX Address Clock Enable During Write Cycle Waveform



## **Memory Modes**

Stratix II and Stratix II GX TriMatrix memory blocks include input registers that synchronize writes, and output registers to pipeline data to improve system performance. All TriMatrix memory blocks are fully synchronous, meaning that all inputs are registered, but outputs can be either registered or unregistered.



TriMatrix memory does not support asynchronous memory (unregistered inputs).

Depending on which TriMatrix memory block you use, the memory has various modes, including:

- Single-port
- Simple dual-port
- True dual-port (bidirectional dual-port)
- Shift-register
- ROM
- FIFO



Violating the setup or hold time on the memory block address registers could corrupt memory contents. This applies to both read and write operations.

### **Single-Port Mode**

All TriMatrix memory blocks support the single-port mode that supports non-simultaneous read and write operations. Figure 2–5 shows the single-port memory configuration for TriMatrix memory.

Figure 2–5. Single-Port Memory Note (1)



Note to Figure 2-5:

 Two single-port memory blocks can be implemented in a single M4K or M-RAM block.

M4K and M-RAM memory blocks can also be halved and used for two independent single-port RAM blocks. The Altera® Quartus® II software automatically uses this single-port memory packing when running low on memory resources. To force two single-port memories into one M4K or M-RAM block, first ensure that each of the two independent RAM blocks is equal to or less than half the size of the M4K or M-RAM block. Secondly, assign both single-port RAMs to the same M4K or M-RAM block.

In single-port RAM configuration, the outputs can only be in read-during-write mode, which means that during the write operation, data written to the RAM flows through to the RAM outputs. When the output registers are bypassed, the new data is available on the rising edge of the same clock cycle on which it was written. Refer to "Read-During-Write Operation at the Same Address" on page 2–33 for more information about read-during-write mode. Table 2–8 shows the port width configurations for TriMatrix blocks in single-port mode.

| Table 2–8. Stratix II and Stratix II GX Port Width Configurations for M512, |
|-----------------------------------------------------------------------------|
| M4K, and M-RAM Blocks (Single-Port Mode)                                    |

| M512 Blocks                                                             | M4K Blocks                                                                                       | M-RAM Blocks                                                                                                     |
|-------------------------------------------------------------------------|--------------------------------------------------------------------------------------------------|------------------------------------------------------------------------------------------------------------------|
| 512 × 1<br>256 × 2<br>128 × 4<br>64 × 8<br>64 × 9<br>32 × 16<br>32 × 18 | 4K × 1<br>2K × 2<br>1K × 4<br>512 × 8<br>512 × 9<br>256 × 16<br>256 × 18<br>128 × 32<br>128 × 36 | 64K × 8<br>64K × 9<br>32K × 16<br>32K × 18<br>16K × 32<br>16K × 36<br>8K × 64<br>8K × 72<br>4K × 128<br>4K × 144 |
|                                                                         | 512 × 1<br>256 × 2<br>128 × 4<br>64 × 8<br>64 × 9<br>32 × 16                                     | 512 x 1                                                                                                          |

Figure 2–6 shows timing waveforms for read and write operations in single-port mode.

Figure 2-6. Stratix II and Stratix II GX Single-Port Timing Waveforms



Note to Figure 2-6:

(1) The crosses in the data waveform during read mean "don't care."

## Simple Dual-Port Mode

All TriMatrix memory blocks support simple dual-port mode which supports a simultaneous read and write operation. Figure 2–7 shows the simple dual-port memory configuration for TriMatrix memory.

Figure 2–7. Stratix II and Stratix II GX Simple Dual-Port Memory Note (1)



*Note to Figure 2–7:* 

(1) Simple dual-port RAM supports input/output clock mode in addition to the read/write clock mode shown.

TriMatrix memory supports mixed-width configurations, allowing different read and write port widths. Tables 2–9 through 2–11 show the mixed width configurations for the M512, M4K, and M-RAM blocks, respectively.

| Table 2–9. Stratix II and Stratix II GX M512 Block Mixed-Width Configurations (Simple Dual-Port Mode) |          |            |          |          |          |          |          |  |
|-------------------------------------------------------------------------------------------------------|----------|------------|----------|----------|----------|----------|----------|--|
| D 1 D 1                                                                                               |          | Write Port |          |          |          |          |          |  |
| Read Port                                                                                             | 512 × 1  | 256 × 2    | 128 × 4  | 64 × 8   | 32 × 16  | 64 × 9   | 32 × 18  |  |
| 512 × 1                                                                                               | <b>✓</b> | <b>✓</b>   | <b>✓</b> | <b>✓</b> | <b>✓</b> |          |          |  |
| 256 × 2                                                                                               | <b>✓</b> | <b>✓</b>   | ~        | <b>✓</b> | <b>✓</b> |          |          |  |
| 128 × 4                                                                                               | <b>✓</b> | <b>✓</b>   | <b>✓</b> | <b>✓</b> | <b>✓</b> |          |          |  |
| 64 × 8                                                                                                | <b>✓</b> | <b>✓</b>   | <b>✓</b> | <b>✓</b> | <b>✓</b> |          |          |  |
| 32 × 16                                                                                               | <b>✓</b> | <b>✓</b>   | <b>✓</b> | <b>✓</b> | <b>✓</b> |          |          |  |
| 64 × 9                                                                                                |          |            |          |          |          | <b>✓</b> | <b>✓</b> |  |
| 32 × 18                                                                                               |          |            |          |          |          | <b>✓</b> | <b>✓</b> |  |

| Table 2-10. S | Table 2–10. Stratix II and Stratix II GX M4K Block Mixed-Width Configurations (Simple Dual-Port Mode) |            |          |          |          |          |          |          |          |  |  |
|---------------|-------------------------------------------------------------------------------------------------------|------------|----------|----------|----------|----------|----------|----------|----------|--|--|
| Dood Dout     |                                                                                                       | Write Port |          |          |          |          |          |          |          |  |  |
| Read Port     | 4K × 1                                                                                                | 2K × 2     | 1K × 4   | 512 × 8  | 256 × 16 | 128 × 32 | 512 × 9  | 256 × 18 | 128 × 36 |  |  |
| 4K × 1        | <b>✓</b>                                                                                              | <b>✓</b>   | <b>✓</b> | <b>✓</b> | <b>✓</b> | <b>✓</b> |          |          |          |  |  |
| 2K × 2        | ~                                                                                                     | ~          | <b>✓</b> | <b>✓</b> | <b>✓</b> | ~        |          |          |          |  |  |
| 1K × 4        | <b>✓</b>                                                                                              | <b>✓</b>   | ~        | <b>✓</b> | <b>✓</b> | <b>✓</b> |          |          |          |  |  |
| 512 × 8       | <b>✓</b>                                                                                              | <b>✓</b>   | ~        | <b>✓</b> | <b>✓</b> | <b>✓</b> |          |          |          |  |  |
| 256 × 16      | <b>✓</b>                                                                                              | <b>✓</b>   | ~        | ✓        | <b>✓</b> | <b>✓</b> |          |          |          |  |  |
| 128 × 32      | <b>✓</b>                                                                                              | <b>✓</b>   | ~        | <b>✓</b> | <b>✓</b> | <b>✓</b> |          |          |          |  |  |
| 512 × 9       |                                                                                                       |            |          |          |          |          | <b>✓</b> | <b>✓</b> | <b>✓</b> |  |  |
| 256 × 18      |                                                                                                       |            |          |          |          |          | <b>✓</b> | ~        | <b>✓</b> |  |  |
| 128 × 36      |                                                                                                       |            |          |          |          |          | <b>✓</b> | <b>✓</b> | <b>✓</b> |  |  |

| Dood Dow  |          |          | Write Por | t        |          |
|-----------|----------|----------|-----------|----------|----------|
| Read Port | 64K × 9  | 32K × 18 | 18K × 36  | 8K × 72  | 4K × 144 |
| 64K × 9   | <b>✓</b> | <b>✓</b> | <b>✓</b>  | ✓        |          |
| 32K × 18  | <b>✓</b> | <b>✓</b> | <b>✓</b>  | ✓        |          |
| 18K × 36  | <b>✓</b> | <b>✓</b> | <b>✓</b>  | <b>✓</b> |          |
| 8K × 72   | <b>✓</b> | <b>✓</b> | <b>✓</b>  | <b>✓</b> |          |
| 4K × 144  |          |          |           |          | ~        |

In simple dual-port mode, M512 and M4K blocks have one write enable and one read enable signal. However, M-RAM blocks contain only a write-enable signal, which is held high to perform a write operation. M-RAM blocks are always enabled for read operations. If the read address and the write address select the same address location during a write operation, M-RAM block output is unknown.

TriMatrix memory blocks do not support a clear port on the write enable and read enable registers. When the read enable is deactivated, the current data is retained at the output ports. If the read enable is activated during a write operation with the same address location selected, the simple dual-port RAM output is either unknown or can be set to output the old data stored at the memory address. Refer to "Read-During-Write Operation at the Same Address" on page 2–33 for more information. Figure 2–8 shows timing waveforms for read and write operations in simple dual-port mode.



Figure 2–8. Stratix II and Stratix II GX Simple Dual-Port Timing Waveforms

#### *Notes to Figure 2–8:*

- (1) The crosses in the data waveform during read mean "don't care."
- (2) The read enable rden signal is not available in M-RAM blocks. The M-RAM block in simple dual-port mode always reads out the data stored at the current read address location.

#### **True Dual-Port Mode**

Stratix II and Stratix II GX M4K and M-RAM memory blocks support the true dual-port mode. True dual-port mode supports any combination of two-port operations: two reads, two writes, or one read and one write at two different clock frequencies. Figure 2–9 shows Stratix II and Stratix II GX true dual-port memory configuration.

Figure 2–9. Stratix II and Stratix II GX True Dual-Port Memory Note (1)



*Note to Figure 2–9:* 

 True dual-port memory supports input/output clock mode in addition to the independent clock mode shown. The widest bit configuration of the M4K and M-RAM blocks in true dual-port mode is as follows:

- 256 × 16-bit (×18-bit with parity) (M4K)
- $\blacksquare$  8K × 64-bit (×72-bit with parity) (M-RAM)

The  $128 \times 32$ -bit (×36-bit with parity) configuration of the M4K block and the  $4K \times 128$ -bit (×144-bit with parity) configuration of the M-RAM block are unavailable because the number of output drivers is equivalent to the maximum bit width of the respective memory block. Because true dual-port RAM has outputs on two ports, the maximum width of the true dual-port RAM equals half of the total number of output drivers. Table 2–12 lists the possible M4K block mixed-port width configurations.

| Table 2–12. Stratix II and Stratix II GX M4K Block Mixed-Port Width Configurations (True Dual-Port) |            |          |          |          |          |         |          |
|-----------------------------------------------------------------------------------------------------|------------|----------|----------|----------|----------|---------|----------|
| Dood Dovi                                                                                           | Write Port |          |          |          |          |         |          |
| Read Port                                                                                           | 4K × 1     | 2K × 2   | 1K × 4   | 512 × 8  | 256 × 16 | 512 × 9 | 256 × 18 |
| 4K × 1                                                                                              | ✓          | <b>✓</b> | <b>✓</b> | <b>✓</b> | <b>✓</b> |         |          |
| 2K × 2                                                                                              | <b>✓</b>   | ✓        | <b>✓</b> | <b>✓</b> | <b>✓</b> |         |          |
| 1K × 4                                                                                              | <b>✓</b>   | ✓        | <b>✓</b> | <b>✓</b> | <b>✓</b> |         |          |
| 512 × 8                                                                                             | ✓          | <b>✓</b> | <b>✓</b> | <b>✓</b> | <b>✓</b> |         |          |
| 256 × 16                                                                                            | <b>✓</b>   | ✓        | <b>✓</b> | <b>✓</b> | <b>✓</b> |         |          |
| 512 × 9                                                                                             |            |          |          |          |          | ✓       | ✓        |
| 256 × 18                                                                                            |            |          |          |          |          | ✓       | ✓        |

Table 2–13 lists the possible M-RAM block mixed-port width configurations.

| Read Port | Write Port |          |          |          |
|-----------|------------|----------|----------|----------|
| Heau Puri | 64K × 9    | 32K × 18 | 18K × 36 | 8K × 72  |
| 64K × 9   | <b>✓</b>   | ✓        | <b>✓</b> | <b>✓</b> |
| 32K × 18  | <b>✓</b>   | ✓        | <b>✓</b> | <b>✓</b> |
| 18K × 36  | <b>✓</b>   | <b>✓</b> | <b>✓</b> | <b>✓</b> |
| 8K × 72   | <b>✓</b>   | <b>✓</b> | <b>✓</b> | <b>✓</b> |

In true dual-port configuration, the RAM outputs can only be configured for read-during-write mode. This means that during write operation, data being written to the A or B port of the RAM flows through to the A or B outputs, respectively. When the output registers are bypassed, the new data is available on the rising edge of the same clock cycle on which it was written. Refer to "Read-During-Write Operation at the Same Address" on page 2–33 for waveforms and information on mixed-port read-during-write mode.

Potential write contentions must be resolved external to the RAM because writing to the same address location at both ports results in unknown data storage at that location. For a valid write operation to the same address of the M-RAM block, the rising edge of the write clock for port A must occur following the maximum write cycle time interval after the rising edge of the write clock for port B. Data is written on the rising edge of the write clock for the M-RAM block.

Because data is written into the M512 and M4K blocks at the falling edge of the write clock, the rising edge of the write clock for port A should occur following half of the maximum write cycle time interval after the falling edge of the write clock for port B. If this timing is not met, the data stored in that particular address will be invalid.



Refer to the *Stratix II Device Family Data Sheet* (volume 1) of the *Stratix II Device Handbook* or the *Stratix II GX Device Family Data Sheet* (volume 1) of the *Stratix II GX Device Handbook* for the maximum synchronous write cycle time.



Figure 2–10 shows true dual-port timing waveforms for the write operation at port A and the read operation at port B.

#### *Note to Figure 2–10:*

(1) The crosses in the data\_a waveform during write mean "don't care."

## Shift-Register Mode

All Stratix II memory blocks support the shift register mode.

Embedded memory block configurations can implement shift registers for digital signal processing (DSP) applications, such as finite impulse response (FIR) filters, pseudo-random number generators, multi-channel filtering, and auto-correlation and cross-correlation functions. These and other DSP applications require local data storage, traditionally implemented with standard flip-flops that quickly exhaust many logic cells for large shift registers. A more efficient alternative is to use embedded memory as a shift-register block, which saves logic cell and routing resources.

The size of a  $(w \times m \times n)$  shift register is determined by the input data width (w), the length of the taps (m), and the number of taps (n), and must be less than or equal to the maximum number of memory bits in the respective block: 576 bits for the M512 block, 4,608 bits for the M4K block, and 589,824 bits for the MRAM block. In addition, the size of  $w \times n$  must be less than or equal to the maximum width of the respective block: 18

bits for the M512 block, 36 bits for the M4K block, and 144 bits for the MRAM block. If a larger shift register is required, the memory blocks can be cascaded.

In M512 and M4K blocks, data is written into each address location at the falling edge of the clock and read from the address at the rising edge of the clock. The shift-register mode logic automatically controls the positive and negative edge clocking to shift the data in one clock cycle. The MRAM block performs reads and writes on the rising edge. Figure 2–11 shows the TriMatrix memory block in the shift-register mode.

 $w \times m \times n$  Shift Register m-Bit Shift Register m-Bit Shift Register n Number of Taps m-Bit Shift Register m-Bit Shift Register

Figure 2-11. Stratix II and Stratix II GX Shift-Register Memory Configuration

#### **ROM Mode**

M512 and M4K memory blocks support ROM mode. A memory initialization file (.mif) initializes the ROM contents of these blocks. The address lines of the ROM are registered. The outputs can be registered or unregistered. The ROM read operation is identical to the read operation in the single-port RAM configuration.

#### **FIFO Buffers Mode**

TriMatrix memory blocks support the FIFO mode. M512 memory blocks are ideal for designs with many shallow FIFO buffers. All memory configurations have synchronous inputs; however, the FIFO buffer outputs are always combinational. Simultaneous read and write from an empty FIFO buffer is not supported.



Refer to the *Single- and Dual-Clock FIFO Megafunctions User Guide* and *FIFO Partitioner Megafunction User Guide* for more information on FIFO buffers.

## **Clock Modes**

Depending on which TriMatrix memory mode is selected, the following clock modes are available:

- Independent
- Input/output
- Read/write
- Single-clock

Table 2–14 shows these clock modes supported by all TriMatrix blocks when configured as respective memory modes.

| Table 2–14. Stratix II and Stratix II GX TriMatrix Memory Clock Modes |                        |                          |                  |  |
|-----------------------------------------------------------------------|------------------------|--------------------------|------------------|--|
| Clocking Modes                                                        | True Dual-Port<br>Mode | Simple Dual-Port<br>Mode | Single-Port Mode |  |
| Independent                                                           | ✓                      |                          |                  |  |
| Input/output                                                          | ✓                      | ✓                        | ✓                |  |
| Read/write                                                            |                        | ✓                        |                  |  |
| Single clock                                                          | <b>✓</b>               | <b>✓</b>                 | <b>✓</b>         |  |

### **Independent Clock Mode**

The TriMatrix memory blocks can implement independent clock mode for true dual-port memory. In this mode, a separate clock is available for each port (A and B). Clock A controls all registers on the port A side, while clock B controls all registers on the port B side. Each port also supports independent clock enables for port A and B registers. Asynchronous clear signals for the registers, however, are supported.

Clock Mode Note (1) address\_b[] data\_b[] ENA Write Pulse Generator Address Clock Enable B Byte Enable B Data Out Memory Block ⋖ Data Out Data In ENA \_ ₩ address\_a[]data\_a[]. enable\_aaddressstall a

Figure 2–12 shows a TriMatrix memory block in independent clock mode.

Figure 2–12. Stratix II and Stratix II GX TriMatrix Memory Block in Independent

Note to Figure 2–12:

 Violating the setup or hold time on the memory block address registers could corrupt the memory contents. This applies to both read and write operations.

### Input/Output Clock Mode

Stratix II and Stratix II GX TriMatrix memory blocks can implement input/output clock mode for true and simple dual-port memory. On each of the two ports, A and B, one clock controls all registers for the following inputs into the memory block: data input, write enable, and address. The other clock controls the blocks' data output registers. Each memory block port also supports independent clock enables for input and output registers. Asynchronous clear signals for the registers, however, are not supported.

Figures 2–13 through 2–15 show the memory block in input/output clock mode for true dual-port, simple dual-port, and single-port modes, respectively.



Figure 2–13. Stratix II and Stratix II GX Input/Output Clock Mode in True Dual-Port Mode Note (1)

Note to Figure 2–13:

 Violating the setup or hold time on the memory block address registers could corrupt the memory contents. This applies to both read and write operations.



Figure 2–14. Stratix II and Stratix II GX Input/Output Clock Mode in Simple Dual-Port Mode Note (1)

#### *Notes to Figure 2–14:*

- Violating the setup or hold time on the memory block address registers could corrupt the memory contents. This
  applies to both read and write operations.
- (2) The read enable rden signal is not available in the M-RAM block. An M-RAM block in simple dual-port mode is always reading out the data stored at the current read address location.
- (3) Refer to the Stratix II Device Family Data Sheet (volume 1) of the Stratix II Device Handbook or the Stratix II GX Device Family Data Sheet (volume 1) of the Stratix II GX Device Handbook for more information on the MultiTrack™ interconnect.



Figure 2–15. Stratix II and Stratix II GX Input/Output Clock Mode in Single-Port Mode Note (1)

#### *Notes to Figure 2–15:*

- Violating the setup or hold time on the memory block address registers could corrupt the memory contents. This
  applies to both read and write operations.
- (2) Refer to the Stratix II Device Family Data Sheet (volume 1) of the Stratix II Device Handbook or the Stratix II GX Device Family Data Sheet (volume 1) of the Stratix II GX Device Handbook for more information on the MultiTrack interconnect.

#### Read/Write Clock Mode

Stratix II and Stratix II GX TriMatrix memory blocks can implement read/write clock mode for simple dual-port memory. This mode uses up to two clocks. The write clock controls the blocks' data inputs, write address, and write enable signals. The read clock controls the data output, read address, and read enable signals. The memory blocks support independent clock enables for each clock for the read- and write-side registers. Asynchronous clear signals for the registers, however, are not supported. Figure 2–16 shows a memory block in read/write clock mode.



Figure 2–16. Stratix II and Stratix II GX Read/Write Clock Mode Note (1)

#### Notes to Figure 2–16:

- Violating the setup or hold time on the memory block address registers could corrupt the memory contents. This
  applies to both read and write operations.
- (2) The read enable rden signal is not available in the M-RAM block. An M-RAM block in simple dual-port mode is always reading the data stored at the current read address location.
- (3) Refer to the Stratix II Device Family Data Sheet (volume 1) of the Stratix II Device Handbook or the Stratix II GX Device Family Data Sheet (volume 1) of the Stratix II GX Device Handbook for more information on the MultiTrack interconnect.

## Single-Clock Mode

Stratix II and Stratix II GX TriMatrix memory blocks implement single-clock mode for true dual-port, simple dual-port, and single-port memory. In this mode, a single clock, together with clock enable, is used to control all registers of the memory block. Asynchronous clear signals for the registers, however, are not supported. Figures 2–17 through 2–19 show the memory block in single-clock mode for true dual-port, simple dual-port, and single-port modes, respectively.



Figure 2–17. Stratix II and Stratix II GX Single-Clock Mode in True Dual-Port Mode Note (1)

Note to Figure 2–17:

 Violating the setup or hold time on the memory block address registers could corrupt the memory contents. This applies to both read and write operations.



Figure 2–18. Stratix II and Stratix II GX Single-Clock Mode in Simple Dual-Port Mode Note (1)

#### *Notes to Figure 2–18:*

- (1) Violating the setup or hold time on the memory block address registers could corrupt the memory contents. This applies to both read and write operations.
- (2) The read enable rden signal is not available in the M-RAM block. An M-RAM block in simple dual-port mode is always reading the data stored at the current read address location.
- (3) Refer to the Stratix II Device Family Data Sheet (volume 1) of the Stratix II Device Handbook or the Stratix II GX Device Family Data Sheet (volume 1) of the Stratix II GX Device Handbook for more information on the MultiTrack interconnect.



Figure 2–19. Stratix II and Stratix II GX Single-Clock Mode in Single-Port Mode Note (1)

#### *Notes to Figure 2–19:*

- (1) Violating the setup or hold time on the memory block address registers could corrupt the memory contents. This applies to both read and write operations.
- (2) Refer to the Stratix II Device Family Data Sheet (volume 1) of the Stratix II Device Handbook or the Stratix II GX Device Family Data Sheet (volume 1) of the Stratix II GX Device Handbook for more information on the MultiTrack interconnect.

# Designing With TriMatrix Memory

When instantiating TriMatrix memory, it is important to understand the features that set it apart from other memory architectures. The following sections describe the unique attributes and functionality of TriMatrix memory.

## **Selecting TriMatrix Memory Blocks**

The Quartus II software automatically partitions user-defined memory into embedded memory blocks using the most efficient size combinations. The memory can also be manually assigned to a specific block size or a mixture of block sizes. Table 2–1 on page 2–2 is a guide for selecting a TriMatrix memory block size based on supported features.



Refer to *AN* 207: *TriMatrix Memory Selection Using the Quartus II Software* for more information on selecting the appropriate memory block.

### Synchronous and Pseudo-Asynchronous Modes

The TriMatrix memory architecture implements synchronous RAM by registering the input and output signals to the RAM block. The inputs to all TriMatrix memory blocks are registered providing synchronous write cycles, while the output registers can be bypassed. In a synchronous operation, RAM generates its own self-timed strobe write enable signal derived from the global or regional clock. In contrast, a circuit using asynchronous RAM must generate the RAM write enable signal while ensuring that its data and address signals meet setup and hold time specifications relative to the write enable signal. During a synchronous operation, the RAM is used in pipelined mode (inputs and outputs registered) or flow-through mode (only inputs registered). However, in an asynchronous memory, neither the input nor the output is registered.

While Stratix II and Stratix II GX devices do not support asynchronous memory, they do support a pseudo-asynchronous read where the output data is available during the clock cycle when the read address is driven into it. Pseudo-asynchronous reading is possible in the simple and true dual-port modes of the M512 and M4K blocks by clocking the read enable and read address registers on the negative clock edge and bypassing the output registers.



Refer to AN 210: Converting Memory from Asynchronous to Synchronous for Stratix and Stratix GX Designs for more information.

## **Power-up Conditions and Memory Initialization**

Upon power up, TriMatrix memory is in an idle state. The M512 and M4K block outputs always power-up to zero, regardless of whether the output registers are used or bypassed. Even if an MIF is used to pre-load the contents of the RAM block, the outputs will still power-up as cleared. For example, if address 0 is pre-initialized to FF, the M512 and M4K blocks power up with the output at 00.

M-RAM blocks do not support MIFs; therefore, they cannot be pre-loaded with data upon power up. M-RAM blocks asynchronous outputs and memory controls always power up to an unknown state. If M-RAM block outputs are registered, the registers power up as cleared. When a read is performed immediately after power up, the output from the read operation will be undefined since the M-RAM contents are not initialized. The read operation will continue to be undefined for a given address until a write operation is performed for that address.

# Read-During-Write Operation at the Same Address

The "Same-Port Read-During-Write Mode" on page 2–33 and "Mixed-Port Read-During-Write Mode" on page 2–34 sections describe the functionality of the various RAM configurations when reading from an address during a write operation at that same address. There are two read-during-write data flows: same-port and mixed-port. Figure 2–20 shows the difference between these flows.

Port A data in

Mixed-port data flow

Port A data out

Port B data out

Figure 2-20. Stratix II and Stratix II GX Read-During-Write Data Flow

## Same-Port Read-During-Write Mode

For read-during-write operation of a single-port RAM or the same port of a true dual-port RAM, the new data is available on the rising edge of the same clock cycle on which it was written. This behavior is valid on all memory block sizes. Figure 2–21 shows a sample functional waveform. When using byte enables in true dual-port RAM mode, the outputs for the masked bytes on the same port are unknown (refer to Figure 2–1 on page 2–7). The non-masked bytes are read out as shown in Figure 2–21.

Figure 2–21. Stratix II and Stratix II GX Same-Port Read-During-Write Functionality Note (1)



Note to Figure 2-21:

(1) Outputs are not registered.

#### Mixed-Port Read-During-Write Mode

This mode is used when a RAM in simple or true dual-port mode has one port reading and the other port writing to the same address location with the same clock.

The READ\_DURING\_WRITE\_MODE\_MIXED\_PORTS parameter for M512 and M4K memory blocks determines whether to output the old data at the address or a "don't care" value. Setting this parameter to OLD\_DATA outputs the old data at that address. Setting this parameter to DONT\_CARE outputs a "don't care" or unknown value. Figures 2–22 and 2–23 show sample functional waveforms where both ports have the same address. These figures assume that the outputs are not registered.

The DONT\_CARE setting allows memory implementation in any TriMatrix memory block, whereas the OLD\_DATA setting restricts memory implementation to only M512 or M4K memory blocks. Selecting DONT\_CARE gives the compiler more flexibility when placing memory functions into TriMatrix memory.

The RAM outputs are unknown for a mixed-port read-during-write operation of the same address location of an M-RAM block, as shown in Figure 2–23.



Figure 2–22. Stratix II and Stratix II GX Mixed-Port Read-During-Write: OLD\_DATA

Figure 2–23. Stratix II and Stratix II GX Mixed-Port Read-During-Write: DONT CARE



Mixed-port read-during-write is not supported when two different clocks are used in a dual-port RAM. The output value is unknown during a mixed-port read-during-write operation.

## **Conclusion**

The TriMatrix memory structure of Stratix II and Stratix II GX devices provides an enhanced RAM architecture with high memory bandwidth. It addresses the needs of different memory applications in FPGA designs with features such as different memory block sizes and modes, byte enables, parity bit storage, address clock enables, mixed clock mode, shift register mode, mixed-port width support, and true dual-port mode.

# Referenced Documents

This chapter references the following documents:

- AN 207: TriMatrix Memory Selection Using the Quartus II Software
- AN 210: Converting Memory from Asynchronous to Synchronous for Stratix and Stratix GX Designs
- FIFO Partitioner Megafunction User Guide
- Single- and Dual-Clock FIFO Megafunctions User Guide
- Stratix II Device Family Data Sheet (volume 1) of the Stratix II Device Handbook
- Stratix II GX Device Family Data Sheet (volume 1) of the Stratix II GX Device Handbook
- Using Parity to Detect Memory Errors white paper

# Document Revision History

Table 2–15 shows the revision history for this chapter.

| Table 2–15. Document Revision History |                                                                                                                                                                                                       |                    |  |
|---------------------------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--------------------|--|
| Date and<br>Document<br>Version       | Changes Made                                                                                                                                                                                          | Summary of Changes |  |
| January 2008,                         | Added "Referenced Documents" section.                                                                                                                                                                 | _                  |  |
| v4.5                                  | Minor text edits.                                                                                                                                                                                     | _                  |  |
| No change                             | For the <i>Stratix II GX Device Handbook</i> only: Formerly chapter 7. The chapter number changed due to the addition of the <i>Stratix II GX Dynamic Reconfiguration</i> chapter. No content change. | _                  |  |
| May 2007,<br>v4.4                     | Added note to "Byte Enable Functional Waveform" section.                                                                                                                                              | _                  |  |
|                                       | Updated "Byte Enable Support" section.                                                                                                                                                                | _                  |  |
| February 2007<br>v4.3                 | Added the "Document Revision History" section to this chapter.                                                                                                                                        | _                  |  |
| April 2006,<br>v4.2                   | Chapter updated as part of the <i>Stratix II Device Handbook</i> update.                                                                                                                              | _                  |  |
| No change                             | Formerly chapter 6. Chapter number change only due to chapter addition to Section I in February 2006; no content change.                                                                              | _                  |  |
| December<br>2005, v4.1                | Chapter updated as part of the Stratix II Device Handbook update.                                                                                                                                     | _                  |  |
| October 2005<br>v4.0                  | Added chapter to the Stratix II GX Device Handbook.                                                                                                                                                   | _                  |  |