

# MAX 10 エンベデッド・メモリ・ユーザ ーガイド

 署名  
 フィードバック

UG-  
**M10MEMORY**  
2014.09.22 | 101 Innovation Drive  
San Jose, CA 95134  
[www.altera.com](http://www.altera.com)



# 目次

|                                                         |            |
|---------------------------------------------------------|------------|
| <b>MAX 10 エンベデッド・メモリの概要.....</b>                        | <b>1-1</b> |
| <b>MAX 10 エンベデッド・メモリのアーキテクチャと機能.....</b>                | <b>2-1</b> |
| MAX 10 エンベデッド・メモリの一般的な機能.....                           | 2-1        |
| コントロール信号.....                                           | 2-2        |
| パリティ・ビット.....                                           | 2-2        |
| 読み取りイネーブル.....                                          | 2-2        |
| Read-During-Write.....                                  | 2-3        |
| バイト・イネーブル.....                                          | 2-3        |
| パック・モードのサポート.....                                       | 2-5        |
| アドレス・クロック・イネーブルのサポート.....                               | 2-6        |
| 非同期クリア.....                                             | 2-7        |
| MAX 10 エンベデッド・メモリの動作モード.....                            | 2-8        |
| サポートされるメモリの動作モード.....                                   | 2-9        |
| MAX 10 エンベデッド・メモリのクロック・モード.....                         | 2-11       |
| クロック・モードの非同期クリア.....                                    | 2-12       |
| 同時読み取り/書き込みにおける出力読み取りデータ.....                           | 2-12       |
| クロック・モードの独立クロック・イネーブル.....                              | 2-12       |
| MAX 10 エンベデッド・メモリの構成.....                               | 2-12       |
| ポート幅コンフィギュレーション.....                                    | 2-13       |
| データ幅混合ポートのコンフィギュレーション.....                              | 2-13       |
| 最大ブロック深度の設定 .....                                       | 2-14       |
| <b>MAX 10 エンベデッド・メモリのデザイン検討事項.....</b>                  | <b>3-1</b> |
| 外部の競合解決を実装する.....                                       | 3-1        |
| Read-During-Write 動作をカスタマイズする.....                      | 3-1        |
| 同一ポートの Read-During-Write モード.....                       | 3-2        |
| 混合ポートの Read-During-Write モード .....                      | 3-3        |
| パワーアップ状態およびメモリの初期化.....                                 | 3-4        |
| クロッキングをコントロールして消費電力を削減する.....                           | 3-5        |
| Read-During-Write 出力の選択 .....                           | 3-6        |
| <b>RAM: 1-PORT IP コア・リファレンス.....</b>                    | <b>4-1</b> |
| MAX 10 デバイスの RAM: 1-PORT IP コア信号 .....                  | 4-2        |
| MAX 10 デバイスの RAM: 1-PORT IP コアのパラメータ.....               | 4-4        |
| <b>RAM: 2-PORT IP コア・リファレンス.....</b>                    | <b>5-1</b> |
| MAX 10 デバイスの RAM: 2-PORT IP コア信号（シンプル・デュアル・ポート RAM） ... | 5-5        |

|                                                     |             |
|-----------------------------------------------------|-------------|
| MAX 10 デバイスの RAM: 2-PORT IP コア信号（トゥルー・デュアル・ポート RAM） | 5-7         |
| MAX 10 デバイスの RAM: 2-PORT IP コアのパラメータ                | 5-10        |
| <b>ROM: 1-PORT IP コア・リファレンス</b>                     | <b>6-1</b>  |
| MAX 10 デバイスの ROM: 1-PORT IP コア信号                    | 6-2         |
| MAX 10 デバイスの ROM: 1-PORT IP コアのパラメータ                | 6-4         |
| <b>ROM: 2-PORT IP コア・リファレンス</b>                     | <b>7-1</b>  |
| MAX 10 デバイスの ROM: 2-PORT IP コア信号                    | 7-3         |
| MAX 10 デバイスの ROM: 2-PORT IP コアのパラメータ                | 7-5         |
| <b>シフト・レジスタ (RAM ベース) IP コア・リファレンス</b>              | <b>8-1</b>  |
| MAX 10 デバイスのシフト・レジスタ (RAM ベース) IP コア信号              | 8-1         |
| MAX 10 デバイスのシフト・レジスタ (RAM ベース) IP コアのパラメータ          | 8-2         |
| <b>FIFO IP コア・リファレンス</b>                            | <b>9-1</b>  |
| MAX 10 デバイスの FIFO IP コア信号                           | 9-2         |
| MAX 10 デバイスの FIFO IP コアのパラメータ                       | 9-5         |
| <b>ALTMEMMULT IP コア・リファレンス</b>                      | <b>10-1</b> |
| MAX 10 デバイスの ALTMEMMULT IP コア信号                     | 10-1        |
| MAX 10 デバイスの ALTMEMMULT IP コアのパラメータ                 | 10-2        |
| <b>MAX 10 エンベデッド・メモリ・ユーザーガイドの追加情報</b>               | <b>A-1</b>  |
| MAX 10 エンベデッド・メモリ・ユーザーガイド改訂履歴                       | A-1         |

# MAX 10 エンベデッド・メモリの概要

1

2014.09.22

UG-M10MEMORY

 署名  フィードバック

MAX® 10 エンベデッド・メモリ・ブロックは、高スループット・パケット処理、エンベデッド・プロセッサ・プログラム、およびエンベデッド・データ・ストレージなどのアプリケーションに最適です。

© 2014 Altera Corporation. All rights reserved. ALTERA, ARRIA, CYCLONE, ENPIRION, MAX, MEGACORE, NIOS, QUARTUS and STRATIX words and logos are trademarks of Altera Corporation and registered in the U.S. Patent and Trademark Office and in other countries. All other words and logos identified as trademarks or service marks are the property of their respective holders as described at [www.altera.com/common/legal.html](http://www.altera.com/common/legal.html). Altera warrants performance of its semiconductor products to current specifications in accordance with Altera's standard warranty, but reserves the right to make changes to any products and services at any time without notice. Altera assumes no responsibility or liability arising out of the application or use of any information, product, or service described herein except as expressly agreed to in writing by Altera. Altera customers are advised to obtain the latest version of device specifications before relying on any published information and before placing orders for products or services.

ISO  
9001:2008

# MAX 10 エンベデッド・メモリのアーキテクチャと機能

2

2014.09.22

UG-M10MEMORY

 署名  フィードバック

MAX 10 エンベデッド・メモリ構造は、9,216 ビット（パリティ・ビットを含む）のブロックで構成されています。RAM、ROM、シフト・レジスタ、FIFO などのさまざまなメモリ機能を提供するために、各 M9K ブロックは異なる幅およびコンフィギュレーションで使用することができます。

以下に MAX 10 エンベデッド・メモリ機能の大要を示します。

- エンベデッド・メモリの一般的な機能
- エンベデッド・メモリの動作モード
- エンベデッド・メモリのクロック・モード

## 関連情報

### MAX 10 Device Overview

MAX 10 デバイスのエンベデッド・メモリ容量と分配についての詳細です。

## MAX 10 エンベデッド・メモリの一般的な機能

MAX 10 エンベデッド・メモリは、以下の一般的な機能をサポートします。

- ブロックあたり 8,192 メモリ・ビット（パリティ・ビットを含めた場合、ブロックあたり 9,216 ビット）
- 各ポートの独立した読み取りイネーブル（rden）信号および書き込みイネーブル（wren）信号
- M9K メモリ・ブロックが 2 つの 4.5 K シングル・ポート RAM に分割されたパック・モード
- 可変ポート・コンフィギュレーション
- すべてのポート幅におけるシングル・ポート・モードおよびシンプル・デュアル・ポート・モードのサポート
- トゥルー・デュアル・ポート（1 回の読み取りと 1 回の書き込み、2 回の読み取り、あるいは 2 回の書き込み）動作
- 書き込み中のデータ入力マスキングのバイト・イネーブル
- 各ポート（ポート A とポート B）の 2 つのクロック・イネーブル・コントロール信号
- RAM および ROM モードでメモリの内容をプリロードするための初期化ファイル

© 2014 Altera Corporation. All rights reserved. ALTERA, ARRIA, CYCLONE, ENPIRION, MAX, MEGACORE, NIOS, QUARTUS and STRATIX words and logos are trademarks of Altera Corporation and registered in the U.S. Patent and Trademark Office and in other countries. All other words and logos identified as trademarks or service marks are the property of their respective holders as described at [www.altera.com/common/legal.html](http://www.altera.com/common/legal.html). Altera warrants performance of its semiconductor products to current specifications in accordance with Altera's standard warranty, but reserves the right to make changes to any products and services at any time without notice. Altera assumes no responsibility or liability arising out of the application or use of any information, product, or service described herein except as expressly agreed to in writing by Altera. Altera customers are advised to obtain the latest version of device specifications before relying on any published information and before placing orders for products or services.

ISO  
9001:2008

## コントロール信号

クロック・イネーブル・コントロール信号は、入力レジスタと出力レジスタ、およびM9Kメモリ・ブロック全体に入力するクロックを制御します。この信号は、M9Kメモリ・ブロックがクロック・エッジを検出しないよう、またどんな動作も実行しないようにクロックをディセーブルします。

`rden` および `wren` コントロール信号は、M9Kメモリ・ブロックの各ポートの書き込み動作と読み取り動作を制御します。動作が必要ない場合、電力を節約するために `rden` および `wren` 信号を個別にディセーブルすることができます。

図 2-1: M9K エンベデット・メモリ・ブロックにおけるレジスタ・クロック、クリア、およびコントロール信号の実装



## パリティ・ビット

パリティ・ビットを内部ロジック・リソースと併せて使用して、エラー検出のためのパリティ・チェックを実行することができます。M9Kメモリ・ブロックは、各ストレージ・バイトのパリティ・ビットをサポートします。このビットは、パリティ・ビットまたは追加のデータ・ビットとして使用することができます。このビットではパリティ機能は実行されません。エラー検出が必要ない場合、パリティ・ビットは追加データ・ビットとして使用することができます。

## 読み取りイネーブル

M9K メモリ・ブロックは、すべてのメモリ・モードの読み取りイネーブル機能をサポートします。

| 以下を実行した場合：                                                                                               | 次のようになります：                                                                                                                                                            |
|----------------------------------------------------------------------------------------------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 読み取りイネーブル・ポートを作成し、読み取りイネーブル・ポートがディアサートされた状態で書き込み動作を実行する                                                  | データ出力ポートは、直近のアクティブ読み取りイネーブル中に保持していた以前の値を継続して保持する                                                                                                                      |
| <ul style="list-style-type: none"><li>書き込み動作中に読み取りイネーブルをアクティブにする、または</li><li>読み取りイネーブル信号を作成しない</li></ul> | 出力ポートは以下を表示します： <ul style="list-style-type: none"><li>新しく書き込まれているデータ、</li><li>そのアドレスにある古いデータ、または</li><li>同じアドレス位置で Read-During-Write が実行される際の“Don't Care”的値</li></ul> |

## Read-During-Write

Read-During-Write 動作は、読み取り動作と書き込み動作が同時に同じメモリ位置を対象としているときに実行されます。

Read-During-Write 動作は、以下の方法で動作します。

- 同一ポート
- 混合ポート

### 関連情報

3-1 ページの [Read-During-Write 動作をカスタマイズする](#)

## バイト・イネーブル

- RAM として実装されるメモリ・ブロックは、バイト・イネーブルをサポートします。
- バイト・イネーブル・コントロールは、データの特定のバイトのみが書き込まれるよう入力データをマスクします。書き込まれないバイトは以前に書き込まれた値を保持します。
- 書き込みイネーブル (wren) 信号は、バイト・イネーブル (byteena) 信号と共に RAM ブロック上の書き込み動作を制御します。デフォルトでは、byteena 信号は High (イネーブル) となっており、書き込み動作は wren 信号によってのみ制御されます。
- バイト・イネーブル・レジスタは clear ポートを有しません。
- M9K ブロックは、書き込みポートのデータ幅が×16、×18、×32、または×36 ビットのときにバイト・イネーブルをサポートします。
- バイト・イネーブルは 1 ホット形式で動作します。byteena 信号の LSB はデータ・バスの LSB に対応します。たとえば、byteena = 01 で RAM ブロックを×18 モードで使用している場合、data[8:0]がイネーブルされ、data[17:9]がディセーブルされます。同様に、byteena = 11 の場合、data[8:0]と data[17:9]の両方がイネーブルされます。
- バイト・イネーブルはアクティブ High です。

## バイト・イネーブル・コントロール

表 2-1: M9K ブロックのバイト・イネーブル選択

| byteena[3:0] | 影響のあるバイト（どのバイト・イネーブルの組み合わせも可能です） |             |             |             |
|--------------|----------------------------------|-------------|-------------|-------------|
|              | datain x 16                      | datain x 18 | datain x 32 | datain x 36 |
| [0] = 1      | [7:0]                            | [8:0]       | [7:0]       | [8:0]       |
| [1] = 1      | [15:8]                           | [17:9]      | [15:8]      | [17:9]      |
| [2] = 1      | —                                | —           | [23:16]     | [26:18]     |
| [3] = 1      | —                                | —           | [31:24]     | [35:27]     |

## データ・バイト出力

| 以下を実行する場合：                       | 次のようにになります：                                                                            |
|----------------------------------|----------------------------------------------------------------------------------------|
| 書き込みサイクル中にバイト・イネーブル・ビットをディアサートする | メモリ内の古いデータが対応するデータ・バイト出力に表示されます。                                                       |
| 書き込みサイクル中にバイト・イネーブル・ビットをアサートする   | 対応するデータ・バイト出力は、Quartus® II ソフトウェアの設定によって決まります。設定は新たに書き込まれたデータか、その位置にある古いデータのいずれかになります。 |

## RAM ブロックの動作

次の図は、wren 信号と byteena 信号が RAM の動作を制御する方法を図示しています。

図 2-2: バイト・イネーブル機能の波形



この機能波形では、New Dataモードが選択されています。

## パック・モードのサポート

以下の条件の下、单一ブロックに 2 つのシングル・ポート・メモリ・ブロックを実装することができます。

- 2 つの独立したブロックのサイズがそれぞれ、M9K ブロック・サイズの半分以下であること。  
独立した各ブロックの最大データ幅が 18 ビット幅であること。
- 各シングル・ポート・メモリ・ブロックがそれぞれ、シングル・クロック・モードでコンフィギュレーションされていること。

### 関連情報

2-11 ページの **MAX 10 エンベデッド・メモリのクロック・モード**

## アドレス・クロック・イネーブルのサポート

- アドレス・クロック・イネーブル機能は、アドレス・クロック・イネーブル信号 (`addressstall`) がイネーブルされている間 (`addressstall = 1`) 以前のアドレス値を保持します。
- M9K メモリ・ブロックをデュアル・ポート・モードでコンフィギュレーションすると、各ポートは独立した専用のアドレス・クロック・イネーブルを有します。
- アドレス・クロック・イネーブル機能を使用して、キャッシュ・ミス時にキャッシュ・メモリ・アプリケーションの有効性を向上させます。
- `addressstall` 信号のデフォルト値は Low です。
- アドレス・レジスタ出力は、マルチプレクサを使用してレジスタ入力にフィード・バックします。マルチプレクサ出力は `addressstall` 信号によって選択されます。

図 2-3: アドレス・クロック・イネーブルのブロック図



## 読み取りサイクル中のアドレス・クロック・イネーブルの波形

図 2-4: 読み取りサイクル中のアドレス・クロック・イネーブルの波形



## 書き込みサイクル中のアドレス・クロック・イネーブルの波形

図 2-5: 書き込みサイクル中のアドレス・クロック・イネーブルの波形



## 非同期クリア

RAM: 1-PORT および RAM: 2-PORT IP コアを使用して、ロジカル・メモリごとに非同期クリアを選択的にイネーブルすることができます。

M9k ブロックは、次の非同期クリアをサポートします。

- 読み取りアドレス・レジスタ：読み取り動作中に非同期クリアを読み取りアドレス・レジスタにアサートすると、メモリの内容が破損する可能性があります。
- 出力レジスタ：非同期クリアを出力レジスタに適用すると、非同期クリア信号は出力レジスタをクリアし、即時にそれを確認することができます。RAM が出力レジスタを使用しない場合でも、出力ラッチの非同期クリア機能を使用して RAM 出力をクリアすることができます。
- 出力ラッチ

注: 読み取りアドレス・レジスタ以外の入力レジスタはサポートされません。

図 2-6: 出力ラッチの非同期クリアの波形



#### 関連情報

- [Internal Memory \(RAM and ROM\) User Guide](#)

### M9K ブロックにおけるレジスタのリセット

M9K ブロックのレジスタをリセットするには、3つの方法があります。

- デバイスをパワー・アップする
- 出力レジスタにのみ `aclr` 信号を使用する
- `DEV_CLRn` オプションを使用して、デバイス・ワイドのリセット信号をアサートする

## MAX 10 エンベデッド・メモリの動作モード

M9K メモリ・ブロックにより、複数の動作モードで完全同期 SRAM メモリを実装することができます。M9K メモリ・ブロックは、非同期（レジスタに格納されていない）メモリ入力をサポートしません。

注: M9K メモリ・ブロック入力レジスタでセットアップまたはホールド・タイムに違反すると、メモリの内容が破損する可能性があります。これは読み取りおよび書き込み動作のいずれにも当てはまります。

## サポートされるメモリの動作モード

表 2-2: M9K エンベデッド・メモリ・ブロックでサポートされるメモリ動作モード

| メモリの動作モード         | 関連する IP コア        | 説明                                                                                                                                                                                                                                                                                                                                    |
|-------------------|-------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| シングル・ポート RAM      | RAM: 1-PORT IP コア | <p>シングル・ポート・モードは、單一アドレスからの非同時の読み取りおよび書き込み動作をサポートします。</p> <p>書き込み動作中は、読み取りイネーブル・ポートを使用して RAM の出力ポートの動作を制御します。</p> <ul style="list-style-type: none"> <li>新しく書き込まれているデータ、あるいはそのアドレスの古いデータのいずれかを表示するには、書き込み動作中に読み取りイネーブルをアクティブにします。</li> <li>直近のアクティブ読み取りイネーブル中に保持していた以前の値を継続して保持するには、読み取りイネーブル・ポートがディアサートされた状態で書き込み動作を実行します。</li> </ul> |
| シンプル・デュアル・ポート RAM | RAM: 2-PORT IP コア | 書き込み動作がポート A で起こり、読み取り動作がポート B で起こる異なる位置に、読み取り動作と書き込み動作を同時に実行することができます。                                                                                                                                                                                                                                                               |
| トゥルー・デュアル・ポート RAM | RAM: 2-PORT IP コア | <p>2つのポート動作の任意の組み合わせを実行することができます。</p> <ul style="list-style-type: none"> <li>2つの読み取り、2つの書き込み、または、</li> <li>2つの異なるクロック周波数での1つの読み取りと1つの書き込み</li> </ul>                                                                                                                                                                                  |
| シングル・ポート ROM      | ROM: 1-PORT IP コア | <p>読み取り動作には1つのアドレス・ポートのみが使用可能です。</p> <p>メモリ・ブロックを ROM として使用することができます。</p> <ul style="list-style-type: none"> <li>.mif または.hex ファイルを使用して、メモリ・ブロックの ROM の内容を初期化します。</li> <li>ROM のアドレス・ラインはレジスタに格納されます。</li> <li>出力はレジスタに格納することも、しないことも可能です。</li> <li>ROM の読み取り動作は、シングル・ポート RAM コンフィギュレーションにおける読み取り動作と同じです。</li> </ul>                  |

| メモリの動作モード       | 関連する IP コア               | 説明                                                                                                                                                                                                                                                                                                                                                                                                  |
|-----------------|--------------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| デュアル・ポート ROM    | ROM: 2-PORT IP コア        | <p>デュアル・ポート ROM は、シングル・ポート ROM とほぼ同じ機能ポートを有します。この 2 つの相違点は、デュアル・ポート ROM は読み取り動作のための追加のアドレス・ポートを有することです。</p> <p>メモリ・ブロックを ROM として使用することができます。</p> <ul style="list-style-type: none"> <li>• .mif または.hex ファイルを使用して、メモリ・ブロックの ROM の内容を初期化します。</li> <li>• ROM のアドレス・ラインはレジスタに格納されます。</li> <li>• 出力はレジスタに格納することも、しないことも可能です。</li> <li>• ROM の読み取り動作は、シングル・ポート RAM コンフィギュレーションにおける読み取り動作と同じです。</li> </ul> |
| シフト・レジスタ        | シフト・レジスタ (RAM ベース) IP コア | <p>メモリ・ブロックをシフト・レジスタ・ブロックとして使用して、ロジック・セルと配線リソースを節約することができます。</p> <p>入力データ幅 (w)、タップの長さ (m)、およびタップの数 (n) によってシフト・レジスタの容量 (<math>w \times m \times n</math>) を決定します。</p> <p>より大きなシフト・レジスタを実装するためにメモリ・ブロックをカスケード接続することができます。</p>                                                                                                                                                                        |
| FIFO            | FIFO IP コア               | <p>メモリ・ブロックを FIFO バッファとして使用することができます。</p> <ul style="list-style-type: none"> <li>• シングル・クロック FIFO (SCFIFO) モードおよびデュアル・クロック FIFO (DCFIFO) モードで FIFO IP コアを使用して、デザインにシングルおよびデュアル・クロック FIFO バッファを実装します。</li> <li>• クロック・ドメイン間でデータを転送しているときは、デュアル・クロック FIFO バッファを使用します。</li> <li>• M9K メモリ・ブロックは、空の FIFO バッファからの同時の読み取りおよび書き込みをサポートしません。</li> </ul>                                                     |
| メモリ・ベースのマルチプライヤ | ALTMEMMULT IP コア         | メモリ・ブロックをメモリ・ベースのマルチプライヤとして使用することができます。                                                                                                                                                                                                                                                                                                                                                             |

## 関連情報

[MAX 10 エンベデッド・メモリに関する IP](#)

## MAX 10 エンベデッド・メモリのクロック・モード

| クロック・モード          | 説明                                                                                                                                                                                                                                                                                                                                     | モード                           |                               |                  |     |      |
|-------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------------------------------|-------------------------------|------------------|-----|------|
|                   |                                                                                                                                                                                                                                                                                                                                        | トゥル<br>ー・デ<br>ュア<br>ル・ポ<br>ート | シンプ<br>ル・デ<br>ュア<br>ル・ポ<br>ート | シング<br>ル・ポ<br>ート | ROM | FIFO |
| 独立クロック・モード        | <p>独立したクロックは次のポートで使用可能です。</p> <ul style="list-style-type: none"> <li>ポート A—クロック A がポート A 側のすべてのレジスタを制御します。</li> <li>ポート B—クロック B がポート B 側のすべてのレジスタを制御します。</li> </ul>                                                                                                                                                                   | あり                            | —                             | —                | あり  | —    |
| 入力/出力クロック・モード     | <ul style="list-style-type: none"> <li>M9K メモリ・ブロックは、シングル・ポート、トゥルー・デュアル・ポート、およびシンプル・デュアル・ポート・メモリ・モードの入力または出力クロック・モードを実装することができます。</li> <li>入力クロックは <code>data</code>、<code>address</code>、<code>byteena</code>、<code>wren</code>、および <code>rden</code> レジスタを含む、メモリ・ブロックへのすべての入力レジスタを制御します。</li> <li>出力クロックはデータ出力レジスタを制御します。</li> </ul> | あり                            | あり                            | あり               | あり  | —    |
| 読み取り/書き込みクロック・モード | <ul style="list-style-type: none"> <li>M9K メモリ・ブロックは、読み取りおよび書き込みクロックの独立したクロック・イネーブルをサポートします。</li> <li>読み取りクロックは、データ出力、読み取りアドレス、および読み取りイネーブル・レジスタを制御します。</li> <li>書き込みクロックは、データ入力、書き込みアドレス、および書き込みイネーブル・レジスタを制御します。</li> </ul>                                                                                                          | —                             | あり                            | —                | —   | あり   |
| シングル・クロック・モード     | シングル・クロックは、クロック・イネーブルと併用してメモリ・ブロックのすべてのレジスタを制御します。                                                                                                                                                                                                                                                                                     | あり                            | あり                            | あり               | あり  | あり   |

### 関連情報

- 2-5 ページの **パック・モードのサポート**
- 3-5 ページの **クロッキングをコントロールして消費電力を削減する**
- 2-12 ページの **同時読み取り/書き込みにおける出力読み取りデータ**

## クロック・モードの非同期クリア

非同期クリアは、すべてのクロック・モードで出力ラッチと出力レジスタにのみ使用可能です。独立クロック・モードでは、非同期クリアはポート A とポート B に適用することができます。

## 同時読み取り/書き込みにおける出力読み取りデータ

読み取りまたは書き込みクロック・モードを使用して同じアドレス位置に同時読み取り/書き込みを実行する場合、出力読み取りデータは未知の値となります。出力読み取りデータが既知の値として必要な場合は、シングル・クロック・モードまたは入力/出力クロック・モードを使用して、RAM: 1-PORT および RAM: 2-PORT IP コアで適切な Read-During-Write 動作を選択します。

### 関連情報

2-11 ページの [MAX 10 エンベデッド・メモリのクロック・モード](#)

## クロック・モードの独立クロック・イネーブル

表 2-3: 独立クロック・イネーブルでサポートされるクロック・モード

| クロック・モード  | 説明                           |
|-----------|------------------------------|
| 読み取り/書き込み | 読み取りおよび書き込みクロックの両方でサポートされます。 |
| 独立        | 両ポートのレジスタでサポートされます。          |

## MAX 10 エンベデッド・メモリの構成

表 2-4: M9K エンベデッド・メモリ・ブロックでサポートされる最大コンフィギュレーション

| 機能                      | M9K ブロック |
|-------------------------|----------|
|                         | 8192 × 1 |
|                         | 4096 × 2 |
|                         | 2048 × 4 |
|                         | 1024 × 8 |
| コンフィギュレーション<br>(深さ × 幅) | 1024 × 9 |
|                         | 512 × 16 |
|                         | 512 × 18 |
|                         | 256 × 32 |
|                         | 256 × 36 |

## ポート幅コンフィギュレーション

次の式はポート幅のコンフィギュレーションを定義します：メモリの深さ（ワードの数）×データ入力バスの幅

- ポート幅コンフィギュレーション（深さまたは幅のいずれか）が、内部メモリ・ブロックによってサポート可能な量を超える場合、追加のメモリ・ブロック（同じタイプのもの）が使用されます。たとえば、M9Kをサポートされるポート幅  $512 \times 18$  を超える  $512 \times 36$  にコンフィギュレーションする場合、RAMを実装するにあたって2つのM9Kが使用されます。
- サポートされるコンフィギュレーションに加えて、メモリの深さを2のべき乗以外に設定することができます。ただし、割り当てられる実際のメモリの深さは変えることができます。この変動は、実装されるリソースのタイプによって異なります。
- メモリが専用メモリ・ブロックに実装される場合、メモリの深さを2のべき乗以外に設定することは、実際のメモリの深さを反映します。
- 専用メモリ・ブロックを使用してメモリを実装する際は、実際のメモリの深さを確認するにあたってフィッタ・レポートを参照してください。

## データ幅混合ポートのコンフィギュレーション

データ幅混合ポートのコンフィギュレーション・サポートによって、M9Kメモリ・ブロックに異なるデータ幅の読み取りおよび書き込み動作を実行することができます。データ幅混合ポートのコンフィギュレーションは、以下のメモリ・モードによってサポートされます。

- シンプル・デュアル・ポート RAM
- トゥルー・デュアル・ポート RAM
- FIFO

## M9K ブロックのデータ幅混合のコンフィギュレーション（シンプル・デュアル・ポート RAM モード）

| 読み取りポート         | 書き込みポート         |                 |                 |                 |                 |                 |                 |                 |                 |
|-----------------|-----------------|-----------------|-----------------|-----------------|-----------------|-----------------|-----------------|-----------------|-----------------|
|                 | $8192 \times 1$ | $4096 \times 2$ | $2048 \times 4$ | $1024 \times 8$ | $512 \times 16$ | $256 \times 32$ | $1024 \times 9$ | $512 \times 18$ | $256 \times 36$ |
| $8192 \times 1$ | あり              | あり              | あり              | あり              | あり              | あり              | —               | —               | —               |
| $4096 \times 2$ | あり              | あり              | あり              | あり              | あり              | あり              | —               | —               | —               |
| $2048 \times 4$ | あり              | あり              | あり              | あり              | あり              | あり              | —               | —               | —               |
| $1024 \times 8$ | あり              | あり              | あり              | あり              | あり              | あり              | —               | —               | —               |
| $512 \times 16$ | あり              | あり              | あり              | あり              | あり              | あり              | —               | —               | —               |
| $256 \times 32$ | あり              | あり              | あり              | あり              | あり              | あり              | —               | —               | —               |
| $1024 \times 9$ | —               | —               | —               | —               | —               | —               | あり              | あり              | あり              |
| $512 \times 18$ | —               | —               | —               | —               | —               | —               | あり              | あり              | あり              |
| $256 \times 36$ | —               | —               | —               | —               | —               | —               | あり              | あり              | あり              |

## M9K ブロックのデータ幅混合のコンフィギュレーション（トゥルー・デュアル・ポート RAM モード）

| 読み取りポート | 書き込みポート |        |        |        |        |        |        |
|---------|---------|--------|--------|--------|--------|--------|--------|
|         | 8192×1  | 4096×2 | 2048×4 | 1024×8 | 512×16 | 1024×9 | 512×18 |
| 8192×1  | あり      | あり     | あり     | あり     | あり     | —      | —      |
| 4096×2  | あり      | あり     | あり     | あり     | あり     | —      | —      |
| 2048×4  | あり      | あり     | あり     | あり     | あり     | —      | —      |
| 1024×8  | あり      | あり     | あり     | あり     | あり     | —      | —      |
| 512×16  | あり      | あり     | あり     | あり     | あり     | —      | —      |
| 1024×9  | —       | —      | —      | —      | —      | あり     | あり     |
| 512×18  | —       | —      | —      | —      | —      | あり     | あり     |

## 最大ブロック深度の設定

**Set the maximum block depth** パラメータは、使用する専用メモリ・ブロックの最大ブロック深度を制限することを可能にします。メモリ・ブロックは必要な最大ブロック深度にスライスすることができます。たとえば、M9K ブロックの容量が 9,216 ビットであると、各アドレスが 1 ビット ( $8K \times 1$ ) を保存できるデフォルトのメモリ深度は 8K です。最大ブロック深度を 512 に設定する場合、M9K ブロックは 512 の深さにスライスされ、各アドレスは最大 18 ビット ( $512 \times 18$ ) を保存することができます。

このパラメータを使用してデバイスにおける消費電力を節約し、使用されるメモリ・ブロックの数を削減します。ただし、このパラメータは LE の数を増加させ、デザインの性能に影響を与えることもあります。

RAM が浅くスライスされる場合、ダイナミック消費電力量が減少します。ただし、深度 256 の RAM ブロックでは、追加の LE によって使用される電力がより深いスライスによって得られるパワー・ゲインを上回ります。

最大ブロック深度は 2 のべき乗である必要があります、有効な値はそれぞれの専用メモリ・ブロックで異なります。

次の表は、M9K メモリ・ブロックの最大ブロック深度の有効範囲をリストしています。

表 2-5: M9K メモリ・ブロックの最大ブロック深度の有効範囲

| メモリ・ブロック | 有効範囲                                 |
|----------|--------------------------------------|
| M9K      | 256 - 8K。最大ブロック深度は 2 のべき乗である必要があります。 |

最大ブロック深度に有効でない値を入力した場合、IP パラメータ・エディタにエラー・メッセージが表示されます。アルテラは、適切な最大ブロック深度が分からぬ場合やこの設定がデザインに重要でない場合は、**Set the maximum block depth** パラメータの値を **Auto** に設定することを推奨します。**Auto** 設定はコンパイラをイネーブルし、メモリの内部メモリ・ブロックのタイプに適したポート幅コンフィギュレーションの最大ブロック深度を選択します。

# MAX 10 エンベデッド・メモリのデザイン検討 事項

3

2014.09.22

UG-M10MEMORY

✉ 署名

💬 フィードバック

デザインを確実に作成するには、いくつか考慮すべき事項があります。

## 外部の競合解決を実装する

トゥルー・デュアル・ポート RAM モードでは、同じメモリ位置に 2 つの書き込み動作を実行することができます。ただし、メモリ・ブロックは内部競合解決回路を有しません。

アドレスに未知のデータが書き込まれることを防ぐには、メモリ・ブロックに外部競合解決ロジックを実装します。

## Read-During-Write 動作をカスタマイズする

デザイン要件に合うよう、メモリ・ブロックの Read-During-Write 動作をカスタマイズします。

図 3-1: 2 つのタイプの Read-During-Write 動作における違い—同一ポートと混合ポート



### 関連情報

2-3 ページの [Read-During-Write](#)

© 2014 Altera Corporation. All rights reserved. ALTERA, ARRIA, CYCLONE, ENPIRION, MAX, MEGACORE, NIOS, QUARTUS and STRATIX words and logos are trademarks of Altera Corporation and registered in the U.S. Patent and Trademark Office and in other countries. All other words and logos identified as trademarks or service marks are the property of their respective holders as described at [www.altera.com/common/legal.html](http://www.altera.com/common/legal.html). Altera warrants performance of its semiconductor products to current specifications in accordance with Altera's standard warranty, but reserves the right to make changes to any products and services at any time without notice. Altera assumes no responsibility or liability arising out of the application or use of any information, product, or service described herein except as expressly agreed to in writing by Altera. Altera customers are advised to obtain the latest version of device specifications before relying on any published information and before placing orders for products or services.

ISO  
9001:2008

## 同一ポートの Read-During-Write モード

同一ポートの Read-During-Write モードは、シングル・ポート RAM またはトゥルー・デュアル・ポート RAM の同一ポートに適用します。

**表 3-1: 同一ポート Read-During-Write モードでのエンベデッド・メモリ・ブロックの出力モード**

次の表は、同一ポート Read-During-Write モードのエンベデッド・メモリ・ブロックを選択する場合に使用可能な出力モードをリストしています。

| 出力モード                  | 説明                                                                                                                                                                                                                                                                                                             |
|------------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| "new data"<br>(フロースルー) | <p>新しいデータは、新しいデータが書き込まれるのと同じクロック・サイクルの立ち上がりエッジで使用可能です。</p> <p>New Data モードをバイト・イネーブルと併せて使用すると、RAM の出力を制御することができます。</p> <p>バイト・イネーブルが High のとき、メモリに書き込まれたデータは出力に送られます（フロースルー）。</p> <p>バイト・イネーブルが Low のとき、マスク・オフされたデータはメモリに書き込まれず、メモリ内の古いデータが出力に現れます。そのため、出力は byteena によって決定される新しいデータと古いデータの組み合わせにすることができます。</p> |
| "don't care"           | RAM 出力は書き込み動作を進める前に、そのアドレスにある古いデータを反映します。                                                                                                                                                                                                                                                                      |

**図 3-2: 同一ポートの Read-During-Write : New Data モード**



図 3-3: 同一ポートの Read-During-Write: Old Data モード



## 混合ポートの Read-During-Write モード

混合ポートの Read-During-Write モードは、2つのポートが同じクロックを使用して同じメモリ・アドレスで読み取りおよび書き込み動作を実行する（一方のポートがアドレスから読み取り、他方のポートがアドレスに書き込む）、シンプルおよびトゥルー・デュアル・ポート RAM モードに適用します。

表 3-2: 混合ポート Read-During-Write モードでの RAM の出力モード

| 出力モード        | 説明                                                                      |
|--------------|-------------------------------------------------------------------------|
| "old data"   | 異なるポートへの Read-During-Write 動作により、RAM 出力は特定のアドレスにある "old data" の値を反映します。 |
| "don't care" | RAM は "don't care" または "unknown" の値を出力します。                              |

図 3-4: 混合ポートの Read-During-Write : Old Data モード



Don't Care モードでは、Old Dataが“Don't Care”と置き換わります。

### デュアル・クロックを使用する混合ポートの Read-During-Write 動作

デュアル・クロックを使用する混合ポートの Read-During-Write 動作では、クロック間の関係がメモリの出力動作を決定します。

| 以下の場合 :             | 次のようにになります :                                                                                            |
|---------------------|---------------------------------------------------------------------------------------------------------|
| 2つのクロックに同じクロックを使用する | 出力はアドレス位置からの古いデータです。                                                                                    |
| 異なるクロックを使用する        | 混合ポートの Read-During-Write 動作中、出力は不定です。この不定値は、読み取りが書き込みの前に実行されるか後に実行されるかによって、アドレス位置で古いデータあるいは新しいデータになります。 |

### パワーアップ状態およびメモリの初期化

初期パワーアップ値を評価するロジックをデザインしている場合、次の表にリストされているように、異なるタイプのメモリ・ブロックのパワーアップ状態を考慮します。

表 3-3: エンベデッド・メモリ・ブロックの初期パワーアップ値

| メモリ・タイプ | 出力レジスタ   | パワーアップ値 |
|---------|----------|---------|
| M9K     | Used     | ゼロ（クリア） |
|         | Bypassed | ゼロ（クリア） |

デフォルトでは、.mif を指定しない限り Quartus II ソフトウェアは RAM セルをゼロに初期化します。

すべてのメモリ・ブロックは.mif による初期化をサポートします。デザインでメモリをインスタンス化する際、Quartus II ソフトウェアで.mif ファイルを作成し、RAM IP でそれらの使用を指定することができます。メモリが事前に初期化されている（たとえば.mif を使用して）場合でも、パワーアップ時に出力はクリアされています。パワーアップ以後の読み取りによってのみ、事前に初期化された値が出力されます。

## クロッキングをコントロールして消費電力を削減する

各メモリ・ブロックのクロッキングを制御することにより、デザインの AC 消費電力を削減します。

- 読み取りイネーブル信号を使用して、必要なときにのみ読み取り動作が実行されるようにします。Read-During-Write が不要なデザインの場合、書き込み動作中またはメモリ動作が実行されていない期間に読み取りイネーブル信号をディアサートすることによって消費電力を削減することができます。
- Quartus II ソフトウェアを使用して未使用のメモリ・ブロックを自動的に低消費電力モードにし、スタティック消費電力を削減します。
- 消費電力を節約するために、異なる入力および出力レジスタに独立クロック・イネーブルを作成して特定のレジスタのシャット・ダウンを制御します。使用する独立クロック・イネーブルを設定するには、パラメータ・エディタで **More Options**（クロック・イネーブル・オプションの隣）をクリックします。

### 関連情報

2-11 ページの **MAX 10 エンベデッド・メモリのクロック・モード**

## Read-During-Write 出力の選択

- シングル・ポート RAM は、同一ポートの Read-During-Write のみをサポートし、クロック・モードはシングル・クロック・モードまたは入力/出力クロック・モードのいずれかである必要があります。
- シンプル・デュアル・ポート RAM は、混合ポートの Read-During-Write のみをサポートし、クロック・モードはシングル・クロック・モードまたは入力/出力クロック・モードのいずれかである必要があります。
- トゥルー・デュアル・ポート RAM は、同一ポートの Read-During-Write と混合ポートの Read-During-Write をサポートします。
  - 同一ポートの Read-During-Write では、クロック・モードはシングル・クロック・モード、入力/出力クロック・モード、あるいは独立クロック・モードのいずれかである必要があります。
  - 混合ポートの Read-During-Write では、クロック・モードはシングル・クロック・モード、または入力/出力クロック・モードのいずれかである必要があります。

**注:** Read-During-Write が起こるとき、出力について特に懸念がなく、性能を向上させたい場合は **Don't Care** を選択します。 **Don't Care** を選択すると、メモリ・ブロックをインスタンス化する際にユーザーがブロック・タイプを割り当てなければ、使用されているメモリブロックのタイプの柔軟性が向上します。

表 3-4: 同一ポートおよび混合ポートの Read-During-Write の出力選択

| メモリ・ブロック | シングル・ポート RAM                       | シンプル・デュアル・ポート RAM        | トゥルー・デュアル・ポート RAM        |                          |
|----------|------------------------------------|--------------------------|--------------------------|--------------------------|
|          | 同一ポートの Read-During-Write           | 混合ポートの Read-During-Write | 同一ポートの Read-During-Write | 混合ポートの Read-During-Write |
| M9K      | Don't Care<br>New Data<br>Old Data | Old Data<br>Don't Care   | New Data<br>Old Data     | Old Data<br>Don't Care   |

# RAM: 1-PORT IP コア・リファレンス

4

2014.09.22

UG-M10MEMORY

✉ 署名

💬 フィードバック

RAM: 1-PORT IP コアは、シングル・ポート RAM メモリ・モードを実装します。

図 4-1: Single Clock オプションがイネーブルされた RAM: 1-PORT IP コア信号



図 4-2: Dual Clock オプションがイネーブルされた RAM: 1-PORT IP コア信号



© 2014 Altera Corporation. All rights reserved. ALTERA, ARRIA, CYCLONE, ENPIRION, MAX, MEGACORE, NIOS, QUARTUS and STRATIX words and logos are trademarks of Altera Corporation and registered in the U.S. Patent and Trademark Office and in other countries. All other words and logos identified as trademarks or service marks are the property of their respective holders as described at [www.altera.com/common/legal.html](http://www.altera.com/common/legal.html). Altera warrants performance of its semiconductor products to current specifications in accordance with Altera's standard warranty, but reserves the right to make changes to any products and services at any time without notice. Altera assumes no responsibility or liability arising out of the application or use of any information, product, or service described herein except as expressly agreed to in writing by Altera. Altera customers are advised to obtain the latest version of device specifications before relying on any published information and before placing orders for products or services.

ISO  
9001:2008

## MAX 10 デバイスの RAM: 1-PORT IP コア信号

表 4-1: RAM: 1-PORT IP コア入力信号

| 信号             | 必要性   | 説明                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  |
|----------------|-------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| data           | あり    | メモリへのデータ入力。data ポートが必要であり、幅は $q$ ポートの幅と等しいものである必要があります。                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             |
| address        | あり    | メモリへのアドレス入力。                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        |
| wren           | あり    | wraddress ポートの書き込みイネーブル入力。<br>wren ポートが必要です。                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        |
| addressstall_a | オプション | addressstall_a ポートが High である間、address_a ポートの以前のアドレスを保持するためのアドレス・クロック・イネーブル入力。                                                                                                                                                                                                                                                                                                                                                                                                                                                                       |
| clock          | あり    | <p>以下のリストは、どのメモリ・クロックを clock ポートに接続する必要があるのか、また異なるクロッキング・モードでのポート同期について説明しています。</p> <ul style="list-style-type: none"> <li>シングル・クロックシングル・ソース・クロックを clock ポートに接続します。レジスタに格納されたすべてのポートは、同じソース・クロックで同期化されます。</li> <li>読み取り/書き込み—書き込みクロックを clock ポートに接続します。data_a ポート、address_a ポート、wren_a ポート、および byteena_a ポートなどの書き込み動作に関連するすべてのレジスタされたポートは、書き込みクロックで同期化されます。</li> <li>入力/出力—入力クロックを clock ポートに接続します。レジスタに格納されたすべての入力ポートは、入力クロックで同期化されます。</li> <li>独立クロック—ポート A クロックを clock ポートに接続します。レジスタに格納されたポート A のすべての入力および出力ポートは、ポート A クロックで同期化されます。</li> </ul> |
| clkena         | オプション | clock ポートのクロック・イネーブル入力。                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             |
| rden           | オプション | rdaddress ポートの読み取りイネーブル入力。                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          |
| aclr           | オプション | レジスタされた入力および出力ポートを非同期クリアします。非同期クリアは、indata_aclr、wraddress_aclr などの対応する非同期クリア・パラメータを介して制御可能なレジスタに格納されたポートに影響します。                                                                                                                                                                                                                                                                                                                                                                                                                                     |

| 信号         | 必要性   | 説明                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        |
|------------|-------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| inclock    | オプション | <p>以下のリストは、どのメモリ・クロックを <code>inclock</code> ポートに接続する必要があるのか、また異なるクロック・モードでのポート同期について説明しています。</p> <ul style="list-style-type: none"> <li>シングル・クロック—シングル・ソース・クロックを <code>inclock</code> ポートと <code>outclock</code> ポートに接続します。レジスタに格納されたすべてのポートは、同じソース・クロックで同期化されます。</li> <li>読み取り/書き込み—書き込みクロックを <code>inclock</code> ポートに接続します。<code>data</code> ポート、<code>wraddress</code> ポート、<code>wren</code> ポート、および <code>byteena</code> ポートなどの書き込み動作に関連するレジスタに格納されたすべてのポートは、書き込みクロックで同期化されます。</li> <li>入力/出力—入力クロックを <code>inclock</code> ポートに接続します。レジスタに格納されたすべての入力ポートは、入力クロックで同期化されます。</li> </ul> |
| inclocken  | オプション | <code>inclock</code> ポートのクロック・イネーブル入力。                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    |
| outclock   | オプション | <p>以下のリストは、どのメモリ・クロックを <code>outclock</code> ポートに接続する必要があるのか、また異なるクロック・モードでのポート同期について説明しています。</p> <ul style="list-style-type: none"> <li>シングル・クロック—シングル・ソース・クロックを <code>inclock</code> ポートと <code>outclock</code> ポートに接続します。レジスタに格納されたすべてのポートは、同じソース・クロックで同期化されます。</li> <li>読み取り/書き込み—読み取りクロックを <code>outclock</code> ポートに接続します。<code>rdaddress</code> ポート、<code>rdren</code> ポート、および <code>q</code> ポートなどの読み取り動作に関連するレジスタに格納されたすべてのポートは、読み取りクロックで同期化されます。</li> <li>入力/出力—出力クロックを <code>outclock</code> ポートに接続します。レジスタに格納された <code>q</code> ポートは、出力クロックで同期化されます。</li> </ul>               |
| outclocken | オプション | <code>outclock</code> ポートのクロック・イネーブル入力。                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   |

表 4-2: RAM: 1-PORT IP コア出力ポート

| 信号             | 必要性 | 説明                                                                         |
|----------------|-----|----------------------------------------------------------------------------|
| <code>q</code> | あり  | メモリからのデータ出力。 <code>q</code> ポートは、 <code>data</code> ポートの幅と等しいものである必要があります。 |

## MAX 10 デバイスの RAM: 1-PORT IP コアのパラメータ

**表 4-3: MAX 10 デバイスの RAM: 1-PORT IP コアのパラメータ**

この表は、 MAX 10 デバイスに適用可能な IP コアのパラメータをリストしています。

| パラメータ                                  | 値                                                                                                                         | 説明                    |
|----------------------------------------|---------------------------------------------------------------------------------------------------------------------------|-----------------------|
| <b>パラメータ設定 : Widths/Blk Type/Clks</b>  |                                                                                                                           |                       |
| How wide should the 'q' output bus be? | 1、2、3、4、5、6、7、8、9、10、11、12、13、14、15、16、17、18、19、20、21、22、23、24、25、26、27、28、29、30、31、32、36、40、48、64、72、108、128、144、および 256 | ビット内の「q」出力バスの幅を指定します。 |
| How many <X>-bit words of memory?      | 32、64、128、256、512、1024、2048、4096、8192、16384、32768、および 65536                                                               | <X>ビット・ワードの数を指定します。   |

### What should the memory block type be?

|                                |                                                |                                                               |
|--------------------------------|------------------------------------------------|---------------------------------------------------------------|
| Auto                           | On / Off                                       | メモリ・ブロックのタイプを指定します。選択できるメモリ・ブロックのタイプは、ターゲットのデバイスによって異なります。    |
| M9K                            | On / Off                                       |                                                               |
| LC                             | On / Off                                       |                                                               |
| オプション                          | Use default logic cell style                   | ロジック・セル実装のオプションを指定します。LC メモリ・タイプを選択する場合にのみ、このオプションがイネーブルされます。 |
|                                | Use Stratix M512 emulation logic cell style    |                                                               |
| Set the maximum block depth to | Auto、32、64、128、256、512、1024、2048、4096、および 8192 | ワード内の最大ブロック深度を指定します。LC メモリ・タイプを選択する場合にのみ、このオプションがディセーブルされます。  |

### What clocking method would you like to use?

|              |          |                                                |
|--------------|----------|------------------------------------------------|
| Single clock | On / Off | シングル・クロックとクロック・イネーブルは、メモリ・ブロックのすべてのレジスタを制御します。 |
|--------------|----------|------------------------------------------------|

| パラメータ                                  | 値        | 説明                                                                                                                          |
|----------------------------------------|----------|-----------------------------------------------------------------------------------------------------------------------------|
| Dual clock : 個別の「入力」および「出力」クロックを使用します。 | On / Off | 入力および出力クロックは、データ、アドレス、バイト・イネーブル、読み取りイネーブル、および書き込みイネーブルを含むメモリ・ブロックからのデータ入力とデータ出力およびメモリ・ブロックへのデータ入力とデータ出力に関連するすべてのレジスタを制御します。 |

**パラメータ設定 : Regs/Clkens/Byte Enable/Acls****Which ports should be registered?**

|                                                               |                                              |                                                                                                       |
|---------------------------------------------------------------|----------------------------------------------|-------------------------------------------------------------------------------------------------------|
| 'data' and 'wren' input ports                                 | —                                            | このオプションは自動的にイネーブルされます。読み取りまたは書き込み入力ポート、読み取りまたは書き込み出力ポートをレジスタに格納するかどうかを指定します。                          |
| 'address' input port                                          | —                                            | このオプションは自動的にイネーブルされます。読み取りまたは書き込み入力ポート、読み取りまたは書き込み出力ポートをレジスタに格納するかどうかを指定します。                          |
| 'q' output port                                               | On / Off                                     | 読み取りまたは書き込み入力ポート、読み取りまたは書き込み出力ポートをレジスタに格納するかどうかを指定します。                                                |
| Create one clock enable signal for each clock signal.         | On / Off                                     | 各クロック信号に 1 つのクロック・イネーブル信号を作成するためのオプションをオンにするかどうかを指定します。                                               |
| More Options                                                  | Use clock enable for port A input registers  | ポート A 入力および出力レジスタにクロック・イネーブルを使用するかどうかを指定します。                                                          |
|                                                               | Use clock enable for port A output registers | ポート A 入力および出力レジスタにクロック・イネーブルを使用するかどうかを指定します。                                                          |
|                                                               | Create an 'addressstall_a' input port        | アドレス・レジスタのクロック・イネーブルを作成するかどうかを指定します。これらのポートは、アドレス・レジスタの追加のアクティブ Low クロック・イネーブル入力として機能するよう作成することができます。 |
| Create an 'aclr' asynchronous clear for the registered ports. | On / Off                                     | レジスタに格納されたポートの非同期クリア・ポートを作成するかどうかを指定します。                                                              |
| More Options                                                  | 'q' port                                     | 'q' ポートが aclr ポートによってクリアされるかを指定します。                                                                   |

| パラメータ                              | 値        | 説明                                           |
|------------------------------------|----------|----------------------------------------------|
| Create a 'rden' read enable signal | On / Off | rd <sub>en</sub> 読み取りイネーブル信号を作成するかどうかを指定します。 |

### パラメータ設定 : Read During Write Option

#### Single Port Read During Write Option

|                                                                                   |                                                                                                        |                                                                                                                                                                                                                                                                                                           |
|-----------------------------------------------------------------------------------|--------------------------------------------------------------------------------------------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| What should the q output be when reading from a memory location being written to? | <ul style="list-style-type: none"> <li>• Don't Care</li> <li>• New Data</li> <li>• Old Data</li> </ul> | <p>Read-During-Write が起こるときの出力動作を指定します。</p> <ul style="list-style-type: none"> <li>• Don't Care—RAM は Read-During-Write 動作の"don't care"または"unknown"値を出力します。</li> <li>• New Data—データが書き込まれたものと同じクロック・サイクルの立ち上がりエッジで新しいデータが使用可能です。</li> <li>• Old Data—RAM 出力は書き込み動作を進める前に、そのアドレスにある古いデータを反映します。</li> </ul> |
| Get x's for write masked bytes instead of old data when byte enable is used       | On / Off                                                                                               | マスクされたバイトで「X」を取得するには、このオプションをオンにします。                                                                                                                                                                                                                                                                      |

### パラメータ設定 : Mem Init

#### Do you want to specify the initial content of the memory?

|                                                                   |          |                                                                                                                                                                                                                                                                              |
|-------------------------------------------------------------------|----------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| No, leave it blank                                                | On / Off | メモリの初期内容を指定します。メモリをゼロに初期化します。                                                                                                                                                                                                                                                |
| Initialize memory content data to XX..X on power-up in simulation | On / Off |                                                                                                                                                                                                                                                                              |
| Yes, use this file for the memory content data                    | On / Off | <p>メモリ初期化ファイル (.mif) または 16 進 (Intel-Format) ファイル (.hex) を指定することを可能にします。</p> <p>注: デバイスのコンフィギュレーション手法は内部コンフィギュレーションです。メモリの初期化を使用するためには、Enable ERAM Preload オプションをオンにする必要があります。Enable ERAM Preload オプションは、More Analysis &amp; Synthesis Settings ダイアログ・ポップスでオンにすることができます。</p> |

| パラメータ                                                                                                 | 値        | 説明                                                                                      |
|-------------------------------------------------------------------------------------------------------|----------|-----------------------------------------------------------------------------------------|
| Allow In-System Memory Content Editor to capture and update content independently of the system clock | On / Off | In-System Memory Content Editor がシステム・クロックに関わらずメモリのコンテンツをキャプチャし、更新することを可能にするかどうかを指定します。 |
| The 'Instance ID' of this RAM is                                                                      | —        | RAM ID を指定します。                                                                          |

# RAM: 2-PORT IP コア・リファレンス

5

2014.09.22

UG-M10MEMORY

✉ 署名

💬 フィードバック

RAM: 2-PORT IP コアは、シンプル・デュアル・ポート RAM およびトゥルー・デュアル・ポート RAM メモリ・モードを実装します。

図 5-1: シングル・クロック・オプションがイネーブルされた、1 つの読み取りポートと 1 つの書き込みポートを有する RAM: 2-PORT IP コア信号



© 2014 Altera Corporation. All rights reserved. ALTERA, ARRIA, CYCLONE, ENPIRION, MAX, MEGACORE, NIOS, QUARTUS and STRATIX words and logos are trademarks of Altera Corporation and registered in the U.S. Patent and Trademark Office and in other countries. All other words and logos identified as trademarks or service marks are the property of their respective holders as described at [www.altera.com/common/legal.html](http://www.altera.com/common/legal.html). Altera warrants performance of its semiconductor products to current specifications in accordance with Altera's standard warranty, but reserves the right to make changes to any products and services at any time without notice. Altera assumes no responsibility or liability arising out of the application or use of any information, product, or service described herein except as expressly agreed to in writing by Altera. Altera customers are advised to obtain the latest version of device specifications before relying on any published information and before placing orders for products or services.

ISO  
9001:2008

図 5-2: One Read Port and One Write Port、および Dual Clock: Use Separate 'Read' and 'Write' Clocks オプションがイネーブルされた RAM: 2-PORT IP コア信号



図 5-3: One Read Port and One Write Port、および Dual Clock: Use Separate 'Input' and 'Output' Clocks オプションがイネーブルされた RAM: 2-PORT IP コア信号



図 5-4: Two Read/Write Ports および Single Clock オプションがイネーブルされた RAM: 2-PORT IP コア信号



図 5-5: Two Read/Write Ports および Dual Clock: Use Separate 'Input' and 'Output' Clocks オプションがイネーブルされた RAM: 2-PORT IP コア信号



図 5-6: Two Read/Write Ports および Dual Clock: Use Separate for A and B Ports オプションがインエーブルされた RAM: 2-PORT IP コア信号



## MAX 10 デバイスの RAM: 2-PORT IP コア信号 (シンプル・デュアル・ポート RAM)

表 5-1: RAM: 2-PORT IP コア入力信号 (シンプル・デュアル・ポート RAM)

| 信号                     | 必要性 | 説明                                                                                                 |
|------------------------|-----|----------------------------------------------------------------------------------------------------|
| <code>data</code>      | あり  | メモリへのデータ入力。 <code>data</code> ポートが必要であり、幅は <code>q</code> ポートの幅と等しいものである必要があります。                   |
| <code>wraddress</code> | あり  | メモリへの書き込みアドレス入力。 <code>wraddress</code> ポートが必要であり、幅は <code>wraddress</code> ポートの幅と等しいものである必要があります。 |
| <code>wren</code>      | あり  | <code>wraddress</code> ポートの書き込みイネーブル入力。 <code>wren</code> ポートが必要です。                                |
| <code>rdaddress</code> | あり  | メモリへの読み取りアドレス入力。 <code>rdaddress</code> ポートが必要であり、幅は <code>wraddress</code> ポートの幅と等しいものである必要があります。 |

| 信号       | 必要性 | 説明                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          |
|----------|-----|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| clock    | あり  | <p>以下のリストは、どのメモリ・クロックを <code>clock</code> ポートに接続する必要があるのか、また異なるクロック・モードでのポート同期について説明しています。</p> <ul style="list-style-type: none"> <li>シングル・クロック—シングル・ソース・クロックを <code>clock</code> ポートに接続します。レジスタに格納されたすべてのポートは、同じソース・クロックで同期化されます。</li> <li>読み取り/書き込み—書き込みクロックを <code>clock</code> ポートに接続します。 <code>data_a</code> ポート、<code>address_a</code> ポート、<code>wren_a</code> ポート、および <code>byteena_a</code> ポートなどの書き込み動作に関連するすべてのレジスタに格納されたポートは、書き込みクロックで同期化されます。</li> <li>入力/出力—入力クロックを <code>clock</code> ポートに接続します。レジスタに格納されたすべての入力ポートは、入力クロックで同期化されます。</li> <li>独立クロック—ポート A クロックを <code>clock</code> ポートに接続します。レジスタに格納されたポート A のすべての入力および出力ポートは、ポート A クロックで同期化されます。</li> </ul> |
| inclock  | あり  | <p>以下のリストは、どのメモリ・クロックを <code>inclock</code> ポートに接続する必要があるのか、また異なるクロック・モードでのポート同期について説明しています。</p> <ul style="list-style-type: none"> <li>シングル・クロック—シングル・ソース・クロックを <code>inclock</code> ポートと <code>outclock</code> ポートに接続します。レジスタに格納されたすべてのポートは、同じソース・クロックで同期化されます。</li> <li>読み取り/書き込み—書き込みクロックを <code>inclock</code> ポートに接続します。 <code>data</code> ポート、<code>wraddress</code> ポート、<code>wren</code> ポート、および <code>byteena</code> ポートなどの書き込み動作に関連するレジスタに格納されたすべてのポートは、書き込みクロックで同期化されます。</li> <li>入力/出力—入力クロックを <code>inclock</code> ポートに接続します。レジスタに格納されたすべての入力ポートは、入力クロックで同期化されます。</li> </ul>                                                                                  |
| outclock | あり  | <p>以下のリストは、どのメモリ・クロックを <code>outclock</code> ポートに接続する必要があるのか、また異なるクロック・モードでのポート同期について説明しています。</p> <ul style="list-style-type: none"> <li>シングル・クロック—シングル・ソース・クロックを <code>inclock</code> ポートと <code>outclock</code> ポートに接続します。レジスタに格納されたすべてのポートは、同じソース・クロックで同期化されます。</li> <li>読み取り/書き込み—読み取りクロックを <code>outclock</code> ポートに接続します。 <code>rdaddress</code> ポート、<code>rdren</code> ポート、および <code>q</code> ポートなどの読み取り動作に関連するレジスタに格納されたすべてのポートは、読み取りクロックで同期化されます。</li> <li>入力/出力—出力クロックを <code>outclock</code> ポートに接続します。レジスタに格納された <code>q</code> ポートは、出力クロックで同期化されます。</li> </ul>                                                                                                |

| 信号         | 必要性   | 説明                                                                                                                                                                                                                                                          |
|------------|-------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| rden       | オプション | rdaddress ポートの読み取りイネーブル入力。rden ポートは use_eab パラメータが OFF に設定されるときにサポートされます。What should the memory block type be? パラメータが MLAB に設定されるとき、rden ポートはサポートされません。読み取りイネーブル機能を別のメモリ・ブロックで使用する場合、IP コアをインスタンス化します。                                                      |
| byteena_a  | オプション | <p>data_a ポートをマスクするためのバイト・イネーブル入力。data_a ポートをマスクすることにより、データの特定のバイト、ニブル、またはビットのみが書き込まれます。byteena_a ポートは以下の条件ではサポートされません。</p> <ul style="list-style-type: none"> <li>implement_in_les パラメータが ON に設定される。</li> <li>operation_mode パラメータが ROM に設定される。</li> </ul> |
| outclocken | オプション | outclock ポートのクロック・イネーブル入力。                                                                                                                                                                                                                                  |
| inclocken  | オプション | inclock ポートのクロック・イネーブル入力。                                                                                                                                                                                                                                   |

表 5-2: RAM: 2-PORT IP コア出力信号（シンプル・デュアル・ポート RAM）

| 信号 | 必要性 | 説明                                                     |
|----|-----|--------------------------------------------------------|
| q  | あり  | メモリからのデータ出力。q ポートが必要であり、幅は data ポートの幅と等しいものである必要があります。 |

## MAX 10 デバイスの RAM: 2-PORT IP コア信号（トゥルー・デュアル・ポート RAM）

表 5-3: RAM: 2-PORT IP コア入力信号（トゥルー・デュアル・ポート RAM）

| 信号        | 必要性   | 説明                                                                                                                                                                                        |
|-----------|-------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| data_a    | オプション | <p>メモリのポート A へのデータ入力。operation_mode パラメータを以下の値のいずれかに設定する場合、data_a ポートが必要です。</p> <ul style="list-style-type: none"> <li>SINGLE_PORT</li> <li>DUAL_PORT</li> <li>BIDIR_DUAL_PORT</li> </ul> |
| address_a | あり    | メモリのポート A へのアドレス入力。すべての動作モードに address_a ポートが必要です。                                                                                                                                         |

| 信号        | 必要性   | 説明                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            |
|-----------|-------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| wren_a    | オプション | <p>address_a ポートの書き込みイネーブル入力。operation_mode パラメータを以下の値のいずれかに設定する場合、wren_a ポートが必要です。</p> <ul style="list-style-type: none"> <li>• SINGLE_PORT</li> <li>• DUAL_PORT</li> <li>• BIDIR_DUAL_PORT</li> </ul>                                                                                                                                                                                                                                                                                                                                                       |
| data_b    | オプション | メモリのポート B へのデータ入力。operation_mode パラメータを BIDIR_DUAL_PORT に設定する場合、data_b ポートが必要です。                                                                                                                                                                                                                                                                                                                                                                                                                                                                              |
| address_b | オプション | メモリのポート B へのアドレス入力。operation_mode パラメータを以下の値に設定する場合、address_b ポートが必要です。                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       |
| wren_b    | あり    | address_b ポートの書き込みイネーブル入力。operation_mode パラメータを BIDIR_DUAL_PORT に設定する場合、wren_b ポートが必要です。                                                                                                                                                                                                                                                                                                                                                                                                                                                                      |
| clock     | あり    | <p>以下のリストは、どのメモリ・クロックを clock ポートに接続する必要があるのか、また異なるクロック・モードでのポート同期について説明しています。</p> <ul style="list-style-type: none"> <li>• シングル・クロック—シングル・ソース・クロックを clock ポートに接続します。レジスタに格納されたすべてのポートは、同じソース・クロックで同期化されます。</li> <li>• 読み取り/書き込み—書き込みクロックを clock ポートに接続します。data_a ポート、address_a ポート、wren_a ポート、および byteena_a ポートなどの書き込み動作に関連するすべてのレジスタに格納されたポートは、書き込みクロックで同期化されます。</li> <li>• 入力/出力—入力クロックを clock ポートに接続します。レジスタに格納されたすべての入力ポートは、入力クロックで同期化されます。</li> <li>• 独立クロック—ポート A クロックを clock ポートに接続します。レジスタに格納されたポート A のすべての入力および出力ポートは、ポート A クロックで同期化されます。</li> </ul> |

| 信号                          | 必要性   | 説明                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        |
|-----------------------------|-------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| inclock                     | あり    | <p>以下のリストは、どのメモリ・クロックを <code>inclock</code> ポートに接続する必要があるのか、また異なるクロック・モードでのポート同期について説明しています。</p> <ul style="list-style-type: none"> <li>シングル・クロック—シングル・ソース・クロックを <code>inclock</code> ポートと <code>outclock</code> ポートに接続します。レジスタに格納されたすべてのポートは、同じソース・クロックで同期化されます。</li> <li>読み取り/書き込み—書き込みクロックを <code>inclock</code> ポートに接続します。<code>data</code> ポート、<code>wraddress</code> ポート、<code>wren</code> ポート、および <code>byteena</code> ポートなどの書き込み動作に関連するレジスタに格納されたすべてのポートは、書き込みクロックで同期化されます。</li> <li>入力/出力—入力クロックを <code>inclock</code> ポートに接続します。レジスタに格納されたすべての入力ポートは、入力クロックで同期化されます。</li> </ul> |
| outclock                    | あり    | <p>以下のリストは、どのメモリ・クロックを <code>outclock</code> ポートに接続する必要があるのか、また異なるクロック・モードでのポート同期について説明しています。</p> <ul style="list-style-type: none"> <li>シングル・クロック—シングル・ソース・クロックを <code>inclock</code> ポートと <code>outclock</code> ポートに接続します。レジスタに格納されたすべてのポートは、同じソース・クロックで同期化されます。</li> <li>読み取り/書き込み—読み取りクロックを <code>outclock</code> ポートに接続します。<code>rdaddress</code> ポート、<code>rdren</code> ポート、および <code>q</code> ポートなどの読み取り動作に関連するレジスタに格納されたすべてのポートは、読み取りクロックで同期化されます。</li> <li>入力/出力—出力クロックを <code>outclock</code> ポートに接続します。レジスタに格納された <code>q</code> ポートは、出力クロックで同期化されます。</li> </ul>               |
| <code>rden_a</code>         | オプション | <code>address_a</code> ポートの読み取りイネーブル入力。 <code>rden_a</code> ポートは、選択したメモリ・モードとメモリ・ブロックに応じてサポートされます。                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        |
| <code>rden_b</code>         | オプション | <code>address_b</code> ポートの読み取りイネーブル入力。 <code>rden_b</code> ポートは、選択したメモリ・モードとメモリ・ブロックに応じてサポートされます。                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        |
| <code>byteena_a</code>      |       | <p><code>data_a</code> ポートをマスクするためのバイト・イネーブル入力。<code>data_a</code> ポートをマスクすることにより、データの特定のバイト、二ブル、またはビットのみが書き込まれます。<code>byteena_a</code> ポートは以下の条件ではサポートされません。</p> <ul style="list-style-type: none"> <li><code>implement_in_les</code> パラメータが <code>ON</code> に設定される。</li> <li><code>operation_mode</code> パラメータが <code>ROM</code> に設定される。</li> </ul>                                                                                                                                                                                                                                    |
| <code>addressstall_a</code> | オプション | <code>addressstall_a</code> ポートが <code>High</code> である間、 <code>address_a</code> ポートの以前のアドレスを保持するためのアドレス・クロック・イネーブル入力。                                                                                                                                                                                                                                                                                                                                                                                                                                                                     |

| 信号             | 必要性   | 説明                                                                            |
|----------------|-------|-------------------------------------------------------------------------------|
| addressstall_b | オプション | addressstall_b ポートが High である間、address_b ポートの以前のアドレスを保持するためのアドレス・クロック・イネーブル入力。 |

表 5-4: RAM: 2-PORT IP コア出力信号（トゥルー・デュアル・ポート RAM）

| 信号  | 必要性 | 説明                                                                                                                                                                                                                                                                                          |
|-----|-----|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| q_a | あり  | <p>メモリのポート A からのデータ出力。<code>operation_mode</code> パラメータを以下の値のいずれかに設定する場合、<code>q_a</code> ポートが必要です。</p> <ul style="list-style-type: none"> <li>• SINGLE_PORT</li> <li>• BIDIR_DUAL_PORT</li> <li>• ROM</li> </ul> <p><code>q_a</code> ポートの幅は <code>data_a</code> ポートの幅と等しいものである必要があります。</p> |
| q_b | あり  | <p>メモリのポート B からのデータ出力。<code>operation_mode</code> パラメータを以下の値に設定する場合、<code>q_b</code> ポートが必要です。</p> <ul style="list-style-type: none"> <li>• DUAL_PORT</li> <li>• BIDIR_DUAL_PORT</li> </ul> <p><code>q_b</code> ポートの幅は <code>data_b</code> ポートの幅と等しいものである必要があります。</p>                       |

## MAX 10 デバイスの RAM: 2-PORT IP コアのパラメータ

表 5-5: MAX 10 デバイスの RAM: 2-PORT IP コアのパラメータ

この表は、 MAX 10 デバイスに適用可能な IP コアのパラメータをリストしています。

| オプション                                        | 正当な値                                                                                                                           | 説明                                  |
|----------------------------------------------|--------------------------------------------------------------------------------------------------------------------------------|-------------------------------------|
| <b>パラメータ設定 : General</b>                     |                                                                                                                                |                                     |
| How will you be using the dual port RAM?     | <ul style="list-style-type: none"> <li>• With one read port and one write port</li> <li>• With two read/write ports</li> </ul> | デュアル・ポート RAM を使用する方法を指定します。         |
| How do you want to specify the memory size?  | <ul style="list-style-type: none"> <li>• As a number of words</li> <li>• As a number of bits</li> </ul>                        | メモリ容量をワードで指定するか、またはビットで指定するかを決定します。 |
| <b>パラメータ設定 : Widths/ Blk Type</b>            |                                                                                                                                |                                     |
| How many <X>-bit words of memory?            | —                                                                                                                              | <X>ビット・ワードの数を指定します。                 |
| Use different data widths on different ports | On / Off                                                                                                                       | 異なるポートで異なるデータ幅を使用するかどうかを指定します。      |

| オプション                                 | 正当な値                                                                                                                                                                                                                         | 説明                                                                                                                                                                                                                                                                                             |
|---------------------------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Read/Write Ports                      | <p><b>With one read port and one write port</b> を選択すると、以下のオプションが使用可能です。</p> <ul style="list-style-type: none"> <li>• How wide should the 'data_a' input bus be?</li> <li>• How wide should the 'q' output bus be?</li> </ul> | <p>1、2、3、4、5、6、7、8、9、16、18、32、36、64、72、108、128、144、256、および288</p> <p>入力ポートと出力ポートの幅を指定します。</p> <p><b>How wide should the 'q' output bus be? および How wide should the 'q_b' output bus be?</b> オプションは、<b>Use different data widths on different ports</b> パラメータをオンにする場合にのみ使用可能です。</p>             |
|                                       | <p><b>With two read/write ports</b> を選択すると、以下のオプションが使用可能です。</p> <ul style="list-style-type: none"> <li>• How wide should the 'q_a' output bus be?</li> <li>• How wide should the 'q_b' output bus be?</li> </ul>             |                                                                                                                                                                                                                                                                                                |
| What should the memory block type be? | <ul style="list-style-type: none"> <li>• Auto</li> <li>• M9K</li> <li>• LCs</li> </ul>                                                                                                                                       | <p>メモリ・ブロックのタイプを指定します。選択可能なメモリ・ブロックのタイプは、ターゲットのデバイスによって異なります。</p> <p><b>LCs</b> の値は以下の条件でのみ使用可能です。</p> <ul style="list-style-type: none"> <li>• <b>With one read port and one write port</b> オプションをオンにする</li> <li>• <b>Use different data widths on different ports</b> オプションをオフにする</li> </ul> |
| オプション                                 | How should the memory be implemented?                                                                                                                                                                                        | <ul style="list-style-type: none"> <li>• Use default logic cell style</li> <li>• Use Stratix M512 emulation logic cell style</li> </ul> <p>ロジック・セル実装のオプションを指定します。LCメモリ・タイプを選択する場合にのみ、このオプションがイネーブルされます。</p>                                                                                    |

| オプション                          | 正当な値                                                                                                                                         | 説明                  |
|--------------------------------|----------------------------------------------------------------------------------------------------------------------------------------------|---------------------|
| Set the maximum block depth to | <ul style="list-style-type: none"><li>Auto</li><li>128</li><li>256</li><li>512</li><li>1024</li><li>2048</li><li>4096</li><li>8192</li></ul> | 最大ブロック深度をワードで指定します。 |

パラメータ設定 : Clks/Rd, Byte En

| オプション                                       | 正当な値                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         | 説明                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           |
|---------------------------------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| What clocking method would you like to use? | <p><b>With one read port and one write port</b> を選択すると、以下の値が使用可能です。</p> <ul style="list-style-type: none"><li>• Single clock</li><li>• Dual clock: use separate ‘input’ and ‘output’ clocks</li><li>• Dual clock: use separate ‘read’ and ‘write’ clocks</li></ul> <p><b>With two read/write ports</b> を選択すると、以下のオプションが使用可能です。</p> <ul style="list-style-type: none"><li>• Single clock</li><li>• Dual clock: use separate ‘input’ and ‘output’ clocks</li><li>• Dual clock: use separate clocks for A and B ports</li></ul> | <p>使用するクロッキング方法を指定します。</p> <ul style="list-style-type: none"><li>• Single clock—シングル・クロックとクロック・イネーブルがメモリ・ブロックのすべてのレジスタを制御します。</li><li>• Dual Clock: use separate ‘input’ and ‘output’ clocks—入力クロックと出力クロックが、データ、アドレス、バイト・イネーブル、読み取りイネーブル、および書き込みイネーブルを含むメモリ・ブロックへのデータの出入力、およびメモリ・ブロックからのデータの出入力に関連するすべてのレジスタを制御します。</li><li>• Dual clock: use separate ‘read’ and ‘write’ clocks—読み取りクロックがデータ出力、読み取りアドレス、および読み取りイネーブル・レジスタを制御する一方で、書き込みクロックがデータ入力、書き込みアドレス、および書き込みイネーブル・レジスタを制御します。</li><li>• Dual clock: use separate clocks for A and B ports—クロック A がポート A 側のすべてのレジスタを制御し、クロック B がポート B 側のすべてのレジスタを制御します。また、各ポートはそれぞれ、ポート A およびポート B レジスタの独立クロック・イネーブルをサポートします。</li></ul> |

| オプション                                             | 正当な値                          | 説明                                                                                                                                                  |
|---------------------------------------------------|-------------------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------|
| Create a 'rden' read enable signal                | On / Off                      | With one read port and one write port オプションを選択する場合に使用可能です。                                                                                          |
| Create a 'rden_a' and 'rden_b' read enable signal | On / Off                      | <ul style="list-style-type: none"> <li>With two read/write ports オプションを選択する場合に使用可能です。</li> <li>ポート A とポート B の読み取りイネーブル信号を作成するかどうかを指定します。</li> </ul> |
| Byte Enable Ports                                 | Create byte enable for port A | ポート A とポート B のバイト・イネーブルを作成するかどうかを指定します。データの特定のバイト、二ブル、またはビットのみが書き込まれるよう入力データをマスクする場合は、これらのオプションをオンにします。                                             |
| パラメータ設定 : Regs/Clkens/Aclrs                       |                               |                                                                                                                                                     |

| オプション                                                 | 正当な値                                                                                                                                                                                                                                                                                                                                                                                                                                                    | 説明                                                                         |
|-------------------------------------------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|----------------------------------------------------------------------------|
| Which ports should be registered?                     | <p><b>With one read port and one write port</b> を選択する場合、以下のオプションが使用可能です。</p> <ul style="list-style-type: none"> <li>書き込み入力ポート 'data_a'、'wraddress_a'、および 'wren_a'</li> <li>読み取り入力ポート 'rdaddress' と 'rden'</li> <li>読み取り出力ポート 'q_a' と 'q_b'</li> </ul> <p><b>With two read/write ports</b> を選択する場合、以下のオプションが使用可能です。</p> <ul style="list-style-type: none"> <li>書き込み入力ポート 'data_a'、'wraddress_a'、および 'wren_a'</li> <li>読み取り出力ポート 'q_a' と 'q_b'</li> </ul> | 読み取りまたは書き込み入力ポート、読み取りまたは書き込み出力ポートをレジスタに格納するかどうかを指定します。                     |
| More Options                                          | <p><b>With one read port and one write port</b> を選択する場合、以下のオプションが使用可能です。</p> <ul style="list-style-type: none"> <li>'q_b' ポート</li> </ul> <p><b>With two read/write ports</b> を選択する場合、以下のオプションが使用可能です。</p> <ul style="list-style-type: none"> <li>'q_a' ポート</li> <li>'q_b' ポート</li> </ul>                                                                                                                                                                | デフォルトでは、読み取り入力ポートと書き込み入力ポートはオンになっていません。Q 出力ポートをレジスタに格納するかどうかのみ指定する必要があります。 |
| Create one clock enable signal for each clock signal. | On / Off                                                                                                                                                                                                                                                                                                                                                                                                                                                | 各クロック信号に 1 つのクロック・イネーブル信号を作成するためのオプションをオンにするかどうかを指定します。                    |

| オプション                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             | 正当な値     | 説明                                                                                                                                                                                                                                                                                                        |
|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|----------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| <p>More Options</p> <p><b>With one read port and one write port</b> を選択する場合、以下のオプションが使用可能です。</p> <ul style="list-style-type: none"> <li>• Clock enable options <ul style="list-style-type: none"> <li>• Use clock enable for write input registers</li> </ul> </li> <li>• Address options <ul style="list-style-type: none"> <li>• Create an 'wr_addressstall' input port.</li> <li>• Create an 'rd_addressstall' input port.</li> </ul> </li> </ul> <p><b>With two read /write ports</b> を選択する場合、以下のオプションが使用可能です。</p> <ul style="list-style-type: none"> <li>• Clock enable options <ul style="list-style-type: none"> <li>• Use clock enable for port A input registers</li> <li>• Use clock enable for port A output registers</li> </ul> </li> <li>• Address options <ul style="list-style-type: none"> <li>• Create an 'addressstall_a' input port.</li> <li>• Create an 'addressstall_b' input port.</li> </ul> </li> </ul> | On / Off | <ul style="list-style-type: none"> <li>• Clock enable options—デフォルトでは、ポート B の入力および出力レジスタのクロック・イネーブルはオンです。ポート A の入力および出力レジスタのクロック・イネーブルを使用するかどうかのみ指定する必要があります。</li> <li>• Address options—アドレス・レジスタのクロック・イネーブルを作成するかどうかを指定します。これらのポートは、アドレス・レジスタの追加のアクティブ Low クロック・イネーブル入力として機能するよう作成することができます。</li> </ul> |
| Create an 'aclr' asynchronous clear for the registered ports.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     | On / Off | レジスタに格納されたポートの非同期クリア・ポートを作成するかどうかを指定します。                                                                                                                                                                                                                                                                  |

| オプション        | 正当な値                                                                                                                                                                                                                                                                                                           | 説明                                                                      |
|--------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------------------------------------------------------------------------|
| More Options | <p><b>With one read port and one write port</b> を選択する場合、以下のオプションが使用可能です。</p> <ul style="list-style-type: none"> <li>‘rdaddress’ポート</li> <li>‘q_b’ポート</li> </ul> <p><b>With two read /write ports</b> を選択する場合、以下のオプションが使用可能です。</p> <ul style="list-style-type: none"> <li>‘q_a’ポート</li> <li>‘q_b’ポート</li> </ul> | On / Off<br><br>raddress、q_a、および q_b ポートが aclr ポートによってクリアされるかどうかを指定します。 |

## パラメータ設定 : Output 1

|                                                         |                                                                                                                                                                                                                                                                                                                                                                                                                                                                               |                                                                                                                                     |                                                                                                                                                                                                                                                                                                                                                                                                                                                           |
|---------------------------------------------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------------------------------------------------------------------------------------------------------------------------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Mixed Port Read-During-Write for Single Input Clock RAM | <p><b>With one read port and one write port</b> を選択する場合、次のオプションが使用可能です。</p> <ul style="list-style-type: none"> <li>How should the q output behave when reading a memory location that is being written from the other port?</li> </ul> <p><b>With two read /write ports</b> を選択する場合、次のオプションが使用可能です。</p> <ul style="list-style-type: none"> <li>How should the q_a and q_b outputs behave when reading a memory location that is being written from the other port?</li> </ul> | <ul style="list-style-type: none"> <li>Old memory contents appear</li> <li>I do not care (the outputs will be undefined)</li> </ul> | <p>Read-During-Write が起こるときの出力動作を指定します。</p> <ul style="list-style-type: none"> <li><b>Old memory contents appear</b>—書き込み動作を進める前に、RAM 出力はそのアドレスにある古いデータを反映します。</li> <li><b>I do not care</b>—選択する以下のメモリ・ブロック・タイプに応じてオンになると、このオプションは異なる機能を果たします。           <ul style="list-style-type: none"> <li>メモリ・ブロック・タイプを <b>Auto</b>、または <b>M9K</b> に設定する場合、RAM はタイミング・パスを解析することなく Read-During-Write 動作の ‘don't care’ または “unknown” 値を出力します。</li> </ul> </li> </ul> |
|---------------------------------------------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------------------------------------------------------------------------------------------------------------------------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|

| オプション                                                                                                                                                             | 正当な値                                                                                  | 説明                                                                                                                                                                                                                         |
|-------------------------------------------------------------------------------------------------------------------------------------------------------------------|---------------------------------------------------------------------------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Do not analyze the timing between write and read operation. Metastability issues are prevented by never writing and reading at the same address at the same time. | On / Off                                                                              | このオプションは <b>I do not care (The outputs will be undefined)</b> オプションをオンにする場合、自動的にオンになります。このオプションは、タイミング・パスを解析することなく Read-During-Write 動作の 'don't care' または 'unknown' 値を出力する RAM をイネーブルします。                                  |
| <b>パラメータ設定 : Output 2 (このタブは two read/write ports を選択する場合にのみ使用可能です)</b>                                                                                           |                                                                                       |                                                                                                                                                                                                                            |
| Port A Read-During-Write Option                                                                                                                                   | What should the 'q_a' output be when reading from a memory location being written to? | Read-During-Write が起こるときの出力動作を指定します。 <ul style="list-style-type: none"><li>• <b>New Data</b>—データが書き込まれたのと同じクロック・サイクルの立ち上がりエッジで新しいデータが使用可能です。</li><li>• <b>Old Data</b>—RAM 出力は書き込み動作を進める前に、そのアドレスにある古いデータを反映します。</li></ul> |
| Port B Read-During-Write Option                                                                                                                                   | What should the 'q_b' output be when reading from a memory location being written to? |                                                                                                                                                                                                                            |
| Get x's for write masked bytes instead of old data when byte enable is used                                                                                       | On / Off                                                                              | このオプションは、New Data 値を選択すると自動的にオンになります。このオプションはマスクされたバイトで 'X' を取得します。                                                                                                                                                        |

**パラメータ設定 : Mem Init**

| オプション                                                              | 正当な値                                                                                                                      | 説明                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          |
|--------------------------------------------------------------------|---------------------------------------------------------------------------------------------------------------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Do you want to specify the initial content of the memory?          | <ul style="list-style-type: none"><li>No, leave it blank</li><li>Yes, use this file for the memory content data</li></ul> | <p>メモリの初期内容を指定します。</p> <ul style="list-style-type: none"><li>メモリをゼロに初期化するには、<b>No, leave it blank</b> を選択します。</li><li>メモリ初期化ファイル (.mif) または 16 進 (Intel-Format) ファイル (.hex) を使用するには、<b>Yes, use this file for the memory content data</b> を選択します。</li></ul> <p>注: デバイスのコンフィギュレーション手法は Internal Configuration です。メモリの初期化を使用するためには、<b>Enable ERAM Preload</b> オプションをオンにする必要があります。<b>Enable ERAM Preload</b> オプションは、<b>More Analysis &amp; Synthesis Settings</b> ダイアログ・ボックスでオンにすることができます。</p> |
| The initial content file should conform to which port's dimension? | <ul style="list-style-type: none"><li>PORT_A</li><li>PORT_B</li></ul>                                                     | 初期コンテンツ・ファイルを準拠させる必要があるポートの寸法を指定します。                                                                                                                                                                                                                                                                                                                                                                                                                                                        |

# ROM: 1-PORT IP コア・リファレンス

6

2014.09.22

UG-M10MEMORY

✉ 署名

💬 フィードバック

ROM: 1-PORT IP コアは、シングル・ポート ROM メモリ・モードを実装します。

図 6-1: Single Clock オプションがイネーブルされた ROM: 1-PORT IP コア信号



© 2014 Altera Corporation. All rights reserved. ALTERA, ARRIA, CYCLONE, ENPIRION, MAX, MEGACORE, NIOS, QUARTUS and STRATIX words and logos are trademarks of Altera Corporation and registered in the U.S. Patent and Trademark Office and in other countries. All other words and logos identified as trademarks or service marks are the property of their respective holders as described at [www.altera.com/common/legal.html](http://www.altera.com/common/legal.html). Altera warrants performance of its semiconductor products to current specifications in accordance with Altera's standard warranty, but reserves the right to make changes to any products and services at any time without notice. Altera assumes no responsibility or liability arising out of the application or use of any information, product, or service described herein except as expressly agreed to in writing by Altera. Altera customers are advised to obtain the latest version of device specifications before relying on any published information and before placing orders for products or services.

ISO  
9001:2008

図 6-2: Dual Clock: Use Separate 'Input' and 'Output' Clocks オプションがイネーブルされた ROM: 1-PORT IP コア信号



## MAX 10 デバイスの ROM: 1-PORT IP コア信号

表 6-1: ROM: 1-PORT IP コア入力信号

| 信号             | 必要性   | 説明                                                                                                                                                                            |
|----------------|-------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| address        | あり    | メモリへのアドレス入力。                                                                                                                                                                  |
| addressstall_a | オプション | addressstall_a ポートが High である間、address_a ポートの以前のアドレスを保持するためのアドレス・クロック・イネーブル入力。                                                                                                 |
| rden           | オプション | rdaddress ポートの読み取りイネーブル入力。rden ポートは、use_eab パラメータが OFF に設定されるときにサポートされます。ram_block_type パラメータが MLAB に設定されるとき、rden ポートはサポートされません。読み取りイネーブル機能を別のメモリ・ブロックで使用する場合、IP をインスタンス化します。 |

| 信号        | 必要性   | 説明                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         |
|-----------|-------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| clock     | あり    | <p>以下のリストは、どのメモリ・クロックを <code>clock</code> ポートに接続する必要があるのか、また異なるクロック・モードでのポート同期について説明しています。</p> <ul style="list-style-type: none"> <li>シングル・クロック—シングル・ソース・クロックを <code>clock</code> ポートに接続します。レジスタに格納されたすべてのポートは、同じソース・クロックで同期化されます。</li> <li>読み取り/書き込み—書き込みクロックを <code>clock</code> ポートに接続します。<code>data_a</code> ポート、<code>address_a</code> ポート、<code>wren_a</code> ポート、および <code>byteena_a</code> ポートなどの書き込み動作に関連するすべてのレジスタに格納されたポートは、書き込みクロックで同期化されます。</li> <li>入力/出力—入力クロックを <code>clock</code> ポートに接続します。レジスタに格納されたすべての入力ポートは、入力クロックで同期化されます。</li> <li>独立クロック—ポート A クロックを <code>clock</code> ポートに接続します。ポート A のレジスタに格納されたすべての入力および出力ポートは、ポート A クロックで同期化されます。</li> </ul> |
| clken     | オプション | <code>clock</code> ポートのクロック・イネーブル入力。                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       |
| inclock   | あり    | <p>以下のリストは、どのメモリ・クロックを <code>inclock</code> ポートに接続する必要があるのか、また異なるクロック・モードでのポート同期について説明しています。</p> <ul style="list-style-type: none"> <li>シングル・クロック—シングル・ソース・クロックを <code>inclock</code> ポートと <code>outclock</code> ポートに接続します。レジスタに格納されたすべてのポートは、同じソース・クロックで同期化されます。</li> <li>読み取り/書き込み—書き込みクロックを <code>inclock</code> ポートに接続します。<code>data</code> ポート、<code>wraddress</code> ポート、<code>wren</code> ポート、および <code>byteena</code> ポートなどの書き込み動作に関連するレジスタに格納されたすべてのポートは、書き込みクロックで同期化されます。</li> <li>入力/出力—入力クロックを <code>inclock</code> ポートに接続します。レジスタに格納されたすべての入力ポートは、入力クロックで同期化されます。</li> </ul>                                                                                  |
| inclocken | オプション | <code>inclock</code> ポートのクロック・イネーブル入力。                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     |

| 信号         | 必要性   | 説明                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           |
|------------|-------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| outclock   | あり    | <p>以下のリストは、どのメモリ・クロックを <code>outclock</code> ポートに接続する必要があるのか、また異なるクロック・モードでのポート同期について説明しています。</p> <ul style="list-style-type: none"> <li>シングル・クロック—シングル・ソース・クロックを <code>inclkock</code> ポートと <code>outclock</code> ポートに接続します。レジスタに格納されたすべてのポートは、同じソース・クロックで同期化されます。</li> <li>読み取り/書き込み—読み取りクロックを <code>outclock</code> ポートに接続します。<code>rdaddress</code> ポート、<code>rdren</code> ポート、および <code>q</code> ポートなどの読み取り動作に関連するレジスタに格納されたすべてのポートは、読み取りクロックで同期化されます。</li> <li>入力/出力—出力クロックを <code>outclock</code> ポートに接続します。レジスタに格納された <code>q</code> ポートは、出力クロックで同期化されます。</li> </ul> |
| outclocken | オプション | <code>outclock</code> ポートのクロック・イネーブル入力。                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      |

表 6-2: ROM: 1-PORT IP コア出力信号

| 信号             | 必要性 | 説明                                                                                |
|----------------|-----|-----------------------------------------------------------------------------------|
| <code>q</code> | あり  | メモリからのデータ出力。 <code>q</code> ポートが必要であり、幅は <code>data</code> ポートの幅と等しいものである必要があります。 |

## MAX 10 デバイスの ROM: 1-PORT IP コアのパラメータ

表 6-3: MAX 10 デバイスの ROM: 1-PORT IP コアのパラメータ

この表は、 MAX 10 デバイスに適用可能な IP コアのパラメータをリストしています。

| オプション                                                 | 正当値                                                                                                                       | 説明                                   |
|-------------------------------------------------------|---------------------------------------------------------------------------------------------------------------------------|--------------------------------------|
| <b>パラメータ設定 : General</b>                              |                                                                                                                           |                                      |
| How wide should the ' <code>q</code> ' output bus be? | 1、2、3、4、5、6、7、8、9、10、11、12、13、14、15、16、17、18、19、20、21、22、23、24、25、26、27、28、29、30、31、32、36、40、48、64、72、108、128、144、および 256 | ビット内の「 <code>q</code> 」出力バスの幅を指定します。 |
| How many <X>-bit words of memory?                     | 32、64、128、256、512、1024、2048、4096、8192、16384、32768、および 65536                                                               | <X>ビット・ワードの数を指定します。                  |

| オプション                                       | 正当値                                                                                                                                                                           | 説明                                                                                                                                                                                                                                                                                                                                 |
|---------------------------------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| What should the memory block type be?       | <ul style="list-style-type: none"> <li>Auto</li> <li>M9K</li> </ul>                                                                                                           | メモリ・ブロックのタイプを指定します。選択できるメモリ・ブロックのタイプは、ターゲットのデバイスによって異なります。                                                                                                                                                                                                                                                                         |
| Set the maximum block depth to              | <ul style="list-style-type: none"> <li>Auto</li> <li>32</li> <li>64</li> <li>128</li> <li>256</li> <li>512</li> <li>1024</li> <li>2048</li> <li>4096</li> <li>8192</li> </ul> | 最大ブロック深度をワードで指定します。                                                                                                                                                                                                                                                                                                                |
| What clocking method would you like to use? | <ul style="list-style-type: none"> <li>Single clock</li> <li>Dual clock: use separate 'input' and 'output' clocks</li> </ul>                                                  | <p>使用するクロッキング方法を指定します。</p> <ul style="list-style-type: none"> <li>Single clock—シングル・クロックとクロック・イネーブルは、メモリ・ブロックのすべてのレジスタを制御します。</li> <li>Dual clock: use separate 'input' and 'output' clocks—入力および出力クロックは、データ、アドレス、バイト・イネーブル、読み取りイネーブル、および書き込みイネーブルを含むメモリ・ブロックからのデータ入力とデータ出力およびメモリ・ブロックへのデータ入力とデータ出力に関連するすべてのレジスタを制御します。</li> </ul> |

## パラメータ設定 : Regs/Clkens/Acls

|                                   |                                                                                                 |          |                                                        |
|-----------------------------------|-------------------------------------------------------------------------------------------------|----------|--------------------------------------------------------|
| Which ports should be registered? | <ul style="list-style-type: none"> <li>'address' input port</li> <li>'q' output port</li> </ul> | On / Off | 読み取りまたは書き込み入力ポート、読み取りまたは書き込み出力ポートをレジスタに格納するかどうかを指定します。 |
|-----------------------------------|-------------------------------------------------------------------------------------------------|----------|--------------------------------------------------------|

| オプション                                                         | 正当値                                                                                                                                                                                                                                                                                                                                                                         | 説明                                                                                                                                                                                                                                                                                                                        |
|---------------------------------------------------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Create one clock enable signal for each clock signal.         | On / Off                                                                                                                                                                                                                                                                                                                                                                    | 各クロック信号に 1 つのクロック・イネーブル信号を作成するためのオプションをオンにするかどうかを指定します。                                                                                                                                                                                                                                                                   |
| More Options                                                  | <ul style="list-style-type: none"> <li>• Clock enable options           <ul style="list-style-type: none"> <li>• Use clock enable for port A input registers</li> <li>• Use clock enable for port A output registers</li> </ul> </li> <li>• Address options           <ul style="list-style-type: none"> <li>• Create an 'addressstall_a' input port</li> </ul> </li> </ul> | <p>On / Off</p> <ul style="list-style-type: none"> <li>• Clock enable options—デフォルトでは、ポート B の入力および出力レジスタのクロック・イネーブルはオンです。ポート A の入力および出力レジスタのクロック・イネーブルを使用するかどうかのみ指定する必要があります。</li> <li>• Address options—アドレス・レジスタのクロック・イネーブルを作成するかどうかを指定します。これらのポートは、アドレス・レジスタの追加のアクティブ Low クロック・イネーブル入力として機能するよう作成することができます。</li> </ul> |
| Create an 'aclr' asynchronous clear for the registered ports. | On / Off                                                                                                                                                                                                                                                                                                                                                                    | レジスタに格納されたポートの非同期クリア・ポートを作成するかどうかを指定します。                                                                                                                                                                                                                                                                                  |
| More Options                                                  | <ul style="list-style-type: none"> <li>• 'address' port</li> <li>• 'q' port</li> </ul>                                                                                                                                                                                                                                                                                      | address および q ポートが aclr ポートによってクリアされるかどうかを指定します。                                                                                                                                                                                                                                                                          |
| Create a 'rden' read enable signal                            | On / Off                                                                                                                                                                                                                                                                                                                                                                    | rden 読み取りイネーブル信号を作成するかどうかを指定します。                                                                                                                                                                                                                                                                                          |

### パラメータ設定 : Mem Init

| オプション                                                                                                 | 正当値                                             | 説明                                                                                                                                                                                                                                                                                                                        |
|-------------------------------------------------------------------------------------------------------|-------------------------------------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Do you want to specify the initial content of the memory?                                             | Yes, use this file for the memory content data. | メモリの初期内容を指定します。ROM モードでは、メモリ初期化ファイル (.mif) または 16 進 (Intel-Format) ファイル (.hex) を指定する必要があります。<br><br>注: デバイスのコンフィギュレーション手法は Internal Configuration です。メモリの初期化を使用するためには、Enable ERAM Preload オプションをオンにする必要があります。<br><b>Enable ERAM Preload</b> オプションは <b>More Analysis &amp; Synthesis Settings</b> ダイアログ・ボックスでオンにすることができます。 |
| Allow In-System Memory Content Editor to capture and update content independently of the system clock | On / Off                                        | In-System Memory Content Editor が独立してシステム・クロックのコンテンツをキャプチャし、更新することを可能にするかどうかを指定します。                                                                                                                                                                                                                                       |
| The 'Instance ID' of this RAM is                                                                      | —                                               | RAM ID を指定します。                                                                                                                                                                                                                                                                                                            |

# ROM: 2-PORT IP コア・リファレンス

7

2014.09.22

UG-M10MEMORY

✉ 署名

💬 フィードバック

この IP コアは、デュアル・ポート ROM メモリ・モードを実装します。デュアル・ポート ROM は、シングル・ポート ROM とほぼ同じ機能ポートを有します。この 2 つの相違点は、デュアル・ポート ROM は読み取り動作のための追加のアドレス・ポートを有することです。

図 7-1: Single Clock オプションがイネーブルされた ROM: 2-PORT IP コア信号



© 2014 Altera Corporation. All rights reserved. ALTERA, ARRIA, CYCLONE, ENPIRION, MAX, MEGACORE, NIOS, QUARTUS and STRATIX words and logos are trademarks of Altera Corporation and registered in the U.S. Patent and Trademark Office and in other countries. All other words and logos identified as trademarks or service marks are the property of their respective holders as described at [www.altera.com/common/legal.html](http://www.altera.com/common/legal.html). Altera warrants performance of its semiconductor products to current specifications in accordance with Altera's standard warranty, but reserves the right to make changes to any products and services at any time without notice. Altera assumes no responsibility or liability arising out of the application or use of any information, product, or service described herein except as expressly agreed to in writing by Altera. Altera customers are advised to obtain the latest version of device specifications before relying on any published information and before placing orders for products or services.

ISO  
9001:2008

図 7-2: Dual Clock: Use Separate 'Input' and 'Output' Clocks オプションがイネーブルされた ROM: 2-PORT IP コア信号



図 7-3: Dual Clock: Use Separate Clocks for A and B Ports オプションがイネーブルされた ROM: 2-PORT IP コア信号



# MAX 10 デバイスの ROM: 2-PORT IP コア信号

表 7-1: ROM: 2-PORT IP コア入力信号

| 信号             | 必要性   | 説明                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        |
|----------------|-------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| address_a      | あり    | メモリのポート A へのアドレス入力。すべての動作モードに address_a ポートが必要です。                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         |
| rden_a         | オプション | address_a ポートの読み取りイネーブル入力。rden_a ポートは、選択したメモリ・モードとメモリ・ブロックに応じてサポートされます。                                                                                                                                                                                                                                                                                                                                                                                                                                                                   |
| address_b      | オプション | メモリのポート B へのアドレス入力。 <code>operation_mode</code> パラメータを以下の値に設定する場合、address_b ポートが必要です。 <ul style="list-style-type: none"><li>DUAL_PORT</li><li>BIDIR_DUAL_PORT</li></ul>                                                                                                                                                                                                                                                                                                                                                                   |
| rden_b         | オプション | address_b ポートの読み取りイネーブル入力。rden_b ポートは、選択したメモリ・モードとメモリ・ブロックに応じてサポートされます。                                                                                                                                                                                                                                                                                                                                                                                                                                                                   |
| clock          | あり    | 以下のリストは、どのメモリ・クロックを clock ポートに接続する必要があるのか、また異なるクロック・モードでのポート同期について説明しています。 <ul style="list-style-type: none"><li>シングル・クロック—シングル・ソース・クロックを clock ポートに接続します。レジスタに格納されたすべてのポートは、同じソース・クロックで同期化されます。</li><li>読み取り/書き込み—書き込みクロックを clock ポートに接続します。data_a ポート、address_a ポート、wren_a ポート、および bytewra_a ポートなどの書き込み動作に関連するすべてのレジスタに格納されたポートは、書き込みクロックで同期化されます。</li><li>入力/出力—入力クロックを clock ポートに接続します。レジスタに格納されたすべての入力ポートは、入力クロックで同期化されます。</li><li>独立クロック—ポート A クロックを clock ポートに接続します。ポート A のレジスタに格納されたすべての入力および出力ポートは、ポート A クロックで同期化されます。</li></ul> |
| addressstall_a | オプション | addressstall_a ポートが High である間、address_a ポートの以前のアドレスを保持するためのアドレス・クロック・イネーブル入力。                                                                                                                                                                                                                                                                                                                                                                                                                                                             |
| addressstall_b | オプション | addressstall_b ポートが High である間、address_b ポートの以前のアドレスを保持するためのアドレス・クロック・イネーブル入力。                                                                                                                                                                                                                                                                                                                                                                                                                                                             |

| 信号         | 必要性   | 説明                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        |
|------------|-------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| inclock    | あり    | <p>以下のリストは、どのメモリ・クロックを <code>inclock</code> ポートに接続する必要があるのか、また異なるクロック・モードでのポート同期について説明しています。</p> <ul style="list-style-type: none"> <li>シングル・クロック—シングル・ソース・クロックを <code>inclock</code> ポートと <code>outclock</code> ポートに接続します。レジスタに格納されたすべてのポートは、同じソース・クロックで同期化されます。</li> <li>読み取り/書き込み—書き込みクロックを <code>inclock</code> ポートに接続します。<code>data</code> ポート、<code>wraddress</code> ポート、<code>wren</code> ポート、および <code>byteena</code> ポートなどの書き込み動作に関連するレジスタに格納されたすべてのポートは、書き込みクロックで同期化されます。</li> <li>入力/出力—入力クロックを <code>inclock</code> ポートに接続します。レジスタに格納されたすべての入力ポートは、入力クロックで同期化されます。</li> </ul> |
| outclock   | あり    | <p>以下のリストは、どのメモリ・クロックを <code>outclock</code> ポートに接続する必要があるのか、また異なるクロック・モードでのポート同期について説明しています。</p> <ul style="list-style-type: none"> <li>シングル・クロック—シングル・ソース・クロックを <code>inclock</code> ポートと <code>outclock</code> ポートに接続します。レジスタに格納されたすべてのポートは、同じソース・クロックで同期化されます。</li> <li>読み取り/書き込み—読み取りクロックを <code>outclock</code> ポートに接続します。<code>rdaddress</code> ポート、<code>rdren</code> ポート、および <code>q</code> ポートなどの読み取り動作に関連するレジスタに格納されたすべてのポートは、読み取りクロックで同期化されます。</li> <li>入力/出力—出力クロックを <code>outclock</code> ポートに接続します。レジスタに格納された <code>q</code> ポートは、出力クロックで同期化されます。</li> </ul>               |
| inclocken  | オプション | <code>inclock</code> ポートのクロック・イネーブル入力。                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    |
| outclocken | オプション | <code>outclock</code> ポートのクロック・イネーブル入力。                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   |
| aclr       | オプション | レジスタされた入力および出力ポートを非同期クリアします。非同期クリアは <code>indata_aclr</code> や <code>wraddress_aclr</code> などの対応する非同期クリア・パラメータを介して制御可能な、レジスタに格納されたポートに影響します。                                                                                                                                                                                                                                                                                                                                                                                                                                              |

表 7-2: ROM: 2-PORT IP コア出力信号

| 信号  | 必要性 | 説明                                                                                                                                                                                                                                                                               |
|-----|-----|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| q_a | あり  | メモリのポート A からのデータ出力。 <code>operation_mode</code> パラメータを以下の値のいずれかに設定する場合、 <code>q_a</code> ポートが必要です。 <ul style="list-style-type: none"> <li>• SINGLE_PORT</li> <li>• BIDIR_DUAL_PORT</li> <li>• ROM</li> </ul> <code>q_a</code> ポートの幅は、 <code>data_a</code> ポートの幅と等しいものである必要があります。 |
| q_b | あり  | メモリのポート B からのデータ出力。 <code>operation_mode</code> パラメータを以下の値に設定する場合、 <code>q_b</code> ポートが必要です。 <ul style="list-style-type: none"> <li>• DUAL_PORT</li> <li>• BIDIR_DUAL_PORT</li> </ul> <code>q_b</code> ポートの幅は <code>data_b</code> ポートの幅と等しいものである必要があります。                        |

## MAX 10 デバイスの ROM: 2-PORT IP コアのパラメータ

表 7-3: MAX 10 デバイスの ROM: 2-PORT IP コアのパラメータ

この表は、 MAX 10 デバイスに適用可能な IP コアのパラメータをリストしています。

| オプション                                        | 正当値                                                                                                     | 説明                                                                                                                                                          |
|----------------------------------------------|---------------------------------------------------------------------------------------------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------|
| <b>パラメータ設定 : Widths/Blk Type</b>             |                                                                                                         |                                                                                                                                                             |
| How do you want to specify the memory size?  | <ul style="list-style-type: none"> <li>• As a number of words</li> <li>• As a number of bits</li> </ul> | メモリ容量をワードで指定するか、またはビットで指定するかを決定します。                                                                                                                         |
| How many <X>-bit words of memory?            | —                                                                                                       | <X>ビット・ワードの数を指定します。                                                                                                                                         |
| Use different data widths on different ports | On / Off                                                                                                | 異なるポートで異なるデータ幅を使用するかどうかを指定します。                                                                                                                              |
| Read Ports                                   | How wide should the 'q_a' output bus be?<br>How wide should the 'q_b' output bus be?                    | 入力ポートと出力ポートの幅を指定します。<br><b>How wide should the 'q_b' output bus be?</b> オプションは、 <b>Use different data widths on different ports</b> パラメータをオンにする場合にのみ使用可能です。 |
|                                              | 1、2、3、4、5、6、7、8、9、16、18、32、36、64、72、108、128、144、256、および 288                                             |                                                                                                                                                             |

| オプション                                 | 正当値                                  | 説明                                                         |
|---------------------------------------|--------------------------------------|------------------------------------------------------------|
| What should the memory block type be? | Auto、M9K                             | メモリ・ブロックのタイプを指定します。選択できるメモリ・ブロックのタイプは、ターゲットのデバイスによって異なります。 |
| Set the maximum block depth to        | Auto、128、256、512、1024、2048、4096、8192 | 最大ブロック深度をワードで指定します。                                        |

## パラメータ設定 : Clks/Rd, Byte En

|                                                   |                                                                                                                                                                                         |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              |
|---------------------------------------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| What clocking method would you like to use?       | <ul style="list-style-type: none"> <li>Single clock</li> <li>Dual clock: use separate 'input' and 'output' clocks</li> <li>Dual clock: use separate clocks for A and B ports</li> </ul> | <p>使用するクロッキング方法を指定します。</p> <ul style="list-style-type: none"> <li><b>Single clock</b>—シングル・クロックとクロック・イネーブルがメモリ・ブロックのすべてのレジスタを制御します。</li> <li><b>Dual Clock: use separate 'input' and 'output' clocks</b>—入力クロックと出力クロックが、データ、アドレス、バイト・イネーブル、読み取りイネーブル、および書き込みイネーブルを含むメモリ・ブロックへのデータ出入力、およびメモリ・ブロックからのデータ出入力に関するすべてのレジスタを制御します。</li> <li><b>Dual clock: use separate clocks for A and B ports</b>—クロック A がポート A 側のすべてのレジスタを制御し、クロック B がポート B 側のすべてのレジスタを制御します。また、各ポートはそれぞれ、ポート A およびポート B レジスタの独立クロック・イネーブルをサポートします。</li> </ul> |
| Create a 'rden_a' and 'rden_b' read enable signal | On / Off                                                                                                                                                                                | 読み取りイネーブル信号を作成するかどうかを指定します。                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  |

## パラメータ設定 : Regs/Clkens/Aclrs

|                                   |                                                                                                  |          |                                                        |
|-----------------------------------|--------------------------------------------------------------------------------------------------|----------|--------------------------------------------------------|
| Which ports should be registered? | <ul style="list-style-type: none"> <li>Write input ports</li> <li>Read output port(s)</li> </ul> | On / Off | 読み取りまたは書き込み入力ポート、読み取りまたは書き込み出力ポートをレジスタに格納するかどうかを指定します。 |
|-----------------------------------|--------------------------------------------------------------------------------------------------|----------|--------------------------------------------------------|

| オプション                                                         | 正当値                                                                                                                                                                                                                                                                                                                                                                                                                            | 説明                                                                                                                                                                                                                                                                                                        |
|---------------------------------------------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| More Options                                                  | <ul style="list-style-type: none"> <li>• Input ports           <ul style="list-style-type: none"> <li>• 'address_a' port</li> <li>• 'address_b' port</li> </ul> </li> <li>• Q output ports           <ul style="list-style-type: none"> <li>• 'q_a' port</li> <li>• 'q_b' port</li> </ul> </li> </ul>                                                                                                                          | デフォルトでは、読み取り入力ポートと書き込み入力ポートはオフになっています。Q 出力ポートをレジスタに格納するかどうかのみ指定する必要があります。                                                                                                                                                                                                                                 |
| Create one clock enable signal for each clock signal.         | On / Off                                                                                                                                                                                                                                                                                                                                                                                                                       | 各クロック信号に 1 つのクロック・イネーブル信号を作成するためのオプションをオンにするかどうかを指定します。                                                                                                                                                                                                                                                   |
| More Options                                                  | <ul style="list-style-type: none"> <li>• Clock enable options           <ul style="list-style-type: none"> <li>• Use clock enable for port A input registers</li> <li>• Use clock enable for port A output registers</li> </ul> </li> <li>• Address options           <ul style="list-style-type: none"> <li>• Create an 'addressstall_a' input port.</li> <li>• Create an 'addressstall_b' input port.</li> </ul> </li> </ul> | <ul style="list-style-type: none"> <li>• Clock enable options—デフォルトでは、ポート B の入力および出力レジスタのクロック・イネーブルはオフです。ポート A の入力および出力レジスタのクロック・イネーブルを使用するかどうかのみ指定する必要があります。</li> <li>• Address options—アドレス・レジスタのクロック・イネーブルを作成するかどうかを指定します。これらのポートは、アドレス・レジスタの追加のアクティブ Low クロック・イネーブル入力として機能するよう作成することができます。</li> </ul> |
| Create an 'aclr' asynchronous clear for the registered ports. | On / Off                                                                                                                                                                                                                                                                                                                                                                                                                       | レジスタに格納されたポートの非同期クリア・ポートを作成するかどうかを指定します。                                                                                                                                                                                                                                                                  |
| More Options                                                  | <ul style="list-style-type: none"> <li>• 'q_a' port</li> <li>• 'q_b' port</li> </ul>                                                                                                                                                                                                                                                                                                                                           | 'q_a' および 'q_b' ポートが aclr ポートによってクリアされるかどうかを指定します。                                                                                                                                                                                                                                                        |

## パラメータ設定 : Mem Init

| オプション                                                              | 正当値                                                                      | 説明                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             |
|--------------------------------------------------------------------|--------------------------------------------------------------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Do you want to specify the initial content of the memory?          | Yes, use this file for the memory content data                           | <p>メモリの初期内容を指定します。</p> <ul style="list-style-type: none"> <li>メモリをゼロに初期化するには、<b>No, leave it blank</b> を選択します。</li> <li>メモリ初期化ファイル (.mif) または 16 進 (Intel-Format) ファイル (.hex) を使用するには、<b>Yes, use this file for the memory content data</b> を選択します。</li> </ul> <p>注: デバイスのコンフィギュレーション手法は Internal Configuration です。メモリの初期化を使用するためには、<b>Enable ERAM Preload</b> オプションをオンにする必要があります。<b>Enable ERAM Preload</b> オプションは、<b>More Analysis &amp; Synthesis Settings</b> ダイアログ・ボックスでオンにすることができます。</p> |
| The initial content file should conform to which port's dimension? | <ul style="list-style-type: none"> <li>PORT_A</li> <li>PORT_B</li> </ul> | 初期コンテンツ・ファイルを準拠させる必要があるポートの寸法を指定します。                                                                                                                                                                                                                                                                                                                                                                                                                                                           |

# シフト・レジスタ（RAM ベース）IP コア・リ ファレンス

8

2014.09.22

UG-M10MEMORY

✉ 署名    🗣 フィードバック

シフト・レジスタ（RAM ベース）IP コアは、従来のシフト・レジスタにはない追加の機能を有します。メモリブロックをシフト・レジスタ・ブロックとして使用して、ロジック・セルと配線リソースを節約することができます。また、より大きなシフト・レジスタを実装するためにメモリ・ブロックをカスケード接続することができます。

図 8-1: シフト・レジスタ（RAM ベース）IP コア信号



## MAX 10 デバイスのシフト・レジスタ（RAM ベース）IP コア信号

表 8-1: シフト・レジスタ（RAM ベース）IP コア入力信号

| 信号        | 必要性 | 説明                                                                     |
|-----------|-----|------------------------------------------------------------------------|
| shiftin[] | あり  | シフタへのデータ入力。入力ポート WIDTH ビット幅です。                                         |
| clock     | あり  | ポジティブ・エッジ・トリガ・クロック。                                                    |
| clken     | なし  | clock ポートのクロック・イネーブル。デフォルトでは、clken は VCC です。                           |
| aclr      | なし  | シフト・レジスタ・チェインのコンテンツを非同期クリアします。shiftout 出力は aclr 信号がアサートされると直ちにクリアされます。 |

© 2014 Altera Corporation. All rights reserved. ALTERA, ARRIA, CYCLONE, ENPIRION, MAX, MEGACORE, NIOS, QUARTUS and STRATIX words and logos are trademarks of Altera Corporation and registered in the U.S. Patent and Trademark Office and in other countries. All other words and logos identified as trademarks or service marks are the property of their respective holders as described at [www.altera.com/common/legal.html](http://www.altera.com/common/legal.html). Altera warrants performance of its semiconductor products to current specifications in accordance with Altera's standard warranty, but reserves the right to make changes to any products and services at any time without notice. Altera assumes no responsibility or liability arising out of the application or use of any information, product, or service described herein except as expressly agreed to in writing by Altera. Altera customers are advised to obtain the latest version of device specifications before relying on any published information and before placing orders for products or services.

ISO  
9001:2008

表 8-2: シフト・レジスタ (RAM ベース) IP コア出力信号

| 信号         | 必要性 | 説明                                                                                                                                    |
|------------|-----|---------------------------------------------------------------------------------------------------------------------------------------|
| shiftout[] | あり  | シフト・レジスタの終端からの出力。出力ポート <code>WIDTH</code> ビット幅です。                                                                                     |
| taps[]     | あり  | シフト・レジスタに沿った等間隔のタップからの出力。出力ポート <code>WIDTH * NUMBER_OF_TAPS</code> 幅です。このポートは、シフト・レジスタに沿ったすべての等間隔タップ（各 <code>WIDTH</code> ビット）の集合体です。 |

## MAX 10 デバイスのシフト・レジスタ (RAM ベース) IP コアのパラメータ

表 8-3: MAX 10 デバイスのシフト・レジスタ (RAM ベース) IP コアのパラメータ

この表は、 MAX 10 デバイスに適用可能な IP コアのパラメータをリストしています。

| オプション                                                                   | 値                                                    | 説明                                                                         |
|-------------------------------------------------------------------------|------------------------------------------------------|----------------------------------------------------------------------------|
| How wide should the "shiftin" input and the "shiftout" output buses be? | 1、2、3、4、5、6、7、8、12、16、24、32、48、64、96、128、192、および 256 | 入力パターンの幅を指定します。                                                            |
| How many taps would you like?                                           | 1、2、3、4、5、6、7、8、12、16、24、32、48、64、96、および 128         | シフト・レジスタに沿った等間隔タップの数を指定します。                                                |
| Create groups for each tap output                                       | On / Off                                             | 各タップの出力にグループを作成します。                                                        |
| How wide should the distance between taps be?                           | 3、4、5、6、7、8、16、32、64、および 128                         | クロック・サイクルで等間隔タップ間の距離を指定します。この数値は使用する RAM ワードの数に変換します。なお、値は 3 以上である必要があります。 |
| Create a clock enable port                                              | On / Off                                             | <code>clken</code> ポートを作成します。                                              |
| Create an asynchronous clear port                                       | On / Off                                             | <code>aclr</code> ポートを作成します。                                               |
| What should the RAM block type be?                                      | Auto、M9K                                             | RAM ブロック・タイプを指定します。                                                        |

2014.09.22

UG-M10MEMORY

✉ 署名

💬 フィードバック

FIFO IP コアは FIFO モードを実装しており、メモリ・ブロックを FIFO バッファとして使用することができます。

- ・ デザインにシングル・クロック FIFO バッファおよびデュアル・クロック FIFO バッファを実装するには、FIFO IP コアをシングル・クロック FIFO (SCFIFO) モードおよびデュアル・クロック FIFO (DCFIFO) モードで使用します。
- ・ デュアル・クロック FIFO バッファは、クロック・ドメイン間でデータを転送する際に役立ちます。
- ・ M9K メモリ・ブロックは、空の FIFO バッファからの同時の読み取りおよび書き込みをサポートしません。

図 9-1: FIFO IP コア : SCFIFO モード信号



© 2014 Altera Corporation. All rights reserved. ALTERA, ARRIA, CYCLONE, ENPIRION, MAX, MEGACORE, NIOS, QUARTUS and STRATIX words and logos are trademarks of Altera Corporation and registered in the U.S. Patent and Trademark Office and in other countries. All other words and logos identified as trademarks or service marks are the property of their respective holders as described at [www.altera.com/common/legal.html](http://www.altera.com/common/legal.html). Altera warrants performance of its semiconductor products to current specifications in accordance with Altera's standard warranty, but reserves the right to make changes to any products and services at any time without notice. Altera assumes no responsibility or liability arising out of the application or use of any information, product, or service described herein except as expressly agreed to in writing by Altera. Altera customers are advised to obtain the latest version of device specifications before relying on any published information and before placing orders for products or services.

ISO  
9001:2008

図 9-2: FIFO IP コア：DCFIFO モード信号



## MAX 10 デバイスの FIFO IP コア信号

表 9-1: FIFO IP コア入力信号

| 信号    | 必要性 | 説明                                                                                                                                                                 |
|-------|-----|--------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| clock | あり  | ポジティブ・エッジ・トリガ・クロック。                                                                                                                                                |
| wrclk | あり  | ポジティブ・エッジ・トリガ・クロック。以下のポートを同期化します。 <ul style="list-style-type: none"> <li>• data</li> <li>• wrreq</li> <li>• wrfull</li> <li>• wrempy</li> <li>• wrusedw</li> </ul> |
| rdclk | あり  | ポジティブ・エッジ・トリガ・クロック。以下のポートを同期化します。 <ul style="list-style-type: none"> <li>• q</li> <li>• rdreq</li> <li>• rdbufull</li> <li>• rdempty</li> <li>• rdusedw</li> </ul> |

| 信号    | 必要性 | 説明                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               |
|-------|-----|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| data  | あり  | wrreq 信号がアサートされるとき、FIFO IP コアに書き込まれるデータを保持します。<br>FIFO IP コアを手動でインスタンス化する場合、ポート幅が <b>How wide should the FIFO be?</b> パラメータと等しいものであることを確認してください。                                                                                                                                                                                                                                                                                                                                                                                                                                 |
| wrreq | あり  | 書き込み動作を要求するには、この信号をアサートします。<br>以下の条件が満たされていることを確認してください。 <ul style="list-style-type: none"> <li>full (SCFIFO モードの FIFO IP コア) または wrfull (DCFIFO モードの FIFO IP コア) ポートが High のとき、wrreq 信号をアサートしない。FIFO IP コアがフルのとき、自動的に wrreq 信号をディセーブルできるようオーバーフロー保護回路をイネーブルするか、<b>Disable overflow checking. Writing to a full FIFO will corrupt contents</b> パラメータをオンにします。</li> <li>wrreq 信号は、full または wrfull 信号に基づいて機能タイミング要件を満たす必要があります。</li> <li>aclr 信号がディアサートしている間 wrreq 信号をアサートしない。wrreq ポートが High に設定されている場合、この要件に違反すると、aclr 信号の立ち下りエッジと write クロックの立ち上がりエッジの間で競合状態を引き起こします。</li> </ul> |
| rdreq | あり  | 読み取り動作を要求するには、この信号をアサートします。rdreq 信号は通常の同期 FIFO モードと show-ahead モード同期 FIFO モードでは異なる機能を果たします。<br>以下の条件が満たされていることを確認してください。 <ul style="list-style-type: none"> <li>empty (SCFIFO モードの FIFO IP コア) または rdempty (DCFIFO モードの FIFO IP コア) ポートが High のとき、rdreq 信号をアサートしない。FIFO IP コアが空のとき、自動的に rdreq 信号をディセーブルできるようアンダーフロー保護回路をイネーブルするか、<b>Disable underflow checking. Reading from an empty FIFO will corrupt contents</b> パラメータをオンにします。</li> </ul> rdreq 信号は、empty または rdempty 信号に基づいて機能タイミング要件を満たす必要があります。                                                                           |
| sclr  | なし  | すべての出力ステータス・ポートをクリアするには、この信号をアサートします。ただし、q 出力への影響は異なる FIFO コンフィギュレーションで相違する場合があります。アクティブのままにしておく必要がある aclr 信号のクロック・サイクルの最小数に制限はありません。                                                                                                                                                                                                                                                                                                                                                                                                                                            |
| aclr  | なし  |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  |

表 9-2: FIFO IP コア出力信号

| 信号           | 必要性 | 説明                                                                                                                                                                                                                                                                                                                                                                                                                                 |
|--------------|-----|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| q            |     | 読み取り要求動作から読み取られるデータを示します。SCFIFO および DCFIFO モードでは、q ポートの幅は data ポートの幅と等しいものである必要があります。IP を手動でインスタンス化する場合、ポート幅が <b>How wide should the FIFO be?</b> パラメータと等しいことを確認してください。DCFIFO_MIXED_WIDTHS モードでは、q ポートの幅は data ポートの幅と異なるものでも構いません。IP を手動でインスタンス化する場合、q ポートの幅が <b>Use a different output width</b> パラメータと等しいことを確認してください。IP は幅の広い書き込みポートと幅の狭い読み取りポート、および幅の狭い書き込みポートと幅の広い読み取りポートをサポートします。ただし、幅の比は RAM ブロックのタイプによって制限され、一般的には 2 の累乗です。 |
| full         | なし  | アサートされる場合、FIFO IP コアはフルとみなされます。FIFO IP コアがフルのとき、書き込み要求動作を実行しないでください。一般的に rdfull 信号は wrfull 信号の遅延バージョンです。ただし、rdfull 信号は wrfull 信号の派生バージョンとしてではなく、組み合わせ出力として機能します。そのため、ターゲット・デバイスとは関係なく、常に wrfull ポートを参照して有効な書き込み要求動作が実行できるかどうかを確認する必要があります。                                                                                                                                                                                         |
| wrfull       |     |                                                                                                                                                                                                                                                                                                                                                                                                                                    |
| rdfull       |     |                                                                                                                                                                                                                                                                                                                                                                                                                                    |
| empty        | なし  | アサートされる場合、FIFO IP コアは空とみなされます。FIFO IP コアが空のとき、読み取り要求動作を実行しないでください。一般的に wrempty 信号は rdempty 信号の遅延バージョンです。ただし、wrempty 信号は rdempty 信号の派生バージョンとしてではなく、組み合わせ出力として機能します。そのため、ターゲット・デバイスとは関係なく、常に rdempty ポートを参照して有効な読み取り要求動作が実行できるかどうかを確認する必要があります。                                                                                                                                                                                      |
| wrempty      |     |                                                                                                                                                                                                                                                                                                                                                                                                                                    |
| rdempty      |     |                                                                                                                                                                                                                                                                                                                                                                                                                                    |
| almost_full  | なし  | usedw 信号が <b>Almost full</b> パラメータと等しいか、それを超える場合にアサートされます。full 信号の早期通知として使用されます。                                                                                                                                                                                                                                                                                                                                                   |
| almost_empty | なし  | usedw 信号が <b>Almost empty</b> パラメータを下回る場合にアサートされます。empty 信号の早期通知として使用されます。                                                                                                                                                                                                                                                                                                                                                         |
| usedw        | なし  | FIFO に格納されたワード数を示します。SCFIFO または DCFIFO モードでは、FIFO IP コアを手動でインスタンス化する場合、ポート幅が <b>usedw[]</b> パラメータと等しいことを確認してください。DCFIFO_MIXED_WIDTH モードでは、wrusedw ポートおよび rdusedw ポートの幅はそれぞれ、 <b>usedw[]</b> および <b>Use a different output width</b> パラメータと等しいものである必要があります。                                                                                                                                                                         |
| wrusedw      |     |                                                                                                                                                                                                                                                                                                                                                                                                                                    |
| rdusedw      |     |                                                                                                                                                                                                                                                                                                                                                                                                                                    |

## MAX 10 デバイスの FIFO IP コアのパラメータ

表 9-3: MAX 10 デバイスの FIFO IP コアのパラメータ

この表は、 MAX 10 デバイスに適用可能な IP コアのパラメータをリストしています。

| パラメータ                                                               | HDL パラメータ                  | 説明                                                                                                                                                                                                                                                                                                                                                                                                                                                                           |
|---------------------------------------------------------------------|----------------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| <b>How wide should the FIFO be?</b>                                 | <code>lpm_width</code>     | SCFIFO モードと DCFIFO モードの FIFO IP コアの <code>data</code> ポートおよび <code>q</code> ポートの幅を指定します。DCFIFO_MIXED_WIDTHS モードの FIFO IP コアでは、このパラメータは <code>data</code> ポートの幅のみを指定します。                                                                                                                                                                                                                                                                                                      |
| <b>Use a different output width<sup>(1)</sup></b>                   | <code>lpm_width_r</code>   | DCFIFO_MIXED_WIDTHS モードの FIFO IP コアの <code>q</code> ポートの幅を指定します。                                                                                                                                                                                                                                                                                                                                                                                                             |
| <b>Usedw[]</b>                                                      | <code>lpm_widthu</code>    | SCFIFO モードの FIFO IP コアの <code>usedw</code> ポートの幅、あるいは DCFIFO モードの FIFO IP コアの <code>rdusedw</code> および <code>wrusedw</code> ポートの幅を指定します。DCFIFO_MIXED_WIDTHS モードの FIFO IP コアでは、 <code>wrusedw</code> ポートの幅のみを表します。                                                                                                                                                                                                                                                            |
| <b>How deep should the FIFO be?</b>                                 | <code>lpm_numwords</code>  | 必要な FIFO の深度を指定します。値は 4 以上でなければなりません。割り当てる値は、 $2^{\text{LPM\_WIDTHU}}$ の式に準拠している必要があります。                                                                                                                                                                                                                                                                                                                                                                                     |
| <b>Which kind of read access do you want with the rdreq signal?</b> | <code>lpm_showahead</code> | FIFO が通常の同期 FIFO モードであるのか、show-ahead モード同期 FIFO モードであるのかを指定します。通常の同期 FIFO モードでは、 <code>rdreq</code> ポートがアサートされる場合、FIFO IP コアはこのポートを読み取り動作のみを実行する通常の読み取り要求として扱います。show-ahead モード同期 FIFO モードでは、FIFO IP コアは <code>rdreq</code> 信号をアサートせずに、 <code>rdreq</code> を FIFO IP コア内の有効なデータの最初のワードを自動的に出力する読み取り確認として扱います ( <code>empty</code> または <code>rdempty</code> ポートが Low のとき)。 <code>rdreq</code> 信号をアサートすると、可能な場合、FIFO IP コアが次のデータ・ワードを出力します。このパラメータをオンにすると、パフォーマンスが低下することがあります。 |
| <b>Do you want a common clock for reading and writing the FIFO?</b> | <code>lpm_type</code>      | LPM (Library of Parameterized Modules) のエンティティ名を識別します。値は SCFIFO と DCFIFO です。                                                                                                                                                                                                                                                                                                                                                                                                 |

<sup>(1)</sup> DCFIFO\_MIXED\_WIDTHS モードでのみ適用可能です。

| パラメータ                                                                                | HDL パラメータ          | 説明                                                                                                                                                                                                                                                                                                                                |
|--------------------------------------------------------------------------------------|--------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| <b>Disable overflow checking. Writing to a full FIFO will corrupt contents</b>       | overflow_checking  | FIFO IP コアがフルのとき、wrreq ポートをディセーブルするオーバーフローのチェックのための保護回路をイネーブルするかどうかを指定します。このパラメータは、デフォルトでイネーブルされています。                                                                                                                                                                                                                             |
| <b>Disable underflow checking. Reading from an empty FIFO will corrupt contents.</b> | underflow_checking | FIFO IP コアが空のとき、rdreq ポートをディセーブルするアンダーフローのチェックのための保護回路をイネーブルするかどうかを指定します。このパラメータは、デフォルトでイネーブルされています。空の SCFIFO モードからの読み取りによって予測不可能な結果が起こり得ることに注意してください。                                                                                                                                                                            |
| <b>Add an extra MSB to usedw<sup>(2)</sup></b>                                       | add_usedw_msb_bit  | rdusedw および wrusedw ポートの幅を 1 ビットずつ増大させます。幅を大きくことによって、FIFO IP コアがフルのとき、ゼロにロール・オーバーすることを防ぎます。このパラメータは、デフォルトでディセーブルされています。                                                                                                                                                                                                           |
| <b>How many sync stages? <sup>(2)</sup></b>                                          | rdsync_delaypipe   | クロス・クロック・ドメインにおける同期ステージ数を指定します。rdsync_delaypipe パラメータの値は、同期ステージを書き込みコントロール・ロジックから読み取りコントロール・ロジックに関連させます。wrsync_delaypipe パラメータの値は、同期ステージを読み取りコントロール・ロジックから書き込みコントロール・ロジックに関連させます。クロックが同期化されていない場合はこれらのパラメータを使用して同期ステージの数を設定し、clocks_are_synchronized パラメータを FALSE に設定します。実装されている実際の同期ステージは、ターゲットのデバイスに応じて割り当てられたパラメータの値に多様に関連します。 |
| <b>How many sync stages? <sup>(2)</sup></b>                                          | wrsync_delaypipe   | クロス・クロック・ドメインにおける同期ステージ数を指定します。rdsync_delaypipe パラメータの値は、同期ステージを書き込みコントロール・ロジックから読み取りコントロール・ロジックに関連させます。wrsync_delaypipe パラメータの値は、同期ステージを読み取りコントロール・ロジックから書き込みコントロール・ロジックに関連させます。クロックが同期化されていない場合はこれらのパラメータを使用して同期ステージの数を設定し、clocks_are_synchronized パラメータを FALSE に設定します。実装されている実際の同期ステージは、ターゲットのデバイスに応じて割り当てられたパラメータの値に多様に関連します。 |

<sup>(2)</sup> DCFIFO モードでのみ適用可能です。

| パラメータ                                                                                           | HDL パラメータ               | 説明                                                                                                                                                                                                                                                                                                                                                 |
|-------------------------------------------------------------------------------------------------|-------------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| <b>Implement FIFO storage with logic cells only, even if the device contains memory blocks.</b> | use_eab                 | FIFO IP コアが RAM ブロックを使用して構成されるかどうかを指定します。デフォルトでは、このパラメータはディセーブルされています。このパラメータをオフにすると、 <b>What should the memory block type be</b> パラメータに割り当てられたメモリ・ブロック・タイプに関係なく、FIFO IP コアはロジック・エレメントに実装されます。                                                                                                                                                     |
| <b>Add circuit to synchronize ‘aclr’ input with ‘wrclk’<sup>(2)</sup></b>                       | write_aclr_synch        | wrclk クロックによって aclr ポートを内部的に同期させる回路を追加するかどうかを指定します。この回路を追加すると、FIFO IP コアを破損し得る wrreq ポートと aclr ポート間の競合状態を防ぐことができます。デフォルトでは、このパラメータはディセーブルされています。                                                                                                                                                                                                   |
| <b>Add circuit to synchronize ‘aclr’ input with ‘rdclk’</b>                                     | read_aclr_synch         | rdclk クロックによって aclr ポートを内部的に同期させる回路を追加するかどうかを指定します。この回路を追加すると、FIFO IP コアを破損し得る rdreq ポートと aclr ポート間の競合状態を防ぐことができます。デフォルトでは、このパラメータはディセーブルされています。                                                                                                                                                                                                   |
| <b>Which type of optimization do you want?<sup>(2)</sup></b>                                    | clocks_are_synchronized | 書き込みクロックと読み取りクロックが同期化されるかどうかを指定します。これにより、FIFO の動作を安定させるために追加される内部同期ステージ数を決定します。値は TRUE と FALSE です。省略する場合、デフォルト値は FALSE です。書き込みクロックと読み取りクロックが常に同期され、互いの倍数になる場合のみパラメータを TRUE に設定する必要があります。それ以外の場合は、メタ stabilitiy の問題を防ぐため、このパラメータを FALSE に設定します。クロックが同期化されない場合はこのパラメータを FALSE に設定し、rdsync_delaypipe および wrsync_delaypipe パラメータを使用して必要な同期ステージ数を決定します。 |
| <b>What should the memory block type be</b>                                                     | ram_block_type          | 使用するターゲット・デバイスのメモリ・ブロックを指定します。設定した RAM コンフィギュレーションに基づいた適切な実装を取得するには、このパラメータを無視するとによって Quartus II ソフトウェアが自動的にメモリ・タイプを選択することを可能にし、 <b>Implement FIFO storage with logic cells only, even if the device contains memory blocks.</b> パラメータをオンにします。これにより、必要な FIFO の深度に基づいて使用可能なメモリ・リソースにメモリ機能を配置するにあたって、コンパイラの柔軟性が増します。                                 |

| パラメータ                                                                                               | HDL パラメータ               | 説明                                                                                             |
|-----------------------------------------------------------------------------------------------------|-------------------------|------------------------------------------------------------------------------------------------|
| Would you like to register the output to maximize the performance but use more area? <sup>(3)</sup> | add_ram_output_register | 出力をレジスタするかどうかを指定します。値は Yes (best speed) と No (smallest area) です。デフォルト値は No (smallest area) です。 |
| Becomes true when usedw[] is greater than or equal to: <sup>(3)</sup>                               | almost_full_value       | almost_full ポートのスレッショルド値を設定します。 FIFO IP コアに格納されているワード数がこの値以上になる場合、almost_full ポートがアサートされます。    |
| Almost full <sup>(3)</sup>                                                                          |                         |                                                                                                |
| Almost empty <sup>(3)</sup>                                                                         | almost_empty_value      | almost_empty ポートのスレッショルド値を設定します。 FIFO IP コアに格納されているワード数がこの値未満になる場合、almost_empty ポートがアサートされます。  |
| Becomes true when usedw[] is less than: <sup>(3)</sup>                                              |                         |                                                                                                |
| Currently selected device family                                                                    | intended_device_family  | Quartus II プロジェクトで設定したデバイスと一致するデバイスを指定します。機能シミュレーションでのみこのパラメータを使用します。                          |

<sup>(3)</sup> SCFIFO モードでのみ適用可能です。

# ALTMEMMULT IP コア・リファレンス 10

2014.09.22

UG-M10MEMORY

✉ 署名    🗣 フィードバック

ALTMEMMULT IP コアは、M9K メモリ・ブロックが有するオンチップ・メモリ・ブロックを使用してメモリ・ベースの乗算器のみを作成します。

図 10-1: ALTMEMMULT IP コア信号



## MAX 10 デバイスの ALTMEMMULT IP コア信号

表 10-1: ALTMEMMULT IP コア入力信号

| 信号          | 必要性 | 説明                                                  |
|-------------|-----|-----------------------------------------------------|
| clock       | あり  | 乗算器へのクロック入力。                                        |
| coeff_in[]  | なし  | 乗算器の係数入力ポート。入力ポートの容量は WIDTH_C パラメータの値によって決まります。     |
| data_in[]   | あり  | 乗算器へのデータ入力ポート。入力ポートの容量は WIDTH_D パラメータの値によって決まります。   |
| sclr        | なし  | 同期クリア入力。使用しない場合、デフォルト値はアクティブ High です。               |
| sel[]       | なし  | 固定係数選択。入力ポートの容量は WIDTH_S パラメータの値によって決まります。          |
| sload_coeff | なし  | 同期ロード係数入力ポート。現在選択している係数値を coeff_in 入力で指定した値に置き換えます。 |

© 2014 Altera Corporation. All rights reserved. ALTERA, ARRIA, CYCLONE, ENPIRION, MAX, MEGACORE, NIOS, QUARTUS and STRATIX words and logos are trademarks of Altera Corporation and registered in the U.S. Patent and Trademark Office and in other countries. All other words and logos identified as trademarks or service marks are the property of their respective holders as described at [www.altera.com/common/legal.html](http://www.altera.com/common/legal.html). Altera warrants performance of its semiconductor products to current specifications in accordance with Altera's standard warranty, but reserves the right to make changes to any products and services at any time without notice. Altera assumes no responsibility or liability arising out of the application or use of any information, product, or service described herein except as expressly agreed to in writing by Altera. Altera customers are advised to obtain the latest version of device specifications before relying on any published information and before placing orders for products or services.

ISO  
9001:2008

| 信号         | 必要性 | 説明                                                                                                                                              |
|------------|-----|-------------------------------------------------------------------------------------------------------------------------------------------------|
| sload_data | なし  | 同期ロード・データ入力ポート。新しい乗算演算を指定し、既存の乗算演算をキャンセルする信号。 <code>MAX_CLOCK_CYCLES_PER_RESULT</code> パラメータが 1 の値を有する場合、 <code>sload_data</code> 入力ポートは無視されます。 |

表 10-2: ALTMEMMULT IP コア出力信号

| 信号           | 必要性 | 説明                                                                                                                                          |
|--------------|-----|---------------------------------------------------------------------------------------------------------------------------------------------|
| result[]     | あり  | 乗算器出力ポート。出力ポートの容量は <code>WIDTH_R</code> パラメータの値によって決まります。                                                                                   |
| result_valid | あり  | 出力が完全な乗算の有効な結果である場合を示します。 <code>MAX_CLOCK_CYCLES_PER_RESULT</code> パラメータが 1 の値を有する場合、 <code>result_valid</code> 出力ポートは使用されません。              |
| load_done    | なし  | 新しい係数のロードが完了したことを示します。 <code>load_done</code> 信号は、新しい係数のロードが完了したときにアサートします。 <code>load_done</code> 信号が High でない場合は、他の係数値をメモリにロードすることはできません。 |

## MAX 10 デバイスの ALTMEMMULT IP コアのパラメータ

表 10-3: MAX 10 デバイスの ALTMEMMULT IP コアのパラメータ

この表は、 MAX 10 デバイスに適用可能な IP コアのパラメータをリストしています。

| オプション                                          | 値                          | 説明                                                            |
|------------------------------------------------|----------------------------|---------------------------------------------------------------|
| How wide should the 'data_in' input bus be?    | 2、3、4、5、6、7、8、16、24、および 32 | <code>data_in</code> ポートの幅を指定します。                             |
| What is the representation of 'data_in'?       | SIGNED、UNSIGNED            | <code>data_in</code> 入力ポートが符号付きか、または符号なしを指定します。               |
| How wide should the coefficient be?            | 2、3、4、5、6、7、8、16、24        | <code>coeff_in</code> ポートの幅を指定します。                            |
| What is the representation of the coefficient? | SIGNED、UNSIGNED            | <code>coeff_in</code> 入力ポートとプリロードされた係数が符号付きか、または符号なしを指定します。   |
| What is the value of the initial coefficient?  | 0、1、2、3、および 4              | 最初の固定係数の値を指定します。                                              |
| Create ports to allow loading coefficients     | On / Off                   | <code>coeff_in</code> および <code>sload_coeff</code> ポートを作成します。 |
| Create a synchronous clear input               | On / Off                   | <code>sclr</code> ポートを作成します。                                  |
| What should the RAM block type be?             | Auto、M9K                   | RAM ブロック・タイプを指定します。                                           |

# MAX 10 エンベデッド・メモリ・ユーザーガイドの追加情報

A

2014.09.22

UG-M10MEMORY

 署名  フィードバック

## MAX 10 エンベデッド・メモリ・ユーザーガイド改訂履歴

| 日付         | バージョン      | 変更内容 |
|------------|------------|------|
| 2014 年 9 月 | 2014.09.22 | 初版   |

© 2014 Altera Corporation. All rights reserved. ALTERA, ARRIA, CYCLONE, ENPIRION, MAX, MEGACORE, NIOS, QUARTUS and STRATIX words and logos are trademarks of Altera Corporation and registered in the U.S. Patent and Trademark Office and in other countries. All other words and logos identified as trademarks or service marks are the property of their respective holders as described at [www.altera.com/common/legal.html](http://www.altera.com/common/legal.html). Altera warrants performance of its semiconductor products to current specifications in accordance with Altera's standard warranty, but reserves the right to make changes to any products and services at any time without notice. Altera assumes no responsibility or liability arising out of the application or use of any information, product, or service described herein except as expressly agreed to in writing by Altera. Altera customers are advised to obtain the latest version of device specifications before relying on any published information and before placing orders for products or services.

ISO  
9001:2008