# カタログ等資料中の旧社名の扱いについて

2010年4月1日を以ってNECエレクトロニクス株式会社及び株式会社ルネサステクノロジが合併し、両社の全ての事業が当社に承継されております。従いまして、本資料中には旧社名での表記が残っておりますが、当社の資料として有効ですので、ご理解の程宜しくお願い申し上げます。

ルネサスエレクトロニクス ホームページ (http://www.renesas.com)

2010 年 4 月 1 日 ルネサスエレクトロニクス株式会社

【発行】ルネサスエレクトロニクス株式会社(http://www.renesas.com)

【問い合わせ先】http://japan.renesas.com/inquiry



## ご注意書き

- 1. 本資料に記載されている内容は本資料発行時点のものであり、予告なく変更することがあります。当社製品のご購入およびご使用にあたりましては、事前に当社営業窓口で最新の情報をご確認いただきますとともに、当社ホームページなどを通じて公開される情報に常にご注意ください。
- 2. 本資料に記載された当社製品および技術情報の使用に関連し発生した第三者の特許権、著作権その他の知的 財産権の侵害等に関し、当社は、一切その責任を負いません。当社は、本資料に基づき当社または第三者の 特許権、著作権その他の知的財産権を何ら許諾するものではありません。
- 3. 当社製品を改造、改変、複製等しないでください。
- 4. 本資料に記載された回路、ソフトウェアおよびこれらに関連する情報は、半導体製品の動作例、応用例を説明するものです。お客様の機器の設計において、回路、ソフトウェアおよびこれらに関連する情報を使用する場合には、お客様の責任において行ってください。これらの使用に起因しお客様または第三者に生じた損害に関し、当社は、一切その責任を負いません。
- 5. 輸出に際しては、「外国為替及び外国貿易法」その他輸出関連法令を遵守し、かかる法令の定めるところにより必要な手続を行ってください。本資料に記載されている当社製品および技術を大量破壊兵器の開発等の目的、軍事利用の目的その他軍事用途の目的で使用しないでください。また、当社製品および技術を国内外の法令および規則により製造・使用・販売を禁止されている機器に使用することができません。
- 6. 本資料に記載されている情報は、正確を期すため慎重に作成したものですが、誤りがないことを保証するものではありません。万一、本資料に記載されている情報の誤りに起因する損害がお客様に生じた場合においても、当社は、一切その責任を負いません。
- 7. 当社は、当社製品の品質水準を「標準水準」、「高品質水準」および「特定水準」に分類しております。また、各品質水準は、以下に示す用途に製品が使われることを意図しておりますので、当社製品の品質水準をご確認ください。お客様は、当社の文書による事前の承諾を得ることなく、「特定水準」に分類された用途に当社製品を使用することができません。また、お客様は、当社の文書による事前の承諾を得ることなく、意図されていない用途に当社製品を使用することができません。当社の文書による事前の承諾を得ることなく、「特定水準」に分類された用途または意図されていない用途に当社製品を使用したことによりお客様または第三者に生じた損害等に関し、当社は、一切その責任を負いません。なお、当社製品のデータ・シート、データ・ブック等の資料で特に品質水準の表示がない場合は、標準水準製品であることを表します。

標準水準: コンピュータ、OA 機器、通信機器、計測機器、AV 機器、家電、工作機械、パーソナル機器、産業用ロボット

高品質水準: 輸送機器(自動車、電車、船舶等)、交通用信号機器、防災・防犯装置、各種安全装置、生命 維持を目的として設計されていない医療機器(厚生労働省定義の管理医療機器に相当)

特定水準: 航空機器、航空宇宙機器、海底中継機器、原子力制御システム、生命維持のための医療機器(生命維持装置、人体に埋め込み使用するもの、治療行為(患部切り出し等)を行うもの、その他直接人命に影響を与えるもの)(厚生労働省定義の高度管理医療機器に相当)またはシステム

- 8. 本資料に記載された当社製品のご使用につき、特に、最大定格、動作電源電圧範囲、放熱特性、実装条件その他諸条件につきましては、当社保証範囲内でご使用ください。当社保証範囲を超えて当社製品をご使用された場合の故障および事故につきましては、当社は、一切その責任を負いません。
- 9. 当社は、当社製品の品質および信頼性の向上に努めておりますが、半導体製品はある確率で故障が発生したり、使用条件によっては誤動作したりする場合があります。また、当社製品は耐放射線設計については行っておりません。当社製品の故障または誤動作が生じた場合も、人身事故、火災事故、社会的損害などを生じさせないようお客様の責任において冗長設計、延焼対策設計、誤動作防止設計等の安全設計およびエージング処理等、機器またはシステムとしての出荷保証をお願いいたします。特に、マイコンソフトウェアは、単独での検証は困難なため、お客様が製造された最終の機器・システムとしての安全検証をお願いいたします。
- 10. 当社製品の環境適合性等、詳細につきましては製品個別に必ず当社営業窓口までお問合せください。ご使用に際しては、特定の物質の含有・使用を規制する RoHS 指令等、適用される環境関連法令を十分調査のうえ、かかる法令に適合するようご使用ください。お客様がかかる法令を遵守しないことにより生じた損害に関して、当社は、一切その責任を負いません。
- 11. 本資料の全部または一部を当社の文書による事前の承諾を得ることなく転載または複製することを固くお断りいたします。
- 12. 本資料に関する詳細についてのお問い合わせその他お気付きの点等がございましたら当社営業窓口までご 照会ください。
- 注1. 本資料において使用されている「当社」とは、ルネサスエレクトロニクス株式会社およびルネサスエレクトロニクス株式会社がその総株主の議決権の過半数を直接または間接に保有する会社をいいます。
- 注 2. 本資料において使用されている「当社製品」とは、注 1 において定義された当社の開発、製造製品をいいます。



# R8A66597FP/DFP/BG

ASSP (USB2.0 2Port Host/1Port Peripheral Controller)

RJJ03F0130-0102 Rev1.02 2008.10.17

# 1概要

## 1.1 概要

R8A66597は、USBホスト機能及びペリフェラル機能を備えたOn-The-Go対応のUSBコントローラーです。 ホストコントローラー機能選択時は、USB (Universal Serial Bus) 規格Rev.2.0のHi-Speed転送、Full-Speed転送、 Low-Speed転送に対応し、USBポートを2ポート使用可能です。

ペリフェラルコントローラー機能選択時は、USB規格Rev.2.0のHi-Speed転送、Full-Speed転送に対応し、USBポートを1ポート使用可能です。

本コントローラーは、USBトランシーバを内蔵し、USB規格Rev.2.0で定義されている全転送タイプに対応しています。

本コントローラーは、データ転送用に8.5Kバイトのバッファメモリを内蔵し、最大10本のパイプを使用できます。また、パイプ1-9に対しては、通信を行うペリフェラル機器やユーザーシステムに合わせた、任意のエンドポイントアドレスの割り付けが可能です。CPUとの接続は、セパレートバスとマルチプレクスバスのどちらかを選択できます。また、CPUバスインタフェースとは独立したスプリットバスインタフェース(DMAインタフェース専用)を備え、高速大容量データ転送を要求されるシステムに適しています。

## 1.2 特長

#### 1.2.1 USB Hi-Speed対応のホストコントローラーとペリフェラルコントローラーを内蔵

- USBホストコントローラーとペリフェラルコントローラーを内蔵
- USBホスト機能とペリフェラル機能をレジスタ設定により切り替え可能
- USBトランシーバ内蔵

#### 1.2.2 低消費電力

- 1.5Vコア電源採用による動作時の低消費電力を実現
- Low Power Sleep Mode機能搭載により、携帯機器向けにも適したUSB未使用時の低消費電力を実現
- USB機能未使用時にVIF電源のみオンにすることにより、待機電流を非常に小さく抑える事が可能
- 1.5Vコア電源用のレギュレータを内蔵し、3.3V単一電源で動作可能

## 1.2.3 省スペース実装対応

- 少ない外付け素子かつ省スペース実装が可能
  - ・VBUS信号をコントローラーの入力端子に直接接続可能
  - ・D+プルアップ抵抗内蔵(ペリフェラル機能選択時)
  - ・D+、D-のプルダウン抵抗内蔵(ホスト機能選択時)
  - ・D+、D-終端抵抗内蔵(Hi-Speed動作時)
  - ・D+、D-出力抵抗内蔵 (Full/Low-Speed動作時)



### 1.2.4 USB全転送タイプに対応

- アイソクロナス転送対応を含むUSB全転送タイプに対応
  - ・コントロール転送
  - ・バルク転送
  - ・インタラプト転送(High Bandwidthは非対応)
  - ・アイソクロナス転送(High Bandwidthは非対応)

#### 1.2.5 パスインタフェース

- 16bitCPUバスインタフェース
  - ・16bitセパレートバス/16bitマルチプレクスバス対応
  - ・8/16bit単位DMA転送対応(スレーブ機能)
- 8bitスプリットバス(外部DMAC専用)インタフェース
- DMAインタフェースを2ch内蔵
- DMA転送により40Mバイト/秒の高速データ転送が可能

#### 1.2.6 パイプコンフィグレーション

- USB通信用バッファメモリを8.5Kバイト内蔵
- 最大10本のパイプを選択可能(デフォルトコントロールパイプを含む)
- プログラマブルなパイプ構成
- パイプ1-9は任意のエンドポイントアドレスを割り付け可能
- 各パイプの設定可能な転送条件
  - ・パイプ0:コントロール転送、シングルバッファで256バイト固定
  - ・パイプ1~2:バルク転送 / アイソクロナス転送、連続転送モード、 バッファサイズはプログラマブル (片面最大2Kバイトまで指定可能、ダブルバッファ指定可能)
  - ・パイプ3~5:バルク転送、連続転送モード、
    - バッファサイズはプログラマブル(片面最大2Kバイトまで指定可能、ダブルバッファ指定可能)
  - ・パイプ6~9:インタラプト転送、シングルバッファで64バイト固定

## 1.2.7 ホスト機能選択時の特長

- Hi-Speed転送 (480Mbps)、Full-Speed転送 (12Mbps)及び、Low-Speed転送 (1.5Mbps)に対応
- ハブを1段経由し、複数のペリフェラル機器と接続可能
- リセットハンドシェイク自動応答
- SOF、パケット送信のスケジュールを自動化
- アイソクロナス転送、インタラプト転送の転送インターバル設定機能

### 1.2.8 ペリフェラル機能選択時の特長

- Hi-Speed転送 (480Mbps)とFull-Speed転送 (12Mbps)に対応
- リセットハンドシェイク自動応答による、Hi-Speed動作、もしくはFull-Speed動作自動認識
- コントロール転送ステージ管理機能
- デバイスステート管理機能
- SET ADDRESSリクエストに対する自動応答機能
- NAK応答割り込み機能(NRDY)
- SOF補間機能

#### 1.2.9 On-the-go対応を容易にする機能

- 起動時のA-Device/B-Device判定を容易にするためのID端子及びID端子モニタービットを内蔵
- Host Negotiation Protocolを容易にするための制御ビットを搭載

### 1.2.10 その他の機能

- バイトエンディアンスワップ機能により、ビッグエンディアン、リトルエンディアンのどちらのCPUにも対応可能
- トランザクションカウントによるトランスファー終了機能
- 外部トリガ(DEND端子)によるDMA転送の終了機能
- SOFパルス出力機能



- PLL内蔵により、3種類の入力クロック選択可能
  - ・48MHz/24MHz/12MHzから選択
- BRDY割り込みイベント通知タイミング変更機能(BFRE)
- DxFIFOポートで指定したパイプのデータ読み出し後自動バッファメモリクリア機能(DCLRM)
- クロック停止状態からの自動クロック供給機能
- トランスファー終了による応答PIDのNAK設定機能(SHTNAK)

## 1.2.11 用途

ナビゲーションシステム、DVDレコーダ、セットトップボックス、オーディオ機器、プリンタ、外部ストレージ機器、 その他USB搭載の機器全般



## 1.3 パッケージ

#### ピン配置図 1.3.1

に本コントローラーの端子配置図 (上面図) を示します。



図 1.1 R8A66597FP/DFP端子配置図

|    |                                                                                             |         |            | R8A    | 6659   | 7BG     |         |       |      |   |  |
|----|---------------------------------------------------------------------------------------------|---------|------------|--------|--------|---------|---------|-------|------|---|--|
|    |                                                                                             | 7.      | <b>ドール</b> | /配置    | ( T    | OP V    | IEW     | )     |      |   |  |
|    | 1                                                                                           | 2       | 3          | 4      | 5      | 6       | 7       | 8     | 9    | - |  |
| Α  | GND                                                                                         | D15     | D14        | D10    | GND    | D5/AD5  | D2/AD2  | D0    | GND  | A |  |
| В  | VIF                                                                                         | INT_N   | D13        | D11    | VIF    | D4/AD4  | D1/AD1  | CS_N  | VIF  | В |  |
| С  | DREQ0_N                                                                                     | DACK0_N | SOF_N      | D9     | D7/AD7 | D3/AD3  | WR1_N   | WR0_N | RD_N | С |  |
| D  | DREQ1_N                                                                                     | DACK1_N | DEND0_N    | D12    | D8     | D6/AD6  | A6      | A4    | A5   | D |  |
| E  | GND                                                                                         | VDD     | DEND1_N    | SD0    | GND    | A7/ALE  | А3      | VDD   | GND  | E |  |
| F  | SD2                                                                                         | SD3     | SD4        | SD1    | VBOUT0 | A2      | GND     | MPBUS | A1   | F |  |
| G  | SD5                                                                                         | SD6     | AVCC       | VBOUT1 | OVCUR1 | EXTLP0  | ID0     | RST_N | VCC  | G |  |
| Н  | VIF                                                                                         | SD7     | XIN        | AGND   | VCC    | OVCUR0B | OVCUR0A | GND   | VBUS | н |  |
| J  | GND                                                                                         | VCC     | XOUT       | REFRIN | DM1    | DP1     | GND     | DM0   | DP0  | J |  |
|    | 1 2 3 4 5 6 7 8 9                                                                           |         |            |        |        |         |         |       |      |   |  |
| Lo | 各信号名の"_N"は パッケージ<br>Lowアクティブであることを<br>示します。 R8A66597BG: PLBG0081KA-A: 81pinLFBGA (0.5mmピッチ) |         |            |        |        |         |         |       |      |   |  |

図 1.2 R8A66597BG端子配置図

## 1.4 端子説明

表 1.1に本コントローラーの端子説明表を、表 1.2に未使用端子の処理方法を示します。

表 1.1 端子説明表

| 区分      | 端子名       | 名称                  | I/O | 機能                                               | 端子数 | 端子のネ         | 犬態 *5)       |
|---------|-----------|---------------------|-----|--------------------------------------------------|-----|--------------|--------------|
|         |           |                     |     |                                                  |     | リセッ<br>ト中    | リセッ<br>ト直後   |
| CPUバスイ  | D15-0     | データバス               | I/O | I<br>16bitデータバスです。                               | 16  | *2)          | *2)          |
| ンタフェー   | L         | マルチプレクス             |     | マルチプレクスバス設定時、本端子群をデータ                            | . • | ~)           | ~)           |
| ス       |           | アドレスバス              |     | バスの一部(D7-D1)、もしくはアドレスバス                          |     |              |              |
|         |           |                     |     | (A7-A1)として時分割で用います。                              |     |              |              |
|         | A7-1      | アドレスバス              | IN  | 7bitアドレスバスです。                                    | 7   | 入力           | 入力           |
|         |           |                     |     | 16bitデータバスのためA0はありません。                           |     | *3)          | *3)          |
|         | ALE       | アドレスラッチ             | IN  | マルチプレクスバス設定時、A7端子をALE信号                          |     | 入力           | 入力           |
|         |           | イネーブル               |     | として使用します。                                        |     |              |              |
|         | CS_N      | チップセレクト             | IN  | "L"レベルで本コントローラーが選択されます。                          | 1   | 入力           | 入力           |
|         | 55.11     |                     |     |                                                  | 4   | *4)          | *4)          |
|         | RD_N      | リードストロー             | IN  |                                                  | 1   | 入力           | 入力           |
|         | WDO N     | ブ                   | INI | データを読み出します。                                      | 4   | \ <u>+</u>   | \            |
|         | WR0_N     | D7-0バイトライ           | IN  | 立ち上がりエッジでD7-D0を本コントローラー                          | ı   | 入力           | 入力           |
|         | WR1_N     | トストローブ<br>D15-8バイトラ | IN  | のレジスタに書き込みます。                                    | 1   | *4)          | *4)          |
|         | VVIX I_IN |                     | IIN | 立ち上がりエッジでD15-D8を本コントロー                           | ı   | 入力<br>*4)    | 入力<br>*4)    |
|         | MPBUS     | イトストローブ<br>バスモード選択  | IN  | ラーのレジスタに書き込みます。<br>"L"レベルでセパレートバスです。             | 1   | 入力           | 入力           |
|         | IVIPBUS   | ハスモート選択             | IIN | L レヘルとセハレートハスとり。<br> "H"レベルでマルチプレクスバスです。         | 1   | パル<br>*1)    | *1)          |
|         |           |                     |     | F レヘルとマルテフレクスハスとす。<br> "H"/"L"どちらかのレベルに固定してください。 |     | 1)           | 1)           |
| SPLITバス | SD7-0     | スプリットデー             | 1/0 |                                                  | 8   | 入力           | 入力           |
| インタフ    | 307-0     | タバス                 | 1/0 | ハフリッドハスが選択されている場合はスプ<br> リットバスのデータバスとして機能します。    | O   | ハハ<br>(Hi-Z) | ハハ<br>(Hi-Z) |
| エース     |           | 3/12                |     | サッドハスのナータハスとして機能しよす。<br>                         |     | (111-2)      | (111-2)      |
|         | DREQ0_N   | DMAリクエスト            | OUT | D0FIFOポート、D1FIFOポートのDMA転送リク                      | 2   | Н            | Н            |
|         | DREQ1_N   |                     |     | エストを通知します。                                       |     |              |              |
| ェース     |           | DMAアクノリッ            | IN  | D0FIFOポート、D1FIFOポートのDMAアクノリ                      | 2   | 入力           | 入力           |
|         | _         | ジ                   |     | ッジ信号を入力してください。                                   |     | , (, )       | , (, )       |
|         | DEND0_N   | DMA転送終了             | I/O |                                                  | 2   | 入力           | 入力           |
|         | DEND1_N   | , == 3              |     | 号として他の周辺チップまたはCPUから転送                            |     | (Hi-Z)       | (Hi-Z)       |
|         |           |                     |     | 終了信号を受け付けます。                                     |     | , ,          | , ,          |
|         |           |                     |     | <fifoポートアクセス読み出し方向時>出力信</fifoポートアクセス読み出し方向時>     |     |              |              |
|         |           |                     |     | 号として転送の最終データを示します。                               |     |              |              |
| 割り込み    | INT_N     | 割り込み                | OUT | "L"アクティブでUSB通信に関する各種割り込                          | 1   | Н            | Н            |
| /SOF出力  |           |                     |     | みを通知します。アクティブはデフォルト"L"                           |     |              |              |
|         |           |                     |     | アクティブですが、ソフトウェアでINTAビット                          |     |              |              |
|         |           |                     |     | の設定値を変更することにより、"H"アクティブ                          |     |              |              |
|         |           |                     |     | に設定可能です                                          |     |              |              |
|         | SOF_N     | SOFパルス出力            | OUT |                                                  | 1   | Н            | Н            |
|         | 2/12/     | 7×+= m ) +          |     | 力します。                                            | _   |              |              |
| クロック    | XIN       | 発振用入力               | IN  | XIN、XOUTの間に水晶振動子を接続してくださ                         | 1   |              |              |
|         | XOUT      | 上<br>発振用出力          | OUT | い。外部クロック入力する場合は、XINに外部<br>クロック信号を接続し、XOUTは開放してくだ | 1   |              |              |
|         | λου:      |                     |     | プロック信号を接続し、XOUTは開放してくた<br>さい。                    | •   |              |              |
| システム    | RST_N     | リセット信号              | IN  | 本コントローラーを"L"レベルで初期化します。                          | 1   | 入力(L)        | 入力(H)        |
| 制御      |           |                     |     |                                                  |     |              | ` ′          |
| USBバスイ  |           | USB D+データ           | I/O | USBバスのD+端子に接続してください。                             | 2   | 入力           | 入力           |
| ンタフェー   | DP1       |                     |     |                                                  |     | (Hi-Z)       | (Hi-Z)       |
| ス       | DM0       | USB D-データ           | I/O | USBバスのD-端子に接続してください。                             | 2   | 入力           | 入力           |
|         | DM1       |                     |     |                                                  |     | (Hi-Z)       | (Hi-Z)       |



| 区分       | 端子名     | 名称       | I/O  | 機能                                           | 端子数              | 端子のキ   | 犬態 *5) |
|----------|---------|----------|------|----------------------------------------------|------------------|--------|--------|
|          |         |          |      |                                              |                  | リセッ    | リセッ    |
|          |         |          |      |                                              |                  | ト中     | 卜直後    |
| VBUS     | VBUS    | VBUS入力   | IN   | <host controller機能選択時=""></host>             | 1                | 入力     | 入力     |
| 監視入力     |         |          |      | オープンまたは、USBバスのVbusに直接接続し                     |                  | (Hi-Z) | (Hi-Z) |
|          |         |          |      | てください。                                       |                  |        |        |
|          |         |          |      | 接続されるデバイスへのVbus供給はできま                        |                  |        |        |
|          |         |          |      | せん。                                          |                  |        |        |
|          |         |          |      | <peripheral controller機能選択時=""></peripheral> |                  |        |        |
|          |         |          |      | USBバスのVbusに直接接続してください。                       |                  |        |        |
|          |         |          |      | Vbusの接続/切断を検出することができます。                      |                  |        |        |
|          |         |          |      | Vbusに接続しない場合は5Vに接続してくださ                      |                  |        |        |
| 甘淮北七     | REFRIN  | リファレンス入  | IN   | い。                                           | 1                |        |        |
| 基準抵抗     | KEFKIN  |          |      | 5.6k ±1%抵抗を介してアナログGND端子に<br>接続してください。        | I                |        |        |
|          | ID0     | カ        |      | 接続してください<br>USB Mini-ABレセプタクルのID端子に接続して      | 1                | λ +-   | 入力     |
| OTG関連    | IDO     | ID入力     | IIN  | USB MIMI-ABレセフタクルのID蛹子に接続して<br>ください。         | 1                | 入力     | 人刀     |
| USB Host | VBOUT0  | 外部電源オン   | OLIT |                                              | 2                | 1      | 1      |
| 時電源管理    |         | アロ电泳カン   | 001  | が記載が回路へのの1701日が日に使用します。 がお電源回路に接続してください。     | 2                | L      | _      |
| 関連       |         |          |      | DP0,DM0をOTGとして使用する場合は、                       |                  |        |        |
| 12,12    |         |          |      | VBOUT1端子は使用できません。                            |                  |        |        |
|          | OVCUROA | PORT0用オー | IN   |                                              | 2                | 入力     | 入力     |
|          | OVCUR0B | バーカレント入  |      | 力に使用します。PORTO用の外部電源回路に接                      |                  | /(/)   | /(/)   |
|          |         | カ        |      | 続してください。                                     |                  |        |        |
|          |         | , ,      |      | 外部電源回路からのオーバーカレント検出入                         |                  |        |        |
|          |         |          |      | 力が1本の場合はOVCUR0Aに接続し、                         |                  |        |        |
|          |         |          |      | OVCUROBをHighまたはLowに固定してくださ                   |                  |        |        |
|          |         |          |      | ι I <sub>0</sub>                             |                  |        |        |
|          | OVCUR1  | PORT1用オー | IN   | 外部電源回路からのオーバーカレント検出入                         | 1                | 入力     | 入力     |
|          |         | バーカレント入  |      | 力に使用します。PORT1用の外部電源回路に接                      |                  |        |        |
|          |         | カ        |      | 続してください。                                     |                  |        |        |
|          |         |          |      | DP0,DM0をOTGとして使用する場合は、                       |                  |        |        |
|          |         |          |      | OVCUR1端子は使用できません                             |                  |        |        |
|          | EXTLP0  |          | OUT  |                                              | 1                | L      | L      |
|          |         | 制御       |      | に低消費電力モードオン/オフ切り替えに使用                        |                  |        |        |
|          |         |          |      | します。PORT0用の外部電源回路に接続してく                      |                  |        |        |
|          |         |          |      | ださい。                                         |                  |        |        |
| 電源/GND   |         | アナログ電源   | -    | 3.3Vに接続してください。                               | 1                |        |        |
|          | AGND    | アナログGND  | -    |                                              | 1                |        |        |
|          | VCC     | 電源       | -    |                                              | 3                |        |        |
|          | GND     | GND      | -    |                                              | 9 (FP)<br>10(BG) |        |        |
|          | VIF     | IO電源     | -    |                                              | 4                |        |        |
|          | VDD     | コア電源     |      |                                              | 2                |        |        |
|          |         |          |      | を出力。コア電源の安定化の為、GNDとの間に                       |                  |        |        |
|          |         |          |      | コンデンサ(4.7uF,0.1uF)を接続してください。                 |                  |        |        |
|          |         |          |      | 尚、外部電源の接続は不要です。                              |                  |        |        |
|          | l .     | 1        |      |                                              |                  |        |        |

- \*1) MPBUS 端子の入力レベルは、H/W リセット直後に確定している必要があります。また、動作中には切り替えを行わないでください。
- \*2) CS\_N="L" かつ RD\_N="L"の時出力、それ以外は入力となります。
- \*3) MPBUS="H"の時には、Hi-Z 入力(オープン)可能です。
- \*4)  $CS_N$ 、 $WR0_N$  および  $WR1_N$  信号は、リセット中およびリセット解除直後は以下(a)もしくは(b)の状態を保ってください。
  - (a)  $CS_N="H"$  (b)  $WR0_N="H"$ 、かつ、 $WR1_N="H"$
- \*5) "端子の状態"欄の説明

(a) 入力 : 入力ポート、Hi-Z状態(オープン)不可(b) 入力(Hi-Z) : 入力ポート、Hi-Z状態(オープン)可能

(c) H、L、H/L : 出力ポートの状態を示します

## 表 1.2 R8A66597未使用端子の処理例

| 区分              | 端子名                         | 処理内容                                                               |
|-----------------|-----------------------------|--------------------------------------------------------------------|
| SPLIT バスインタフェース | SD7-0                       | オープン                                                               |
|                 | DREQ0_N, DREQ1_N            | オープン                                                               |
| DMAバスインタフェース    | DACK0_N, DACK1_N            | VIFの"H"レベルに固定*1)                                                   |
|                 | DEND0_N, DEND1_N            | オープン*2)                                                            |
| SOF出力           | SOF_N                       | オープン                                                               |
| VBUS監視入力        | VBUS                        | Host機能選択時:<br>オープン<br>ペリフェラル機能選択時:<br>USBコネクタのVBUS信号に<br>接続してください。 |
|                 | ID0                         | "L"固定                                                              |
| USB Host        | VBOUT0, VBOUT1              | オープン                                                               |
| 時電源管理関連         | OVCUR0A, OVCUR0B,<br>OVCUR1 | "L"固定                                                              |
|                 | EXTLP0                      | オープン                                                               |

<sup>\*1)</sup> DACKn\_N端子を使用しない場合、DMAnCFGレジスタのDFROMビットを"000"に かつDACKAビットを"0"に設定してください(n=0,1)



<sup>\*2)</sup> DENDn\_N端子を使用しない場合、DMAnCFGレジスタのDENDEビットを"0"に設 定してください (n=0,1)

## 1.5 端子機能構成

図 1.3に本コントローラーの端子機能構成図を示します。



図 1.3 端子機能構成図

### 1.6 機能概要

#### 1.6.1 コントローラー機能選択

本コントローラーはレジスタ設定によりホスト機能とペリフェラル機能を切り替えることが可能です。 またホスト、ペリフェラルのどちらの機能を選択した場合も、ハードウェアが、USB転送Speedを自動認識します。

#### 1.6.2 パスインタフェース

本コントローラーは、下記に示すバスインタフェースに対応しています。

#### 1.6.2.1 外部パスインタフェース

本コントローラーは、CPUバスインタフェースを使用して、制御用レジスタにアクセスします。

CPUとのバスインタフェースは、下記の2種類のアクセス方法に対応しています。チップセレクト端子(CS\_N)及び3本のストローブ端子(RD\_N、WR0\_N、WR1\_N)でアクセスしてください。

(1) 16bitセパレートバス

7本のアドレスバス(A7-1)、及び16本のデータバス(D15-0)を使用します。

(2) 16bitマルチプレクスバス

ALE端子(ALE)、及び16本のデータバス(D15-0)を使用します。データバスは、アドレスとデータを時分割で使用します。

セパレートバス、及びマルチプレクスバスは、H/Wリセット解除時のMPBUS端子信号レベルで選択します。

#### 1.6.2.2 FIFO パッファメモリアクセス方法

本コントローラーは、USBデータ転送用のFIFOバッファメモリへのアクセス方法として下記の2種類に対応しています。CPU (DMAC) からFIFOポートアクセス (読み出し / 書き込み) を行うことにより、FIFOバッファメモリからの読み出し (への書き込み) を行うことが出来ます。

(1) CPUアクセス

アドレス信号、及びコントロール信号を使用して、データをFIFOバッファメモリに書き込み、もしくはFIFOバッファメモリから読み出してください。

(2) DMAアクセス

CPU内蔵DMAC、もしくは専用DMACから、データを本コントローラーのFIFOバッファメモリに書き込み、もしくはFIFOバッファメモリから読み出してください。

USBデータ通信はリトルエンディアンで行われます。FIFOポートアクセスにはバイトエンディアンスワップ機能があり、16bitアクセスの場合には、レジスタ設定によるエンディアン切り替えができます。

#### 1.6.2.3 DMAC からの FIFO パッファメモリアクセス方法

FIFOバッファメモリへのアクセスをDMAアクセスで行う場合は、さらに下記2種類のアクセス方法を選択できます。

- (1) CPUとの共有バスを使用する方法
- (2) 専用バス(スプリットバス)を使用する方法

#### 1.6.3 USBイベント

本コントローラーは、USB動作上のイベントを割り込みによりユーザーシステムに通知します。また、DMAインタフェースを選択したパイプのバッファメモリへのアクセスが可能なことを、DREQ信号をアサートすることにより通知します。

ソフトウエアの設定により種類別、要因別に割り込み通知の可否を選択することができます。



### 1.6.4 USBデータ転送

本コントローラーは、USB通信のコントロール転送、バルク転送、インタラプト転送、及びアイソクロナス転送の全種 類のデータ転送が可能です。各転送タイプに対するパイプのリソースは下記のとおりです。

- (1) コントロール転送専用パイプ:1本
- (2) インタラプト転送専用パイプ:4本
- (3) バルク転送専用パイプ:3本
- (4) バルク転送もしくはアイソクロナス転送選択パイプ; 2本

各パイプは、ユーザーシステムに合わせて転送タイプ、エンドポイントアドレス、マックスパケットサイズ等のUSB 転送に必要な設定を行ってください。

また、本コントローラーは、8.5Kバイトのバッファメモリを内蔵しています。バルク転送専用パイプ、及びバルク転送 もしくはアイソクロナス転送選択パイプに対しては、ユーザーシステムによるバッファメモリの割り当てやバッファ動作 モードなどの設定を行ってください。バッファ動作モード設定は、ダブルバッファ構成やデータパケットの連続転送機能 により、少ない割り込み回数で、高速なデータ転送が可能です。バルク転送及びアイソクロナス転送を行うパイプでの効 率のよいデータ転送のために、トランザクションカウンタ機能によるトランスファー終了機能を備えています。

ユーザーシステムの制御用CPU、及びDMAコントローラーからのバッファメモリへのアクセスは、3本のFIFOポート レジスタを通して行います。

#### 1.6.5 DMAC(ダイレクトメモリアクセスコントローラー)からのアクセス用インタフェース

DMAインタフェースは、DxFIFOポートを使用した、ユーザーシステムと本コントローラーの間のデータ転送であり、 CPUが介在しないデータ転送です。本コントローラーは、2チャンネルのDMAインタフェースを備えており、下記のよ うな機能を有しています。

- (1) 転送終了信号(DEND信号)によるトランスファー終了通知機能
- (2) Zero-Lengthパケット受信時のFIFOバッファ自動クリア機能

本コントローラーは、下記の2種類のDMA転送に対応したインタフェースを備えています。

- (1) サイクルスチール転送
  - 1データ転送(1バイト/1ワード)ごとにDREQ端子のアサート、ネゲートが繰り返される転送。
- (2) バースト転送

当該FIFOポートに、割り当てられたパイプのバッファメモリ領域分、もしくはDEND信号による転送終了まで DREQ端子をアサートしたままネゲートしない転送。

また、DMAインタフェースのハンドシェーク信号(端子)として「CS\_N、RD\_N、WR\_N」、もしくはDACK\_Nを選択 可能です。スプリットバスを使用したDMA転送では、DMAxCFGレジスタのOBUSビット操作でデータセットアップタ イミングを変更することにより、高速なDMA転送が可能です。

## 1.6.6 SOFパルス出力機能

SOFパケットの送受信タイミングを通知するSOFパルス出力機能を備えています。ホストコントローラー機能選択 時には、SOFパケットの送信時にSOF\_N端子にパルスを出力します。ペリフェラルコントローラー機能選択時には SOFパケットの受信時にSOF\_N端子にパルスを出力します。SOFパケット破損時もSOF補間タイマにより、一定間 隔でパルスを出力します。



#### 1.6.7 外付け素子の取り込み

本コントローラーは、下記の外付け素子を内蔵しています。また、VBUS端子は5V耐圧のため、ユーザーシステムは、 VBUS信号を本コントローラーに直接入力することができます。

(1) D+、D-ラインの制御に必要な抵抗

USB通信時に必要となる以下のD+、D-の抵抗を内蔵しています。

- ・D+プルアップ抵抗(Peripheral Controller機能選択時)
- ・D+、D-のプルダウン抵抗(Host Controller機能選択時)
- ・D+、D-の終端抵抗(Hi-Speed動作時)
- ・D+、D-の出力抵抗 (Full/Low -Speed動作時)
- (2) 48MHz、及び480MHzのPLL 3種類の外部クロック(12MHz/24MHz/48MHz)から一つを選択し、動作させることができます。
- (3) 3.3V->1.5Vレギュレータ コア電源用の1.5Vを本コントローラー内部で生成します。インターフェイス電源を3.3Vで使用するシステムでは、 本コントローラーを単一電源で動作させることが可能です。



# 2レジスタ

## <u>レジスタ表の見方</u>

ビット番号 各レジスタは、16ビットの内部バスに接続されています。

奇数番地はb15~b8に、偶数番地はb7~b0になります。

リセット後の状態 リセット動作直後のレジスタ初期状態を示します。

H/WリセットはRST\_N端子から外部リセット信号を入力した場合の初期状態です。 USBリセットは本コントローラーがUSBバスリセットを検出した場合の初期状態です。

なお、リセット動作中に特筆すべき事項は注意事項で記載しています。

"-"は本コントローラーによる操作がなく、ユーザー設定が保持されている状態です。

"?"は値が不定な状態であることを示します。

S/W Access条件 ソフトウェアがレジスタをアクセスする場合の条件です。

H/W Access条件 本コントローラーがリセット動作以外でレジスタをアクセスする場合の条件です。

R · · · · Read Only
W · · · · Write Only
R/W · · · Read / Write
R(0) · · "0"Read Only
W(1) · · "1"Write Only

Remarks 備考、および、詳細説明項目番号です。

H時...Host Controller機能選択時 P時...Peripheral Controller機能選択時

ビットシンボル及びビット名称です。

Function 機能説明です。特に断りのない場合は、読み出し時の値は

ソフトウェアまたはハードウェアが書き込んだ値です。

#### <表記例>

Name

網掛け部分には何も配置されていません。"0"に固定してください。

| Bit Number → | 15,/     | 14   | 13   | 12   | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 |
|--------------|----------|------|------|------|----|----|---|---|---|---|---|---|---|---|---|---|
| Bit Symbol → | <b>V</b> | Abit | Bbit | Cbit |    |    |   |   |   |   |   |   |   |   |   |   |
| H/Wリセット →    | ?        | 0    | 0    | 0    |    |    |   |   |   |   |   |   |   |   |   |   |
| USBリセット →    | ?        | 0    | -    | -    |    |    |   |   |   |   |   |   |   |   |   |   |

| bit | Name            | Function                                 | S/W           | H/W | Remarks             |
|-----|-----------------|------------------------------------------|---------------|-----|---------------------|
| 15  | 何も配置されていません     | ん。"0"に固定してください。                          |               |     |                     |
| 14  | A bit<br>AAA 許可 | 0:動作禁止<br>1:動作許可                         | R/W           | R   | P時<br>書<br>込み<br>禁止 |
| 13  | B bit<br>BBB 動作 | 0:Low 出力<br>1:High 出力                    | R             | W   |                     |
| 12  | C bit<br>CCC 制御 | 0: • • • • • • • • • • • • • • • • • • • | R(0)/<br>W(1) | R   |                     |
|     |                 |                                          |               |     |                     |

<<Remarks>>

## 2.1 レジスタ一覧

表 2.1に本コントローラーのレジスター覧表を示します。

表 2.1 レジスター覧表

| Address  | Symbol    | Name                          | Index |
|----------|-----------|-------------------------------|-------|
| 00       | SYSCFG0   | システムコンフィグレーションコントロールレジスタ      |       |
| 02       | SYSCFG1   | Port1システムコンフィグレーションコントロールレジスタ |       |
| 04       | SYSSTS0   | Port0システムコンフィグレーションステータスレジスタ  |       |
| 06       | SYSSTS1   | Port1システムコンフィグレーションステータスレジスタ  |       |
| 08       | DVSTCTR0  | Port0デバイスコントロールレジスタ           |       |
| 0A       | DVSTCTR 1 | Port1デバイスコントロールレジスタ           |       |
| 0C       | TESTMODE  | テストモードレジスタ                    |       |
| 0E       | PINCFG    | データピンコンフィグレーションレジスタ           |       |
| 10       | DMA0CFG   | DMA0ピンコンフィグレーションレジスタ          |       |
| 12       | DMA1CFG   | DMA1ピンコンフィグレーションレジスタ          |       |
| 14       | CFIFO     | CFIFOポートレジスタ                  |       |
| 16       | 01110     |                               |       |
| 18       | D0FIFO    | D0FIFOポートレジスタ                 |       |
| 1A       |           |                               |       |
| 1C       | D1FIFO    | D1FIFOポートレジスタ                 |       |
| 1E       |           |                               |       |
| 20       | CFIFOSEL  | CFIFOポート選択レジスタ                |       |
| 22       | CFIFOCTR  | CFIFOポートコントロールレジスタ            |       |
| 24       |           |                               |       |
| 26       |           |                               |       |
| 28       | D0FIFOSEL | D0FIFOポート選択レジスタ               |       |
| 2A       | D0FIFOCTR | D0FIFOポートコントロールレジスタ           |       |
| 2C       | D1FIFOSEL | D1FIFOポート選択レジスタ               |       |
| 2E       | D1FIFOCTR | D1FIFOポートコントロールレジスタ           |       |
| 30       | INTENB0   | 割り込み許可レジスタ0                   |       |
| 32       | INTENB1   | 割り込み許可レジスタ1                   |       |
| 34       | INTENB2   | 割り込み許可レジスタ2                   |       |
| 36       | BRDYENB   | BRDY割り込み許可レジスタ                |       |
| 38       | NRDYENB   | NRDY割り込み許可レジスタ                |       |
| 3A       | BEMPENB   | BEMP割り込み許可レジスタ                |       |
| 3C       | SOFCFG    | SOF出力コンフィグレーションレジスタ           |       |
| 3E       |           |                               |       |
| 40       | INTSTS0   | 割り込みステータスレジスタ0                |       |
| 42       | INTSTS1   | 割り込みステータスレジスタ1                |       |
| 44       | INTSTS2   | 割り込みステータスレジスタ2                |       |
| 46       | BRDYSTS   | BRDY割り込みステータスレジスタ             |       |
| 48       | NRDYSTS   | NRDY割り込みステータスレジスタ             |       |
| 4A       | BEMPSTS   | BEMP割り込みステータスレジスタ             |       |
| 4C       | FRMNUM    | フレームナンバレジスタ                   |       |
| 4E       | UFRMNUM   | マイクロフレームナンバレジスタ               |       |
| 50<br>54 | USBADDR   | USBアドレスレジスタ                   |       |
| 54<br>56 | USBREQ    | USBリクエストタイプレジスタ               |       |
| 58       | USBVAL    | USBリクエストバリューレジスタ              |       |
|          | USBINDX   | USBリクエストインデックスレジスタ            |       |
| 5A       | USBLENG   | USBリクエストレングスレジスタ              |       |
| 5C       | DCPCFG    | DCPコンフィグレーションレジスタ             |       |
| 5E       | DCPMAXP   | DCPマックスパケットサイズレジスタ            |       |
| 60       | DCPCTR    | DCPコントロールレジスタ                 |       |
| 62<br>64 | DIDECE    | パイプウィンドウ選切しぶった                |       |
| 04       | PIPESEL   | パイプウィンドウ選択レジスタ                |       |



| Address    | Symbol               | Name                                                | Index |
|------------|----------------------|-----------------------------------------------------|-------|
| 66         | <b>C</b> yllinger    | 1,0,1,0                                             | maex  |
| 68         | PIPECFG              | パイプコンフィグレーションレジスタ                                   |       |
| 6A         | PIPEBUF              | パイプバッファ指定レジスタ                                       |       |
| 6C         | PIPEMAXP             | パイプマックスパケットサイズレジスタ                                  |       |
| 6E         | PIPEPERI             | パイプ周期制御レジスタ                                         |       |
| 70         | PIPE1CTR             | PIPE1コントロールレジスタ                                     |       |
| 72         | PIPE2CTR             | PIPE2コントロールレジスタ                                     |       |
| 74         | PIPE3CTR             | PIPE3コントロールレジスタ                                     |       |
| 76         | PIPE4CTR             | PIPE4コントロールレジスタ                                     |       |
| 78         | PIPE5CTR             | PIPE5コントロールレジスタ                                     |       |
| 7A         | PIPE6CTR             | PIPE6コントロールレジスタ                                     |       |
| 7C         | PIPE7CTR             | PIPE7コントロールレジスタ                                     |       |
| 7E         | PIPE8CTR             | PIPE8コントロールレジスタ                                     |       |
| 80         | PIPE9CTR             | PIPE9コントロールレジスタ                                     |       |
| 82-8E      |                      |                                                     |       |
| 90         | PIPE1TRE             | PIPE1トランザクションカウンタイネーブルレジスタ                          |       |
| 92         | PIPE1TRN             | PIPE1トランザクションカウンタレジスタ                               |       |
| 94         | PIPE2TRE             | PIPE2トランザクションカウンタイネーブルレジスタ                          |       |
| 96         | PIPE2TRN             | PIPE2トランザクションカウンタレジスタ                               |       |
| 98         | PIPE3TRE             | PIPE3トランザクションカウンタイネーブルレジスタ                          |       |
| 9A<br>9C   | PIPE3TRN<br>PIPE4TRE | PIPE3トランザクションカウンタレジスタ                               |       |
| 9C<br>9E   | PIPE4TRE<br>PIPE4TRN | PIPE4トランザクションカウンタイネーブルレジスタ                          |       |
| A0         | PIPE5TRE             | PIPE4トランザクションカウンタレジスタ                               |       |
| AU<br>A2   | PIPESTRE<br>PIPESTRN | PIPE5トランザクションカウンタイネーブルレジスタ<br>PIPE5トランザクションカウンタレジスタ |       |
| A4-CE      | PIPESTRIN            | PIPE5トラフザクションカワフタレシスタ                               |       |
| D0         | DEVADD0              | デバイスアドレス0コンフィグレーションレジスタ                             |       |
| D2         | DEVADD1              | デバイスアドレス1コンフィグレーションレジスタ                             |       |
| D4         | DEVADD2              | デバイスアドレス2コンフィグレーションレジスタ                             |       |
| D6         | DEVADD3              | デバイスアドレス3コンフィグレーションレジスタ                             |       |
| D8         | DEVADD4              | デバイスアドレス4コンフィグレーションレジスタ                             |       |
| DA         | DEVADD5              | デバイスアドレス5コンフィグレーションレジスタ                             |       |
| DC         | DEVADD6              | デバイスアドレス6コンフィグレーションレジスタ                             |       |
| DE         | DEVADD7              | デバイスアドレス7コンフィグレーションレジスタ                             |       |
| E0         | DEVADD8              | デバイスアドレス8コンフィグレーションレジスタ                             |       |
| E2         | DEVADD9              | デバイスアドレス9コンフィグレーションレジスタ                             |       |
| E4         | DEVADDA              | デバイスアドレスAコンフィグレーションレジスタ                             |       |
| <b>E</b> 6 |                      |                                                     |       |

網掛けの番地には何も配置されていません。アクセスを行わないでください。



# 2.2 ビットシンボル一覧

表 2.2に本コントローラーのビットシンボル一覧表を示します。

表 2.2 ビットシンボル一覧表

|      |                        |        |        |           | 쵊        | 番地               |          |         |          |                |            |                | 偶数       | 番地         |           |          |          |
|------|------------------------|--------|--------|-----------|----------|------------------|----------|---------|----------|----------------|------------|----------------|----------|------------|-----------|----------|----------|
| addr | レジスタ名                  | 15     | 14     | 13        | 12       | 11               | 10       | 9       | 8        | 7              | 6          | 5              | 4        | 3          | 2         | 1        | 0        |
| 00   | SYSCFG0                | XT     |        | XCKE      | 12       | PLLC             | SCKE     | - U     | - U      | HSE            | DCFM       | DRPD           | DPRPU    |            |           |          | USBE     |
|      | SYSCFG1                | Α.     | 7 (    | TORE      | CNTFLG   | 1 220            | COILE    | PCSDIS  | LPSMF    | HSE            | BOI III    | DRPD           | Di iti o |            |           |          | OUDE     |
| -    | SYSSTS0                | OVC    | MON    |           | 51111 20 |                  |          | . 662.6 | 2. 02    |                |            | SOFEA          |          |            | IDMON     | LN       | ST       |
|      | SYSSTS1                | OVC    |        |           |          |                  |          |         |          |                |            | SOFEA          |          |            | 12.11.011 | LN       |          |
|      | DVSTCTR0               |        |        |           |          | HNPBTOA          | FXTI P0  | VBOUT   | WKUP     | RWUPE          | USBRST     | RESUME         | UACT     |            |           | RHST     | •        |
|      | DVSTCTR1               |        |        |           |          | THE BYOK         | 271121 0 | VBOUT   |          | RWUPE          |            | RESUME         |          |            |           | RHST     |          |
|      | TESTMODE               |        |        |           |          |                  |          | 12001   |          | TOTAL E        | COBITOT    | TECOME         | 07101    |            | UT        |          |          |
|      | PINCFG                 | LDRV   |        |           |          |                  |          |         |          |                |            |                |          |            |           |          | INTA     |
|      | DMA0CFG                | LDITT  | DREQA  | BURST     |          |                  | DACKA    |         | DFORM    |                | DENDA      | PKTM           | DENDE    |            | OBUS      |          | 114174   |
|      | DMA1CFG                |        |        | BURST     |          |                  | DACKA    |         | DFORM    |                | DENDA      | PKTM           | DENDE    |            | OBUS      |          |          |
|      | CFIFO                  |        | DILLAK | DOIGO     |          |                  | DAONA    |         | CFP      | OPT            | DENDA      | I IXTIVI       | DENDE    |            | OBOO      |          |          |
| 16   | 0. 1. 0                |        |        |           |          |                  |          |         | 011      | OKI            |            |                |          |            |           |          |          |
|      | D0FIFO                 |        |        |           |          |                  |          |         | D0FF     | OPT            |            |                |          |            |           |          |          |
| 1A   | B01 11 0               |        |        |           |          |                  |          |         | DOLL     | OICI           |            |                |          |            |           |          |          |
|      | D1FIFO                 |        |        |           |          |                  |          |         | D1FIF    | PORT           |            |                |          |            |           |          |          |
| 1E   | 2 11 11 O              |        |        |           |          |                  |          |         | וווע     | JICI           |            |                |          |            |           |          |          |
|      | CFIFOSEL               | RCNT   | REW    |           |          |                  | MBW      |         | BIGEND   |                |            | ISEL           |          |            | CURI      | PIPF     |          |
|      | CFIFOCTR               | BVAL   | BCLR   | FRDY      |          |                  | INIDAA   |         | PIGEIND  |                | DT         | LN             |          | l          | CURI      | 1 II L   |          |
| 24   | CI II OCTK             | DVAL   | BOLK   | FRUI      |          |                  |          |         |          |                | ا <i>ا</i> | LIN            |          |            |           |          |          |
| 26   |                        |        |        |           |          |                  |          |         |          |                |            |                |          |            |           |          |          |
|      | D0FIFOSEL              | RCNT   | REW    | DCLRM     | DREQE    |                  | MBW      |         | BIGEND   |                |            |                |          |            | CURI      | DIDE     |          |
|      | D0FIFOCTR              | BVAL   | BCLR   | FRDY      | DREQE    |                  | IVIDVV   |         | DIGEND   |                | DT         | LN             |          |            | CURI      | FIFE     |          |
|      | D1FIFOSEL              | RCNT   | REW    |           | DREQE    |                  | MBW      |         | BIGEND   |                | l l        | LIN            |          |            | CUR       | DIDE     |          |
|      | D1FIFOSEL<br>D1FIFOCTR | BVAL   | BCLR   | FRDY      | DREQE    |                  | IVIDVV   |         | DIGEND   |                | DT         | I NI           |          |            | CURI      | PIPE     |          |
| _    | INTENB0                | VBSE   | RSME   | SOFE      | DVSE     | CTRE             | BEMPE    | NRDYE   | DDDVE    |                | וט         | LIN            |          |            |           |          |          |
|      | INTENB1                |        | BCHGE  | SUFE      |          |                  | DEIVIPE  | NKUTE   | DKUTE    |                | EOFERRE    | CICNE          | SACKE    |            |           |          |          |
|      | INTENB2                |        |        |           |          | ATTCHE           |          |         |          |                |            |                | SAUKE    |            |           |          |          |
|      | BRDYENB                | OVRCRE | BCHGE  |           | DICHE    | ATTCHE           |          |         |          |                | EOFERRE    |                |          |            |           |          |          |
|      | NRDYENB                |        |        |           |          |                  |          |         |          |                |            | PIPER          |          |            |           |          |          |
|      | BEMPENB                |        |        |           |          |                  |          |         |          |                |            | PIPEN<br>PIPEB |          |            |           |          |          |
|      | SOFCFG                 |        |        |           |          |                  |          |         |          |                | BRDYM      |                | EDGESTS  | 00         | FM        |          |          |
| 3E   | SOFCFG                 |        |        |           |          |                  |          |         | TRNENSEL |                | DKDIM      | INIL           | EDGESTS  | 30         | F IVI     |          |          |
|      | INTSTS0                | VBINT  | RESM   | SOFR      | DVST     | CTRT             | BEMP     | NRDY    | BRDY     | VBSTS          |            | DVSQ           |          | VALID      |           | CTSQ     |          |
|      | INTSTS0                | OVRCR  | BCHG   | SUFK      | DTCH     | ATTCH            | DEIVIF   | INKUT   | DKUT     | VDS13          | EOFERR     |                | SACK     | VALID      |           | CISQ     |          |
|      | INTSTS1                | OVRCR  | BCHG   |           | DTCH     | ATTCH            |          |         |          |                | EOFERR     | SIGN           | SACK     |            |           |          |          |
|      | BRDYSTS                | OVNCK  | BCHG   |           | DIGII    | ATTOIT           |          |         |          |                | LOFERN     | PIPEI          | DDDV     |            |           |          |          |
|      | NRDYSTS                |        |        |           |          |                  |          |         |          |                |            | PIPEI          |          |            |           |          |          |
|      | BEMPSTS                |        |        |           |          |                  |          |         |          |                |            | PIPE           |          |            |           |          |          |
|      | FRMNUM                 | OVRN   | CRCE   |           |          |                  |          | 1       |          |                |            | FRNM           |          |            |           |          |          |
|      | UFRMNUM                | OVKIN  | UNUE   |           |          |                  |          |         |          |                |            | EIZINIVI       |          |            |           | UFRNM    |          |
|      | USBADDR                |        |        |           |          |                  |          |         |          |                |            |                |          | JSBADDF    | <u> </u>  | OFKINIVI |          |
| 52   | COPUDDI                |        |        |           |          |                  |          |         |          |                |            |                |          |            | \         |          |          |
|      | USBREQ                 |        |        |           | hDa.     | quest            |          |         |          |                |            |                | bmRequ   | ioetTyroo  |           |          |          |
|      | USBVAL                 |        |        |           | DRec     | <sub>fueor</sub> |          |         | wVa      | aluo           |            |                | bilikequ | iest i ype |           |          |          |
|      | USBINDX                |        |        |           |          |                  |          |         |          |                |            |                |          |            |           |          |          |
|      | USBLENG                |        |        |           |          |                  |          |         | wln      |                |            |                |          |            |           |          |          |
|      | DCPCFG                 |        |        |           |          |                  |          |         | WLe      | ngth<br>SHTNAK |            |                | DIR      |            |           |          |          |
|      | DCPCFG                 |        | רי     | (CE)      |          |                  |          |         | CINTIND  | SHINAK         |            |                | אוע      | MVDC       |           |          |          |
|      |                        | DOTO   |        | SEL COOLD | CCCTC    |                  |          |         | 2001     | COCET          | COMON      | DDLIOV         | DINIOE   | MXPS       | CCDI      | , r      | <u> </u> |
|      | DCPCTR                 | BSTS   | SUKEQ  | CSCLR     | CSSIS    | SUREQCLR         |          |         | SQULK    | SUSET          | SQMON      | LR021          | PINGE    |            | CCPL      | PI       | υ        |
| 62   | DIDECEI                |        |        |           |          |                  |          |         |          |                |            |                |          |            | 5:5-      | CEL      |          |
|      | PIPESEL                |        |        |           |          |                  |          |         |          |                |            |                |          |            | PIPE      | SEL      |          |
| 66   | DIDECEO                |        | DE.    |           |          |                  | DEST     | DD: 5   | ONITY    | OLUTAL S       |            |                | D:0      |            |           |          |          |
|      | PIPECFG                | TY     | PΕ     |           |          |                  | BFRE     | DBLB    | CNTMD    | SHTNAK         |            |                | DIR      |            | EPN       | IUM      |          |
| ьΑ   | PIPEBUF                |        |        |           | BUFSIZE  |                  |          | CNIC    |          |                | <u> </u>   |                |          | BUFNMB     |           |          |          |

RENESAS

| addr       |                      |      |        |            | 一一一一一一一一一一一一一一一一一一一一一一一一一一一一一一一一一一一一一一一 | 番地 |        |         |              |            |       |       | 偶数 | 番地 |   |      |        |
|------------|----------------------|------|--------|------------|-----------------------------------------|----|--------|---------|--------------|------------|-------|-------|----|----|---|------|--------|
| addr       | レジスタ名                | 15   | 14     | 13         | 12                                      | 11 | 10     | 9       | 8            | 7          | 6     | 5     | 4  | 3  | 2 | 1    | 0      |
| 6C         | PIPEMAXP             |      | DEV    | 'SEL       |                                         |    |        |         |              |            |       | MXPS  |    | •  | • |      |        |
| 6E         | PIPEPERI             |      |        |            | IFIS                                    |    |        |         |              |            |       |       |    |    |   | IITV |        |
| 70         | PIPE1CTR             | BSTS | INBUFM | CSCLR      | CSSTS                                   |    | ATREPM | ACLRM   | SQCLR        | SQSET      | SQMON | PBUSY |    |    |   |      | PID    |
| 72         | PIPE2CTR             | BSTS | INBUFM | CSCLR      | CSSTS                                   |    | ATREPM | ACLRM   | SQCLR        | SQSET      | SQMON | PBUSY |    |    |   |      | PID    |
| 74         | PIPE3CTR             | BSTS | INBUFM | CSCLR      | CSSTS                                   |    | ATREPM | ACLRM   | SQCLR        | SQSET      | SQMON | PBUSY |    |    |   |      | PID    |
| 76         | PIPE4CTR             | BSTS | INBUFM | CSCLR      | CSSTS                                   |    | ATREPM | ACLRM   | SQCLR        | SQSET      | SQMON | PBUSY |    |    |   |      | PID    |
| 78         | PIPE5CTR             | BSTS | INBUFM | CSCLR      | CSSTS                                   |    | ATREPM | ACLRM   | SQCLR        | SQSET      | SQMON | PBUSY |    |    |   |      | PID    |
| 7A         | PIPE6CTR             | BSTS |        | CSCLR      | CSSTS                                   |    |        | ACLRM   | SQCLR        | SQSET      | SQMON | PBUSY |    |    |   |      | PID    |
| 7C         | PIPE7CTR             | BSTS |        | CSCLR      | CSSTS                                   |    |        | ACLRM   | SQCLR        | SQSET      | SQMON | PBUSY |    |    |   |      | PID    |
| 7E         | PIPE8CTR             | BSTS |        | CSCLR      | CSSTS                                   |    |        | ACLRM   | SQCLR        | SQSET      | SQMON | PBUSY |    |    |   |      | PID    |
| 80         | PIPE9CTR             | BSTS |        | CSCLR      | CSSTS                                   |    |        | ACLRM   | SQCLR        | SQSET      | SQMON | PBUSY |    |    |   |      | PID    |
| 82-        |                      |      |        |            |                                         |    |        |         |              |            |       |       |    |    |   |      |        |
| 8E         | DIDE (TDE            |      |        |            |                                         |    |        |         |              |            |       |       |    |    |   |      |        |
|            | PIPE1TRE             |      |        |            |                                         |    |        | TRENB   | TRCLR        |            |       |       |    |    |   |      |        |
|            | PIPE1TRN             |      |        |            |                                         |    |        | I       | TRN          | CNT        |       |       |    |    |   |      |        |
| <u> </u>   | PIPE2TRE             |      |        |            |                                         |    |        | TRENB   | TRCLR        |            |       |       |    |    |   |      |        |
| ••         | PIPE2TRN             |      |        |            |                                         |    |        | I       | TRN          | CNT        |       |       |    |    |   |      |        |
| ••         | PIPE3TRE             |      |        |            |                                         |    |        | TRENB   | TRCLR        |            |       |       |    |    |   |      |        |
| 07.        | PIPE3TRN             |      |        |            |                                         |    |        |         | TRN          | CNI        |       |       |    |    |   |      |        |
|            | PIPE4TRE<br>PIPE4TRN |      |        |            |                                         |    |        | TRENB   | TRCLR        | ONT        |       |       |    |    |   |      |        |
|            | PIPE4TRN<br>PIPE5TRE |      |        |            |                                         |    |        | TDEND   | TRN          | CNI        |       |       |    |    |   |      |        |
|            | PIPESTRE<br>PIPESTRN |      |        |            |                                         |    |        | TRENB   | TRCLR<br>TRN | CNT        |       |       |    |    |   |      |        |
| A4-        | PIPESTRIN            |      |        |            |                                         |    |        |         | IKIN         | CIVI       |       |       |    |    |   |      |        |
| CE         |                      |      |        |            |                                         |    |        |         |              |            |       |       |    |    |   |      |        |
| D0         | DEVADD0              |      |        | HPP        | HUB                                     |    | ı      | HUBPOR  |              | USB        | SPD   |       |    |    |   |      | RTPORT |
|            | DEVADD1              |      |        | HPP        |                                         |    |        | HUBPOR  |              | USB        |       |       |    |    |   |      | RTPORT |
|            | DEVADD2              |      |        | HPP        | -                                       |    |        | HUBPOR  |              | USB        | -     |       |    |    |   |      | RTPORT |
|            | DEVADD3              |      |        | HPP        | -                                       |    |        | HUBPOR  |              | USB        | -     |       |    |    |   |      | RTPORT |
|            | DEVADD4<br>DEVADD5   |      | -      | HPP<br>HPP | -                                       |    |        | HUBPORT |              | USB<br>USB | -     |       |    |    |   |      | RTPORT |
|            | DEVADDS<br>DEVADD6   |      |        | HPP        | _                                       |    |        | HUBPOR  |              | USB        | _     |       |    |    |   |      | RTPORT |
|            | DEVADDO<br>DEVADD7   |      |        | HPP        | _                                       |    |        | HUBPOR  |              | USB        |       |       |    |    |   |      | RTPORT |
|            | DEVADD7              |      |        | HPP        |                                         |    |        | HUBPOR  |              | USB        | _     |       |    |    |   |      | RTPORT |
|            | DEVADD9              |      |        | HPP        |                                         |    |        | HUBPOR  |              | USB        |       |       |    |    |   |      | RTPORT |
| E4         | DEVADDA              |      |        | HPP        | HUB                                     |    |        | HUBPOR  | Γ            | USB        | SPD   |       |    |    |   |      | RTPORT |
| <b>E</b> 6 |                      |      |        |            |                                         |    |        |         |              |            |       |       |    |    |   |      |        |



XTAL 0

## 2.3 システムコンフィグレーションコントロール

XCKE

0

◆ システムコンフィグレーションコントロールレジスタ【SYSCFG0】 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6

PLLC SCKE

0

0

|   | <アドレ | ノス:00 | H>   |
|---|------|-------|------|
| 3 | 2    | 1     | 0    |
|   |      |       | USBE |
| ? | ?    | ?     | Ω    |

5

DCFM DRPD DPRPU

0

0

| Bit   | Name                       | Function                                                                                                                                                          | S/W | H/W | Remarks                  |
|-------|----------------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------|-----|-----|--------------------------|
| 15-14 | XTAL<br>XIN クロック選択         | XIN 端子から入力するクロックの周波数を指定します。<br>00: 12MHz 入力<br>01: 24MHz 入力<br>10: 48MHz 入力<br>11: Reserved                                                                       | R/W | R   |                          |
| 13    | XCKE<br>発振バッファ許可           | 発振バッファ動作の禁止/許可を指定します。<br>0: 発振バッファ動作禁止<br>1: 発振バッファ動作許可                                                                                                           | R/W | R   |                          |
| 12    | 何も配置されていません。"0"に固定して       | てください。                                                                                                                                                            |     |     |                          |
| 11    | PLLC<br>48MHzPLL 動作許可      | 48MHzPLL 動作の禁止/許可を指定します。<br>0: PLL 動作禁止<br>1: PLL 動作許可                                                                                                            | R/W | R/W |                          |
| 10    | SCKE<br>USB プロッククロック許可     | USB ブロックへの 48MHz クロック供給の停止/許可を指定します。<br>0: USB ブロックへのクロック供給停止<br>1: USB ブロックへのクロック供給許可                                                                            | R/W | R/W |                          |
| 9-8   | 何も配置されていません。"0"に固定して       |                                                                                                                                                                   |     |     | •                        |
| 7     | HSE<br>PORT0 Hi-Speed 動作許可 | PORT0 の Hi-Speed 動作禁止/許可を指定します。<br>0: Hi-Speed 動作禁止<br>(Peripheral 機能選択時:Full-Speed、<br>Host 機能選択時: Full-/Low-Speed)<br>1: Hi-Speed 動作許可(コントローラーが通信<br>Speed を検出) | R/W | R   |                          |
| 6     | DCFM<br>コントローラー機能選択        | 本コントローラーの機能を指定します。<br>0: Peripheral Controller 機能選択<br>1: Host Controller 機能選択                                                                                    | R/W | R   |                          |
| 5     | DRPD<br>PORT0 D+/D-ライン抵抗制御 | PORT0 の Host Controller 機能用、D+/D-ライン Pull Down の禁止/許可を指定します。<br>0: Pull Down 禁止<br>1: Pull Down 許可                                                                | R/W | R   | H<br>(P 時<br>"0"を設<br>定) |
|       | DPRPU<br>PORT0 D+ライン抵抗制御   | PORT0のPeripheral Controller 機能用 D+ライン PullUp の禁止/許可を指定します。<br>0: Pull Up 禁止<br>1: Pull Up 許可                                                                      | R/W | R   | P<br>(H 時<br>"0"を設<br>定) |
| 3-1   | 何も配置されていません。"0"に固定して       | てください。                                                                                                                                                            |     |     |                          |
| 0     | USBE<br>USB ブロック動作許可       | USB ブロックの動作禁止/許可を指定します。<br>0: USB ブロック動作禁止<br>1: USB ブロック動作許可                                                                                                     | R/W | R   |                          |

HSE

0

0

<<Remarks>>

なし



## 2.3.1 XINクロック選択ビット(XTAL)

本ビットに、XIN端子に接続する水晶振動子、または発振器に応じた値を設定してください。本コントローラーは本ビットの設定値によって、48MHzPLLの逓倍数を判断します。

本ビットの設定はハードウェアリセットリセット直後に行い、本コントローラの動作中は変更しないでください。

#### 2.3.2 **発振パッファ許可ビット**(XCKE)

本ビットを"1"に設定することにより、本コントローラーの発振バッファ動作を許可します。発振バッファ動作を禁止する時には"0"を書き込んでください。

本コントローラーがクロック復帰処理を行っている期間("CNTFLG=1"が表示されている期間)は、"XCKE=0"を書き込まないでください。また、クロック復帰処理終了時には、必ず"XCKE=1"を書き込んでください。

## 2.3.3 48MHzPLL動作許可ビット(PLLC)

本ビットを"1"に設定することにより、本コントローラーの48MHzPLLの動作を許可します。48MHzPLLの動作を禁止する時には"0"を書き込んでください。

#### 2.3.4 USBプロッククロック許可ピット(SCKE)

本ビットを"1"に設定することにより、本コントローラーのUSBブロックへのクロック供給を許可します。USBブロックへのクロック供給を禁止する時には"0"を書き込んでください。

表 2.3に本ビットが"0"の時に書き込み可能なレジスタを示します。その他のレジスタへの書き込みは行えません。 本ビットが"0"の時の各レジスタの読み出しは可能です。

表 2.3 "SCKE=0"の時に、ソフトウェアによる書き込みが可能なレジスタ一覧

| アドレス | レジスタ名   |
|------|---------|
| 00H  | SYSCFG0 |
| 02H  | SYSCFG1 |
| 0EH  | PINCFG  |

### 2.3.5 Hi-Speed動作許可ビット(HSE)

本ビットを"1"に設定することにより、PORT0に対してHi-Speed動作を許可します。"HSE=1"を設定した場合、本コントローラーはReset Handshakeの結果に従いPORT0をHi-SpeedまたはFull-Speed動作させます。

#### 2.3.5.1 Host Controller 機能選択時

"HSE=0"を設定した場合、当該PORTはLow-Speed動作、または、Full-Speed動作を行います。

当該PORTにLow-SpeedのPeripheralデバイスがアタッチされたことを検出した場合には、必ず"HSE=0"を設定してください。

"HSE=1"を設定した場合、本コントローラーはReset Handshake Protocolの結果に従い、自動的に当該PORTをHi-SpeedまたはFull-Speed動作させます。

本ビットの変更は、"アタッチ検出 (ATTCH割り込み検出)後からUSBバスリセット実行前("USBRST=1"設定前)"の期間に行ってください。



#### 2.3.5.2 Peripheral Controller 機能選択時

"HSE=0"を設定した場合、本コントローラーはFull-Speed動作を行います。

"HSE=1"を設定した場合、本コントローラーはReset Handshake Protocolの結果に従い自動的にHi-SpeedまたはFull-Speed動作を行います。

本ビットの書き換えは、"DPRPU=0"の時に行ってください。

### 2.3.6 コントローラー機能選択ビット(DCFM)

本ビットを設定することにより、本コントローラーをHost Controller機能またはPeripheral Controller機能に指定します。

本ビットの書き換えは、"DPRPU=0かつDRPD=0"の時に行ってください。

## 2.3.7 PORT0用D+,D-ライン抵抗制御 (DRPD、DPRPU)

表 2.4にPORTOのUSBデータバスの抵抗についての設定を示します。DRPDビット及びDPRPUビットでUSBデータバスの抵抗選択を行ってください。

| 設定   | 設定 内容                      |           |           | USB データバス抵抗制御                          |  |  |
|------|----------------------------|-----------|-----------|----------------------------------------|--|--|
| DRPD | DRPD DPRPU D- Line D+ Line |           | D+ Line   | Remarks                                |  |  |
| 0    | 0                          | Open      | Open      |                                        |  |  |
| 0    | 1                          | Open      | Pull-Up   | Peripheral Controller として動作させる場合はこの設定に |  |  |
|      |                            |           |           | してください                                 |  |  |
| 1    | 0                          | Pull-Down | Pull-Down | Host Controller として動作させる場合はこの状態に設定し    |  |  |
|      |                            |           |           | てください                                  |  |  |
| 1    | 1                          | Pull-Down | Pull-Up   | 設定埜止                                   |  |  |

表 2.4 PORTO USBデータバス抵抗の制御

## 2.3.7.1 Host Controller 機能用 PORT0 PullDown 抵抗制御 (DRPD)

Host Controller機能選択時に本ビットを"1"に設定すると、本コントローラーはPORT0のD+、D-ラインをPull Downします。

本ビットへの"1"設定は、Host Controller機能選択時に行ってください。

#### 2.3.7.2 Peripheral Controller 機能用 PORT0 D+Pull Up 抵抗制御 (DPRPU)

Peripheral Controller機能選択時に本ビットを"1"に設定すると、本コントローラーはPORT0のD+ラインを3.3VにPull Upし、USBホストに対してアタッチを通知することができます。

また、本ビットを"1"から"0"に変更することにより、本コントローラーはD+ラインのPull Upを解消しますので、 USBホストに対してデタッチしたと見せることができます。

本ビットへの"1"設定は、Peripheral Controller機能選択時に行ってください。



#### USBプロック動作許可ピット(USBE) 2.3.8

本ビットを設定することにより、本コントローラーのUSBブロックの動作許可、禁止を行います。 "USBE=1"から"USBE=0"に変更した場合には、本コントローラーは表 2.5、表 2.6に示すビットを初期化します。

表 2.5 "USBE=0"書き込みにより初期化されるレジスター覧 (Peripheral Controller機能選択 ("DCFM=0"設定) 時)

| レジスタ名                | ビット名                      | Remark                   |
|----------------------|---------------------------|--------------------------|
| SYSSTS0<br>SYSSTS1   | LNST                      | Host Controller機能選択時は値保持 |
| DVSTCTR0<br>DVSTCTR0 | RHST                      |                          |
| INTSTS0              | DVSQ                      | Host Controller機能選択時は値保持 |
| USBADDR              | USBADDR                   | Host Controller機能選択時は値保持 |
| USBREQ               | bRequest<br>bmRequestType | Host Controller機能選択時は値保持 |
| USBVAL               | wValue                    | Host Controller機能選択時は値保持 |
| USBINDX              | wIndex                    | Host Controller機能選択時は値保持 |
| USBLENG              | wLength                   | Host Controller機能選択時は値保持 |

## 表 2.6 "USBE=0"書き込みにより初期化されるレジスター覧 (Host Controller機能選択 ("DCFM=1"設定) 時)

| レジスタ名                | ビット名  | Remark                         |
|----------------------|-------|--------------------------------|
| DVSTCTR0<br>DVSTCTR0 | RHST  |                                |
| FRMNUM               | FRNM  | Peripheral Controller機能選択時は値保持 |
| UFRMNUM              | UFRNM | Peripheral Controller機能選択時は値保持 |

本ビットの変更は、"SCKE=1"の時に行ってください。

Host Controller機能選択時は、"DPRD=1"設定後、LNSTビットのチャタリング除去を行い、USBバスの状態が安 定したことを確認した後で、"USBE=1"の設定を行ってください。



14 13

15

◆ PORT1システムコンフィグレーションコントロールレジスタ【SYSCFG1】

9

0

8

0

0

PCSDIS LPSME HSE

12 11 10

CNTFLG 0

| <アドレス:02H> |   |   |   |  |  |  |
|------------|---|---|---|--|--|--|
| 3          | 2 | 1 | 0 |  |  |  |
|            |   |   |   |  |  |  |
| 2          | 2 | 2 | 2 |  |  |  |

4

DRPD

0

| Bit   | Name                      | Function                            | S/W   | H/W      | Remarks |  |  |
|-------|---------------------------|-------------------------------------|-------|----------|---------|--|--|
|       |                           |                                     | 0, 11 | 1 1/ V V |         |  |  |
|       | 何も配置されていません。"0"に固定してください。 |                                     |       |          |         |  |  |
| . –   | CNTFLG                    | 現在オートクロックセットアップ処理中かど                | R     | W        |         |  |  |
|       | オートクロックモニター               | うかが表示されます。                          |       |          |         |  |  |
|       |                           | 0: オートクロック処理終了またはクロック停              |       |          |         |  |  |
|       |                           | 止中                                  |       |          |         |  |  |
|       |                           | 1: オートクロック処理中                       |       |          |         |  |  |
| 11-10 | 何も配置されていません。"0"に固定して      | :ください。                              |       |          |         |  |  |
|       | PCSDIS                    | CS_N の立下りによる Low パワースリープ            | R/W   | R        |         |  |  |
|       |                           | モードからの復帰の禁止/許可を指定します。               |       |          |         |  |  |
|       | による復帰禁止                   | 0: CS_N による復帰許可                     |       |          |         |  |  |
|       |                           | 1: CS_N による復帰禁止                     |       |          |         |  |  |
| 8     | LPSME                     | クロック停止中に本コントローラーが Low パ             | R/W   | R        |         |  |  |
|       | Low パワースリープモード許可          | ワースリープモードへ遷移するかどうかの禁                |       |          |         |  |  |
|       |                           | 止/許可を指定します。                         |       |          |         |  |  |
|       |                           | 0: Low パワースリープモード禁止                 |       |          |         |  |  |
|       |                           | 1: Low パワースリープモード許可                 |       |          |         |  |  |
| 7     | HSE                       | Host Controller 機能選択時、PORT1 の       | R/W   | R        | Н       |  |  |
|       | PORT1 Hi-Speed 動作許可       | Hi-Speed 動作許可を行います。                 |       |          | (P 時    |  |  |
|       |                           | 0: Hi-Speed 動作禁止 Full-/Low-Speed)   |       |          | "0"を設   |  |  |
|       |                           | 1: Hi-Speed 動作許可(コントローラーが通信         |       |          | 定)      |  |  |
|       |                           | Speed を検出)                          |       |          |         |  |  |
| 6     | 何も配置されていません。"0"に固定して      | ください。                               |       |          | •       |  |  |
| 5     | DRPD                      | PORT1 の(Host Controller 機能用)D+/D-ライ | R/W   | R        | Н       |  |  |
|       | PORT1 D+/D-ライン抵抗制御        | ン Pull Down の禁止/許可を指定します。           |       |          | (P 時    |  |  |
|       |                           | 0: Pull Down 禁止                     |       |          | "0"を設   |  |  |
|       |                           | 1: Pull Down 許可                     |       |          | 定)      |  |  |
| 4-0   | 何も配置されていません。"0"に固定して      | ください。                               |       |          | '       |  |  |

#### <<Remarks>>

なし

## 2.3.9 オートクロックモニタービット(CNTFLG)

本コントローラーがクロック復帰処理を行っている期間に"1"が表示されるビットです。

本ビットは、本コントローラーがクロック復帰処理を開始したときに"0"から"1"に変化し、クロック復帰が完了して"SCKE=1"の状態になったときに"1"から"0"に変化します。

## 2.3.10 CS\_N復帰禁止ビット(PCSDIS)

本コントローラーがLowパワースリープ状態から通常状態へ遷移するためのイベントとしてCS\_N端子の立下りエッジを許可するか、禁止するかを設定するためのビットです。

本ビットの設定値による復帰イベントの相違については表 2.7を参照ください。



#### 2.3.11 Lowパワースリープモード許可ビット(LPSME)

"LPSME=1"設定時に発振バッファを停止 ("XCKE=0"設定) させた場合、 本コントローラーはLowパワースリープ 状態に遷移し、"LPSME=0"設定時の発振バッファ停止状態よりも待機電流を低減させることができます。

"LPSME=1"かつ"XCKE=0"によるLowパワースリープ状態から本コントローラが通常のクロック動作状態へ復帰 するためのイベントは以下の2種類です。

表 2.7 Lowパワースリープ状態 ("LPSME=1"かつ"XCKE=0") からの復帰イベント

| コントローラー機能<br>選択<br>(DCFMビット設定値) | 条件                | 復帰イベント                                                                                     |
|---------------------------------|-------------------|--------------------------------------------------------------------------------------------|
| Peripheral Controller<br>機能選択時  | "PCSDIS=0"<br>設定時 | (1) "RSME=1"設定時のRESM割り込み検出<br>(2) "VBSE=1"設定時のVBINT割り込み検出<br>(3) CPUからのダミーリードによるCS_N信号アサート |
|                                 | "PCSDIS=1"<br>設定時 | (1) "RSME=1"設定時のRESM割り込み検出<br>(2) "VBSE=1"設定時のVBINT割り込み検出                                  |
| Host Controller機能選択時            | "PCSDIS=0"<br>設定時 | (1) "BCHGE=1"設定PORTにおけるBCHG割り込み検出<br>(2) CPUからのダミーリードによるCS_N信号アサート                         |
|                                 | "PCSDIS=1"<br>設定時 | (1) "BCHGE=1"設定PORTにおけるBCHG割り込み検出                                                          |

"LPSME=1"設定は、"XCKE=1"の時に行ってください。

"LPSME=1"設定時に、"XCKE=0"設定によってLowパワースリープ状態に遷移させた場合、"XCKE=0"設定後10us 間は本コントローラーへのアクセスは禁止です。従ってCPUからのダミーリードによるLowパワースリープ状態から の復帰は、少なくとも"XCKE=0"設定後10us経過後に実施してください。

本コントローラーがLowパワースリープ状態に遷移した場合、FIFOバッファ内の値は失われます。"LPSME=1" 設定で本コントローラを使用する場合、"XCKE=0"を設定する前にFIFOの内容の読み出しを完了させるかもしくは かFIFOバッファのクリアを実施してください。

#### 2.3.12 Hi-Speed動作許可ピット (HSE)

本ビットを"1"に設定することにより、PORT1に対してHi-Speed動作を許可します。"HSE=1"を設定した場合、本 コントローラーはReset Handshakeの結果に従いPORT1をHi-SpeedまたはFull-Speed動作させます。

## 2.3.12.1 Host Controller 機能選択時

2.3.5.1を参照してください。

#### 2.3.12.2 Peripheral Controller 機能選択時

本ビットには"0"を設定してください。

Peripheral Controller機能選択時はPORT1を使用することはできません。

## 2.3.13 PORT1用D+,D-ライン抵抗制御ビット (DRPD)

表 2.8にPORT1のUSBデータバスの抵抗についての設定を示します。SYSCFG1レジスタのDRPDビットでUSB データバスの抵抗選択を行ってください。

表 2.8 PORT1 USBデータバス抵抗の制御

| DRPD | D- Line   | D+ Line    | Remarks                       |  |  |
|------|-----------|------------|-------------------------------|--|--|
| 0    | Open Open |            | PORT1 未使用時                    |  |  |
| 1    | Pull-Down | Pull- Down | Host Controller として動作中はこの状態に設 |  |  |
|      | II I      |            | 定してください                       |  |  |

Host Controller機能選択時に本ビットを"1"に設定すると、本コントローラーはPORT1のD+、D-ラインをPull Downします。



OVCMON

## 2.4 システムコンフィグレーションステータス

12

13

|   | システムコンフィ | グレーション | ステータスし | バスター  | I OZTZZVZ I |
|---|----------|--------|--------|-------|-------------|
| • | ンスノムコノノイ | ソレーション | スノーツスレ | ノンスツー | しつもつひょうひょ   |

10

| <アドレス:04H> |       |    |    |  |  |  |
|------------|-------|----|----|--|--|--|
| 3          | 2     | 1  | 0  |  |  |  |
|            | IDMON | LN | ST |  |  |  |
| ?          | ?     | Ο  | Ω  |  |  |  |

| Bit   | Name                            | Function                                                                                                                                                       | S/W | H/W | Remarks |
|-------|---------------------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------|-----|-----|---------|
| 15-14 | OVCMON<br>OVCUR0A,OVCUR0B端子モニター | OVCUR0A,OVCUR0B端子の入力状態が表示されます。<br>00:OVCUR0A=Low, OVCUR0B=Low<br>01:OVCUR0A=Low, OVCUR0B=High<br>10:OVCUR0A=High, OVCUR0B=Low<br>11:OVCUR0A=High, OVCUR0B=High | R   | W   |         |
| 13-6  | 何も配置されていません。"0"に固定して            | ください。                                                                                                                                                          |     |     |         |
| 5     | Port0 HOST SOFアクティブモニター         | Port0の動作に対しUACTビットの設定が反映<br>されたことを表示します。<br>0: (micro) SOFの発行を停止した<br>1: (micro) SOFの発行を継続している                                                                 | R   | W   |         |
| 4-2   | 何も配置されていません。"0"に固定して            | てください。                                                                                                                                                         |     |     |         |
| 2     | IDMON<br>ID0端子モニター              | ID0端子の入力状態が表示されます。<br>0: ID0=Low<br>1: ID0=High                                                                                                                | R   | W   |         |
|       | LNST<br>PORT0 USBデータラインステータスモ   | PORTOのUSBライン状態が表示されます。<br>詳細説明をご覧下さい。                                                                                                                          | R   | W   |         |

6

SOFEA

#### <<Remarks>>

ニター

なし

## 2.4.1 OVCUR0A、OVCUR0B端子モニタービット (OVCMON)

本コントローラーは、本レジスタのbit15にOVCUR0A端子の状態を、bit14にOVCUR0B端子の入力状態を表示します。

#### 2.4.2 Port0 HOST SOFアクティブモニタビット (SOFEA)

Host Controller機能選択時にソフトウェアがUACTビットを"1"に設定すると、本コントローラーは本ビットに"1"を表示し、PORTOをUSBバス許可状態にし、SOF出力を行います。

ソフトウェアがUACTビットを"0"に設定した場合、本コントローラーは、(micro) SOF出力後Idle状態に遷移し本ビットに"0"を表示します。

サスペンド実行時、ソフトウェアが**UACT**ビットを"0"にクリアした後に、本コントローラがPort0に最後のSOFを出力し終わっことを確認するために本ビットを使用します。

## 2.4.3 ID0端子モニタビット (IDMON)

本コントローラーは、本ビットにID0端子の入力状態を表示します。

#### 2.4.4 ラインステータスモニタピット (LNST)

表 2.9に本コントローラーのUSBデータバスラインステータス表を示します。本コントローラーは、**SYSSTS0**レジスタの**LNST**ビットにPORT0のUSBデータバスのラインステータス(D+ライン、及びD-ライン)をモニタします。

LNSTビットの参照は、Peripheral Controller機能選択時にはアタッチ処理("DPRPU=1"設定)以後、Host Controller機能選択時には、Pull Down許可("DRPD=1"設定)以後に行ってください。

## 表 2.9 USBデータパスラインステータス表

| LNST [1]    | ] LNST [0] Low-Speed 動作時<br>(Host Controller 機<br>能選択時のみ) |         |         | Hi-Speed 動作時 | Chirp 動作時 |
|-------------|-----------------------------------------------------------|---------|---------|--------------|-----------|
| 0           | 0 0 SE0                                                   |         | SE0     | Squelch      | Squelch   |
| 0           | 0 1 K State                                               |         | J State | Unsquelch    | Chirp J   |
| 1 0 J State |                                                           | K State | Invalid | Chirp K      |           |
| 1           | 1                                                         | SE1     | SE1     | Invalid      | Invalid   |

Chirp: Hi-Speed 動作許可の状態(HSE = "1")で、リセットハンドシェイクプロトコル実行中

Squelch: SE0、もしくは Idle 状態

 $\dot{}$  Unsquelch : Hi-Speed J State、もしくは Hi-Speed K State

 $\begin{array}{ll} \text{Chirp J:} & \text{Chirp J State} \\ \text{Chirp K:} & \text{Chirp K State} \end{array}$ 



◆ PORT1システムコンフィグレーションステータスレジスタ【SYSSTS1】

| <ア | ľ | レス | • | 06H> |
|----|---|----|---|------|
|    |   |    |   |      |

| 15   | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5     | 4 | 3 | 2 | 1 | 0  |
|------|----|----|----|----|----|---|---|---|---|-------|---|---|---|---|----|
| OVCN |    |    |    |    |    |   |   |   |   | SOFEA |   |   |   |   | ST |
| ?    | 0  | ?  | ?  | ?  | ?  | ? | ? | ? | ? | 0     | ? | ? | ? | 0 | 0  |
| ?    | 0  | ?  | 7  | 7  | ?  | ? | 7 | ? | 7 | ?     | 7 | 7 | ? | ? | ?  |

| Bit  | Name                                 | Function                                                                                       | S/W | H/W | Remarks                   |
|------|--------------------------------------|------------------------------------------------------------------------------------------------|-----|-----|---------------------------|
|      | OVCUR1端子モニター                         | bit15にOVCUR1端子の状態が表示されます。<br>bit14は'0'固定です。<br>00:OVCUR1=Low<br>10:OVCUR1=High                 | R   | W   |                           |
| 13-6 | 何も配置されていません。"O"に固定して<br>ください。        |                                                                                                |     |     |                           |
| -    | SOFEA<br>Port1 HOST SOFアクティブモニター     | Port1の動作に対しUACTビットの設定が反映<br>されたことを表示します。<br>0: (micro) SOFの発行を停止した<br>1: (micro) SOFの発行を継続している | R   | W   |                           |
| 4-2  | 何も配置されていません。"0"に固定して                 | ください。                                                                                          |     |     |                           |
|      | LNST<br>PORT1 USBデータラインステータスモ<br>ニター | PORT1のUSBライン状態が表示されます。<br>詳細説明をご覧下さい。                                                          | R   | W   | H<br>(P 時読<br>み出し<br>値無効) |

<<Remarks>>

なし

## 2.4.5 OVCUR1端子モニターピット (OVCMON)

本コントローラーは、本レジスタのbit15にOVCUR1端子の状態を表示します。bit14は"0"固定です。

#### 2.4.6 Port1 HOST SOFアクティブモニタピット (SOFEA)

Host Controller機能選択時にソフトウェアがUACTビットを"1"に設定すると、本コントローラーは本ビットに"1"を表示し、PORT1をUSBバス許可状態にし、SOF出力を行います。

ソフトウェアがUACTビットを"0"に設定した場合、本コントローラーは本ビットに"0"を表示し、(micro) SOF出力後Idle状態に遷移します。

サスペンド実行時、ソフトウェアが**UACT**ビットを"0"にクリアした後に、本コントローラがPort1に最後のSOFを出力し終わっことを確認するために本ビットを使用します。

## 2.4.7 ラインステータスモニタビット (LNST)

本コントローラーは、**SYSSTS1**レジスタの**LNST**ビットにPORT1のUSBデータバスのラインステータス(D+ライン、及びD-ライン)をモニタします。各**LNST**ビットは2bit構成です。各ビットの意味は表 2.9を参照してください。

PORT1のLNSTビットは、Host Controller機能選択時のみ有効です。

LNSTビットの参照は、Host Controller機能選択時には、Pull Down許可("DRPD=1"設定)以後に行ってください。



# 2.5 USB信号制御

◆ デバイスステートコントロールレジスタ【DVSTCTR0】

| <ア | ľ | レス | : | 08H> |
|----|---|----|---|------|
|    |   |    |   |      |

| 15 | 14 | 13 | 12 | 11      | 10     | 9     | 8    | 7     | 6 | 5      | 4    | 3 | 2 | 1    | 0 |
|----|----|----|----|---------|--------|-------|------|-------|---|--------|------|---|---|------|---|
|    |    |    |    | HNPBTOA | EXTLP0 | VBOUT | WKUP | RWUPE |   | RESUME | UACT |   |   | RHST |   |
| ?  | ?  | ?  | ?  | 0       | 0      | 0     | 0    | 0     | 0 | 0      | 0    | ? | 0 | 0    | 0 |
| ?  | ?  | ?  | ?  | -       | -      | -     | 0    | -     | - | -      | -    | ? | - | -    | - |

| Bit   | Name                                                        | Function                                                                                                                                              | S/W    | H/W    | Remarks              |
|-------|-------------------------------------------------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------|--------|--------|----------------------|
| 15-12 | 何も配置されていません。"0"に固定して                                        | ください。                                                                                                                                                 |        |        |                      |
|       | HNPBTOA<br>HNP(ホストネゴシエーションプロトコ<br>ル) B-Device Host 遷移時制御ビット | On-The-Go (OTG) B-Device として使用しているときに、Peripheral から Host に切り替える HNP 時に使用します。<br>0: 通常動作<br>1: OTG Peripheral から Host への切り替え許可                         | R/W(1) | R/W(0) |                      |
| 10    | EXTLP0<br>EXTLP0 端子出力制御                                     | EXTLP0 端子に出力する状態を制御します。<br>0: EXTLP0 Low 出力(Default)<br>1: EXTLP0 High 出力                                                                             | R/W    | R      |                      |
| 9     | VBOUT<br>VBOUT0 端子出力制御                                      | VBOUT0 端子に出力する状態を制御します。<br>0: VBOUT0=Low 出力(Default)<br>1: VBOUT0=High 出力                                                                             | R/W    | R      |                      |
| 8     | WKUP<br>ウェイクアップ出力                                           | Peripheral Controller 機能選択時に、リモートウェイクアップ(レジューム信号出力)禁止/許可を指定します。<br>0: リモートウェイクアップ信号非出力1: リモートウェイクアップ信号出力                                              | R/W(1) | R/W(0) | P<br>(H 時"0"<br>を設定) |
| 7     | RWUPE<br>リモートウェイクアップ検出許可                                    | Host Controller 機能選択時に、PORT0 に接続された Peripheral Device からのリモートウェイクアップ(レジューム信号出力)検出の禁止/許可を指定します。 0: DownPort リモートウエイクアップ出力不許可 1: DownPort リモートウエイクアップ許可 | R/W    | R      | H<br>(P 時"0"<br>を設定) |
| 6     | USBRST<br>PORT0 USB バスリセット出力                                | PORT0 の USB バスリセット出力制御を行い<br>ます。<br>0: 非出力<br>1: USB バスリセット信号出力                                                                                       | R/W    | R      | H<br>(P 時"0"<br>を設定) |
|       | RESUME<br>PORT0 レジューム出力                                     | PORT0 のレジューム出力制御を行います。<br>0:非出力<br>1:レジューム信号出力                                                                                                        | R/W    | R/W(1) | (P 時"0"<br>を設定)      |
|       | UACT<br>PORT0 USB バス許可                                      | PORTO の USB バス動作許可を行います。<br>0:DownPort 動作禁止(SOF/ μ SOF 送出禁<br>止)<br>1:DownPort 動作許可(SOF/ μ SOF 送出許<br>可)                                              | R/W    | R/W(0) | H<br>(P 時"0"<br>を設定) |
|       | 何も配置されていません。"0"に固定して                                        |                                                                                                                                                       |        | 1      | ,                    |
| 2-0   | RHST<br>PORT0 リセットハンドシェイク                                   | PORTO のリセットハンドシェイクの状態を表示します。<br>詳細説明をご覧下さい。                                                                                                           | R      | W      |                      |

<<Remarks>>

なし



## 2.5.1 HNP(ホストネゴシエーションプロトコル) B-Device Host遷移時制御ビット (HNPBTOA)

本コントローラーをOn-The-Go (OTG) B-Deviceとして使用しているときに、PeripheralからHostに切り替えるHNP時にソフトウェアで本ビットを"1"に設定してください。

本ビットが"1"の時、ソフトウェアで"DPRPU=0"または"DCFM=1"を設定しても、コントローラー内部のペリフェラル制御回路は、HNP処理が終了するまでサスペンド状態を維持します。また、この時D+信号の立下りを検出しても、レジューム(**RESM**)割り込みは発生しません。

本ビットへ"1"書き込みは、OTG B-Deviceとして動作中かつPeripheral Controller機能選択時のサスペンド時にのみ行ってください。

#### 2.5.2 EXTLPO端子出力制御ビット (EXTLPO)

本ビットへの設定値が"1"のときはHighが、"0"の時はLowが**EXTLP0**端子に出力されます。

## 2.5.3 VBOUT0端子出力制御ビット (VBOUT0)

本ビットへの設定値が"1"のときはHighが、"0"の時はLowがVBOUT0端子に出力されます。

### 2.5.4 Peripheral Controller機能用 リモートウェイクアップ (レジューム信号出力) 禁止/許可ピット (WKUP)

Peripheral Controller機能選択時に本ビットを"1"に設定すると、本コントローラーはPORT0 USBバスにリモートウェイクアップ信号を出力します。

本コントローラーは、リモートウェイクアップ信号の出力時間を管理しています。ソフトウエアが**WKUP**ビットに"1"を設定すると、本コントローラーは10msの"K-State"を出力しその後"WKUP=0"にします。

USB規格では、リモートウェイクアップ信号の送信までに最短5msのUSBバスアイドル状態を保持する必要があります。この為、サスペンド状態を検出した直後に"WKUP=1"を書き込んでも、本コントローラーは2ms待ってから Kステートを出力します。

WKUPビットへの"1"書き込みは、デバイスステートがサスペンド ("DVSQ=1xx") でありかつUSBホストからリモートウェイクアップが許可されている場合にのみ行ってください。

**WKUP**ビットを"1"に設定する場合は、サスペンド中であっても内部クロックを停止しないでください ("SCKE=1" の状態で"WKUP=1"を書き込んでください)。

#### 2.5.5 Host Controller機能用 PORT0リモートウェイクアップ検出禁止/許可ビット (RWUPE)

Host Controller機能選択時に本ビットを"1"に設定すると、本コントローラーは当該PORTに接続された Peripheralデバイスからのリモートウェイクアップ信号(2.5us間のK-State)を検出し、レジューム処理(K - Stateのドライブ)を行います。

本ビットを"0"に設定した場合、本コントローラーが当該PORTに接続されたPeripheralデバイスからのリモートウェイクアップ信号(K-State)を検出しても無視します。

本ビットを"1"に設定した時には、サスペンド中であっても内部クロックを停止しないでください ("SCKE=1"の状態にしてください)。また、サスペンド状態からのUSBバスリセット実行("USBRST=1"設定)は行わないでください。 USB Specification 2.0で禁止されています。

#### 2.5.6 Host Controller機能用 PORT0 USBバスリセット出力禁止/許可ビット (USBRST)

Host Controller機能選択時に本ビットを"1"に設定すると、本コントローラーは当該PORTのSE0ドライブを行い、USBバスリセット処理を行います。このとき、PORT0に対応するHSEビットが"1"の場合、Reset Handshake Protocolを実行します。

本コントローラーは、"USBRST=1"の期間 (ソフトウェアが"USBRST=0"を書き込むまで) SE0出力を継続します。 "USBRST=1"の期間 (USBバスリセット期間) はUSB Specification2.0に準拠した時間を確保してください。

通信中 ("UACT=1") またはレジューム中 ("RESUME=1") に本ビットに"1"を書き込んだ場合、本コントローラーは"UACT=0"かつ"RESUME=0"の状態になるまでUSBバスリセットを開始しません。

USBバスリセット終了 ("USBRST=0"書き込み) と同時にUACTビットに"1"を書き込んでください。



## 2.5.7 Host Controller機能用 PORTO レジューム信号出力ビット (RESUME)

Host Controller機能選択時に本ビットを"1"に設定すると、本コントローラーはPORT0をK-Stateドライブし、レジューム出力を行います。"RWUPE=1"かつUSBサスペンド状態でリモートウェイクアップ信号を検出した時に、本コントローラーは本ビットを"1"にセットします。

本コントローラーは、"RESUME=1"の期間 (ソフトウェアが" RESUME =0"を書き込むまで) K-State出力を継続します。" RESUME =1"の期間 (レジューム期間) はUSB Specification2.0に準拠した時間を確保してください。

本ビットへの"1"書き込みは、サスペンド中にのみ行ってください。 レジューム終了("RESUME=0"書き込み) と同時に**UACT**ビットに"1"を書き込んでください。

## 2.5.8 Host Controller機能用 PORTO USBパス動作許可ピット (UACT)

Host Controller機能選択時に本ビットを"1"に設定すると、本コントローラーはPORT0をUSBバス許可状態にし、SOF出力およびデータ送受信を行います。

ソフトウェアが"UACT=1"を書き込んでから、1 (マイクロ) フレーム時間以内に(micro) SOF出力を開始します。

ソフトウェアが本ビットを"0"に設定した場合、本コントローラーは(micro) SOF出力後Idle状態に遷移します。

以下の場合に、本コントローラーは本ビットを"0"に設定します。

- (1) 通信中("UACT=1"設定時)にDTCH割り込みを検出した場合
- (2) 通信中("UACT=1"設定時)にEOFERR割り込みを検出した場合

本ビットへの"1"書き込みは、USBリセット処理終了時("USBRST=0"書き込み)、または、サスペンドからのレジューム処理終了時("RESUME =0"書き込み)、いずれかのタイミングで行ってください。

### 2.5.9 PORTOのリセットハンドシェイクステータスピット (RHST)

本コントローラーはPORT0のReset Handshakeの結果を本ビットに表示します。表 2.10 にReset Handshake結果一覧を示します。

| バスの状態                     | RHST ビットの値                     |                          |  |  |  |
|---------------------------|--------------------------------|--------------------------|--|--|--|
|                           | Peripheral Controller<br>機能選択時 | Host Controller<br>機能選択時 |  |  |  |
| Powered 時 or Disconnect 時 | 000                            | 000                      |  |  |  |
| ResetHandshake 中          | 100                            | 1xx                      |  |  |  |
| Low-Speed 接続時             | -                              | 001                      |  |  |  |
| Full-Speed 接続時            | 010                            | 010                      |  |  |  |
| Hi-Speed 接続時              | 011                            | 011                      |  |  |  |

表 2.10 PORTO Reset Handshakeステータス表

#### 2.5.9.1 Host Controller 機能選択時

Host Controller機能選択時、ソフトウェアが"USBRST=1"書き込み後、本ビットは"100"を示します。

当該PORTに対して"HSE=1"を設定している場合、本コントローラーがPeripheralデバイスからのChirpKを検出した時点で、本ビットは"111"を示します。

ソフトウェアが当該PORTの"USBRST=0"を書き込み、本コントローラーがSE0ドライブを終了した時点で、本コントローラーはR**HST**ビットの値を確定します。

ソフトウェアが"UTST=1xxx"を書き込んだ場合 (即ち、HOSTテスト用パラメーターを設定した場合) には、本ビットは"011"を示します。



#### 2.5.9.2 Peripheral Controller 機能選択時

当該PORTに対して"HSE=1"を設定している場合、本コントローラーがUSBバスリセットを検出すると、本ビット は"100"を示します。その後、本コントローラーがChirpKを出力し、USBホストからのChirpJKを3回検出した時点 で本ビットは"011"を示します。ChirpK出力後、2.5ms以内にHi-Speedに確定しなければ、本ビットは"010"を示し ます。

当該PORTに対して"HSE=0"を設定している場合、本コントローラーがUSBバスリセットを検出すると、本ビット は"010"を示します。

本コントローラーがUSBバスリセットを検出後、RHSTビットが"010"または"011"に確定した時点で、DVST割り 込みが発生します。



◆ デバイスステートコントロールレジスタ【DVSTCTR1】 <アドレス・OAH>

|    | ,,,,, | ~ \ / / / |    |    | <i>,,,</i> | , ,,, | 010110 | * 4 |        |        |      |   | '/ ' | 77. 01 | 11 1/ |
|----|-------|-----------|----|----|------------|-------|--------|-----|--------|--------|------|---|------|--------|-------|
| 15 | 14    | 13        | 12 | 11 | 10         | 9     | 8      | 7   | 6      | 5      | 4    | 3 | 2    | 1      | 0     |
|    |       |           |    |    |            | VBOUT |        |     | USBRST | RESUME | UACT |   |      | RHST   |       |
| ?  | ?     | ?         | ?  | ?  | ?          | 0     | ?      | 0   | 0      | 0      | 0    | ? | 0    | 0      | 0     |
| ?  | ?     | ?         | ?  | ?  | ?          | - 1   | ?      | -   | -      | -      | -    | ? | -    | -      | -     |

| Bit   | Name                               | Function                                                                                                                                                    | S/W | H/W    | Remarks                  |
|-------|------------------------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------|-----|--------|--------------------------|
| 15-10 | 何も配置されていません。"0"に固定して               | てください。                                                                                                                                                      |     |        |                          |
| 9     | VBOUT<br>VBOUT 端子出力制御              | VBOUT1 端子に出力する状態を制御します。<br>0: VBOUT1=Low 出力(Default)<br>1: VBOUT1=High 出力                                                                                   | R/W | R      |                          |
| -     | RWUPE<br>PORT1 リモートウェイクアップ検出許<br>可 | Host Controller 機能選択時に、PORT1 に接続された Peripheral Device からのリモートウェイクアップ(レジューム信号出力)検出の禁止/許可を指定します。 0: Down Port ウエイクアップ禁止 1: Down Port ウエイクアップ許可                | R/W | R      | H<br>(P時"0"<br>を設定)      |
| 6     | USBRST<br>PORT1 USB バスリセット出力       | PORT1 の USB バスリセット出力制御を行い<br>ます。<br>0:USB バスリセット非出力<br>1:USB バスリセット信号出力                                                                                     | R/W | R      | P<br>(H 時<br>"0"を設<br>定) |
| 5     | RESUME<br>PORT1 レジューム出力            | PORT1 のレジューム出力制御を行います。<br>0:レジューム信号非出力<br>1:レジューム信号出力                                                                                                       | R/W | R/W(1) | H<br>(P時"0"<br>を設定)      |
| 4     | UACT<br>PORT1 USB バス許可             | PORT1 の USB バス動作許可を行います。<br>0: DownPort 動作禁止(SOF/ µ SOF 送出禁<br>止)<br>1: DownPort 動作許可(SOF/ µ SOF 送出許<br>可)                                                  | R/W | R      | H<br>(P時"0"<br>を設定)      |
| 3     | 何も配置されていません。"0"に固定して               | てください。                                                                                                                                                      |     |        |                          |
| 2-0   | RHST<br>PORT1 リセットハンドシェイク          | PORT1 のリセットハンドシェイクの状態または結果が表示されます。<br>000: Powered 時 or Disconnect 時<br>1xx: リセットハンドシェイク中<br>001: Low-Speed 接続時<br>010: Full-Speed 接続時<br>011: Hi-Speed 接続時 | R   | W      | H<br>(P時"0"<br>を設定)      |

### <<Remarks>>

なし

## 2.5.10 Host Controller機能用 PORT1リモートウェイクアップ検出禁止/許可ビット (RWUPE)

2.5.5を参照ください。

## 2.5.11 Host Controller機能用 PORT1 USBパスリセット出力禁止/許可ビット (USBRST)

2.5.6を参照ください。

## 2.5.12 Host Controller機能用 PORT1 レジューム信号出力ビット (RESUME)

2.5.7を参照ください。

## 2.5.13 Host Controller機能用 PORT1のUSBパス動作許可ビット (UACT)

page 31 of 183

2.5.8を参照ください。



## 2.5.14 PORT1のリセットハンドシェイクステータスピット (RHST)

本コントローラーはPORT1のReset Handshakeの結果を本ビットに表示します。表 2.10にReset Handshake結果一覧を示します。

表 2.11 PORT1 Reset Handshakeステータス表

| バスの状態                     | RHST ビットの値                     |                          |  |  |  |
|---------------------------|--------------------------------|--------------------------|--|--|--|
|                           | Peripheral Controller<br>機能選択時 | Host Controller<br>機能選択時 |  |  |  |
| Powered 時 or Disconnect 時 | -                              | 000                      |  |  |  |
| ResetHandshake 中          | -                              | 1xx                      |  |  |  |
| Low-Speed 接続時             | -                              | 001                      |  |  |  |
| Full-Speed 接続時            | -                              | 010                      |  |  |  |
| Hi-Speed 接続時              | -                              | 011                      |  |  |  |

## 2.5.14.1 Host Controller 機能選択時

2.5.9.1を参照ください。

#### 2.5.14.2 Peripheral Controller 機能選択時

当該PORTはPeripheral Controller機能選択時には使用できないため、本ビットの値は参照しないでください。



## 2.6 テストモード

#### テストモードレジスタ【TESTMODE】 <アドレス:0CH> 13 12 11 10 9 6 8 0 0 0 0

| Bit  | Name                      | Function    | S/W | H/W | Remarks |  |
|------|---------------------------|-------------|-----|-----|---------|--|
| 15-4 | 何も配置されていません。"0"に固定してください。 |             |     |     |         |  |
|      | UTST<br>テストモード            | 詳細説明をご覧下さい。 | R/W | R   |         |  |

<<Remarks>>

なし

#### 2.6.1 テストモードピット (UTST)

本ビットに値を書き込むことにより、本コントローラーはHi-Speed動作時のUSBテスト信号出力を行います。表 2.12に本コントローラーのテストモード動作表を示します。

| テストモード            | UTST                       | ごット設定                |
|-------------------|----------------------------|----------------------|
|                   | Peripheral Controller機能選択時 | Host Controller機能選択時 |
| 通常動作              | 0000                       | 0000                 |
| Test_J            | 0001                       | 1001                 |
| Test_K            | 0010                       | 1010                 |
| Test_SE0_NAK      | 0011                       | 1011                 |
| Test_Packet       | 0100                       | 1100                 |
| Test_Force_Enable | -                          | 1101                 |
| Reserved          | 0101-0111                  | 1110-1111            |

表 2.12 テストモード動作表

### 2.6.1.1 Host Controller 機能選択時

Host Controller機能選択時、PORTO、及びPORT1のうちテスト対象のPortに対応する"DRPD=1"書き込み後に本 ビットの設定が可能です。本ビットはPORT0、及びPORT1共通のレジスタです。" DRPD=1かつUACT=1"を設定し たPORTに対して、本コントローラーは波形出力を行います。

Host Controller機能選択時は、本ビットへの書き込みを行うことにより、本コントローラーはPORT0、及びPORT1 に対してHi-Speed終端を行います。

HOSTモード時のUTSTビット設定手順は以下のとおりです。

- (1) ハードウェアリセット
- (2) クロック起動 (XTAL設定、"XCKE=1"書き込み後"SCKE=1"になるまでウェイト)
- (3) "DCFM=1"、"DPRD=1" ("HSE=1"の設定は必要ありません。)
- (4) "USBE=1"
- (5) UTSTビットにテスト内容に応じた値を設定
- (6) テスト対象PORTのUACTビットに"1"を設定

HOSTモード時のUTSTビット変更手順は以下のとおりです。

- (1) (上記(6)の状態で) "UACT=0"、"USBE=0"
- (2) "USBE=1"
- (3) UTSTビットにテスト内容に応じた値を設定
- (4) テスト対象PORTの**UACT**ビットに"1"を設定

"Test\_SE0\_NAK"("1011")設定時は、"UACT=1"を設定したPORTに対しても本コントローラーはSOFパケットを 出力しません。

"Test\_Force\_Enable"("1101")設定時は、"UACT=1"を設定したPORTに対して、本コントローラーはSOFパケットを出力します。また、本モード設定時には、本コントローラーがHi-Speedディスコネクトを検出 (**DTCH**割り込みを検出) しても本コントローラーは検出に付随するハードウェア制御を行いません。

Host Controller機能選択時、**UTST**ビットを設定する場合は、すべてのPIPEの**PID**ビットに"NAK"を設定にしてください。

テストモード設定後、通常のUSB通信を行う場合は、ハードウェアリセットを実施してください。

## 2.6.1.2 Peripheral Controller 機能選択時

Peripheral Controller機能選択時は、Hi-Speed通信時のUSBホストからのSetFeatureリクエストに従って本ビットを書き込んでください。

Peripheral Controller機能選択時、本ビットに"0001"~"0100"を設定している時には、本コントローラーはサスペンド状態へ遷移しません。

テストモード設定後、通常のUSB通信を行う場合は、ハードウェアリセットを実施してください。



# 2.7 パスインタフェース制御

| •    | データヒ | <u> </u> | フィグし | ノーショ | ンレジス | スタ【P | INCFG | ] |   |   |   |   | <アドし | ノス:0E | EH>  |
|------|------|----------|------|------|------|------|-------|---|---|---|---|---|------|-------|------|
| 15   | 14   | 13       | 12   | 11   | 10   | 9    | 8     | 7 | 6 | 5 | 4 | 3 | 2    | 1     | 0    |
| LDRV |      |          |      |      |      |      |       |   |   |   |   |   |      |       | INTA |
| 0    | ?    | ?        | ?    | ?    | ?    | ?    | ?     | ? | ? | ? | ? | ? | ?    | ?     | 0    |
| -    | ?    | ?        | ?    | ?    | ?    | ?    | ?     | ? | ? | ? | ? | ? | ?    | ?     | -    |

| Bit  | Name                 | Function                                                       | S/W | H/W | Remarks |
|------|----------------------|----------------------------------------------------------------|-----|-----|---------|
| _    | LDRV<br>出力端子駆動電流制御   | 0:VIF=1.6-2.0V時<br>1:VIF=2.7-3.6V時                             | R/W | R   |         |
| 14-1 | 何も配置されていません。"0"に固定して | ください。                                                          |     |     |         |
| 0    | INTA<br>INT_Nアクティブ設定 | INT_N端子からの割り込み出力のアクティブ<br>を設定します。<br>0:Lowアクティブ<br>1:Highアクティブ | R/W | R   |         |

### <<Remarks>>

# 2.7.1 出力端子駆動電流制御ビット (LDRV)

VIF電源に合わせて本ビットの値を設定してください。 本ビットによる駆動電流制御対象の出力端子は以下のとおりです。

SD7-0、D15-0、INT\_N、DREQx\_N、DENDx\_N、SOF\_N端子

本ビットの設定は、ハードウェアリセット後に行い、本コントローラの動作中は変更しないでください。

## 2.7.2 INT\_Nアクティブ設定ピット (INTA)

制御用CPUの割り込み入力仕様にあわせて、INT\_N端子からの割り込み出力のアクティブを設定してください。

本ビットの設定は、ハードウェアリセット後に行い、本コントローラの動作中は変更しないでください。



DMA0CFGレジスタは、DMA0インタフェース用入出力端子、及びD0FIFOポートの制御を、DMA1CFGレジスタは、 DMA1インタフェース用入出力端子、及びD1FIFOポートの制御を行うレジスタです。

◆ DMA0ピンコンフィグレーションレジスタ【DMA0CFG】

<アドレス:10H> <アドレス:12H>

◆ DMA1ピンコンフィグレーションレジスタ【DMA1CFG】

|   | 15 | 14    | 13    | 12 | 11 | 10    | 9 | 8     | 7 | 6     | 5    | 4     | 3 | 2    | 1 | 0 |
|---|----|-------|-------|----|----|-------|---|-------|---|-------|------|-------|---|------|---|---|
|   |    | DREQA | BURST |    |    | DACKA |   | DFORM |   | DENDA | PKTM | DENDE |   | OBUS |   |   |
| ı | ?  | 0     | 0     | ?  | ?  | 0     | 0 | 0     | 0 | 0     | 0    | 0     | ? | 0    | ? | ? |
|   | ?  | -     | -     | ?  | ?  | -     | - | -     | - | - ]   | -    | -     | ? | -    | ? | ? |

| Bit       | Name                   | Function                                                                                                                                                     | S/W | H/W | Remarks |
|-----------|------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------|-----|-----|---------|
| 15        | 何も配置されていません。"0"に固定して   | ください。                                                                                                                                                        |     |     |         |
|           | DREQA<br>DREQx_N信号極性選択 | DREQx_N端子のアクティブを指定します。<br>0:Lowアクティブ<br>1:Highアクティブ                                                                                                          | R/W | R   |         |
|           | BURST<br>バーストモード       | DxFIFOに対してサイクルスチール転送でアクセスするかバースト転送でアクセスするかを指定します。 0:サイクルスチール転送 1:バースト転送                                                                                      | R/W | R   |         |
| 12-1<br>1 | 何も配置されていません。"0"に固定して   | てください。                                                                                                                                                       |     |     |         |
|           | DACKA<br>DACKx_N信号極性選択 | DACKx_N端子のアクティブを指定します。<br>0:Lowアクティブ<br>1:Highアクティブ                                                                                                          | R/W | R   |         |
| -         | DFORM<br>DMA転送信号選択     | DMAでFIFOバッファにアクセスする場合の制御信号を指定します 000: アドレス信号+RD_N/WRx_N信号を使用(CPUバス) 010: DACKx_N+RD_N/WRx_N信号を使用(CPUバス) 011: DACKx_N信号のみ使用(CPUバス) 100: DACKx_N信号を使用(SPLITバス) | R/W | R   |         |
| _         | DENDA<br>DENDx_N信号極性選択 | DENDx_N端子のアクティブを指定します。<br>0:Lowアクティブ<br>1:Highアクティブ                                                                                                          | R/W | R   |         |
| 5         | PKTM<br>DEND出力パケットモード  | DEND出力タイミングを指定します。 0:トランスファー単位にDENDx_N信号をアサート 1:バッファサイズ分のデータ転送毎に DENDx_N信号をアサート                                                                              | R/W | R   |         |
|           | DENDE<br>DENDx_N信号許可   | DENDx_N信号の入出力許可を行います。<br>0:DENDx_N信号禁止(Hi-z出力)<br>1:DENDx_N信号許可                                                                                              | R/W | R   |         |
| 3         | 何も配置されていません。"0"に固定して   |                                                                                                                                                              |     |     |         |
| 2         | OBUS<br>OBUS動作禁止       | OBUS動作の禁止を行います。<br>0:OBUSモードを許可<br>1:OBUSモードを禁止                                                                                                              | R/W | R   |         |
| 1-0       | 何も配置されていません。"0"に固定して   | <b>てください。</b>                                                                                                                                                |     |     |         |

#### <<Remarks>>

なし



#### 2.7.3 DMA信号制御

DMAインタフェースでデータ転送を行う場合は、DMAxCFGレジスタのBURSTビット、PKTMビット、DENDEビット、及びOBUSビットでユーザーシステムに合わせたDMAインタフェース動作選択 (DREQx\_N信号、及びDENDx\_N信号のアサート、ネゲート及びDMA転送モード設定)を行ってください。DMA信号は、後述のDxFIFOSELレジスタのCURPIPEビットで選択したPIPE (当該PIPE)に割り当てたFIFOバッファへのアクセスに対して有効です。当該PIPEのFIFOバッファがバッファレディ (BRDY)状態となったときに"DREQE=1"が設定されていれば、本コントローラーはDREQx\_N信号をアサートします。

#### 2.7.4 DREQx\_N信号極性選択ビット (DREQA)

本ビットにDREQx\_N端子のアクティブを設定してください。

本ビットは、当該FIFOポートに対する"CURPIPE=000"の時に設定してください。

### 2.7.5 パーストモードビット (BURST)

DMAコントローラーがDxFIFOに対してサイクルスチール転送を行う場合、本ビットに"0"を設定してください。本コントローラーはDREQx\_N信号を1ワード、または1バイトアクセスごとにネゲートします。

DMAコントローラーがDxFIFOに対してバースト転送を行う場合、本ビットに"1"を設定してください。本コントローラーはDREQx\_N信号をFIFOバッファ分のアクセスごとにネゲートします。

当該PIPEが通信中は、本ビットの変更を行わないでください。

### 2.7.6 DACKx\_N信号極性選択ビット (DACKA)

本ビットにDACKx\_N端子のアクティブを設定してください。

本ビットは、当該FIFOポートに対する"CURPIPE=000"の時に設定してください。

#### 2.7.7 DMA転送信号選択ビット (DFORM)

本ビットにDMAコントローラーでFIFOバッファにアクセスする場合の制御信号を設定してください。

本ビットは、当該FIFOポートに対する"CURPIPE=000"の時に設定してください。

#### 2.7.8 DENDx N信号極性選択ビット (DENDA)

本ビットにDENDx\_N端子のアクティブを設定してください。

本ビットは、当該FIFOポートに対する"CURPIPE=000"の時に設定してください。

# 2.7.9 DEND出力パケットモードビット (PKTM)

本ビットにDEND出力タイミングを設定してください。

本ビットに"0"を設定した場合、本コントローラーは以下 $(1) \sim (3)$ いずれかの条件が満たされた時にDENDx\_N信号をアサートします。

- (1) ショートパケットデータの読出し時の最後のリードアクセス時
- (2) トランザクションカウンタ (TRNCNT) で終了したデータの読出し時の最後のリードアクセス時
- (3) FIFOバッファが空の状態でZero-Lengthパケットを受信した時

本ビットに"1"を設定した場合、本コントローラーはFIFOバッファサイズ分のデータ転送毎にDENDx\_N出力をアサートします。

本ビットは、当該FIFOポートに対する"CURPIPE=000"の時に設定してください。



### 2.7.10 DENDx\_N信号の入出力許可ビット (DENDE)

本ビットにDENDx\_N端子の入出力禁止/許可を設定してください。

本ビットは、当該FIFOポートに対する"CURPIPE=000"の時に設定してください。

## 2.7.11 OBUS動作禁止ビット (OBUS)

本ビットにOBUS動作の許可/禁止を設定してください。

本ビットに"0"を設定した場合、スプリットバスのSD7-0とDENDが常時出力または常時入力許可状態になります。

本ビットに"1"を設定した場合、スプリットバスのSD7-0とDENDx\_Nが、DACKx\_Nがアクティブの期間のみ出力 または入力許可状態になります。

D0FIFO及び、D1FIFOを共にスプリットバスにて使用する時には、すべてのOBUSビットを"1"に設定してくださ ١١。



### 2.8 FIFOポート

◆ CFIFOポートレジスタ【CFIFO】

<アドレス:14H>

◆ D0FIFOポートレジスタ【D0FIFO】

<アドレス:18H>

◆ D1FIFOポートレジスタ【D1FIFO】

<アドレス:1CH>

| 15 |          | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 |
|----|----------|----|----|----|----|----|---|---|---|---|---|---|---|---|---|---|
|    | FIFOPORT |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |
| 0  |          | 0  | 0  | 0  | 0  | 0  | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 |
| -  |          | -  | -  | -  | -  | -  | - | - | - | - | - | - | - | - | - | - |

| Bit | Name    | Function                                                            | S/W | H/W | Remarks |
|-----|---------|---------------------------------------------------------------------|-----|-----|---------|
|     | FIFOポート | 本ビットにアクセススことにより、FIFOバッファからの受信データ読み出し、もしくはFIFOバッファへの送信データの書き込みを行います。 |     | R/W |         |

#### <<Remarks>>

なし

#### 2.8.1 FIFOポート制御

本コントローラーの送受信バッファメモリはFIFO構造 (FIFOバッファ) となっています。FIFOバッファへのアクセスはFIFOポートレジスタを使用してください。FIFOポートはCFIFOポート、D0FIFOポート、及びD1FIFOポートの3ポートがあります。各FIFOポートはFIFOバッファへのデータ読み書きを行うポートレジスタ (CFIFO、D0FIFO、及びD1FIFO)、FIFOポートに割り当てるパイプを選択するレジスタ (CFIFOSEL、D0FIFOSEL、及びD1FIFOSEL)、コントロールレジスタ (CFIFOCTR、D0FIFOCTR、及びD1FIFOCTR) で構成されます。

各FIFOポートには下記に示す特徴があります。

- (1) DCP用FIFOバッファへのアクセスはCFIFOポートを通して行ってください。
- (2) DMA転送によるFIFOバッファアクセスは、DxFIFOポートを通して行ってください。
- (3) CPUによるDxFIFOポートアクセスも可能です。
- (4) FIFOポート固有の機能を使用する場合は、CURPIPEビットに設定するPIPE番号 (選択パイプ) を変更できません。 (DMA関連端子への信号入出力等)
- (5) FIFOポートを構成するレジスタ群は、他のFIFOポートに影響を与えることはありません。
- (6) 同一PIPEを別々のFIFOポートへ割り当てないで下さい。
- (7) FIFOバッファの状態には、アクセス権がCPU側にある場合とSIE側にある場合の2種類があります。 バッファメモリのアクセス権がSIE側にある場合は、CPUからのアクセスはできません。

## 2.8.2 FIFOポートビット (CFIFO、D0FIFO、及びD1FIFO)

ソフトウェアが本レジスタにアクセスを行うことにより、本コントローラーは各選択レジスタ (CFIFOSEL、D0FIFOSEL、またはD1FIFOSEL)のCURPIPEビットに設定したPIPE番号に割り当てたFIFOバッファへのアクセスを行います。

本レジスタへのアクセスは、各コントロールレジスタ (CFIFOCTR、D0FIFOCTR、またはD1FIFOCTR)のFRDYビットが"1"を示している(または本コントローラーがDREQx\_Nをアサートしている)時のみ可能です。

本レジスタの有効ビットは、MBWビットの設定値、及び、BIGENDビットの設定値により異なります。有効ビットを、表 2.13に示します。

| MBW 設定値 | BIGEND 設定値 | b15-b8  | b7-b0   |
|---------|------------|---------|---------|
| 0       | 0          | 無効      | N+0 バイト |
| 0       | 1          | N+0 バイト | 無効      |
| 1       | 0          | N+1 バイト | N+0 バイト |
|         |            |         |         |

N+0 バイト

N+1 バイト

表 2.13 FIFOポートの有効ビット

"MBW =0"を設定した場合、表 2.13に示すN+0バイト側へのアクセスが可能です。

読み出し時は、アドレス14H、18H、1AHへの16bit幅アクセスを行い、表 2.13に示すN+0バイト側の8bitをデータとして使用してください。

書き込み時は、アドレス14H、18H、1AHへの16bit幅アクセス(WR0\_N及びWR1\_Nを共にアサートによるアクセス。この場合、本コントローラーは表 2.13に示すN+1バイト側を無視します)、または、アドレス14H、18H、1AHへの8bit幅アクセス(WR0\_Nのみをアサート)を行ってください。

"MBW=1"を設定した場合、表 2.13に示すN+0バイト側へのアクセスが可能です。

読み出し時は、アドレス14H、18H、1AHへの16bit幅アクセスを行ってください。

書き込み時は、アドレス14H、18H、1AHへの16bit幅アクセス(WR0\_N及びWR1\_Nを共にアサートによるアクセス)を行ってください。

アドレス15H、19H、1BHへのアクセスは行わないでください。



| •    | ▶ CFIFOポート選択レジスタ【CFIFOSEL】 |    |    |    |     |   |        |   |   |      |   | <アドレス:20H> |     |      |   |
|------|----------------------------|----|----|----|-----|---|--------|---|---|------|---|------------|-----|------|---|
| 15   | 14                         | 13 | 12 | 11 | 10  | 9 | 8      | 7 | 6 | 5    | 4 | 3          | 2   | 1    | 0 |
| RCNT | REW                        |    |    |    | MBW |   | BIGEND |   |   | ISEL |   |            | CUR | PIPE |   |
| 0    | 0                          | ?  | ?  | ?  | 0   | ? | 0      | ? | ? | 0    | ? | 0          | 0   | 0    | 0 |
| -    | -                          | ?  | ?  | ?  | -   | ? | -      | ? | ? | -    | ? | -          | -   | -    | - |

| Bit | Name                                         | Function                            | S/W     | H/W     | Remarks |
|-----|----------------------------------------------|-------------------------------------|---------|---------|---------|
| 15  | RCNT<br>リードカウントモード                           | CFIFOCTR の DTLN の読み出しモードを指定         | R/W     | R       |         |
|     |                                              | します。<br> 0: 全受信データ読み出しで DTLN ビットクリ  |         |         |         |
|     |                                              | ア                                   |         |         |         |
|     |                                              | 1: 受信データ読み出し毎に DTLN ビットカウ           |         |         |         |
| 14  | REW                                          | ントダウン<br>バッファポインタのリワインドを行う場合に       | D(0)/M  | D/M/O   |         |
| 14  | NEW<br> バッファポインタリワインド                        | ハッファホイフタのウワイフトを行う場合に<br> "1"を指定します。 | K(U)/VV | K/VV(U) |         |
|     |                                              | 0:バッファポインタリワインドしない                  |         |         |         |
|     |                                              | 1:バッファポインタリワインドする                   |         |         |         |
|     | 何も配置されていません。"0"に固定し <sup>-</sup>             | てください。                              |         |         |         |
| 10  | MBW                                          | CFIFOポートへのアクセスビット幅を指定し              | R/W     | R       |         |
|     | CFIFOポートアクセスビット幅<br>                         | ます。                                 |         |         |         |
|     |                                              | 0:8ビット幅<br>1:16ビット幅                 |         |         |         |
| 9   | <br>  何も配置されていません。"0"に固定し <sup>-</sup>       | 1 111                               |         |         |         |
|     | BIGEND                                       | CFIFOポートのバイトエンディアンを指定し              | R/W     | R       |         |
|     | FIFOポートエンディアン制御                              | ます。                                 |         |         |         |
|     |                                              | 0:リトルエンディアン                         |         |         |         |
|     |                                              | 1:ビッグエンディアン                         |         |         |         |
|     | 何も配置されていません。"0"に固定し                          | てください。                              |         |         |         |
| 5   | ISEL                                         | CURPIPEビットにDCP選択時のFIFOポート           | R/W     | R       |         |
|     | DCP選択時のFIFOポートアクセス方向                         |                                     |         |         |         |
|     |                                              | 0:バッファメモリ読み出し選択<br>1:バッファメモリ書き込み選択  |         |         |         |
| 4-3 | <u> </u><br>何も配置されていません。"0"に固定し <sup>-</sup> |                                     |         |         | l       |
|     | CURPIPE                                      | CFIFOポートにアクセスするPIPE番号を指定            | R/W     | R       |         |
| _   | FIFOポートアクセスパイプ指定                             | します。                                |         |         |         |
|     |                                              | 0000 : DCP                          |         |         |         |
|     |                                              | 0001 : PIPE1                        |         |         |         |
|     |                                              | 0010 : PIPE2                        |         |         |         |
|     |                                              | 1000 : PIPE8                        |         |         |         |
|     |                                              | 1001 : PIPE9                        |         |         |         |
|     | I                                            | I.                                  |         |         |         |

### <<Remarks>>

なし



### 2.8.3 リードカウントモード (RCNT)

本ビットに"0"を設定した場合、CURPIPEビットに指定したPIPE (指定PIPE) に割り付けたFIFOバッファの全受信データ読み出し終了時 (ダブルバッファの場合は一面分の読み出し終了時) に、本コントローラーはCFIFOCTRレジスタのDTLNビットを"0"にクリアします。

本ビットに"1"を設定した場合、指定PIPEに割り付けたFIFOバッファから受信データ読み出し毎に、本コントローラーはCFIFOCTRレジスタのDTLNビットをカウントダウンします。

### 2.8.4 バッファポインタリワインド (REW)

指定PIPEが受信方向の場合に、FIFOバッファの読み出し中に本ビットに"1"を設定すると、FIFOバッファの最初のデータから読み出しを行うことができます(ダブルバッファの場合は読み出し中の一面の最初のデータからの再読み出し可能状態になります)。ソフトウェアが本ビットに"1"を書き込んだ後、本コントローラーは本ビットを"0"に戻します。

"REW=1"設定とCURPIPEビットの設定変更を同時に行わないでください。

"REW=1"設定を実行する時には、かならず"FRDY=1"である事を確認してから実施してください。

送信方向のPIPEに対してFIFOバッファの最初のデータから書き込みをやり直す場合は、**BCLR**ビットを使用してください。

### 2.8.5 CFIFOポートアクセスピット幅 (MBW)

本ビットにCFIFOポートへのアクセスビット幅を設定してください。

CURPIPEビットに指定したPIPEが受信方向の場合、本ビットに"1"を設定して読み出しを開始した時には、すべてのデータの読み出しが完了するまでMBWビットの"1"から"0"への変更を行わないでください。DTLNビットが奇数の場合には、最後の1バイト読み出し前に"MBW=0"を設定して8bit長の変数で読み出すか、または、"MBW=1"のまま16bitで読み出し余分の1バイトを破棄してください。

指定PIPEが受信方向の場合、CURPIPEビットとMBWビットを同時に設定してください。

指定PIPEが送信方向の場合、奇数バイト数データの書き込みを行う時には、本ビットに"1"を設定して書き込みを開始した時には、最後の1バイト書き込み前に"MBW=0"を設定して16bit長の変数で書き込む(書き込まれるデータについては2.8.2を参照してください)か、または、"MBW=1"のまま8bit長の変数で書き込みを行ってください("BIGEND=0"の場合はWR0\_Nストロー部で、"BIGEND=1"の場合はWR1\_Nストローブで書き込んでください)。

### 2.8.6 CFIFOポート バイトエンディアン制御ビット (BIGEND)

本ビットにCFIFOポートのバイトエンディアンを設定してください。 詳細は、2.8.2を参照してください。

### 2.8.7 DCP選択時のFIFOポートアクセス方向指定ビット (ISEL)

指定PIPEがDCPの時に、本ビットを変更する時は、本ビットへの書き込み後、読み出しを行い、書き込み値と読み出し値が一致することを確認してから、次の処理に進んでください。

FIFOバッファへのアクセスの途中で本ビットの設定を変更した場合、それまでのアクセスを保持し、本ビットの設定を書き戻し後、続けてアクセスする事ができます。

本ビットの設定は、CURPIPEビットの設定と同時に行ってください。

### 2.8.8 FIFOポートアクセスパイプ指定ピット (CURPIPE)

page 42 of 183

CFIFOポート経由で、データの読み出しまたは書き込みを行いたいPIPE番号を設定してください。

本ビットを変更する時は、本ビットへの書き込み後、読み出しを行い、書き込み値と読み出し値が一致することを確認してから、次の処理に進んでください。



**CFIFOSEL**レジスタ、**D0FIFOSEL**レジスタおよび**D1FIFOSEL**レジスタの**CURPIPE**ビットに同じPIPEを設定しないでください。

FIFOバッファへのアクセスの途中で本ビットの設定を変更した場合、それまでのアクセスを保持し、本ビットの書き戻し後、続けてアクセスする事ができます。



◆ D0FIFOポート選択レジスタ【D0FIFOSEL】

<アドレス:28H> <アドレス:2CH>

| • | D1FIFOポー | ト選択レジスタ | 【D1FIFOSEL】 |
|---|----------|---------|-------------|
|---|----------|---------|-------------|

| 15   | 14  | 13    | 12    | 11 | 10  | 9 | 8      | 7 | 6 | 5 | 4 | 3 | 2    | 1    | 0 |
|------|-----|-------|-------|----|-----|---|--------|---|---|---|---|---|------|------|---|
| RCNT | REW | DCLRM | DREQE |    | MBW |   | BIGEND |   |   |   |   |   | COIN | PIPE |   |
| 0    | 0   | 0     | 0     | ?  | 0   | ? | 0      | ? | ? | ? | ? | 0 | 0    | 0    | 0 |
| -    | -   | -     | -     | ?  | -   | ? | -      | ? | ? | ? | ? | - | -    | -    | - |

| Bit | Name                                 | Function                           | S/W     | H/W     | Remarks |
|-----|--------------------------------------|------------------------------------|---------|---------|---------|
| 15  | RCNT                                 | Dx_FIFOCTR DTLN の読み出しモードを指定        | R/W     | R       |         |
|     | リードカウントモード                           | します。                               |         |         |         |
|     |                                      | 0: 全受信データ読み出しで DTLN ビットクリ          |         |         |         |
|     |                                      | P                                  |         |         |         |
|     |                                      | 1: 受信データ読み出し毎に DTLN ビットカウ          |         |         |         |
| 14  | REW                                  | ントダウン                              | D(O)AA  | DAM(O)  |         |
|     | rcvv<br>バッファポインタリワインド                | バッファポインタのリワインドを行う場合に<br>"1"を指定します。 | K(U)/VV | K/VV(U) |         |
|     |                                      | 「で疳圧しより。<br>  0:バッファポインタリワインドしない   |         |         |         |
|     |                                      | 1:バッファポインタリワインドする                  |         |         |         |
| 13  | DCLRM                                | 指定パイプのデータ読み出し後自動バッファ               | R/W     | R       |         |
|     | 指定パイプのデータ読み出し後自動バ                    | メモリクリアの禁止/許可を指定します。                |         |         |         |
|     | ッファメモリクリアモード                         | 0:自動バッファクリアモード禁止                   |         |         |         |
|     |                                      | 1:自動バッファクリアモード許可                   |         |         |         |
|     | DREQE                                | DREQ信号出力禁止/許可を指定します。               | R/W     | R       |         |
|     | DREQ信号出力許可                           | 0:出力禁止                             |         |         |         |
|     |                                      | 1:出力許可                             |         |         |         |
|     | 何も配置されていません。"0"に固定し <sup>-</sup>     |                                    | D 244   |         |         |
|     | MBW<br>FIFOポートアクセスビット幅               | FIFOポートアクセスビット幅を指定します。             | R/W     | R       |         |
|     | FIFOがードアクセスこッド順<br>                  | 0:8ビット幅<br>1:16ビット幅                |         |         |         |
| 9   | <br>何も配置されていません。"0"に固定し <sup>-</sup> |                                    |         |         |         |
|     | PIGEND                               | と、たさい。<br> 各FIFOポートのバイトエンディアンを指定し  | R/W     | R       |         |
|     | FIFOポートエンディアン制御                      | ます。                                | 10,00   | 1       |         |
|     |                                      | 0:リトルエンディアン                        |         |         |         |
|     |                                      | 1:ビッグエンディアン                        |         |         |         |
| 7-4 | 何も配置されていません。"0"に固定し <sup>-</sup>     |                                    | 1       | 1       |         |
| 3-0 | CURPIPE                              | 0000:指定なし                          | R/W     | R       |         |
|     | FIFOポートアクセスパイプ指定                     | 0001 : PIPE1                       |         |         |         |
|     |                                      | 0010 : PIPE2                       |         |         |         |
|     |                                      | LOGG BIRES                         |         |         |         |
|     |                                      | 1000 : PIPE8                       |         |         |         |
|     |                                      | 1001 : PIPE9                       |         |         |         |

### <<Remarks>>

なし

### 2.8.9 リードカウントモード (RCNT)

本ビットに"0"を設定した場合、CURPIPEビットに指定したPIPE (指定PIPE) に割り付けたFIFOバッファの全受信 データ読み出し終了時 (ダブルバッファの場合は一面分の読み出し終了時) に、本コントローラーはDxFIFOCTRレジス タのDTLNビットを"0"にクリアします。

本ビットに"1"を設定した場合、指定PIPEに割り付けたFIFOバッファからの受信データ読み出し毎に、本コントロー ラーはDxFIFOCTRレジスタのDTLNビットをカウントダウンします。

BFREビットに"1"を設定してDxFIFOにアクセスを行う場合は、本ビットに"0"を設定してください。



### 2.8.10 バッファポインタリワインド (REW)

指定PIPEが受信方向の場合に、FIFOバッファの読み出し中に本ビットに"1"を設定すると、FIFOバッファの最初のデータから読み出しを行うことができます(ダブルバッファの場合は読み出し中の一面の最初のデータからの再読み出し可能状態になります)。ソフトウェアが本ビットに"1"を書き込んだ後、本コントローラーは本ビットを"0"に戻します。

"REW=1"設定とCURPIPEビットの設定変更を同時に行わないでください。

"REW=1"設定を実行する時には、かならず"FRDY=1"である事を確認してから実施してください。

BFREビットに"1"を設定してDxFIFOにアクセスを行う場合は、ショートパケットデータを読み出し終えた状態で本ビットに"1"を設定しないでください。

送信方向のPIPEに対してFIFOバッファの最初のデータから書き込みをやり直す場合は、BCLRビットを使用してください。

### 2.8.11 自動FIFOパッファクリア 禁止/許可ピット (DCLRM)

指定PIPEのデータ読み出し後自動FIFOバッファクリアの禁止/許可を設定してください。本ビットに"1"を設定した場合、指定PIPEに割り当てたFIFOバッファが空の状態でZero-Length packetを受信した時、または"BFRE=1"設定時にショートパケット受信しデータ読出しを完了時に、FIFOバッファへの"BCLR=1"処理を本コントローラーが行います。

"BRDYM=1"に設定して本コントローラーを使用する時には、必ず本ビットに"0"を設定してください。

#### 2.8.12 DREQx N出力禁止/許可ビット (DREQE)

本ビットに、DxREQ\_N信号の出力禁止/許可を設定してください。

DxREQ\_N信号の出力を許可する場合、CURPIPEビット設定後に本ビットに"1"を設定してください。CURPIPEビット設定を変更するときには、本ビットに"0"を設定した後で変更を行ってください。

### 2.8.13 DxFIFOポートアクセスピット幅 (MBW)

本ビットにDxFIFOポートへのアクセスビット幅を設定してください。

詳細は、2.8.5を参照してください。

#### 2.8.14 DxFIFOポート バイトエンディアン制御ピット (BIGEND)

本ビットにDxFIFOポートのバイトエンディアンを設定してください。 詳細は、2.8.2を参照してください。

## 2.8.15 FIFOポートアクセスパイプ指定ビット (CURPIPE)

DxFIFOポート経由で、データの読み出しまたは書き込みを行いたいPIPE番号を設定してください。

本ビットを変更する時は、本ビットへの書き込み後、読み出しを行い、書き込み値と読み出し値が一致することを確認 してから、次の処理に進んでください。

**CFIFOSEL**レジスタ、**D0FIFOSEL**レジスタおよび**D1FIFOSEL**レジスタの**CURPIPE**ビットに同じPIPEを設定しないでください。

FIFOバッファへのアクセスの途中で本ビットの設定を変更した場合、それまでのアクセスを保持し、本ビットの書き戻し後、続けてアクセスする事ができます。



0

BVAL BCLR FRDY

0

0

◆ CFIFOポートコントロールレジスタ【CFIFOCTR】

◆ D0FIFOポートコントロールレジスタ【D0FIFOCTR】

<アドレス:22H> <アドレス:2AH>

◆ D1FIFOポートコントロールレジスタ【D1FIFOCTR】

0

10

0

0

0

0

|   | < | アド | シレ | ス:2 | EF | -I> |  |
|---|---|----|----|-----|----|-----|--|
| 3 |   | 2  |    | 1   |    | 0   |  |
|   |   |    |    |     |    |     |  |

0

0

0

4

0

0

DTLN

0

0

| Bit  | Name                 | Function                                                                              | S/W           | H/W    | Remarks |
|------|----------------------|---------------------------------------------------------------------------------------|---------------|--------|---------|
| 15   | BVAL<br>バッファメモリ有効フラグ | CURPIPEに指定したPIPE(当該PIPE)のCPU<br>側のFIFOバッファの書き込み終了時に"1"を<br>指定します。<br>0:無効<br>1:書き込み終了 | R/<br>W(1)    | R/W    |         |
|      | BCLR<br>CPUバッファクリア   | 当該PIPEのCPU側のFIFOバッファをクリア<br>する場合に"1"を指定します。<br>0:無効<br>1:CPU側バッファメモリクリア               | R(0)/<br>W(1) | R/W(0) |         |
|      | FRDY<br>FIFOポートレディ   | FIFOポートにアクセス可能かどうかが表示されます。<br>0:FIFOポートアクセス不可<br>1:FIFOポートアクセス可能                      | R             | W      |         |
| 12   | 何も配置されていません。"0"に固定し  | てください。                                                                                |               |        |         |
| 11-0 | DTLN<br>受信データ長       | 当該PIPEのFIFOバッファの受信データ長が<br>表示されます。                                                    | R             | W      |         |

#### <<Remarks>>

なし

### 2.8.16 パッファメモリ有効フラグ (BVAL)

**CURPIPE**ビットに指定したPIPE(指定PIPE)が送信方向の時、以下の場合に本ビットに"1"を設定してください。本コントローラーはCPU側のFIFOバッファをSIE側にし、送信可能状態にします。

- (1) ショートパケットの送信を行いたい時、データ書き込み終了時に本ビットに"1"を設定
- (2) Zero-Lengthパケットの送信を行いたい時、FIFOへデータを書き込む前に本ビットに"1"を設定
- (3) 連続転送モードのPIPEに対して、MaxPacketSizeの自然数倍かつBufferSize未満のデータ書き込み後に本ビットに"1"を設定

非連続転送モードのPIPEに対してMaxPacketSize分のデータを書き込むと、本コントローラーが本ビットを"1"にし、CPU側のFIFOバッファをSIE側にして、送信可能状態にします。

本ビットへの"1"書き込みは、本コントローラーが"FRDY=1"を示している時に実施してください。

指定PIPEが受信方向の時には、本ビットへの"1"書き込みを行わないでください。



### 2.8.17 CPUパッファクリアピット (BCLR)

本ビットに"1"を設定すると、本コントローラーは指定PIPEにアサインされているFIFOバッファのうち、CPU側の FIFOバッファをクリアします。

指定PIPEにアサインされているFIFOバッファがダブルバッファ設定の場合で、両面共に読み出し可能状態である場合 でも、本コントローラーは片面のFIFOバッファのみをクリアします。

指定PIPEがDCPの場合は、FIFOバッファがCPU側、SIE側にかかわらず、"BCLR=1"設定により本コントローラーは FIFOバッファをクリアします。SIE側のバッファをクリアする時には、DCPのPIDビットを必ず"NAK"に設定した後で "BCLR=1"を行ってください。

指定PIPEが送信方向の場合、BVALビットとBCLRビットへ同時に"1"を書き込んだ場合には、本コントローラーはそ れ以前に書き込んだデータをクリアし、Zero-Length パケットを送信可能な状態にします。

指定PIPEがDCP以外の場合、本ビットへの"1"書き込みは、本コントローラーが"FRDY=1"を示している時に実施して ください。

### 2.8.18 FIFOポートレディビット (FRDY)

CPU (DMAC) からのFIFOポートへのアクセス可否を、本コントローラが本ビットに表示します。

以下の場合には、本コントローラーは"FRDY=1"を表示しますが、読み出すべきデータがないためFIFOポートからの データ読み出しはできません。これらのケースでは、"BCLR=1"を設定してFIFOバッファのクリアを行い、次のデータ 送受信を行える状態にしてください。

- (1) 指定PIPEにアサインされているFIFOバッファが空の状態でZero-Length パケット受信した場合。
- (2) "BFRE=1"設定時に、ショートパケットを受信し、データ読み出しを完了した時。

#### 2.8.19 受信データ長ピット (DTLN)

本コントローラは、本ビットに受信データ長を表示します。FIFOバッファ読み出し中の本ビットの値は、RCNTビッ トの設定値によって以下のように異なります。

(1) "RCNT=0"設定時:

CPU (DMAC) がFIFOバッファ1面分の受信データを読み出し完了するまで、本コントローラーは受信データ長を 本ビットに表示します。

"BFRE=1"設定時には、読み出しが完了しても"BCLR=1"を行うまでは本コントローラーは受信データ長を保持し ます。

(2) "RCNT=1"設定時:

読み出し毎に本コントローラーはDTLNビットの表示をダウンカウントします。 ("MBW=0"設定時は-1、"MBW=1"設定時は-2ずつダウンカウント)

1面分のFIFOバッファ読み出し完了時に、本コントローラーは"DTLN=0"を表示します。ただし、ダブルバッファ設定 時かつFIFOバッファ1面分の受信データの読み出しを完了する前にもう1面分のFIFOバッファに受信完了した場合は、先 の1面分の読み出し完了時に後の1面分の受信データ長をDTLNビットに表示します。

"RCNT=1"設定時に、FIFOバッファ読み出し途中で本ビットの値を読み出す時には、FIFOポートへのリードサイクル 後150ns後までに本コントローラーは本ビットの更新値を表示します。



# 2.9 割り込み許可

| ◆ 割り込み許可レジスタ0【INTENB0】 <アドレス:30H> |      |      |      |      |       |       |       |   |   |   |   | H> |   |   |   |
|-----------------------------------|------|------|------|------|-------|-------|-------|---|---|---|---|----|---|---|---|
| 15                                | 14   | 13   | 12   | 11   | 10    | 9     | 8     | 7 | 6 | 5 | 4 | 3  | 2 | 1 | 0 |
| VBSE                              | RSME | SOFE | DVSE | CTRE | BEMPE | NRDYE | BRDYE |   |   |   |   |    |   |   |   |
| 0                                 | 0    | 0    | 0    | 0    | 0     | 0     | 0     | ? | ? | ? | ? | ?  | ? | ? | ? |
| -                                 | -    | -    | -    | -    | -     | -     | -     | ? | ? | ? | ? | ?  | ? | ? | ? |

| Bit | Name                             | Function                                                          | S/W | H/W | Remarks             |
|-----|----------------------------------|-------------------------------------------------------------------|-----|-----|---------------------|
| 15  | VBSE<br>VBUS割り込み許可               | VBINT割り込み検出時のINT_Nアサートの禁止/許可を指定します。<br>0:割り込み出力禁止<br>1:割り込み出力許可   | R/W | R   |                     |
| 14  | RSME<br>レジューム割り込み許可              | RESM割り込み検出時のINT_Nアサートの禁止/許可を指定します。<br>0:割り込み出力禁止<br>1:割り込み出力許可    | R/W | R   | P<br>(H時"0"<br>を設定) |
| 13  | SOFE<br>フレーム番号更新割り込み許可           | SOF割り込み検出時のINT_Nアサートの禁止/<br>許可を指定します。<br>0:割り込み出力禁止<br>1:割り込み出力許可 | R/W | R   |                     |
| 12  | DVSE<br>デバイスステート遷移割り込み許可         | DVST割り込み検出時のINT_Nアサートの禁止/許可を指定します。<br>0:割り込み出力禁止<br>1:割り込み出力許可    | R/W | R   | P<br>(H時"0"<br>を設定) |
| 11  | CTRE<br>コントロール転送ステージ遷移割り込<br>み許可 | CTRT割り込み検出時のINT_Nアサートの禁止/許可を指定します。<br>0:割り込み出力禁止<br>1:割り込み出力許可    | R/W | R   | P<br>(H時"0"<br>を設定) |
|     | BEMPE<br>バッファエンプティ割り込み許可         | BEMP割り込み検出時のINT_Nアサートの禁止/許可を指定します。<br>0:割り込み出力禁止<br>1:割り込み出力許可    | R/W | R   |                     |
|     | NRDYE<br>バッファノットレディ応答割り込み許<br>可  | NRDY割り込み検出時のINT_Nアサートの禁止/許可を指定します。<br>0:割り込み出力禁止<br>1:割り込み出力許可    | R/W | R   |                     |
|     | BRDYE<br>パッファレディ割り込み許可           | BRDY割り込み検出時のINT_Nアサートの禁止/許可を指定します。 0:割り込み出力禁止 1:割り込み出力許可          | R/W | R   |                     |
| 7-0 | 何も配置されていません。"0"に固定し              | てください。                                                            |     |     |                     |

### <<Remarks>>



<sup>\*</sup> RESM ビット、DVSE ビット、及び CTRE ビットは Peripheral Controller 機能選択時のみ設定が可能です。Host Controller 機 能選択時は許可を行わないでください。

#### ◆ 割り込み許可レジスタ1【INTENB1】

| •     | ◆ 割り込み許可レジスタ1【INTENB1】 |    |       |        |    |   |   |   |         |       |       |   | <アドし | ノス:32 | !H> |
|-------|------------------------|----|-------|--------|----|---|---|---|---------|-------|-------|---|------|-------|-----|
| 15    | 14                     | 13 | 12    | 11     | 10 | 9 | 8 | 7 | 6       | 5     | 4     | 3 | 2    | 1     | 0   |
| OVRCR | E BCHGE                |    | DTCHE | ATTCHE |    |   |   |   | EOFERRE | SIGNE | SACKE |   |      |       |     |
| 0     | 0                      | ?  | 0     | 0      | ?  | ? | ? | ? | 0       | 0     | 0     | ? | ?    | ?     | ?   |
| -     | -                      | ?  | -     | -      | ?  | ? | ? | ? | -       | -     | -     | ? | ?    | ?     | ?   |

| Bit  | Name                                        | Function                                                                              | S/W | H/W | Remarks             |
|------|---------------------------------------------|---------------------------------------------------------------------------------------|-----|-----|---------------------|
|      | OVRCRE<br>PORT0 OVRCR 割り込み許可                | PORT0 OVRCR 割り込み検出時の INT_N ア<br>サートの禁止/許可を指定します。<br>0:割り込み出力禁止<br>1:割り込み出力許可          | R/W | R   | H<br>(P時"0"<br>を設定) |
|      | BCHGE<br>PORT0 USB バス変化割り込み許可               | PORT0 BCHG 割り込み検出時の INT_N ア<br>サートの禁止/許可を指定します。<br>0:割り込み出力禁止<br>1:割り込み出力許可           | R/W | R   | H<br>(P時"0"<br>を設定) |
|      | 何も配置されていません。"0"に固定し <sup>-</sup>            | てください。                                                                                |     |     |                     |
|      | DTCHE<br>PORT0 切断検出割り込み許可                   | PORT0 DTCH 割り込み検出時の INT_N アサートの禁止/許可を指定します(HOST 時のみ許可可能)。<br>0:割り込み出力禁止<br>1:割り込み出力許可 | R/W | R   | H<br>(P時"0"<br>を設定) |
|      | ATTCHE<br>PORT0 接続検出割り込み許可                  | PORT0 ATTCH 割り込み検出時の INT_N ア<br>サートの禁止/許可を指定します。<br>0:割り込み出力禁止<br>1:割り込み出力許可          | R/W | R   | H<br>(P時"0"<br>を設定) |
| 10-7 | 何も配置されていません。"0"に固定し <sup>-</sup>            | てください。                                                                                |     |     |                     |
|      |                                             |                                                                                       |     |     |                     |
| _    | EOFERRE<br>PORT0 EOF エラー検出割り込み許可            | PORT0 EOFERR 割り込み検出時の INT_N アサートの禁止/許可を指定します。<br>0:割り込み出力禁止<br>1:割り込み出力許可             | R/W | R   | H<br>(P時"0"<br>を設定) |
|      | SIGNE<br>PORT0 セットアップトランザクション<br>エラー割り込み許可  | PORT0 SIGN 割り込み検出時の INT_N アサートの禁止/許可を指定します。<br>0:割り込み出力禁止<br>1:割り込み出力許可               | R/W | R   | H<br>(P時"0"<br>を設定) |
|      | SACKE<br>PORT0 セットアップトランザクション<br>正常応答割り込み許可 | PORT0 SACK 割り込み検出時の INT_N ア<br>サートの禁止/許可を指定します。<br>0:割り込み出力禁止<br>1:割り込み出力許可           | R/W | R   | H<br>(P時"0"<br>を設定) |
| 3-0  | 何も配置されていません。"0"に固定し <sup>-</sup>            | てください。                                                                                |     |     |                     |

### <<Remarks>>



<sup>\*</sup> OVRCRE ビットを除く INTENB1 レジスタよる割り込み許可は、Host Controller 機能選択時のみ設定が可能です。Peripheral Controller 機能選択時は許可を行わないでください。

<sup>\*</sup> OVRCRE ビットによる割り込み許可は、Host Controller 機能選択時または、OTG の A-Devcie として本コントローラーを動作 させる場合の Peripheral Controller 機能選択時に、設定が可能です。

#### ◆ 割り込み許可レジスタ2【INTENB2】

| •      | 割り込   | み許可 | レジスタ  | 72 [IN] | ΓENB2 | 1 |   |   |         |   |   |   | <アドし | ノス:34 | H> |
|--------|-------|-----|-------|---------|-------|---|---|---|---------|---|---|---|------|-------|----|
| 15     | 14    | 13  | 12    | 11      | 10    | 9 | 8 | 7 | 6       | 5 | 4 | 3 | 2    | 1     | 0  |
| OVRCRE | BCHGE |     | DTCHE | ATTCHE  |       |   |   |   | EOFERRE |   |   |   |      |       |    |
| 0      | 0     | ?   | 0     | 0       | ?     | ? | ? | ? | 0       | ? | ? | ? | ?    | ?     | ?  |
| -      | -     | ?   | -     | -       | ?     | ? | ? | ? | -       | ? | ? | ? | ?    | ?     | ?  |

| Bit  | Name                             | Function                                                                           | S/W | H/W | Remarks             |
|------|----------------------------------|------------------------------------------------------------------------------------|-----|-----|---------------------|
|      | OVRCRE<br>PORT1 OVRCR 割り込み許可     | PORT1 OVRCR 割り込み検出時の INT_N ア<br>サートの禁止/許可を指定します。<br>0:割り込み出力禁止<br>1:割り込み出力許可       | R/W | R   | H<br>(P時"0"<br>を設定) |
|      | BCHGE<br>PORT1 USB バス変化割り込み許可    | PORT1 BCHG 割り込み検出時の INT_N ア<br>サートの禁止/許可を指定します。<br>0:割り込み出力禁止<br>1:割り込み出力許可        | R/W | R   | H<br>(P時"0"<br>を設定) |
| 13   | 何も配置されていません。"0"に固定して             | てください。                                                                             |     |     |                     |
|      | DTCHE<br>PORT1 切断検出割り込み許可        | PORT1 DTCH割り込み検出時のINT_Nアサートの禁止/許可を指定します(HOST 時のみ許可可能)。<br>0:割り込み出力禁止<br>1:割り込み出力許可 | R/W | R   | H<br>(P時"0"<br>を設定) |
|      | ATTCHE<br>PORT1 接続検出割り込み許可       | PORT1 ATTCH 割り込み検出時の INT_N ア<br>サートの禁止/許可を指定します。<br>0:割り込み出力禁止<br>1:割り込み出力許可       | R/W | R   | H<br>(P時"0"<br>を設定) |
| 10-7 | 何も配置されていません。"0"に固定して             | てください。                                                                             |     |     |                     |
| _    | EOFERRE<br>PORT1 EOF エラー検出割り込み許可 | PORT1 EOFERR 割り込み検出時の INT_N アサートの禁止/許可を指定します。 0:割り込み出力禁止 1:割り込み出力許可                | R/W | R   | H<br>(P時"0"<br>を設定) |
| 5-0  | 何も配置されていません。"0"に固定して             | てください。                                                                             |     |     | _                   |

#### <<Remarks>>

#### 2.9.1 割り込み許可レジスタ0、1、2 (INTENB0、INTENB1、INTENB2)

ソフトウェアが本レジスタに"1"を設定したビットに対応する割り込みを本コントローラが検出した場合に、本コント ローラーはINT\_N端子から割り込みをアサートします。

本コントローラーは、本レジスタの設定値(割り込み通知の禁止/許可)にかかわらず、各割り込み要因の検出条件を満 たした時にINTSTS0、INTSTS1、INTSTS2レジスタの対応するステータスビットに"1"を表示します。

各割り込み要因に対応するINTSTS0、INTSTS1、INTSTS2レジスタのステータスビットが"1"を示している状態で、ソ フトウェアが本レジスタの対応する割り込み許可ビットを"0"から"1"に変更すれば、本コントローラーはINT\_N端子から 割り込みをアサートします。



<sup>\*</sup> INTENB2 レジスタよる割り込み許可は、Host Controller 機能選択時のみ設定が可能です。Peripheral Controller 機能選択時は 許可を行わないでください。

| •  | BRDY割 | り込み | 許可レき | ジスタ【 | BRDYE | ENB ] |   |   |   |       |       |   | <アドし | ノス:36 | 6H> |
|----|-------|-----|------|------|-------|-------|---|---|---|-------|-------|---|------|-------|-----|
| 15 | 14    | 13  | 12   | 11   | 10    | 9     | 8 | 7 | 6 | 5     | 4     | 3 | 2    | 1     | 0   |
|    |       |     |      |      |       |       |   |   |   | PIPEE | BRDYE |   |      |       |     |
| ?  | ?     | ?   | ?    | ?    | ?     | 0     | 0 | 0 | 0 | 0     | 0     | 0 | 0    | 0     | 0   |
| ?  | ?     | ?   | ?    | ?    | ?     | -     | - | - | - | -     | -     | - | -    | -     | -   |

| Bit   | Name                         | Function                                                               | S/W | H/W | Remarks |
|-------|------------------------------|------------------------------------------------------------------------|-----|-----|---------|
| 15-10 | 何も配置されていません。"0"に固定し          | てください。                                                                 |     |     |         |
| 0 0   | PIPEBRDYE<br>各パイプのBRDY割り込み許可 | 各パイプのBRDY割り込み検出時にBRDYビットを"1"にするかどうかの禁止/許可を指定します。 0:割り込み出力禁止 1:割り込み出力許可 | R/W | R   |         |

#### <<Remarks>>

### 2.9.2 各パイプのBRDY割り込み許可ピット (PIPEBRDYE)

ソフトウェアが本レジスタに"1"を設定したPIPEに対して、本コントローラがBRDY割り込みを検出した場合に、本コ ントローラーはBRDYSTSレジスタのPIPEBRDYビットの対応するビットに"1"を表示し、INTSTS0レジスタのBRDYビッ トに"1"を表示し、INT\_N端子から割り込みをアサートします。

BRDYSTSレジスタのPIPEBRDYビットの少なくともひとつのビットが"1"を示している状態で、ソフトウェアが本レ ジスタの対応する割り込み許可ビットを"0"から"1"に変更すれば、本コントローラーはINT\_N端子から割り込みをアサー トします。

<アドレス:38H>

#### ◆ NRDY割り込み許可レジスタ【NRDYENB】

| 15 | 14 | 13 | 12 | 11 | 10 | 9 | 1 | 8 | 7 | 6 | 5     | 4    | 3 | 2 | 1 | 0 |
|----|----|----|----|----|----|---|---|---|---|---|-------|------|---|---|---|---|
|    |    |    |    |    |    |   |   |   |   |   | PIPEN | KUYE |   |   |   |   |
| ?  | ?  | ?  | ?  | ?  | ?  | 0 | ( | 0 | 0 | 0 | 0     | 0    | 0 | 0 | 0 | 0 |
| ?  | ?  | ?  | ?  | ?  | ?  | - |   | - | - | - | -     | -    | - | - | - | - |

| Bit   | Name                         | Function                                                                     | S/W | H/W | Remarks |
|-------|------------------------------|------------------------------------------------------------------------------|-----|-----|---------|
| 15-10 | 何も配置されていません。"0"に固定し          | てください。                                                                       |     |     |         |
|       | PIPENRDYE<br>各パイプのNRDY割り込み許可 | 各パイプのNRDY割り込み検出時にNRDYビットを"1"にするかどうかの禁止/許可を指定します。<br>0:割り込み出力禁止<br>1:割り込み出力許可 | R/W | R   |         |

#### <<Remarks>>

## 2.9.3 各パイプのNRDY割り込み許可ピット (PIPENRDYE)

page 51 of 183

ソフトウェアが本レジスタに"1"を設定したPIPEに対して、本コントローラがNRDY割り込みを検出した場合に、本コ ントローラーはNRDYSTSレジスタのPIPENRDYビットの対応するビットに"1"を表示し、INTSTS0レジスタのNRDYビッ トに"1"を表示し、INT\_N端子から割り込みをアサートします。

NRDYSTSレジスタのPIPENRDYビットの少なくともひとつのビットが"1"を示している状態で、ソフトウェアが本レ ジスタの対応する割り込み許可ビットを"0"から"1"に変更すれば、本コントローラーはINT\_N端子から割り込みをアサー トします。



<sup>\*</sup>ビット番号がパイプ番号に該当します。

<sup>\*</sup>ビット番号がパイプ番号に該当します。

| <b>♦</b> ] | ◆ BEMP割り込み許可レジスタ【BEMPENB】 |    |    |    |    |           |   |   |   |   |   |   | <アドレ | ノス:3/ | AH> |  |
|------------|---------------------------|----|----|----|----|-----------|---|---|---|---|---|---|------|-------|-----|--|
| 15         | 14                        | 13 | 12 | 11 | 10 | 9         | 8 | 7 | 6 | 5 | 4 | 3 | 2    | 1     | 0   |  |
|            |                           |    |    |    |    | PIPEBEMPE |   |   |   |   |   |   |      |       |     |  |
| 2          | 2                         | 2  | 2  | 2  | 2  | Λ         | Λ | Λ | Λ | Λ | Λ | Λ | Λ    | Λ     | Λ   |  |

| Bit   | Name                | Function                                                                 | S/W | H/W | Remarks |
|-------|---------------------|--------------------------------------------------------------------------|-----|-----|---------|
| 15-10 | 何も配置されていません。"0"に固定し | てください。                                                                   |     |     |         |
|       | 各パイプのBEMP割り込み許可     | 各パイプのBEMP割り込み検出時にBEMPビットを"1"にするかどうかの禁止/許可を指定します。<br>0:割り込み出力禁止1:割り込み出力禁止 | R/W | R   |         |

#### <<Remarks>>

\* ビット番号がパイプ番号に該当します。

# 2.9.4 各パイプのBEMP割り込み許可ビット (PIPEBEMPE)

ソフトウェアが本レジスタに"1"を設定したPIPEに対して、本コントローラがBEMP割り込みを検出した場合に、本コントローラーはBEMPSTSレジスタのPIPEBEMPビットの対応するビットに"1"を表示し、INTSTSOレジスタのBEMPビットに"1"を表示し、INT\_N端子から割り込みをアサートします。

BEMPSTSレジスタのPIPEBEMPビットの少なくともひとつのビットが"1"を示している状態で、ソフトウェアが本レジスタの対応する割り込み許可ビットを"0"から"1"に変更すれば、本コントローラーはINT\_N端子から割り込みをアサートします。



# 2.10 SOF制御レジスタ

SOFピンコンフィグレーションレジスタ【SOFCFG】 13 12 11 10 9

|    | <アトレス:3CH> |   |   |  |  |  |  |  |  |  |  |  |  |  |
|----|------------|---|---|--|--|--|--|--|--|--|--|--|--|--|
| 3  | 2          | 1 | 0 |  |  |  |  |  |  |  |  |  |  |  |
| SC | FM         |   |   |  |  |  |  |  |  |  |  |  |  |  |
| Λ  | Λ          | 7 | ? |  |  |  |  |  |  |  |  |  |  |  |

| Bit  | Name                                      | Function                                                                                                                        | S/W | H/W | Remarks                 |
|------|-------------------------------------------|---------------------------------------------------------------------------------------------------------------------------------|-----|-----|-------------------------|
| 15-9 | 何も配置されていません。"0"に固定し                       | てください。                                                                                                                          |     |     | •                       |
| 8    | TRNENSEL<br>トランザクション有効期間切り替えビット           | Full-Speed または Low-Speed 通信中の PORT において、1 フレーム中に本コントローラーがトークン発行を行う期間(トランザクション有効期間)を指定します。 0: Low-Speed 未対応 1: Low-Speed 対応      | R/W | R   | H<br>(P時"0"<br>を設<br>定) |
| 7    | 何も配置されていません。"0"に固定し                       | てください。                                                                                                                          |     |     |                         |
| _    | BRDYM<br>PIPEBRDY 割り込みステータスクリア<br>タイミング設定 | PIPEBRDY 割り込みステータスをクリアする<br>タイミングを指定します。<br>0: SW がステータスをクリア<br>1: FIFO バッファの読み出しまたは FIFO バッ<br>ファへの書き込み動作により HW がステー<br>タスをクリア | R/W | R   |                         |
| _    | INTL<br>割り込み出力センス設定                       | INT_N 端子の割り込み出力センスを指定します。<br>0:エッジセンス<br>1:レベルセンス                                                                               | R/W | R   |                         |
| _    | EDGESTS<br>割り込みエッジ処理ステータス                 | 割り込みエッジ処理ステータスが表示されます。<br>0:割り込みエッジ動作していない<br>1:割り込みエッジ動作中                                                                      | R   | W   |                         |
|      | SOFM<br>SOF 端子機能設定                        | SOF パルス出力モードを選択します<br>00:SOF 出力禁止<br>01:1ms 単位で SOF 出力<br>10:125us 単位で μ SOF 出力<br>11:Reserved                                  | R/W | R   |                         |
| 1-0  | 何も配置されていません。"0"に固定し                       | てください。                                                                                                                          |     |     |                         |

8

TRNENSEL

0

6

BRDYM

0

INTL

0

**EDGESTS** 

0

#### <<Remarks>>



<sup>\*</sup> TRNENSEL ビットの設定は、Host Controller 機能選択時のみ有効です。また、Host Controller 機能選択時であっても Hi-Speed のトランザクション有効期間には影響しません。本ビットは2つの PORT に共通のビットです。

<sup>\* &</sup>quot;BRDYM=1"を設定する場合は、"INTL=1" (レベルセンス)を設定してください。

<sup>\* &</sup>quot;INTL=0"を設定時に、割り込みステータスをクリア後システムクロックを停止する("SCKE=0"を設定)場合は、"EDGESTS=0" を確認した後で、"SCKE=0"を書き込んでください。

# 2.11 割り込みステータス

◆ 割り込みステータスレジスタ0【INTSTS0】

| <ア | ľ | レス | ٠ | 40H> |
|----|---|----|---|------|
|    |   |    |   |      |

| 15    | 14   | 13   | 12   | 11   | 10   | 9    | 8    | 7     | 6 |     | 5    | 4 | 3     | 2 | 1    | 0 |
|-------|------|------|------|------|------|------|------|-------|---|-----|------|---|-------|---|------|---|
| VBINT | RESM | SOFR | DVST | CTRT | BEMP | NRDY | BRDY | VBSTS |   |     | DVSQ |   | VALID |   | CTSQ |   |
| 0     | 0    | 0    | 0    | 0    | 0    | 0    | 0    | ?     | 0 | T I | 0    | 0 | 0     | 0 | 0    | 0 |
| -     | -    | -    | 1    | -    | -    | -    | -    | -     | 0 |     | 0    | 1 | -     | - | -    | - |

| Bit | Name                                | Function                                                                                                                  | S/W    | H/W | Remarks                  |
|-----|-------------------------------------|---------------------------------------------------------------------------------------------------------------------------|--------|-----|--------------------------|
| 15  | VBINT<br>VBUS変化検出割り込みステータス          | VBUS変化検出割り込みステータスが表示されます。<br>0:VBUS割り込み非発生<br>1:VBUS割り込み発生                                                                | R/W(0) | W   |                          |
| 14  | RESM<br>レジューム割り込みステータス              | レジューム検出割り込みステータスが表示されます。<br>0:レジューム割り込み非発生<br>1:レジューム割り込み発生                                                               | R/W(0) | W   | P<br>(H時読<br>み出し<br>値無効) |
| 13  | SOFR<br>フレーム番号更新割り込みステータス           | フレーム番号更新割り込みステータスが表示<br>されます。<br>0:SOF割り込み非発生<br>1:SOF割り込み発生                                                              | R/W(0) | W   |                          |
| 12  | DVST<br>デバイスステート遷移割り込みステータ<br>ス     | デバイスステート遷移割り込みが表示されます。<br>ステータス0:デバイスステート遷移遷移割り<br>込み非発生<br>1:デバイスステート遷移遷移割り込み発生                                          | R/W(0) | W   | P<br>(H時読<br>み出し<br>値無効) |
| 11  | CTRT<br>コントロール転送ステージ遷移割り込み<br>ステータス | コントロール転送ステージ遷移割り込みステータスが表示されます。<br>ステータス<br>0:コントロール転送ステージ遷移割り込み非<br>発生<br>1:コントロール転送ステージ遷移割り込み発<br>生                     |        | W   | P<br>(H時読<br>み出し<br>値無効) |
| 10  | BEMP<br>BEMP割り込みステータス               | BEMP割り込みステータスが表示されます。<br>0:BEMP割り込み非発生<br>1:BEMP割り込み発生                                                                    | R      | W   |                          |
| 9   | NRDY<br>NRDY割り込みステータス               | NRDY割り込みステータスが表示されます。<br>0:NRDY割り込み非発生<br>1:NRDY割り込み発生                                                                    | R      | W   |                          |
| 8   | BRDY<br>BRDY割り込みステータス               | BRDY割り込みステータスが表示されます。<br>0:BRDY割り込み非発生<br>1:BRDY割り込み発生                                                                    | R      | W   |                          |
| 7   | VBSTS<br>VBUS入力ステータス                | VBUS端子の入力状態が表示されます。<br>0:VBUS端子が"L"レベル<br>1:VBUS端子が"H"レベル                                                                 | R      | W   |                          |
| 6-4 | DVSQ<br>デバイスステート                    | デバイスステートが表示されます。<br>000: Poweredステート<br>001: Defaultステート<br>010: Addressステート<br>011: Configuredステート<br>1xx: Suspendedステート | R      | W   | P<br>(H時読<br>み出し<br>値無効) |
| 3   | VALID<br>USBリクエスト受信                 | USBリクエスト受信検出有無が表示されま<br>す。<br>0:未検出<br>1:セットアップパケット受信                                                                     | R/W(0) | W   | P<br>(H時読<br>み出し<br>値無効) |



| Bit | Name | Function                                                                                                                                                                      | S/W | H/W | Remarks                  |
|-----|------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-----|-----|--------------------------|
| 2-0 |      | コントロール転送ステージが表示されます。 000:アイドルまたはセットアップステージ 001:コントロールリードデータステージ 010:コントロールリードステータスステージ 011:コントロールライトデータステージ 100:コントロールライト(NoData)ステータスステージ 110:コントロール転送シーケンスエラー 111: Reserved | R   | W   | P<br>(H時読<br>み出し<br>値無効) |

#### <<Remarks>>

- \*VBINT ビット、RESM ビット、SOFR ビット、DVST ビット、または CTRT ビットが示すステータスをクリアする場合は、ク リアしたいビットのみに"0"を、他のビットには"1"を書き込んでください。"0"を示しているステータスビットへの"0"書き込みを 行わないでください。
- \*本コントローラーは本レジスタの VBINT ビット、RESM ビットが示すステータス変化をクロック停止中("SCKE=0") でも検 出し、対応する割り込みが許可されていれば割り込みを通知します。ソフトウェアによるステータスのクリアはクロック許可後 に行ってください。
- \* RESM ビット、DVST ビット、CTRT ビットのステータス変化は、Peripheral Controller 機能選択時のみ発生します。Host Controller 機能選択時には対応する割り込み許可ビットを禁止"0"に設定してください。
- \* DVSQ ビット、VALID ビット、CTRQ ビットは、Peripheral Controller 機能選択時のみ有効です。

## 2.11.1 VBUS変化割り込みステータスピット (VBINT)

本コントローラーがVBUS端子入力値の変化 (HighからLowへの変化、及びLowからHighへの変化) を検出したときに、 本ビットに"1"を表示します。本コントローラーはVBUS端子の入力値を、VBSTSビットに表示します。VBINT割り込み 発生時は、ソフトウェアでVBSTSビット読み出しの数度一致を行い、チャタリング除去を実施してください。

### 2.11.2 レジューム割り込みステータスピット (RESM)

Peripheral Controller機能設定時、本コントローラーがSuspend状態 (DVSQ=1XX) であり、かつ、DP端子の立下り を検出したときに、本ビットに"1"を表示します。

### 2.11.3 フレーム番号更新割り込みステータスピット (SOFR)

本コントローラーが本ビットに"1"を表示する条件は、以下のとおりです。

### 2.11.3.1 Host Controller 機能設定時

ソフトウェアがPORTO、またはPORT1に対応するUACTビットの少なくとも一方を"1"に設定している状態で、フレー ムナンバーの更新タイミングで本コントローラーは本ビットに"1"を表示します。(本割り込みは、1ms毎に検出します。)

### 2.11.3.2 Peripheral Controller 機能設定時

フレームナンバーの更新時に本コントローラーは本ビットに"1"を表示します。 (本割り込みは、1ms毎に検出します。) USB HOSTからのSOFパケットが破損した時でも、内部補間により、本コントローラーはSOFR割込みを検出します。

### 2.11.4 デバイスステート遷移割り込みステータスピット (DVST)

page 55 of 183

Peripheral Controller機能設定時、本コントローラーがデバイスステートの変化を検出したときに、本コントローラー はDVSQの値を更新し、本ビットに"1"を表示します。

本割り込みが発生した時には、本コントローラが次のデバイスステートステート遷移を検出する前に、ステータスクリ アを実施してください。



### 2.11.5 コントロール転送ステージ遷移割り込みステータスピット (CTRT)

Peripheral Controller機能設定時、本コントローラーがコントロール転送のステージ遷移を検出したときに、本コントローラーは**CTSQ**の値を更新し、本ビットに"1"を表示します。

本割り込みが発生した時には、本コントローラがコントロール転送の次のステージ遷移を検出するまでに、ステータスクリアを実施してください。

### 2.11.6 バッファエンプティ割り込みステータスピット (BEMP)

BEMPENBレジスタのPIPEBEMPEビットに"1"を設定したPIPEに対応するBEMPSTSレジスタのPIPEBEMPビットのうち、少なくともひとつが"1"の状態になった時(ソフトウェアがBEMP割り込み通知を許可したPIPEのうち少なくともひとつに対し本コントローラーがBEMP割り込み状態を検出した時)に、本コントローラーは本割込みステータスに"1"を表示します。

PIPEBEMPステータスのアサート条件は、PIPEBEMPレジスタを参照ください。

ソフトウェアが、PIPEBEMPEビットで許可を設定しているPIPEに対応するPIPEBEMPビットすべてに"0"を書き込むと、本コントローラーは本ビットを"0"にクリアします。

ソフトウェアが本ビットに対して"0"を書き込んでも、本ビットの"0"クリアを行うことはできません。

## 2.11.7 パッファノットレディ割り込みステータスピット (NRDY)

NRDYENBレジスタのPIPENRDYEビットに"1"を設定したPIPEに対応するBNRDYSTSレジスタのPIPENRDYビットのうち、少なくともひとつが"1"の状態になった時(ソフトウェアがNRDY割り込み通知を許可したPIPEのうち少なくともひとつに対し本コントローラーがNRDY割り込み状態を検出した時)に、本コントローラーは本割込みステータスに"1"を表示します。

PIPENRDYステータスのアサート条件は、PIPENRDYレジスタを参照ください。

ソフトウェアが、PIPENRDYEビットで許可を設定しているPIPEに対応するPIPENRDYビットのすべてに"0"を書き込むと、本コントローラーは本ビットを"0"にクリアします。

ソフトウェアが本ビットに対して"0"を書き込んでも、本ビットの"0"クリアを行うことはできません。

### 2.11.8 パッファレディ割り込みステータスピット (BRDY)

BRDYENBレジスタのPIPEBRDYEビットに"1"を設定したPIPEに対応するBRDYSTSレジスタのPIPEBRDYビットのうち、少なくともひとつが"1"の状態になった時(ソフトウェアがBRDY割り込み通知を許可したPIPEのうち少なくともひとつに対し本コントローラーがBRDY割り込み状態を検出した時)に、本コントローラーは本割込みステータスに"1"を表示します。

PIPEBRDYステータスのアサート条件は、PIPEBRDYレジスタを参照ください。

ソフトウェアが、PIPEBRDYEビットで許可を設定しているPIPEに対応するPIPEBRDYビットのすべてに"0"を書き込むと、本コントローラーは本ビットを"0"にクリアします。

ソフトウェアが本ビットに対して"0"を書き込んでも、本ビットの"0"クリアを行うことはできません。



#### 割り込みステータスレジスタ1【INTSTS1】

| <ア | ド | レ | ス | : | 42H> |
|----|---|---|---|---|------|
|----|---|---|---|---|------|

| 15           | 14   | 13 | 12   | 11    | 10 | 9 | 8 | 7 | 6      | 5    | 4    | 3 | 2 | 1 | 0 |
|--------------|------|----|------|-------|----|---|---|---|--------|------|------|---|---|---|---|
| <b>OVRCR</b> | BCHG |    | DTCH | ATTCH |    |   |   |   | EOFERR | SIGN | SACK |   |   |   |   |
| 0            | 0    | ?  | 0    | 0     | ?  | ? | ? | ? | 0      | 0    | 0    | ? | ? | ? | ? |
| -            | -    | ?  | -    | -     | ?  | ? | ? | ? | -      | -    | -    | ? | ? | ? | ? |

| Bit  | Name                                   | Function                                                                                                                | S/W    | H/W | Remarks                  |
|------|----------------------------------------|-------------------------------------------------------------------------------------------------------------------------|--------|-----|--------------------------|
|      | OVRCR<br>PORT0 OVRCR 割り込みステータス         | PORTO OVRCR 割り込みステータスが表示されます。OVCUR0A 端子、または、OVCUR0B 端子の入力ステータスが変化した場合に本割り込みは発生します。<br>0:OVRCR 割り込み非発生<br>1:OVRCR 割り込み発生 |        | W   | H<br>(P時読<br>み出し<br>値無効) |
|      | BCHG<br>PORT0 USB バス変化割り込みステー<br>タス    | PORT0 USB バス変化割り込みステータスが<br>表示されます。<br>0:BCHG 割り込み非発生<br>1:BCHG 割り込み発生                                                  | R/W(0) | W   | H<br>(P時読<br>み出し<br>値無効) |
| 13   | 何も配置されていません。"0"に固定して                   | てください。                                                                                                                  |        |     |                          |
|      | DTCH<br>PORTOUSB 切断検出割り込みステータ<br>ス     | PORTO USB 切断検出割り込みステータスが<br>表示されます。<br>0:DTCH 割り込み非発生<br>1:DTCH 割り込み発生                                                  | R/W(0) | W   | H<br>(P時読<br>み出し<br>値無効) |
|      | ATTCH<br>PORT0 USB 接続検出割り込みステー<br>タス   | PORTO ATTCH 割り込みステータスが表示されます。<br>0:ATTCH 割り込み非発生<br>1:ATTCH 割り込み発生                                                      | R/W(0) | W   | H<br>(P時読<br>み出し<br>値無効) |
| 10-7 | 何も配置されていません。"0"に固定して                   | てください。                                                                                                                  |        |     |                          |
| _    | EOFERR<br>PORT0 EOF エラー検出割り込みス<br>テータス | PORTO EOFERR 割り込みステータスが表示<br>されます。<br>0:EOFERR 割り込み非発生<br>1:EOFERR 割り込み発生                                               | R/W(0) | W   | H<br>(P時読<br>み出し<br>値無効) |
| 5    | SIGN<br>セットアップトランザクションエラー<br>割り込みステータス | セットアップトランザクションエラー割り込<br>みステータスが表示されます。<br>0:SIGN 割り込み非発生<br>1:SIGN 割り込み発生                                               | R/W(0) | W   | H<br>(P時読<br>み出し<br>値無効) |
|      |                                        | セットアップトランザクション正常応答割り<br>込みステータスが表示されます。<br>0:SACK 割り込み非発生<br>1:SACK 割り込み発生                                              | R/W(0) | W   | H<br>(P時読<br>み出し<br>値無効) |
| 3-0  | 何も配置されていません。"0"に固定して                   | てください。                                                                                                                  |        |     |                          |

#### <<Remarks>>

OVRCR ビット、BCHG ビット以外の割り込みは、クロック停止中 ("SCKE=0") は検出しません。



<sup>\*</sup> 本レジスタの各ビットが示すステータス変化による割り込みは、Host Controller 機能選択時のみ許可してください。

<sup>\*</sup>本レジスタの各ビットが示すステータスのクリアは、クリアしたいビットのみに"0"を、他のビットには"1"をソフトウェア書き 込むことにより実施してください。

<sup>\*</sup>本コントローラーは本レジスタの OVRCR ビット、BCHG ビットが示すステータス変化をクロック停止中 ("SCKE=0") でも検 出し、対応する割り込みが許可されていれば割り込みを通知します。ソフトウェアによるステータスのクリアはクロック許可後 に行ってください。

### 2.11.9 PORTO OVRCR割り込みステータスピット (OVRCR)

OVCUR0A端子、またはOVCUR0B端子いずれかの入力状態が変化 (LowからHigh、HighからLow) した時に、本コン トローラーはPORTO OVRCR割り込みを検出し、本ビットに"1"を表示します。この時、ソフトウェアが該当する割り込 み許可ビットに"1"を設定していれば、本コントローラはINT\_N端子をアサートし、割り込み発生を通知します。

本コントローラーはOVCUR0A端子、及びOVCUR0B端子の現在の入力状態を、SYSSTS0レジスタのOVCMONビット に表示します。

Host Controller機能選択時に、PORT0にUSB接続される機器に対してVBUSを供給するための外部電源ICからのオー バーカレント通知信号をOVCUR0A端子、またはOVCUR0B端子に接続すると、ソフトウェアでオーバーカレント発生を 検出することができます。OVRCR割り込み発生時は、ソフトウェアでOVCMONビット読み出しの数度一致を行い、チャ タリング除去を実施してください。

### 2.11.10 PORTO USBバス変化割り込みステータスピット (BCHG)

PORTOのFull Speed / Low-Speed信号レベルでの状態変化が発生した(J-State、K-State、またはSE0のいずれかの状 態から、J-State、K-State、またはSE0のいずれかの状態に変化した) 時に、本コントローラーはPORT0 BCHG割り込 みを検出し、本ビットに"1"を表示します。この時、ソフトウェアが該当する割り込み許可ビットに"1"を設定していれば、 本コントローラはINT N端子をアサートし、割り込み発生を通知します。

本コントローラーはPORT0の現在の入力状態を、SYSSTS0レジスタのLNSTビットに表示します。

以下のいずれか場合には、BCHG割り込みを許可してください。

- (1) サスペンドに入る場合でリモートウェイクアップを許可する場合。
- (2) サスペンドに入る場合でクロック停止を行う場合 (サスペンド中のデタッチ検出のために必要です)
- (3) Peripheral Deviceが一つも接続されていない時にクロックを停止させる場合 (アタッチ検出のために必要です)

BCHG端子割り込み発生時に、上記(1)の場合はDVSTCTRレジスタのRESUMEビットでPeripheralデバイスのリモート ウェイクアップ確認を、(2)及び(3)の場合はソフトウェアでLNSTビットのチャタリング除去を実施し、Peripheralデバイ スのアタッチ、デタッチ検出を行ってください。

### 2.11.11 Host Controller機能用 PORT0 USB切断検出割り込みステータスピット (DTCH)

PORT0のUSBバスディスコネクト検出時に、本コントローラーはPORT0 DTCH割り込みを検出し、本ビットに"1"を 表示します。この時、ソフトウェアが該当する割り込み許可ビットに"1"を設定していれば、本コントローラはINT\_N端 子をアサートし、割り込み発生を通知します。

本コントローラーは、USB Specification2.0に準じた基準でバスディスコネクトを検出します。

本コントローラーは、DTCH割り込みを検出後(該当する割り込み許可ビットの設定値にかかわらず)以下のハードウ ェア制御を行います。ソフトウェアは、当該PORTに対して通信を行っているPIPEをすべて通信終了させ、当該PORT へのアタッチ (ATTCH割り込み発生) 待ちの状態に遷移してください。

- (1) DTCH割り込みを検出したPORTのUACTビットを"0"に変更し、表示
- (2) DTCH割り込みが発生したPORTをIdle状態に遷移させる。

### 2.11.12 Host Controller機能用 PORT0 USB接続検出割り込みステータスピット (ATTCH)

Host Controller機能選択時に、本コントローラーがPORT0にFull Speed / Low-Speed信号レベルのJ-Stateまたは K-Stateを2.5us間検出した時、本コントローラーはPORTO ATTCH割り込みを検出し、本ビットに"1"を表示します。こ の時、ソフトウェアが該当する割り込み許可ビットに"1"を設定していれば、本コントローラはINT\_N端子をアサートし、 割り込み発生を通知します。

本コントローラーのATTCH割り込み検出条件は、具体的には以下のとおりです。

- (1) "K-State、SE0、またはSE1"から"J-State"に変化し"J-State"のまま2.5us間継続した時
- (2) "J-State、SE0、またはSE1"から"K-State"に変化し"K-State"のまま2.5us間継続した時



# 2.11.13 Host Controller機能用 PORT0 EOFエラー割り込みステータスピット (EOFERR)

USB Specification2.0に定められているEOF2タイミング時点PORT0の通信が終了しないことを本コントローラが検出した時に、本コントローラーはPORT0 EOFERR割り込みを検出し、本ビットに"1"を表示します。この時、ソフトウェアが該当する割り込み許可ビットに"1"を設定していれば、本コントローラはINT\_N端子をアサートし、割り込み発生を通知します。

本コントローラーは、**EOFERR**割り込みを検出後 (該当する割り込み許可ビットの設定値にかかわらず) 以下のハードウェア制御を行います。ソフトウェアは、当該PORTに対して通信を行っているPIPEをすべて通信終了させ、当該PORTへの再Enumerationを行ってください。

- (1) EOFERR割り込みを検出したPORTのUACTビットを"0"に変更し、表示
- (2) **EOFERR**割り込みが発生したPORTをIdle状態に遷移させる。

### 2.11.14 Host Controller機能用 セットアップトランザクションエラー割り込みステータスピット (SIGN)

本コントローラーが発行したSETUPトランザクションにおいて、PeripheralデバイスがACK応答を行わない状態が連続3回発生した時に、本コントローラーは**SIGN**割り込みを検出し、本ビットに"1"を表示します。この時、ソフトウェアが該当する割り込み許可ビットに"1"を設定していれば、本コントローラはINT\_N端子をアサートし、割り込み発生を通知します。

本コントローラーの**SIGN**割り込み検出条件は、具体的には3回の連続したSETUPトランザクションに対して、以下 (1)~(3)のいずれかの応答が発生した時です。

- (1) Peripheralデバイスが何も応答しない状態で本コントローラーがタイムアウトを検出した
- (2) ACKパケットが破損した時
- (3) ACK以外のHandshake (NAK、NYET、またはSTALL)を受信した時

## 2.11.15 Host Controller機能用 セットアップトランザクション正常応答割り込みステータスピット (SACK)

本コントローラーが発行したSETUPトランザクションにおいて、PeripheralデバイスからのACK応答を受信した時に、本コントローラーはSACK割り込みを検出し、本ビットに"1"を表示します。この時、ソフトウェアが該当する割り込み許可ビットに"1"を設定していれば、本コントローラはINT\_N端子をアサートし、割り込み発生を通知します。



#### ◆ 割り込みステータスレジスタ1【INTSTS2】

| •     | 割り込み | ナステー | タスレ  | ブスタ1  | [INTS] | ΓS2】 |   |   |        |   |   |   | <アドし | ノス:44 | H> |
|-------|------|------|------|-------|--------|------|---|---|--------|---|---|---|------|-------|----|
| 15    | 14   | 13   | 12   | 11    | 10     | 9    | 8 | 7 | 6      | 5 | 4 | 3 | 2    | 1     | 0  |
| OVRCR | BCHG |      | DTCH | ATTCH |        |      |   |   | EOFERR |   |   |   |      |       |    |
| 0     | 0    | ?    | 0    | 0     | ?      | ?    | ? | ? | 0      | ? | ? | ? | ?    | ?     | ?  |
| -     | -    | ?    | -    | -     | ?      | ?    | ? | ? | -      | ? | ? | ? | ?    | ?     | ?  |

| Bit  | Name                                   | Function                                                                                        | S/W    | H/W | Remarks                  |
|------|----------------------------------------|-------------------------------------------------------------------------------------------------|--------|-----|--------------------------|
|      | OVRCR<br>PORT1 OVRCR 割り込みステータス         | PORT1 OVRCR 割り込みステータスが表示されます。OVCUR1 端子の入力ステータスが変化した場合に本割り込みは発生します。0:OVRCR 割り込み非発生1:OVRCR 割り込み発生 | R/W(0) | W   | H<br>(P時読<br>み出し<br>値無効) |
| 1    | BCHG<br>PORT1 USB バス変化割り込みステー<br>タス    | PORT1 USB バス変化割り込みステータスが<br>表示されます。<br>0:BCHG 割り込み非発生<br>1:BCHG 割り込み発生                          | R/W(0) | W   | H<br>(P時読<br>み出し<br>値無効) |
| 13   | 何も配置されていません。"0"に固定して                   | てください。                                                                                          |        |     |                          |
|      | DTCH<br>PORT1 切断検出割り込みステータス            | PORT1 切断検出割り込みステータスが表示されます。<br>0: DTCH 割り込み非発生<br>1: DTCH 割り込み発生                                | R/W(0) | W   | H<br>(P時読<br>み出し<br>値無効) |
| 1    | ATTCH<br>PORT1 接続検出割り込みステータス           | PORT1 ATTCH 割り込みステータスが表示されます。<br>0:ATTCH 割り込み非発生<br>1:ATTCH 割り込み発生                              | R/W(0) | W   | H<br>(P時読<br>み出し<br>値無効) |
| 10-7 | 何も配置されていません。"0"に固定して                   | てください。                                                                                          |        |     |                          |
| _    | EOFERR<br>PORT1 EOF エラー検出割り込みス<br>テータス | PORT1 EOFERR 割り込みステータスが表示<br>されます。<br>0:EOFERR 割り込み非発生<br>1:EOFERR 割り込み発生                       | R/W(0) | R   | H<br>(P時読<br>み出し<br>値無効) |
| 5-0  | 何も配置されていません。"0"に固定して                   | てください。                                                                                          |        | -   | _                        |

#### <<Remarks>>

- \* 本レジスタの各ビットが示すステータス変化による割り込みは、Host Controller 機能選択時のみ許可してください。
- \* 本レジスタの各ビットが示すステータスのクリアは、クリアしたいビットのみに"0"を、他のビットには"1"をソフトウェア書 き込むことにより実施してください。
- \* 本コントローラーは本レジスタの OVRCR ビット、BCHG ビットが示すステータス変化をクロック停止中 ("SCKE=0") でも 検出し、対応する割り込みが許可されていれば割り込みを通知します。ソフトウェアによるステータスのクリアはクロック許可 後に行ってください。

OVRCR ビット、BCHG ビット以外の割り込みは、クロック停止中 ("SCKE=0") は検出しません。



### 2.11.16 PORT1 OVRCR割り込みステータスピット (OVRCR)

**OVCUR1**端子の入力状態が変化 (LowからHigh、HighからLow) した時に、本コントローラーはPORT1 **OVRCR**割り込みを検出し、本ビットに"1"を表示します。この時、ソフトウェアが該当する割り込み許可ビットに"1"を設定していれば、本コントローラはINT\_N端子をアサートし、割り込み発生を通知します。

本コントローラーはOVCUR1端子の現在の入力状態を、SYSSTS1レジスタのOVCMONビットに表示します。

Host Controller機能選択時に、PORT1にUSB接続される機器に対してVBUSを供給するための外部電源ICからのオーバーカレント通知信号をOVCUR1端子に接続すると、ソフトウェアでオーバーカレント発生を検出することができます。OVRCR割り込み発生時は、ソフトウェアでOVCMONビット読み出しの数度一致を行い、チャタリング除去を実施してください。

### 2.11.17 PORT1 USB**バス変化割り込みステータスピット** (BCHG)

PORT1のFull Speed / Low-Speed信号レベルでの状態変化が発生した (J-State、K-State、またはSE0のいずれかの状態から、J-State、K-State、またはSE0のいずれかの状態に変化した) 時に、本コントローラーはPORT1 **BCHG**割り込みを検出し、本ビットに"1"を表示します。この時、ソフトウェアが該当する割り込み許可ビットに"1"を設定していれば、本コントローラはINT\_N端子をアサートし、割り込み発生を通知します。

本コントローラーはPORT1の現在の入力状態を、SYSSTS1レジスタのLNSTビットに表示します。

2.11.10も参照ください

### 2.11.18 Host Controller機能用 PORT1 USB切断検出割り込みステータスピット (DTCH)

PORT1のUSBバスディスコネクト検出時に、本コントローラーはPORT1 **DTCH**割り込みを検出し、本ビットに"1"を表示します。この時、ソフトウェアが該当する割り込み許可ビットに"1"を設定していれば、本コントローラはINT\_N端子をアサートし、割り込み発生を通知します。

2.11.11も参照ください

#### 2.11.19 Host Controller機能用 PORT1 USB接続検出割り込みステータスピット (ATTCH)

Host Controller機能選択時に、本コントローラーがPORT1にFull Speed / Low-Speed信号レベルのJ-Stateまたは K-Stateを2.5us間検出した時、本コントローラーはPORT1 **ATTCH**割り込みを検出し、本ビットに"1"を表示します。この時、ソフトウェアが該当する割り込み許可ビットに"1"を設定していれば、本コントローラはINT\_N端子をアサートし、割り込み発生を通知します。

2.11.12も参照ください

### 2.11.20 Host Controller機能用 PORT1 EOFエラー割り込みステータスピット (EOFERR)

USB Specification2.0に定められているEOF2タイミング時点PORT1の通信が終了しないことを本コントローラが検出した時に、本コントローラーはPORT1 **EOFERR**割り込みを検出し、本ビットに"1"を表示します。この時、ソフトウェアが該当する割り込み許可ビットに"1"を設定していれば、本コントローラはINT\_N端子をアサートし、割り込み発生を通知します。

2.11.13も参照ください



◆ BRDY割り込みステータスレジスタ【BRDYSTS】

| <ア | ۲ | レス | ٠ | 46 | H> |
|----|---|----|---|----|----|
|    |   |    |   |    |    |

| 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5     | 4    | 3 | 2 | 1 | 0   |
|----|----|----|----|----|----|---|---|---|---|-------|------|---|---|---|-----|
|    |    |    |    |    |    |   |   |   |   | PIPEI | BRDY |   |   |   |     |
| ?  | ?  | ?  | ?  | ?  | ?  | 0 | 0 | 0 | 0 | 0     | 0    | 0 | 0 | 0 | 0   |
| ?  | ?  | ?  | ?  | ?  | ?  | - | - | - | - | -     | -    | - | - | - | - 1 |

| Bit  | Name                | Function                                                | S/W    | H/W | Remarks |
|------|---------------------|---------------------------------------------------------|--------|-----|---------|
| 15-1 | 可も配置されていません。"0"に固定し | てください。                                                  |        |     |         |
| 9-0  |                     | 各パイプのBRDY割り込みステータスが表示<br>されます。<br>0:割り込み非発生<br>1:割り込み発生 | R/W(0) | W   |         |

#### <<Remarks>>

- \* ビット番号がパイプ番号に該当します。
- \* "BRDYM=0"の設定の場合、本レジスタの各ビットが示すステータスをクリアする場合は、クリアしたいビットのみに"0"を、 他のビットには"1"を書き込んでください。
- \* "BRDYM=0"の設定の場合、本割り込みのクリアは、必ず FIFO アクセスを行う前に実施してください。

### 2.11.21 各パイプのBRDY割り込みステータスピット (PIPEBRDY)

本コントローラがあるPIPEに対してBRDY割り込みを検出した場合に、本コントローラーはBRDYSTSレジスタの PIPEBRDYビットの対応するビットに"1"を表示します。このとき、ソフトウェアによってBRDYENBレジスタの対応す るビットに"1"が設定されている場合、本コントローラーはINTSTSOレジスタのBDYビットに"1"を表示し、INT\_N端子か ら割り込みをアサートします。

BRDY割り込みは、BRDYMビットおよび各PIPEのBFREビットの設定により、発生条件及びクリア方法が異なります。

#### 2.11.21.1 "BRDYM=0 かつ BFRE=0"設定時

この設定の場合、BRDY割込みはFIFOポートにアクセス可能になった事を示す割り込みになります。

本コントローラーは、下記に示す条件の場合に、内部BRDY割り込み要求トリガを発生させ、要求トリガー発生PIPE に対応するPIPEBRDYビットに"1"を表示します。

- (1) 送信方向に設定したPIPEの場合
- (a) ソフトウェアがDIRビットを"0"から"1"に変更した時
- (b) 当該PIPEに割り付けたFIFOバッファへのCPUからの書き込みが不可状態の時(BSTSビット読み出し値が"0"の 時)に、本コントローラーが当該PIPEのパケット送信を完了した時。 連続送受信モードに設定した場合には、FIFOバッファー面分のデータの送信完了時に要求トリガが発生しま す。
- (c) FIFOバッファをダブルバッファに設定している時で、FIFOバッファ書き込み完了時にもう一方のFIFOバッファが 空であった時

FIFOバッファ書き込み中にもう一方が送信完了になっても、現在書き込み中の面が書き込み完了になるまでは 要求トリガは発生しません。

- (d)転送TYPEがIsochronousのPIPEにおいて、ハードウェアによるバッファフラッシュが発生した時
- (e) ACLRMビットに"1"を書き込むことより、FIFOバッファが書き込み不可状態から書き込み可能状態になった時

DCPに対しては(即ち、コントロール転送でのデータ送信においては)要求トリガは発生しません。

- (2) 受信方向に設定したPIPEの場合
- (a) 当該PIPEに割り付けたFIFOバッファへのCPUからの読み出しが不可状態の時 (BSTSビット読み出し値が"0"の 時)に、パケット受信が正常に完了し、FIFOバッファが読み出し可能状態になった時。

データPIDミスマッチのトランザクションに対しては要求トリガは発生しません。

連続送受信モードの場合には、MaxPacketSizeのデータサイズで、かつまだバッファに空きがある場合には要求 トリガは発生しません。

ショートパケットを受信した場合には、FIFOバッファに空きがあっても要求トリガは発生します。

トランザクションカウンタを使用している場合には、設定値分のパケットを受信時に要求トリガは発生します。 この時、FIFOバッファにまだ空きがあっても要求トリガは発生します。

(b) FIFOバッファをダブルバッファに設定している時で、FIFOバッファ読出し完了時にもう一方のFIFOバッファも 読出し可能状態であった時

読み出し中にもう一方が受信完了しても、現在読み出し中の面が読出し完了になるまで要求トリガは発生しません。

Peripheral Controller機能選択時のコントロール転送のステータスステージでの通信では本割り込みは発生しません。

ソフトウェアは、本ビットの該当PIPEに対応するビットに"0"を書き込むことにより、該当PIPEのPIPEBRDY割り込みステータスを"0"にクリアすることができます。この時、他のPIPEに対応するビットには"1"を書き込んでください。本割り込みステータスのクリアは、必ずFIFOバッファへのアクセスを行う前に実施してください。

#### 2.11.21.2 "BRDYM=0 かつ BFRE=1"設定時

この設定の場合、本コントローラーは、受信PIPEにおいて1トランスファー分の全データ読み出し完了時に、BRDY割り込み発生と判断し、本レジスタの該当PIPEに対応するビットに"1"を表示します。

本コントローラーは、以下のいずれかの時に1トランスファーにおける最後のデータを受信したと判定します。

- (1) Zero-Lengthパケットを含むショートパケットを受信した時
- (2) トランザクションカウンタ (TRNCNTビット) を使用し、TRNCNTビット設定値分のパケットを受信した時

上記判定条件を満たした後、そのデータの読み出しが完了した時に、本コントローラーは1トランスファー分の全データ読み出し完了と判断します。

FIFOバッファが空の状態でZero-Lengthパケット受信した場合は、Zero-LengthパケットデータがCPU側へトグルされた時点で、本コントローラーは1トランスファー分の全データ読み出し完了と判断します。

この場合、次のトランスファーを開始するためには、対応するFIFOCTRレジスタのBCLRビットにソフトウェアで"1"を書き込んでください。

本設定の場合には、本コントローラーは送信PIPEに対してBRDY割込みを検出しません。

ソフトウェアは、本ビットの該当PIPEに対応するビットに"0"を書き込むことにより、該当PIPEの**PIPEBRDY**割り込みステータスを"0"にクリアすることができます。この時、他のPIPEに対応するビットには"1"を書き込んでください。

本モードを使用する時には、トランスファー分の処理を終了するまでBFREビットの設定値を変更しないでください。 途中でBFREビットを変更する場合には、ACLRMビットにより対応するPIPEのFIFOバッファをすべてクリアしてく ださい。

## 2.11.21.3 "BRDYM=1 かつ BFRE=0"設定時

この設定の場合、本ビットの値は各PIPEのBSTSビットに連動します。即ち、BRDY割込みステータスはFIFOバッファの状態によって本コントローラーが"1"、"0"を表示します。

(1) 送信方向に設定したPIPEの場合

FIFOポートにデータが書き込み可能な状態であれば"1"を表示し、書き込み不可の状態になれば"0"を表示します。ただしDCPの送信PIPEが書き込み可能であっても、BRDY割込みはアサートされません。

(2) 受信方向に設定したPIPEの場合

FIFOポートにデータが読出し可能な状態であれば"1"を表示し、すべてのデータを読み出したら (読出し不可の状態になったら) "0"を表示します。

FIFOバッファが空でZero-Lengthパケットを受信した場合、ソフトウェアが"BCLR=1"を書き込むまで該当ビットには"1"が表示されBRDY割込みはアサートされ続けます。

本設定時、ソフトウェアは、本ビットの"0"クリアを行うことはできません。

BRDYM="1"設定時は、BFREビットは必ずすべて(全PIPE) "0"に設定してください。BRDYM="1"設定時は、INTLビットは必ず"1"(レベル制御)に設定してください。



◆ NRDY割り込みステータスレジスタ【NRDYSTS】

| <ア       | ド | レス | • | 48H>  |
|----------|---|----|---|-------|
| <b>\</b> |   | レハ | • | TO11/ |

| 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | (   | 3 | 5     | 4 | 3 | 2 | 1 | 0   |
|----|----|----|----|----|----|---|---|---|-----|---|-------|---|---|---|---|-----|
|    |    |    |    |    |    |   |   |   |     |   | PIPEI |   |   |   |   |     |
| ?  | ?  | ?  | ?  | ?  | ?  | 0 | 0 | 0 | (   | ) | 0     | 0 | 0 | 0 | 0 | 0   |
| ?  | ?  | ?  | ?  | ?  | ?  | - | - | - | 1 . | - | -     | - | - | - | - | - 1 |

| Bit   | Name                | Function                                            | S/W    | H/W  | Remarks |
|-------|---------------------|-----------------------------------------------------|--------|------|---------|
| 15-10 | 何も配置されていません。"0"に固定し | てください。                                              |        |      |         |
| 0 0   | o                   | 各パイプのNRDY割り込みステータスが表示されます。<br>0:割り込み非発生<br>1:割り込み発生 | R/W(0) | W(1) |         |

#### <<Remarks>>

- \* ビット番号がパイプ番号に該当します。
- \* 本レジスタの各ビットが示すステータスをクリアする場合は、クリアしたいビットのみに"0"を、他のビットには"1"を書き込 んでください。

## 2.11.22 各パイプのNRDY割り込みステータスピット (PIPENRDY)

ソフトウェアが"PID=BUF"に設定したPIPEに対して、本コントローラが内部NRDY割り込み要求を発生させた場合に、 本コントローラーはNRDYSTSレジスタのPIPENRDYビットの対応するビットに"1"を表示します。このとき、ソフトウ ェアによってNRDYENBレジスタの対応するビットに"1"が設定されている場合、本コントローラーはINTSTS0レジスタ のNRDYビットに"1"を表示し、INT\_N端子から割り込みをアサートします。

本コントローラが、あるPIPEに対して内部NRDY割り込み要求を発生させる条件を2.11.22.1、2.11.22.2、及び2.11.22.3 に述べます。

ただし、Host Controller機能選択時のSETUPトランザクション実行時は以下の割り込み発生条件に該当しません。 Host Controller機能選択時のSETUPトランザクションでは、SACK割り込み、または、SIGN割り込みを検出します。 また、Peripheral Controller機能選択時のコントロール転送ステータスステージ実行時は割り込み要求を発生させませ

## 2.11.22.1 Host Controller 機能選択時、かつスプリットトランザクションが発生しない接続の場合

- (1) 送信方向PIPEの場合
- 本コントローラーは、以下(a)~(c)のいずれかの条件を満たした場合に、NRDY割り込みを検出します。
- (a) 転送TYPEがIsochronousのPIPEにおいて、FIFOバッファに送信データがない状態でOUTトークン発行タイミン グに達した時。
  - この時、本コントローラーはOUTトークンに続けてZero-Lengthパケットを送信し、PIPENRDYビットの対応する ビットに"1"を表示し、OVRNビットにも"1"を表示します。
- (b) 転送TYPEがIsochronous以外のPIPE、かつSETUPトランザクション以外の通信において、Peripheralデバイスが 無応答 (PeripheralデバイスからのHandshakeパケットを検出しないままTimeoutを検出) した、またはPeripheral デバイスからのパケットにエラーを検出したケースが任意の組み合わせで3回連続して発生した時 この時、本コントローラーは、PIPENRDYビットの対応するビットに"1"を表示し、対応するPIPEのPIDビットを "NAK"に変更します。
- (c) SETUPトランザクション以外の通信において、PeripheralデバイスからSTALL Handshakeを受信した時 (OUTに 対するSTALLだけではなく、PINGに対するSTALLも該当します)。 この時、本コントローラーは、PIPENRDYビットの対応するビットに"1"を表示し、対応するPIPEのPIDビットを "STALL(11)"に変更します。
- (2) 受信方向PIPEの場合
- (a) 転送TYPEがIsochronousのPIPEにおいて、FIFOバッファに空きがない状態でIN Token発行タイミングに達し
  - この時本コントローラーは、IN Tokenに対する受信データを破棄し、当該PIPEに対応する**PIPENRDY**ビットに"1" を表示し、OVRNビットにも"1"を表示します。
  - 更に、IN Tokenに対する受信データにパケットエラーを検出した場合には、CRCEビットにも"1"を表示します。
- (b) 転送TYPEがIsochronous転送以外のPIPEで、本コントローラーが発行したIN Tokenに対してPeripheralデバイ スが無応答 (PeripheralデバイスからのDATAパケットを検出しないままTimeoutを検出)した場合、または Peripheralデバイスからのパケットにエラーを検出したケースが任意の組み合わせで3回連続して発生した時。

この時本コントローラーは、当該PIPEに対応する**PIPENRDY**ビットに"1"を表示し、対応するPIPEの**PID**ビットを"NAK"に変更します。

- (c) 転送TYPEがIsochronousのPIPEにおいて、IN Tokenに対してPeripheralデバイスが無応答 (PeripheralデバイスからのDATAパケットを検出しないままTimeoutを検出)した場合、またはPeripheralデバイスからのパケットにエラーを検出した時
  - この時本コントローラーは、当該PIPEに対応する**PIPENRDY**ビットに"1"を表示します (対応するPIPEの**PID**ビットの変更は行いません)。
- (d) 転送TYPEがIsochronousのPIPEにおいて、受信したデータパケットにCRCエラーまたはビットスタッフィングエラーを検出した時。
  - この時本コントローラーは、当該PIPEに対応する**PIPENRDY**ビットに"1"を表示し、CRCEビットに"1"を表示します。
- (e) STALL Handshakeを受信した時。
  - この時本コントローラーは、当該PIPEに対応する**PIPENRDY**ビットに"1"を表示し、対応するPIPEの**PID**ビットを"STALL"に変更します。

### 2.11.22.2 Host Controller 機能選択時、かつスプリットトランザクションが発生するの接続の場合

- (1) 送信方向PIPEの場合
- (a) 転送TYPEがIsochronousのPIPEにおいて、FIFOバッファに送信データがない状態でOUTトークン発行タイミングに達した時。
- この時本コントローラーは、Start-Splitトランザクション (S-Split)発行時点で当該PIPEに対応する**PIPENRDY**ビットに"1"を表示し、
  - OVRNビットに"1"を表示します。また、OUTトークンに続けてZero-Lengthパケットを送信します。
  - (b) 転送TYPEがIsochronous以外のPIPEにおいて、S-SplitまたはComplete-Spritトランザクション (C-Split) に対して、Hubが無応答(HubからのHandshakeパケットを検出しないままTimeoutを検出)、またはHubからのパケットにエラーを検出したケースが任意の組み合わせで3回連続して発生した時
    - この時本コントローラーは、当該PIPEに対応する**PIPENRDY**ビットに"1"を表示し、対応するPIPEの**PID**ビットを"NAK"に変更します。
    - C-Split発行時にNRDY割り込みを検出した場合には、本コントローラーはCSSTSビットをクリアし"0"を表示します。
  - (c) C-Splitに対し、STALL Handshakeを受信した時。
    - この時本コントローラーは、当該PIPEに対応する**PIPENRDY**ビットに"1"を表示し、対応するPIPEの**PID**ビットを"STALL(11)"に変更し、**CSSTS**ビットをクリアし"0"を表示します。
    - ただしSETUPトランザクションにおいては、本割り込みを検出しません。
  - (d) 転送TYPEがInterruptのPIPEにおいて、microFrame番号 = 4の時のC-Splitに対して、NYETを受信した時。 この時本コントローラーは、当該PIPEに対応する**PIPENRDY**ビットに"1"を表示し、**CSSTS**ビットをクリアし"0" を表示します(対応するPIPEの**PID**ビットは変更しません)。
  - (2) 受信方向PIPEの場合
  - (a) 転送TYPEがIsochronousのPIPEにおいて、FIFOバッファに空きがない状態でIN Token発行タイミングに達した時。
    - この時本コントローラーは、S-Split発行時点で当該PIPEに対応するPIPENRDYビットに"1"を表示し、OVRNビットに"1"を表示します。また、IN Tokenに対する受信データを破棄します。
  - (b) 転送TYPEがBulkのPIPEの転送、またはDCPのSETUPトランザクション以外の転送において、S-Splitまたは C-Split発行時に、本コントローラーが発行したIN Tokenに対してHubが無応答 (HubからのDATAパケットを検 出しないままTimeoutを検出)した場合、またはHubからのパケットにエラーを検出した場合が任意の組み合わせで 3回連続して発生した時。
    - この時本コントローラーは、当該PIPEに対応する**PIPENRDY**ビットに"1"を表示し、対応するPIPEの**PID**ビットを"NAK"に変更します。C-Splitにおいて本条件が発生した場合には、本コントローラーは**CSSTS**ビットをクリアし"0"を表示します。
  - (c) 転送TYPEがIsochronousまたはInterruptのPIPEのC-Splitにおいて、本コントローラーが発行したIN Tokenに対してHubが無応答 (HubからのDATAパケットを検出しないままTimeoutを検出) した場合、またはHubからのパケットにエラーを検出した場合が任意の組み合わせで3回連続して発生した時。
    - 転送TYPEがInterruptのPIPEにおいて、本条件が発生した場合、本コントローラーは、当該PIPEに対応するPIPENRDYビットに"1"を表示し、対応するPIPEのPIDビットを"NAK"に変更し、CSSTSビットをクリアし"0"を表示します。
    - 転送TYPEがIsochronousのPIPEにおいて、本条件が発生した場合、本コントローラーは、当該PIPEに対応するPIPENRDYビットに"1"を表示し、CRCEビットに"1"を表示し、CSSTSビットをクリアし"0"を表示します。(PIPEのPIDビットの変更は行いません)。

- (d) 転送TYPEがIsochronous以外のPIPEのC-Splitにおいて、STALL Handshakeを受信した時 この時本コントローラーは、当該PIPEに対応する**PIPENRDY**ビットに"1"を表示し、対応するPIPEの**PID**ビットを "STALL(11)"に変更し、**CSSTS**ビットをクリアし"0"を表示します。
- (e) 転送TYPEがIsochronous/InterruptのPIPEのC-Splitにおいて、microFrame = 4の時にNYET Handshakeを受信した場合。

この時本コントローラーは、当該PIPEに対応するPIPENRDYビットに"1"を表示し、CRCEビットに"1"を表示し、CSSTSビットをクリアし"0"を表示します。 (PIPEのPIDビットの変更は行いません)。

### 2.11.22.3 Peripheral Controller 機能選択時

- (1) 送信方向PIPEの場合
- (a) 当該PIPEの**PID**ビットが"BUF"("01")に設定されている場合にFIFOバッファに送信データがない状態でIN Tokenを受信した時

IN Token受信時に本コントローラーは**NRDY**割り込み要求を発生させ**PIPENRDY**ビットに"1"を表示します。 割り込み発生PIPEの転送TYPEがIsochronousの場合、本コントローラーはZero-Lengthパケットを送信し、**OVRN** ビットに"1"を表示します。

- (2) 受信方向PIPEの場合
- (a) 当該PIPEの**PID**ビットが"BUF"("01")に設定されている場合にFIFOバッファに空きがない状態でOUTトークンを 受信した時

割り込み発生PIPEの転送TYPEがIsochronousの場合、OUTトークン受信時に本コントローラーはNRDY割り込み要求を発生させ、PIPENRDYビットに"1"を表示し、OVRNビットに"1"を表示します。

割り込み発生PIPEの転送TYPEがIsochronous以外の場合、本コントローラーは、OUTトークンに続くデータ受信後NAK Handshakeを送信する時にNRDY割り込み要求を発生させ、**PIPENRDY**ビットに"1"を表示します。ただし、再送時 (DATA-PIDミスマッチ発生時)には、**NRDY**割り込み要求を発生させません。

また、DATAパケットにエラーがある場合にも、発生させません。

- (b) 当該PIPEの**PID**ビットが"BUF"("01")に設定されている場合にFIFOバッファに空きがない状態でPINGトークンを 受信した時
  - PINGトークン受信時に本コントローラーはNRDY割り込み要求を発生させPIPENRDYビットに"1"を表示します。
- (c) 転送TYPEがIsochronousのPIPEにおいて、当該PIPEの**PID**ビットが"BUF"("01")に設定されている場合にインター バルフレーム内に正常受信されなかった時

SOF受信のタイミングで本コントローラーは、NRDY割り込み要求を発生させ、PIPENRDYビットに"1"を表示します。



#### DEMD申川パルコフテータフしぶフタ「DEMDCTC」

| •  | ◆ BEMP割り込みステータスレジスタ【BEMPSTS】 |    |    |    |    |          |   |   |   |   |   |   | <アドし | ノス:4/ | AH> |
|----|------------------------------|----|----|----|----|----------|---|---|---|---|---|---|------|-------|-----|
| 15 | 14                           | 13 | 12 | 11 | 10 | 9        | 8 | 7 | 6 | 5 | 4 | 3 | 2    | 1     | 0   |
|    |                              |    |    |    |    | PIPEBEMP |   |   |   |   |   |   |      |       |     |
| ?  | ?                            | ?  | ?  | ?  | ?  | 0        | 0 | 0 | 0 | 0 | 0 | 0 | 0    | 0     | 0   |
| ?  | ?                            | ?  | ?  | ?  | ?  | -        | - | - | - | - | - | - | -    | -     | -   |

| В   | t Name                  | Function                                                | S/W    | H/W  | Remarks |
|-----|-------------------------|---------------------------------------------------------|--------|------|---------|
| 15- | 10  何も配置されていません。"0"に固定し | てください。                                                  |        |      |         |
| 9-  | 各パイプのBEMP割り込みステータス      | 各パイプのBEMP割り込みステータスが表示<br>されます。<br>0:割り込み非発生<br>1:割り込み発生 | R/W(0) | W(1) |         |

#### <<Remarks>>

- \* ビット番号がパイプ番号に該当します。
- \* 本レジスタの各ビットが示すステータスをクリアする場合は、クリアしたいビットのみに"0"を、他のビットには"1"を書き込 んでください。

## 2.11.23 各パイプのBEMP割り込みステータスピット (PIPEBEMP)

ソフトウェアが"PID=BUF"に設定したPIPEに対して、本コントローラが、BEMP割り込みを検出した場合に、本コン トローラーはBEMPSTSレジスタのPIPEBEMPビットの対応するビットに"1"を表示します。このとき、ソフトウェアに よってBEMPENBレジスタの対応するビットに"1"が設定されている場合、本コントローラーはINTSTSOレジスタの BEMPビットに"1"を表示し、INT\_N端子から割り込みをアサートします。

以下の場合に、本コントローラーは内部BEMP割り込み要求を発生させます。

(1) 送信方向PIPEにおいて、送信完了時 (Zero-Lengthパケットの送信時を含む) に、対応するPIPEのFIFOバッ ファが空の時。

シングルバッファ設定時は、DCP以外のPIPEに対してはBRDY割り込みと同時に内部BEMP割り込み要求を発生さ せます。

ただし、以下の場合は内部BEMP割り込み要求を発生させません。

- (a) ダブルバッファ設定時に、1面分のデータ送信完了時にソフトウェア (DMAC)がCPU側のFIFOバッファに対す る書き込みを開始している場合
- (b) また、ACLRMビットまたはBCLRビットに"1"を書き込むことによるバッファクリア (エンプティ)。
- (c) Peripheral Controller機能設定時、コントロール転送StatusステージのIN転送 (Zero-Lengthパケット送信)時

### (2) 受信方向PIPEの場合

MaxPacketSizeの設定値より大きなデータサイズを正常受信した時

この場合、本コントローラーは、BEMP割り込み要求を発生させ、PIPEBEMPビットの対応するビットに"1"を表示 し、受信データを破棄し、対応するPIPEのPIDビットを"STALL"("11")に変更します。

この時本コントローラーは、HOST Controller機能設定時には無応答し、Peripheral Controller機能設定時には STALL応答を行います。

ただし、以下の場合は内部BEMP割り込み要求を発生させません。

- (a) 受信データにCRCエラー、またはビットスタッフィングエラー等を検出した時
- (b) SETUPトランザクション実行時

page 67 of 183

本ビットに"0"を書き込むことにより、ステータスをクリアすることができます。 本ビットに"1"を書き込んでも、何もしません。



## 2.12 フレーム番号レジスタ

◆ フレームナンバレジスタ【FRMNUM】

| ィア | ド | レス | • | 4CH> | , |
|----|---|----|---|------|---|
|    |   |    |   |      |   |

|      |      |    |    | _  |    |   |   |   |   |      |   |   |   |   |   |
|------|------|----|----|----|----|---|---|---|---|------|---|---|---|---|---|
| 15   | 14   | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5    | 4 | 3 | 2 | 1 | 0 |
| OVRN | CRCE |    |    |    |    |   |   |   |   | FRNM |   |   |   |   |   |
| 0    | 0    | ?  | ?  | ?  | 0  | 0 | 0 | 0 | 0 | 0    | 0 | 0 | 0 | 0 | 0 |
| -    | -    | ?  | ?  | ?  | -  | - | - | - | - | -    | - | - | - | - | - |

| Bit   | Name                             | Function                                                                               | S/W    | H/W  | Remarks |
|-------|----------------------------------|----------------------------------------------------------------------------------------|--------|------|---------|
| 15    | OVRN<br>オーバーラン/アンダーラン検出ステー<br>タス | Isochronous転送を行っているPIPEに対する<br>オーバーラン/アンダーランエラー検出の有無<br>が表示されます。<br>0:エラーなし<br>1:エラー発生 | R/W(0) | W(1) |         |
|       |                                  | Isochronous転送を行っているPIPEに対する<br>CRCエラー検出ステータスが表示されます。<br>0:エラーなし<br>1:エラー発生             | R/W(0) | W(1) |         |
| 13-11 | 何も配置されていません。"0"に固定して             | ください。                                                                                  |        |      |         |
| 10-0  | FRNM<br>フレーム番号                   | 最新のフレーム番号が表示されます。                                                                      | R      | W    |         |

#### <<Remarks>>

\* OVRN ビットはデバッグ用のビットです。システムとしてはオーバーラン・アンダーランが発生しないようにタイミング設計 を行ってください。

# 2.12.1 オーパーラン/アンダーラン検出ステータスピット (OVRN)

転送TYPEがIsochronousのPIPEにおいて、本コントローラーがオーバーランまたはアンダーランを検出したときに、 本ビットに"1"を表示します。

オーバーランまたはアンダーラン検出時には、本コントローラーは内部NRDY割り込み要求を発生させます。詳細は、 2.11.22を参照してください。

ソフトウェアは、本ビットに"0"を書き込むことにより、本ビットを"0"にクリアすることができます。この時、本レジ スタの他のビットには"1"を書き込んでください。

### 2.12.1.1 Host Controller 機能選択時

以下の(1)~(2)いずれかの場合に、本コントローラーが本ビットに"1"を表示します。

- (1) 転送TYPEがIsochronousの送信方向PIPEにおいて、FIFOバッファに送信データの書き込みが完了していないのに OUTトークン発行タイミングに達した時。
- (2) 転送TYPEがIsochronousの受信方向PIPEにおいて、少なくとも一面分のFIFOバッファの空がない状態で、INトー クン発行タイミングに達した時。

#### 2.12.1.2 Peripheral Controller 機能選択時

以下の(1)~(2)いずれかの場合に、本コントローラーが本ビットに"1"を表示します。

- (1) 転送TYPEがIsochronousの送信方向PIPEにおいて、FIFOバッファに送信データの書き込みが完了していないのに IN Tokenを受信した時。
- (2) 転送TYPEがIsochronousの受信方向PIPEにおいて、少なくとも一面分のFIFOバッファの空がない状態で、OUT トークンを受信した時。

### 2.12.2 CRCエラー検出ステータスピット (CRCE)

page 68 of 183

転送TYPEがIsochronousのPIPEにおいて、本コントローラーがCRCエラーやビットスタッフィングエラーを検出した ときに、本ビットに"1"を表示します。

ソフトウェアは、本ビットに"0"を書き込むことにより、本ビットを"0"にクリアすることができます。この時、本レジ スタの他のビットには"1"を書き込んでください。

CRCエラーの検出時には、本コントローラーは内部NRDY割り込み要求を発生させます。詳細は、2.11.22を参照して ください。

# 2.12.3 フレーム番号ビット (FRNM)

本コントローラーは1msに1回のSOF発行タイミング、または、SOF受信時に本ビットを更新し、フレーム番号を表示 します。

ソフトウェアで本ビットを読み出す場合には、2度一致を行ってください。



| •  | ◆ μフレームナンバレジスタ【UFRNM】 |    |    |    |    |   |   |   | <アドレス:4EH> |   |   |   |   |           |    |  |
|----|-----------------------|----|----|----|----|---|---|---|------------|---|---|---|---|-----------|----|--|
| 15 | 14                    | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6          | 5 | 4 | 3 | 2 | 1         | 0  |  |
|    |                       |    |    |    |    |   |   |   |            |   |   |   |   | UFRNM     |    |  |
|    |                       |    |    |    |    |   |   |   |            |   |   |   |   | UFRN      | M  |  |
| ?  | ?                     | ?  | ?  | ?  | ?  | ? | ? | ? | ?          | ? | ? | ? | 0 | UFRN<br>0 | M0 |  |

| Bit  | Name                      | Function           | S/W | H/W | Remarks |  |  |  |
|------|---------------------------|--------------------|-----|-----|---------|--|--|--|
| 15-3 | 何も配置されていません。"0"に固定してください。 |                    |     |     |         |  |  |  |
| 2-0  | UFRNM<br>マイクロフレーム         | マイクロフレーム番号が表示されます。 | R   | W   |         |  |  |  |

### <<Remarks>>

なし

# 2.12.4 マイクロフレーム番号ピット (UFRNM)

PORT0またはPORT1の少なくとも一方がHi-Speedの場合、本コントローラーは本ビットにマイクロフレーム番号を表示します。PORT0及びPORT1の両方がHi-Speed以外の場合、本コントローラーは本ビットに0x00を表示します。

ソフトウェアで本ビットを読み出す場合には、2度一致を行ってください。



# 2.13 Peripheral Controller機能選択時USBアドレス

| •  | USBアト | ・レスレ | ジスタ | <b>USBA</b> | ADDR ] |   |   |   |         |   |   |   | <アドし | ノス:50 | )H> |  |  |
|----|-------|------|-----|-------------|--------|---|---|---|---------|---|---|---|------|-------|-----|--|--|
| 15 | 14    | 13   | 12  | 11          | 10     | 9 | 8 | 7 | 6       | 5 | 4 | 3 | 2    | 1     | 0   |  |  |
|    |       |      |     |             |        |   |   |   | USBADDR |   |   |   |      |       |     |  |  |
| ?  | ?     | ?    | ?   | ?           | ?      | ? | ? | ? | 0       | 0 | 0 | 0 | 0    | 0     | 0   |  |  |
| ?  | ?     | ?    | ?   | ?           | ?      | ? | ? | ? | 0       | 0 | 0 | 0 | 0    | 0     | 0   |  |  |

| Bit  | Name                | Function                                                   | S/W | H/W | Remarks                  |
|------|---------------------|------------------------------------------------------------|-----|-----|--------------------------|
| 15-7 | 何も配置されていません。"0"に固定し | てください。                                                     |     |     |                          |
| 6-0  | USBADDR<br>USBアドレス  | Peripheral Controller機能選択時に、Hostから割り付けられたUSBアドレス確認が表示されます。 | R   | R/W | P<br>(H時読<br>み出し<br>値無効) |

## <<Remarks>>

## 2.13.1 USBアドレスピット (USBADDR)

Peripheral Controller機能選択時に、本コントローラーがSetAddressリクエストを正常に処理した時に、本ビットに受信したUSBアドレスを表示します。

Peripheral Controller機能選択時に、本コントローラーがUSBリセットを検出した時に、本コントローラーは本ビットに0x00を表示します。

Host Controller機能選択時には、本コントローラーは本ビットを使用しません。



## 2.14 USBリクエストレジスタ

USBリクエストレジスタは、コントロール転送のセットアップリクエストを格納するためのレジスタです。 Peripheral Controller機能選択時には受信したUSBリクエストの値が格納されます。Host Controller機能選択時には 送信するUSBリクエストを設定してください。

◆ USBリクエストタイプレジスタ【USBREQ】

| <ブ | 7ド | レス | : | 54H: | > |
|----|----|----|---|------|---|
|    | 2  |    | 1 |      | Λ |

| 15 | 1 | 14 | 13 | 12 | 11    | 10 | 9 | 8 | 7 | 6 | 5 | 4      | 3        | 2 | 1 | 0 |
|----|---|----|----|----|-------|----|---|---|---|---|---|--------|----------|---|---|---|
|    |   |    |    |    | quest |    |   |   |   |   |   | bmRequ | iestType |   |   |   |
| 0  |   | 0  | 0  | 0  | 0     | 0  | 0 | 0 | 0 | 0 | 0 | 0      | 0        | 0 | 0 | 0 |
| 0  |   | 0  | 0  | 0  | 0     | 0  | 0 | 0 | 0 | 0 | 0 | 0      | 0        | 0 | 0 | 0 |

| Bit | Name              | Function                    | S/W            | H/W              | Remarks |
|-----|-------------------|-----------------------------|----------------|------------------|---------|
|     | bRequest<br>リクエスト | USBリクエストbRequestの値          | P時:R<br>H時:R/W | P時:W<br>H時:R     |         |
|     | l '_ , _ ´'       | USBリクエスト<br>bmRequestTypeの値 | P時:R<br>H時:R/W | P時 : W<br>H時 : R |         |

#### <<Remarks>>

なし

### 2.14.1 USBリクエストピット (bRequest)

## 2.14.1.1 Host Controller 機能選択時

ソフトウェアで、送信するSETUPトランザクションのUSBリクエストデータ値を設定してください。

ソフトウェアによる"SUREQ=1"設定後、本コントローラーによる"SUREQ=0"表示までの期間は、ソフトウェアによ る本ビットの書き換えを行わないでください。

## 2.14.1.2 Peripheral Controller 機能選択時

本コントローラーがSETUPトランザクションで受信したUSBリクエストデータ値を、このビットに表示します。ソフ トウェアによる本ビットへの書き込みは無効です。

## 2.14.2 USBリクエストピット (bRmRequestType)

#### 2.14.2.1 Host Controller 機能選択時

ソフトウェアで、送信するSETUPトランザクションのUSBリクエストデータ値を設定してください。

ソフトウェアによる"SUREQ=1"設定後、本コントローラーによる"SUREQ=0"表示までの期間は、ソフトウェアによ る本ビットの書き換えを行わないでください。

### 2.14.2.2 Peripheral Controller 機能選択時

本コントローラーがSETUPトランザクションで受信したUSBリクエストデータ値を、このビットに表示します。ソフ トウェアによる本ビットへの書き込みは無効です。



| •  | USB    | リク | 'エス | トバ | (リコ | L — | レジス | スタ | U | SBV | VAL | 1 |   |   |   |   |   |   | <アドし | /ス : <u>{</u> | 56H | > |
|----|--------|----|-----|----|-----|-----|-----|----|---|-----|-----|---|---|---|---|---|---|---|------|---------------|-----|---|
| 15 |        |    |     |    |     |     |     |    |   |     |     |   |   | 3 | 2 | 1 |   | 0 |      |               |     |   |
|    | wValue |    |     |    |     |     |     |    |   |     |     |   |   |   |   |   |   |   |      |               |     |   |
| 0  | C      | )  | 0   |    | 0   |     | 0   | (  | ) |     | 0   |   | 0 | 0 | 0 | 0 | 0 | 0 | 0    | 0             |     | 0 |
| 0  | C      |    | 0   |    | 0   |     | 0   | (  | ) |     | 0   |   | 0 | 0 | 0 | 0 | 0 | 0 | 0    | 0             |     | 0 |

| Bit  | Name           | Function         | S/W            | H/W          | Remarks |
|------|----------------|------------------|----------------|--------------|---------|
| 15-0 | wValue<br>バリュー | USBリクエストwValueの値 | P時:R<br>H時:R/W | P時:W<br>H時:R |         |

#### <<Remarks>>

なし

### 2.14.3 バリュービット (wValue)

USBリクエストwValueの値を書き込み、または読み出すためのビットです。b7-0が下位バイトです。

#### 2.14.3.1 Host Controller 機能選択時

ソフトウェアで、送信するSETUPトランザクションのUSBリクエストwValueの値を設定してください。

ソフトウェアによる"SUREQ=1"設定後、本コントローラーによる"SUREQ=0"表示までの期間は、ソフトウェアによ る本ビットの書き換えを行わないでください。

## 2.14.3.2 Peripheral Controller 機能選択時

本コントローラーがSETUPトランザクションで受信したUSBリクエストwValueの値を、このビットに表示します。ソ フトウェアによる本ビットへの書き込みは無効です。

<アドレス:58H>

#### ◆ USBリクエストインデックスレジスタ【USBINDX】

|    | ,  | _,,, |    |    |    |   |   |      |   |   |   |   |   |   |   |
|----|----|------|----|----|----|---|---|------|---|---|---|---|---|---|---|
| 15 | 14 | 13   | 12 | 11 | 10 | 9 | 8 | 7    | 6 | 5 | 4 | 3 | 2 | 1 | 0 |
|    |    |      |    |    |    |   |   | ndex |   |   |   |   |   |   |   |
| 0  | 0  | 0    | 0  | 0  | 0  | 0 | 0 | 0    | 0 | 0 | 0 | 0 | 0 | 0 | 0 |
| 0  | 0  | 0    | 0  | 0  | 0  | 0 | 0 | 0    | 0 | 0 | 0 | 0 | 0 | 0 | 0 |

| Bit | Name             | Function         | S/W            | H/W          | Remarks |
|-----|------------------|------------------|----------------|--------------|---------|
|     | wIndex<br>インデックス | USBリクエストwIndexの値 | P時:R<br>H時:R/W | P時:W<br>H時:R |         |

## <<Remarks>>

なし

### 2.14.4 インデックスピット (windex)

USBリクエストwIndexの値を書き込み、または読み出すためのビットです。b7-0が下位バイトです。

#### 2.14.4.1 Host Controller 機能選択時

ソフトウェアで、送信するSETUPトランザクションのUSBリクエストwIndexの値を設定してください。

ソフトウェアによる"SUREQ=1"設定後、本コントローラーによる"SUREQ=0"表示までの期間は、ソフトウェアによ る本ビットの書き換えを行わないでください。

### 2.14.4.2 Peripheral Controller 機能選択時

本コントローラーがSETUPトランザクションで受信したUSBリクエストwIndexの値を、このビットに表示します。ソ フトウェアによる本ビットへの書き込みは無効です。

page 73 of 183

#### ◆ USBリクエストレングスレジスタ【USBLENG】

| <br>•   | U | SB リ | リク | エス | <b> </b> | レング | ブス | スレジ | ス | タ【1 | USI | 3LE | NG | ] |   |   |   |   |   | < | アドレ | ノス | : 5 | AΗ | > |
|---------|---|------|----|----|----------|-----|----|-----|---|-----|-----|-----|----|---|---|---|---|---|---|---|-----|----|-----|----|---|
| 15      |   | 14   |    | 13 |          | 12  |    | 11  |   | 10  |     | 9   |    | 8 | 7 | 6 | 5 | 4 | 3 |   | 2   |    | 1   | I  | 0 |
| wLength |   |      |    |    |          |     |    |     |   |     |     |     |    |   |   |   |   |   |   |   |     |    |     |    |   |
| 0       |   | 0    |    | 0  |          | 0   |    | 0   |   | 0   |     | 0   |    | 0 | 0 | 0 | 0 | 0 | 0 |   | 0   |    | 0   |    | 0 |
| 0       |   | 0    |    | 0  |          | 0   |    | 0   |   | 0   |     | 0   |    | 0 | 0 | 0 | 0 | 0 | 0 |   | 0   |    | 0   |    | 0 |

| Bit  | Name    | Function          | S/W     | H/W  | Remarks |
|------|---------|-------------------|---------|------|---------|
| 15-0 | wLength | USBリクエストwLengthの値 | P時:R    | P時:W |         |
|      | レングス    |                   | H 時:R/W | H時:R |         |

#### <<Remarks>>

なし

## 2.14.5 レングスピット (wLength)

USBリクエストwLengthの値を書き込み、または読み出すためのビットです。b7-0が下位バイトです。

### 2.14.5.1 Host Controller 機能選択時

ソフトウェアで、送信するSETUPトランザクションのUSBリクエストwLengthの値を設定してください。

ソフトウェアによる"SUREQ=1"設定後、本コントローラーによる"SUREQ=0"表示までの期間は、ソフトウェアによ る本ビットの書き換えを行わないでください。

## 2.14.5.2 Peripheral Controller 機能選択時

本コントローラーがSETUPトランザクションで受信したUSBリクエストwLengthの値を、このビットに表示します。 ソフトウェアによる本ビットへの書き込みは無効です。



# 2.15 DCPコンフィグレーション

コントロール転送でデータ通信を行う場合は、デフォルトコントロールパイプ(DCP)を用いてください。

| <u> </u> | DCP = : | ソフィグ | <u> レーシ</u> | ョンレシ | <b>バスタ【</b> | DCPCF | G]    |        |   |   |     |   | <アドし | ノス:50 | CH> |
|----------|---------|------|-------------|------|-------------|-------|-------|--------|---|---|-----|---|------|-------|-----|
| 15       | 14      | 13   | 12          | 11   | 10          | 9     | 8     | 7      | 6 | 5 | 4   | 3 | 2    | 1     | 0   |
|          |         |      |             |      |             |       | CNTME | SHTNAK | ( |   | DIR |   |      |       |     |
| ?        | ?       | ?    | ?           | ?    | ?           | ?     | 0     | 0      | ? | ? | 0   | ? | ?    | ?     | ?   |
| ?        | ?       | ?    | ?           | ?    | ?           | ?     | -     | -      | ? | ? | -   | ? | ?    | ?     | ?   |

| Bit  | Name                        | Function                                                                                                       | S/W | H/W | Remarks             |
|------|-----------------------------|----------------------------------------------------------------------------------------------------------------|-----|-----|---------------------|
| 15-9 | 何も配置されていません。"0"に固定して        | ください。                                                                                                          |     |     |                     |
| 8    | CNTMD<br>連続転送モード            | Default Control PIPEを連続転送モードで通信<br>させるかどうかを指定します。<br>0:非連続転送モード<br>1:連続転送モード                                   | R/W | R   |                     |
| 7    | SHTNAK<br>トランスファー終了時のPIPE禁止 | Default Control PIPEが受信方向の場合に、トランスファー終了時にPIDをNAKに変更するかどうかを指定します。<br>0:トランスファー終了時にPIPE継続<br>1:トランスファー終了時にPIPE禁止 | R/W | R   |                     |
| 3-0  | 何も配置されていません。"0"に固定して        | ください。                                                                                                          |     |     |                     |
| 1    | DIR<br>転送方向                 | Host Controller 機能選択時のコントロール転<br>送のデータステージ、ステータスステージの転<br>送方向を設定します。<br>0:データ受信方向<br>1:データ送信方向                 | R/W | R   | H<br>(P時"0"<br>を設定) |
| 3-0  | 何も配置されていません。"0"に固定して        |                                                                                                                |     |     |                     |

## <<Remarks>>

なし

# 2.15.1 転送方向ビット (DIR)

Host Controller機能選択時のコントロール転送のデータステージ、ステータスステージの転送方向を本ビットに設定 してください。

Peripheral Controller機能選択時には、本ビットへは"0"を設定してください。



#### ◆ DCPマックスパケットサイズレジスタ【DCPMAXP】

| 15 | 14  | 13  | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3    | 2 | 1 | 0 |
|----|-----|-----|----|----|----|---|---|---|---|---|---|------|---|---|---|
|    | DEV | SEL |    |    |    |   |   |   |   |   |   | MXPS |   |   |   |
| 0  | 0   | 0   | 0  | ?  | ?  | ? | ? | ? | 1 | 0 | 0 | 0    | 0 | 0 | 0 |
| -  | -   | -   | -  | ?  | ?  | ? | ? | ? | - | - | - | -    | - | - | - |

<アドレス:5EH>

| Bit   | Name                      | Function                                                                                                                                                                    | S/W | H/W | Remarks                    |
|-------|---------------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-----|-----|----------------------------|
| 15-12 | DEVSEL<br>デバイス選択          | Host Controller 機能選択時に、コントロール転送の通信相手の Peripheral Device のアドレスを指定します。<br>0000:アドレス"0000"<br>0001:アドレス"0001"<br><br>1001:アドレス"1001"<br>1010:アドレス"1010"<br>1011-1111: Reserved | R/W | R   | H<br>(P時<br>all"0"を<br>設定) |
| 11-7  | 何も配置されていません。"0"に固定してください。 |                                                                                                                                                                             |     |     |                            |
| 6-0   | MXPS<br>マックスパケットサイズ       | DCPの最大データペイロード(マックスパケットサイズ)を指定します。                                                                                                                                          | R/W | R   |                            |

#### <<Remarks>>

なし

## 2.15.2 デバイス選択ビット (DEVSEL)

Host Controller機能選択時に、通信相手のUSBデバイスアドレスを本ビットに設定してください。

本ビットの設定値に対応する**DEVADDx**レジスタの設定を行ったあとで、本ビットを設定してください。例えば、"DEVSEL=0010"を設定する場合、H'D4番地の**DEVADD2**レジスタの設定を行ってください。

本ビットの設定は、"CSSTS=0"、"PID=NAK"、及び"SUREQ=0"の期間に実施してください。 DCPの**PID**ビットを"BUF"から"NAK"へ変更してから本ビットを変更する場合には、"CSSTS=0"および"PBUSY=0"を確認してから本ビットを変更してください。ただし、本コントローラーが**PID**ビットを"NAK"に変更した場合には、ソフトウェアによる**PBUSY**ビットの確認は必要ありません。

Peripheral Controller機能選択時には、本ビットへは"0000"を設定してください。

## 2.15.3 マックスパケットサイズビット (MXPS)

DCPの最大データペイロード (マックスパケットサイズ)を本ビットに設定してください。 初期値は、0x40(64Bytes)です。

MXPSビットの設定は、USB規格に準拠した値を設定してください。

MXPSビットの設定は、"CSSTS=0"、"PID=NAK"、およびCURPIPEビットに未設定時に実施してください。 対応するPIPEのPIDビットを"BUF"から"NAK"へ変更してから本ビットを変更する場合には、"CSSTS=0"および"PBUSY=0"を確認してから本ビットを変更してください。ただし、本コントローラーがPIDビットを"NAK"に変更した場合には、ソフトウェアによるPBUSYビットの確認は必要ありません。

"MXPS=0"の設定でのFIFOバッファへの書き込み、または"PID=BUF"の設定は行わないでください。



◆ DCPコントロールレジスタ【DCPCTR】

| <アトレス:60H> |      |     |   |  |  |  |  |  |
|------------|------|-----|---|--|--|--|--|--|
| 3          | 2    | 1   | 0 |  |  |  |  |  |
|            | CCPL | PID |   |  |  |  |  |  |
|            |      |     |   |  |  |  |  |  |

| 15   | 14 | 13    | 12    | 11       | 10 | 9 | 8     | 7     | 6     | 5     | 4     | 3 | 2    | 1  | 0 |
|------|----|-------|-------|----------|----|---|-------|-------|-------|-------|-------|---|------|----|---|
| BSTS |    | CSCLR | CSSTS | SUREQCLR |    |   | SQCLR | SQSET | SQMON | PBUSY | PINGE |   | CCPL | Pl | D |
| 0    | 0  | 0     | 0     | 0        | ?  | ? | 0     | 0     | 1     | 0     | 0     | ? | 0    | 0  | 0 |
| -    | -  | -     | -     | -        | ?  | ? | -     | -     | -     | -     | -     | ? | 0    | 0  | 0 |

| Bit  | Name                                                        | Function                                                                                                                                                                    | S/W           | H/W    | Remarks                  |
|------|-------------------------------------------------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------|---------------|--------|--------------------------|
|      | BSTS<br>バッファステータス                                           | DCP FIFO バッファへのアクセス可否ステー<br>タスが表示されます。<br>0:バッファアクセス不可<br>1:バッファアクセス可                                                                                                       | R             | W      |                          |
|      | SUREQ<br>SETUP トークン送出                                       | Host Controller 機能選択時に、本ビットを"1"<br>にすることによりセットアップパケットが送<br>信されます。<br>0:無効<br>1:セットアップパケット送出                                                                                 | R/W(1)        | R/W(0) | H<br>(P時"0"<br>を設定)      |
| 13   | CSCLR<br>Split Transaction の CSPLIT ステータス<br>クリア            | Host Controller 機能選択時に、Split Transaction を使用する転送について、本ビットを"1"にすることにより、CSSTS ビットを 0にクリアすることができます。このとき DCPの次回の転送は SSPLIT から再開されます。0:無効1: CSSTS ビットのクリア実行                      | R(0)/W(<br>1) | R/W(0) | H<br>(P時"0"<br>を設定)      |
| 12   | CSSTS<br>Split Transaction の COMPLETE<br>SPLIT(CSPLIT)ステータス | Host Controller 機能選択時に、Split<br>Transaction の CSPLIT ステータスが表示され<br>ます。<br>0:START-SPLIT(SSPLIT)トランザクション処<br>理中、または Split Transaction 未使用デバイス<br>の処理中<br>1:CSPLITトランザクション処理中 | R             | R/W    | H<br>(P時読<br>み出し<br>値無効) |
| 11   | SUREQCLR<br>SUREQ ビットのクリア                                   | Host Controller 機能選択時に、本ビットを"1"<br>にすることにより SUREQ ビットをクリアす<br>ることができます。<br>0:無効<br>1:SUREQ ビットの 0 クリア実行                                                                     | R(0)/W(<br>1) | R/W(0) | H<br>(P時"0"<br>を設定)      |
| 10-9 | 何も配置されていません。"0"に固定して                                        | こください。                                                                                                                                                                      |               | I      |                          |
| 8    | SQCLR<br>トグルビットクリア                                          | DCPの転送において、次のトランザクションの<br>シーケンストグルビットの期待値をDATAOに<br>設定する事ができます。<br>0:無効<br>1:DATAO指定                                                                                        | R(0)/<br>W(1) | R      |                          |
| 7    | SQSET<br>トグルビットセット                                          | DCPの転送において、次のトランザクションの<br>シーケンストグルビットの期待値をDATA1に<br>設定する事ができます。<br>0:無効<br>1:DATA1指定                                                                                        | R(0)/<br>W(1) | R      |                          |
| 6    | SQMON<br>シーケンストグルビットモニター                                    | DCPの転送において、次のトランザクションの<br>シーケンストグルビットの期待値が表示され<br>ます。<br>0:DATA0<br>1:DATA1                                                                                                 | R             | W      |                          |
|      | PBUSY<br>PIPEビジー                                            | DCPのPIDビットをBUFからNAKに変更した<br>場合に、DCPの実際の通信がNAK状態に遷移し<br>たかどうかが表示されます。<br>0:NAKに遷移未完了<br>1:NAKに遷移完了                                                                           | R             | W      |                          |

| Bit | Name                  | Function                                                                                                  | S/W | H/W    | Remarks             |
|-----|-----------------------|-----------------------------------------------------------------------------------------------------------|-----|--------|---------------------|
| 4   | PINGE<br>PINGトークン発行許可 | Host Controller機能選択時に、本ビットを1にすることによりOUTトランザクションにおいて、PINGトークンを使用することができます。0:PINGトークン発行禁止1:通常PING動作         | R/W | R      | H<br>(P時"0"<br>を設定) |
| 5-3 | 何も配置されていません。"0"に固定して  | てください。                                                                                                    |     |        |                     |
| 2   | CCPL<br>コントロール転送終了許可  | Peripheral Controller機能選択時に、ビットを<br>1にすることによりコントロール転送のステー<br>タスステージの終了許可を設定します。<br>0:無効<br>1:コントロール転送終了許可 | R/W | R/W(0) | P<br>(H時"0"<br>を設定) |
| 1-0 | PID<br>応答PID          | 本ビットによりコントロール転送における本<br>コントローラーの応答を制御します。<br>00:NAK応答<br>01:BUF応答(バッファ状態に従う)<br>10:STALL応答<br>11:STALL応答  | R/W | R/W    |                     |

### <<Remarks>>

なし

## 2.15.4 パッファステータスピット (BSTS)

DCPに割り付けたFIFOバッファへのCPUからのアクセスが可能かどうかを、本コントローラーが表示するビットです。 本ビットの意味は、ISELビットの設定値により以下のように異なります。

- (1) "ISEL=0"のとき: 受信データの読み出しが可能かどうか、を表示します。
- (2) "ISEL=1"のとき: 送信データの書き込みが可能かどうか、を表示します。

### 2.15.5 SETUPトークン送出ビット (SUREQ)

Host Controller機能選択時に、ソフトウェアが本ビットに"1"を設定することにより、本コントローラーはSETUPパケ ットを送信します。

SETUPトランザクション処理終了後、本コントローラーはSACK割り込み、もしくはSIGN割り込みのどちらかを発生 させ、本ビットを"0"にクリアします。

また、SUREQCLRビットをソフトウェアで"1"にセットする事により、本コントローラーは本ビットを"0"にクリアし ます。

**DEVSEL**ビット、**USBREQ**レジスタ、**USBVAL**レジスタ、**USBINDX**レジスタ、及び**USBLENG**レジスタにSETUPト ランザクションで送信したいUSBリクエストを設定した後で、本ビットに"1"を設定してください。"SUREQ=1"を設定す る前に、DCPのPIDビットを"NAK"に設定している事を確認してください。また、本ビットへの"1"設定後、SETUPトラ ンザクションが終了するまで ("SUREQ=1") の期間はDEVSELビット、USBREQレジスタ、USBVALレジスタ、USBINDX レジスタ、及びUSBLENGレジスタの値を変更しないでください。

SETUPトークンを出す時のみ本ビットを"1"にセットしてください。その他の時には、必ず"0"を書き込んでください。

Peripheral Controller機能選択時には、本ビットへは必ず"0"を書き込んでください。



### 2.15.6 Split TransactionのCSPLITステータスクリアピット (CSCLR)

Host Controller機能選択時に、ソフトウェアが本ビットに"1"を設定すると本コントローラーは**CSSTS**ビットを"0"にクリアします。

Split Transactionを使用する転送において、強制的に次回の転送をS-Splitから再開させたいときに、ソフトウェアで本ビットに"1"を設定してください。正常なSplit Transactionでは、C-Split終了時に本コントローラーが自動的に**CSSTS** ビットを"0"にクリアしますので、ソフトウェアによるクリア処理は不要です。

本ビットによる**CSSTS**ビットの制御は、"UACT=0"による通信停止時、またはデタッチ検出時で転送を行っていないことが確実な時に行ってください。

"CSSTS=0"の時に本ビットに"1"を設定しても、"CSSTS=0"ままです。

Peripheral Controller機能選択時には、本ビットへは必ず"0"を書き込んでください。

## 2.15.7 Split TransactionのCSPLITステータスピット (CSSTS)

Host Controller機能選択時に、本コントローラーはSplit TransactionのC-Splitステータスを本ビットに表示します。

本コントローラーは、C-Split開始時に本ビットに"1"を表示し、C-Split終了を検出したときに本ビットに"0"を表示します。

本ビットの表示は、Host Controller機能選択時のみ有効な値を示します。

## 2.15.8 SUREQのクリアピット (SUREQCLR)

Host Controller機能選択時に、ソフトウェアが本ビットに"1"を設定すると本コントローラーはSUREQビットを"0"にクリアします。本コントローラーは、常に本ビットに"0"を表示します。

SETUPトランザクションにおいて、"SUREQ=1"のまま通信が停止した時に、ソフトウェアで本ビットに"1"を設定してください。正常なSETUPトランザクションでは、トランザクション終了時に本コントローラーが自動的に**SUREQ**ビットを"0"にクリアしますので、ソフトウェアによるクリア処理は不要です。

本ビットによるSUREQビットの制御は、"UACT=0"による通信停止時、またはデタッチ検出時で転送を行っていないことが確実な時に行ってください。

Peripheral Controller機能選択時には、本ビットへは必ず"0"を書き込んでください。

### 2.15.9 シーケンストグルビットのクリアビット (SQCLR)

ソフトウェアが本ビットに"1"を設定すると本コントローラーは当該PIPEのシーケンストグルビットの期待値をDATA0に設定します。本コントローラーは、常に本ビットに"0"を表示します。

SQCLRビットとSQSETビットに同時に"1"を設定しないでください。

本ビットへの"1"設定は、"CSCTS=0"、"PID=NAK"、及び"CURPIPEに未設定時"に実施してください。 対応するPIPEの**PID**ビットを"BUF"から"NAK"へ変更してから本ビットに"1"を設定する場合には、"CSSTS=0"および"PBUSY=0"を確認してから本ビットを変更してください。ただし、本コントローラーが**PID**ビットを"NAK"に変更した場合には、ソフトウェアによる**PBUSY**ビットの確認は必要ありません。



### 2.15.10 シーケンストグルビットのセットビット (SQSET)

ソフトウェアが本ビットに"1"を設定すると本コントローラーは当該PIPEのシーケンストグルビットの期待値を DATA1に設定します。本コントローラーは、常に本ビットに"0"を表示します。

SQCLRビットとSQSETビットに同時に"1"を設定しないでください。

本ビットへの"1"設定は、"CSSTS=0"、"PID=NAK"、及び"CURPIPEに未設定時"に実施してください。

対応するPIPEのPIDビットを"BUF"から"NAK"へ変更してから本ビットに"1"を設定する場合には、"CSSTS=0"および "PBUSY=0"を確認してから本ビットを変更してください。ただし、本コントローラーがPIDビットを"NAK"に変更した 場合には、ソフトウェアによるPBUSYビットの確認は必要ありません。

## 2.15.11 シーケンストグルビットのモニタービット (SQMON)

本コントローラーは当該PIPEのシーケンストグルビットの期待値を本ビットに表示します。

トランザクションが正常処理すると本コントローラーは本ビットをトグルさせます。 ただし、受信方向転送時のDATA-PIDミスマッチ発生時には、本ビットをトグルさせません。

Peripheral Controller機能選択時、SETUPパケット正常受信時に、本コントローラーは本ビットを"1"にセット (期待 値をDATA1に設定) します。

Peripheral Controller機能選択時、本コントローラーはステータスステージのIN/OUTトランザクションでは本ビット を参照しません。また正常終了してもトグルさせません。

## 2.15.12 PIPEビジービット (PBUSY)

本コントローラーは、当該PIPEのUSBトランザクションを開始したときに本ビットを"0"から"1"に変更します。ひと つのトランザクションが終了したときに本ビットを"1"から"0"に変更します。

ソフトウェアが"PID=NAK"を設定した後、本ビットを読み出すことにより、PIPE設定変更が可能になったかどうかを 確認することが出来ます

## 2.15.13 PINGトークン発行許可ピット (PINGE)

Host Controller機能選択時にソフトウェアが本ビットに"1"を設定すると、送信方向の転送において本コントローラー はPINGトークンの発行を行います。送信方向の転送をPINGトランザクションから開始します。

PINGトランザクションにおいてACK Handshakeを検出した場合、次のトランザクションでOUTトランザクションを 実行します。

OUTトランザクションにおいてNAK Handshake、またはNYET Handshakeを検出した場合、次のトランザクション でPINGトランザクションを実行します。

Host Controller機能選択時にソフトウェアが本ビットに"0"を設定すると、送信方向の転送において本コントローラー はPINGトークンの発行を行いません。送信方向の転送はすべてOUTトランザクションで実行します。

本ビットの変更は、"CSSTS=0"、かつPID=NAK"の時に実施してください。

対応するPIPEのPIDビットを"BUF"から"NAK"へ変更してから本ビットに"1"を設定する場合には、"CSSTS=0"および "PBUSY=0"を確認してから本ビットを変更してください。ただし、本コントローラーがPIDビットを"NAK"に変更した 場合には、ソフトウェアによるPBUSYビットの確認は必要ありません。



## 2.15.14 コントロール転送終了許可ピット (CCPL)

Peripheral Controller機能選択時、対応する**PID**ビットが"BUF"のときにソフトウェアが本ビットに"1"を設定すると、本コントローラーはコントロール転送のステータスステージを完了させます。

即ち、コントロールリード転送時ではUSB HostからのOUTトランザクションに対してACK Handshakeを送信し、コントロールライト及びノーデータコントロール転送時ではUSB HostからのINトランザクションに対してZero-Lengthパケットを送信します。ただし、SET\_ADDRESSリクエスト検出時は、本ビットの設定値に関係なく本コントローラーはSETUPステージからステータスステージ完了まで自動応答を行います。

新たなSETUPパケットを受信したときに、本コントローラーは本ビットを"1"から"0"に変更します。

"VALID=1"のとき、ソフトウェアは本ビットへの"1"書き込みを行うことが出来ません。

Host Controller機能選択時には、本ビットへは必ず"0"を書き込んでください。

### 2.15.15 応答PIDビット (PID)

本ビットに対し、コントロール転送のデータステージ、またはステータスステージ実行時、ソフトウェアで本ビットを"NAK"から"BUF"に変更してください。

#### 2.15.15.1 Host Controller 機能選択時

以下の手順で本ビットを"NAK"から"BUF"に変更してください。

(1) 送信方向設定時

"UACT=1"かつ"PID=NAK"の状態でFIFOバッファに送信データを書き込み完了し、"PID=BUF"を書き込んでください。"PID=BUF"の書き込み後、本コントローラーはOUTトランザクション (またはPINGトランザクション)を実行します。

(2) 受信方向設定時

"UACT=1"かつ"PID=NAK"の状態でFIFOバッファが空の状態であることを確認し (空の状態にし)、"PID=BUF" を書き込んでください。"PID=BUF"の書き込み後、本コントローラーはINトランザクションを実行します。

以下の(1)~(3)いずれかの場合には本コントローラーが本ビットの値を変更します。

- (1) ソフトウェアが本ビットに"BUF"を設定しているときに、本コントローラーがMaxPacketSizeを超えるデータを受信した場合、本コントローラーは"PID=STALL(11)"を表示します。
- (2) CRCエラーなどの受信エラーを3回連続で検出した場合には、本コントローラーは"PID=NAK"を表示します。
- (3) STALLハンドシェイクを受信した場合、本コントローラーは"PID=STALL(11)"を表示します。

本コントローラーが当該PIPEにおいてSplitトランザクションのS-Split発行後 (CSSTS="1"表示中) にソフトウェアが本ビットを"NAK"に変更しても、C-Split終了までトランザクションを実行します。C-Split終了時に本コントローラーは"PID=NAK"を表示します。

### 2.15.15.2 Peripheral Controller 機能選択時

以下の場合には本コントローラーが本ビットの値を変更します。

- (1) 本コントローラーがSETUPパケットを受信した時に、本コントローラーは本ビットを"NAK" ("00")に変更します。この時、本コントローラーは"VALID=1"を表示し、ソフトウェアで"VALID=0"を設定するまではソフトウェアは本ビットの変更を行うことはできません。
- (2) ソフトウェアが本ビットに"BUF"を設定しているときに、本コントローラーがMaxPacketSizeを超えるデータを受信した場合、本コントローラーは"PID=STALL(11)"を表示します。
- (3) 本コントローラーがコントロール転送シーケンスエラーを検出した場合、"PID=STALL(1x)"を表示します。
- (4) 本コントローラーがUSBバスリセットを検出した場合、"PID=NAK"を表示します。

SET\_ADDRESSリクエスト処理(自動処理)時には、本コントローラーは本ビットの設定値を参照しません。



## 2.16 パイプコンフィグレーションレジスタ

PIPE1-9の設定は、PIPESELレジスタ、PIPECFGレジスタ、PIPEBUFレジスタ、PIPEMAXPレジスタ、PIPEPERIレジスタ、PIPExCTRレジスタ、PIPExTREレジスタ及びPIPExTRNレジスタで行ってください。

PIPESELレジスタにて使用するパイプを選択した後、PIPECFGレジスタ、PIPEBUFレジスタ、PIPEMAXPレジスタ、及びPIPEPERIレジスタに、各パイプの機能設定を行います。なお、PIPExCTRレジスタ、PIPExTREレジスタ及びPIPExTRNレジスタは、PIPESELレジスタによるパイプ選択とは無関係に設定可能です。

| <u> </u> | パイプウ | フィンド | ウ選択し | レジスタ | PIPE | SEL |   |   |   |   |   |   | <アドレ | ノス:64 | H> |
|----------|------|------|------|------|------|-----|---|---|---|---|---|---|------|-------|----|
| 15       | 14   | 13   | 12   | 11   | 10   | 9   | 8 | 7 | 6 | 5 | 4 | 3 | 2    | 1     | 0  |
|          |      |      |      |      |      |     |   |   |   |   |   |   | PIPE | SEL   |    |
| ?        | ?    | ?    | ?    | ?    | ?    | ?   | ? | ? | ? | ? | ? | 0 | 0    | 0     | 0  |
| ?        | ?    | ?    | ?    | ?    | ?    | ?   | ? | ? | ? | ? | ? | - | -    | -     | -  |

| Bit  | Name                 | Function                                                                                                                                     | S/W | H/W | Remarks |
|------|----------------------|----------------------------------------------------------------------------------------------------------------------------------------------|-----|-----|---------|
| 15-4 | 何も配置されていません。"0"に固定して | ください。                                                                                                                                        |     |     |         |
| 3-0  |                      | アドレス68H-6EHのレジスタに対するPIPE指定を行います。 0000:未選択 0001:PIPE1 0010:PIPE2 0011:PIPE3 0100:PIPE4 0101:PIPE5 0110:PIPE6 0111:PIPE7 1000:PIPE8 1001:PIPE8 | R/W | R   |         |

## <<Remarks>>

## 2.16.1 パイプウィンドウ選択ビット (PIPESEL)

ソフトウェアが本ビットに"0001"~"1001"を設定すると、本コントローラーはアドレスH68番地~H6C番地のレジスタに対応するPIPEの情報、及び設定値を表示します。本ビットへのPIPE指定設定後、ソフトウェアがアドレスH68番地~H6C番地に設定する値は、本コントローラーによって対応するPIPEの転送方法に反映されます。

ソフトウェアが本ビットに"0000"を設定すると、本コントローラーはアドレスH68番地~H6E番地のレジスタにALL"0"を表示します。この時、ソフトウェアによるアドレスH68番地~H6E番地への書き込みは無効です。



<sup>\* &</sup>quot;PIPESEL=0000"設定時は、上記の関連レジスタの各ビットにすべて"0"が読み出されます。"PIPESEL=0000"設定時のアドレス 68H-6EH のレジスタに対する書き込みは無効です。

## ◆ パイプコンフィグレーションレジスタ【PIPECFG】

| •  | パイプ | ゚コン | フィ | グレー | ・ショ | ンレ | <b>/</b> ジスタ | [PIPE | CFG]  |        |    |   |     |   | <アドし | ノス:68 | BH> |
|----|-----|-----|----|-----|-----|----|--------------|-------|-------|--------|----|---|-----|---|------|-------|-----|
| 15 | 14  | 1   | 3  | 12  |     | 11 | 10           | 9     | 8     | 7      | 6  | 5 | 4   | 3 | 2    | 1     | 0   |
| T١ | /PE |     |    |     |     |    | BFRE         | DBLB  | CNTMD | SHTNAK |    |   | DIR |   | EPI  | NUM   |     |
| 0  | 0   |     | ?  | ?   |     | ?  | 0            | 0     | 0     | 0      | ?  | ? | 0   | 0 | 0    | 0     | 0   |
|    | . i |     |    |     |     |    |              | ·     | i     |        | ·A |   | ·   | ā |      |       | A   |

| Bit   | Name                       | Function                                     | S/W      | H/W | Remarks |
|-------|----------------------------|----------------------------------------------|----------|-----|---------|
| _     | TYPE<br>転送タイプ              | PIPESELビットに指定したPIPE(当該PIPE)の<br>転送タイプを指定します。 | R/W      | R   |         |
|       |                            | 00:パイプ使用不可                                   |          |     |         |
|       |                            | 01:バルク転送<br>10:インタラプト転送                      |          |     |         |
|       |                            | 10:1 フラフフト転送<br> 11:アイソクロナス転送                |          |     |         |
| 13-11 | <br>  何も配置されていません。"0"に固定して |                                              |          |     |         |
|       | BFRE                       | 本コントローラからの当該PIPE に関する                        | R/W      | R   |         |
|       | BRDY割り込み動作指定               | BRDY割り込みの通知タイミングを指定しま                        |          |     |         |
|       |                            | す。                                           |          |     |         |
|       |                            | 0:データ送受信時にBRDY割り込み通知                         |          |     |         |
|       |                            | 1:データ読み出し完了時にBRDY割り込み通知                      |          |     |         |
| 9     | DBLB                       | 当該PIPEが使用するFIFOバッファがシングル                     | R/W      | R   |         |
|       | ダブルバッファモード                 | バッファかダブルバッファかを指定します。                         |          |     |         |
|       |                            | 0:シングルバッファ                                   |          |     |         |
|       | ONTAR                      | 1:ダブルバッファ                                    | D 444    |     |         |
| _     | CNTMD<br>連続転送モード           | 当該PIPEを連続転送モードで通信させるかど<br>うかを指定します。          | R/W      | R   |         |
|       |                            | 7) で相足しより。<br>  0:非連続転送モード                   |          |     |         |
|       |                            | 1:連続転送モード                                    |          |     |         |
| 7     | SHTNAK                     | 当該PIPEが受信方向の場合に、トランスフ                        | R/W      | R   |         |
|       | トランスファー終了時のPIPE禁止          | ァー終了時にPIDをNAKに変更するかどうか                       |          |     |         |
|       |                            | を指定します。                                      |          |     |         |
|       |                            | 0:トランスファー終了時にPIPE継続<br>1:トランスファー終了時にPIPE禁止   |          |     |         |
| 6-5   | <br>  何も配置されていません。"0"に固定して |                                              |          |     |         |
|       | DIR                        | 当該PIPEの転送方向を指定します。                           | R/W      | R   |         |
|       | 転送方向                       | 日 : 受信方向                                     | 1 V, V V |     |         |
|       |                            | 1:送信方向                                       |          |     |         |
| 3-0   | EPNUM                      | 当該PIPEのエンドポイント番号を指定しま                        | R/W      | R   |         |
|       | エンドポイント番号                  | す。                                           |          |     |         |

## <<Remarks>>

なし



## 2.16.2 転送タイプピット (TYPE)

PIPESELビットに設定したPIPE (選択PIPE) のUSB転送タイプを本ビットに対して設定してください。 選択PIPEと本ビットに設定可能な転送タイプの一覧を表 2.14に示します。

表 2.14 選択PIPEとTYPEビットに設定可能な転送タイプの一覧

| 選択 PIPE         | TYPE ビット     | USB 転送 TYPE                |
|-----------------|--------------|----------------------------|
| PIPE1、または PIPE2 | "01"、または"11" | bulk 転送、または isochronous 転送 |
| PIPE3 ~ PIPE5   | "01"         | bulk 転送                    |
| PIPE6 ~ PIPE9   | "10"         | interrupt 転送               |

"PID=BUF"に設定(することにより選択PIPEを使用したUSB通信を開始)する前に、必ず本ビットを"00"以外の値に設定してください。

本ビットの変更は、選択PIPEの**PID**ビットが"NAK"状態の時に行ってください。選択PIPEの**PID**ビットを"BUF"から "NAK"へ変更してから本ビットを変更する場合には、"CSSTS=0"および"PBUSY=0"を確認してから本ビットを変更してください。ただし、本コントローラーが**PID**ビットを"NAK"に変更した場合には、ソフトウェアによる**PBUSY**ビットの確認は必要ありません。

## 2.16.3 BRDY割り込み動作指定ビット (BFRE)

本ビットは、選択PIPEがPIPE1~PIPE5の場合に有効なビットです。

ソフトウェアが本ビットに"1"を設定し、かつ、選択PIPEを受信方向で使用している (即ち"DIRビット=0"に設定している時)場合、本コントローラーは、トランスファーの終了を検出し、そのパケットを読み出し終えた時にBRDY割り込みを発行します。

この設定でBRDY割り込みが発生した時には、ソフトウェアは"BCLR=1"の書き込み処理を行う必要があります。 "BCLR=1"を行うまでは選択PIPEに割り付けられたFIFOバッファは受信可能状態になりません。

ソフトウェアが本ビットに"1"を設定し、かつ、選択PIPEの選択PIPEを送信方向で使用している(即ち"DIRビット=1"に設定している時)場合、本コントローラーはBRDY割り込みを発生させません。

詳細は、PIPEBRDY割り込みレジスタを参照してください。

本ビットの変更は、"CSSTS=0"、"PID=NAK"、およびCURPIPEビットにPIPE未設定、の状態の時に実施してください。

また、選択PIPEを使用したUSB通信を行った後、本ビットの設定を変更する場合には、上記3つのレジスタの状態に加え、ソフトウェアで"ACLRM=1"、"ACLRM=0"を連続して書き込み、選択PIPEに割り付けられたFIFOバッファのクリアを実行してください。

選択PIPEの**PID**ビットを"BUF"から"NAK"へ変更してから本ビットを変更する場合には、"CSSTS=0"および"PBUSY=0"を確認してから本ビットを変更してください。ただし、本コントローラーが**PID**ビットを"NAK"に変更した場合には、ソフトウェアによる**PBUSY**ビットの確認は必要ありません。

## 2.16.4 ダブルバッファモードビット (DBLB)

本ビットは、選択PIPEがPIPE1~PIPE5の場合に有効なビットです。

ソフトウェアが本ビットに"1"を設定している場合、本コントローラーは選択PIPEに対し、**PIPEBUF**レジスタの**BUFSIZE**ビットで指定したFIFOバッファサイズを2面分割り当てます。

即ち、本コントローラーが選択PIPEに対して割り当てるFIFOバッファの容量は以下のとおりです。 (BUFSIZE+1)\*64\*(DBLB+1) [バイト]

ソフトウェアが本ビットに"1"を設定し、かつ、選択PIPEを送信方向で使用している ("DIRビット=1"に設定している) 場合、本コントローラーはBRDY割り込みを発生させません。

詳細は、PIPEBRDY割り込みレジスタを参照してください。

本ビットの変更は、"CSSTS=0"、"PID=NAK"、およびCURPIPEビットにPIPE未設定、の状態の時に実施してくださ



l1.

また、選択PIPEを使用したUSB通信を行った後、本ビットの設定を変更する場合には、上記3つのレジスタの状態に加 え、ソフトウェアで"ACLRM=1"、"ACLRM=0"を連続して書き込み、選択PIPEに割り付けられたFIFOバッファのクリ アを実行してください。

選択PIPEのPIDビットを"BUF"から"NAK"へ変更してから本ビットを変更する場合には、"CSSTS=0"および "PBUSY=0"を確認してから本ビットを変更してください。ただし、本コントローラーがPIDビットを"NAK"に変更した 場合には、ソフトウェアによるPBUSYビットの確認は必要ありません。

## 2.16.5 連続転送モードビット (CNTMD)

本ビットは、選択PIPEがPIPE1~PIPE5であり、かつ、選択PIPEの転送タイプをbulkに設定している場合に有効なビ ットです。

本ビットの設定値によって、本コントローラーは選択PIPEに割り当てられたFIFOバッファに対する送受信完了判定を 表 2.15に示すとおりに行います。

表 2.15 CNTMDビット設定値とFIFOバッファに対する送受信完了判定方法の関係

| CNTMD ビット | 読み出し可能状態、送信可能の判定方法                                     |
|-----------|--------------------------------------------------------|
| 設定値       |                                                        |
| 0         | 受信方向設定時("DIR=0")FIFO バッファ読み出し可能状態になる条件;                |
|           | 本コントローラーが1パケット受信した時                                    |
|           | 送信方向設定時("DIR=1")FIFO バッファ送信可能状態になる条件;                  |
|           | 以下(1)、(2)のいずれかを満たした時                                   |
|           | (1) ソフトウェア (または DMAC) がマックスパケットサイズ分のデータを FIFO バッファに書き  |
|           | 込んだ。                                                   |
|           | (2) ソフトウェア(または DMAC) がショートパケット分のデータ (0 バイトの場合を含む) を    |
|           | FIFO バッファに書き込み、"BVAL=1"を書き込んだ。                         |
| 1         | 受信方向設定時("DIR=0")FIFO バッファ読み出し可能状態になる条件;                |
|           | (1)選択 PIPE に設定した FIFO バッファに受信したデータのバイト数と、設定したバ         |
|           | イト数 ((BUFSIZE+1)*64) が等しくなったとき                         |
|           | (2) 本コントローラーが Zero-Length パケット以外のショートパケットを受信したとき       |
|           | (3) 選択 PIPE に設定した FIFO バッファにすでにデータが格納されている状態で、本コン      |
|           | トローラーが Zero-Length パケットを受信したとき。                        |
|           | (4)ソフトウェアが選択 PIPE に対して設定したトランザクションカウンター回数分のパケットを       |
|           | 受信した時                                                  |
|           | 送信方向設定時("DIR=1")FIFO バッファ送信可能状態になる条件;                  |
|           | 以下(1)から(3)のいずれかを満たしたとき                                 |
|           | (1) ソフトウェア(または DMAC) が書き込んだデータ数が、選択 PIPE に設定した FIFO    |
|           | バッファサイズ 1 面分と等しくなったとき。                                 |
|           | (2) ソフトウェア(または DMAC)が、選択 PIPE に設定した FIFO バッファサイズ 1 面分よ |
|           | りも小さいデータ数 (0 バイトの場合を含む) を FIFO バッファに書き込み、"BVAL=1"を書き   |
|           | 込んだ時。                                                  |
|           | (3) DMAC が、選択 PIPE に設定した FIFO バッファサイズ1面分よ              |
|           | りも小さいデータ数を FIFO バッファに書き込み、最後の書き込み                      |
|           | と同時に DENDx_N 信号をアサートした時。                               |

本ビットの変更は、"CSSTS=0"、"PID=NAK"、およびCURPIPEビットにPIPE未設定、の状態の時に実施してくださ l 1.

また、選択PIPEを使用したUSB通信を行った後、本ビットの設定を変更する場合には、上記3つのレジスタの状態に加 え、ソフトウェアで"ACLRM=1"、"ACLRM=0"を連続して書き込み、選択PIPEに割り付けられたFIFOバッファのクリ アを実行してください。

選択PIPEのPIDビットを"BUF"から"NAK"へ変更してから本ビットを変更する場合には、"CSSTS=0"および "PBUSY=0"を確認してから本ビットを変更してください。ただし、本コントローラーが**PID**ビットを"NAK"に変更した 場合には、ソフトウェアによるPBUSYビットの確認は必要ありません。



## 2.16.6 トランスファー終了時のPIPE禁止ビット (SHTNAK)

本ビットは、選択PIPEがPIPE1~PIPE5であり、かつ、受信方向である場合に有効なビットです。

受信方向PIPEに対してソフトウェアが本ビットに"1"を設定している場合、本コントローラーは、選択PIPEに対しト ランスファーの終了を判定したときに選択PIPEに対応するPIDビットを"NAK"に変更します。本コントローラーは、以 下(1)または(2)の条件が満たされた時にトランスファー終了と判定します。

- (1) ショートパケットデータ (Zero-Lengthパケットを含む) を正常に受信した時。
- (2) トランザクションカウンタを使用し、トランザクションカウンタ分のパケットを正常受信した時。

本ビットの変更は、"CSSTS=0"、及び"PID=NAK"の状態の時に実施してください。

選択PIPEのPIDビットを"BUF"から"NAK"へ変更してから本ビットを変更する場合には、"CSSTS=0"および "PBUSY=0"を確認してから本ビットを変更してください。ただし、本コントローラーが**PID**ビットを"NAK"に変更した 場合には、ソフトウェアによるPBUSYビットの確認は必要ありません。

送信方向PIPEに対しては、本ビットを"0"に設定してください。

#### 2.16.7 転送方向ビット (DIR)

ソフトウェアが本ビットに"0"を設定している場合、本コントローラーは選択PIPEを受信方向に、本ビットに"1"を設定 している場合、本コントローラーは選択PIPEを送信方向に使用します。

本ビットの変更は、"CSSTS=0"、"PID=NAK"、およびCURPIPEビットにPIPE未設定、の状態の時に実施してくださ L1.

また、選択PIPEを使用したUSB通信を行った後、本ビットの設定を変更する場合には、上記3つのレジスタの状態に加 え、ソフトウェアで"ACLRM=1"、"ACLRM=0"を連続して書き込み、選択PIPEに割り付けられたFIFOバッファのクリ アを実行してください。

選択PIPEのPIDビットを"BUF"から"NAK"へ変更してから本ビットを変更する場合には、"CSSTS=0"および "PBUSY=0"を確認してから本ビットを変更してください。ただし、本コントローラーが**PID**ビットを"NAK"に変更した 場合には、ソフトウェアによるPBUSYビットの確認は必要ありません。

#### 2.16.8 エンドポイント番号ビット (EPNUM)

ソフトウェアで本ビットに選択PIPEに対するエンドポイント番号を設定してください。 ただし、"0000"の設定は、未使用PIPEを意味します。

本ビットの変更は、"CSSTS=0"、"PID=NAK"、およびCURPIPEビットにPIPE未設定、の状態の時に実施してくださ l 1.

選択PIPEのPIDビットを"BUF"から"NAK"へ変更してから本ビットを変更する場合には、"CSSTS=0"および "PBUSY=0"を確認してから本ビットを変更してください。ただし、本コントローラーがPIDビットを"NAK"に変更した 場合には、ソフトウェアによるPBUSYビットの確認は必要ありません。

DIRビットとEPNUMビットの設定の組み合わせが他のPIPE設定と重複しないようにして設定してください。 ("EPNUM=000" (選択PIPEは未使用) の設定は重複可能です)



#### ◆ パイプバッファ指定レジスタ【PIPEBUF】

| <アドレス:6AH> |
|------------|
|------------|

| 15 | 14 | 13 |   | 12    |   | 11 | 10 | 9 | 8 | 7 |   | 6 | 5 | 4 |    | 3    |   | 2 | 1 | 0 |  |
|----|----|----|---|-------|---|----|----|---|---|---|---|---|---|---|----|------|---|---|---|---|--|
|    |    |    | В | UFSIZ | E |    |    |   |   |   | I |   |   |   | BU | IFNM | В |   |   |   |  |
| ?  | 0  | 0  |   | 0     |   | 0  | 0  | ? | ? | 0 | T | 0 | 0 | 0 | Ī  | 0    |   | 0 | 0 | 0 |  |
| ?  | -  | -  |   | -     |   | -  | -  | ? | ? | - | ı | - | - | - |    | -    |   | - | - | - |  |

| Bit   | Name                 | Function                                                                                              | S/W | H/W | Remarks |
|-------|----------------------|-------------------------------------------------------------------------------------------------------|-----|-----|---------|
| 15    | 何も配置されていません。"0"に固定して | てください。                                                                                                |     |     |         |
| 14-10 | バッファサイズ              | PIPESELビットに指定したPIPE(当該PIPE)の<br>FIFOバッファサイズを指定します。<br>0x00: 64バイト<br>0x01: 128バイト<br><br>0x1F: 2Kバイト) | R/W | R   |         |
| 9-8   | 何も配置されていません。"0"に固定して | こください。                                                                                                |     |     |         |
| 7-0   | BUFNMB<br>バッファ番号     | 当該PIPE のFIFOバッファ番号を指定します。<br>(0x4 - 0x87)                                                             | R/W | R   |         |

#### <<Remarks>>

- 本レジスタの各ビットの変更は、ソフトウェアが"CSSTS=0"、"PID=NAK"、および CURPIPE ビットに PIPE 未設定、の状態 の時に実施してください。
- \*選択 PIPE の PID ビットを"BUF"から"NAK"へ変更してから本ビットを変更する場合には、"CSSTS=0"および"PBUSY=0"を確 認してから本ビットを変更してください。ただし、本コントローラーが PID ビットを"NAK"に変更した場合には、ソフトウェア による PBUSY ビットの確認は必要ありません。

## 2.16.9 バッファサイズピット (BUFSIZE)

当該PIPEに割り付けるFIFOバッファサイズを、本ビットに指定してください。

単位はブロック数であり、1ブロックは64バイトです。

ソフトウェアが"DBLB=1"を設定している場合、本コントローラーは選択PIPEに対し、本ビットで指定したFIFOバッ ファサイズを2面分割り当てます。

本コントローラーが選択PIPEに対して割り当てるFIFOバッファの容量は以下のとおりです。

(BUFSIZE+1)\*64\*(DBLB+1) [バイト]

本ビットへは以下の範囲の値を設定してください。

- (1) 選択PIPEがPIPE1~PIPE5の場合; 0x0から0x1Fの値を設定可能です。
- (2) 選択PIPEがPIPE6~PIPE9の場合; 0x0のみを設定可能です。

"CNTMD=1"で使用する場合には、BUFSIZEビットにはMaxPacketSizeの整数倍の値を設定してください。

### 2.16.10 バッファ番号ビット (BUFNMB)

当該PIPEに割り付けるFIFOバッファのうち、先頭のブロック番号を指定してください。 本コントローラーが選択PIPEに対して割り当てるFIFOバッファのブロックは以下のとおりです。 ブロック番号:BUFNMB~ブロック番号:BUFNMB+(BUFSIZE+1)\*(DBLB+1)-1

本ビットへは0(0x00) から8640(0x87) の範囲の値を設定してください。ただし、以下の条件を守ってください。 0x00~0x03~0x03はDCP専用です。

0x04はPIPE6専用です。ただしPIPE6を使用しない場合は他のPIPEで使用可能です。また選択PIPEがPIPE6の場合、 本ビットへの書き込みは無効です。本コントローラーはPIPE6に対し"BUFNMB=0x04"を自動的に割り付けます。

"0x05はPIPE7専用です。ただしPIPE7を使用しない場合は他のPIPEで使用可能です。また選択PIPEがPIPE7の場合、

本ビットへの書き込みは無効です。本コントローラーはPIPE7に対し"BUFNMB=0x05"を自動的に割り付けます。

0x06はPIPE8専用です。ただしPIPE8を使用しない場合は他のPIPEで使用可能です。また選択PIPEがPIPE8の場合、

本ビットへの書き込みは無効です。本コントローラーはPIPE8に対し"BUFNMB=0x06"を自動的に割り付けます。 0x07はPIPE9専用です。ただしPIPE9を使用しない場合は他のPIPEで使用可能です。また選択PIPEがPIPE9の場合、

本ビットへの書き込みは無効です。本コントローラーはPIPE9に対し"BUFNMB=0x07"を自動的に割り付けます。

page 87 of 183

#### ◆ パイプマックスパケットサイズレジスタ【PIPFMAXP】

| •  | パイプマ | マックス | パケッ | トサイズ | レジスケ | タ【PIP | EMAX | P] |      |      |   |   | <アドし | ノス:60 | CH> |
|----|------|------|-----|------|------|-------|------|----|------|------|---|---|------|-------|-----|
| 15 | 14   | 13   | 12  | 11   | 10   | 9     | 8    | 7  | 6    | 5    | 4 | 3 | 2    | 1     | 0   |
|    | DEV  | 'SEL |     |      |      |       |      |    |      | MXPS |   |   |      |       |     |
| 0  | 0    | 0    | 0   | ?    | 0    | 0     | 0    | 0  | 0(1) | 0    | 0 | 0 | 0    | 0     | 0   |
| -  | -    | -    | -   | ?    | -    | -     | -    | -  | -    | -    | - | - | -    | -     | -   |

| Bit   | Name                 | Function                                                                                                                                                  | S/W | H/W | Remarks                    |
|-------|----------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------|-----|-----|----------------------------|
| 15-12 | DEVSEL<br>デバイス選択     | Host Controller 機能選択時にペリフェラルの<br>デバイスアドレスを指定します。<br>0000:アドレス"0000"<br>0001:アドレス"0001"<br><br>1001:アドレス"1001"<br>1010:アドレス"1010"<br>1011 - 1111: Reserved | R/W | R   | H<br>(P時<br>all"0"を<br>設定) |
| 11    | 何も配置されていません。"0"に固定して | てください。                                                                                                                                                    |     |     |                            |
| 10-0  | MXPS<br>マックスパケットサイズ  | 当該パイプの最大データペイロード(マックスパケットサイズ)を指定します。<br>PIPE6 - 9 は 0x1 – 0x40 バイトまで設定可能です。                                                                               | R/W | R   |                            |

#### <<Remarks>>

## 2.16.11 デバイス選択ビット (DEVSEL)

Host Controller機能選択時に、通信相手のUSBデバイスアドレスを本ビットに設定してください。

本ビットの設定値に対応するDEVADDxレジスタの設定を行ったあとで、本ビットを設定してください。 例えば、"DEVSEL=0010"を設定する場合、H'D4番地のDEVADD2レジスタの設定を行ってください。

本ビットの設定は、"CSSTS=0"、"PID=NAK"の期間に実施してください。

対応するPIPEのPIDビットを"BUF"から"NAK"へ変更してから本ビットを変更する場合には、"CSSTS=0"および "PBUSY=0"を確認してから本ビットを変更してください。ただし、本コントローラーが**PID**ビットを"NAK"に変更した 場合には、ソフトウェアによるPBUSYビットの確認は必要ありません。

Peripheral Controller機能選択時には、本ビットへは"0000"を設定してください。

## 2.16.12 マックスパケットサイズビット (MXPS)

選択PIPEの最大データペイロード(マックスパケットサイズ)を本ビットに設定してください。

PIPE1,2に対しては1バイト (0x1) ~1024バイト (0x400) の値を設定可能です。

PIPE3~5に対しては8バイト (0x8)、16バイト (0x10)、32バイト (0x20)、64バイト (0x40)、512バイト (0x200) の 値を設定可能です。([2:0]のビットはありません。)

PIPE6~9に対しては1バイト (0x1) ~64バイト (0x40) の値を設定可能です。

初期値は、0x40 (64バイト) です。

MXPSビットの設定は、転送タイプ毎にUSB規格に準拠した値を設定してください。

Isochronous-PIPEをSplit-Transactionで通信する場合には、MXPSビットには188バイト以下の値を設定してください。 MXPSビットの設定は、"CSSTS=0"、"PID=NAK"、およびCURPIPEビットに未設定時に実施してください。

対応するPIPEのPIDビットを"BUF"から"NAK"へ変更してから本ビットを変更する場合には、"CSSTS=0"および "PBUSY=0"を確認してから本ビットを変更してください。ただし、本コントローラーがPIDビットを"NAK"に変更した 場合には、ソフトウェアによるPBUSYビットの確認は必要ありません。

"MXPS=0"の設定でのFIFOバッファへの書き込み、または"PID=BUF"の設定は行わないでください。



<sup>\*</sup> MXPS ビットの初期値は、PIPESEL レジスタの PIPESEL ビットでパイプを選択していないときは"0x00"、パイプを選択して いる時は"0x40"が表示されます。

#### ◆ パイプ周期制御レジスタ【PIPFPFRI】

| •  | パイこ | プ周 | 期制御 | レジス  | タ【PIF | PEPERI | 1 |   |   |   |   |   |   | <アド | レス:6 | EH> |
|----|-----|----|-----|------|-------|--------|---|---|---|---|---|---|---|-----|------|-----|
| 15 | 14  |    | 13  | 12   | 11    | 10     | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2   | 1    | 0   |
|    |     |    |     | IFIS |       |        |   |   |   |   |   |   |   |     | IITV |     |
| ?  | ?   |    | ?   | 0    | ?     | ?      | ? | ? | ? | ? | ? | ? | ? | 0   | 0    | 0   |
| 2  | ^   |    | ^   | E .  |       | 2      | ^ | 1 |   |   |   |   | 1 |     | 1    | 1   |

| Bit   | Name                  | Function                                                                                                  | S/W | H/W | Remarks             |
|-------|-----------------------|-----------------------------------------------------------------------------------------------------------|-----|-----|---------------------|
| 15-13 | 何も配置されていません。"0"に固定して  | ください。                                                                                                     |     |     |                     |
| 12    | アイソクロナスINバッファフラッシュ    | PIPESELビットに指定したPIPE(当該PIPE)が<br>アイソクロナスIN転送の場合に、バッファフラ<br>ッシュ有無を指定します。<br>0:バッファフラッシュしない<br>1:バッファフラッシュする | R/W | R   | P<br>(H時"0"<br>を設定) |
| 11-3  | 何も配置されていません。"0"に固定して  | ください。                                                                                                     |     |     |                     |
| 2-0   | IITV<br>インターバルエラー検出間隔 | 当該PIPEの転送インターバルタイミングをフレームタイミングの2のn乗で指定します。                                                                | R/W | R   |                     |

#### <<Remarks>>

なし

### 2.16.13 アイソクロナスINバッファフラッシュピット (IFIS)

Peripheral Controller機能選択時に、選択PIPEの転送TYPEがIsochronous、かつ転送方向がIN転送の場合において、 IITVビットに設定したInterval毎の(マイクロ)フレーム中にUSB HOSTからIN-Tokenを本コントローラーが受信しな かった場合に、本コントローラーが自動的にFIFOバッファをクリアする機能です。

ダブルバッファ設定時 ("DBLB=1"設定時) は、本コントローラーがクリアするのは古い方の1面分データのみです。 FIFOバッファクリアのタイミングは、IN-Tokenを受信するはずの(マイクロ)フレーム直後のSOFパケット受信時で す。またSOFパケットが破損した場合でも内部補間機能によりSOFを受信すべきタイミングにクリアを行います。

Host Controller機能選択時には、本ビットへは"0"を設定してください。 選択PIPEの転送TYPEがIsochronous以外の場合は、本ビットへは"0"を設定してください。

### 2.16.14 インターバルエラー検出間隔ビット (IITV)

本ビットにインターバルエラー検出間隔をフレームタイミングの2のn乗で指定してください。 詳細機能は、後述のようにHost Controller機能選択時とPeripheral Controller機能選択時で異なります。

本ビットの設定は、"CSSTS=0"、"PID=NAK"、およびCURPIPEビットに未設定時に実施してください。 対応するPIPEのPIDビットを"BUF"から"NAK"へ変更してから本ビットを変更する場合には、"CSSTS=0"および "PBUSY=0"を確認してから本ビットを変更してください。ただし、本コントローラーが**PID**ビットを"NAK"に変更した 場合には、ソフトウェアによるPBUSYビットの確認は必要ありません。

本ビットを設定し、USB通信を行った後で別の値に変更する場合には、"PID=NAK"設定後"ACLRM=1"をセットし、 Intervalタイマの初期化を行って下さい。

PIPE3~5に対しては、本ビットは存在しません。PIPE3~5に対応する本ビットには"0"を設定してください。



## 2.16.14.1 Host Controller 機能選択時

選択PIPEの転送TYPEがIsochronous、またはInterruptの場合に、本ビットへの設定が可能です。本ビットの設定値に従って本コントローラーはToken発行間隔を制御します。本コントローラーは2^IITV回の(マイクロ)フレームに1回の間隔で選択PIPEに対するTokenを発行します。

本コントローラーは、High-Speed HUBに接続されたFull-Speed/Low-Speed Peripheral デバイスとの通信に使用する PIPEに対しては、1msフレームでインターバルをカウントします。

本コントローラーは、ソフトウェアが**PID**ビットを"BUF"に設定した次の(マイクロ)フレームからToken発行間隔のカウントを開始します。

| USB バス                          | S<br>O<br>F |    | S O F |    | S O F | O<br>U<br>T | D<br>A<br>T<br>A<br>0 | S O F | O<br>U<br>T | D<br>A<br>T<br>A<br>0 |
|---------------------------------|-------------|----|-------|----|-------|-------------|-----------------------|-------|-------------|-----------------------|
| PID ビット設定値                      | N           | ΑK | В     | UF | В     | U           | F                     | В     | U           | F                     |
| Token 発行有無<br>(0: 発行<br>-: 非発行) |             | -  |       | -  |       | 0           |                       |       | 0           |                       |
| インターバル<br>カウント開始                |             |    |       |    |       |             |                       |       |             |                       |

図 2.1 "IITV=0"の場合のToken発行有無

| USB バス                          | S O F |    | S O F |    | S<br>O<br>F | O<br>U<br>T | D<br>A<br>T<br>A<br>0 | S O F |    | S O F | O U T | D<br>A<br>T<br>A<br>0 | S O F |   |   | S O F | O<br>T |   |
|---------------------------------|-------|----|-------|----|-------------|-------------|-----------------------|-------|----|-------|-------|-----------------------|-------|---|---|-------|--------|---|
| PID ビット設定値                      | N     | ΑK | В     | UF | В           | U           | F                     | В     | UF | В     | U     | F                     | В     | U | F | В     | U      | F |
| Token 発行有無<br>(0: 発行<br>-: 非発行) |       | -  |       | -  |             | 0           |                       |       | -  |       | 0     |                       |       | - |   |       | 0      |   |
| インターバル<br>カウント開始                |       |    |       |    |             |             |                       |       |    |       |       |                       |       |   |   |       |        | _ |

図 2.2 "IITV=1"の場合のToken発行有無

選択PIPEの転送TYPEがIsochronousの場合には、本コントローラーはToken発行間隔の制御に付随して以下の動作を行います。転送TYPEがIsochronousの場合、NRDY割り込み発生条件を満たした場合でも本コントローラーはTokenを発行します。

## (1) 選択PIPEがIsochronous-IN転送PIPEの場合

In-Tokenを発行し、Peripheral デバイスから正常にパケットを受信しなかった場合 (無応答やパケットエラー等の場合) に、NRDY割り込みを発生させます。

(ソフトウェア (DMAC) がFIFOバッファからデータを読み出すのが遅いなどの原因で) FIFOバッファがフルのために、本コントローラーがデータを受信できない状態で、IN-Token発行タイミングに至った場合、本コントローラーはOVRNビットに"1"を表示し、NRDY割り込みを発生させます。

### (2) 選択PIPEがIsochronous-OUT転送PIPEの場合

(ソフトウェア (DMAC) がFIFOバッファにデータを書き込むのが遅いなどの原因で) 送信可能なデータがFIFO バッファに無い状態でOUT-TOKEN発行タイミングに至った場合、本コントローラーはOVRNビットに"1"を表示し、NRDY割り込みを発生させ、Zero-Lengthパケットを送信します。

Token発行間隔のリセット条件は以下(1)または(2)の場合です。

- (1) 本コントローラーがHWリセットされた場合 (この時、**IITV**ビットへの設定値も"0"にクリアされます。)
- (2) ソフトウェアが"ACLRM=1"を設定した場合。



#### 2.16.14.2 Peripheral Controller 機能選択時

選択PIPEの転送TYPEがIsochronousの場合に、本ビットへの設定が可能です。

(1) 選択PIPEがIsochronous-OUT転送PIPEの場合

IITVビットに設定したInterval毎の (マイクロ) フレーム中にDATAパケットを受信しなかった時、本コントロー ラーはNRDY割り込みを発生させます。

DATAパケットにCRCエラー等のエラーが発生したために受信できなかった時、または (ソフトウェア (DMAC) がFIFOバッファからデータを読み出すのが遅いなどの原因で) FIFOバッファがフルのために本コントローラーが データを受信できなかったときにもNRDY割り込みを発生させます。

NRDY割り込みの発生のタイミングは、SOFパケット受信時です。またSOFパケットが破損した場合でも内部補間 機能によりSOFを受信すべきタイミングに割り込みを発生させます。

ただし"IITV=0"以外の時には、インターバルのカウント開始後のインターバル毎のSOFパケット受信時にNRDY 割込みを発生させます。

インターバルタイマ起動後、ソフトウェアでPIDビットを"NAK"に設定した場合、本コントローラーはSOFパケッ トを受信してもNRDY割込みを発生させません。

インターバルのカウント開始条件は、IITVビットの設定値により異なります。

(a) "IITV=0"の時: 選択PIPEのPIDビットを"BUF"に変更した次の(マイクロ)フレームからインターバルのカウント を開始します。

| (マイクロ)<br>フレーム                          | S<br>O<br>F | SOF | S O D O U A F T A O | S O D O D A F T A O O |
|-----------------------------------------|-------------|-----|---------------------|-----------------------|
| PID ビット設定値                              | NAK         | BUF | BUF                 | BUF                   |
| Token 受信期待有無<br>(0: 受信を期待<br>-: 非受信を期待) | -           | -   | 0                   | 0                     |
| インターバル<br>カウント開始                        |             |     |                     |                       |

図 2.3 "IITV=0"の場合の (マイクロ) フレームとToken受信期待有無の関係

(b) "IITV=0"以外の時: 選択PIPEのPIDビットを"BUF"に変更した後最初のDATAパケット正常受信完了時点からイン ターバルのカウントを開始します。

| (マイクロ)<br>フレーム                          | S O F |    | SOF |    | SOF | OUT | D<br>A<br>T<br>A<br>0 | S O F |    | SOF | OUT | D<br>A<br>T<br>A<br>0 | S O F |   |   | SOF | OUT | D<br>A<br>T<br>A |
|-----------------------------------------|-------|----|-----|----|-----|-----|-----------------------|-------|----|-----|-----|-----------------------|-------|---|---|-----|-----|------------------|
| PID ビット設定値                              | N     | ΑK | В   | UF | В   | U   | F                     | В     | UF | В   | U   | F                     | В     | U | F | В   | U   | F                |
| Token 受信期待有無<br>(0: 受信を期待<br>-: 非受信を期待) |       | -  |     | -  |     | 0   |                       |       | -  |     | 0   |                       |       | - |   |     | 0   |                  |
| インターバル<br>カウント開始                        |       | -  |     |    |     |     |                       |       | _  |     |     |                       |       |   |   |     |     |                  |

図 2.4 IITV=0"の場合の(マイクロ) フレームとToken受信期待有無の関係

(2) 選択PIPEがIsochronous-IN転送PIPEの場合

"IFIS="1"と組み合わせて使用します。"IFIS=0"の場合にはIITVビットへの設定値とは関係なく、受信したTokenに応

答してデータパケットを送信します。

"IFIS=1"を設定している場合、FIFOバッファに送信可能なデータが存在している状態で、IITVビットに設定した Interval毎の (マイクロ) フレーム中にIN-Tokenを受信しなかった時、本コントローラーはFIFOバッファをクリアします。

IN-TokenにCRCエラー等のバスエラーが発生したために本コントローラーが正常受信できなかった場合にもクリアを行います。

FIFOバッファクリアのタイミングは、SOFパケット受信時です。またSOFパケットが破損した場合でも内部補間機能によりSOFを受信すべきタイミングにFIFOバッファクリアを行います

インターバルのカウント開始条件は、IITVビットの設定値により異なります。 (OUT時と同様です)

Peripheral Controller機能選択時のインターバルカウント条件は以下(1)、(2)または(3)の場合です。

- (1) 本コントローラーがHWリセットされた場合 (この時、IITVビットへの設定値も"0"にクリアされます。)
- (2) ソフトウェアが"ACLRM=1"を設定した場合。
- (3) 本コントローラーがUSBリセットを検出した場合



# 2.17 パイプコントロールレジスタ

◆ PIPE1コントロールレジスタ【PIPE1CTR】 <アドレス:70H> ◆ PIPE2コントロールレジスタ【PIPE2CTR】 <アドレス:72H> ◆ PIPE3コントロールレジスタ【PIPE3CTR】 <アドレス:74H> ◆ PIPE4コントロールレジスタ【PIPE4CTR】 <アドレス:76H> ◆ PIPE5コントロールレジスタ【PIPE5CTR】 <ア<u>ドレス:78H></u>

| 15   | 14     | 13    | 12    | 11 | 10     | 9     | 8     | 7     | 6 | 5    | 4 | 3 | 2 | 1  | 0 |
|------|--------|-------|-------|----|--------|-------|-------|-------|---|------|---|---|---|----|---|
| BSTS | INBUFM | CSCLR | CSSTS |    | ATREPM | ACLRM | SQCLR | SQSET |   | PBSY |   |   |   | Pl | D |
| 0    | 0      | 0     | 0     | ?  | 0      | 0     | 0     | 0     | 0 | 0    | ? | ? | ? | 0  | 0 |
| -    | -      | -     | -     | ?  | -      | -     | -     | -     | - | -    | ? | ? | ? | 0  | 0 |

| Bit | Name                       | Function                                                                                                                           | S/W           | H/W    | Remarks             |
|-----|----------------------------|------------------------------------------------------------------------------------------------------------------------------------|---------------|--------|---------------------|
| 15  | BSTS<br>バッファステータス          | 当該PIPEのFIFOバッファステータスが表示<br>されます。<br>0:バッファアクセス不可<br>1:バッファアクセス可                                                                    | R             | W      |                     |
| 14  | INBUFM<br>送信バッファモニタ        | 当該PIPEが送信方向の場合に、当該PIPEの<br>FIFOバッファステータスが表示されます。<br>0:FIFOバッファに送信可能データなし<br>1:FIFOバッファに送信可能データあり                                   | R             | W      |                     |
| 13  | CSCLR<br>CSPLITステータスクリアビット | 当該PIPEのCSSTSビットをクリアする場合<br>にCSCLR=1を設定します。<br>0:書き込み無効<br>1:CSSTSビットをクリア                                                           | R/<br>W(1)    | R/W(0) | H<br>(P時"0"<br>を設定) |
| 12  | CSSTS<br>CSSTSステータスビット     | 当該PIPEのSplit TransactionのCSPLITステータスが表示されます。<br>0:SSplit Transaction処理中、またはSplit<br>Transaction未使用転送である<br>1:CSplit Transaction処理中 | R             | R/W    | Н                   |
| 11  | 何も配置されていません。"0"に固定して       | こください。                                                                                                                             |               |        |                     |
| 10  | ATREPM<br>自動応答モード          | 当該PIPEの自動応答禁止/許可を指定します。<br>0:禁止<br>1:許可(当該PIPEのFIFOバッファの状態にかかわらず、送信時Zero-length Packet応答、受信時NAK応答しNRDY割り込み発生)                      | R/W           | R      | P<br>(H時"0"<br>を設定) |
| 9   | ACLRM<br>自動バッファクリアモード      | 当該PIPEの自動バッファクリアモードの禁止/許可を指定します。<br>0:禁止<br>1:許可(全バッファ初期化)                                                                         | R/W           | R      |                     |
| 8   | SQCLR<br>トグルビットクリア         | 当該PIPEの次回トランザクションにおける<br>シーケンストグルビットの期待値をDATA0<br>にクリアするときに"1"を指定します。<br>0:書き込み無効<br>1:DATA0指定                                     | R(0)/<br>W(1) | R      |                     |
| 7   | SQSET<br>トグルビットセット         | 当該PIPEの次回トランザクションにおける<br>シーケンストグルビットの期待値をDATA1<br>にセットするときに"1"を指定します。<br>0:書き込み無効<br>1:DATA1指定                                     | R(0)/<br>W(1) | R      |                     |
| 6   | SQMON<br>トグルビット確認          | 当該PIPEの次回トランザクションにおける<br>シーケンストグルビットの期待値が表示され<br>ます。<br>0:DATA0<br>1:DATA1                                                         | R             | W      |                     |
| 5   | PBUSY<br>PIPEビジー           | 当該PIPEを現在USBバスで使用中かどうか<br>が表示されます。                                                                                                 | R             | W      |                     |

| Bit | Name                 | Function                                                                                            | S/W | H/W | Remarks |
|-----|----------------------|-----------------------------------------------------------------------------------------------------|-----|-----|---------|
|     |                      | 0:当該PIPEをUSBバスにて未使用<br>1:当該PIPEをUSBバスにて使用                                                           |     |     |         |
| 4-2 | 何も配置されていません。"0"に固定して | てください。                                                                                              |     |     |         |
| 1-0 |                      | 当該PIPEの次回トランザクションにおける<br>応答方法を指定します。<br>00:NAK応答<br>01:BUF応答(バッファ状態に従う)<br>10:STALL応答<br>11:STALL応答 | R/W | R/W |         |

<<Remarks>>

なし

## 2.17.1 バッファステータスピット (BSTS)

当該PIPEに割り付けたFIFOバッファへのCPUからのアクセスが可能かどうかを、本コントローラが表示するビットです。

本ビットの意味は、DIRビット、BFREビット及びDCLRMビットの設定値により以下のように異なります。

| DIR ビット | BFRE ビッ | DCLRM ビ | BSTS ビットの意味                           |
|---------|---------|---------|---------------------------------------|
| 設定値     | ト設定値    | ット設定値   |                                       |
| 0       | 0       | 0       | "FIFO バッファからの受信データの読み出しが可能になったとき"に"1" |
|         |         |         | を表示し、データの読み出しが完了したときに"0"を表示します。       |
|         |         | 1       | この組み合わせは設定禁止です。                       |
|         | 1       | 0       | "FIFO バッファからの受信データの読み出しが可能になったとき"に"1" |
|         |         |         | を表示し、データの読み出しが完了した後でソフトウェアが"BCLR=1"   |
|         |         |         | を書き込んだときに"0"を表示します。                   |
|         |         | 1       | "FIFO バッファからの受信データの読み出しが可能になったとき"に"1" |
|         |         |         | を表示し、データの読み出しが完了したときに"0"を表示します。       |
| 1       | 0       | 0       | "FIFO バッファへの送信データの書き込みが可能になったとき"に"1"を |
|         |         |         | 表示し、データの書き込みが完了したときに"0"を表示します。        |
|         |         | 1       | この組み合わせは設定禁止です。                       |
|         | 1       | 0       | この組み合わせは設定禁止です。                       |
|         |         | 1       | この組み合わせは設定禁止です。                       |

表 2.16 BSTSビットの動作

## 2.17.2 送信パッファモニタピット (INBUFM)

当該PIPEを送信方向 ("DIR=1") に設定している場合に、ソフトウェア (またはDMAC) が少なくとも1面分のデータをFIFOバッファに書き込み完了した時に、本コントローラーは本ビットに"1"を表示します。

書き込みが完了している面のFIFOバッファ上のデータを本コントローラーがすべて送信完了した時に、本コントローラーは本ビットに"0"を表示します。ダブルバッファ使用時 ("DBLB=1"設定時) には、本コントローラーが2面分のデータを送信完了しかつソフトウェア (またはDMAC) が1面分のデータ書き込みを完了していない時に、本ビットに"0"を表示します。

当該PIPEを受信方向("DIR=0")に設定している場合には、本ビットはBSTSビットと同じ値を示します。

### 2.17.3 Split TransactionのCSPLITステータスクリアピット (CSCLR)

Host Controller機能選択時に、ソフトウェアが本ビットに"1"を設定すると本コントローラーはCSSTSビットを"0"にクリアします。

Split Transactionを使用する転送において、強制的に次回の転送をS-Splitから再開させたいときに、ソフトウェアで本ビットに"1"を設定してください。正常なSplit Transactionでは、C-Split終了時に本コントローラーが自動的に**CSSTS**ビットを"0"にクリアしますので、ソフトウェアによるクリア処理は不要です。

本ビットによるCSSTSビットの制御は、"UACT=0"による通信停止時、またはデタッチ検出時で転送を行っていない



ことが確実な時に行ってください。

"CSSTS=0"の時に本ビットに"1"を設定しても、"CSSTS=0"ままです。

Peripheral Controller機能選択時には、本ビットへは必ず"0"を書き込んでください。

## 2.17.4 Split TransactionのCSPLITステータスピット (CSSTS)

Host Controller機能選択時に、本コントローラーはSplit TransactionのC-Splitのステータスを本ビットに表示します。

本コントローラーは、C-Split開始時に本ビットに"1"を表示し、C-Split終了を検出したときに本ビットに"0"を表示し ます。

本ビットの表示は、Host Controller機能選択時のみ有効な値を示します。



## 2.17.5 自動応答モードビット (ATREPM)

Peripheral Controller機能選択時に、当該PIPEの転送TYPEを"Bulk"に設定している場合、本ビットへの"1"設定が可能です。

本ビットに"1"を設定した場合、USB HOSTからのTokenに対し本コントローラーは以下のように応答します。

(1) 当該PIPEがBulk-IN転送 ("TYPE=01"かつ"DIR=1"を設定) の場合

"ATREPM=1"かつ"PID=BUF"を設定している場合、IN-Tokenに対して本コントローラーはZero-Lengthパケットを送信します。

USB HostからのACK受信の度に (1トランザクションはIN-Token受信 Zero Lengthパケット送信 ACK受信)、本コントローラーはシーケンストグルビット (DATA-PID) の更新 (トグル) を行います。 BRDY割り込み、BEMP割り込みは発生させません。

(2) 当該PIPEがBulk-OUT転送 ("TYPE=01"かつ"DIR=0"を設定) の場合 "ATREPM=1"かつ"PID=BUF"を設定している場合、OUT-Token (またはPING-Token) に対して本コントローラーはNAK応答を行い、NRDY割り込みを発生させます。

本ビットの変更は、"CSSTS=0"、"PID=NAK"設定時に実施してください。

対応するPIPEの**PID**ビットを"BUF"から"NAK"へ変更してから本ビットを変更する場合には、"CSSTS=0"および"PBUSY=0"を確認してから本ビットを変更してください。ただし、本コントローラーが**PID**ビットを"NAK"に変更した場合には、ソフトウェアによる**PBUSY**ビットの確認は必要ありません。

本ビットを"1"に設定してUSB通信を行う場合、FIFOバッファは必ず空の状態で設定を行ってください。本ビットを"1"に設定してUSB通信を行っている期間はFIFOバッファへの書き込みを行わないでください。

当該PIPEの転送TYPEがIsochronous転送の場合、本ビットには必ず"0"を設定してください。

Host Controller機能選択時には、本ビットへは必ず"0"を書き込んでください。

### 2.17.6 自動バッファクリアモードピット (ACLRM)

当該PIPEに割り付けたFIFOバッファの内容をすべて削除したい場合に、ACLRMビットに"1"、"0"を連続して書き込んでください。

本ビットに"1"、"0"を連続して設定した場合に本コントローラーがクリアする内容と、当該項目のクリアが必要なケースについて表 2.17に示します。

| 表 2.17  | "ACLRM=1"設定時に本コントロ・ | - ラーがクリアされる内容              |
|---------|---------------------|----------------------------|
| 1X W.II |                     | 2 11 2 2 1 C 1 C 2 P 3 T C |

| 番号  | ACLRM ビット操作によるクリア内容                                                  | クリアが必要なケース              |
|-----|----------------------------------------------------------------------|-------------------------|
| (1) | 当該 PIPE に割り付けた FIFO バッファのすべての内容<br>(ダブルバッファ設定時は FIFO バッファを 2 面ともクリア) |                         |
| (2) | 当該 PIPE の転送 TYPE が Isochronous 転送の場合、イン<br>ターバルカウント値                 | インターバルカウント値のリセットを行いたい場合 |
| (3) | BFRE ビットに関する内部フラグ                                                    | BFRE ビットの設定値変更時         |
| (4) | FIFO バッファトグル制御                                                       | DBLB ビットの設定値変更時         |
| (5) | トランザクションカウントに関する内部フラグ                                                | トランザクションカウント機能の強制終了実行時  |

本ビットの変更は、"CSSTS=0"、"PID=NAK"、および当該PIPEをCURPIPEビットに未設定時に実施してください。 対応するPIPEのPIDビットを"BUF"から"NAK"へ変更してから本ビットを変更する場合には、"CSSTS=0"および"PBUSY=0"を確認してから本ビットを変更してください。ただし、本コントローラーがPIDビットを"NAK"に変更した場合には、ソフトウェアによるPBUSYビットの確認は必要ありません。



### 2.17.7 シーケンストグルビットのクリアビット (SQCLR)

ソフトウェアが本ビットに"1"を設定すると本コントローラーは当該PIPEのシーケンストグルビットの期待値をDATAOに設定します。本コントローラーは、常に本ビットに"0"を表示します。

Host Controller機能選択時、Bulk-Out転送PIPEに対して本ビットに"1"を設定すると、本コントローラーは当該PIPEの次回転送をPING-tokenから開始します。

**SQCLR**ビットへの"1"設定は、"CSCTS=0"、かつ"PID=NAK"に実施してください。

対応するPIPEの**PID**ビットを"BUF"から"NAK"へ変更してから本ビットに"1"を設定する場合には、"CSSTS=0"および"PBUSY=0"を確認してから本ビットを変更してください。ただし、本コントローラーが**PID**ビットを"NAK"に変更した場合には、ソフトウェアによる**PBUSY**ビットの確認は必要ありません。

## 2.17.8 シーケンストグルビットのセットビット (SQSET)

ソフトウェアが本ビットに"1"を設定すると本コントローラーは当該PIPEのシーケンストグルビットの期待値をDATA1に設定します。本コントローラーは、常に本ビットに"0"を表示します。

**SQSET**ビットへの"1"設定は、"CSSTS=0"、かつ"PID=NAK"設定時に実施してください。

対応するPIPEの**PID**ビットを"BUF"から"NAK"へ変更してから本ビットに"1"を設定する場合には、"CSSTS=0"および"PBUSY=0"を確認してから本ビットを変更してください。ただし、本コントローラーが**PID**ビットを"NAK"に変更した場合には、ソフトウェアによる**PBUSY**ビットの確認は必要ありません。

## 2.17.9 シーケンストグルビットのモニタービット (SQMON)

本コントローラーは当該PIPEのシーケンストグルビットの期待値を本ビットに表示します。

当該PIPEの転送TYPEがIsochronous転送以外の場合、トランザクションが正常処理すると本コントローラーは本ビットをトグルさせます。ただし、受信方向転送時のDATA-PIDミスマッチ発生時には、本ビットをトグルさせません。

## 2.17.10 PIPEビジービット (PBUSY)

本コントローラーは、当該PIPEのUSBトランザクションを開始したときに本ビットを"0"から"1"に変更します。ひとつのトランザクションが終了したときに本ビットを"1"から"0"に変更します。

ソフトウェアが"PID=NAK"を設定した後、本ビットを読み出すことにより、PIPE設定変更が可能になったかどうかを確認することが出来ます



## 2.17.11 応答PIDビット (PID)

本ビットに対し、ソフトウェアで各PIPEにおける本コントローラーの応答を設定してください。

本ビットのデフォルト値は"NAK"です。当該PIPEでUSB転送を行う場合には本ビットを"BUF"に変更してください。 PIDビットの設定値毎の本コントローラーの基本動作 (通信パケットにエラーがない場合の動作) は表 2.18、及び表 2.19のとおりです。

当該PIPEがUSB通信中であるときに、ソフトウェアで本ビットを"BUF"から"NAK"に変更する場合、"NAK"を書き込んだ後、実際に当該PIPEのUSB転送が"NAK"状態に遷移したことを確認するために"PBUSY=1"であることを確認してください。ただし、本コントローラーが本ビットを"NAK"に変更した場合には、ソフトウェアによる**PBUSY**ビットの確認は必要ありません。

以下の場合には本コントローラーが本ビットの値を変更します。

- (1) 当該PIPEが受信方向の場合、かつソフトウェアが当該PIPEのSHTNAKビットに"1"を設定している場合、本コントローラーがトランスファー終了を認識した時に、"PID=NAK"を表示します。
- (2) 当該PIPEに対し、MaxPacketSizeを超えるペイロードのデータパケットを受信した場合、本コントローラーは "PID=STALL(11)"を表示します。
- (3) Peripheral Controller機能選択時に、USBバスリセットを検出した場合、本コントローラーは"PID=NAK"を表示します。
- (4) Host Controller機能選択時に、CRCエラーなどの受信エラーを3回連続で検出した場合には、本コントローラーは "PID=NAK"を表示します。
- (5) Host Controller機能選択時に、STALLハンドシェイクを受信した場合、本コントローラーは"PID=STALL(11)"を表示します。

"PID=NAK("00")"の状態から"PID=STALL"状態にする場合には、"10"を書き込んでください。 BUF("01")状態からSTALL状態にする場合には、"11"を書き込んでください。 STALL("11")からNAK状態にする場合には、一旦"10"を書き込んでから"00"を書き込んでください。 STALL状態からBUF状態に変更する場合は、一旦NAK状態に変更し、その後、BUF状態に変更して下さい。



## 表 2.18 PIDビットによる本コントローラーの動作一覧 (Host Controller機能選択時)

| PID ビット<br>設定値                       | 転送 TYPE<br>(TYPE ビット設定値)                          | 転送方向<br>(DIR ビット設定値) | 本コントローラーの動作                                                                                             |
|--------------------------------------|---------------------------------------------------|----------------------|---------------------------------------------------------------------------------------------------------|
| "00 (NAK)"                           | 設定値に依存しない                                         | 設定値に依存しない            | トークンを発行しない                                                                                              |
| "01 (BUF)"                           | Bulk ("TYPE=01")、<br>または<br>Interrupt ("TYPE=10") | 設定値に依存しない            | "UACT=1"が設定されて、かつ当該 PIPE に対応する FIFO バッファが送受信可能な状態ならばトークン を発行する。 "UACT=0"が設定される、または送受信可能でなければトークンを発行しない。 |
|                                      | Isochronous<br>("TYPE=11")                        | 設定値に依存しない            | "UACT=1"が設定されていれば、当該 PIPE に対応する FIFO バッファの状態にかかわらず Token を発行する。 "UACT=0"が設定されていればトークンを発行しない。            |
| "10 (STALL)"、<br>または<br>"11 (STALL)" | 設定値に依存しない                                         | 設定値に依存しない            | トークンを発行しない                                                                                              |

# 表 2.19 PIDピットによる本コントローラーの動作一覧 (Peripheral Controller機能選択時)

| PID ビット<br>設定値                       | 転送 TYPE<br>(TYPE ビット設定値)                         | 転送方向<br>(DIR ビット設定値) | 本コントローラーの動作                                                                                                                                                                                                     |
|--------------------------------------|--------------------------------------------------|----------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| "00 (NAK)"                           | Bulk("TYPE=01")、<br>または<br>Interrupt ("TYPE=10") | 設定値に依存しない            | USB Host からの Token に NAK 応答を行う<br>ただし、"ATREPM=1"設定時は2.17.5に述べる動作を<br>行う。                                                                                                                                        |
|                                      | Isochronous<br>("TYPE=11")                       | 設定値に依存しない            | USB Host からの Token に無応答を行う                                                                                                                                                                                      |
|                                      | 未設定("TYPE=00")                                   | 設定値に依存しない            | USB Host からの Token に無応答を行う                                                                                                                                                                                      |
| "01 (BUF)"                           | Bulk("TYPE=01")                                  | 受信方向<br>("DIR=0")    | USB Host からの OUT Token に対し、当該 PIPE に対応する FIFO バッファが受信可能な状態ならばデータを受信し ACK または NYET 応答を行う。受信可能な状態でなければ NAK 応答を行う USB Host からの PING Token に対し、当該 PIPE に対応する FIFO バッファが受信可能な状態ならば ACK 応答を行う。 受信可能な状態でなければ NAK 応答を行う |
|                                      | Interrupt ("TYPE=10")                            | 受信方向<br>("DIR=0")    | USB Host からの OUT Token に対し、当該 PIPE に対応する FIFO バッファが受信可能な状態ならばデータを受信し ACK 応答を行う。受信可能な状態でなければ NAK 応答を行う                                                                                                           |
|                                      | Bulk("TYPE=01")、<br>または<br>Interrupt ("TYPE=10") | 送信方向<br>("DIR=1")    | 対応する FIFO バッファが送信可能な状態ならば<br>USB Host からの Token に対しデータを送信する。<br>送信可能でなければ NAK 応答を行う。                                                                                                                            |
|                                      | Isochronous<br>("TYPE=11")                       | 受信方向<br>("DIR=0")    | USB Host からの OUT Token に対し、当該 PIPE に対応する FIFO バッファが受信可能な状態ならばデータを受信する。受信可能な状態でなければデータを破棄する。                                                                                                                     |
|                                      |                                                  | 送信方向<br>("DIR=1")    | 対応する FIFO バッファが送信可能な状態ならば<br>USB Host からの Token に対しデータを送信する。<br>送信可能でなければ Zero-Length パケットを送信す<br>る。                                                                                                            |
| "10 (STALL)"、<br>または<br>"11 (STALL)" | Bulk("TYPE=01")、<br>または<br>Interrupt ("TYPE=10") | 設定値に依存しない            | USB Host からの Token に STALL 応答を行う                                                                                                                                                                                |
| ,                                    | Isochronous<br>("TYPE=11")                       | 設定値に依存しない            | USB Host からの Token に無応答を行う                                                                                                                                                                                      |

◆ PIPE6コントロールレジスタ【PIPE6CTR】 <アドレス:7AH> ◆ PIPE7コントロールレジスタ【PIPE7CTR】 <アドレス:7CH> ◆ PIPE8コントロールレジスタ【PIPE8CTR】 <アドレス:7EH> ◆ PIPE9コントロールレジスタ【PIPE9CTR】 <アドレス:80H>

| 15   | 14 | 13    | 12    | 11 | 10 | 9     | 8     | 7     | 6     | 5    | 4 | 3 | 2 | 1  | 0 |
|------|----|-------|-------|----|----|-------|-------|-------|-------|------|---|---|---|----|---|
| BSTS |    | CSCLR | CSSTS |    |    | ACLRM | SQCLR | SQSET | SQMON | PBSY |   |   |   | PI | D |
| 0    | ?  | 0     | 0     | ?  | ?  | 0     | 0     | 0     | 0     | 0    | ? | ? | ? | 0  | 0 |
| -    | ?  | -     | -     | ?  | ?  | -     | -     | -     | -     | -    | ? | ? | ? | 0  | 0 |

| Bit   | Name                       | Function                                                                                                                    | S/W           | H/W    | Remarks             |
|-------|----------------------------|-----------------------------------------------------------------------------------------------------------------------------|---------------|--------|---------------------|
|       | BSTS<br>バッファステータス          | 当該PIPEのFIFOバッファステータスが表示<br>されます。<br>0:バッファアクセス不可<br>1:バッファアクセス可                                                             | R             | W      |                     |
|       | 何も配置されていません。"0"に固定して       |                                                                                                                             |               |        |                     |
| 13    | CSCLR<br>CSPLITステータスクリアビット | 当該PIPEのCSSTSビットをクリアする場合<br>に、CSCLR=1を設定します。<br>0:書き込み無効<br>1:CSSTSビットをクリア                                                   | R/<br>W(1)    | R/W(0) | H<br>(P時"0"<br>を設定) |
| 12    | CSSTS<br>CSSTSステータスビット     | 当該PIPEのSplit TransactionのCSPLITステータスが表示されます。<br>0:SSplit Transaction処理中、またはSplit Transaction未使用転送である1:CSplit Transaction処理中 | R             | R/W    | Н                   |
| 11-10 | 何も配置されていません。"0"に固定して       | てください。                                                                                                                      |               |        |                     |
| 9     | ACLRM<br>自動バッファクリアモード      | 当該PIPEの自動バッファクリアモードの禁止/許可を指定します。<br>0:自動バッファクリアモード禁止<br>1:自動バッファクリアモード許可(全バッファ初期化)                                          | R/W           | R/W    |                     |
| 8     | SQCLR<br>トグルビットクリア         | 当該PIPEの次回トランザクションにおける<br>シーケンストグルビットの期待値をDATA0<br>にクリアするときに"1"を指定します。<br>0:無効<br>1:DATA0指定                                  | R(0)/<br>W(1) | R      |                     |
| 7     | SQSET<br>トグルビットセット         | 当該PIPEの次回トランザクションにおける<br>シーケンストグルビットの期待値をDATA1<br>にセットするときに"1"を指定します。<br>0:無効<br>1:DATA1指定                                  | R(0)/<br>W(1) | R      |                     |
| 6     | SQMON<br>トグルビット確認          | 当該PIPEの次回トランザクションにおける<br>シーケンストグルビットの期待値が表示され<br>ます。<br>0:DATA0<br>1:DATA1                                                  | R             | W      |                     |
|       | PBUSY<br>PIPEビジー           | 当該PIPEを現在USBバスで使用中かどうか<br>が表示されます。<br>0:当該PIPEをUSBバスにて未使用<br>1:当該PIPEをUSBバスにて使用                                             | R             | W      |                     |
|       | 何も配置されていません。"0"に固定して       |                                                                                                                             |               |        |                     |
| 1-0   | PID<br>応答PID               | 当該PIPEの次回トランザクションにおける<br>応答方法を指定します。<br>00:NAK応答<br>01:BUF応答(バッファ状態に従う)<br>10:STALL応答<br>11:STALL応答                         | R/W           | R/W    |                     |



#### <<Remarks>>

なし

## 2.17.12 パッファステータスピット (BSTS)

2.17.1を参照ください。

## 2.17.13 Split TransactionのCSPLITステータスクリアピット (CSCLR)

2.17.3を参照ください。

## 2.17.14 Split TransactionのCSPLITステータスピット (CSSTS)

2.17.4を参照ください。

## 2.17.15 自動パッファクリアモードピット (ACLRM)

当該PIPEに割り付けたFIFOバッファの内容をすべて削除したい場合に、ACLRMビットに"1"、"0"を連続して書き込 んでください。

本ビットに"1"、"0"を連続して設定した場合に本コントローラーがクリアする内容と、当該項目のクリアが必要なケー スについて表 2.20に示します。

## 表 2.20 "ACLRM=1"設定時に本コントローラーがクリアされる内容

| 番号  | ACLRM ビット操作によるクリア内容                                                     | クリアが必要なケース              |
|-----|-------------------------------------------------------------------------|-------------------------|
| (1) | 当該 PIPE に割り付けた FIFO バッファのすべての内容                                         |                         |
| (2) | Host Controller 機能選択時、当該 PIPE の転送 TYPE が<br>Interrupt 転送の場合、インターバルカウント値 | インターバルカウント値のリセットを行いたい場合 |
| (3) | BFRE ビットに関する内部フラグ                                                       | BFRE ビットの設定値変更時         |
| (4) | トランザクションカウントに関する内部フラグ                                                   | トランザクションカウント機能の強制終了実行時  |

本ビットの変更は、"CSSTS=0"、"PID=NAK"、および当該PIPEをCURPIPEビットに未設定時に実施してください。 対応するPIPEのPIDビットを"BUF"から"NAK"へ変更してから本ビットを変更する場合には、"CSSTS=0"および "PBUSY=0"を確認してから本ビットを変更してください。ただし、本コントローラーがPIDビットを"NAK"に変更した 場合には、ソフトウェアによるPBUSYビットの確認は必要ありません。

### 2.17.16 シーケンストグルビットのクリアビット (SQCLR)

2.17.7を参照ください。

### 2.17.17 シーケンストグルビットのセットビット (SQSET)

2.17.8を参照ください。

## 2.17.18 シーケンストグルビットのモニタービット (SQMON)

2.17.9を参照ください。

## 2.17.19 PIPEビジービット (PBUSY)

2.17.10を参照ください。

## 2.17.20 応答PIDビット (PID)

2.17.11を参照ください。



## 2.18 トランザクションカウンタ

| • | PIP1トランザクションカウンタ許可レジスタ【PIPE1TRE】 | <アドレス:90H> |
|---|----------------------------------|------------|
| • | PIP2トランザクションカウンタ許可レジスタ【PIPE2TRE】 | <アドレス:94H> |
| • | PIP3トランザクションカウンタ許可レジスタ【PIPE3TRE】 | <アドレス:98H> |
| • | PIP4トランザクションカウンタ許可レジスタ【PIPE4TRE】 | <アドレス:9CH> |
| • | PIP5トランザクションカウンタ許可レジスタ【PIPE5TRE】 | <アドレス:A0H> |

| 15 | 14 | 13 | 12 | 11 | 10 | 9     | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 |
|----|----|----|----|----|----|-------|---|---|---|---|---|---|---|---|---|
|    |    |    |    |    |    | TRENB |   |   |   |   |   |   |   |   |   |
| ?  | ?  | ?  | ?  | ?  | ?  | 0     | 0 | ? | ? | ? | ? | ? | ? | ? | ? |
| ?  | ?  | ?  | ?  | ?  | ?  | -     | - | ? | ? | ? | ? | ? | ? | ? | ? |

| Bit   | Name                      | Function                                                          | S/W           | H/W | Remarks |  |  |  |  |  |  |
|-------|---------------------------|-------------------------------------------------------------------|---------------|-----|---------|--|--|--|--|--|--|
| 15-10 | 何も配置されていません。"0"に固定してください。 |                                                                   |               |     |         |  |  |  |  |  |  |
| 9     | TRENB<br>トランザクションカウンタ許可   | トランザクションカウンタ無効/有効を指定します。<br>0:トランザクションカウンタ機能無効1:トランザクションカウンタ機能有効  | R/W           | R   |         |  |  |  |  |  |  |
| 8     | TRCLR<br>トランザクションカウンタクリア  | 本ビットに"1"を設定することによりトランザクションカウンタを0にクリアすることができます。 0:無効 1:カレントカウンタクリア | R(0)/<br>W(1) | R   |         |  |  |  |  |  |  |
| 7-0   | 何も配置されていません。"0"に固定し       | てください。                                                            |               |     |         |  |  |  |  |  |  |

#### <<Remarks>>

本レジスタの各ビットの変更は、"CSSTS=0"、"PID=NAK"時に実施してください。 対応する PIPE の PID ビットを"BUF"から"NAK"へ変更したあとで各ビットの設定値を変更する場合には、"CSSTS=0"および "PBUSY=0"を確認してから本ビットを変更してください。 ただし、 本コントローラーが PID ビットを"NAK"に変更した場合に は、ソフトウェアによる PBUSY ビットの確認は必要ありません

## 2.18.1 トランザクションカウンタ許可ピット (TRENB)

受信PIPEに対して、ソフトウェアでTRNCNTビットに総パケット数を設定した後で本ビットに"1"を設定すると、本コ ントローラーはTRNCNTビットの設定値と同数のパケット受信を終了したときに以下の制御を行います。

- (1) 連続送受信モード使用("CNTMD=1"設定) 時、受信完了時にFIFOバッファがフルの状態でなくても、CPU側にト グルさせます。
- (2) "SHTNAK=1"設定時、TRNCNTビットの設定値と同数のパケット受信を終了時点で対応するPIPEのPIDビットを "NAK"に変更します。
- (3) "DENDE=1"かつ"PKTM=0"設定時、TRNCNTビットの設定値と同数のパケット受信を終了し最後のデータを読 み出す時にDEND信号をアサートします。
- (4) "BFRE=1"設定時、TRNCNTビットの設定値と同数のパケット受信を終了し最後のデータを読み出し終えた時に、 BRDY割り込みをアサートします。

送信PIPEについては、本ビットに"0"を設定してください。

トランザクションカウント機能を使用しない場合は、本ビットに"0"を設定してください。

トランザクションカウント機能を使用する場合、本ビットに"1"を設定する前にTRNCNTビットの設定を行ってくださ い。また、トランザクションカウントの対象となる最初のパケットを受信する前に本ビットに"1"を設定してください。

## 2.18.2 トランザクションカウンタクリアピット (TRCLR)

ソフトウェアが本ビットに"1"を設定すると、本コントローラーは当該PIPEに対応するトランザクションカウンタの現 在のカウント値をクリアし、本ビットに"0"を表示します。



| •        | PIP1トランザクションカウンタレジスタ【PIPE1TRN】 | <アドレス:92H> |
|----------|--------------------------------|------------|
| <b>♦</b> | PIP2トランザクションカウンタレジスタ【PIPE2TRN】 | <アドレス:96H> |
| •        | PIP3トランザクションカウンタレジスタ【PIPE3TRN】 | <アドレス:9AH> |
| •        | PIP4トランザクションカウンタレジスタ【PIPE4TRN】 | <アドレス:9EH> |
| •        | PIP5トランザクションカウンタレジスタ【PIPE5TRN】 | <アドレス:A2H> |

| 15 | 14     | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 |
|----|--------|----|----|----|----|---|---|---|---|---|---|---|---|---|---|
|    | TRNCNT |    |    |    |    |   |   |   |   |   |   |   |   |   |   |
| 0  | 0      | 0  | 0  | 0  | 0  | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 |
| -  | -      | -  | -  | -  | -  | - | - | - | - | - | - | - | - | - | - |

| Bit  | Name | Function                                                                                                                                             | S/W | H/W | Remarks |
|------|------|------------------------------------------------------------------------------------------------------------------------------------------------------|-----|-----|---------|
| 15-0 |      | トランザクションカウンタ Write 時 : 当該 pipe が受信すべき総パケット数 (トランザクション回数) を設定します Read 時 : "TRENB=0"の場合: 設定したトランザクション回数が表示されます。 "TRENB=1"の場合: カウント中のトランザクション回数が表示されます。 | R/W | R/W |         |

<<Remarks>>

## 2.18.3 トランザクションカウンタビット (TRNCNT)

受信PIPEに対して、ソフトウェアで本ビットに受信すべき総パケット数を設定した後でTRENBビットに"1"を設定す ると、本コントローラーは2.18.1に述べる制御を行います。

"TRENB=0"の場合、本コントローラーは本ビットに、ソフトウェアが設定したトランザクション回数を表示します。 "TRENB=1"の場合、本コントローラーは本ビットに、カウント中のトランザクション回数を表示します。

本コントローラーは、受信時の状態が以下(a)から(c)をすべて満たしたときにTRNCNTビットの表示を1インクリメント します。

- (a) "TRENB=1"である
- (b) パケット受信時に (TRNCNT設定値 現在のカウント値+1)である
- (c) 受信したパケットのペイロードがMXPSビットへの設定値と一致した

本コントローラーは、以下(1)、(2)、または(3)のいずれかの条件が満たされたときにTRNCNTビットの表示を0にクリ アします。

- (1) 以下(a)から(c)の条件がすべて満たされた時
- (a) "TRENB=1"である
- (b) パケット受信時に (TRNCNT設定値 = 現在のカウント値+1)である
- (c) 受信したパケットのペイロードがMXPSビットへの設定値と一致した
- (2) 以下(a)及び(b) の条件がすべて満たされた時
- (a) "TRENB=1"である
- (b) ショートパケットを受信した
- (3) 以下(a)及び(b) の条件がすべて満たされた時
- (a) "TRENB=1"である
- (b) ソフトウェアがTRCLRビットに"1"を設定した

送信PIPEについては、本ビットに"0"を設定してください。

トランザクションカウント機能を使用しない場合は、本ビットに"0"を設定してください。

本ビットの変更は、"CSSTS=0"、"PID=NAK"、かつ"TRENB=0"設定時に実施してください。

対応するPIPEのPIDビットを"BUF"から"NAK"へ変更してから本ビットを変更する場合には、"CSSTS=0"および "PBUSY=0"を確認してから本ビットを変更してください。ただし、本コントローラーがPIDビットを"NAK"に変更した 場合には、ソフトウェアによるPBUSYビットの確認は必要ありません。

本ビットの値を変更する場合は、"TRENB=1"を設定する前に"TRCLR=1"を実施してください。



# 2.19 デバイスアドレスコンフィグレーションレジスタレジスタ

| ◆ デバイスアドレス0 コンフィグレーションレジスタレジスタ【DEVADD0】 | <アドレス: D0H>  |
|-----------------------------------------|--------------|
| ◆ デバイスアドレス1 コンフィグレーションレジスタレジスタ【DEVADD1】 | <アドレス: D2H>  |
| ◆ デバイスアドレス2 コンフィグレーションレジスタレジスタ【DEVADD2】 | <アドレス:D4H>   |
| ◆ デバイスアドレス3 コンフィグレーションレジスタレジスタ【DEVADD3】 | <アドレス: D6H>  |
| ◆ デバイスアドレス4 コンフィグレーションレジスタレジスタ【DEVADD4】 | <アドレス:D8H>   |
| ◆ デバイスアドレス5 コンフィグレーションレジスタレジスタ【DEVADD5】 | <アドレス : DAH> |
| ◆ デバイスアドレス6 コンフィグレーションレジスタレジスタ【DEVADD6】 | <アドレス : DCH> |
| ◆ デバイスアドレス7 コンフィグレーションレジスタレジスタ【DEVADD7】 | <アドレス : DEH> |
| ◆ デバイスアドレス8 コンフィグレーションレジスタレジスタ【DEVADD8】 | <アドレス:E0H>   |
| ◆ デバイスアドレス9 コンフィグレーションレジスタレジスタ【DEVADD9】 | <アドレス:E2H>   |
| ◆ デバイスアドレスA コンフィグレーションレジスタレジスタ【DEVADDA】 | <アドレス:E4H>   |

| 15 | 14 | 13 | 12   | 11 | 10 | 9      | 8 | 7     | 6   | 5 | 4 | 3 | 2 | 1 | 0      |
|----|----|----|------|----|----|--------|---|-------|-----|---|---|---|---|---|--------|
|    |    |    | PHUB |    | F  | IUBPOR |   | . 000 | SPD |   |   |   |   |   | RTPORT |
| ?  | 0  | 0  | 0    | 0  | 0  | 0      | 0 | 0     | 0   | ? | ? | ? | ? | ? | 0      |
| ?  | -  | -  | -    | -  | -  | -      | - | -     | -   | ? | ? | ? | ? | ? | - 1    |

| Bit   | Name                             | Function                                                                                                                                  | S/W | H/W | Remarks                    |
|-------|----------------------------------|-------------------------------------------------------------------------------------------------------------------------------------------|-----|-----|----------------------------|
| 15    | 何も配置されていません。"0"に固定し              | てください。                                                                                                                                    |     |     |                            |
| 14-11 | UPPHUB<br>通信対象接続HUBレジスタ          | 通信対象のPeripheral Deviceが接続されているHUBのUSB Addressを設定します。<br>0000:本コントローラーのPORTに直接接続されている<br>0001-1010: HUBのUSB Address<br>1011-1111: Reserved | R/W | R   | H<br>(P時all<br>"0"を設<br>定) |
| 10-8  | HUBPORT<br>通信対象接続HUBポート          | 通信対象のPeripheral Deviceが接続されているHUBのPORT番号を設定します。<br>000: 本コントローラーのPORTに直接接続されている<br>001-111: HUBのPORT番号                                    | R/W | R   | H<br>(P時all<br>"0"を設<br>定) |
| 7-6   | USBSPD<br>通信対象デバイスの転送速度          | 通信対象のPeripheral DeviceのUSB転送速度<br>を設定します。<br>00:DEVADDxレジスタ未使用<br>01:Low-Speed<br>10:Full-Speed<br>11:High-Speed                          | R/W | R   | H<br>(P時all<br>"0"を設<br>定) |
| 7-1   | 何も配置されていません。"0"に固定し              | てください。                                                                                                                                    |     |     |                            |
| 0     | RTPORT<br>通信対象ツリーのルートハブポート番<br>号 | 通信対象ツリーが接続されている本コント<br>ローラーのPORT番号(ROOT HUB PORT番<br>号)を設定します。<br>0:PORT0<br>1:PORT1                                                      | R/W | R   | H<br>(P時all<br>"0"を設<br>定) |

#### <<Remarks>>

- \*1 Host Controller 機能選択時、各 pipe に対する通信を開始する前に、必ず本レジスタの各ビットを設定してください。
- \*2 本レジスタの各ビットの変更は、本ビットの設定を使用している有効なpipeが存在しないときに行ってください。有効なpipe とは以下(1)及び(2)の両方を満たしている pipe です。
  - (1) DEVSEL ビットの設定が、本レジスタを指定している時
- (2) 当該 PIPE の PID ビットに"BUF"を設定している時、または当該 PIPE が DCP であり"SUREQ=1"を設定している時 \*3 Peripheral Controller 機能選択時、本レジスタの各ビットには"0"を設定してください。



## 2.19.1 通信対象接続HUBレジスタビット (UPPHUB)

Host Controller機能選択時、本コントローラーは、Splitトランザクションを実行する時に本ビットの設定値を参照してパケットを生成します。

## 2.19.2 通信対象接続HUBポートピット (HUBPORT)

Host Controller機能選択時、本コントローラーは、Splitトランザクションを実行する時に本ビットの設定値を参照してパケットを生成します。

## 2.19.3 通信対象デバイスの転送速度ビット (USBSPD)

Host Controller機能選択時、本コントローラーは、本ビットの設定値を参照してパケットを生成します。

## 2.19.4 通信対象ツリーのルートハブポート番号ビット (RTPORT)

Host Controller機能選択時、本コントローラーは、本ビットの設定値を参照してパケットを生成します。



# 3動作説明

# 3.1 システム制御及び発振制御

本章では、本コントローラーの初期設定に必要なレジスタ操作、及び消費電力制御を行うために必要なレジスタの説明について述べます。

#### 3.1.1 リセット

表 3.1に本コントローラーのリセット種別の一覧表を示します。なお、各リセット動作後のレジスタ初期化状態については、第2章レジスタを参照してください。

表 3.1 リセット種別一覧表

| 名称        | 操作                                                        |
|-----------|-----------------------------------------------------------|
| H/Wリセット   | RST_N端子からの"L"レベル入力                                        |
| USBバスリセット | Peripheral Controller機能選択時に本コントローラーが D+、D-ラインのステータスから自動検出 |

#### 3.1.2 パスインタフェースの設定

表 3.2に発振バッファ動作の許可前 ("XCKE=0") に設定するべき本コントローラーのバスインタフェースについてのパラメーターを示します。H/Wリセット後に最初に設定してください。表 3.3に発振バッファ動作の許可後("XCKE=1"を設定し"SCKE=1"の状態になった)に設定するパラメーターを示します。

表 3.2 パスインタフェース設定表 (クロック供給開始前に設定)

| レジスタ名  | ビット名 | 設定内容            |
|--------|------|-----------------|
| PINCFG | LDRV | 駆動電流の制御指定       |
| PINCFG | INTA | INT_N端子のアクティブ指定 |

表 3.3 パスインタフェース設定表(クロック供給開始後に設定)

| レジスタ名   | ビット名   | 設定内容                           |
|---------|--------|--------------------------------|
| SYSCFG1 | PCSDIS | Lowパワースリープモードからの復帰条件にCS_Nのアサート |
|         |        | を含めるかどうかを指定                    |
| SYSCFG1 | LPSME  | Lowパワースリープモードの使用有無指定           |
| DMAxCFG | DREQA  | DREQx_N端子のアクティブ指定              |
| DMAxCFG | DACKA  | DACKx_N端子のアクティブ指定              |
| DMAxCFG | DENDA  | DENDx_N端子のアクティブ指定              |
| DMAxCFG | OBUS   | OBUSモード指定                      |
| SOFCFG  | BRDYM  | PIPEBRDY割り込みステータスクリアタイミング設定    |
| SOFCFG  | INTL   | INT_N端子の出力センス指定                |

x=0、または1

#### 3.1.3 クロック供給制御

ソフトウェアでSYSCFGレジスタのXTALビットにてXIN端子の入力クロック選択を指定し、XCKEビットにて発振バッファの許可を行うと、本コントローラーはUSBブロックへのクロック供給を開始します。

ソフトウェアはSCKEビットが"1"にセットされたことを確認し、次の処理に移ってください。



#### 3.1.4 USBブロック動作許可

USBブロックへのクロック供給が開始された ("SCKE=1") 後、ソフトウェアでSYSCFGレジスタのUSBEビットを"1" に設定することにより、USBブロックの動作許可を行います。

#### コントローラー機能選択ビットの設定 3.1.5

USBブロック動作許可設定後、本コントローラーの機能選択ビット (SYSCFGレジスタのDCFMビット) を設定してく ださい。

本コントローラーは、Host Controller機能またはPeripheral Controller機能をソフトウェアで選択することができます。

表 3.4に本コントローラの各USBポートに対する機能選択について示します。

Host Controller機能選択時 ("DCFM=1") No. PORT0 PORT1 各PORTへのスケジューリング Hi-Speed 転送スケジューリングはPORT0/PORT1共通であり、出 (1)Hi-Speed (2)Full or Low Full or Low 力はPORT0/PORT1の両ポートヘドライブします。 (3) Hi-Speed Full or Low 転送スケジューリングはPORT0/PORT1別々に動作し、 (4)Full or Low Hi-Speed それぞれのポートの転送速度に依存しません。 Peripheral Controller機能選択時("DCFM=0") PORT0 PORT1 備考 (5)Hi or Full 未使用 PORT1は無効です。またLow-Speedには未対応です。

表 3.4 USBポートの機能選択

#### 3.1.6 Hi-Speed動作許可ピットの設定とUSB通信速度判定

page 108 of 183

## 3.1.6.1 Host Controller 機能設定時

Host Controller機能選択時には、Peripheral機器のアタッチ検出後、アタッチされた機器がD+ラインをPull Upした場 合 (即ちLow-Speedではない場合) のみ、Hi-Speed動作許可ビット (PORT0: SYSCFGレジスタのHSEビット、PORT1: SYSCFG1レジスタのHSEビット)を"1"に設定してください。アタッチされた機器がLow-Speedの場合、もしくは Hi-Speed動作を許可しない場合は、当該PORTのHi-Speed動作許可ビットに"0"を設定してください。

また、アタッチされた機器がLow-Speedの場合は、SOFCFGレジスタのTRNENSELビットに"1"を設定する必要があり ます。3.6.1章を参照してください。

Hi-Speed動作を許可しているPORTに対してUSBリセットを発行 ("USBRST=1"を設定) すると、本コントローラーは Reset Handshake Protocolを実行し、USB通信速度を自動的に判定します。PORT0のReset Handshakeの結果は **DVSTCTR0**レジスタの**RHST**ビットに、PORT1のReset Handshakeの結果は**DVSTCTR1**レジスタの**RHST**ビットに表示 されます。

#### 3.1.6.2 Peripheral Controller 機能設定時

Peripheral Controller機能選択時にHi-Speed動作を許可する場合には、コントローラー機能選択ビットの設定後、 Hi-Speed動作許可ビット (SYSCFGレジスタのHSEビット) に"1"を設定してください。

Full-Speedのみで動作させる場合には、SYSCFGレジスタのHSEビットに"0"を設定してください。

Hi-Speed動作を許可している場合、本コントローラーはReset Handshake Protocolを実行し、USB通信速度を自動的 に判定します。Reset Handshakeの結果はDVSTCTROレジスタのRHSTビットに表示されます。



# 3.1.7 DCFMビットの設定値とUSB通信速度整理

DCFMビットの設定値とUSB通信速度の組み合わせを表 3.5に示します。

表 3.5 コントローラ機能選択表

|      | 設定内容    |         |            |            |            | 機能と転送スピード                                    |
|------|---------|---------|------------|------------|------------|----------------------------------------------|
| DCFM | PORT0 用 | PORT1 用 | Contoller  | PORT0      | PORT1      | Remarks                                      |
|      | HSE     | HSE     | 機能         | Speed      | Speed      |                                              |
| 0    | 0       | 0       | Peripheral | Full       |            | PORT0 は Full-Speed で動作                       |
|      |         |         |            |            | 使用不可       |                                              |
| 0    | 1       | 0       |            | Hi or Full |            | PORT0 は Reset Handshake Protocol (RHSP) 成立時  |
|      |         |         |            |            | 使用不可       | に Hi-Speed で動作。RHSP 非成立時に Full-Speed で       |
|      |         |         |            |            |            | 動作                                           |
| 1    | 0       | 0       | Host       | Full or    |            | PORT0、PORT1 それぞれ、D+が Pull Up されている           |
|      |         |         |            | Low        | Low        | 場合は Full-Speed、D-が Pull Up されている場合は          |
|      |         |         |            |            |            | Low-Speed で動作。                               |
|      |         |         |            |            |            | D-が Pull Up されている場合は、必ず対応する PORT             |
|      |         |         |            |            |            | を"HSE=0"に設定してください。                           |
| 1    | 1       | 0       |            | Hi or Full |            | PORT0 : RHSP 成功時に Hi-Speed Host Controller と |
|      |         |         |            |            | Low        | して動作。RHSP 非成立時に Full-Speed で動                |
|      |         |         |            |            |            | 作                                            |
|      |         |         |            |            |            | PORT1: D+が Pull Up されている場合は Full-Speed、      |
|      |         |         |            |            |            | D-が Pull Up されている場合は Low-Speed で             |
|      |         |         |            |            |            | 動作。                                          |
|      |         |         |            |            |            | D-が Pull Up されている場合は、必ず対応す                   |
|      |         |         |            |            |            | る PORT を"HSE=0"に設定してください。                    |
| 1    | 0       | 1       |            | Full or    | Hi or Full | PORT0:D+が Pull Up されている場合は Full-Speed、       |
|      |         |         |            | Low        |            | D-が Pull Up されている場合は Low-Speed で             |
|      |         |         |            |            |            | 動作。                                          |
|      |         |         |            |            |            | D-が Pull Up されている場合は、必ず対応する                  |
|      |         |         |            |            |            | PORTを"HSE=0"に設定してください。                       |
|      |         |         |            |            |            | PORT1:RHSP 成功時に Hi-Speed Host Controller とし  |
|      | 4       | 4       |            | =          |            | て動作。RHSP 非成立時に Full-Speed で動作                |
| 1    | 1       | 1       |            | HI Or Full | HI or Full | PORT0、PORT1 それぞれ、RHSP 成功時に Hi-Speed          |
|      |         |         |            |            |            | Host Controller として動作。RHSP 非成立時に             |
|      |         |         |            |            |            | Full-Speed で動作                               |



# 3.1.8 USBデータバスのPull DownとPull Up設定

コントローラーの機能選択実施後、USBデータラインの抵抗設定を行ってください。

本コントローラーは、D+信号のPull Up抵抗とD+、D-信号のPull Down抵抗を内蔵しています。D+のPull Upの電源はAVCCです。

Host Controller機能選択時は、PORT0を使用する場合にはSYSCFGレジスタのDRPDビットを、PORT1を使用する場合にはSYSCFG1レジスタのDRPDビットを"1"に設定し、各PORTのD+,D-ラインをPull Downしてください。

Peripheral Controller機能選択時は、USB Hostへの接続を認識した後で、**SYSCFG**レジスタの**DPRPU**ビットを"1"に設定し、D+をPull Upしてください。

また、本コントローラーはHi-Speed通信時のD+、D-信号の終端抵抗、及び、Full-Speed通信時の出力抵抗を内蔵しています。USBホストまたはPeripheral機器との接続後の内蔵抵抗の切り替えは、リセットハンドシェイク、サスペンド、レジューム実行/検出時に本コントローラーが自動的に行います。

また、Peripheral Controller機能を選択しUSBホストに接続されている状態で**SYSCFG**レジスタの**DPRPU**ビットに"0" を設定した場合、本コントローラーはUSB D+ラインのプルアップ (もしくはD+、D-ラインの終端) を無効にしますので、USBホストから見てUSBケーブルが抜かれた状態をソフトウェアによって作り出すことができます。



## 3.1.9 消費電力の制御

#### 3.1.9.1 消費電力制御概要

本コントローラーの低消費電力状態には、Lowパワースリープ状態、及びVCCオフ状態の2種類があります。表 3.6に 各低消費電力状態の説明を示します。

図 3.1に本コントローラーの状態遷移図を示します。

表 3.6 各低消費電力状態の説明

| コントローラー<br>の状態   | 説明                                                                                                                            |
|------------------|-------------------------------------------------------------------------------------------------------------------------------|
| Lowパワース<br>リープ状態 | 初期設定で"LPSME=1"を設定し、本コントローラーが動作している状態でクロック停止 (3.1.10.2参照)を行うと、本コントローラーはLowパワースリープ状態に遷移します。 各レジスタの値は保持されます。FIFOバッファの内容は保持されません。 |
| VCCオフ状態          | VIFオンのまま、VCCのみをオフにするとVCCオフ状態に遷移します。Lowパワースリープ状態よりも更に消費電力を低減する事ができます。<br>各レジスタの値は保持されません。                                      |



図 3.1 コントローラーの状態遷移図

#### 3.1.9.2 ローパワースリープ状態

本コントローラーの初期設定においてSYSCFG1レジスタのLPSMEビットを"1"に設定してある場合、本コントロー ラーが通常動作状態にあるときにクロック停止処理を行うと、本コントローラーはLowパワースリープ状態に遷移します。 Lowパワースリープ状態は、各レジスタの値を保持したままで消費電力を低減するモードです。即ち、USBサスペンド中 に本状態に遷移させた場合、USBアドレス、デバイスステートなどの情報を保持したままで消費電力を低減する事ができ ます。

Lowパワースリープ状態への設定シーケンスは3.1.10.2及び、図 3.3)を参照してください。

Lowパワースリープ状態からの復帰条件は、表 2.7を参照してくだい。また、復帰シーケンスは3.1.10.3及び図 3.4を 参照してください。

本コントローラーは、Lowパワースリープ状態からの復帰要因を検出した場合に自動的に発振バッファ動作許可を行い ます。このとき、XCKEビットの値は変更されませんので、ソフトウェアで"SCKE=1"を確認した後で"XCKE=1"を設定 しください。

Lowパワースリープ状態を有効にするために、本コントローラーの初期設定においてSYSCFG1レジスタのLPSMEビッ トを"1"に設定してください。

Lowパワースリープ状態中はレジスタアクセスを行うことはできません。また、本状態に遷移する時にはFIFOバッフ ァのデータは保護されませんので、遷移させる前にFIFOバッファの中の送受信データの処理を行ってください。

Host Controller機能選択時において、サスペンド状態からリモートウェイクアップ信号を受信した場合、信号検出後 1ms以内に内部クロック(SCKE)を供給しレジューム信号出力を開始する必要があります。このためリモートウェイクア ップを許可してサスペンド状態になる場合には内部クロックの停止を行わないでください。

#### 3.1.9.3 VCC オフ状態

VCCオフ状態は本コントローラの電源を一部供給したまま、USBブロックの電源をオフにするに機能です。VIFをオン にしたまま、VCC及びAVCCをオフにすることにより本コントローラーはVCCオフ状態に遷移します。

ソフトウェアによって本コントローラーのレジスタを操作して実現するLowパワースリープ状態とは異なり、本状態か らの復帰を行うためには本コントローラーのVCC及びAVCCをオンし、H/Wリセットを行う事が必要です。 VCCオフ状態では各レジスタの値は保持されません。復帰後は初期状態に遷移します。



## 3.1.10 状態遷移タイミング

# 3.1.10.1 内部クロック供給開始 (H/W リセット状態から通常動作状態)

図 3.2に本コントローラーのクロック供給開始制御タイミング図を示します。H/Wリセット状態から通常動作状態へ移 行させる場合、及び、クロック停止状態から"XCKE=1"設定により通常動作状態へ移行させる場合は、下記のタイミング でビットを操作してください。

(1)発振バッファを許可する。

- "XCKE=1"
- (2) "SCKE=1"になるまでソフトウェアで待つ。(コントローラーが自動的にPLLC、及びSCKEを許可する)



図 3.2 クロック供給開始制御タイミング図

#### 3.1.10.2 内部クロック供給停止(通常動作状態から Low パワースリープ状態への設定シーケンス)

図 3.3に本コントローラーの通常動作状態からLowパワースリープ状態への、制御タイミング図を示します。Lowパ ワースリープ状態を有効にするために、初期設定で"LPSME=1"を設定してください。

- (1) SOFCFGレジスタのEDGESTSビットを確認"EDGESTS=0"までソフトウェアで待つ。
- (2)内部クロックの供給を停止する。
- "SCKE=0"
- (3) 内部クロックが停止するまでソフトウェアで待つ。(60ns以上の待ち時間が必要です。)

(4) PLLを停止させる。

"PLLC=0"

(5)発振バッファ動作を禁止する。

"XCKE=0



図 3.3 内部クロック供給停止処理タイミング図

# 3.1.10.3 内部クロック供給再開 (Low パワースリープ状態から通常動作状態)

図 3.4にLowパワースリープ状態から通常動作状態への遷移タイミング図を示します。

- (1)ローパワースリープ状態から復帰の割り込みが発生し、INT\_N端子がアサートされる。 (または、ソフトウェアでダミーリードを行い、コントローラーを復帰させる\*6)) 発振バッファ許可状態になるが、XCKEビットには反映されない。
- (2) 1msソフトウェアで待つ。 (この間はCPUからのアクセスを行わないでください)
- (3) "SCKE=1"になるまでソフトウェアで待つ。(コントローラーが自動的に発振バッファ動作を開始し、PLLC、及びSCKEを許可する)
- (4) ソフトウェアで"XCKE=1"を設定する。
- \*6) CPU からのアクセスによるローパワースリープ状態からの復帰は INTENB1 レジスタの PCSDIS ビットを "0"に設定している場合に有効です。この条件による復帰の場合は INT\_N はアサートされません。



図 3.4 Lowパワースリープ状態からの復帰制御タイミング図

# 3.2 割り込み機能

# 3.2.1 割り込み機能概要

表 3.7に本コントローラーの割り込み機能一覧表を示します。

表 3.7 割り込み機能一覧表

| ビット                                     | 割り込み名称           | 割り込み検出条件                                                                             | 発生する                | 関連ステー    | 参照                 |
|-----------------------------------------|------------------|--------------------------------------------------------------------------------------|---------------------|----------|--------------------|
| '                                       | '                | [使用方法]                                                                               | 機能設定                | タス       | '                  |
| VBINT                                   | VBUS割り込み         | VBUS入力端子の状態変化を検出した時                                                                  | Host、               | VBSTS    | 2.11.1             |
|                                         |                  | ("Low" "High"、"High" "Low"の両方の変化)                                                    | Peripheral          |          |                    |
| 55011                                   |                  | [Peripheral Controller機能選択時のHostへの接続、切断検出]                                           |                     |          |                    |
| RESM                                    | レジューム割り          | サスペンド状態においてUSBバスの状態変化を検出した時                                                          | Peripheral          | -        | 2.11.2             |
|                                         | 込み               | (J-State K-State、もしくはJ-State SEO)                                                    |                     |          | 2.11.2             |
| 0055                                    |                  | [Peripheral Controller機能選択時のレジューム検出]                                                 |                     |          | 0.44.0             |
| SOFR                                    | フレーム番号更          | フレーム番号の異なるSOFパケットを送信した時                                                              | Host,<br>Peripheral | -        | 2.11.3<br>3.2.8    |
| DVST                                    | 新割り込み<br>デバイスステー | <br>  デバイスステートの遷移を検出した時                                                              | Peripheral          | DVSQ     | 2.11.4             |
| DVSI                                    | ト遷移割り込み          | リススナードの危極を検出した時<br>  USBバスリセット検出                                                     | Feliplielai         | DVSQ     | 3.2.6              |
|                                         | 「危惨割り込み          | サスペンド状態検出                                                                            |                     |          | 0.2.0              |
|                                         |                  | Set Addressリクエストの受信                                                                  |                     |          |                    |
|                                         |                  | Set Address サノエストの支信<br>Set Configuration リクエストの受信                                   |                     |          |                    |
| CTRT                                    | コントロール転          | コントロール転送のステージ遷移を検出した時                                                                | Peripheral          | CTSQ     | 2.11.5             |
| • • • • • • • • • • • • • • • • • • • • | 送ステージ遷移          | コントロール報送のスケーン造物を採出した時   セットアップステージ完了                                                 | · onprioral         | 0.00     | 3.2.7              |
|                                         | 割り込み             | コントロールライト転送ステータスステージ遷移                                                               |                     |          |                    |
|                                         | 137247           | コントロールリード転送ステータスステージ遷移                                                               |                     |          |                    |
|                                         |                  | コントロール転送完了                                                                           |                     |          |                    |
|                                         |                  | コントロール転送シーケンスエラー発生                                                                   |                     |          |                    |
| BEMP                                    | バッファエンプ          | バッファメモリ中の全データを送信しバッファが空になった時                                                         | Host、               | PIPEBEMP | 2.11.6             |
|                                         | ティ割り込み           | マックスパケットサイズを超えたパケットを受信した時                                                            | Peripheral          |          | 2.11.23            |
|                                         |                  |                                                                                      |                     |          | 3.2.5              |
| NRDY                                    | バッファノット          | < Host Controller機能選択時 >                                                             | Host                | PIPENRDY | 2.11.7<br>2.11.22  |
|                                         | レディ割り込み          | ペリフェラル側からSTALLを受信した時。                                                                | Peripheral          |          | 3.2.4              |
|                                         |                  | ペリフェラル側の無応答を3回検出した時。                                                                 |                     |          | 5.2.4              |
|                                         |                  | アイソクロナス転送時のオーバーラン / アンダーランが発生した時。                                                    |                     |          |                    |
|                                         |                  | <peripheral controller機能選択時=""><br/>"PID=BUF"設定時かつバッファメモリが送受信可能な状態ではない状</peripheral> |                     |          |                    |
|                                         |                  | PID=BOF 設定時かりパックアスモリが医受信可能な状態ではない状態   態でトークンを受信した時                                   |                     |          |                    |
|                                         |                  | 感とドーソンを支信した時<br>  アイソクロナス転送でデータ受信時にCRCエラー、ビットスタッフエ                                   |                     |          |                    |
|                                         |                  | アインプログス転送とゲーク支信時にGRGエジー、こうドスクップエー<br>  ラーが発生した時                                      |                     |          |                    |
| BRDY                                    | バッファレディ          | FIFOバッファがレディ(リード、もしくはライト可能状態)になった                                                    | Host,               | PIPEBRDY | 2.11.8             |
| 1                                       | 割り込み             | 時                                                                                    | Peripheral          |          | 2.11.21            |
|                                         |                  |                                                                                      |                     |          | 3.2.3              |
| OVRCR                                   | OVRCR発生割         | 関連するPortのOVCMONビットが変化した時                                                             | Host、               | OVCMON   | 2.11.9             |
|                                         | り込み              | [Host Controller機能選択時、VBUS供給用電源スイッチから通知される                                           | Peripheral          |          | 2.11.16            |
|                                         |                  | オーバーカレントステータスをOVCR0A、OVCR0B、OVCR1端子に接                                                |                     |          |                    |
| DOLLO                                   |                  | 続し、各Portのオーバーカレント検出に使用]                                                              |                     |          | 0.44.40            |
| BCHG                                    | バス変化割り込          | USBバスステートの変化を検出した時                                                                   | Host                | -        | 2.11.10<br>2.11.17 |
|                                         | み                | [Host Controller機能選択時、サスペンド中の各Portにおける切断や、                                           | Peripheral          |          | 2.11.17            |
| DTCH                                    | ₹URC‡◆ TT        | リモートウェイクアップ検出に使用]<br>Peripheral Deviceの切断を検出した時。                                     | Host                | _        | 2.11.11            |
| DICH                                    | 切断検出             | Peripheral Deviceの切断を検出した時。<br>                                                      | HOSI                | -        | 2.11.11            |
| ATTCH                                   | 接続検出             | Peripheral Deviceの接続を検出した時。                                                          | Host                | _        | 2.11.12            |
|                                         |                  |                                                                                      |                     |          | 2.11.19            |
| EOFERR                                  | EOFエラー検          | 対応するPortにおけるEOFエラーを検出した時                                                             | Host                | -        | 2.11.13            |
|                                         | 出割り込み            |                                                                                      |                     |          | 2.11.20            |
| SIGN                                    | SETUPトラン         | セットアップトランザクションのエラー(無応答、ACKパケット破損)                                                    | Host                | -        | 2.11.14            |
|                                         | ザクションエ           | を検出した時。                                                                              |                     |          |                    |
|                                         | ラー割り込み           |                                                                                      |                     |          | <u> </u>           |
| SACK                                    | SETUPトラン         | セットアップトランザクションにおいて正常応答(ACK)を受信した時                                                    | Host                | -        | 2.11.15            |
|                                         | ザクション正常          |                                                                                      |                     |          |                    |
|                                         | 応答割り込み           |                                                                                      |                     |          |                    |



表 3.8に本コントローラーのINT\_N端子動作表を示します。複数の割り込み要因が発生した場合のINT\_N端子出力 の方法を、SOFCFGレジスタのINTLビットにより設定できます。またINT\_N端子のアクティブをPINCFGレジスタの INTAビットにより設定できます。ユーザーシステムに合わせてINT\_N端子の動作設定を行ってください。

表 3.8 INT\_N端子動作表

| INT_N端子<br>動作<br>INTL設定 | 発生した割り込み要因が1つの場合                                          | 発生した割り込み要因が複数の場合                   |
|-------------------------|-----------------------------------------------------------|------------------------------------|
| エッジセンス<br>("INTL=0")    | 要因解除 (当該割り込みのステータスがクリアされる、または当該割り込みの許可ビットを禁止に設定する) までアサート | 1つの要因が解除されると48MHzで32クロッ<br>ク時間ネゲート |
| レベルセンス<br>("INTL=1")    | 要因解除までアサート                                                | 全ての要因解除までアサート                      |

アクティブレベル: "INTA=0"設定時 Low、"INTA=1"設定時 High



図 3.5 INT\_N端子動作図 ("INTA=0"設定時の例)

図 3.6に本コントローラーの割り込み関連図を示します。



図 3.6 割り込み関連図

#### 3.2.2 クロックを停止した状態での動作と注意事項

VBINT、RESM、BCHG割り込みは、クロックを停止した状態 (Lowパワースリープ状態を含む) でも割り込み要因が発生し、許可レジスタで許可を行っている場合にはINT\_N端子から割り込みがアサートされます。

割り込み要因のクリアは、クロック供給開始処理を行ったあとで行ってください。

クロック停止中のPeripheral Device挿抜によるBCHG割り込み発生時には、クロック復帰後にATCH割り込みまたは DTCH割り込みが発生しますので、ソフトウェアの処理速度や割り込み要因の判定順序によってはBCHG割り込みではなくATCH割り込み、DTCH割り込みで挿抜処理を行う場合があります。

#### 3.2.3 BRDY割り込み

BRDY割り込みはHost、Peripheralのどちらの機能を選択した場合にも発生します。発生条件は2.11.21のとおりです。 図 3.7にBRDY割り込み発生タイミング図を示します。

Zero-Lengthパケットを受信した場合、BRDYSTSレジスタの該当するビットが"1"になりますが、当該パケットのデータの読み出しはできません。BRDYSTSレジスタをクリアした後、バッファクリア ("BCLR=1") を行ってください。またパイプ1-パイプ9では、読み出し方向でDMA転送を使用している場合に、PIPECFGレジスタのBFREビットを"1"に設定する事により、トランスファー単位で割り込みを発生させることが可能です。



**図 3.7 BRDY割り込み発生タイミング図** 



本コントローラーがINTSTS0レジスタのBRDYビットをクリアする条件は、SOFCFGレジスタのBRDYMビットの設定 値によって異なります。表 3.9にBRDYビットクリア条件を示します。

# 表 3.9 コントローラーによるBRDYビットクリア条件表

| BRDYM | BRDYビットクリア条件                                        |
|-------|-----------------------------------------------------|
| 0     | ソフトウエアがBRDYSTSレジスタの全ビットをクリアすると、本コントローラーはINTSTS0レジ   |
|       | スタのBRDYビットをクリアします。                                  |
| 1     | 全パイプのBSTSビットが"0"になったときに、本コントローラーはINTSTS0レジスタのBRDYビッ |
|       | トをクリアします。                                           |



# 3.2.4 NRDY割り込み

NRDY割り込みはHost、Peripheralのどちらの機能を選択した場合にも発生します。NRDY割り込み要求の発生条件は2.11.22のとおりです。

図 3.8にPeripheral Controller機能選択時のNRDY割り込み発生タイミング図を示します。

| (1) データ送信時の例 (シ                                                                | ・<br>・ングルパッファ設定時)                          |
|--------------------------------------------------------------------------------|--------------------------------------------|
| USBバス —                                                                        | IN Token Packet NAK Handshake (*1          |
| バッファメモリの状態―<br>NRDY割り込み<br>(PIPENRDYの該当<br>ビットの変化) <sup>(*2</sup>              | 書き込み可能状態 (送信可能データなし)                       |
| (2) データ受信;OUTトー                                                                | クン受信時の例 (シングルバッファ設定時)                      |
| USBバス —                                                                        | OUT Token Packet Data Packet NAK Handshake |
| バッファメモリの状態 <del>・</del>                                                        | 読み出し可能状態 (受信可能領域なし)                        |
| NRDY割り込み<br>(PIPENRDYの該当<br>ビットの変化) <sup>(*2</sup><br>(CRCビット等) <sup>(*3</sup> |                                            |
| (3) <b>データ受信</b> ;PINGトー                                                       | -クン受信時の例 (シングルバッファ設定時)                     |
| USBバス —                                                                        | PING Packet NAK Handshake                  |
| バッファメモリの状態―<br>NRDY割り込み<br>(PIPENRDYの該当<br>ビットの変化) <sup>(*2</sup>              | 読み出し可能状態 (受信可能領域なし)                        |
| *2) 当該PipeのPIDビットを                                                             |                                            |

図 3.8 Peripheral Controller機能選択時のNRDY割り込み発生タイミング図

## 3.2.5 BEMP割り込み

**BEMP**割り込みはHost、Peripheralのどちらの機能を選択した場合にも発生します。割り込み要求の発生条件は2.11.23のとおりです。

図 3.9に本コントローラーのBEMP割り込み発生タイミング図を示します。



図 3.9 Peripheral Controller機能選択時のBEMP割り込み発生タイミング図



## 3.2.6 デバイスステート遷移割り込み

図 3.10に本コントローラーのデバイスステート遷移図を示します。本コントローラーは、エラー! プロパティ名に誤りがあります。デバイスステートを管理し、デバイスステート遷移割り込みが発生します。エラー! プロパティ名に誤りがあります。ただし、サスペンドからの復帰(レジューム信号検出)は、レジューム割り込みで検出します。デバイスステート遷移割り込みは、INTENB0レジスタで割り込みの許可、もしくは禁止を設定することができます。また、遷移したデバイスステートは、INTSTS0レジスタのDVSQビットにて確認できます。

Defaultステートに遷移する場合には、リセットハンドシェイクプロトコルの終了後に、デバイスステート遷移割り込みが発生します。

デバイスステートの管理は、Peripheral Controller機能選択時のみ行います。デバイスステート遷移割り込みも Peripheral Controller機能選択時のみ発生します。



図 3.10 デバイスステート遷移図

#### 3.2.7 コントロール転送ステージ遷移割り込み

図 3.11に本コントローラーのコントロール転送ステージ遷移図を示します。本**エラー! プロパティ名に誤りがあります。**コントローラーは、コントロール転送のシーケンスを管理し、コントロール転送ステージ遷移割り込みが発生します。コントロール転送ステージ遷移割り込みは、INTENBOレジスタで個別に割り込みの許可、もしくは禁止を設定することができます。また、遷移した転送ステージはINTSTSOレジスタのCTSQビットにて確認できます。

コントロール転送ステージ遷移割り込みはPeripheral Controller機能を選択した場合にのみ発生します。

コントロール転送のシーケンスエラーを下記に示します。エラーが発生した場合は、DCPCTRレジスタのPIDビットが "1X" ("STALL") になります。

- (1) コントロールリード転送時
  - (a) データステージのINトークンに対して、一度もデータ転送していない状態でOUT、もしくはPINGトークン を受信
  - (b) ステータスステージでINトークン受信
  - (c) ステータスステージでデータパケットが"DATAPID=DATA0"のパケットを受信
- (2) コントロールライト転送時
  - (a) データステージのOUTトークンに対して、一度もACK応答していない状態でINトークンを受信
  - (b) データスステージで最初のデータパケットが"DATAPID=DATA0"のパケットを受信
  - (c) ステータスステージでOUT、もしくはPINGトークン受信
- (3) ノーデータコントロール転送時
  - (a) ステータスステージでOUTまたはPINGトークン受信

なお、コントロールライト転送データステージで、受信データ数がUSBリクエストのwLength値を越えた場合は、コントロール転送シーケンスエラーと認識できません。また、コントロールリード転送ステータスステージで、Zero-Lengthパケット以外のパケット受信には、ACK応答を行い正常終了します。

シーケンスエラーによるCTRT割り込み発生時("SERR=1"設定)は、ソフトウエアが"CTRT=0"の書き込み(割り込みステータスクリア)を行うまで"CTSQ=110"の値が保持されます。このため、"CTSQ=110"が保持されている状態では、新しいUSBリクエストを受信しても、セットアップステージ完了のCTRT割り込みは発生しません。セットアップステージ完了イベントは本コントローラーで保持されており、ソフトウェアによる割り込みステータスクリア後に、セットアップステージ完了割り込みが発生します。



図 3.11 コントロール転送ステージ遷移図

#### 3.2.8 フレーム更新割り込み

図 3.12に本コントローラーのSOFR割り込み出力タイミング例を示します。

Peripheral Controller機能を選択した場合、本コントローラーは、Full-Speed動作中に新しいSOFパケットを検出する と、フレーム番号を更新し**SOFR**割り込みを発生します。また、Hi-Speed動作中は、μSOFロック状態になったあとにフ レーム番号が異なるSOFパケットを検出した時にFRNMビットを更新しSOFR割り込みを発生します。また、Hi-Speed 動作中のSOFの補間機能もµSOFロック状態になったあとに動作します。µSOFロック状態とは、エラーなしでフレー ム番号の異なるμSOFパケットを2回受信(μSOFロック状態)することです。

なお、μSOFロック監視開始条件、及びμSOFロック監視停止条件は下記(1)、(2)のとおりです。

- (1) µSOFロック監視開始条件
  - USBE=1かつ内部クロック供給状態であること
- (2) µSOFロック監視停止条件
  - USBE=0、USBバスリセット受信、もしくはサスペンド検出



図 3.12 SOFR割り込み出力タイミングの例

# 3.3 パイプコントロール

表 3.10に本コントローラーのパイプ設定項目一覧表を示します。USBデータ転送は、エンドポイントと呼ばれる論理パイプにて、データ通信を行います。本コントローラーにはデータ転送用に9本のパイプがあります。各パイプは、ユーザーシステムの仕様に合わせて設定を行ってください。

表 3.10 パイプ設定項目一覧表

| レジスタ名              | ビット名            | 設定内容                                    | 備考                                                     |
|--------------------|-----------------|-----------------------------------------|--------------------------------------------------------|
| PIPESEL            | PIPESEL         | PIPEBU、PIPEMAXP、                        | 2.16.1章を参照してください                                       |
|                    |                 | PIPEPERIレジスタで設定を                        |                                                        |
|                    |                 | 行う対象のPipe番号を指定                          |                                                        |
| DCPCFG             | TYPE            | 転送Typeを指定                               | 2.16.2を参照してください                                        |
| PIPECFG            | BFRE            | BRDY割り込みモードを選                           | PIPE1-5: 設定可                                           |
|                    | 5515            | 択                                       | 2.16.3章、3.4.3.4章、及び3.4.3.5章を参照してください                   |
|                    | DBLB            | シングルもしくはダブルバ                            | PIPE1-5: 設定可                                           |
|                    | CNTMD           | ッファを選択                                  | 2.16.4章、及び3.4.1.4章を参照してください                            |
|                    | CNTMD           | 連続転送もしくは非連続転                            | PIPE1-2: 設定可 (バルク転送選択時のみ設定可能 )<br>PIPE3-5: 設定可         |
|                    |                 | 送を選択<br>                                | PIPE3-3. 設定可<br>  連続送受信ではバッファサイズをペイロードの整数倍に設定          |
|                    |                 |                                         | してください                                                 |
|                    |                 |                                         | 2.16.5章、3.4.1.5章を参照してください                              |
|                    | DIR             | 転送方向 (読み出しもしく                           | INまたはOUT設定可                                            |
|                    |                 | は書き込み)を選択                               | 2.16.7章、及び3.4.2.1章を参照してください                            |
|                    | EPNUM           | エンドポイント番号                               | 2.16.8章を参照してください                                       |
|                    | SHTNAK          | トランスファー終了時のパ                            | DCP: 設定可                                               |
|                    |                 | イプ禁止選択                                  | PIPE 1-2: 設定可 (バルク転送選択時のみ設定可能)                         |
|                    |                 |                                         | PIPE 3-5: 設定可                                          |
|                    |                 |                                         | 2.16.6章を参照してください                                       |
| PIPEBUF            | BUFSIZE         | バッファメモリサイズ                              | DCP: 設定不可 (256バイト固定)                                   |
|                    |                 |                                         | PIPE 1-5: 設定可 (64バイト単位で最大2Kバイトまで指定可)                   |
|                    |                 |                                         | PIPE 6-9: 設定不可 (64バイト固定)                               |
|                    |                 |                                         | 2.16.9章、及び3.4.1章を参照してください                              |
|                    | BUFNMB          | バッファメモリ番号                               | DCP: 設定不可 (領域0-3固定)                                    |
|                    |                 |                                         | PIPE 1-5: 設定可 (領域8-135 (0x87) で指定可)                    |
|                    |                 |                                         | PIPE 6-9: 設定不可 (領域4-7固定)<br>2.16.10章、及び3.4.1章を参照してください |
| DCPMAXP            | DEVSEL          | <br>  デバイス選択                            | 2.16.11章を参照してください                                      |
| PIPEMAXP           | DEVOLE          |                                         | 2.10.11章を多無して、たとい                                      |
|                    | MXPS            | マックスパケットサイズ                             | 2.16.12章、及び3.3.1章を参照してください                             |
| PIPEPERI           | IFIS            | バッファフラッシュ                               | PIPE 1-2: 設定可 (アイソクロナス転送選択時のみ)                         |
|                    |                 |                                         | PIPE 3-9: 設定不可                                         |
|                    |                 |                                         | 2.16.13章、及び3.9.5章を参照してください                             |
|                    | IITV            | インターバルカウンタ                              | PIPE 1-2:設定可 (アイソクロナス転送選択時のみ)                          |
|                    |                 |                                         | PIPE 6-9:設定可 (Host Contoller機能選択時のみ)                   |
| DODGED             | DOTO            | 1,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,, | 2.16.14章、及び3.9.3章を参照してください                             |
| DCPCTR<br>PIPExCTR | BSTS            | バッファステータス                               | 2.17.1章、及び3.4.1.1章を参照してください。                           |
| I II LACTIN        | INBUFM<br>SUREQ | INバッファモニタ<br>SETUPリクエスト                 | 2.17.2章、及び3.4.1.1章を参照してください。                           |
|                    | SUKEU           | SEIUPリグエスト                              | DCPのみ設定可能<br>  Host選択時のみ制御可能                           |
|                    | SUREQCLR        | SUBLOAILA                               |                                                        |
|                    | JUNEQUER        | SUREQクリア                                | DCPのみ設定可能<br>Host選択時のみ制御可能                             |
|                    | CSCLR           | CSSTSクリア                                | Host選択時のみ制御可能                                          |
|                    | CSSTS           | Split Transactionステータス                  | Host選択時のみ参照可能                                          |
|                    |                 | 確認                                      |                                                        |
|                    | ATREPM          | 自動応答モード                                 | パイプ1-5:設定可能                                            |
|                    |                 |                                         | Peripheral選択時のみ設定可能                                    |
|                    | I               |                                         | I outprovide 1/40 as a text of 1 to                    |

| レジスタ名    | ビット名    | 設定内容          | 備考                          |
|----------|---------|---------------|-----------------------------|
|          | ACLRM   | 自動バッファクリア     | バッファメモリ読み出し設定時は許可/禁止設定可     |
|          |         |               | 2.17.6章、及び2.17.15章を参照してください |
|          | SQCLR   | シーケンストグルビットク  | データトグルビットのクリア               |
|          |         | リア            | 2.17.7章、及び3.3.4を参照してください    |
|          | SQSET   | シーケンストグルビットセ  | データトグルビットのセット               |
|          |         | ット            | 2.17.8章、及び3.3.4章を参照してください   |
|          | SQMON   | シーケンストグルビット確  | データトグルビットの確認                |
|          |         | 認             | 2.17.9章、及び3.3.4章を参照してください   |
|          | PBUSY   | Pipeビジー確認     | 2.17.10章を参照してください           |
|          | PID     | 応答PID         | 2.17.11章、及び第3.3.2章を参照してください |
| PIPExTRE | TRENB   | トランザクションカウント  | パイプ1-5:設定可能                 |
|          |         | 許可            | 2.18.2章を参照してください            |
|          | TRCLR   | カレントトランザクション  | パイプ1-5:設定可能                 |
|          |         | カウンタのクリア      | 2.18.3章を参照してください            |
| PIPExTRN | TRNCNT  | トランザクションカウンタ  | パイプ1-5:設定可能                 |
|          |         |               | 2.18.1章を参照してください            |
| DEVADDx  | UPPHUB  | 通信対象接続HUBレジスタ | Host選択時のみ設定可能               |
|          |         |               | 2.19.1章を参照してください            |
|          | HUBPORT | 通信対象接続HUBポート  | Host選択時のみ設定可能               |
|          |         |               | 2.19.2章を参照してください            |
|          | USBSPD  | 通信対象デバイスの転送速  | Host選択時のみ設定可能               |
|          |         | 度             | 2.19.3章を参照してください            |
|          | RTPORT  | 通信対象ツリーのルートハ  | Host選択時のみ設定可能               |
| Ì        |         | ブポート番号        | 2.19.4章を参照してください            |



#### マックスパケットサイズ設定 3.3.1

DCPMAXPレジスタ、及びPIPEMAXPレジスタのMXPSビットにて各パイプのマックスパケットサイズを設定します。 DCP、及びパイプ1-5はUSB規格で定義されているすべてのマックスパケットサイズに設定が可能です。パイプ6-9は最 大64バイトがマックスパケットサイズの上限です。マックスパケットサイズは転送を開始 ("PID=BUF"を設定) する前 に設定してください。

DCP: Hi-Speed動作時は"64"を設定してください。

DCP: Full-Speed動作時は"8"、"16"、"32"、"64"から選択して設定してください。 PIPE 1-5: Hi-Speedバルク転送時は、"512"を設定してください。

PIPE 1-5: Full-Speedバルク転送時は、"8"、"16"、"32"、"64"から選択して設定してください。

PIPE 1-2: Hi-Speedアイソクロナス転送時は、"1"から"1024"の値を設定してください。

PIPE 1-2: Full-Speedアイソクロナス転送時は、"1"から"1023"の値を設定してください。詳細は3.9章を参照くだ さい。

PIPE 6-9:"1"から"64"の値を設定してください。

インタラプト転送及びアイソクロナス転送のHighband-Widthは未対応です。



## 3.3.2 **応答PID**

DCPCTRレジスタ、及びPIPExCTRレジスタのPIDビットにて各パイプの応答PIDを設定してください。

(1) Host Controller機能選択時の応答PID設定

応答PIDには、トランザクションの実施を指定します。

- (a) NAK設定: パイプ禁止状態です。トランザクションは実施されません。
- バッファメモリの状況に応じてトランザクションが実施されます。 (b) BUF設定: OUT方向の場合、バッファメモリに送信データがある場合、OUTトークンを発行します。 IN方向の場合、バッファメモリに空きがあり受信可能な場合にINトークンを発行します。
- (c) STALL設定: パイプ禁止状態です。トランザクションは実施されません。

DCPのセットアップトランザクションはSUREQビット操作で実施してください。

(2) Peripheral Controller機能選択時の応答PID設定

応答PIDは、ホストからのトランザクションに対する応答を指定します。

- (a) NAK設定: 発生したトランザクションに対して常に"NAK応答"します。
- バッファメモリの状況に応じてトランザクションに応答します。 (b) BUF設定:
- (c) STALL設定: 発生したトランザクションに対して常に"STALL応答"します。

セットアップトランザクションに対しては、PIDビットの設定値に関わらず、常に"ACK応答"し、レジスタにUSB リクエストを格納します。

トランザクション結果によっては、本コントローラーによるPIDビットへの書き込みが発生する場合があります。 本コントローラーによりPIDビットへの書き込みが発生するのは下記の場合です。

- (1) Host Controller機能選択時にH/Wが応答PIDを設定する場合
  - (a) NAK設定:

以下の場合に、"PID=NAK"となりトークンの発行を自動的に停止します。

- (ア)アイソクロナス以外の転送で、送信したトークンに対する応答において、無応答、ビットスタッフィ ングエラーまたはCRCエラーなどの受信エラーが3回連続して発生した時。
- (イ)アイソクロナス転送で、送信したトークンに対する応答において、ビットスタッフィングエラーまた はCRCエラーなどの受信エラーが3回連続して発生した時。
- (ウ) DCPCFGレジスタのSHTNAKビットを"1"に設定した場合で、コントロールリード転送のデータス テージにおいて、ショートパケットを受信した時。
- (エ) バルク転送時にPIPECFGレジスタのSHTNAKビットを"1"に設定した場合で、ショートパケットを受 信した時。
- (オ) バルク転送時にPIPECFGレジスタのSHTNAKビットを"1"に設定した場合で、トランザクションカウ ンタが終了した時。
- (b) BUF設定:本コントローラーによる"BUF"書き込みはありません。
- (c) STALL設定:

以下の場合に、"PID=STALL"となりトークンの発行を自動的に停止します。

- (ア) 送信したトークンに対してSTALLを受信した時。
- (イ) 受信したデータパケットがマックスパケットサイズを越えた時。
- (2) Peripheral Controller機能選択時にH/Wが応答PIDを設定する場合

page 128 of 183

- (a) NAK設定:
  - (ア) SETUPトークンを正常に受信した時 (DCPのみ)。
  - (イ) バルク転送時にPIPECFGレジスタのSHTNAKビットを"1"に設定し、ショートパケットを受信した時。
  - (ウ) バルク転送時にSHTNAKビットを"1"に設定し、トランザクションカウンタが終了した時。
- (b) BUF設定: コントローラーによるBUF書き込みはありません。
- (c) STALL設定:
  - (ア) 受信データパケットでマックスパケットサイズオーバーエラーを検出した時。
  - (イ) コントロール転送シーケンスエラーを検出した時。



#### PIPE情報変更手順 3.3.3

パイプコントロールレジスタの以下のビットは、USB通信が不許可("PID=NAK")である時のみ書き換えが可能です。 図 3.13にUSB通信許可("PID=BUF")状態からパイプコントロールレジスタの切り替え手順を示します。

USB通信許可("PID=BUF")状態では設定禁止であるレジスタ

- **・DCPCFG**レジスタ、DCPMAXPレジスタの各ビット
- ・DCPCTRレジスタのSQCLRビット、SQSETビット、CSCLRビット、
- PIPECFGレジスタ、PIPEBUFレジスタ、PIPEMAXPレジスタ、PIPEPERIレジスタの各ビット
- PIPExCTRレジスタのATREPMビット、ACLRMビット、SQCLRビット、SQSETビット
- PIPExTREレジスタ、PIPExTRNレジスタの各ビット
- DEVADDxレジスタの各ビット

CSCLRビット及びDEVADDxレジスタの各ビットの設定については上記以外にも2章の各ビット説明に記載 のある設定方法を守ってください。



図 3.13 USB通信許可("PID=BUF")状態からのPIPE情報変更手順

またパイプコントロールレジスタの以下のビットは、CPU/DMA0/DMA1-FIFOポートのいずれのCURPIPEビットにも 設定されていないPipe情報のみ書き換えが可能です。

FIFOポートのCURPIPEビットに設定中に設定禁止であるレジスタ

- DCPCFGレジスタ、DCPMAXPレジスタの各ビット
- PIPECFGレジスタ、PIPEBUFレジスタ、PIPEMAXPレジスタ、PIPEPERIレジスタの各ビット

Pipe情報を変更する場合には、CURPIPEビットの設定を変更対象Pipe以外に指定してください。なお、DCPについて はPipe情報修正後、BCLRビットにてバッファのクリア処理をしてください。

#### 3.3.4 データPIDシーケンスピット

コントロール転送のデータステージ、バルク転送、インタラプト転送において正常なデータ転送が行われると、本 コントローラーによりデータPIDのシーケンスビットが自動的にトグル動作します。次に送出されるデータPIDの シーケンスビットは、DCPCTRレジスタ、及びPIPExCTRレジスタのSQMONビットにて確認できます。データ送信 時は、ACKハンドシェイク受信タイミングで、データ受信時は、ACKハンドシェイク送信タイミングで、シーケン スビットが切り替わります。また、DCPCTRレジスタ、及びPIPExCTRレジスタのSQCLRビット、SQSETビットに てデータPIDシーケンスビットを変更可能です。

またPeripheral Controller機能選択時のコントロール転送では、ステージ遷移時に本コントローラーが自動的にシーケンスビットを設定します。セットアップステージ終了時はDATA0になり、ステータスステージではDATA1で応答します。この為、ソフトウェアによる設定は必要ありません。Host Controller機能選択時のコントロール転送では、ステージ遷移時にシーケンスビットをソフトウェアで設定する必要があります。

Host、Peripheralのどちらの機能を選択した場合でも、ClearFeatureリクエストの送信または受信時などは、ソフトウェアでデータPIDシーケンスビットを設定する必要がありますのでご注意ください。

なお、アイソクロナス転送設定パイプはSQSETビットによるシーケンスビット操作を行うことはできません。



# 3.4 バッファメモリ

本章では本コントローラーに内蔵するバッファメモリに関する動作を説明します。特に記載がなければ、Host、 Peripheral機能のどちらを選択した場合も同じ動作となります。

#### 3.4.1 バッファメモリ割り当て

図 3.14に本コントローラーのバッファメモリマップ例を示します。バッファメモリはユーザーシステムの制御用CPU と本コントローラーが共用する領域です。バッファメモリの状況には、アクセス権がユーザーシステム(CPU側)にあ る場合と、本コントローラー(SIE側)にある場合があります。

バッファメモリは、パイプごとに独立した領域を設定します。メモリ領域は、64バイトを1ブロックとして、ブロック 先頭番号とブロック数(PIPEBUFレジスタのBUFNMBビット、及びBUFSIZEビットで指定)で設定します。PIPExCFG レジスタのCNTMDビットにて連続転送モードを選択した場合には、BUFSIZEビットの設定は、必ずマックスパケットサ イズの整数倍になるように設定してください。またPIPExCFGレジスタのDBLBビットにてダブルバッファを選択した場 合には、同一パイプに対してPIPEBUFレジスタのBUFSIZEビットにて指定したメモリ領域を2面分割り当てられます。

バッファメモリへのアクセス (データ読み書き) は3本のFIFOポートを使用します。FIFOポートに割り当てるパイプ は、C/DxFIFOSELレジスタのCURPIPEビットにてパイプ番号を指定します。

各パイプのバッファステータス (CPUからバッファメモリへのデータ読み書き可否) は、DCPCTRレジスタ、及び PIPExCTRレジスタのBSTSビット、INBUFMビットで確認できます。また、FIFOポートのアクセス権は、C/DxFIFOCTR レジスタのFRDYビットで確認できます。





図 3.14 バッファメモリマップ例

#### 3.4.1.1 パッファステータス

表 3.11に本コントローラーのバッファステータス表を示します。バッファメモリステータスをBSTSビット、及びINBUFMビットにて確認できます。バッファメモリのアクセス方向は、PIPExCFGレジスタのDIRビット、もしくはCFIFOSELレジスタのISELビット (DCP選択時) で、バッファメモリのアクセス方向を指定します。

なお、INBUFMビットは送信方向のパイプ1~5のみで有効です。

送信側の転送パイプをダブルバッファに設定している場合、BSTSビットはCPU側のバッファの状態を、INBUFMビットはSIE側のバッファの状態を判断するために使用します。CPU(DMAC)によるFIFOポートへの書き込みが遅く、BEMP割り込みではバッファの空が判別できない場合に、INBUFMビットで送信完了を確認できます。

表 3.11 BSTSピットによるパッファステータス表

| ISELまたはDIR | BSTS | バッファメモリの状態                                                                                        |
|------------|------|---------------------------------------------------------------------------------------------------|
| 0(受信方向)    | 0    | 受信データなし、もしくは受信中。FIFOポートからの読み出し不可。                                                                 |
| 0(受信方向)    | 1    | 受信データあり、もしくはZero-Lengthパケット受信。FIFOポートからの読み出し<br>可能。<br>ただし、Zero-Lengthパケット受信時は読み出し不可のためバッファクリアが必要 |
| 1(送信方向)    | 0    | 送信を完了していない。FIFOポートへの書き込み不可。                                                                       |
| 1(送信方向)    | 1    | 送信完了。FIFOポートへの書き込み可能。                                                                             |

# 表 3.12 INBUFMビットによるバッファステータス表

| DIR     | INBUFM | バッファメモリの状態                        |
|---------|--------|-----------------------------------|
| 0(受信方向) | 無効     | 無効                                |
| 1(送信方向) | 0      | 送信可能データを送信完了した。送信可能データなし。         |
| 1(送信方向) | 1      | 送信可能データがFIFOポートから書き込まれた。送信可能データあり |

#### 3.4.1.2 パッファクリア

表 3.13に本コントローラーによるバッファメモリのクリア一覧表を示します。バッファメモリは下記の4ビットによってクリアできます。

表 3.13 バッファクリアビット一覧表

| ビット名 | BCLR                                                                | SCLR                                                          | DCLRM                                                                             | ACLRM                                                                        |
|------|---------------------------------------------------------------------|---------------------------------------------------------------|-----------------------------------------------------------------------------------|------------------------------------------------------------------------------|
| レジスタ | CFIFOCTRレジスタ<br>DxFIFOCTRレジスタ                                       | CFIFOSIEレジスタ                                                  | DxFIFOSELレジスタ                                                                     | PIPExCTRレジスタ                                                                 |
| 機能   | CFIFOポートまたは<br>DxFIFOポートに割り<br>付けているPIPEの<br>CPU側バッファメモリ<br>をクリアします | CFIFOポートに割り付けているPIPEのSIE側バッファメモリをクリアします                       | 指定パイプのデータを読み出した後で、自動でバッファメモリをクリアするモードです。DMACを使用してデータ読み出しを行う場合に便利な機能です。第3.4.3.4章参照 | ACLRMビットに"1"、"0"<br>を連続して書き込むこと<br>で当該PIPEのCPU側及び<br>SIE側バッファメモリを<br>クリアします。 |
| 設定方法 | "BCLR=1"設定により<br>バッファメモリをクリ<br>ア<br>(自動的に" BCLR=0"に<br>もどります)       | "SCLR=1"設定により<br>バッファメモリをクリ<br>ア<br>(自動的に" SCLR=0"に<br>もどります) | "DCLRM=1"設定により<br>モード有効<br>"DCLRM=0"設定により<br>モード無効                                | "ACLRM=1"設定により<br>モード有効<br>"ACLRM=0"設定により<br>モード無効                           |

# 3.4.1.3 バッファ領域

表 3.14に本コントローラーのバッファメモリマップを示します。バッファメモリには、あらかじめパイプに割り 当てられている専用固定領域、及びユーザー設定が可能なユーザー領域があります。DCP用バッファは、コントロー ルリード転送、及びコントロールライト転送で、同一領域を使用する専用固定領域です。パイプ6-9には、あらかじ め領域を割り当ててありますが、パイプ6-9のいずれかを使用しない場合、未使用パイプの領域はユーザー領域とし てパイプ1-5に割り当てて使用可能です。各パイプで領域が重ならないように設定してください。また、バッファサ イズはマックスパケットサイズ以上になるように設定してください。

| バッファメモリ        | バッファサイズ         | 割付可能PIPE  |
|----------------|-----------------|-----------|
| 番号             |                 |           |
| 0-3            | 256バイト          | DCP専用固定領域 |
|                | (64バイトx4ブロック)   |           |
| 4              | 64バイト           | パイプ6用固定領域 |
| 5              | 64バイト           | パイプ7用固定領域 |
| 6              | 64バイト           | パイプ8用固定領域 |
| 7              | 64バイト           | パイプ9用固定領域 |
| 8 – 135 (0x87) | 4736バイト         | パイプ1-5    |
|                | (64バイトx128ブロック) |           |

表 3.14 バッファメモリマップ

# 3.4.1.4 パッファメモリ仕様 (シングル/ダブル設定)

パイプ1-5は、PIPExCFGレジスタのDBLBビットにてシングルバッファ、もしくはダブルバッファを選択できます。 ダブルバッファは同一パイプに対してPIPEBUFレジスタのBUFSIZEビットにて指定したメモリ領域を2面分割り当 てる機能です。図 3.14バッファメモリマップ例のPIPE1及びPIPE3がダブルバッファ設定の例です。



#### 3.4.1.5 パッファメモリ動作(連続転送設定)

DCPCFGレジスタ、及びPIPExCFGレジスタのCNTMDビットにて連続転送モード、もしくは非連続転送モードを選択できます。この選択は、パイプ0-5に対して有効です。

連続転送モード機能は、複数のトランザクションを連続して送受信する機能です。連続転送モード設定時は、各パイプに割り当てられたバッファサイズまでCPUへ割り込みを発生させずにデータ転送ができます。

連続送信モードでは、書き込みデータをマックスパケットサイズで分割して送信します。バッファサイズ未満のデータ送信(ショートパケット、もしくはマックスパケットサイズの整数倍でバッファサイズ未満)の場合には、送信データの書き込み後"BVAL=1"を設定する必要があります。

連続受信モードでは、バッファサイズまでのパケット受信、トランザクションカウントの終了、もしくはショートパケットを受信するまで、BRDY割り込みは発生しません。

図 3.15に本コントローラーのCNTMDビットとバッファメモリの状態遷移例を示します。



図 3.15 CNTMDビットとバッファメモリ状態遷移例

## 3.4.2 FIFOポートの機能

本章ではFIFOポートに関する機能の説明をします。表 3.15に本コントローラーのFIFOポート機能設定表を示します。 データ書き込みアクセス時は、バッファフル(非連続転送時はマックスパケットサイズ数)まで書き込みを行うと、自動 的にUSBバスに送信可能な状態となります。 バッファフル ( 非連続転送時はマックスパケットサイズ数 ) 未満のデータを 送信可能状態にするには、C/DxFIFOCTRレジスタのBVALビットによる書き込み終了設定(DMA転送時にはDEND信号) が必要です。また、Zero-Lengthパケットの送信は、同レジスタのBCLRビットによるバッファクリアの上、BVALビッ トによる書き込み終了設定が必要です。

読み出しアクセス時は、すべてのデータを読み出すと、自動的に新しいパケット受信可能状態になります。ただし、 Zero-Lengthパケット受信時(DTLN=0)は、データは読み出せませんので、同レジスタのBCLRビットによるバッファ クリアが必要です。受信データ長は、C/DxFIFOCTRレジスタのDTLNビットにて確認します。

| レジスタ名       | ビット名    | 機能                          | 参照                           | 備考       |
|-------------|---------|-----------------------------|------------------------------|----------|
| C/DxFIFOSEL | RCNT    | DTLN読み出しモード選択               |                              |          |
|             | REW     | バッファメモリリワインド( 再読み出し、再書き込み ) | 2.8.4<br>3.4.2.2             |          |
|             | DCLRM   | 指定パイプの受信データ読み出し後自動クリア       | 2.8.11<br>3.4.1.2<br>3.4.3.4 | DxFIFO専用 |
|             | DREQE   | DREQ信号アサート                  | 3.4.3                        | DxFIFO専用 |
|             | MBW     | FIFOポートアクセスビット幅             | 2.8.5<br>3.4.2.1             |          |
|             | BIGEND  | FIFOポートエンディアン制御             | 2.8.6                        |          |
|             | ISEL    | FIFOポートアクセス方向               | 2.8.7<br>3.4.2.1             | DCP専用    |
|             | CURPIPE | カレントPIPE選択                  | 2.8.8                        |          |
| C/DxFIFOCTR | BVAL    | バッファメモリ書き込み終了               | 2.8.16                       |          |
|             | BCLR    | CPU側バッファメモリクリア              | 2.8.17<br>3.4.1.2            |          |
|             | FRDY    | FIFOポートレディーモニタ              | 2.8.18                       |          |
|             | DTLN    | 受信データ長確認                    | 2.8.19                       |          |
| 外部端子        | DEND    | バッファメモリ書き込み終了               | 1.4<br>3.4.3.3               | DMA転送専用  |

表 3.15 FIFOポート機能設定表

#### 3.4.2.1 FIFO ポート選択

表 3.16に各FIFOポートで選択可能なパイプ表を示します。C/DxFIFOSELレジスタのCURPIPEビットにて、アク セスするパイプを選択します。パイプ選択後、書き込んだCURPIPE値が正しく読み出せたのを確認してから(前回 のパイプ番号が読み出された場合には、本コントローラーがパイプ変更処理中である事を示します)、"FRDY=1"を 確認しFIFOポートへアクセスしてください。

また、MBWビットで、FIFOポートへアクセスするバス幅を選択してください。

バッファメモリアクセス方向は、DCPの場合はISELビットの設定に、その他のパイプはPIPExCFGレジスタのDIR ビットに従います。

| パイプ       | アクセス方法  | 使用可能なポート      |
|-----------|---------|---------------|
| DCP       | CPUアクセス | CFIFOポートレジスタ  |
| パイプ1~パイプ7 | CPUアクセス | CFIFOポートレジスタ  |
|           |         | DxFIFOポートレジスタ |
|           | DMAアクセス | DxFIFOポートレジスタ |

表 3.16 パイプ別FIFOポートアクセス表

# 3.4.2.2 REW ビット

現在アクセス中のパイプアクセスを一時的に中断し、別のパイプに対するアクセスを行い、再度現在のパイプ処理 を継続して行うことができます。このような処理には、C/DxFIFOSELレジスタのREWビットを使用します。



## 3.4.2.3 トランザクションカウンタ(読み出し方向)

本コントローラーは、データパケット受信方向で、指定回数のトランザクションが終了した場合に、トランスファー終了と認識することができます。トランザクションカウンタは、受信方向に設定されているPIPEに対して動作する機能です。どのFIFOポートから読み出しを行う場合にでも本機能を使用可能です。

トランザクションカウンタには、トランザクション回数を指定するTRNCNTレジスタと、内部でトランザクションをカウントするカレントカウンタがあり、カレントカウンタが指定回数に一致すると、バッファメモリがフルではないときでもバッファメモリが読み出し可能状態となります。Host Controller機能選択時には、バッファメモリが読み出し可能になることに加え、本コントローラーからの当該PIPEに対するトークン発行が停止します。

TRCLRビットにて、トランザクションカウンタ機能のカレントカウンタを初期化し、トランザクションを最初からカウントし直すことができます。TRENBビットの設定により、TRNCNTレジスタ読み出し時の情報が異なります。

TRENB=0設定時: 設定したトランザクションカウンタ値が読み出せます。

TRENB=1設定時:内部でカウントしたカレントカウンタ値が読み出せます。

CURPIPEビットの変更条件は下記のとおりです。

- (1) 指定したパイプのトランザクションが終了するまで、CURPIPEビットは変更しないでください。
- (2) カレントカウンタがクリアされていないと**CURPIPE**ビットは変更できません。 **TRCLR**ビットの操作条件は下記のとおりです。
- (1) トランザクションカウント中、かつ、"PID=BUF"の場合は、カレントカウンタはクリアできません。
- (2) バッファ内にデータが残っている状態ではカレントカウンタはクリアできません。



#### 3.4.3 DMA転送(DxFIFOポート)

#### 3.4.3.1 DMA 転送概要

**エラー! プロパティ名に誤りがあります。エラー! プロパティ名に誤りがあります。**パイプ1~9に対して、DMAC によるFIFOポートアクセスが可能です。DMAに設定したパイプのバッファにアクセス可能になった場合に、**DREQ** 信号をアサートします。

DMA転送は、1データ(8ビットまたは16ビット)転送ごとにDREQ信号をアサートするサイクルスチール転送モードと、バッファメモリ内の全データ転送が完了するまでDREQ信号のアサートを続ける、バースト転送モードを選択することができます。タイミングは第4章 電気的特性を参照ください。

DxFIFOSELレジスタのMBWビットにてFIFOポートへの転送単位(8ビットまたは16ビット)を、CURPIPEビットにてDMA転送するパイプを選択してください。なお、DMA転送中は選択しているパイプ(CURPIPEビットへの設定値)を変更しないでください。

#### 3.4.3.2 DMA 制御信号選択

DMAxCFGレジスタのDFORMビットにてDMA転送で使用する端子の選択を、DxFIFOSELレジスタのDREQEビットにて、DREQx\_N端子の制御を行ってください。表 3.17に本コントローラーのDMA制御端子一覧表を、図 3.16にFIFOポートアクセス方法とDMA制御端子を示します。

| レジスタ       |       |   |      | 端子 |        |      |      |       | 備考          |            |
|------------|-------|---|------|----|--------|------|------|-------|-------------|------------|
| アクセス<br>方法 | DREQE | D | FORM | И  | DATAバス | DREQ | DACK | RD/WR | ADDR<br>+CS |            |
| CPUバス0     | 0     | 0 | 0    | 0  | CPU    | -    | -    |       |             | CPUアクセス    |
| CPUバス1     | 1     | 0 | 0    | 0  | CPU    |      | -    |       |             | CPUバスでのDMA |
| CPUバス2     | 1     | 0 | 1    | 0  | CPU    |      |      |       | *1)         | CPUバスでのDMA |
| CPUバス3     | 1     | 0 | 1    | 1  | CPU    |      |      | -     | *1)         | CPUバスでのDMA |
| SPLITバス    | 1     | 1 | 1    | 0  | SPLIT  |      |      | -     | -           | スプリットバス    |

表 3.17 DMA制御端子一覧表

\*1) 本アクセス方法を設定する場合、DxFIFO ポートへのアクセス中は CS\_N 信号をインアクティブに("High"に固定) してください。



図 3.16 FIFOポートアクセス方法とDMA制御端子

#### 3.4.3.3 DEND 端子

本コントローラーは、エラー! プロパティ名に誤りがあります。DEND端子を使用し、DMA転送を終了することが 可能です。DEND端子はUSBデータ転送方向により、入出力が別の機能となります。

#### (1) バッファメモリ読み出し方向

**DEND**端子は、出力端子となり、外部DMAコントローラーに対して最後のデータ転送通知が可能です。**DEND**信号 アサート条件は、DMAxCFGレジスタのPKTMビットによって設定することができます。

表 3.18に本コントローラーのDEND端子アサート一覧表を示します。

表 3.18 DEND端子アサート一覧表

|    | イベント  | トランザクショ<br>ンカウント終了 | パケット受信に<br>よるBRDY発生 | Zero-Lengthパケッ<br>ト以外のショート | バッファ非EMPTY<br>時のZero-Lengthパ | バッファEMPTY時<br>のZero-Lengthパケ |
|----|-------|--------------------|---------------------|----------------------------|------------------------------|------------------------------|
| PK | CTM \ |                    |                     | パケット受信                     | ケット受信                        | ット受信*1)                      |
| 0  |       | アサート               | アサートせず              | アサート                       | アサート                         | アサート                         |
| 1  |       | アサート               | アサート                | アサート                       | アサート                         | アサートせず                       |

<sup>\*1)</sup> バッファエンプティ時の Zero-Length パケット受信では DREQ 信号をアサートしません。

#### (2)バッファメモリ書き込み方向

DEND端子は入力端子となり、アクティブエッジの検出でバッファメモリを送信可能状態("BVAL=1"を設定した 場合と同じ状態)にします。

## 3.4.3.4 DxFIFO 自動クリアモード (DxFIFO ポート読み出し方向)

DxFIFOSELレジスタのDCLRMビットに"1"を設定することで、本コントローラーはバッファメモリからのデータ 読み出しを完了した場合に、当該パイプのバッファメモリを自動的にクリアします。

表 3.19に各設定での、パケット受信とソフトウエアによるバッファメモリクリア処理の関連表を示します。 表 3.19に示すように、BFREビットの設定値によりバッファクリア条件が異なりますが、クリアが必要などのよう な状態においても、DCLRMビットを使用することでソフトウエアによるバッファクリアが不要になり、ソフトウエ アを介在させないDMA転送が可能となります。

なお、本機能はバッファメモリ読み出し方向のみ設定できます。

表 3.19 パケット受信とソフトウェアによるパッファメモリクリア処理の関連表

| レジスタ設定            | DCLR   | RM = 0 | DCLRM=1 |        |
|-------------------|--------|--------|---------|--------|
| パケット受信時のバッファ状態    | BFRE=0 | BFRE=1 | BFRE=0  | BFRE=1 |
| バッファフル            | クリア不要  | クリア不要  | クリア不要   | クリア不要  |
| Zero-Lengthパケット受信 | クリア必要  | クリア必要  | クリア不要   | クリア不要  |
| 通常のショートパケット受信     | クリア不要  | クリア必要  | クリア不要   | クリア不要  |
| トランザクションカウント終了    | クリア不要  | クリア必要  | クリア不要   | クリア不要  |



# 3.4.3.5 BRDY 割り込みタイミング選択機能

PIPECFGレジスタのBFREビットの設定により、マックスパケットサイズのデータパケットを受信時にBRDY割り込みを発生させないようにすることができます。

この機能によりDMA転送を使用している場合に、最終データを受信したときのみに割り込みを発生させることができます。最終データとはショートパケットの受信、またはトランザクションカウントの終了を示します。"BFRE=1"に設定してる場合は、受信したデータを読み出した後で、BRDY割り込みが発生します。DnFIFOCTRレジスタのDTLNビットを読み出すことにより、BRDY割り込みの発生時に最後に受信したデータパケットの受信データ長を確認することができます。

表 3.20に本コントローラーのBRDY割り込み発生タイミングを示します。

表 3.20 BRDY割り込み発生タイミング表

| レジスタ設定 パケット受信時のパッファ状態 | BFRE = "0" | BFRE = "1"                  |
|-----------------------|------------|-----------------------------|
| バッファフル(通常のパケット受信)     | パケット受信時    | 発生しない                       |
| Zero-Lengthパケット受信     | パケット受信時    | パケット受信時                     |
| 通常のショートパケット受信         | パケット受信時    | バッファメモリから、受信デー<br>タの読み出し完了時 |
| トランザクションカウント終了        | パケット受信時    | バッファメモリから、受信デー<br>タの読み出し完了時 |

BFRE ビット機能はバッファメモリから読み出し方向のみ有効です。書き込み方向の場合には BFRE ビットは"0"に固定してください。



## 3.4.4 FIFOポートアクセス可能タイミング

本章ではFIFOポートへのアクセス可能なタイミングについて説明します。

#### 3.4.4.1 パイプ切り替え時の FIFO ポートアクセス可能タイミング

図 3.17に、FIFOポートで指定するパイプを切り替えた(C/DxFIFOSELレジスタのCURPIPEビットを変更した)場合の、FRDYビット、及びDTLNビットが確定するまでのタイミング図を示します。

**CURPIPE**ビットを変更した場合は、書き込んだ**CURPIPE**値が正しく読み出せたのを確認してから(前回のパイプ番号が読み出された場合には、本コントローラーがパイプ変更処理中である事を示します)、"FRDY=1"を確認しFIFOポートへアクセスしてください。

なお、CFIFOポートに対しては、ISELビットを変更時も同様のタイミングになります。



図 3.17 パイプ変更後のFRDY、DTLNの確定タイミング

## 3.4.4.2 ダブルバッファ時の読み出し、書き込み完了後の FIFO ポートアクセス可能タイミング

図 3.18に、ダブルバッファのパイプに対して、バッファリード、もしくはライト完了後、もう一方のバッファがアクセス可能状態になるまでのタイミングを示します。

ダブルバッファ時は、トグル直前のアクセス後に300ns待った後、FIFOポートへのアクセスを行ってください。なおIN方向のパイプにて"BVAL=1"設定によるショートパケット送信を行う時も同様のタイミングになります。



図 3.18ダブルバッファ時の読み出し、書き込み完了後のFRDY、DTLNの確定タイミング

# 3.5 データセットアップタイミング

本章ではスプリットバスのタイミングを設定するOBUSビットについて説明します。Host、Peripheral機能のどちらを 選択した場合も同じ動作となります。

本コントローラーはDMAxCFGレジスタのOBUSビットにより、SD0-7とDEND端子のタイミングを、表 3.21のよう に変えることができます。OBUSビットは、スプリットバスを用いたDMA転送時のみ有効な機能です。CPUバスでDMA 転送を行う場合には、OBUSビットの設定は無視されます。

| 方向   | OBUS<br>ビット設定 | 動作                                              |
|------|---------------|-------------------------------------------------|
| 読み出し | 0             | コントロール信号*2)に関わらず、SD0-7、DEND信号は常に出力します。          |
|      |               | コントロール信号がネゲートされると次のデータが出力されます。                  |
|      |               | このため、DMACのデータセットアップ時間が確保され、高速なDMA転送が可能になります。    |
|      | 1             | コントロール信号アサートされてから、SD0-7、DEND信号を出力します。           |
|      |               | コントロール信号がネゲートされるとSD0-7、DEND信号はHizになります。         |
| 書き込み | 0             | DACKx_N信号に関わらず、SD0-7、DEND信号を常に入力可能とします。         |
|      |               | DMACはDACKx_N信号をアサートするより前から、次のデータを出力することが可能です。   |
|      |               | このため、本コントローラーのデータセットアップ時間が確保されて、高速なDMA転送が可      |
|      |               | 能になります。                                         |
|      | 1             | DACKx_N信号がアサートされている場合のみ、SDO-7、DEND信号は入力可能となります。 |
|      |               | DACKx_N信号がネゲートされている場合は、SD0-7、DEND信号は無視します。      |

表 3.21 OBUSビット設定値によるの動作相違点

読み出し方向でOBUS=0に設定すると、SD0-7、DEND信号が常に出力になりますので、他のデバイスとバスを共有す る場合には信号の衝突にご注意下さい。

書き込み方向でOBUS=0に設定すると、SD0-7、DEND信号を常に入力可能な状態になります。信号を中間電位にしな いようご注意下さい。



図 3.19に本コントローラーの、OBUSビットによるデータセットアップタイミング概要図を示します。

図 3.19 データセットアップタイミング概要図

<sup>\*2)</sup> コントロール信号とは、DMAxCFG レジスタの DFORM[9-7]が"100"の場合は、DACKx\_N を示します。

# 3.6 コントロール転送 (DCP)

コントロール転送のデータステージのデータ転送は、デフォルトコントロールパイプ (DCP)を使用します。DCPのバッファメモリは、コントロールリード、及びコントロールライト共用の固定領域で256バイトシングルバッファです。 バッファメモリへのアクセスは、CFIFOポートのみ可能です。

### 3.6.1 Host Controller機能選択時のコントロール転送

コントロール転送のステージ遷移管理は以下のとおりソフトウェアが行います。

コントロール転送を行う相手のPeripheral DeviceがLow-Speedの場合は、そのDeviceとのコントロール転送期間中はSOFCFGレジスタのTRNENSELビットに"1"を設定してください。

### 3.6.1.1 セットアップステージ

USBREQレジスタ, USBVALレジスタ, USBINDXレジスタ及びUSBLENGレジスタはセットアップトランザクションのUSBリクエスト送信用のレジスタです。セットアップパケットのデータをレジスタに書き込み、DCPCTRレジスタのSUREQビットに"1"を書き込むことで設定されているデータがセットアップトランザクションとして送出されます。SUREQビットは、トランザクションが終了すると、H/Wが"0"を書き込みます。"SUREQ =1"中は上記USBリクエストレジスタを操作しないで下さい。

Peripheralデバイスのアタッチ検出後、そのデバイスに対する最初のセットアップトランザクションは、DCPMAXPレジスタのDEVSELビットに0を設定し、DEVADD0レジスタのUPPHUBビット、HUBPORTビット、USBSPDビット、RTPORTビットを設定し上記シーケンスでセットアップトランザクションを発行してください。

PeripheralデバイスがAddressステートに遷移した以降は、**DEVSEL**ビットに割り付けたUSB Address値を設定し、USB Addressに対応する**DEVADDx**レジスタの各ビットを設定後に上記シーケンスでセットアップトランザクションを発行してください。例えば、"**DEVSEL**=0x2"の時は**DEVADD2**レジスタを、"**DEVSEL**=0xA"の時は**DEVADDA**レジスタを設定してください。

トランザクションを送出すると、ペリフェラルからの応答により割り込み要求が発生します(INTSTS1レジスタのSIGNビット及びSACKビット)。この割り込み要求によりセットアップトランザクション結果を確認することができます。

セットアップトランザクションのデータパケットはDCPCTRレジスタのSQMONビットの内容に関わらす、常にDATA0のデータパケット(USBリクエスト)が送信されます。

### 3.6.1.2 データステージ

DCPバッファメモリを使用してデータの転送を行います。

DCPバッファメモリへのアクセスにはCFIFOSELレジスタのISELビットでアクセス方向を指定してください。また DCPCFGレジスタのDIRビットで転送方向を指定してください。

データステージの第1データパケットはデータPIDをDATA1として通信する必要があります。DCPCFGレジスタのSQSETビットでデータPIDをDATA1にセットし、PIDビットをBUFに設定することでトランザクションを実行します。データ転送の完了は、BRDY割り込み及びBEMP割り込みによって検出します。

また、コントロールライト転送の場合、送信データがマックスパケットサイズの整数倍の場合は最後にZero-Lengthパケットを送出するようにソフトウェアで制御してください。

Hi-Speed動作時のデータ送信方向の通信において、最初に発行するトークンをPINGにするかOUTにするかを **DCPCTR**レジスタの**PINGE**ビットで設定する事ができます。

PINGパケットの制御はバルク転送と同様です。3.7.1章を参照ください。

### 3.6.1.3 ステータスステージ

データステージと逆方向のZero-Lengthパケットのデータ転送です。データステージ同様にDCPバッファメモリを使用したデータ転送になります。データステージと同様手順でトランザクションを実行します。

データステージのデータパケットはデータPIDをDATA1として通信する必要があります。**DCPCFG**レジスタの**SQSET** ビットでデータPIDをDATA1にセットしてください。

また、Zero-Lengthパケットの受信は、BRDY割り込み発生後CFIFOCTRレジスタのDTLNビットで受信データ長を確認のうえ、BCLRビットでバッファメモリクリアを行ってください。

Hi-Speed動作時のデータ送信方向の通信において、最初に発行するトークンをPINGにするかOUTにするかを DCPCTRレジスタのPINGEビットで設定する事ができます。

### 3.6.1.4 データステージ及びステータスステージにおける PING パケット制御

OUT方向のPINGパケットの送信は、本コントローラーにより自動的に送出されます。"PINGE=0"設定時には、以下



に示すとおり本コントローラーは送信方向の通信をOUTパケットから開始します。OUTトランザクションにおいてNAKまたはNYETを受信するとPING送出を行います。PINGに対するACKハンドシェイクを受信するとOUTパケットを送出します。

<<OUTデータ送信開始>>

- (1) OUTデータパケット送信
- (2) ACKハンドシェイク受信
- (3) OUTデータパケット送信

:

- (4) NAK/NYETハンドシェイク受信
- (5) PINGパケット送信
- (6) NAKハンドシェイク受信
- (7) PINGパケット送信

:

- (8) ACKハンドシェイク受信
  - "PINGE=0"設定での使用を推奨します。 "PINGE=1"設定時は3.7.1章に示す動作を行います。



### Peripheral Controller機能選択時のコントロール転送

### 3.6.2.1 セットアップステージ

本コントローラーは、本コントローラーに対する正常なセットアップパケットに対して、必ずACK応答します。セッ トアップステージでの本コントローラーの動作を以下に示します。

- (1) 新しいセットアップパケットを受信すると、本コントローラーは、以下のビットをセットします。
  - (a) INTSTS0レジスタのVALIDビットを"1"にセット
  - (b) DCPCTRレジスタのPIDビットを"NAK"にセット
  - (c) DCPCTRレジスタのCCPLビットを"0"にセット
- (2) セットアップパケットに引き続き、データパケット受信すると、本コントローラーは、USBリクエストのパラメータ を、USBREQレジスタ、USBVALレジスタ、USBINDXレジスタ、及びUSBLENGレジスタに格納します。

コントロール転送に対する応答処理は、必ず"VALID=0"を設定後に行ってください。"VALID=1"状態では"PID=BUF" 設定が行えず、データステージを終了することができません。

VALIDビットの機能により、本コントローラーは、コントロール転送中に新しいUSBリクエストを受信した場合には処 理中のリクエスト処理を中断し、最新のリクエストに対する応答を行うことができます。

また、本コントローラーは、受信したUSBリクエストの方向ビット(bmRequestTypeのbit8)、及びリクエストデー タ長(wLength)を自動判別し、コントロールリード転送、コントロールライト転送、及びノーデータコントロール転送 を識別し、ステージ遷移を管理します。間違ったシーケンスに対しては、コントロール転送ステージ遷移割り込みのシー ケンスエラーが発生し、ソフトウェアに通知します。本コントローラーのステージ管理については図 3.11を参照くださ い。

### 3.6.2.2 データステージ

受信したUSBリクエストに対応したデータ転送をDCPにて行ってください。

DCPバッファメモリへアクセスする前に、CFIFOSELレジスタのISELビットにてアクセス方向を指定してください。 またDCPCFGレジスタのDIRビットで転送方向を指定してください。

データステージの第1データパケットはデータPIDをDATA1として通信する必要があります。DCPCFGレジスタの SQSETビットでデータPIDをDATA1にセットし、PIDビットをBUFに設定することでトランザクションを実行します。 データ転送の完了は、BRDY割り込み及びBEMP割り込みによって検出します。コントロールライト転送ではBRDY割 り込みを、コントロールリード転送ではBEMP割り込みを使用してください。

Hi-Speed動作時のコントロールライト転送では、バッファメモリの状況に応じてNYETハンドシェイク応答を行います。 3.6.1.4章を参照してください。

# 3.6.2.3 ステータスステージ

DCPCTRレジスタのPIDビットが"PID=BUF"の状態で、CCPLビットに"1"を設定することによりコントロール転送を 終了します。

上記設定後、セットアップステージで確定したデータ転送方向に従い、本コントローラーが自動的にステータスステー ジを実行します。具体的には下記のとおりです。

(1) コントロールリード転送の場合:

本コントローラーはZero-Lengthパケットの送信を行い、USB Host ControllerからのACK応答を受信します。

(2) コントロールライト転送、ノーデータコントロール転送の場合: USBホストからのZero-Lengthパケットを受信し、ACK応答を送信します。

### 3.6.2.4 コントロール転送自動応答機能

本コントローラーは、正常なエラー!プロパティ名に誤りがあります。SET\_ADDRESSリクエストに自動応答します。 SET\_ADDRESSリクエストに下記のエラーがある場合は、ソフトウェアによる応答が必要です。

"0x00" (1) コントロールリード転送以外の場合: bmRequestType (2) リクエストエラーの場合: wIndex "0x00"

(3) ノーデータコントロール転送以外の場合: wLength "0x00"

(4) リクエストエラーの場合: > "0x7F" wValue

(5) デバイスステートエラーのコントロール転送: **DVSQ** = "011 ( Configured ) "

SET\_ADDRESS以外の全てのリクエストには対応するソフトウェアによる応答が必要です。



# 3.7 パルク転送 (パイプ1-5)

バルク転送では、バッファメモリの使用方法(シングル/ダブルバッファ設定、もしくは連続/非連続転送モード設定)の選択ができます。バッファメモリサイズは、最大2Kバイトのダブルバッファまで設定可能です。バッファメモリの状態はコントローラーが管理し、PINGパケット/NYETハンドシェイクには自動応答します。

### 3.7.1 Host Controller機能選択時のPINGパケット制御

OUT方向のPINGパケットの送信は、本コントローラーにより自動的に送出されます。以下に示すとおり本コントローラーは送信方向の通信をPINGパケットから開始します。PINGに対するACKハンドシェイクを受信するとOUTパケットを送出します。OUTトランザクションにおいてNAKまたはNYETを受信するとPING送出状態に戻ります。

<<OUTデータ送信開始>>

- (1) PINGパケット送信
- (2) NAKハンドシェイク受信
- (3) PINGパケット送信
- (2) ACKハンドシェイク受信
- (3) OUTデータパケット送信
- (4) ACKハンドシェイク受信
- (5) OUTデータパケット送信

:

(6) NAK/NYETハンドシェイク受信

また、本コントローラーがPINGパケットの送信に戻る要因は、H/Wリセット 、NYET/NAKハンドシェイク受信、シーケンストグルビットのクリア(**SQCLR**)、バッファクリア(**ACLRM**)設定です。

### 3.7.2 Peripheral Controller機能選択時のNYET八ンドシェイク制御

表 3.22にバルク転送及びコントロール転送における受信トークンに対する応答一覧表を示します。本コントローラーは、バルク転送及びコントロール転送においてOUTトークン受信時にバッファメモリに1パケット分の空き領域しかない場合にNYET応答を行います。ただし、ショートパケット受信時は、この条件の場合でもNYET応答をせずにACK応答を行います。

表 3.22 受信トークンに対する応答一覧表

| PIDビット    | バッファメモリ    |             |           |                       |
|-----------|------------|-------------|-----------|-----------------------|
| 設定値       | の状態*1)     | 受信トークン      | 応答        | 備考                    |
| NAK/STALL | -          | SETUP       | ACK       | -                     |
| NANGTALL  | -          | IN/OUT/PING | NAK/STALL | -                     |
|           | -          | SETUP       | ACK       | -                     |
|           | RCV-BRDY*1 | OUT/PING    | ACK       | OUTトークン受信時はデータパケットを受信 |
|           | RCV-BRDY*2 | OUT         | NYET      | データパケット受信、受信不能通知      |
| BUF       | RCV-BRDY*2 | OUT (Short) | ACK       | データパケット受信、受信可能通知      |
| БОР       | RCV-BRDY*2 | PING        | ACK       | 受信可能通知                |
|           | RCV-NRDY   | OUT / PING  | NAK       | 受信不可通知                |
|           | TRN-BRDY   | IN          | DATA0 / 1 | データパケット送信             |
|           | TRN-NRDY   | IN          | NAK       |                       |

### \*1) 具体的には下記のとおりです。

RCV-BRDY\*1: OUT/PINGトークン受信時にバッファメモリに2パケット分以上の空き領域がある。

RCV-BRDY\*2: OUTトークン受信時にバッファメモリに1パケット分の空き領域しかない。

RCV-NRDY: PINGトークン受信時にバッファメモリに空き領域がない。 TRN-BRDY: INトークン受信時にバッファメモリに送信データがある。 TRN-NRDY: INトークン受信時にバッファメモリに送信データがない。



# 3.8 インタラプト転送(パイプ6-9)

Peripheral Controller機能選択時、本コントローラーは、ホストコントローラーが管理している周期に従ってインタラ プト転送を行います。インタラプト転送の場合、PINGパケットに対しては無視(無応答になる)します。またNYETハ ンドシェイクを送信せず、ACK、NAK、STALLいずれかの応答を行います。

Host Controller機能選択時は、インターバルカウンタによりトークン発行タイミングの設定を行うことができます。 OUT方向の転送であっても、PINGトークンは発行せず、OUTトークンを発行します。また、ペリフェラルからNYET ハンドシェイクを受信した場合は、ACK受信として動作します。

また、本コントローラーは、インタラプト転送のHigh-Bandwidth転送には対応していません。

### 3.8.1 Host Controller機能選択時のインタラプト転送時のインターバルカウンタ

### 3.8.1.1 動作概要

インタラプト転送を行う場合、PIPEPERIレジスタのIITVビットに、トランザクションのインターバルを設定します。 本コントローラーは設定されたインターバルにしたがってインタラプト転送のトークンを発行します。

### 3.8.1.2 カウンタの初期化

本コントローラーがインターバルカウンタを初期化する条件は以下のとおりです。

(1) H/Wリセット

IITVビットが初期化されます。

(2) ACLRMによるバッファメモリ初期化

IITVビットは初期化されませんがカウントは初期化されます。ACLRMビットを0にすることにより、IITVの設定 値を最初からカウントします。

なお以下の場合にはインターバルカウンタは初期化されませんのでご注意ください。

(1) USBバスリセット、USBサスペンド

IITVビットは初期化されません。UACTビットを1にすることにより、USBバスリセット、USBサスペンド状態 とする前の値からカウントを開始します。

### 3.8.1.3 トークンの発生タイミングに送受信できない場合の動作

以下のような場合、トークンの発生タイミングであってもトークンを発生させません。このような場合、次のインター バルにトランザクションの実行を試みます。

- (1) PIDビットを"NAK"または"STALL"に設定した場合
- (2) IN方向(受信)の転送でトークンの送信タイミングにバッファメモリに空き領域が無い場合
- (3) OUT方向(送信)の転送でトークンの送信タイミングにバッファメモリに送信データが無い場合

# 3.9 アイソクロナス転送(パイプ1-2)

本コントローラーは、**エラー! プロパティ名に誤りがあります。**アイソクロナス転送に対して下記の機能を備えていま す。

- (1) アイソクロナス転送のエラー情報通知
- (2) インターバルカウンタ (IITVビット指定)
- (3) アイソクロナスIN転送データセットアップコントロール(IDLY機能)
- (4) アイソクロナスIN転送バッファフラッシュ機能(IFISビット指定)
- (5) SOFパルス出力機能

本コントローラーは、アイソクロナス転送のHigh-Bandwidth転送には対応していません。

Isochronous-PIPEをSplit-Transactionで通信する場合には、MXPSビットには188バイト以下の値を設定してください。

Host Controller機能選択時で、2PIPE同時にアイソクロナス転送として使用する場合には、USB2.0 Spec Section5.6.3 のパケット制約を守ってください。



### 3.9.1 アイソクロナス転送のエラー検出

本コントローラーは、**エラー! プロパティ名に誤りがあります。**アイソクロナス転送のエラー発生を、ソフトウェアが管理するために、下記のエラー情報の検出機能を持っています。表 3.23、及び表 3.24にエラーを確認する順番と発生する割り込みについて示します。

- (1) PIDエラー
  - 受信パケットのPIDが不正な場合。
- (2) CRCエラー、ビットスタッフィングエラー 受信パケットのCRCにエラーがあった場合。またはビットスタッフィングが不正な場合。
- (3) マックスパケットサイズオーバー受信パケットのデータサイズがマックスパケットサイズの設定値を越えていた。
- (4) オーバラン、アンダーランエラー
  - (a) Host Controller機能選択時

IN方向(受信)の転送時にトークンの送信タイミングにバッファメモリに空き領域が無い場合 OUT方向(送信)の転送時にトークンの送信タイミングにバッファメモリにデータが無い場合

- (b) Peripheral Controller機能選択時
  - IN方向(送信)の転送時にINトークン受信時にバッファメモリにデータが無い場合 OUT方向(受信)の転送時にOUTトークン受信したがバッファメモリに空き領域が無い場合
- (5) インターバルエラー
  - Peripheral Controller機能選択時に、以下の場合にインターバルエラーとします。
  - (a) アイソクロナスIN転送でインターバルフレームにINトークンを受信できなかった場合。
  - (b) アイソクロナスOUT転送でインターバルフレーム以外にOUTトークンを受信した場合。

### 表 3.23 トークン送受信時のエラー検出

| 検出の<br>優先順位 | エラー種別                | エラー検出時に発生する割り込みとステータス                                                                                                                                                                               |
|-------------|----------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 1           | PIDエラー               | Host / Peripheralのどちらの機能を選択した場合にも、割り<br>込み発生せず(破損パケットとして無視)                                                                                                                                         |
| 2           | CRCエラー、ビットスタッフィングエラー | Host / Peripheralのどちらの機能を選択した場合にも、割り<br>込み発生せず(破損パケットとして無視)                                                                                                                                         |
| 3           | オーバーラン、アンダーランエラー     | Host / Peripheralのどちらの機能を選択した場合にも、NRDY割り込みを発生させ、OVRNビットをセットします。<br>Host Controller機能選択時は、以降のトークンを送信しません。<br>Peripheral Controller機能選択時は、INトークンに対して、Zero-Lengthパケットを送信します。OUTトークンに対してデータパケットを受信しません。 |
| 4           | インターバルエラー            | Peripheral Contoller機能選択時は、NRDY割り込みを発生させます。Host Controller機能選択時は、発生しません。                                                                                                                            |

### 表 3.24 データパケット受信時のエラー検出

| 検出の<br>優先順位 | エラー種別                | 発生する割り込みとステータス                                                       |
|-------------|----------------------|----------------------------------------------------------------------|
| 1           | PIDエラー               | 割り込み発生せず(破損パケットとして無視)                                                |
| 2           | CRCエラー、ビットスタッフィングエラー | Host / Peripheralのどちらの機能を選択した場合にも、NRDY割り込みを発生させて、CRCEビットをセットします。     |
| 3           | マックスパケットサイズオーバーエラー   | Host / Peripheralのどちらの機能を選択した場合にも、BEMP割り込みを発生させて、PIDを"STALL"にセットします。 |



### 3.9.2 **DATA-PID**

本コントローラーはHigh-Bandwidth転送には対応していません。Peripheral Controller機能選択時に、受信したPIDに対する対応を以下に示します。

- (1) IN方向:
  - (a) DATA0: データパケットのPIDとして送信します。
  - (b) DATA1:送信しません。 (c) DATA2:送信しません。 (d) mDATA:送信しません。
- (2)OUT方向(Full-Speed動作時):
  - (a) DATA0: データパケットのPIDとして正常受信します。
  - (b) DATA1: データパケットのPIDとして正常受信します。
  - (c) DATA2:パケットを無視します。 (d) mDATA:パケットを無視します。
- (3) OUT方向(Hi-Speed動作時):
  - (a) DATA0: データパケットのPIDとして正常受信します。 (b) DATA1: データパケットのPIDとして正常受信します。
  - (c) DATA2:データパケットのPIDとして正常受信します。 (d) mDATA:データパケットのPIDとして正常受信します。

### 3.9.3 インターバルカウンタ

### 3.9.3.1 動作概要

PIPEPERIレジスタのIITVビットによりアイソクロナス転送のインターバルを設定できます。インターバルカウンタにより、Peripheral Controller機能選択時、表 3.25の機能を実現します。Host Controller機能選択時は、トークンの発行タイミングを生成します。Host Controller機能選択時のインターバルカウンタの動作は、インタラプト転送と同じ動作となります。3.8.1を参照ください。

表 3.25 Peripheral Controller機能選択時のインターバルカウンタの機能

| 転送方向 | 機能                | 検出条件                                         |
|------|-------------------|----------------------------------------------|
| IN   | 送信バッファフラッシュ機<br>能 | アイソクロナスIN転送でインターバルフレームにINトークンを正<br>常受信できない   |
| OUT  | トークン未受信の通知        | アイソクロナスOUT転送でインターバルフレームにOUTトークン<br>を正常受信できない |

インターバルのカウントは、SOFの受信または補完されたSOFで行いますので、SOFが破損しても等時性を保つことができます。設定できるフレーム間隔は $2^{\Pi TV}$ ( $\mu$ )フレームです。

### 3.9.3.2 Peripheral Controller 機能選択時でのインターバルカウンタの初期化

本コントローラーは、下記の条件でインターバルカウンタを初期化します。

- (1) H/Wリセット
  - IITVビットが初期化されます。
- (2) ACLRMビットによるバッファメモリのクリア

IITVビットは初期化されませんがカウントは初期化されます。ACLRMビットを0にすることにより、IITVの設定値からカウントを開始します。

インターバルカウンタが初期化された後は、正常にパケットを転送したあとに、下記の条件でインターバルのカウントを開始します。

- (1) "PID=BUF"状態でINトークンに対して、データを送信後のSOF受信
- (2) "PID=BUF"状態でOUTトークンの、データを受信後のSOF受信



なお、下記の条件ではインターバルカウンタは初期化されません。

- (1) PIDをNAKまたはSTALLに設定した場合
  - インターバルタイマは停止しません。次のインターバルにトランザクションの実行を試みます。
- (2) USBバスリセット、USBサスペンド

IITVビットは初期化されません。SOFを受信すると、受信前の値からカウントを開始します。

### 3.9.4 Peripheral Controller機能選択時のアイソクロナス転送送信データセットアップ

Peripheral Controller機能選択時、本コントローラーのアイソクロナスデータ送信では、バッファメモリにデータ書き込み後、SOFパケットを検出した次のフレームでデータパケットの送出が可能になります。この機能をアイソクロナス転送送信データセットアップ機能と呼びます。この機能により送信を開始したフレームを特定することができます。

バッファメモリをダブルバッファで使用している場合で、両方のバッファの書き込みが終了している場合も、転送可能 状態になるバッファメモリは先に書き込みを終了した1面だけとなります。このため同一フレームで、複数のINトークン を受信しても、送出されるバッファメモリはただ1パケット分となります。

INトークンの受信時に、バッファメモリが送信可能状態であればデータ転送し正常応答します。しかし、バッファメモリが送信不能状態であれば、Zero-Lengthパケットを送出しアンダーランエラーとなります。

Zero-Lengthパケット送出は図中で網掛けNullと表示しています。

図 3.20に本コントローラーで、"IITV=0 (毎フレーム)"を設定した場合のアイソクロナス転送送信データセットアップ機能による送信例を示します。



図 3.20 データセットアップ機能動作例

### 3.9.5 Peripheral Controller機能選択時のアイソクロナス転送送信パッファフラッシュ

Peripheral Controller機能選択時、本コントローラーは、アイソクロナスデータ送信でインターバルフレームにINトークンを受信せず、次フレームの( $\mu$ )SOFパケットを受信した場合は、INトークン破損として扱い、送信可能状態になっているバッファをクリアし、そのバッファを書き込み可能状態にします。

また、このときにダブルバッファで使用しており両方のバッファの書き込みが終了している場合は、破棄したバッファメモリを同インターバルフレームで送信されたものとみなして、(μ)SOFパケット受信で破棄されていないバッファメモリを転送可能状態にします。

IITVビットの設定値によりバッファフラッシュ機能の動作開始タイミングが異なります。

- (1) IITV=0の場合
  - パイプが有効となった次のフレームからバッファフラッシュ動作を行います。
- (2) IITV=0以外の場合

最初の正常なトランザクション以降バッファフラッシュ動作を行います。

図 3.21に本コントローラーのバッファフラッシュ機能の動作例を示します。ただし、設定されたインターバル間隔外 (インターバルフレーム前の)トークン受信に対しては、データセットアップ状態に従い、書き込みデータの送出もしくはアンダーランエラーとしてZero-Lengthパケットの送出を行います。



図 3.21 バッファフラッシュ機能動作例

図 3.22に本コントローラーのインターバルエラー発生例を示します。インターバルエラーは下記の5種類です。図中のタイミングでインターバルエラーが発生しバッファフラッシュ機能が動作します。

インターバルエラーはIN転送時にバッファフラッシュ機能が動作し、OUT転送時はNRDY割り込みが発生します。 受信パケットエラーなどのNRDY割り込みとオーバーランエラーとの区別はOVRNビットで判定してください。 図中網掛けのトークンに対してはバッファメモリの状態に応じた応答になります。

- (1) IN方向:
  - (a) バッファ転送可能状態であればデータ転送し正常応答
  - (b) バッファ転送不能状態であればZero-Lengthパケット送信しアンダーランエラー
- (2)OUT方向:
  - (a) バッファ受信可能状態であればデータ受信し正常応答
  - (b) バッファ受信不能状態であればデータ破棄しオーバーランエラー



図 3.22 "IITV=1"の時のインターバルエラー発生例

#### Host Controller機能選択時のアイソクロナス転送ペイロード 3.9.6

Isochronous-PIPEをSplit-Transactionで通信する場合には、MXPSビットには188バイト以下の値を設定してください。 Split-Transactionでの通信は、本コントローラーに接続されているHi-speed HubにIsochronous転送を行うFull-speed のデバイスを接続した場合に発生します。図 3.25に接続例を示します。

表 3.26に接続形態とIsochronous PIPEに設定可能なMXPSビットの最大値の関係を示します。



Split-Transaction通信が発生する接続例 図 3.23

### 表 3.26 接続形態とIsochronous PIPEに設定可能なMXPSビットの最大値の関係

|     | 接線                     | 設定可能な                                 |                 |  |
|-----|------------------------|---------------------------------------|-----------------|--|
| No. | 本コントローラーと<br>Hubとの通信速度 | Hubに接続された<br>Peripheral デバイスの<br>通信速度 | MXPSビットの<br>最大値 |  |
| (1) | Hi spood               | Hi-speed                              | 1024バイト         |  |
| (2) | Hi-speed               | Full-speed                            | 188バイト          |  |
| (3) | Full-speed             | Full-speed                            | 1023バイト         |  |
| (4) | Hubなし                  | Hi-speed                              | 1024バイト         |  |
| (5) | TIUD/& U               | Full-speed                            | 1023バイト         |  |

# 3.10 SOF補間機能

Peripheral Controller機能を選択時にSOFパケットの破損、もしくは欠落のために1ms(Full-Speed動作時)または 125us(Hi-Speed動作時)間隔で受信できなかった場合に、コントローラー内部でSOFを補間します。SOF補間動作の開始 は"USBE=1"かつ"SCKE=1"かつSOFパケット受信となります。また、下記の条件で補間機能が初期化されます。

- (1) H/Wリセット
- (2) USBバスリセット
- (3) サスペンド検出

また、SOF補間は次の仕様で動作します。

- (1) フレーム間隔(125usまたは1ms)はリセットハンドシェイクプロトコルの結果に従う。
- (2) SOFパケット受信までは補間機能は動作しない。
- (3) 最初のSOFパケット受信後は内部クロック48MHzで125usもしくは1msをカウントし補間する。
- (4) 2回目以降のSOFパケットを受信後は前回の受信間隔を用いて補間する。
- (5) サスペンド時及びUSBバスリセット受信中は補間しない。 (Hi-Speed動作時のサスペンド移行では最終パケットから3ms間は補間を継続します)

SOF補間機能は次の機能で動作します。

- (1) フレーム番号、及びマイクロフレーム番号の更新
- (2) SOFR割り込みタイミング、及び µ SOFロック
- (3) SOFパルス出力
- (4) アイソクロナス転送インターバルカウント

Full-Speed動作時にSOFパケットが欠落した場合には、FRMNUMレジスタのFRNMビットは更新されません。 Hi-Speed動作時にµSOFパケットが欠落した場合には、UFRMNUMレジスタのUFRNMビットが更新されます。 ただし、" $\mu$  FRNM=000"の $\mu$  SOFパケットが欠落した場合には、FRNMビットは更新されません。この場合は、継続 する" $\mu$  FRNM=000"以外の $\mu$  SOFパケットが正常に受信されてもFRNMビットは更新されません。



### 3.10.1 SOFパルス出力

本コントローラーは、SOF出力が許可されている場合に、SOFのタイミングでSOFパルスを出力することができます。 SOFパルスの出力は、Host、Peripheral Controller機能のどちらを選択している場合でも有効です。

SOFCFGレジスタのSOFMビットの値が"01" (1ms SOF) または"10" (125  $\mu$  s SOF) の時に、SOF\_N端子から"L"アクティブでパルスを出力します。これを"SOF信号"と呼びます。パルスのタイミングについては図 3.24を参照してください。Peripheral Cotnroller機能選択時はSOFパケットの受信または、"SOF補間"によってSOF出力を等間隔に出力します。



図 3.24 SOF出力タイミング



### 3.11 パイプスケジュール

### 3.11.1 トランザクション発行条件

本コントローラーはHost Controller機能選択時、内部クロックを供給し"UACT=1"設定後、以下の条件でトランザクションを発行します。

| トランザクション     | 発行条件 |     |         |         |       |  |  |  |
|--------------|------|-----|---------|---------|-------|--|--|--|
|              | DIR  | PID | IITV*2) | バッファの状態 | SUREQ |  |  |  |
| セットアップ       |      |     |         |         | "1"設定 |  |  |  |
| コントロール転送のデー  | IN   | BUF | 無効      | 受信領域あり  |       |  |  |  |
| タステージ、ステータスス | OUT  | BUF | 無効      | 送信データあり |       |  |  |  |
| テージ、バルク転送    |      |     |         |         |       |  |  |  |
| インタラプト転送     | IN   | BUF | 有効      | 受信領域あり  |       |  |  |  |
|              | OUT  | BUF | 有効      | 送信データあり |       |  |  |  |
| アイソクロナス転送    | IN   | BUF | 有効      | *3)     |       |  |  |  |
|              | OUT  | BUF | 有効      | *4)     |       |  |  |  |

表 3.27 トランザクション発行条件

- \*1) 斜線はトークンの発行に関係のない条件であることを示します。
- \*2) 有効はインタラプト転送とアイソクロナス転送において、インターバルカウンタによる転送フレームでのみ発行されることを示します。無効はインターバルカウンタに関わらず発行されることを示します。
- \*3) 受信領域の有無に関わらずトランザクションを発行します。ただし、受信領域が無かった場合は受信データを破棄します。
- \*4) 送信データの有無に関わらずトランザクションを発行します。ただし送信データが無かった場合は、Zero-Length Packet を送信します。

### 3.11.2 転送スケジュール

本コントローラーのフレーム内の転送のスケジューリング方法について説明します。本コントローラーは、SOFを送信後、以下に示す順番で転送を行います。2Port使用する場合、Port0とPort1の通信速度の組み合わせが表 3.4の(3)及び(4)のケースには、スケジューリングを2系統にわけて行いそれぞれの系統で下記(1)-(3)の順序でスケジュールします。Port0とPort1の通信速度の組み合わせが表 3.4の(1)及び(2)のケースにはスケジューリングを1系統で行います。

### (1) 周期的転送の実行

パイプ1 パイプ2 パイプ6 パイプ7 パイプ8 パイプ9の順に検索し、アイソクロナス転送またはインタラプト転送のトランザクション発行が可能なパイプがあれば、トランザクションを発行します。

- (2) コントロール転送のセットアップトランザクション DCPを確認してセットアップトランザクションが可能であれば送信します。
- (3) バルク、コントロール転送データステージ、ステータスステージの実行 以下の順にパイプを検索し、バルク、コントロール転送データステージ、コントロール転送ステータスステージ のトランザクションの発行が可能なパイプがあれば、トランザクションを実行します。

検索順: DCP パイプ1 パイプ2 パイプ3 パイプ4 パイプ5

トランザクションを発行したとき、ペリフェラルからの応答がACKであってもNAKであっても次のパイプのトランザクションに移ります。また、フレーム内に転送を行う時間があれば、(3)を繰り返します。

### 3.11.3 USB通信許可

DVSTCTRレジスタのUACTビットを"1"に設定することにより、SOFまたは  $\mu$  SOFの送信を開始し、トランザクションの発行が可能となります。

UACTビットを"0"に設定すると、SOFまたは  $\mu$  SOFの送信を停止しサスペンドとなります。UACTビットを1 0に設定する場合、次のSOFまたは  $\mu$  SOFを送信してから停止します。



# 3.12 USBコネクタとの接続例

図 3.26にHost Contoller機能選択時の、図 3.23にPeripheral Contoller機能選択時の本コントローラーとUSBコネク タの接続例を示します。



図 3.25 Host Controller選択時USBコネクタ接続例



図 3.26 Peripheral Controller選択時USBコネクタ接続図

# 4電気的特性

# 4.1 絶対最大定格

| 記号                  | 項目              | 定格値                     | 単位 |
|---------------------|-----------------|-------------------------|----|
| VIF                 | IO電源電圧          | -0.3 ~ +4.0             | V  |
| VCC                 | 電源電圧(3.3V系)     | -0.3 ~ +4.0             | V  |
| AVCC                | アナログ電源電圧(3.3V系) | -0.3 ~ +4.0             | V  |
| VBUS                | VBUS入力電圧        | -0.3 ~ <b>+</b> 5.5     | V  |
| V <sub>I</sub> (IO) | システムインタフェース入力電圧 | -0.3 ~ VIF+0.3, VCC+0.3 | V  |
| $V_O(IO)$           | システムインタフェース出力電圧 | -0.3 ~ VIF+0.3, VCC+0.3 | V  |
| Pd                  | 消費電力            | 600                     | mW |
| Tstg                | 保存温度            | -55 ~ <b>+</b> 150      |    |

# 4.2 推奨動作条件

| 記号                    |               | 項目                         |     | 規格値 |          | 単位 |
|-----------------------|---------------|----------------------------|-----|-----|----------|----|
| 10.5                  |               |                            | 最小  | 標準  | 最大       | 半世 |
| VIF                   | IO電源電圧        | 1.8V対応                     | 1.6 | 1.8 | 2.0      | V  |
|                       |               | 3.3V対応                     | 2.7 | 3.3 | 3.6      | V  |
| VCC                   | 電源電圧(3.3V系)   |                            | 3.0 | 3.3 | 3.6      | V  |
| AVCC                  | アナログ電源電圧(3.3  | 3.0                        | 3.3 | 3.6 | V        |    |
| AGND                  | アナログ電源GND     |                            |     | 0   |          | V  |
| GND                   | 電源GND         |                            | 0   |     | V        |    |
| V <sub>I</sub> (IO)   | システムインタフェース   | ス入力電圧                      | 0   |     | VIF, VCC | V  |
| V <sub>I</sub> (VBUS) | 入力電圧 (VBUS入力の | )み)                        | 0   |     | 5.25     | V  |
| V <sub>O</sub> (IO)   | システムインタフェース   | ス出力電圧                      | 0   |     | VIF, VCC | V  |
| Topr                  | 動作周囲温度        | R8A66597FP/BG(標準品)         | -20 | +25 | +85      |    |
|                       |               | R8A66597DFP(広温度オ<br>プション品) | -40 | +25 | +85      |    |
| tr, tf                | 入力上昇、下降時間     | ノーマル入力                     |     |     | 500      | ns |
|                       |               | シュミットトリガ入力                 |     |     | 5        | ms |



# 4.3 電気的特性 (VIF = 2.7~3.6V対応規格)

| ÷10              | 西口             |              | 2845                                                       | 測定条件                                   |         | 規格値        |        | 単位   |
|------------------|----------------|--------------|------------------------------------------------------------|----------------------------------------|---------|------------|--------|------|
| 記号               | 項目             |              | 川川                                                         | 规定示计                                   |         | 標準         | 最大     | 1 単位 |
| V <sub>IH</sub>  | "H"入力電圧        | 注1           | VCC = 3.6V                                                 |                                        | 2.52    |            | 3.6    | V    |
| V <sub>IL</sub>  | "L"入力電圧        | / <u>*</u> ' | VCC                                                        | C = 3.0V                               | 0       |            | 0.9    | V    |
| V <sub>IH</sub>  | "H"入力電圧        | 注2           |                                                            | = 3.6V                                 | 0.7VIF  |            | 3.6    | V    |
| V <sub>IL</sub>  | "L"入力電圧        | /±Z          | VIF                                                        | = 2.7V                                 | 0       |            | 0.3VIF | V    |
| VT+              | 正方向スレッショルド電圧   |              | VIF                                                        | = 3.3V                                 | 1.4     |            | 2.4    | V    |
| VT-              | 負方向スレッショルド電圧   | 注3           |                                                            |                                        | 0.5     |            | 1.65   | V    |
| VTH              | ヒステリシス電圧       |              |                                                            |                                        |         | 8.0        |        | V    |
| $V_{OH}$         | "H"出力電圧        | Xout         | VCC = 3.0V                                                 | $I_{OH} = -50uA$                       | 2.6     |            |        | V    |
| $V_{OL}$         | "L"出力電圧        | Adul         |                                                            | $I_{OL} = 50uA$                        |         |            | 0.4    | V    |
| $V_{OH}$         | "H"出力電圧        | 注4           | VCC = 3.0V                                                 | $I_{OH} = -2mA$                        | VCC-0.4 |            |        | V    |
| $V_{OL}$         | "L"出力電圧        |              |                                                            | $I_{OL} = 2mA$                         |         |            | 0.4    | V    |
| V <sub>OH</sub>  | "H"出力電圧        | 注5           | VIF = 2.7V                                                 | $I_{OH} = -4mA$                        | VIF-0.4 |            |        | V    |
| $V_{OL}$         | "L"出力電圧        |              |                                                            | $I_{OL} = 4mA$                         |         |            | 0.4    | V    |
| V <sub>OH</sub>  | "H"出力電圧        | 注6           | VIF = 2.7V                                                 | $I_{OH} = -2mA$                        | VIF-0.4 |            |        | V    |
| V <sub>OL</sub>  | "L"出力電圧        |              |                                                            | $I_{OL} = 2mA$                         |         |            | 0.4    | V    |
| VT+              | 正方向スレッショルド電圧   | VBUS         | VCC = 3.3V                                                 |                                        | 1.4     |            | 2.4    | V    |
| VT-              | 負方向スレッショルド電圧   | VBUS         |                                                            |                                        | 0.5     |            | 1.65   | V    |
| I <sub>IH</sub>  | "H"入力電流        |              | VIF,VCC                                                    | $V_I = VIF, VCC$                       |         |            | 10     | uA   |
| I <sub>IL</sub>  | "L"入力電流        |              | = 3.6V                                                     | $V_I = GND$                            |         |            | -10    | uA   |
| l <sub>ozh</sub> | オフ状態"H"出力電流    | 注7           | VIF = 3.6V                                                 | V <sub>O</sub> = VIF                   |         |            | 10     | uA   |
| I <sub>OZL</sub> | オフ状態"L"出力電流    |              |                                                            | $V_O = GND$                            |         |            | -10    | uA   |
| Rdv              | プルダウン抵抗        | VBUS         |                                                            |                                        |         | 500        |        | k    |
| Icc(A)           | HS動作時平均電源電流    | 注8           | VIF, VCC,                                                  | = 48MHz<br>AVCC = 3.6V<br>-0 = HS動作時   |         | 70         |        | mA   |
| Icc(A)           | FS/LS動作時平均電源電流 | 注8           | VIF, VCĆ,                                                  | = 48MHz<br>AVCC = 3.6V<br>) = FS/LS動作時 |         | 22         |        | mA   |
| Icc(S)           | 静止時電源電流        | 注8           | USBサス                                                      | ler機能選択時の<br>スペンド状態<br>VIF = 3.6V      |         | 0.15       |        | mA   |
|                  |                |              | Peripheral Controller機能選択<br>時のUSBサスペンド状態<br>但し、VIF = 3.6V |                                        |         | 0.35       |        | mA   |
|                  |                |              | 但し、'                                                       | ルデタッチ状態<br>VIF = 3.6V                  |         | 0.15.      |        | mA   |
|                  |                |              | VCC,AVCC=                                                  | =0V, VIF = 3.6V                        |         | 0.01<br>以下 |        | mA   |
| $C_{IN}$         | 端子容量(入力)       |              |                                                            |                                        |         | 7          |        | pF   |
| C <sub>OUT</sub> | 端子容量(出力/入出力)   |              |                                                            |                                        |         | 7          |        | pF   |

注1:Xin、OVCUR1、ID0、OVCUR0A、OVCUR0B入力端子

注2: MPBUS、A7-1入力端子、及び、DEND0-1\_N、SD7-0、D15-0入出力端子

注3: DACK0-1\_N、RST\_N、RD\_N、WR0-1\_N、CS\_N、入力端子

注4:VBOUT0-1、EXTLP0出力端子

注5: DREQ0-1\_N出力端子、及び、DEND0-1\_N、SD7-0、D15-0入出力端子

注6:INT\_N、SOF\_N出力端子

注7: DEND0-1\_N、SD7-0、D15-0入出力端子 注8:電源電流はVIF、VCC、AVCCの合計電流



# 4.4 電気的特性 (VIF = 1.6~2.0V対応規格)

| 記号               | 语口                 |      | 測定条件          |                             |         | 単位   |        |       |
|------------------|--------------------|------|---------------|-----------------------------|---------|------|--------|-------|
| 記写               | 項目                 |      | 洪山/           | <b>上</b> 宗什                 | 最小      | 標準   | 最大     | 単111  |
| V <sub>IH</sub>  | "H"入力電圧            | 注1   | VCC           | VCC = 3.6V                  |         |      | 3.6    | V     |
| $V_{IL}$         | "L"入力電圧            | 注!   | VCC           | C = 3.0V                    | 0       |      | 0.9    | V     |
| $V_{IH}$         | "H"入力電圧            | 注2   | VIF           | = 2.0V                      | 0.7VIF  |      | 3.6    | V     |
| $V_{IL}$         | "L"入力電圧            | 注之   | VIF           | = 1.6V                      | 0       |      | 0.3VIF | V     |
| VT+              | 正方向スレッショルド電圧       |      | VIF           | = 1.8V                      | 0.7     |      | 1.4    | V     |
| VT-              | 負方向スレッショルド電圧       | 注3   |               |                             | 0.2     |      | 0.8    | V     |
| VTH              | ヒステリシス電圧           |      |               |                             |         | 0.5  |        | V     |
| V <sub>OH</sub>  | "H"出力電圧            | Xout | VCC = 3.0V    | $I_{OH} = -50uA$            | 2.6     |      |        | V     |
| V <sub>OL</sub>  | "L"出力電圧            | Aout |               | $I_{OL} = 50uA$             |         |      | 0.4    | V     |
| VoH              | "H"出力電圧            | 注4   | VCC = 3.0V    | $I_{OH} = -2mA$             | VCC-0.4 |      |        | V     |
| $V_{OL}$         | "L"出力電圧            |      |               | $I_{OL} = 2mA$              |         |      | 0.4    | V     |
| V <sub>OH</sub>  | "H"出力電圧            | 注5   | VIF = 1.6V    | $I_{OH} = -4mA$             | VIF-0.4 |      |        | V     |
| V <sub>OL</sub>  | "L"出力電圧            |      |               | $I_{OL} = 4mA$              |         |      | 0.4    | V     |
| V <sub>OH</sub>  | "H"出力電圧            | 注6   | VIF = 1.6V    | $I_{OH} = -2mA$             | VIF-0.4 |      |        | V     |
| V <sub>OL</sub>  | "L"出力電圧            |      |               | $I_{OL} = 2mA$              |         |      | 0.4    | V     |
| VT+              | 正方向スレッショルド電圧       | VBUS | VCC = 3.3V    |                             | 1.4     |      | 2.4    | V     |
| VT-              | 負方向スレッショルド電圧       | VBUS |               |                             | 0.5     |      | 1.65   | V     |
| I <sub>IH</sub>  | "H"入力電流            |      | VIF = 2.0V    | $V_I = VIF, VCC$            |         |      | 10     | uA    |
| I <sub>IL</sub>  | "L"入力電流            |      | VCC = 3.6V    | $V_I = GND$                 |         |      | -10    | uA    |
| l <sub>ozh</sub> | オフ状態"H"出力電流        | 注7   | VIF = 2.0V    | $V_O = VIF$                 |         |      | 10     | uA    |
| I <sub>OZL</sub> | オフ状態"L"出力電流        |      |               | $V_0 = GND$                 |         |      | -10    | uA    |
| Rdv              | プルダウン抵抗            | VBUS |               |                             |         | 500  |        | k     |
| Icc(A)           | HS動作時平均電源電流        | 注8   | · ,           | = 48MHz                     |         | 70   |        | mA    |
|                  |                    |      |               | C,AVCC = 3.6V<br>-0 = HS動作時 |         |      |        |       |
| Icc(A)           | FS/LS動作時平均電源電流     | 注8   |               | = 48MHz                     |         | 22   |        | mA    |
| ( )              |                    | ,—-  |               | C,AVCC = 3.6V               |         |      |        |       |
|                  |                    |      |               | ) = FS/LS動作時                |         |      |        |       |
| Icc(S)           | 静止時電源電流            | 注8   |               | ler機能選択時の                   |         | 0.15 |        | mA    |
|                  |                    |      |               | ペンド状態                       |         |      |        |       |
|                  |                    |      |               | VIF = 2.0V                  |         | 0.05 |        |       |
|                  |                    |      |               | ontroller機能選択               |         | 0.35 |        | mA    |
|                  |                    |      | -             | スペンド状態                      |         |      |        |       |
|                  |                    |      |               | /IF = 2.0 V                 |         | 0.15 |        | m A   |
|                  |                    |      |               | ルデタッチ状態<br>VIF = 2.0V       |         | 0.15 |        | mA    |
|                  |                    |      | VCC,AVCC=0    |                             |         | 0.01 |        | mA    |
|                  |                    |      | V 00,A V 00=0 | v, vir = 2.0v               |         | 以下   |        | 111/4 |
| C <sub>IN</sub>  | 端子容量(入力)           |      |               |                             |         | 7    |        | pF    |
| C <sub>OUT</sub> | 端子容量(出力/入出力)       |      |               |                             |         | 7    |        | pF    |
|                  | OVCUP1 ID0 OVCUP0A |      |               |                             |         |      |        | 1 1 1 |

注1:Xin、OVCUR1、ID0、OVCUR0A、OVCUR0B入力端子

注2: MPBUS、A7-1入力端子、及び、DEND0-1\_N、SD7-0、D15-0入出力端子

注3: DACK0-1\_N、RST\_N、RD\_N、WR0-1\_N、CS\_N、入力端子

注4:VBOUT0-1、EXTLP0出力端子

注5: DREQ0-1\_N出力端子、及び、DEND0-1\_N、SD7-0、D15-0入出力端子

注6:INT\_N、SOF\_N出力端子

注7: DEND0-1\_N、SD7-0、D15-0入出力端子 注8:電源電流はVIF、VCC、AVCCの合計電流



#### 測定回路 4.5

#### USBバッファ部以外の端子 4.5.1



#### USBパッファ部(Peripheral Controller機能時、Full-Speed) 4.5.2



#### USBパッファ部(Hi-Speed) 4.5.3



# 4.6 電気的特性 (D+/D-)

# 4.6.1 DC特性

| 記号                  | 項目                                                                                               | 測定条件       |         |               |       | 単   |       |    |
|---------------------|--------------------------------------------------------------------------------------------------|------------|---------|---------------|-------|-----|-------|----|
| 한도                  | <b>以</b> 日                                                                                       |            |         |               | 最小    | 標準  | 最大    | 位  |
| $R_{REF}$           | 基準抵抗                                                                                             |            |         |               | 5.544 | 5.6 | 5.656 | k  |
| $R_o$               | FSドライバ                                                                                           | HS         | 動作時     |               | 40.5  | 45  | 49.5  |    |
|                     | 出力インピーダンス                                                                                        | FS         | 動作時     |               | 28    | 36  | 44    |    |
| $R_{pu}$            | D+,D-プルアップ抵抗                                                                                     | アー         | イドル時    |               | 0.9   |     | 1.575 | k  |
|                     | (Peripheral Controller機能選択時)                                                                     | 送          | 受信時     |               | 1.425 |     | 3.09  | k  |
| $R_{pd}$            | D+,D-プルダウン抵抗                                                                                     |            |         |               | 14.25 |     | 24.80 | k  |
|                     | (Host Controller機能選択時)                                                                           |            |         |               |       |     |       |    |
|                     | peed時の入力特性                                                                                       |            |         |               |       |     |       |    |
| $V_{IH}$            | "H"入力電圧                                                                                          |            |         |               | 2.0   |     |       | V  |
| $V_{IL}$            | "L"入力電圧                                                                                          |            |         |               |       |     | 8.0   | V  |
| $V_{DI}$            | 差分入力感度                                                                                           | (D         | +)-(D-) |               | 0.2   |     |       | V  |
| $V_{CM}$            | 差分コモンモード範囲                                                                                       |            |         |               | 8.0   |     | 2.5   | V  |
| Full/Low-S          | peed時の出力特性                                                                                       |            |         |               |       |     |       |    |
| $V_{OL}$            | "L"出力電圧                                                                                          | VCC = 3.0V |         | のRLから<br>3.6V |       |     | 0.3   | V  |
| $V_{OH}$            | "H"出力電圧                                                                                          |            |         | のRLから<br>GND  | 2.8   |     | 3.6   | V  |
| $V_{SE}$            | シングルエンディッド<br>レシーバスレッショルド電圧                                                                      |            |         |               | 0.8   |     | 2.0   | V  |
| $V_{ORS}$           | 出力信号クロスオーバー<br>電圧                                                                                |            |         |               | 1.3   |     | 2.0   | V  |
| Hi-Speed₽           | -<br>-<br>-<br>-<br>-<br>-<br>-<br>-<br>-<br>-<br>-<br>-<br>-<br>-<br>-<br>-<br>-<br>-<br>-      | •          |         |               |       | I.  | 1     |    |
| V <sub>HSSQ</sub>   | スケルチ検出スレッショルド<br>電圧 (差動電圧)                                                                       |            |         |               | 100   |     | 150   | mV |
| V <sub>HSCM</sub>   | コモンモード電圧範囲                                                                                       |            |         |               | -50   |     | 500   | mV |
|                     | -<br>・<br>・<br>・<br>・<br>・<br>・<br>・<br>・<br>・<br>・<br>・<br>・<br>・<br>・<br>・<br>・<br>・<br>・<br>・ |            |         |               |       | ı   |       | •  |
| V <sub>HSOI</sub>   | アイドル状態                                                                                           |            |         |               | -10.0 |     | 10    | mV |
| V <sub>HSOH</sub>   | "H"出力電圧                                                                                          |            |         |               | 360   |     | 440   | mV |
| V <sub>HSOL</sub>   | "L"出力電圧                                                                                          |            |         |               | -10.0 |     | 10    | mV |
| V <sub>CHIRPJ</sub> | Chirp J出力電圧(差分)                                                                                  |            |         |               | 700   |     | 1100  | mV |
| V <sub>CHIRPK</sub> | Chirp K出力電圧(差分)                                                                                  |            |         |               | -900  |     | -500  | mV |

# 4.6.2 AC特性 (Full-Speed)

| 記号   | 項目             | 測定条件                  |       | 規格値 |    |        |    |
|------|----------------|-----------------------|-------|-----|----|--------|----|
| ID 7 | ルウ             |                       |       |     | 標準 | 最大     | 位  |
| Tr   | 立ち上がり時間        | データ信号:振幅の10% 90% CL=5 | )pF 4 | 1   |    | 20     | ns |
| Tf   | 立ち下がり時間        | データ信号:振幅の90% 10% CL=5 | )pF 4 | 4   |    | 20     | ns |
| TRFM | 立ち上がり/立ち下がり時間比 | tr/tf                 | 9     | 0   | •  | 111.11 | %  |

#### AC特性 (Low-Speed) 4.6.3

| 記号   | 項目             | 測定条件             | 規格値 |    |     | 単  |
|------|----------------|------------------|-----|----|-----|----|
| 記り   | - 「            | <b>加足</b> 赤什     | 最小  | 標準 | 最大  | 位  |
| Tr   | 立ち上がり時間        | データ信号:振幅の10% 90% | 75  |    | 300 | ns |
| Tf   | 立ち下がり時間        | データ信号:振幅の90% 10% | 75  |    | 300 | ns |
| TRFM | 立ち上がり/立ち下がり時間比 | tr/tf            | 80  |    | 125 | %  |



# 4.7 電源シーケンス・リセットタイミング

#### 4.7.1 電源シーケンス



注: VCC, AVCCの投入・切断のタイミングは同時投入・同時切断を推奨します。 VIFの投入タイミングは、VCC, AVCCと同時、または、VCC, AVCCよりも先の投入を推奨します。 VIFの切断タイミングは、VCC, AVCCと同時、または、VCC, AVCCよりも後の切断を推奨します。 RST\_Nによるリセットは必須です。本シーケンスを満たせない場合、次項のリセットタイミングに よる操作を行っても正常動作は保証されません。

#### 4.7.2 リセットタイミング (VCC-ON状態)



# 4.8 スイッチング特性(VIF = 2.7~3.6V、又は1.6~2.0V)

| 記号                   | 項目                                                                         | 測定条件、   |     | 規格値 |     | 単位 | 参照   |
|----------------------|----------------------------------------------------------------------------|---------|-----|-----|-----|----|------|
|                      |                                                                            | その他     | 最小  | 標準  | 最大  | 丰山 | 番号   |
| ta (A)               | アドレスアクセス時間                                                                 | CL=50pF |     |     | 30  | ns | 1    |
| tv (A)               | アドレス後データ有効時間                                                               | CL=10pF | 2   |     |     | ns | 2    |
| ta (CTRL - D)        | コントロール後データアクセス時間                                                           | CL=50pF |     |     | 30  | ns | 3    |
| tv (CTRL - D)        | コントロール後データ有効時間                                                             | CL=10pF | 2   |     |     | ns | (4)  |
| ten (CTRL - D)       | コントロール後データ出力イネーブル時間                                                        | -       | 2   |     |     | ns | (5)  |
| tdis (CTRL - D)      | コントロール後データ出力ディセーブル時<br>間                                                   | CL=50pF |     |     | 30  | ns | 6    |
| ta (CTRL - DV)       | スプリットバス (DMA Interface) Obus=0の<br>時、コントロール後データアクセス時間                      | CL=30pF |     |     | 30  | ns | 9    |
| tv (CTRL – DV)       | スプリットバス (DMA Interface) Obus=0の<br>時、コントロール後データ有効時間                        | CL=10pF | 2   |     |     | ns | 10   |
| ta (CTRL - DendV)    | CPUバス及びスプリットバス(DMA<br>Interface) Obus=0の時、コントロール後<br>DEND出力アクセス時間          | CL=30pF |     |     | 30  | ns | 11)  |
| tv (CTRL - DendV)    | CPUバス及びスプリットバス(DMA<br>Interface) Obus=0の時、コントロール後<br>DEND出力有効時間            | CL=10pF | 2   |     |     | ns | 12   |
| ta (CTRL - Dend)     | スプリットバス(DMA Interface) Obus=1の<br>時、コントロール後DEND出力アクセス時間                    | CL=30pF |     |     | 30  | ns | 13)  |
| tv (CTRL – Dend)     | スプリットバス(DMA Interface) Obus=1の<br>時、コントロール後DEND出力有効時間                      | CL=10pF | 2   |     |     | ns | 14)  |
| ten (CTRL – Dend)    | スプリットバス(DMA Interface) Obus=1の<br>時、コントロール後DEND出力イネーブル時<br>間               |         | 2   |     |     | ns | (15) |
| tdis (CTRL-Dend)     | スプリットバス(DMA Interface) Obus=1の<br>時、コントロール後DEND出力ディセーブル<br>時間              | CL=30pF |     |     | 30  | ns | 16)  |
| tdis (CTRL – Dreq)   | コントロール後DREQディセーブル時間                                                        |         |     |     | 30  | ns | (17) |
| tdis (CTRLH -Dreq)   | DEND入力に書き込み終了後、コントロール<br>終了後DREQディセーブル時間                                   |         |     |     | 30  | ns | 18)  |
| ten (CTRL – Dreq)    | コントロール後DREQイネーブル時間                                                         |         | 20  |     | 70  | ns | (19) |
| twh (Dreq)           | DREQ出力"H"パルス幅                                                              |         | 20  |     | 50  | ns | (20) |
| td (CTRL - INT)      | INT出力ネゲート遅延時間                                                              | -       |     |     | 250 | ns | (21) |
| twh (INT)            | INT出力"H"パルス幅                                                               | 1       | 650 |     |     | ns | 22   |
| td (DREQ - DV)       | スプリットバス (DMA Interface) Obus=0の時、DREQアサート開始後データアクセス時間                      |         |     |     | 0   | ns | 23   |
| td (Dreq - DendV)    | スプリットバス(DMA Interface) Obus=0の<br>時またはCPUバス1,2の時、DREQアサート<br>開始後DEND出力確定時間 |         |     |     | 0   | ns | 24)  |
| tdis (PCTRLH - Dreq) | 前回コントロール終了後DREQディセーブル時間                                                    |         |     |     | 70  | ns | 25   |

凡例 ta:アクセス時間、tv:有効時間、ten:出力イネーブル時間、tdis:出力ディセーブル時間

(A):アドレス、(D):データ、(Dend): DiEND\_N、(Dreq): DiREQ\_N、(CTRL): コントロール、(V): Obus=0

# 4.9 タイミング必要条件(VIF = 2.7~3.6V、又は1.6~2.0V)

| 記号                                   | 項目                                |                                                                 | 測定条件、        | 規格値      |    |    | 参照         |             |
|--------------------------------------|-----------------------------------|-----------------------------------------------------------------|--------------|----------|----|----|------------|-------------|
|                                      | フいしっこくし                           | <br>セットアップ時間                                                    | その他          | 最小       | 標準 | 最大 | 単位         | 番号          |
| tsuw (A)                             |                                   | CL=50pF                                                         | 10           |          |    | ns | <u>(0)</u> |             |
| tsur (A)                             | アドレスリード                           |                                                                 | 0            |          |    | ns | 81)        |             |
| tsu (A - ALE)                        | ップ時間                              | バスの時、アドレスセットア                                                   |              | 10       |    |    | ns         | \$2         |
| thw (A)                              | アドレスライト                           |                                                                 |              | 0        |    |    | ns         | \$3         |
| thr (A)                              | アドレスリード                           | ホールド時間                                                          |              | 10       |    |    | ns         | 84          |
| th (A - ALE)                         | マルチプレクス<br>時間                     | バスの時、アドレスホールド                                                   |              | 0        |    |    | ns         | \$5         |
| tw (ALE)                             | マルチプレクス                           | バスの時、ALEパルス幅                                                    |              | 10       |    |    | ns         | \$6         |
| tdwr (ALE - CTRL)                    | マルチプレクス<br>レイ時間                   | バスの時、ライト/リードディ                                                  |              | 7        |    |    | ns         | \$7         |
| trec (ALE)                           | マルチプレクス                           | バス時、ALEリカバリ時間                                                   |              | 0        |    |    | ns         | \$8         |
| tw (CTRL)                            | コントロールパ                           | ルス幅 (ライト)                                                       |              | 30       |    |    | ns         | <b>8</b> 9  |
| trec (CTRL)                          | コントロール<br>リカバリ時間                  | DMAインタフェース サイ<br>クルスチール使用時                                      |              | 30       |    |    | ns         | 40          |
|                                      | (FIFO)                            | 上記以外                                                            |              | 12       |    |    | ns         |             |
| trecr (CTRL)                         | コントロールリ                           | カバリ時間 (REG)                                                     |              | 12       |    |    | ns         | <b>4</b> 1  |
| twr (CTRL)                           | コントロールパ                           | ルス幅 (リード)                                                       |              | 30       |    |    | ns         | 42          |
| tsu (D)                              | データセットア                           | ップ時間                                                            |              | 10       |    |    | ns         | 43          |
| th (D)                               | データホールド                           | 時間                                                              |              | 0        |    |    | ns         | (4)         |
| tsu (Dend)                           | DEND入力セッ                          | トアップ時間                                                          |              | 10       |    |    | ns         | 45          |
| th (Dend)                            | DEND入力ホー                          | ルド時間                                                            |              | 0        |    |    | ns         | (46)        |
| tw (cycle1)                          | FIFO・レジス<br>タアクセスサ<br>イクル時間       | セパレートバスの時<br>8/16ビットFIFOアクセス<br>(47-2)該当のケース以外)<br>マルチプレクスバスの時、 |              | 60       |    |    | ns         | <b>47-1</b> |
|                                      |                                   | 8/16ビットFIFOアクセス                                                 |              |          |    |    |            |             |
| tw (cycle2)                          | DMAインタフ                           | 8ビットFIFOアクセス                                                    |              | 30       |    |    | ns         | 47-2        |
|                                      | ェース DACKi_Nのみ 使用時FIFOア クセスサイク ル時間 |                                                                 |              | 50       |    |    | ns         |             |
| tw (CTRL_B)                          | バースト転送<br>時コントロー                  | スプリットバス使用時で<br>Obus=0の時                                         |              | 12       |    |    | ns         | 48          |
|                                      | ルパルス幅                             | スプリットバス使用時で<br>Obus=1の時*1                                       |              | 30       |    |    | ns         |             |
|                                      |                                   | CPUバスを使用したDMA<br>転送時                                            |              | 30       |    |    | ns         | =           |
| trec (CTRL_B)                        | バースト転送時                           |                                                                 | 12           |          |    | ns | 49         |             |
| tsud (A)                             | DMAアドレスラ                          |                                                                 | 10           |          |    | ns | 50         |             |
| thd (A)                              | DMAアドレスラ                          |                                                                 | 0            |          |    | ns | 51         |             |
| tw (RST)                             | リセットパルス                           |                                                                 | 100          |          |    | ns | 52         |             |
| tst (RST)                            | リセット後コン                           | トロールスタート幅時間                                                     |              | 500      |    |    | ns         | 53          |
| ・・・・・・・・・・・・・・・・・・・・・・・・・・・・・・・・・・・・ |                                   | 間、tsur:リードセットアップ                                                | <u> </u><br> | <u> </u> |    |    | L          | 30          |

凡例 tsuw:ライトセットアップ時間、tsur:リードセットアップ時間、tsu:セットアップ時間 thw:ライトホールド時間、thr:リードホールド時間、th:ホールド時間、tw:パルス幅、twr:リードパルス幅

tdwr:リードライトディレイ時間、trec:リカバリ時間、trecr:レジスタリカバリ時間

tsud: DMAセットアップ時間、thd: DMAホールド時間、tst: スタート時間

(A): アドレス、(D): データ、(CTRL): コントロール、(CTRL\_B): バーストコントロール、(ALE): ALE



# 4.10 タイミング図一覧

# 4.10.1 レジスタアクセスタイミング図一覧

| バス仕様      | アクセス | R/W   | INDEX    | 備考     |
|-----------|------|-------|----------|--------|
| セパレートバス   | CPU  | WRITE | 4.11.1.1 | CPUバス0 |
| セパレートバス   | CPU  | READ  | 4.11.1.2 | CPUバス0 |
| マルチプレクスバス | CPU  | WRITE | 4.11.2.1 | CPUバス0 |
| マルチプレクスバス | CPU  | READ  | 4.11.2.2 | CPUバス0 |

# 4.10.2 FIFOポートアクセスタイミング図一覧

| アクセス | バスI/F仕様  | 動作時のI/F仕様 | OFORM<br>ビット設<br>定値 | OBUS<br>ビット<br>设定値 | ₹/W   | <b>備考</b>  | NDEX        |
|------|----------|-----------|---------------------|--------------------|-------|------------|-------------|
| CPU  | CPUバス0   | セパレートバス   | _                   |                    | WRITE | -          |             |
| CPU  | CPUバス0   | セパレートバス   | -                   |                    | READ  | -          | 4.11.1.2    |
| CPU  | CPUバス0   | マルチプレクスバス | -                   |                    | WRITE | -          | 4.11.2.1    |
| CPU  | CPUバス0   | マルチプレクスバス | -                   |                    | READ  | -          | 4.11.2.2    |
| DMA  | CPUバス2   | ACK+RD/WR | 010                 |                    | WRITE | サイクルスチール転送 | 4.11.3.1 *1 |
| DMA  | CPUバス2   | ACK+RD/WR | 010                 |                    | READ  | サイクルスチール転送 | 4.11.3.2 *1 |
| DMA  | CPUバス1   | セパレートバス   | 000                 |                    | WRITE | サイクルスチール転送 | 4.11.3.3    |
| DMA  | CPUバス1   | セパレートバス   | 000                 |                    | READ  | サイクルスチール転送 | 4.11.3.4    |
| DMA  | SPLITバス2 | ACKのみ     | 100                 | 1                  | WRITE | サイクルスチール転送 | 4.11.3.5 *1 |
| DMA  | SPLITバス2 | ACKのみ     | 100                 | 1                  | READ  | サイクルスチール転送 | 4.11.3.6 *1 |
| DMA  | SPLITバス2 | ACKのみ     | 100                 | 0                  | WRITE | サイクルスチール転送 | 4.11.3.5 *1 |
| DMA  | SPLITバス2 | ACKのみ     | 100                 | 0                  | READ  | サイクルスチール転送 | 4.11.3.7 *1 |
| DMA  | CPUバス3   | ACKのみ     | 011                 |                    | WRITE | サイクルスチール転送 | 4.11.3.8 *1 |
| DMA  | CPUバス3   | ACKのみ     | 011                 |                    | READ  | サイクルスチール転送 | 4.11.3.9 *1 |
| DMA  | CPUバス1   | マルチプレクスバス | 000                 |                    | WRITE | サイクルスチール転送 | 4.11.4.1    |
| DMA  | CPUバス1   | マルチプレクスバス | 000                 |                    | READ  | サイクルスチール転送 | 4.11.4.2    |
| DMA  | CPUバス2   | ACK+RD/WR | 010                 |                    | WRITE | バースト転送     | 4.11.5.1 *1 |
| DMA  | CPUバス2   | ACK+RD/WR | 010                 |                    | READ  | バースト転送     | 4.11.5.2 *1 |
| DMA  | CPUバス1   | セパレートバス   | 000                 |                    | WRITE | バースト転送     | 4.11.5.3    |
| DMA  | CPUバス1   | セパレートバス   | 000                 |                    | READ  | バースト転送     | 4.11.5.4    |
| DMA  | SPLITバス2 | ACKのみ     | 100                 | 1                  | WRITE | バースト転送     | 4.11.5.5*1  |
| DMA  | SPLITバス2 | ACKのみ     | 100                 | 1                  | READ  | バースト転送     | 4.11.5.6 *1 |
| DMA  | SPLITバス2 | ACKのみ     | 100                 | 1                  | WRITE | バースト転送     | 4.11.5.5_*1 |
| DMA  | SPLITバス2 | ACKのみ     | 100                 | 1                  | READ  | バースト転送     | 4.11.5.6*1  |
| DMA  | SPLITバス2 | ACKのみ     | 100                 | 0                  | WRITE | バースト転送     | 4.11.5.5_*1 |
| DMA  | SPLITバス2 | ACKのみ     | 100                 | 0                  | READ  | バースト転送     | 4.11.5.7_*1 |
| DMA  | CPUバス3   | ACKのみ     | 011                 |                    | WRITE | バースト転送     | 4.11.5.8_*1 |
| DMA  | CPUバス3   | ACKのみ     | 011                 |                    | READ  | バースト転送     | 4.11.5.9 *1 |
| DMA  | CPUバス1   | マルチプレクスバス | 000                 |                    | WRITE | バースト転送     | 4.11.6.1    |
| DMA  | CPUバス1   | マルチプレクスバス | 000                 |                    | READ  | バースト転送     | 4.11.6.2    |

<sup>\*1)</sup>アドレス信号を未使用のため、セパレートバスもマルチプレクスバスも同じタイミングになります。

読み書きタイミングはコントロール信号で行われます。コントロール信号が複数信号の組み合わせで構成される場合は立ち下がリエッジからの規格は、アクティブの遅い信号変化からが有効です。

立ち上がりエッジからの規格は、インアクティブの早い信号変化からが有効です。



# 4.11 タイミング図

# 4.11.1 CPUアクセスタイミング (セパレートパス設定時)

# 4.11.1.1 CPU アクセス Write タイミング (セパレートパス設定時)



### 4.11.1.2 CPU アクセス Read タイミング (セパレートバス設定時)



注1-1:書き込み時のコントロール信号はCS\_N、WR1\_N、WR0\_Nの組み合わせになります。

注1-2:読み出し時のコントロール信号はCS\_N、RD\_Nの組み合わせになります。

注1-3: CS\_Nが立ち上がるタイミングと同時にRD\_NやWR0\_N、WR1\_Nを立ち下げないでください。RD\_NまたはWR0\_N、 WR1\_Nが立ち上がるタイミングと同時にCS\_Nを立ち下げないでください。上記の場合、10ns以上の間隔を空ける必要があり ます。

# 4.11.2 CPUアクセスタイミング (マルチプレクスバス設定時)

# 4.11.2.1 CPU アクセス Write タイミング (マルチプレクスパス設定時)



### 4.11.2.2 CPU アクセス Read タイミング (マルチプレクスバス設定時)



注2-1:書き込み時のコントロール信号はCS\_N、WR1\_N、WR0\_Nの組み合わせになります。

注2-2:読み出し時のコントロール信号はCS\_N、RD\_Nの組み合わせになります。

page 167 of 183

注2-3: CS\_Nが立ち上がるタイミングと同時にRD\_NやWR0\_N、WR1\_Nを立ち下げないでください。RD\_NまたはWR0\_N、 WR1\_Nが立ち上がるタイミングと同時にCS\_Nを立ち下げないでください。上記の場合、10ns以上の間隔を空ける必要があり ます。

### 4.11.3 DMAアクセスタイミング (サイクルスチール転送、セパレートバス設定時)

### 4.11.3.1 DMA サイクルスチール転送 Write タイミング (CPU パスアドレス未使用: DFORM=010)



# 4.11.3.2 DMA サイクルスチール転送 Read タイミング (CPU パスアドレス未使用: DFORM=010)



# 4.11.3.3 DMA サイクルスチール転送 Write タイミング (CPU セパレートバス設定: DFORM=000)



### 4.11.3.4 DMA サイクルスチール転送 Read タイミング (CPU セパレートバス設定: DFORM=000)



# 4.11.3.5 DMA サイクルスチール転送 Write タイミング (SPLIT パス: DFORM=100, OBUS=1/0)



# 4.11.3.6 DMA サイクルスチール転送 Read タイミング (SPLIT パス: DFORM=100, OBUS=1)



# 4.11.3.7 DMA サイクルスチール転送 Read タイミング (SPLIT パス: DFORM=100, OBUS=0)



# 4.11.3.8 DMA サイクルスチール転送 Write タイミング (CPU パスアドレス未使用: DFORM=011)



# 4.11.3.9 DMA サイクルスチール転送 Read タイミング (CPU パスアドレス未使用: DFORM=011)



注3-1: DREQi\_N (i=0、1)のインアクティブ条件は、コントロール信号です。次のDMA転送がある場合にDREQi\_Nがアクティブとなるまでの時間は、twh (Dreq)、またはten(CTRL-Dreq)の遅い規格が有効です。

注3-2:書き込み時のコントロール信号はDACKi\_N、WR1\_N、WR0\_Nの組み合わせになります。

注3-3:読み出し時のコントロール信号はDACKi\_N、RD\_Nの組み合わせになります。

注3-4:書き込み時のコントロール信号はDACKO、DSTRBO\_Nの組み合わせになります。

注3-5:書き込み時のコントロール信号はCS\_N、WR0\_N、WR1\_Nの組み合わせになります。

注3-6:読み出し時のコントロール信号はCS\_N、RD\_Nの組み合わせになります。

 $注3-7: CS_N$ が立ち上がるタイミングと同時にRD\_NやWR0\_N、WR1\_Nを立ち下げないでください。RD\_NまたはWR0\_N、WR1\_Nが立ち上がるタイミングと同時にCS\_Nを立ち下げないでください。上記の場合、10ns以上の間隔を空ける必要があります。

注3-8: DACKi\_Nが立ち上がる(または立ち下がる)タイミングと同時にRD\_NやWR0\_N、WR1\_Nを立ち下げないでください。 RD\_NまたはWR0\_N、WR1\_Nが立ち上がるタイミングと同時にDACKを立ち下げ(または立ち上げ)ないでください。上記の場合、10ns以上の間隔を空ける必要があります。

注3-9: 受信データが1バイトしかない場合、データ出力確定時間は"(23) td(DREQ-DV)"、DEND信号出力確定時は"(24) td(DREQ-DendV)"となります。

注3-10:次のDMA転送がある場合にDREQi\_N (i=0、1)がアクティブとなるまでの時間は、tdis (CTRL-Dreq)、またはtdis (PCTRLH - Dreq)の遅い規格が有効です。



### 4.11.4 DMAアクセスタイミング(サイクルスチール転送、マルチプレクスバス設定時)

# 4.11.4.1 DMA サイクルスチール転送 Write タイミング (CPU マルチプレクスバス設定: DFORM=000)



### 4.11.4.2 DMA サイクルスチール転送 Read タイミング ( CPU マルチプレクスパス設定: DFORM=000 )



注4-1:書き込み時のコントロール信号はCS\_N、WR0\_N、WR1\_Nの組み合わせになります。

注4-2:読み出し時のコントロール信号はCS N、RD Nの組み合わせになります。

注4-3: CS Nが立ち上がるタイミングと同時にRD NやWRO N、WR1 Nを立ち下げないでください。RD NまたはWRO N、 WR1\_Nが立ち上がるタイミングと同時にCS\_Nを立ち下げないでください。上記の場合、10ns以上の間隔を空ける必要があり ます。

注4-4: 受信データが1バイトしかない場合、DEND信号出力確定時は"(24) td(DREQ-DendV)"となります。

注4-5:次のDMA転送がある場合にDREQi\_N (i=0、1)がアクティブとなるまでの時間は、tdis (CTRL-Dreq)、またはtdis (PCTRLH - Dreg)の遅い規格が有効です。

# 4.11.5 DMAアクセスタイミング (パースト転送、セパレートバス設定時)

# 4.11.5.1 DMA パースト転送 Write タイミング (CPU パスアドレス未使用: DFORM=010)



# 4.11.5.2 DMA パースト転送 Read タイミング (CPU パスアドレス未使用: DFORM=010)



# 4.11.5.3 DMA パースト転送 Write タイミング (セパレートパス設定: DFORM=000)



# 4.11.5.4 DMA パースト転送 Read タイミング (セパレートバス設定: DFORM=000)



# 4.11.5.5 DMA パースト転送 Write タイミング (SPLIT パス: DFORM=100, OBUS=1/0)



# 4.11.5.6 DMA パースト転送 Read タイミング (SPLIT パス: DFORM=100, OBUS=1)



# 4.11.5.7 DMA パースト転送 Read タイミング (SPLIT パス: DFORM=100, OBUS=0)



### 4.11.5.8 DMA パースト転送 Write タイミング (CPU パスアドレス未使用: DFORM=011)



### 4.11.5.9 DMA パースト転送 Read タイミング (CPU パスアドレス未使用: DFORM=011)



注5-1: 書き込み時のコントロール信号はDACKi\_N(i=0、1)、WR0\_N、WR1\_Nの組み合わせになります。

注5-2:読み出し時のコントロール信号はDACKi\_N、RD\_Nの組み合わせになります。

注5-3:書き込み時のコントロール信号はDACKO、DSTRBO\_Nの組み合わせになります。

注5-4: 書き込み時のコントロール信号はCS\_N、WR0\_N、WR1\_Nの組み合わせになります。

注5-5: 読み出し時のコントロール信号はCS\_N、RD\_Nの組み合わせになります。

注5-6: 受信データが1バイトしかない場合、データ出力確定時間は"(23) td(DREQ-DV)"、DEND信号出力確定時は"(24) td(DREQ-DendV)"となります。

注5-7:  $CS_N$ が立ち上がるタイミングと同時に $RD_N$ や $WR0_N$ 、 $WR1_N$ を立ち下げないでください。 $RD_N$ または $WR0_N$ 、 $WR1_N$ が立ち上がるタイミングと同時に $CS_N$ を立ち下げないでください。上記の場合、10ns以上の間隔を空ける必要があります。

注5-8: DACKi\_Nが立ち上がる(または立ち下がる)タイミングと同時にRD\_NやWR0\_N、WR1\_Nを立ち下げないでください。 RD\_NまたはWR0\_N、WR1\_Nが立ち上がるタイミングと同時にDACKを立ち下げ(または立ち上げ)ないでください。上記の場合、10ns以上の間隔を空ける必要があります。

注5-9:次のDMA転送がある場合にDREQi\_N (i=0、1)がアクティブとなるまでの時間は、tdis (CTRL-Dreq)、またはtdis

(PCTRLH - Dreq)の遅い規格が有効です。



# 4.11.6 DMAアクセスタイミング (パースト転送、マルチプレクスパス設定時)

# 4.11.6.1 DMA パースト転送 Write タイミング (CPU マルチプレクスパス設定: DFORM=000)



# 4.11.6.2 DMA パースト転送 Read タイミング (CPU マルチプレクスパス設定: DFORM=000)



### R8A66597FP/DFP/BG

注6-1:書き込み時のコントロール信号はCS\_N、WR0\_N、WR1\_Nの組み合わせになります。

注6-2:読み出し時のコントロール信号はCS\_N、RD\_Nの組み合わせになります。

注 $6-3: CS_N$ が立ち上がるタイミングと同時に $RD_N$ や $WR0_N$ 、 $WR1_N$ を立ち下げないでください。 $RD_N$ または $WR0_N$ 、 $WR1_N$ が立ち上がるタイミングと同時に $CS_N$ を立ち下げないでください。上記の場合、10ns以上の間隔を空ける必要があります。

注6-4: 受信データが1バイトしかない場合、DEND信号出力確定時は"(24) td(DREQ-DendV)"となります。

注6-5: 次のDMA転送がある場合にDREQi\_N (i=0、1)がアクティブとなるまでの時間は、tdis (CTRL-Dreq)、またはtdis (PCTRLH - Dreq)の遅い規格が有効です。



# 4.12 割り込みタイミング



注7-1:  $CS_N$ 、 $WR0_N$ 、 $WR1_N$ の組み合わせによる書き込みは、アクティブ("L")のオーバーラップ期間で行われます。立ち上がりエッジからの規格は、インアクティブの早い信号変化からが有効です。



# 改訂記録

|      |            | 改訂内容    |                                                                                                |  |  |  |
|------|------------|---------|------------------------------------------------------------------------------------------------|--|--|--|
| Rev. | 発行日        | ページ     | ポイント                                                                                           |  |  |  |
| 0.80 | 2006.06.02 |         | Rev.0.80 作成                                                                                    |  |  |  |
| 1.00 | 2007.06.19 | 5       | 追記: (1.3.1) BG パッケージピン配置図                                                                      |  |  |  |
|      |            | 13      | 誤記訂正: 番号ずれの修正                                                                                  |  |  |  |
|      |            | 14-15   | 誤記訂正: (表 2.1) アドレス DAH レジスタ名修正「DEVADD7」 「DEVADD5」                                              |  |  |  |
|      |            | 16-17   | 誤記訂正: (表 2.2) アドレス 04H 及び 06H、bit5 SOFEA ビット追記、アドレス 04H                                        |  |  |  |
|      |            |         | 及び 06H、bit4 HDDM ビット削除、アドレス 08H、bit11 HNPATOB ビット追記、                                           |  |  |  |
|      |            |         | アドレス 5CH、bit8 CNTMD ビット、及び bit7 SHTNAK ビット追記、0CH レジス                                           |  |  |  |
|      |            |         | 夕名修正「UTEST」 「TESTMODE」                                                                         |  |  |  |
|      |            | 19      | 誤記訂正: (2.3.5.1) 「USBRESET=1」 「USBRST=1」                                                        |  |  |  |
|      |            | 24、26   | 追記: (2.4) SOFEA ビットの説明                                                                         |  |  |  |
|      |            | 28      | 追記: (2.5.1、2.5.2、2.5.3) HNPBTOA ビット、EXTLP0、VBOUT0 の説明                                          |  |  |  |
|      |            | 29      | 追記: (2.5.7) 「"RWUPE=1"セットします。」                                                                 |  |  |  |
|      |            | 30、32   | 修正: (2.5.9、2.5.14) 表 2.10 及び表 2.11 のタイトル変更                                                     |  |  |  |
|      |            | 33      | 誤記訂正: (2.6.1.1) 「(上記(8)の状態で)」 「(上記(6)の状態で)」                                                    |  |  |  |
|      |            | 34      | 追記: (2.6.1.2) 「テストモード設定後、、ハードウェアリセットを実施してくだ                                                    |  |  |  |
|      |            | 44 44   | さい。」                                                                                           |  |  |  |
|      |            | 41、44   | 誤記訂正: 表中 CURPIPE ビットのビット数                                                                      |  |  |  |
|      |            | 46      | 誤記訂正: (2.8.16) 「連続転送モードの」 「非連続転送モードの」                                                          |  |  |  |
|      |            | 49      | 追記: OVRCRE ビットの OTG 時使用条件追記<br>誤記訂正: (2.10) EDGESTS S/W:「R/W」 「R」、H/W:「R」 「W」                  |  |  |  |
|      |            | 53      |                                                                                                |  |  |  |
|      |            | 58      | 追記: (2.11.10) BCHG 割り込みを許可する場合を追記                                                              |  |  |  |
|      |            | 67      | 誤記訂正: ビット説明表中のビット名「PIPENRDY」 「PIPEBEMP」                                                        |  |  |  |
|      |            | 68      | 誤記訂正: (2.12) OVRN の表中 H/W 欄修正「W」 「W(1)」、CRCE の表中 H/W<br>欄修正「W」 「W(1)」                          |  |  |  |
|      |            | 70      | 誤記訂正: (2.12.4) 「UFRMNUM」 「UFRNM」                                                               |  |  |  |
|      |            | 75      | 追記: (2.15) CNTMD ビット、及び SHTNAK ビットの説明                                                          |  |  |  |
|      |            | 76、88   | 誤記訂正: (2.15.2、2.16.11) 「DEVADD2 アドレス 」 「DEVADD2 レジスタ 」                                         |  |  |  |
|      |            | 77      | 誤記訂正: DCPCTR レジスタ 表中のビット並び誤記修正、CCPL ビット S/W 欄修正 「R(0)/W(1)」 「R/W」                              |  |  |  |
|      |            | 77      | 誤記訂正: DCPCTR レジスタ ビット説明表中のビット名「SPBUSY」「PBUSY」                                                  |  |  |  |
|      |            | 80      | 追記: (2.15.13) 「OUT トランザクションにおいて NAK Handshake を検出」                                             |  |  |  |
|      |            |         | 「OUT トランザクションにおいて NAK Handshake、または NYET Handshake を                                           |  |  |  |
|      |            |         | 検出」                                                                                            |  |  |  |
|      |            | 81      | 追記: (2.15.14) 「コントロール転送のステージを」 「コントロール転送のステー                                                   |  |  |  |
|      |            |         | タスステージを」                                                                                       |  |  |  |
|      |            | 80      | 誤記訂正: (2.16.1) 「H68 番地~H6C 番地」 「H68 番地~H6E 番地」                                                 |  |  |  |
|      |            | 84      | 誤記訂正: (2.16.4) 「ソフトウェアが本ビットに"1"を設定し、かつ、選択 PIPE を<br>送信方向で使用している ("DIR ビット=1"に設定している) 場合、本コントロー |  |  |  |
|      |            |         | ラーはBRDY割り込みを発生させません。詳細は、PIPEBRDY割り込みレジスタ                                                       |  |  |  |
|      |            |         | を参照してください。」を削除                                                                                 |  |  |  |
|      |            | 85      | 誤記訂正: (表 2.15) 送信説明「(1)または(2)」 「(1)から(3)のいずれか」                                                 |  |  |  |
|      |            | 94, 101 | 誤記訂正: PIPExCTR レジスタ 表中「CSSLR」 「CSCLR」                                                          |  |  |  |
|      |            | 100     | 追記: (表 2.18) Isochronous の場合の本コントローラーの動作欄に「UACT」の条件を追記。                                        |  |  |  |
|      |            | 100     | 誤記訂正: (表 2.19) "PID=BUF"、Bulk、受信方向の場合の本コントローラーの動作                                              |  |  |  |
|      |            | 100     | 欄「OUT Token に対し、ACK 応答を行う」 「OUT Token に対し、ACK ま                                                |  |  |  |
|      |            |         | たは NYET 応答を行う」。「PING Token に対し、NYET 応答を行う」 「PING                                               |  |  |  |
|      |            |         | Token に対し、NAK 応答を行う」                                                                           |  |  |  |
|      |            |         | (1/2)                                                                                          |  |  |  |

|      |            |          | 改訂内容                                                                                        |
|------|------------|----------|---------------------------------------------------------------------------------------------|
| Rev. | 発行日        | ページ      | ポイント                                                                                        |
|      |            |          | 追記: 転送 TYPE 未設定の場合を追記                                                                       |
|      |            | 103      | 誤記訂正: (2.18.1) (3)「PKTMD」 「PKTM」                                                            |
|      |            | 104      | 誤記訂正: (2.18.3) 「TRCNT」 「TRNCNT」                                                             |
|      |            | 107-156  | 追記:3 章全体                                                                                    |
|      |            | 157      | 追記: (4.2) BG パッケージ動作周囲温度                                                                    |
|      |            | 158, 159 | 追記: (4.3、4.4) 静止時電流                                                                         |
|      |            |          |                                                                                             |
| 1.01 | 2007.06.21 | -        | 誤記訂正: フッタの総ページ数を 185→184 に変更                                                                |
|      |            | -        | 誤記訂正: 改定履歴の3章追記欄のページを108→107に変更                                                             |
|      |            |          |                                                                                             |
| 1.02 | 2008.10.17 | 2        | 誤記訂正: 1.2.9 の見出しを訂正                                                                         |
|      |            | 7        | 追記: 端子説明表の VDD 機能説明を訂正                                                                      |
|      |            | 8        | 削除: 表 1.2 の TEST 端子は削除                                                                      |
|      |            | 17       | 誤記訂正:A0H:「PIPE5TRN」「PIPE5TRE」、A1H:「PIPE6TRN」「PIPE5TRN」                                      |
|      |            | 22       | 誤記訂正: PCSDIS の説明 「0: CS_N による復帰禁止」「0:CS_N による復帰許                                            |
|      |            |          | 可」、「1: CS_N による復帰許可」「1: CS_N による復帰禁止」                                                       |
|      |            | 41       | 誤記訂正: CFIFOSEL レジスタ REW ビット箇所 H/W 時「R」 「R/W(0)」                                             |
|      |            | 42       | 追記: 2.8.4 に「ソフトウェアが本ビットに"1"を書き込んだ後、本コントローラーは                                                |
|      |            |          | 本ビットを"0"に戻します。」を追記                                                                          |
|      |            | 44       | 誤記訂正: DxFIFOSEL レジスタ REW ビット箇所 H/W 時「R」「R/W(0)」                                             |
|      |            | 46       | 誤記訂正:C/DxFIFOCTR レジスタ BCLR ビット箇所 H/W 時「R」 「R/W(0)」                                          |
|      |            | 57,60    | 誤記訂正:INTSTS1/INTSTS2 の ATTCH 箇所:「0:割り込み出力禁止」「0:ATTCH 割り込み非発生」、「1:割り込み出力許可」「1:ATTCH 割り込み発生」、 |
|      |            |          | INTSTS1/INTSTS2 の EOFERR 箇所:「0:割り込み出力禁止」「0:EOFERR 割り込                                       |
|      |            |          | お非発生」、「1:割り込み出力許可」「1:EOFERR 割り込み発生」                                                         |
|      |            | 161      | 追記: 「4.7.リセットタイミング」を「4.7 電源シーケンス・リセットタイミング」と                                                |
|      |            |          | して見出し訂正。4.7.1 電源シーケンスの注意書き内容を追記。                                                            |
|      |            |          |                                                                                             |
|      |            |          |                                                                                             |
|      |            |          |                                                                                             |
|      |            |          |                                                                                             |
|      |            |          | 1                                                                                           |

### 本資料ご利用に際しての留意事項

- ↓ご利用に際しての留意事項
  本資料は、お客様に用途に応じた適切な弊社製品をご購入いただくための参考資料であり、本資料中に記載の技術情報について弊社または第三者の知的財産権
  その他の権利の実施、使用を許諾または保証するものではありません。
  本資料に記載の製品データ、図、表、プログラム、アルゴリズムその他応用回路例など全ての情報の使用に起因する損害、第三者の知的財産権その他の権利に
  対する侵害に関し、弊社は責任を負いません。
  本資料に記載の製品および技術を大量破壊兵器の開発等の目的、軍事利用の目的、あるいはその他軍事用途の目的で使用しないでください。また、輸出に際しては、「外国為替および外国貿易法」その他輸出関連法令を遵守し、それらの定めるところにより必要な手続を行ってください。
  本資料に記載の製品データ、図、表、プログラム、アルゴリズムその他応用回路例などの全ての情報は本資料行時点のものであり、弊社は本資料に記載した
  製品または仕様等を予告なしに変更することがあります。弊社の半導体製品のご購入およびで使用に当たりましては、事前に弊社営業窓口で最新の情報を
  ご確認いただきますとともに、弊社ホームページ(http://www.renesas.com)などを通じて公開される情報に常にご注意ください。
  本資料に記載した情報は、正確を期すため慎重に制作したものですが、万一本資料の記述の誤りに起因する損害がお客様に生じた場合においても、弊社はその
  書任を負いません。
- 5.
- 本資料に記載した情報は、正確を期ずため慎重に制作したものですが、万一本資料の記述の誤りに起因する損害がお客様に生じた場合においても、弊社はその 責任を負いません。 本資料に記載の製品データ、図、表などに示す技術的な内容、プログラム、アルゴリズムその他応用回路例などの情報を流用する場合は、流用する情報を単独 で評価するだけでなく、システム全体で十分に評価し、お客様の責任において適用可否を判断してください。弊社は、適用可否に対する責任は負いません。 本資料に記載された製品は、各種安全装置や運輸・交通用、医療用、燃烧制御用、航空宇宙用、原子力、海底中継用の機器・システムなど、その故障や誤動作 が直接人命を脅かしあるいは人体に危害を及ぼすおそれのあるような機器・システムや特に高度な品質・信頼性が要求される機器・システムでの使用を意図し て設計、製造されたものではありません(弊社が自動車用と指定する製品を自動車に使用する場合を除きます)。これらの用途に利用されることをご検討の際 には、必ず事前に弊社営業窓口へご照会ください。なお、上記用途に使用されたことにより発生した損害等について弊社はその責任を負いかねますのでご了承 原因とする 願います
- が、なり。 第7項にかかわらず、本資料に記載された製品は、下記の用途には使用しないでください。これらの用途に使用されたことにより発生した損害等につきまして は、弊社は一切の責任を負いません。

- 任を負いません
- 任を買いません。 本資料の全部または一部を弊社の文書による事前の承諾なしに転載または複製することを固くお断りいたします。 本資料に関する詳細についてのお問い合わせ、その他お気付きの点等がございましたら弊社営業窓口までご照会ください。

# **RENESAS**

営業お問合せ窓口 株式会社ルネサス販売

### http://www.renesas.com

| 本 |     |   | 社  | 〒100-0004  | 千代田区大手町2-6-2 (日本ビル)              | (03) 5201-5350 |
|---|-----|---|----|------------|----------------------------------|----------------|
| 4 |     |   | TI | 1 100-0004 | +NBEA+ $=$ 2-0-2 ( $=$ 4- $=$ 7) | ` '            |
| 西 | 東京  | 支 | 社  | 〒190-0023  | 立川市柴崎町2-2-23 (第二高島ビル2F)          | (042) 524-8701 |
| 東 | 北   | 支 | 社  | 〒980-0013  | 仙台市青葉区花京院1-1-20 (花京院スクエア13F)     | (022) 221-1351 |
| い | わ き | 支 | 店  | 〒970-8026  | いわき市平小太郎町4-9 (平小太郎ビル)            | (0246) 22-3222 |
| 茨 | 城   | 支 | 店  | 〒312-0034  | ひたちなか市堀口832-2 (日立システムプラザ勝田1F)    | (029) 271-9411 |
| 新 | 潟   | 支 | 店  | 〒950-0087  | 新潟市東大通1-4-2 (新潟三井物産ビル3F)         | (025) 241-4361 |
| 松 | 本   | 支 | 社  | 〒390-0815  | 松本市深志1-2-11 (昭和ビル7F)             | (0263) 33-6622 |
| 中 | 部   | 支 | 社  | ₹460-0008  | 名古屋市中区栄4-2-29 (名古屋広小路プレイス)       | (052) 249-3330 |
| 関 | 西   | 支 | 社  | 〒541-0044  | 大阪市中央区伏見町4-1-1 (明治安田生命大阪御堂筋ビル)   | (06) 6233-9500 |
| 北 | 陸   | 支 | 社  | 〒920-0031  | 金沢市広岡3-1-1 (金沢パークビル8F)           | (076) 233-5980 |
| 広 | 島   | 支 | 店  | 〒730-0036  | 広島市中区袋町5-25 (広島袋町ビルディング8F)       | (082) 244-2570 |
| 九 | 州   | 支 | 社  | 〒812-0011  | 福岡市博多区博多駅前2-17-1 (博多プレステージ5F)    | (092) 481-7695 |

※営業お問い合わせ窓口の住所・電話番号は変更になることがあります。最新情報につきましては、弊社ホームページをご覧ください。

■技術的なお問合せおよび資料のご請求は下記へどうぞ。

総合お問合せ窓口:コンタクトセンタ E-Mail: csc@renesas.com