

# RX ファミリ、H8S ファミリ

## H8S から RX への置き換えガイド

### シリアルコミュニケーションインターフェース編

#### 要旨

本アプリケーションノートでは、H8S ファミリの SCI のクロック同期式モードから RX ファミリの SCI のクロック同期式モード、H8S ファミリの SCI の調歩同期式モードから RX ファミリの SCI の調歩同期式モードへの置き換えについて説明しています。

#### 対象デバイス

- RX ファミリ
- H8S ファミリ

H8S から RX への置き換え例として、RX ファミリは RX261 グループを、H8S ファミリは H8S/2378 グループを用いて説明しています。本アプリケーションノートを他のマイコンへ適用する場合、そのマイコンの仕様にあわせて変更し、十分評価してください。

#### 動作確認デバイス

- RX ファミリ : RX261
- H8S ファミリ : H8S/2378

表 RX ファミリと H8S ファミリ間の用語差異

| 項目          | RX ファミリ                                      | H8S ファミリ          |
|-------------|----------------------------------------------|-------------------|
| チャネル名称      | SCI <sub>n</sub>                             | チャネル <sub>n</sub> |
| 周辺機能の動作クロック | 周辺モジュールクロック<br>(PCLKA、PCLKB、PCLKC、<br>PCLKD) | ϕ                 |

## 目次

|                                    |    |
|------------------------------------|----|
| 1. シリアルコミュニケーションインターフェースの相違点 ..... | 3  |
| 1.1 機能相違点 .....                    | 3  |
| 1.2 レジスタ相違点 .....                  | 7  |
| 2. 使用する周辺機能 .....                  | 20 |
| 3. クロック同期式シリアル通信の相違点 .....         | 20 |
| 3.1 マスタ送受信動作時の相違点 .....            | 21 |
| 3.1.1 マスタ送受信動作時のタイミング相違点 .....     | 21 |
| 3.1.2 マスタ送受信動作時での設定手順の相違点 .....    | 25 |
| 3.2 マスタ送信動作時の相違点 .....             | 28 |
| 3.2.1 マスタ送信動作時のタイミングの相違点 .....     | 28 |
| 3.2.2 マスタ送信動作時での設定手順の相違点 .....     | 30 |
| 3.3 スレーブ受信動作時の相違点 .....            | 32 |
| 3.3.1 スレーブ受信動作時のタイミングの相違点 .....    | 32 |
| 3.3.2 スレーブ受信動作時での設定手順の相違点 .....    | 34 |
| 4. 調歩同期式シリアル通信の相違点 .....           | 37 |
| 4.1 送信動作時の相違点 .....                | 38 |
| 4.1.1 送信動作時のタイミング相違点 .....         | 38 |
| 4.1.2 送信動作時での設定手順の相違点 .....        | 40 |
| 4.2 受信動作時の相違点 .....                | 42 |
| 4.2.1 受信動作時のタイミング相違点 .....         | 42 |
| 4.2.2 受信動作時での設定手順の相違点 .....        | 44 |
| 5. ビットレートの算出方法 .....               | 47 |
| 6. 割り込みの相違点 .....                  | 48 |
| 7. モジュールストップ機能 .....               | 51 |
| 8. レジスタライトプロテクション機能 .....          | 52 |
| 9. H8S から RX へ置き換えるときのポイント .....   | 53 |
| 9.1 入出力ポート .....                   | 53 |
| 9.2 I/O レジスタマクロ .....              | 54 |
| 9.3 組み込み関数 .....                   | 55 |
| 9.4 トランスマッティネーブルビットに関する注意事項 .....  | 56 |
| 10. 参考ドキュメント .....                 | 57 |

## 1. シリアルコミュニケーションインターフェースの相違点

### 1.1 機能相違点

表 1.1 に、シリアルコミュニケーションインターフェースの機能相違点を示します。表 1.2 に、RX の SCI チャネル別機能一覧を示します。

表 1.1 シリアルコミュニケーションインターフェースの機能相違点

| 項目           | RX (RX261)                                                                                            | H8S (H8S/2378)                                        |
|--------------|-------------------------------------------------------------------------------------------------------|-------------------------------------------------------|
| チャネル         | SCI1、SCI5、SCI6、SCI12                                                                                  | チャネル0、チャネル1、チャネル2、チャネル3、チャネル4                         |
| シリアル通信方式     | 調歩同期式<br>クロック同期式<br>スマートカードインターフェース<br>簡易 I <sup>2</sup> C バス<br>簡易 SPI バス                            | 調歩同期式<br>クロック同期式<br>スマートカードインターフェース                   |
| 転送速度         | 内蔵ボーレートジェネレータで任意のビットレートを設定可能                                                                          |                                                       |
| 全二重通信        | 送信部：ダブルバッファ構成による連続送信が可能<br>受信部：ダブルバッファ構成による連続受信が可能                                                    |                                                       |
| 入出力信号レベル反転   | 入力信号、出力信号のレベルを<br>それぞれ独立して反転可能                                                                        | なし                                                    |
| データ転送        | LSB ファースト/MSB ファースト<br>選択可能 <sup>(注1)</sup>                                                           | LSB ファースト/MSB ファースト<br>選択可能 (調歩同期式 7 ビット<br>データを除く)   |
| 割り込み要因       | 送信終了<br>送信データエンプティ<br>受信データフル<br>受信エラー<br>データ一致<br>開始条件/再開始条件/停止条件生<br>成終了 (簡易 I <sup>2</sup> C モード用) | 送信終了<br>送信データエンプティ<br>受信データフル<br>受信エラー                |
| 消費電力低減機能     | チャネルごとにモジュールストップ状態への遷移が可能                                                                             |                                                       |
| 調歩同期式<br>モード | データ長                                                                                                  | 7 ビット/8 ビット/9 ビット                                     |
|              | 送信ストップビット                                                                                             | 1 ビット/2 ビット                                           |
|              | パリティ機能                                                                                                | 偶数パリティ/奇数パリティ/パリティなし                                  |
|              | 受信エラー検出機能                                                                                             | パリティエラー、オーバランエラー、フレーミングエラー                            |
|              | ハードウェアフロー制御                                                                                           | CTS <sub>n</sub> #端子、RTS <sub>n</sub> #端子を用いた送受信制御が可能 |
|              | データ一致検出                                                                                               | 受信データと比較データレジスターの内容を比較して、値が一致する<br>と割り込み要求を生成可能       |
|              | スタートビットの検出                                                                                            | Low または立ち下がりエッジを選択可能                                  |
|              | 受信データサンプリングタイミング調整                                                                                    | 受信データのサンプリングポイントをデータの中央を基点に前後に<br>変更可能                |
| 調歩同期式<br>モード | 送信信号変化タイミング調整                                                                                         | 送信データの立ち下がりエッジまたは立ち上がりエッジのいずれか<br>を遅延させることが可能         |

| 項目                      | RX (RX261)     | H8S (H8S/2378)                                                         |
|-------------------------|----------------|------------------------------------------------------------------------|
| 機能                      | ブレーク検出         | フレーミングエラー発生時、RXDn 端子のレベルを直接リードする、または S PTR.RXDMON フラグを読み出すことでブレークを検出可能 |
|                         | クロックソース        | 内部クロック/外部クロックの選択が可能<br>TMR からの転送レートクロック入力が可能 (SCI5、SCI6、SCI12)         |
|                         | 倍速モード          | ボーレートジェネレータ倍速モードを選択可能                                                  |
|                         | マルチプロセッサ通信機能   | 複数のプロセッサ間のシリアル通信機能                                                     |
|                         | ノイズ除去          | RXDn 端子入力経路にデジタルノイズフィルタを内蔵                                             |
| クロック同期式モード              | データ長           | 8 ビット                                                                  |
|                         | 受信エラーの検出       | オーバランエラー                                                               |
|                         | ハードウェア FIFO 制御 | CTS#端子、RTS#端子を用いた送受信制御が可能                                              |
| スマートカードインターフェースモード      | エラー処理          | 受信時パリティエラーを検出するとエラーシグナルを自動送出<br>送信時エラーシグナルを受信するとデータを自動再送信              |
|                         | データタイプ         | ダイレクトコンベンション/インバースコンベンションをサポート                                         |
| IrDA                    |                | なし                                                                     |
| 簡易 I <sup>2</sup> C モード | 通信フォーマット       | I <sup>2</sup> C バスフォーマット                                              |
|                         | 動作モード          | マスタ (シングルマスタ動作のみ)                                                      |
|                         | 転送速度           | ファストモード対応                                                              |
|                         | ノイズ除去          | SSCLn、SSDAn 入力経路にデジタルノイズフィルタを内蔵<br>ノイズ除去幅調整可能                          |
| 簡易 SPI モード              | データ長           | 8 ビット                                                                  |
|                         | エラーの検出         | オーバランエラー                                                               |
|                         | SS 入力端子機能      | SS#端子が High のとき、出力端子をハイインピーダンスにすることが可能                                 |
|                         | クロック設定         | クロック位相、クロック極性の設定を 4 種類から選択可能                                           |
| ビットレート モジュレーション機能       |                | 内蔵ボーレートジェネレータの出力補正により誤差を低減可能                                           |

| 項目                   | RX (RX261)                                                                                                      | H8S (H8S/2378)                                                                                                                                                                                                                                                                                                                                            |
|----------------------|-----------------------------------------------------------------------------------------------------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| イベントリンク機能 (SCI5 のみ)  | イベントリンク機能の起動要因として以下要因を設定可能<br>・エラー(受信エラー・エラーシグナル検出)イベント出力<br>・受信データフルイベント出力<br>・送信データエンプティイベント出力<br>・送信終了イベント出力 | なし                                                                                                                                                                                                                                                                                                                                                        |
| 拡張シリアルモード (SCI12 のみ) | Start Frame 送信                                                                                                  | ・Break Field Low width の出力が可能/出力完了割り込み機能あり<br>・バス衝突検出機能あり/検出割り込み機能あり                                                                                                                                                                                                                                                                                      |
|                      | Start Frame 受信                                                                                                  | ・Break Field Low width の検出が可能/検出完了割り込み機能あり<br>・Control Field 0、Control Field 1 のデータ比較/一致割り込み機能あり<br>・Control Field 0、Control Field 1 のデータ比較/一致割り込み機能あり<br>・Control Field 1 にはプライマリ/セカンダリの 2 種類の比較データの設定可能<br>・Control Field 1 にはプライオリティインターラプトビットを設定可能<br>・Break Field がない Start Frame にも対応可能<br>・Control Field 0 がない Start Frame にも対応可能<br>・ビットレート測定機能あり |
|                      | 入出力制御機能                                                                                                         | ・TXDX12/RXDX12 信号の極性選択が可能<br>・RXDX12 信号にデジタルフィルタ機能を設定可能<br>・RXDX12 端子と TXDX12 端子を兼用した半二重通信が可能<br>・RXDX12 端子受信データサンプリングタイミング選択可能<br>・拡張シリアルモード制御部 OFF 時、RXDX12 受信信号を SCIG ヘスル出力可能                                                                                                                                                                          |
|                      | タイマ機能                                                                                                           | リロードタイマ機能として使用可能                                                                                                                                                                                                                                                                                                                                          |

注 1. 簡易 I<sup>2</sup>C モードでは、MSB ファーストでのみ使用可能です。

表 1.2 RX の SCI チャネル別機能一覧

| 項目                      | SCIk     |          |          | SCIh     |
|-------------------------|----------|----------|----------|----------|
|                         | SCI1     | SCI5     | SCI6     | SCI12    |
| 調歩同期式モード                | ○        | ○        | ○        | ○        |
| クロック同期式モード              | ○        | ○        | ○        | ○        |
| スマートカードインターフェースモード      | ○        | ○        | ○        | ○        |
| 簡易 I <sup>2</sup> C モード | ○        | ○        | ○        | ○        |
| 簡易 SPI モード              | ○        | ○        | ○        | ○        |
| データー致検知                 | ○        | ○        | ○        | —        |
| 拡張シリアルモード               | —        | —        | —        | ○        |
| TMR クロック入力              | —        | ○        | ○        | ○        |
| イベントリンク機能               | —        | ○        | —        | —        |
| 周辺モジュールクロック             | ○(PCLKB) | ○(PCLKB) | ○(PCLKB) | ○(PCLKB) |

## 1.2 レジスタ相違点

表 1.3 に、RX と H8S の SCI レジスター一覧を示します。

表 1.3 RX と H8S の SCI レジスター一覧

| RX (RX261)                                     | H8S (H8S/2378)         |
|------------------------------------------------|------------------------|
| レシーブシフトレジスタ (RSR)                              | レシーブシフトレジスタ (RSR)      |
| レシーブデータレジスタ (RDR)                              | レシーブデータレジスタ (RDR)      |
| レシーブデータレジスタ H, L, HL<br>(RDRH, RDRL, RDRHL)    | なし                     |
| トランスマットデータレジスタ (TDR)                           | トランスマットデータレジスタ (TDR)   |
| トランスマットデータレジスタ H, L, HL<br>(TDRH, TDRL, TDRHL) | なし                     |
| トランスマットシフトレジスタ (TSR)                           | トランスマットシフトレジスタ (TSR)   |
| シリアルモードレジスタ (SMR)                              | シリアルモードレジスタ (SMR)      |
| シリアルコントロールレジスタ (SCR)                           | シリアルコントロールレジスタ (SCR)   |
| シリアルステータスレジスタ (SSR)                            | シリアルステータスレジスタ (SSR)    |
| スマートカードモードレジスタ (SCMR)                          | スマートカードモードレジスタ (SCMR)  |
| ビットレートレジスタ (BRR)                               | ビットレートレジスタ (BRR)       |
| なし                                             | IrDA コントロールレジスタ (IrCR) |
| モジュレーションデューティレジスタ (MDDR)                       | なし                     |
| シリアル拡張モードレジスタ (SEMR)                           | シリアル拡張モードレジスタ (SEMR)   |

| RX (RX261)                             | H8S (H8S/2378) |
|----------------------------------------|----------------|
| ノイズフィルタ設定レジスタ (SNFR)                   | なし             |
| I <sup>2</sup> C モードレジスタ 1 (SIMR1)     |                |
| I <sup>2</sup> C モードレジスタ 2 (SIMR2)     |                |
| I <sup>2</sup> C モードレジスタ 3 (SIMR3)     |                |
| I <sup>2</sup> C ステータスレジスタ (SISR)      |                |
| SPI モードレジスタ (SPMR)                     |                |
| 比較データレジスタ(CDR)                         |                |
| データ比較制御レジスタ(DCCR)                      |                |
| シリアルポートレジスタ(SPTR)                      |                |
| 送受信タイミング選択レジスタ(TMGR)                   |                |
| 拡張シリアルモード有効レジスタ (ESMER)                |                |
| コントロールレジスタ 0 (CR0)                     |                |
| コントロールレジスタ 1 (CR1)                     |                |
| コントロールレジスタ 2 (CR2)                     |                |
| コントロールレジスタ 3 (CR3)                     |                |
| ポートコントロールレジスタ (PCR)                    |                |
| 割り込みコントロールレジスタ (ICR)                   |                |
| ステータスレジスタ (STR)                        |                |
| ステータスクリアレジスタ (STCR)                    |                |
| Control Field 0 データレジスタ (CF0DR)        |                |
| Control Field 0 コンペアイネーブルレジスタ (CF0CR)  |                |
| Control Field 0 受信データレジスタ (CF0RR)      |                |
| プライマリ Control Field 1 データレジスタ (PCF1DR) |                |
| セカンダリ Control Field 1 データレジスタ (SCF1DR) |                |
| Control Field 1 コンペアイネーブルレジスタ (CF1CR)  |                |
| Control Field 1 受信データレジスタ (CF1RR)      |                |
| タイマコントロールレジスタ (TCR)                    |                |
| タイマモードレジスタ (TMR)                       |                |
| タイマプリスケーラレジスタ (TPRE)                   |                |
| タイマカウントレジスタ (TCNT)                     |                |

表 1.4 に、RX と H8S の SCI レジスタ相違点を示します。表 1.3 中のレジスタの内、同じ機能を持つレジスタの相違点を示します。表 1.4 に記載していないレジスタおよびビットの機能は、全く同じです。

表 1.4 RX と H8S の SCI レジスタ相違点

| レジスタ名                                                                      |                       | ビット名          |                       | 説明                                                                                                                                                                                        |                                                                                                         |
|----------------------------------------------------------------------------|-----------------------|---------------|-----------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|---------------------------------------------------------------------------------------------------------|
| RX<br>(RX261)                                                              | H8S<br>(H8S/2378<br>) | RX<br>(RX261) | H8S<br>(H8S/<br>2378) | RX (RX261)                                                                                                                                                                                | H8S (H8S/2378)                                                                                          |
| レシーブ<br>データレジ<br>スタ H、<br>L、HL<br>(RDRH、<br>RDRL、<br>RDRHL)                | なし                    |               |                       | RDRH レジスタと RDRL レジスタは、それぞれ受信データを格納するための 8 ビットのレジスタです。調歩同期式モード 9 ビットデータ長選択時に使用します。<br>RDRHL レジスタとして 16 ビットでもアクセスできます。                                                                      | —                                                                                                       |
| トランス<br>ミットデー <sup>ト</sup><br>タレジスタ<br>H、L、HL<br>(TDRH、<br>TDRL、<br>TDRHL) | なし                    |               |                       | TDRH レジスタと TDRL レジスタは、それぞれ送信データを格納するための 8 ビットのレジスタです。<br>調歩同期式モード 9 ビットデータ長選択時に使用します。<br>TDRHL レジスタとして 16 ビットでもアクセスできます。                                                                  | —                                                                                                       |
| シリアルモードレジスタ<br>(SMR)<br>(SCMR.SMIF = 0 のとき)                                | CM                    | C/A           |                       | コミュニケーションモード<br>0 : 調歩同期式モード、または簡易 I2C モードで動作<br>1 : クロック同期式モード、または簡易 SPI モードで動作                                                                                                          | コミュニケーションモード<br>0 : 調歩同期式モードで動作<br>1 : クロック同期式モードで動作                                                    |
|                                                                            | CHR                   |               |                       | キャラクタレンジス <sup>(注1)</sup><br>(調歩同期式モードのみ有効)<br>SCMR.CHR1 ビットと組み合わせて選択<br>CHR1 CHR<br>0 0 データ長 9 ビットで送受信<br>0 1 データ長 9 ビットで送受信<br>1 0 データ長 8 ビットで送受信<br>1 1 データ長 7 ビットで送受信 <sup>(注2)</sup> | キャラクタレンジス <sup>(注1)</sup><br>(調歩同期式モードのみ有効)<br>0 : データ長 8 ビットで送受信<br>1 : データ長 7 ビットで送受信 <sup>(注2)</sup> |
|                                                                            | PM                    | O/E           |                       | パリティモード (ビット名称の差異のみ)                                                                                                                                                                      |                                                                                                         |

| レジスタ名                                           |                   | ビット名                                                                                                                                                                                                              |                                                                                                                                                                                                                                                                 | 説明                                      |                                                                                                                 |
|-------------------------------------------------|-------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-----------------------------------------|-----------------------------------------------------------------------------------------------------------------|
| RX<br>(RX261)                                   | H8S<br>(H8S/2378) | RX<br>(RX261)                                                                                                                                                                                                     | H8S<br>(H8S/<br>2378)                                                                                                                                                                                                                                           | RX (RX261)                              | H8S (H8S/2378)                                                                                                  |
| シリアルモードレジスタ<br>(SMR)<br>(SCMR.SMIF = 1 のとき)     | PM                | O/E                                                                                                                                                                                                               | パリティモード (ビット名称の差異のみ)                                                                                                                                                                                                                                            |                                         |                                                                                                                 |
|                                                 | BCP[1:0]          | BCP1<br>BCP0                                                                                                                                                                                                      | BCP2 BCP[1:0]<br>0 0 0 93 クロック<br>(S = 93)<br>0 0 1 128 クロック<br>(S = 128)<br>0 1 0 186 クロック<br>(S = 186)<br>0 1 1 512 クロック<br>(S = 512)<br>1 0 0 32 クロック<br>(S = 32)<br>1 0 1 64 クロック<br>(S = 64)<br>1 1 0 372 クロック<br>(S = 372)<br>1 1 1 256 クロック<br>(S = 256) | 基本クロックパルス<br>SCMR.BCP2 ビットと組み<br>合わせて選択 | 基本クロックパルス<br>0 0 32 クロック(S = 32)<br>0 1 64 クロック(S = 64)<br>1 0 372 クロック(S =<br>372)<br>1 1 256 クロック(S =<br>256) |
| シリアルコントロールレ<br>ジスタ (SCR)<br>(SCMR.SMIF = 0 のとき) | TEIE              | TEI 割り込みイネーブル<br>0 : TEI 割り込み要求を禁止<br>1 : TEI 割り込み要求を許可<br>簡易 I <sup>2</sup> C モードでは、開始/<br>再開始/停止条件生成完了割<br>り込み (STI 割り込み) が<br>TEI 割り込みに割り当てら<br>れます。その場合も TEIE<br>ビットにより STI 割り込み<br>要求を許可、または禁止す<br>ることができます。 |                                                                                                                                                                                                                                                                 |                                         | TEI 割り込みイネーブル<br>0 : TEI 割り込み要求を禁止<br>1 : TEI 割り込み要求を許可                                                         |

| レジスタ名                                       | ビット名              |               | 説明                    |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             |                                                                                                                                                                                                                                                                                                                                                                 |
|---------------------------------------------|-------------------|---------------|-----------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| RX<br>(RX261)                               | H8S<br>(H8S/2378) | RX<br>(RX261) | H8S<br>(H8S/<br>2378) | RX (RX261)                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  | H8S (H8S/2378)                                                                                                                                                                                                                                                                                                                                                  |
| シリアルコントロールレジスタ (SCR)<br>(SCMR.SMIF = 0 のとき) |                   | CKE[1:0]      | CKE1<br>CKE0          | <p>クロックイネーブル<br/>(調歩同期式の場合)</p> <p>b1 b0</p> <p>0 0 : 内蔵ボーレートジェネレータ<br/>I/O ポートの設定によって、SCKn 端子は入出力ポートとして使用できます。</p> <p>0 1 : 内蔵ボーレートジェネレータ<br/>SCKn 端子からビットレートと同じ周波数のクロックを出力します。</p> <p>1 X : 外部クロックまたは<br/>TMR クロック<br/>外部クロック使用時は、SCKn 端子からビットレートの 16 倍の周波数のクロックを入力してください。<br/>SEMR.ABCS ビットが“1”的ときは 8 倍の周波数のクロックを入力してください。<br/>TMR クロック使用時は、I/O ポートの設定によって、SCKn 端子は入出力ポートとして使用できます。<br/>(注 : TMR クロックは、SCI5、SCI6、SCI12 で使用できます。SCI1 では使用できません。)</p> <p>(クロック同期式の場合)</p> <p>b1 b0</p> <p>0 X : 内部クロック<br/>SCKn 端子はクロック出力端子となります。</p> <p>1 X : 外部クロック<br/>SCKn 端子はクロック入力端子となります。</p> <p>X : Don't care</p> | <p>クロックイネーブル<br/>(調歩同期式の場合)</p> <p>0 0 : 内蔵ボーレートジェネレータ<br/>SCKn 端子は入出力ポートとして使用できます。</p> <p>0 1 : 内蔵ボーレートジェネレータ<br/>SCKn 端子からビットレートと同じ周波数のクロックを出力します。</p> <p>1 X : 外部クロック<br/>SCKn 端子からビットレートの 16 倍の周波数のクロックを入力してください。</p> <p>(クロック同期式の場合)</p> <p>0 X : 内部クロック<br/>SCK 端子はクロック出力端子となります。</p> <p>1 X : 外部クロック<br/>SCK 端子はクロック入力端子となります。</p> <p>X : Don't care</p> |

| レジスタ名                                       |                   | ビット名          |                       | 説明                                                                                                                                                                                                                                                                                                                                                               |                                                                                                                                                                                                                                                                                                                                       |
|---------------------------------------------|-------------------|---------------|-----------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| RX<br>(RX261)                               | H8S<br>(H8S/2378) | RX<br>(RX261) | H8S<br>(H8S/<br>2378) | RX (RX261)                                                                                                                                                                                                                                                                                                                                                       | H8S (H8S/2378)                                                                                                                                                                                                                                                                                                                        |
| シリアルコントロールレジスタ (SCR)<br>(SCMR.SMIF = 1 のとき) |                   | CKE[1:0]      | CKE1<br>CKE0          | <p>クロックイネーブル</p> <ul style="list-style-type: none"> <li>SMR.GM ビット=0 の場合</li> </ul> <p>b1 b0<br/>0 0 : 出力ディスエーブル<br/>(I/O ポートの設定によって、SCKn 端子は入出力ポートとして使用できます)<br/>0 1 : クロック出力<br/>1 X : リザーブ <ul style="list-style-type: none"> <li>SMR.GM ビット=1 の場合</li> </ul> <p>b1 b0<br/>0 0 : Low 出力固定<br/>X 1 : クロック出力<br/>1 0 : High 出力固定</p> <p>X : Don't care</p> </p> | <p>クロックイネーブル</p> <ul style="list-style-type: none"> <li>SMR の GM=0 の場合</li> </ul> <p>0 0 : 出力ディスエーブル<br/>(SCK 端子は入出力ポートとして使用可)</p> <p>0 1 : クロック出力<br/>1 X : リザーブ</p> <ul style="list-style-type: none"> <li>SMR の GM=1 の場合</li> </ul> <p>0 0 : Low 出力固定<br/>0 1 : クロック出力<br/>1 0 : High 出力固定<br/>1 1 : クロック出力<br/>X : Don't care</p> |
| シリアルステータスレジスタ (SSR)<br>(SCMR.SMIF = 0 のとき)  | TDRE              |               |                       | <p>送信データエンプティ</p> <p>[セット条件]</p> <ul style="list-style-type: none"> <li>TDR レジスタから TSR レジスタにデータが転送されたとき</li> </ul> <p>[クリア条件]</p> <ul style="list-style-type: none"> <li>TDR レジスタへ送信データを書いたとき</li> </ul>                                                                                                                                                         | <p>トランスマットデータレジスタエンプティ</p> <p>[セット条件]</p> <ul style="list-style-type: none"> <li>SCR の TE が 0 のとき</li> <li>TDR から TSR にデータが転送され、TDR にデータライトが可能になったとき</li> </ul> <p>[クリア条件]</p> <ul style="list-style-type: none"> <li>1 の状態をリードした後、0 をライトしたとき</li> <li>TXI 割り込み要求により DMAC または DTC で TDR に送信データを転送したとき</li> </ul>                      |

| レジスタ名                                      |                   | ビット名          |                       | 説明                                                                                                                                                                                                                                                                           |                                                                                                                                                                                                                                                                                                               |
|--------------------------------------------|-------------------|---------------|-----------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| RX<br>(RX261)                              | H8S<br>(H8S/2378) | RX<br>(RX261) | H8S<br>(H8S/<br>2378) | RX (RX261)                                                                                                                                                                                                                                                                   | H8S (H8S/2378)                                                                                                                                                                                                                                                                                                |
|                                            | RDRF              |               |                       | <p>受信データフル</p> <p>[セット条件]</p> <ul style="list-style-type: none"> <li>受信が正常終了し、RSR レジスタから RDR レジスタへ受信データが転送されたとき</li> </ul> <p>[クリア条件]</p> <ul style="list-style-type: none"> <li>RDR レジスタからデータを読み出したとき</li> </ul>                                                            | <p>レシーブデータレジスタフル</p> <p>[セット条件]</p> <ul style="list-style-type: none"> <li>受信が正常終了し、RSR から RDR へ受信データが転送されたとき</li> </ul> <p>[クリア条件]</p> <ul style="list-style-type: none"> <li>1 の状態をリードした後、0 をライトしたとき</li> <li>RXI 割り込みにより DMAC または DTC で RDR からデータを転送したとき</li> </ul>                                        |
| シリアルステータスレジスタ (SSR)<br>(SCMR.SMIF = 0 のとき) | TEND              |               |                       | <p>トランスマットエンド</p> <p>[セット条件]</p> <ul style="list-style-type: none"> <li>SCR.TE ビットが“0”(シリアル送信動作を禁止)のとき</li> <li>送信キャラクタの最後尾ビットの送信時、TDR レジスタが更新されていないとき</li> </ul> <p>[クリア条件]</p> <ul style="list-style-type: none"> <li>SCR.TE ビットが“1”的状態で TDR レジスタへ送信データを書き込んだとき</li> </ul> | <p>トランスマットエンド</p> <p>[セット条件]</p> <ul style="list-style-type: none"> <li>SCR の TE が 0 のとき</li> <li>送信キャラクタの最後尾ビットの送信時、TDRE が 1 のとき</li> </ul> <p>[クリア条件]</p> <ul style="list-style-type: none"> <li>TDRE=1 の状態をリードした後、TDRE フラグに 0 をライトしたとき</li> <li>TXI 割り込み要求により DMAC または DTC で TDR へ送信データをライトしたとき</li> </ul> |

| レジスタ名                                          | ビット名              |               | 説明                    |                                                                                                                                                                                                                    |                                                                                                                                                                                                                                                                                                                            |
|------------------------------------------------|-------------------|---------------|-----------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| RX<br>(RX261)                                  | H8S<br>(H8S/2378) | RX<br>(RX261) | H8S<br>(H8S/<br>2378) | RX (RX261)                                                                                                                                                                                                         | H8S (H8S/2378)                                                                                                                                                                                                                                                                                                             |
| シリアルステータスレジ<br>スタ (SSR)<br>(SCMR.SMIF = 1 のとき) | TDRE              |               |                       | <p>送信データエンプティ<br/>[セット条件]</p> <ul style="list-style-type: none"> <li>• TDR レジスタから TSR レジスタにデータが転送されたとき</li> </ul> <p>[クリア条件]</p> <ul style="list-style-type: none"> <li>• TDR レジスタへ送信データを書いたとき</li> </ul>          | <p>トランスマットデータレジ<br/>スタエンプティ<br/>[セット条件]</p> <ul style="list-style-type: none"> <li>• SCR の TE が 0 のとき</li> <li>• TDR から TSR にデータが転送され、TDR にデータライトが可能になったとき</li> </ul> <p>[クリア条件]</p> <ul style="list-style-type: none"> <li>• 1 の状態をリードした後、0 をライトしたとき</li> <li>• TXI 割り込み要求により DMAC または DTC で TDR に送信データを転送したとき</li> </ul> |
|                                                | RDRF              |               |                       | <p>受信データフル<br/>[セット条件]</p> <ul style="list-style-type: none"> <li>• 受信が正常終了し、RSR レジスタから RDR レジスタへ受信データが転送されたとき</li> </ul> <p>[クリア条件]</p> <ul style="list-style-type: none"> <li>• RDR レジスタからデータを読み出したとき</li> </ul> | <p>レシーブデータレジスタフル<br/>[セット条件]</p> <ul style="list-style-type: none"> <li>• 受信が正常終了し、RSR から RDR へ受信データが転送されたとき</li> </ul> <p>[クリア条件]</p> <ul style="list-style-type: none"> <li>• 1 の状態をリードした後、0 をライトしたとき</li> <li>• RXI 割り込みにより DMAC または DTC で RDR からデータを転送したとき</li> </ul>                                                  |

| レジスタ名                                          |                   | ビット名          |                       | 説明                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       |                                                                                                                                                                                                                                                                                                                           |   |   |                     |   |   |   |                       |   |   |   |                       |   |   |   |                       |   |   |   |                     |   |   |   |                     |   |   |   |                       |   |   |   |                       |   |
|------------------------------------------------|-------------------|---------------|-----------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|---|---|---------------------|---|---|---|-----------------------|---|---|---|-----------------------|---|---|---|-----------------------|---|---|---|---------------------|---|---|---|---------------------|---|---|---|-----------------------|---|---|---|-----------------------|---|
| RX<br>(RX261)                                  | H8S<br>(H8S/2378) | RX<br>(RX261) | H8S<br>(H8S/<br>2378) | RX (RX261)                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               | H8S (H8S/2378)                                                                                                                                                                                                                                                                                                            |   |   |                     |   |   |   |                       |   |   |   |                       |   |   |   |                       |   |   |   |                     |   |   |   |                     |   |   |   |                       |   |   |   |                       |   |
| シリアルステータスレジ<br>スタ (SSR)<br>(SCMR.SMIF = 1 のとき) |                   | TEND          |                       | <p>トランスマットエンド<br/>[セット条件]</p> <ul style="list-style-type: none"> <li>SCR.TE ビット=0 のとき</li> <li>1 バイトのデータを送信して一定期間後、ERS フラグ=0 かつ TDR レジスタが更新されていないとき</li> </ul> <p>[クリア条件]</p> <ul style="list-style-type: none"> <li>SCR.TE ビットが"1"の状態で TDR レジスタへ送信データを書き込んだとき</li> </ul>                                                                                                                                                                                                                                                                                                                                                                                                                | <p>トランスマットエンド<br/>[セット条件]</p> <ul style="list-style-type: none"> <li>SCR の TE=0 かつ ERS=0 のとき</li> <li>1 バイトのデータを送信して一定期間後、ERS=0 かつ TDRE=1 のとき</li> </ul> <p>[クリア条件]</p> <ul style="list-style-type: none"> <li>TDRE=1 の状態をリードした後、TDRE フラグに 0 をライトしたとき</li> <li>TXI 割り込み要求により DMAC または DTC で TDR へ送信データをライトしたとき</li> </ul> |   |   |                     |   |   |   |                       |   |   |   |                       |   |   |   |                       |   |   |   |                     |   |   |   |                     |   |   |   |                       |   |   |   |                       |   |
| スマートカードモード<br>レジスタ (SCMR)                      | BCP2              | なし            |                       | <p>基本クロックパルス 2<br/>SMR.BCP[1:0]ビットと組み合わせて選択</p> <p>BCP2 BCP[1:0]</p> <table> <tbody> <tr><td>0</td><td>0</td><td>0</td><td>93 クロック<br/>(S = 93)</td></tr> <tr><td>0</td><td>0</td><td>1</td><td>128 クロック<br/>(S = 128)</td></tr> <tr><td>0</td><td>1</td><td>0</td><td>186 クロック<br/>(S = 186)</td></tr> <tr><td>0</td><td>1</td><td>1</td><td>512 クロック<br/>(S = 512)</td></tr> <tr><td>1</td><td>0</td><td>0</td><td>32 クロック<br/>(S = 32)</td></tr> <tr><td>1</td><td>0</td><td>1</td><td>64 クロック<br/>(S = 64)</td></tr> <tr><td>1</td><td>1</td><td>0</td><td>372 クロック<br/>(S = 372)</td></tr> <tr><td>1</td><td>1</td><td>1</td><td>256 クロック<br/>(S = 256)</td></tr> </tbody> </table> | 0                                                                                                                                                                                                                                                                                                                         | 0 | 0 | 93 クロック<br>(S = 93) | 0 | 0 | 1 | 128 クロック<br>(S = 128) | 0 | 1 | 0 | 186 クロック<br>(S = 186) | 0 | 1 | 1 | 512 クロック<br>(S = 512) | 1 | 0 | 0 | 32 クロック<br>(S = 32) | 1 | 0 | 1 | 64 クロック<br>(S = 64) | 1 | 1 | 0 | 372 クロック<br>(S = 372) | 1 | 1 | 1 | 256 クロック<br>(S = 256) | — |
| 0                                              | 0                 | 0             | 93 クロック<br>(S = 93)   |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          |                                                                                                                                                                                                                                                                                                                           |   |   |                     |   |   |   |                       |   |   |   |                       |   |   |   |                       |   |   |   |                     |   |   |   |                     |   |   |   |                       |   |   |   |                       |   |
| 0                                              | 0                 | 1             | 128 クロック<br>(S = 128) |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          |                                                                                                                                                                                                                                                                                                                           |   |   |                     |   |   |   |                       |   |   |   |                       |   |   |   |                       |   |   |   |                     |   |   |   |                     |   |   |   |                       |   |   |   |                       |   |
| 0                                              | 1                 | 0             | 186 クロック<br>(S = 186) |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          |                                                                                                                                                                                                                                                                                                                           |   |   |                     |   |   |   |                       |   |   |   |                       |   |   |   |                       |   |   |   |                     |   |   |   |                     |   |   |   |                       |   |   |   |                       |   |
| 0                                              | 1                 | 1             | 512 クロック<br>(S = 512) |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          |                                                                                                                                                                                                                                                                                                                           |   |   |                     |   |   |   |                       |   |   |   |                       |   |   |   |                       |   |   |   |                     |   |   |   |                     |   |   |   |                       |   |   |   |                       |   |
| 1                                              | 0                 | 0             | 32 クロック<br>(S = 32)   |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          |                                                                                                                                                                                                                                                                                                                           |   |   |                     |   |   |   |                       |   |   |   |                       |   |   |   |                       |   |   |   |                     |   |   |   |                     |   |   |   |                       |   |   |   |                       |   |
| 1                                              | 0                 | 1             | 64 クロック<br>(S = 64)   |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          |                                                                                                                                                                                                                                                                                                                           |   |   |                     |   |   |   |                       |   |   |   |                       |   |   |   |                       |   |   |   |                     |   |   |   |                     |   |   |   |                       |   |   |   |                       |   |
| 1                                              | 1                 | 0             | 372 クロック<br>(S = 372) |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          |                                                                                                                                                                                                                                                                                                                           |   |   |                     |   |   |   |                       |   |   |   |                       |   |   |   |                       |   |   |   |                     |   |   |   |                     |   |   |   |                       |   |   |   |                       |   |
| 1                                              | 1                 | 1             | 256 クロック<br>(S = 256) |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          |                                                                                                                                                                                                                                                                                                                           |   |   |                     |   |   |   |                       |   |   |   |                       |   |   |   |                       |   |   |   |                     |   |   |   |                     |   |   |   |                       |   |   |   |                       |   |

| レジスタ名                     |                   | ビット名          |                       | 説明                                                                                                                                                                                                                                                                                                   |                                                                                                                                                        |
|---------------------------|-------------------|---------------|-----------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------|
| RX<br>(RX261)             | H8S<br>(H8S/2378) | RX<br>(RX261) | H8S<br>(H8S/<br>2378) | RX (RX261)                                                                                                                                                                                                                                                                                           | H8S (H8S/2378)                                                                                                                                         |
|                           | CHR1              | なし            |                       | <p>キャラクタレンジス 2<sup>(注1)</sup><br/>(調歩同期式モードのみ有効)</p> <p><b>SMR.CHR ビットと組み合わせて選択</b></p> <p>CHR1 CHR</p> <p>0 0 データ長 9 ビットで送受信</p> <p>0 1 データ長 9 ビットで送受信</p> <p>1 0 データ長 8 ビットで送受信</p> <p>1 1 データ長 7 ビットで送受信<sup>(注2)</sup></p>                                                                       | —                                                                                                                                                      |
| スマートカードモード<br>レジスタ (SCMR) | SDIR              |               |                       | <p>送受信データトランスマッテ<br/>ディレクション</p> <p><b>以下のモードで使用可能です。</b></p> <ul style="list-style-type: none"> <li>スマートカードインターフェースモード</li> <li>調歩同期式モード (マルチプロセッサモード)</li> <li>クロック同期式モード</li> <li>簡易 SPI モード<br/>簡易 I<sup>2</sup>C モードで動作させる場合は、“1”にします</li> </ul> <p>0 : LSB ファーストで送受信<br/>1 : MSB ファーストで送受信</p> | <p>スマートカードデータトランスマッテ<br/>ディレクション</p> <p>0 : LSB ファーストで送受信<br/>1 : MSB ファーストで送受信</p> <p>送受信フォーマットが 8 ビットデータの場合のみ有効です。7 ビットデータの場合は LSB ファーストに固定されます。</p> |
|                           | SMIF              |               |                       | <p>スマートカードインターフェースモードセレクト</p> <p>0 : 非スマートカードインターフェースモード (調歩同期式モード、クロック同期式モード、簡易 SPI モード、簡易 I<sup>2</sup>C モード)</p> <p>1 : スマートカードインターフェースモード</p>                                                                                                                                                    | <p>スマートカードインターフェースモードセレクト</p> <p>0 : 通常の調歩同期式またはクロック同期式モード<br/>1 : スマートカードインターフェースモード</p>                                                              |

| レジスタ名                                    | ビット名              |               | 説明                    |                                                                                                                                                                                                                                                        |                |
|------------------------------------------|-------------------|---------------|-----------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|----------------|
| RX<br>(RX261)                            | H8S<br>(H8S/2378) | RX<br>(RX261) | H8S<br>(H8S/<br>2378) | RX (RX261)                                                                                                                                                                                                                                             | H8S (H8S/2378) |
| シリアル拡張モードレジ<br>スタ (SEMR) <sup>(注3)</sup> |                   | RXDES<br>EL   | なし                    | 調歩同期スタートビット<br>エッジ検出セレクト<br>(調歩同期式モードのみ有<br>効)<br>0 : RXDn 端子入力の Low<br>レベルでスタートビット<br>を検出<br>1 : RXDn 端子入力の立ち下<br>がりエッジでスタート<br>ビットを検出                                                                                                                | —              |
|                                          |                   | BGDM          | なし                    | ボーレートジェネレータ倍<br>速モードセレクト<br>(調歩同期式モードで内蔵<br>ボーレートジェネレータ使<br>用時のみ有効)<br>0 : ボーレートジェネレータ<br>から通常の周波数のク<br>ロックを出力<br>1 : ボーレートジェネレータ<br>から 2 倍の周波数のク<br>ロックを出力                                                                                            | —              |
|                                          |                   | NFEN          | なし                    | デジタルノイズフィルタ機<br>能イネーブル<br>(調歩同期式モード)<br>0 : RXDn 入力信号のノイズ<br>除去機能無効<br>1 : RXDn 入力信号のノイズ<br>除去機能有効<br>(簡易 I <sup>2</sup> C モード)<br>0 : SSCLn、SSDAn 入力信<br>号のノイズ除去機能無効<br>1 : SSCLn、SSDAn 入力信<br>号のノイズ除去機能有効<br>上記以外のモードでは、<br>NFEN ビットを“0”にしてく<br>ださい。 | —              |
|                                          |                   | BRME          | なし                    | ビットレートモジュレー<br>ションイネーブル<br>0 : ビットレートモジュレー<br>ション機能無効<br>1 : ビットレートモジュレー<br>ション機能有効                                                                                                                                                                    | —              |

| レジスタ名                                    | ビット名              |                      | 説明                                                                    |                                                                                                                               |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 |
|------------------------------------------|-------------------|----------------------|-----------------------------------------------------------------------|-------------------------------------------------------------------------------------------------------------------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| RX<br>(RX261)                            | H8S<br>(H8S/2378) | RX<br>(RX261)        | H8S<br>(H8S/<br>2378)                                                 | RX (RX261)                                                                                                                    | H8S (H8S/2378)                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  |
| シリアル拡張モードレジ<br>スタ (SEMR) <sup>(注3)</sup> | ACS0              | ACS2<br>ACS1<br>ACS0 | 調歩同期クロックソースセ<br>レクト<br>(調歩同期式モードで<br>SCR.CKE[1:0]=10b,11,のと<br>きのみ有効) | 0 : 外部クロック<br>1 : TMR から出力される 2<br>つのコンペアマッチ出力<br>の論理積(SCI5、SCI6、<br>SCI12 のみ有効)<br>SCI のチャネルごとに使<br>用できるコンペアマッチ<br>出力が異なります。 | 調歩同期クロックソースセ<br>レクト<br>(調歩同期式モードで CKE1<br>= 1 のときのみ有効)<br>平均転送レートのクロック<br>ソースを選択します。平均<br>転送レート選択時は、<br>ABCS ビットの値に関係な<br>く基本クロックが自動設定<br>されます。<br>000 : 外部クロック入力<br>001 : $\phi = 10.667\text{MHz}$ 専用<br>の平均転送レート<br>115.152kbps を選択<br>(転送レートの 16 倍<br>の周波数の基本ク<br>ロックで動作)<br>010 : $\phi = 10.667\text{MHz}$ 専用<br>の平均転送レート<br>460.606kbps を選択<br>(転送レートの 8 倍の<br>周波数の基本クロッ<br>クで動作)<br>011 : $\phi = 32\text{MHz}$ 専用の平<br>均転送レート<br>720kbps を選択 (転<br>送レートの 16 倍の周<br>波数の基本クロック<br>で動作)<br>100 : 設定禁止<br>101 : $\phi = 16\text{MHz}$ 専用の平<br>均転送レート<br>115.196kbps を選択<br>(転送レートの 16 倍<br>の周波数の基本ク<br>ロックで動作)<br>110 : $\phi = 16\text{MHz}$ 専用の平<br>均転送レート<br>460.784kbps を選択<br>(転送レートの 16 倍<br>の周波数の基本ク<br>ロックで動作)<br>111 : $\phi = 16\text{MHz}$ 専用の平<br>均転送レート<br>720kbps を選択 (転<br>送レートの 8 倍の周<br>波数の基本クロック<br>で動作) |

| レジスタ名                                    |                       | ビット名                 |                       | 説明         |                |
|------------------------------------------|-----------------------|----------------------|-----------------------|------------|----------------|
| RX<br>(RX261)                            | H8S<br>(H8S/2378<br>) | RX<br>(RX261)        | H8S<br>(H8S/<br>2378) | RX (RX261) | H8S (H8S/2378) |
| シリアル拡張モードレジ<br>スタ (SEMR) <sup>(注3)</sup> | ACS0                  | ACS2<br>ACS1<br>ACS0 |                       |            |                |

注 1. 調歩同期式モードのみ有効です。調歩同期式モード以外では、データ長は 8 ビット固定となります。

注 2. データ長 7 ビットでは、 LSB ファースト固定となり、MSB (ビット 7) は送信されません。

注 3. H8S では、チャネル 2 にのみあります。

## 2. 使用する周辺機能

表 2.1 に、シリアルコミュニケーションインターフェースの動作例に対して使用する周辺機能およびモードを示します。

表 2.1 シリアルコミュニケーションインターフェースの動作例に対して使用する周辺機能およびモード

| No | 動作例                      | RX (RX261) |            | H8S (H8S/2378) |            | 参照  |
|----|--------------------------|------------|------------|----------------|------------|-----|
|    |                          | 周辺機能       | モード        | 周辺機能           | モード        |     |
| 1  | クロック同期式シリアル通信 (マスタ送受信動作) | SCI        | クロック同期式モード | SCI            | クロック同期式モード | 3.1 |
| 2  | クロック同期式シリアル通信 (マスタ送信動作)  |            |            |                |            | 3.2 |
| 3  | クロック同期式シリアル通信 (スレーブ受信動作) |            |            |                |            | 3.3 |
| 4  | 調歩同期式シリアル通信 (送信動作)       |            | 調歩同期式モード   |                | 調歩同期式モード   | 4.1 |
| 5  | 調歩同期式シリアル通信 (受信動作)       |            |            |                |            | 4.2 |

### 3. クロック同期式シリアル通信の相違点

本章では RX、H8S のクロック同期式シリアル通信の相違点を記載します。

表 3.1 に RX と H8S におけるクロック同期式シリアル通信の前提条件を示します。

なお、TXD 端子および RXD 端子の外部にプルアップ抵抗による制御をしていることを前提とします。

表 3.1 クロック同期式シリアル通信の条件

| 項目          | 送受信条件         |                |
|-------------|---------------|----------------|
|             | RX (RX261)    | H8S (H8S/2378) |
| 周辺機能の動作クロック | PCLKB : 16MHz | ϕ : 20MHz      |
| 通信速度        | 10kbps        |                |
| データフォーマット   | LSB ファースト     |                |
| ハードウェアフロー制御 | 使用しない         | 機能なし           |
| 使用チャネル      | マスタ           | SCI1           |
|             | スレーブ          | SCI5           |
| 使用端子        | マスタ           | RXD1 : P15     |
|             |               | TXD1 : P26     |
|             |               | SCK1 : P17     |
|             | スレーブ          | RXD0 : P32     |
|             |               | TXD0 : P30     |
|             |               | SCK0 : P34     |
|             |               | RXD1 : P33     |
|             |               | TXD1 : P31     |
|             |               | SCK1 : P35     |

### 3.1 マスタ送受信動作時の相違点

#### 3.1.1 マスタ送受信動作時のタイミング相違点

クロック同期式のマスタ送受信を行う場合の相違点について説明します。

前提条件として、送信割り込み、受信割り込み、受信エラー割り込みを使用した送受信処理とし、受信エラーは未発生とします。

受信エラーが発生した場合の相違点については、「3.3.1 スレーブ受信動作時のタイミングの相違点」を参照してください。





注 1. SCR.TE ビットと SCR.RE ビットは同時に"1"または"0"を書き込んでください。

図 3.1 中の①～⑧の番号は、表 3.2 中の説明①～⑧に対応しています。



注 1. SCR.TE ビットと SCR.RE ビットは同時に"1"または"0"を書き込んでください。

図 3.1 RX と H8S の送受信タイミング相違点 (3 バイトずつ送受信する場合)

表 3.2 RX と H8S の各タイミングでの動作および処理内容の相違点 (3 バイトずつ送受信する場合)

| タイミング                        | RX (RX261)                                                                                                                                                                                                                                                                                               | H8S (H8S/2378)                                                                                                                                                                                                     |
|------------------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| ① 送信開始前                      | 端子の機能を TXDn に設定した状態では、SCR.TE ビットを“1”(送信許可) に設定するまで、TXD 端子はハイインピーダンスになります。 <sup>(注 1)</sup>                                                                                                                                                                                                               | SCR.TE ビットを“1”(送信許可) に設定するまで、TXD 端子は汎用入出力ポートです。                                                                                                                                                                    |
| ② 送受信開始時                     | 割り込み許可にするため、以下のビットを設定します。<br>SCR.TIE ビットを“1”<br>SCR.RIE ビットを“1”<br>TXI 割り込みの IEN ビットを“1”<br>RXI 割り込みの IEN ビットを“1”<br>ERI 割り込みの IEN ビットを“1”<br>また、送受信許可にするため、以下のビットを設定します。<br>SCR.TE ビットを“1”<br>SCR.RE ビットを“1”<br>SCR.TE ビットを“1”にしたことにより、送信割り込み (TXI 割り込み) の IR フラグが“1”になります。送信割り込みで 1 バイト目の送信データを書き込みます。 | 割り込み許可にするため、以下のビットを設定します。<br>SCR.TIE ビットを“1”<br>SCR.RIE ビットを“1”<br>また、送受信許可にするため、以下のビットを設定します。<br>SCR.TE ビットを“1”<br>SCR.RE ビットを“1”<br>SCR.TE ビットを“1”にしたことにより、送信割り込み (TXI 割り込み) が発生します。送信割り込みで 1 バイト目の送信データを書き込みます。 |
| ③ 送信シフトレジスタに 1 バイト目の送信データ転送時 | 送信割り込みの IR フラグが“1”になり、送信割り込みが発生します。送信割り込み処理で、2 バイト目のデータを書き込みます。                                                                                                                                                                                                                                          | SSR.TDRE ビットが 1 になり、送信割り込みが発生します。送信割り込み処理で、2 バイト目のデータを書き込み、SSR.TDRE ビットを“0”に設定します。                                                                                                                                 |
| ④ 受信完了時                      | 1 バイトのデータを受信すると、受信データが受信バッファに取り込まれ、受信割り込み (RXI 割り込み) の IR フラグが“1”になります。受信割り込み処理で、受信バッファから値を読み出します。                                                                                                                                                                                                       | 1 バイトのデータを受信すると、受信データが受信バッファに取り込まれ、SSR.RDRF フラグが“1”になり、受信割り込み (RXI 割り込み) が発生します。受信割り込み処理で、受信バッファから値を読み出し、SSR.RDRF フラグを“0”に設定します。                                                                                   |
| ⑤ 最終データ書き込み時の送信割り込み          | 送信割り込み禁止にするため、以下のビットを設定します。<br>SCR.TIE ビットを“0”<br>TXI 割り込みの IEN ビットを“0”                                                                                                                                                                                                                                  | 送信割り込み禁止にするため、以下のビットを設定します。<br>SCR.TIE ビットを“0”                                                                                                                                                                     |
| ⑥ 最終データ書き込み後                 | 送信割り込みは発生しません。                                                                                                                                                                                                                                                                                           |                                                                                                                                                                                                                    |

| タイミング                | RX (RX261)                                                                                                                                                                                                                                                                          | H8S (H8S/2378)                                                                                                                                                                                       |
|----------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| ⑦ 最終データの受信完了<br>割り込み | <p>受信割り込み処理で、受信データを読み出したあと、割り込み禁止にするため、以下のビットを設定します。</p> <p>SCR.RIE ビットを“0”</p> <p>RXI 割り込みの IEN ビットを“0”</p> <p>ERI 割り込みの IEN ビットを“0”</p> <p>また、送受信禁止にするため、以下のビットを設定します。</p> <p>SCR.TE ビットを“0”</p> <p>SCR.RE ビットを“0”</p> <p>端子の機能を TXD に設定した状態で、送信禁止にすると、TXD 端子がハイインピーダンスになります。</p> | <p>受信割り込み処理で、受信データを読み出したあと、割り込み禁止にするため、以下のビットを設定します。</p> <p>SCR.RIE ビットを“0”</p> <p>また、送受信禁止にするため、以下のビットを設定します。</p> <p>SCR.TE ビットを“0”</p> <p>SCR.RE ビットを“0”</p> <p>送信禁止にすると、TXD 端子は汎用入出力ポートになります。</p> |
| ⑧ 再度送受信開始時           | 「②送受信開始時」と同じ処理を行います。                                                                                                                                                                                                                                                                |                                                                                                                                                                                                      |

注 1. 詳細は、「9.4 トランスマットイネーブルビットに関する注意事項」を参照してください。

## 3.1.2 マスタ送受信動作時の設定手順の相違点

表 3.3 に送受信動作時の初期設定手順の相違点を示します。H8S の初期設定手順は、割り込み制御モード 2 を使用する場合の手順を示します。

表 3.4 に送受信動作時の送信割り込み処理内容の相違点を示します。表 3.5 に送受信動作時の受信割り込み処理内容の相違点を示します。

表 3.3 送受信動作時の初期設定手順の相違点

| 手順 |                                | RX (RX261)                                                                                                                                                                                                                                                                                                                                                                                      | H8S (H8S/2378)                                                             |
|----|--------------------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|----------------------------------------------------------------------------|
| 1  | モジュールストップ状態を解除 <sup>(注1)</sup> | SYSTEM.PRCR.WORD = 0xA502;<br>MSTPCR(SCI1) = 0;<br>SYSTEM.PRCR.WORD = 0xA500;                                                                                                                                                                                                                                                                                                                   | MSTPCR.BIT._SCI0 = 0;                                                      |
| 2  | 送受信・割り込み禁止                     | SCI1.SCR.BYTE = 0x00;                                                                                                                                                                                                                                                                                                                                                                           | SCI0.SCR.BYTE = 0x00;                                                      |
| 3  | I/O ポート機能の設定 <sup>(注2)</sup>   | PORT1.PMR.BIT.B5 = 0;<br>PORT2.PMR.BIT.B6 = 0;<br>PORT1.PMR.BIT.B7 = 0;<br>MPC.PWPR.BIT.B0WI = 0;<br>MPC.PWPR.BIT.PFSWE = 1;<br>MPC.P15PFS.BYTE = 0x0A;<br>MPC.P26PFS.BYTE = 0x0A;<br>MPC.P17PFS.BYTE = 0x0A;<br>MPC.PWPR.BIT.PFSWE = 0;<br>MPC.PWPR.BIT.B0WI = 1;<br>PORT1.PMR.BIT.B5 = 1;<br>PORT2.PDR.BIT.B6 = 1;<br>PORT2.PDR.BIT.B6 = 1;<br>PORT2.PMR.BIT.B6 = 1;<br>PORT1.PMR.BIT.B7 = 1; | —<br>(処理なし)                                                                |
| 4  | 送受信モード等の設定                     | SCI1.SCR.BIT.CKE = 00b;<br>SCI1.SIMR1.BYTE = 0x00;<br>SCI1.SPMR.BYTE = 0x00;<br>SCI1.SMR.BYTE = 0x81;<br>SCI1.SCMR.BYTE = 0xF2;<br>SCI1.SEMR.BYTE = 0x00;                                                                                                                                                                                                                                       | SCI0.SCR.BIT.CKE = 00b;<br>SCI0.SMR.BYTE = 0x81;<br>SCI0.SCMR.BYTE = 0xF2; |
| 5  | ビットレートの設定 <sup>(注3)</sup>      | SCI1.BRR = 0x63                                                                                                                                                                                                                                                                                                                                                                                 | SCI0.BRR = 0x7C;                                                           |
| 6  | 1 ビット期間ウェイト                    | —<br>(処理なし)                                                                                                                                                                                                                                                                                                                                                                                     | 1 ビット期間ウェイト処理                                                              |
| 7  | 割り込み制御モード設定 <sup>(注4)</sup>    | —<br>(処理なし)                                                                                                                                                                                                                                                                                                                                                                                     | INTC.INTCR.BIT.INTM = 10b;                                                 |
| 8  | 割り込み優先レベル設定 <sup>(注5)</sup>    | IPR(SCI1, ) = 0x01;                                                                                                                                                                                                                                                                                                                                                                             | INTC.IPRI.BIT._SCI0 = 001b;                                                |
| 9  | 割り込み要求をクリア                     | IR(SCI1,TXI1) = 0;<br>IR(SCI1,RXI1) = 0;<br>IR(SCI1,ERI1) = 0;                                                                                                                                                                                                                                                                                                                                  | —<br>(処理なし)                                                                |
| 10 | 周辺機能割り込み要求を許可                  | SCI1.SCR.BYTE  = 0xF0; /* <sup>(注6)</sup> */                                                                                                                                                                                                                                                                                                                                                    | SCI0.SCR.BYTE  = 0xF0; /* <sup>(注6)</sup> */                               |
| 11 | 送受信許可                          |                                                                                                                                                                                                                                                                                                                                                                                                 |                                                                            |
| 12 | 割り込み要求を許可 <sup>(注7)</sup>      | IEN(SCI1,TXI1) = 1;<br>IEN(SCI1,RXI1) = 1;<br>IEN(SCI1,ERI1) = 1; /* <sup>(注8)</sup> */                                                                                                                                                                                                                                                                                                         | —<br>(処理なし)                                                                |

| 手順                      | RX (RX261)  | H8S (H8S/2378)    |
|-------------------------|-------------|-------------------|
| 13 プロセッサ割り込み優先<br>レベル設定 | —<br>(処理なし) | set_imask_exr(0); |
| 14 マスカブル割り込みの<br>許可     | setpsw_i(); | —<br>(処理なし)       |

- 注 1. モジュールストップ機能については、「7. モジュールストップ機能」を参照してください。
- 注 2. RX では MPC で周辺機能の端子設定を行います。詳細は「9.1 入出力ポート」を参照してください。
- 注 3. ビットレートの詳細は、「5. ビットレートの算出方法」を参照してください。
- 注 4. RX には割り込み制御モードはありません。詳細は「6. 割り込みの相違点」を参照してください。
- 注 5. 割り込み優先レベルの設定方法の詳細は、「6. 割り込みの相違点」を参照してください。
- 注 6. SCR.TE ビットと SCR.RE ビットは同時に“1”(送信許可、受信許可)にしてください。
- 注 7. 割り込み要求を許可にする方法が異なります。詳細は「6. 割り込みの相違点」を参照してください。
- 注 8. 受信エラー割り込みの仕様はマイコンにより異なります。詳細はユーザーズマニュアル ハードウェア編を参照してください。

表 3.4 送受信動作時の送信割り込み処理内容の相違点

| 手順                          | RX (RX261)                                                                             | H8S (H8S/2378)                                                       |
|-----------------------------|----------------------------------------------------------------------------------------|----------------------------------------------------------------------|
| 1 TDRE フラグリード               | —<br>(処理なし)                                                                            | if(SCI0.SSR.BIT.TDRE == 1)<br>{                                      |
| 2 送信データの書き込み                | /* SCI1.TDR レジスタに送信データを書き込む */                                                         | /* SCI0.TDR レジスタに送信データを書き込む */                                       |
| 3 TDRE フラグクリア               | —<br>(処理なし)                                                                            | SCI0.SSR.BIT.TDRE = 0;                                               |
| 4 最終データ書き込み確認               | if(最終データ書き込み済み?)<br>{                                                                  | if(最終データ書き込み済み?)<br>{                                                |
| 5 送信割り込み禁止 (最終データ書き込み後のみ)   | IEN(SCI1,TXI1) = 0;<br>SCI1.SCR.BIT.TIE = 0;<br>while(0 != SCI1.SCR.BIT.TIE)<br>{<br>} | SCI0.SCR.BIT.TIE = 0;<br>while(0 != SCI1.SCR.BIT.TIE)<br>{<br>}<br>} |
| 6 割り込み要求をクリア (最終データ書き込み後のみ) | IR(SCI1,TXI1) = 0;<br>while(0 != IR(SCI1,TXI1))<br>{<br>}                              | —<br>(処理なし)                                                          |

表 3.5 送受信動作時の受信割り込み処理内容の相違点

| 手順 |                                | RX (RX261)                                                                                                       | H8S (H8S/2378)                                                                            |
|----|--------------------------------|------------------------------------------------------------------------------------------------------------------|-------------------------------------------------------------------------------------------|
| 1  | RDRF フラグリード                    | —<br>(処理なし)                                                                                                      | if(SCI0.SSR.BIT.RDRF == 1)<br>{                                                           |
| 2  | 受信データの読み出し                     | /* SCI1.RDR レジスタから受信データを読み出し */                                                                                  | /* SCI0.RDR レジスタから受信データを読み出し */                                                           |
| 3  | RDRF フラグクリア                    | —<br>(処理なし)                                                                                                      | SCI0.SSR.BIT.RDRF = 0;                                                                    |
| 4  | 最終データの受信確認                     | if( 最終データの受信? )<br>{                                                                                             | if( 最終データの受信? )<br>{                                                                      |
| 5  | 送受信禁止および受信割り込みの禁止 (最終データ受信後のみ) | IEN(SCI1,RXI1) = 0;<br>SCI1.SCR.BYTE &= 0x0B; <sup>(注1)</sup><br>while(0x00 != (SCI1.SCR.BYTE & 0xF4))<br>{<br>} | SCI0.SCR.BYTE &= 0x0B; <sup>(注1)</sup><br>while(0x00 != (SCI0.SCR.BYTE & 0xF4))<br>{<br>} |
| 6  | 割り込み要求をクリア (最終データ書き込み後のみ)      | IR(SCI1,RXI1) = 0;<br>while(0 != IR(SCI1,RXI1))<br>{<br>}                                                        | —<br>(処理なし)                                                                               |

注 1. SCR.TE ビットと SCR.RE ビットは同時に"0"(送信禁止、受信禁止)にしてください。

### 3.2 マスタ送信動作時の相違点

クロック同期式のマスタ送信を行う場合の相違点について説明します。

前提条件とし、送信割り込み、送信終了割り込みを使用した送信処理とします。

#### 3.2.1 マスタ送信動作時のタイミングの相違点



図 3.2 に、RX と H8S の送信タイミング相違点(3 バイトずつ送信する場合)を示します。

表 3.6 に、RX と H8S の各タイミングでの動作および処理内容の相違点(3 バイトずつ送信する場合)を示します。



図 3.2 中の①～⑧の番号は、表 3.6 中の説明①～⑧に対応しています。



図 3.2 RX と H8S の送信タイミング相違点 (3 バイトずつ送信する場合)

表 3.6 RX と H8S の各タイミングでの動作および処理内容の相違点 (3 バイトずつ送信する場合)

| タイミング                        | RX (RX261)                                                                                                                                                                                                       | H8S (H8S/2378)                                                                                                                                                                |
|------------------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| ① 送信開始前                      | 端子の機能を TXDn に設定した状態では、SCR.TE ビットを“1”(送信許可) に設定するまで、TXD 端子はハイインピーダンスになります。 <sup>(注 1)</sup>                                                                                                                       | SCR.TE ビットを“1”(送信許可) に設定するまで、TXD 端子は汎用入出力ポートです。                                                                                                                               |
| ② 送信開始時                      | 割り込み許可にするため、以下のビットを設定します。<br>SCR.TIE ビットを“1”<br>TXI 割り込みの IEN ビットを“1”<br>また、送信許可にするため、以下のビットを設定します。<br>SCR.TE ビットを“1”<br>SCR.TE ビットを“1”にしたことにより、送信割り込み (TXI 割り込み) の IR フラグが“1”になります。送信割り込みで 1 バイト目の送信データを書き込みます。 | 割り込み許可にするため、以下のビットを設定します。<br>SCR.TIE ビットを“1”<br>また、送受信許可にするため、以下のビットを設定します。<br>SCR.TE ビットを“1”<br>SCR.TE ビットを“1”にしたことにより、送信割り込み (TXI 割り込み) が発生します。送信割り込みで 1 バイト目の送信データを書き込みます。 |
| ③ 送信シフトレジスタに 1 バイト目の送信データ転送時 | 送信割り込みの IR フラグが“1”になり、送信割り込みが発生します。送信割り込み処理で、2 バイト目のデータを書き込みます。                                                                                                                                                  | SSR.TDRE フラグが“1”になり、送信割り込みが発生します。送信割り込み処理で、2 バイト目のデータを書き込み、SSR.TDRE フラグを“0”に設定します。                                                                                            |
| ④ 最終データ書き込み時の送信割り込み          | 送信割り込み禁止にするため、以下のビットを設定します。<br>SCR.TIE ビットを“0”<br>TXI 割り込みの IEN ビットを“0”<br>また、送信終了割込み許可にするため、以下のビットを設定します。<br>SCR.TEIE ビットを“1”<br>TEI 割り込みの IEN ビットを“1”                                                          | 送信割り込み禁止にするため、以下のビットを設定します。<br>SCR.TIE ビットを“0”<br>また、送信終了割込み許可にするため、以下のビットを設定します。<br>SCR.TEIE ビットを“1”                                                                         |
| ⑤ 最終データ書き込み後                 | 送信割り込みは発生しません。                                                                                                                                                                                                   |                                                                                                                                                                               |
| ⑥ 送信終了時                      | 送信終了割り込みが発生します。                                                                                                                                                                                                  |                                                                                                                                                                               |
| ⑦ 送信終了割り込み処理                 | 送信終了割り込み禁止にするため、以下のビットを設定します。<br>SCR.TEIE ビットを“0”<br>送信終了割り込みの IEN ビットを“0”<br>また、送信禁止にするため、以下のビットを設定します。<br>SCR.TE ビットを“0”<br>端子の機能を TXD に設定した状態で、送信禁止にすると、TXD 端子がハイインピーダンスになります。                                | 送信終了割り込み禁止にするため、以下のビットを設定します。<br>SCR.TEIE ビットを“0”<br>また、送信禁止にするため、以下のビットを設定します。<br>SCR.TE ビットを“0”<br>送信禁止にすると、TXD 端子は汎用入出力ポートになります。                                           |
| ⑧ 再度送信開始時                    | 「②送信開始時」と同じ処理を行います。                                                                                                                                                                                              |                                                                                                                                                                               |

注 1. 詳細は、「9.4 トランスマッティネーブルビットに関する注意事項」を参照してください。

## 3.2.2 マスタ送信動作時の設定手順の相違点

表 3.7 に送信動作時の初期設定手順の相違点を示します。H8S の初期設定手順は、割り込み制御モード 2 を使用する場合の手順を示します。

表 3.8 に送信動作時の送信割り込み処理内容の相違点を示します。

表 3.9 に送信動作時の送信終了割り込み処理内容の相違点を示します。

表 3.7 送信動作時の初期設定手順の相違点

| 手順                                | RX (RX261)                                                                                                                                                                                                                                                                                                                | H8S (H8S/2378)                                                             |
|-----------------------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|----------------------------------------------------------------------------|
| 1 モジュールストップ状態を解除 <sup>(注 1)</sup> | SYSTEM.PRCR.WORD = 0xA502;<br>MSTPCR(SCI1) = 0;<br>SYSTEM.PRCR.WORD = 0xA500;                                                                                                                                                                                                                                             | MSTPCR.BIT._SCI0 = 0;                                                      |
| 2 送受信・割り込み禁止                      | SCI1.SCR.BYTE = 0x00;                                                                                                                                                                                                                                                                                                     | SCI0.SCR.BYTE = 0x00;                                                      |
| 3 I/O ポート機能の設定 <sup>(注 2)</sup>   | PORTR2.PMR.BIT.B6 = 0;<br>PORTR1.PMR.BIT.B7 = 0;<br>MPC.PWPR.BIT.B0WI = 0;<br>MPC.PWPR.BIT.PFSWE = 1;<br>MPC.P26PFS.BYTE = 0x0A;<br>MPC.P17PFS.BYTE = 0x0A;<br>MPC.PWPR.BIT.PFSWE = 0;<br>MPC.PWPR.BIT.B0WI = 1;<br>PORTR2.PODR.BIT.B6 = 1;<br>PORTR2.PDR.BIT.B6 = 1;<br>PORTR2.PMR.BIT.B6 = 1;<br>PORTR1.PMR.BIT.B7 = 1; | —<br>(処理なし)                                                                |
| 4 送信モード等の設定                       | SCI1.SCR.BIT.CKE = 00b;<br>SCI1.SIMR1.BYTE = 0x00;<br>SCI1.SPMR.BYTE = 0x00;<br>SCI1.SMR.BYTE = 0x81;<br>SCI1.SCMR.BYTE = 0xF2;<br>SCI1.SEMR.BYTE = 0x00;                                                                                                                                                                 | SCI0.SCR.BIT.CKE = 00b;<br>SCI0.SMR.BYTE = 0x81;<br>SCI0.SCMR.BYTE = 0xF2; |
| 5 ビットレートの設定 <sup>(注 3)</sup>      | SCI1.BRR = 0x63;                                                                                                                                                                                                                                                                                                          | SCI0.BRR = 0x7C;                                                           |
| 6 1 ビット期間ウェイト                     | —<br>(処理なし)                                                                                                                                                                                                                                                                                                               | 1 ビット期間ウェイト処理                                                              |
| 7 割り込み制御モード設定 <sup>(注 4)</sup>    | —<br>(処理なし)                                                                                                                                                                                                                                                                                                               | INTC.INTCR.BIT.INTM = 10b;                                                 |
| 8 割り込み優先レベル設定 <sup>(注 5)</sup>    | IPR(SCI1, ) = 0x01;                                                                                                                                                                                                                                                                                                       | INTC.IPRI.BIT._SCI0 = 001b;                                                |
| 9 割り込み要求をクリア                      | IR(SCI1, TXI1) = 0;<br>IR(SCI1, TEI1) = 0;                                                                                                                                                                                                                                                                                | —<br>(処理なし)                                                                |
| 10 周辺機能割り込み要求を許可                  | SCI1.SCR.BYTE  = 0xA0;                                                                                                                                                                                                                                                                                                    | SCI0.SCR.BYTE  = 0xA0;                                                     |
| 11 送信許可                           |                                                                                                                                                                                                                                                                                                                           |                                                                            |
| 12 割り込み要求を許可 <sup>(注 6)</sup>     | IEN(SCI1, TXI1) = 1;<br>IEN(SCI1, TEI1) = 1;                                                                                                                                                                                                                                                                              | —<br>(処理なし)                                                                |
| 13 プロセッサ割り込み優先レベル設定               | —<br>(処理なし)                                                                                                                                                                                                                                                                                                               | set_imask_exr(0);                                                          |
| 14 マスカブル割り込みの許可                   | setpsw_i();                                                                                                                                                                                                                                                                                                               | —<br>(処理なし)                                                                |

注 1. モジュールストップ機能については、「7. モジュールストップ機能」を参照してください。

- 注 2. RX では MPC で周辺機能の端子設定を行います。詳細は「9.1 入出力ポート」を参照してください。
- 注 3. ビットレートの詳細は、「5. ビットレートの算出方法」を参照してください。
- 注 4. RX には割り込み制御モードはありません。詳細は「6. 割り込みの相違点」を参照してください。
- 注 5. 割り込み優先レベルの設定方法の詳細は、「6. 割り込みの相違点」を参照してください。
- 注 6. 割り込み要求を許可にする方法が異なります。詳細は「6. 割り込みの相違点」を参照してください。

表 3.8 送信動作時の送信割り込み処理内容の相違点

| 手順 |                                   | RX (RX261)                                                                             | H8S (H8S/2378)                                                  |
|----|-----------------------------------|----------------------------------------------------------------------------------------|-----------------------------------------------------------------|
| 1  | TDRE フラグリード                       | —<br>(処理なし)                                                                            | if(SCI0.SSR.BIT.TDRE == 1)<br>{                                 |
| 2  | 送信データの書き込み                        | /* SCI1.TDR レジスタに送信データ<br>を書き込む */                                                     | /* SCI0.TDR レジスタに送信データ<br>を書き込む */                              |
| 3  | TDRE フラグクリア                       | —<br>(処理なし)                                                                            | SCI0.SSR.BIT.TDRE = 0;                                          |
| 4  | 最終データ書き込み確認                       | if(最終データ書き込み済み?)<br>{                                                                  | if(最終データ書き込み済み?)<br>{                                           |
| 5  | 送信割り込みの禁止 (最<br>終データ書き込み後のみ)      | IEN(SCI1,TXI1) = 0;<br>SCI1.SCR.BIT.TIE = 0;<br>while(0 != SCI1.SCR.BIT.TIE)<br>{<br>} | SCI0.SCR.BIT.TIE = 0;<br>while(0 != SCI0.SCR.BIT.TIE)<br>{<br>} |
| 6  | 割り込み要求をクリア<br>(最終データ書き込み後<br>のみ)  | IR(SCI1,TXI1) = 0;<br>while(0 != IR(SCI1,TXI1))<br>{<br>}                              | —<br>(処理なし)                                                     |
| 7  | 送信終了割り込みを許可<br>(最終データ書き込み後<br>のみ) | SCI1.SCR.BIT.TEIE = 1;<br>IEN(SCI1,TEI1) = 1;<br>}                                     | SCI0.SCR.BIT.TEIE = 1;<br>}                                     |

表 3.9 送信動作時の送信終了割り込み処理内容の相違点

| 手順 |                  | RX (RX261)                                                                                          | H8S (H8S/2378)                                                               |
|----|------------------|-----------------------------------------------------------------------------------------------------|------------------------------------------------------------------------------|
| 1  | 送信および割り込みの禁<br>止 | IEN(SCI1,TEI1) = 0;<br>SCI1.SCR.BYTE &= 0x0B;<br>while(0x00 != (SCI1.SCR.BYTE &<br>0xF4))<br>{<br>} | SCI0.SCR.BYTE &= 0x0B;<br>while(0x00 != (SCI0.SCR.BYTE &<br>0xF4))<br>{<br>} |
| 2  | 割り込み要求をクリア       | IR(SCI1,TEI1) = 0;<br>while(0 != IR(SCI1,TEI1))<br>{<br>}                                           | -<br>(処理なし) <sup>(注1)</sup>                                                  |

注 1. SCR.TEIE ビットを"0"に設定すると、送信終了割り込み要求はクリアされます。

### 3.3 スレーブ受信動作時の相違点

クロック同期式のスレーブ受信を行う場合の相違点について説明します。

前提条件として、受信割り込み、受信エラー割り込みを使用した受信処理とし、データ受信中に他の割り込みにより受信割り込みが待たされ、オーバランエラーが発生する例を示します。

#### 3.3.1 スレーブ受信動作時のタイミングの相違点



図 3.3 に RX と H8S のタイミング相違点 (受信時) を示します。

表 3.10 に RX と H8S の各タイミングでの動作および処理内容の相違点 (受信時) を示します。



図 3.3 中の①～⑥の番号は、表 3.10 中の説明①～⑥に対応しています。



図 3.3 RX と H8S のタイミング相違点 (受信時)

表 3.10 RX と H8S の各タイミングでの動作および処理内容の相違点 (受信時)

| タイミング          | RX (RX261)                                                                                                                                  | H8S (H8S/2378)                                                                                                                   |
|----------------|---------------------------------------------------------------------------------------------------------------------------------------------|----------------------------------------------------------------------------------------------------------------------------------|
| ① 受信許可設定       | 割り込み許可にするため、以下のビットを設定します。<br>SCR.RIE ビットを“1”<br>RXI 割り込みの IEN ビットを“1”<br>ERI 割り込みの IEN ビットを“1”<br>受信許可にするため、以下のビットを設定します。<br>SCR.RE ビットを“1” | 割り込み許可にするため、以下のビットを設定します。<br>SCR.RIE ビットを“1”<br>受信許可にするため、以下のビットを設定します。<br>SCR.RE ビットを“1”                                        |
| ② 受信開始         | SCK 端子にクロックが入力されると、受信動作を開始します。                                                                                                              | SCK 端子にクロックが入力されると、受信動作を開始します。                                                                                                   |
| ③ 受信完了時        | 1 バイトのデータを受信すると、受信データが受信バッファに取り込まれ、受信割り込み (RXI 割り込み) の IR フラグが“1”になり、受信割り込みが発生します。受信割り込み処理で、受信バッファから値を読み出します。                               | 1 バイトのデータを受信すると、受信データが受信バッファに取り込まれ、SSR.RDRF フラグが“1”になり、受信割り込み (RXI 割り込み) が発生します。受信割り込み処理で、受信バッファから値を読み出し、SSR.RDRF フラグを“0”に設定します。 |
| ④ 受信エラー発生時     | オーバランエラー発生時、受信エラー割り込み (ERI 割り込み) の IR フラグが“1”になります。ERI 割り込み処理で、受信エラー処理を行います。                                                                | オーバランエラー発生時、SSR.ORER フラグが“1”になり、ERI 割り込みが発生します。ERI 割り込み処理で、受信エラー処理を行います。                                                         |
| ⑤ 受信エラーフラグのクリア | SSR レジスタのオーバランエラーフラグを読み出し後、“0”を書き込み、エラーフラグをクリアします。                                                                                          | SSR レジスタのオーバランエラーフラグを読み出し後、“0”を書き込み、エラーフラグをクリアします。                                                                               |
| ⑥ 再度受信許可設定時    | 全てのエラーフラグをクリアすると、ERI 割り込みの IR フラグが“0”になり、受信許可状態となります。                                                                                       | 全てのエラーフラグをクリアすると、受信許可状態となります。                                                                                                    |

## 3.3.2 スレーブ受信動作時の設定手順の相違点

表 3.11 に、受信動作時の初期設定手順の相違点を示します。H8S の初期設定手順は、割り込み制御モード 2 を使用する場合の手順を示します。

表 3.12 に、受信動作時の受信割り込み処理内容の相違点を示します。

表 3.13 に、受信動作時の ERI 割り込み処理内容の相違点を示します。

表 3.11 受信動作時の初期設定手順の相違点

| 手順 |                                | RX (RX261)                                                                                                                                                                                                                                                       | H8S (H8S/2378)                                                            |
|----|--------------------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|---------------------------------------------------------------------------|
| 1  | モジュールストップ状態を解除 <sup>(注1)</sup> | SYSTEM.PRCR.WORD = 0xA502;<br>MSTPCR(SCI5) = 0;<br>SYSTEM.PRCR.WORD = 0xA500;                                                                                                                                                                                    | MSTPCR.BIT._SCI1 = 0;                                                     |
| 2  | 送受信・割り込み禁止                     | SCI5.SCR.BYTE = 0x00;                                                                                                                                                                                                                                            | SCI1.SCR.BYTE = 0x00;                                                     |
| 3  | I/O ポート機能の設定 <sup>(注2)</sup>   | PORTA.PMR.BIT.B3 = 0;<br>PORTA.PMR.BIT.B1 = 0;<br>MPC.PWPR.BIT.B0WI = 0;<br>MPC.PWPR.BIT.PFSWE = 1;<br>MPC.PA3PFS.BYTE = 0x0A;<br>MPC.PA1PFS.BYTE = 0x0A;<br>MPC.PWPR.BIT.PFSWE = 0;<br>MPC.PWPR.BIT.B0WI = 1;<br>PORTA.PMR.BIT.B3 = 1;<br>PORTA.PMR.BIT.B1 = 1; | —<br>(処理なし)                                                               |
| 4  | 受信モード等の設定                      | SCI5.SCR.BIT.CKE = 10b;<br>SCI5.SIMR1.BYTE = 0x00;<br>SCI5.SPMR.BYTE = 0x00;<br>SCI5.SMR.BIT.CM = 1;<br>SCI5.SCMR.BYTE = 0xF2;<br>SCI5.SEMR.BYTE = 0x00;                                                                                                         | SCI1.SCR.BIT.CKE = 10b;<br>SCI1.SMR.BIT.CA = 1;<br>SCI1.SCMR.BYTE = 0xF2; |
| 5  | 1 ビット期間ウェイト                    | —<br>(処理なし)                                                                                                                                                                                                                                                      | 1 ビット期間ウェイト処理                                                             |
| 6  | 割り込み制御モード設定 <sup>(注3)</sup>    | —<br>(処理なし)                                                                                                                                                                                                                                                      | INTC.INTCR.BIT.INTM = 10b;                                                |
| 7  | 割り込み優先レベル設定 <sup>(注4)</sup>    | IPR(SCI5, ) = 0x01;                                                                                                                                                                                                                                              | INTC.IPRI.BIT._SCI1 = 001b;                                               |
| 8  | 割り込み要求をクリア                     | IR(SCI5,RXI5) = 0;                                                                                                                                                                                                                                               | —<br>(処理なし)                                                               |
| 9  | 周辺機能割り込み要求を許可                  | SCI5.SCR.BYTE  = 0x50;                                                                                                                                                                                                                                           | SCI1.SCR.BYTE  = 0x50;                                                    |
| 10 | 送受信許可                          |                                                                                                                                                                                                                                                                  |                                                                           |
| 11 | 割り込み要求を許可 <sup>(注5)</sup>      | IEN(SCI5,RXI5) = 1;<br>IEN(SCI5,ERI5) = 1; /* <sup>(注6)</sup> */                                                                                                                                                                                                 | —<br>(処理なし)                                                               |
| 12 | プロセッサ割り込み優先レベル設定               | —<br>(処理なし)                                                                                                                                                                                                                                                      | set_imask_exr(0);                                                         |
| 13 | マスカブル割り込みの許可                   | setpsw_i();                                                                                                                                                                                                                                                      | —<br>(処理なし)                                                               |

注 1. モジュールストップ機能については、「7. モジュールストップ機能」を参照してください。

注 2. RX では MPC で周辺機能の端子設定を行います。詳細は「9.1 入出力ポート」を参照してください。

注 3. RX には割り込み制御モードはありません。詳細は「6. 割り込みの相違点」を参照してください。

注 4. 割り込み優先レベルの設定方法の詳細は、「6. 割り込みの相違点」を参照してください。

注 5. 割り込み要求を許可にする方法が異なります。詳細は「6. 割り込みの相違点」を参照してください。

注 6. 受信エラー割り込みの仕様はマイコンにより異なります。詳細はユーザーズマニュアル ハードウェア編を参照してください。

表 3.12 受信動作時の受信割り込み処理内容の相違点

| 手順 |                              | RX (RX261)                                                                                                                  | H8S (H8S/2378)                                                                         |
|----|------------------------------|-----------------------------------------------------------------------------------------------------------------------------|----------------------------------------------------------------------------------------|
| 1  | RDRF フラグリード                  | —<br>(処理なし)                                                                                                                 | if(SCI1.SSR.BIT.RDRF == 1)<br>{                                                        |
| 2  | 受信データの読み出し                   | /* SCI5.RDR レジスタから受信データを読み出し */                                                                                             | /* SCI1.RDR レジスタから受信データを読み出し */                                                        |
| 3  | RDRF フラグクリア                  | —<br>(処理なし)                                                                                                                 | SCI1.SSR.BIT.RDRF = 0;                                                                 |
| 4  | 最終データ受信確認                    | if(最終データの受信?)<br>{                                                                                                          | if(最終データの受信?)<br>{                                                                     |
| 5  | 受信および割り込みの禁止<br>(最終データ受信後のみ) | IEN(SCI5,RXI5) = 0;<br>IEN(SCI5,ERI5) = 0;<br>SCI5.SCR.BYTE &= 0x0B;<br>while(0x00 != (SCI5.SCR.BYTE<br>& 0xF4))<br>{<br>}  | SCI1.SCR.BYTE &= 0x0B;<br>while(0x00 != (SCI1.SCR.BYTE<br>& 0xF4))<br>{<br>}<br>}<br>} |
| 6  | 割り込み要求をクリア                   | IR(SCI5,RXI5) = 0;<br>while(0 != IR(SCI5,RXI5))<br>{<br>}<br>IR(SCI5,ERI5) = 0;<br>while(0 != IR(SCI5,ERI5))<br>{<br>}<br>} | —<br>(処理なし)                                                                            |

表 3.13 受信動作時の ERI 割り込み処理内容の相違点

| 手順 |               | RX (RX261)                                                                                                              | H8S (H8S/2378)                                                            |
|----|---------------|-------------------------------------------------------------------------------------------------------------------------|---------------------------------------------------------------------------|
| 1  | ORER フラグリード   | dummy = SCI5.SSR.BIT.ORER;<br>/* (注 1) */                                                                               | dummy = SCI1.SSR.BIT.ORER;<br>/* (注 1) */                                 |
| 2  | 受信エラー発生時の処理   | if(dummy== 1)<br>{                                                                                                      | if(dummy== 1)<br>{                                                        |
| 3  | 受信バッファのダミーリード | dummy_data = SCI5.RDR;                                                                                                  | —<br>(処理なし)                                                               |
| 4  | エラー処理         | /* オーバランエラー時の処理を記載 */                                                                                                   | /* オーバランエラー時の処理を記載 */                                                     |
| 5  | 受信および割り込みの禁止  | IEN(SCI5,RXI5) = 0;<br>IEN(SCI5,ERI5) = 0;<br>SCI5.SCR.BYTE &= 0x0B;<br>while(0x00 != (SCI5.SCR.BYTE & 0xF4))<br>{<br>} | SCI1.SCR.BYTE &= 0x0B;<br>while(0x00 != (SCI1.SCR.BYTE & 0xF4))<br>{<br>} |
| 6  | ORER フラグクリア   | SCI5.SSR.BIT.ORER = 0;<br>while(0 != SCI5.SSR.BIT.ORER)<br>{<br>}                                                       | SCI1.SSR.BIT.ORER = 0;<br>while(0 != SCI1.SSR.BIT.ORER)<br>{<br>}         |
| 7  | 割り込み要求をクリア    | IR(SCI5,RXI5) = 0;<br>while(0 != IR(SCI5,RXI5))<br>{<br>}<br>IR(SCI5,ERI5) = 0;<br>while(0 != IR(SCI5,ERI5))<br>{<br>}  | —<br>(処理なし)                                                               |

注 1. ORER フラグ (オーバランエラーフラグ) をクリアする場合は、事前に“1”的状態を読み出してください。

#### 4. 調歩同期式シリアル通信の相違点

本章では RX、H8S の調歩同期式シリアル通信の相違点を記載します。

表 4.1 に RX と H8S における調歩同期式シリアル通信の前提条件を示します。

なお、TXD 端子および RXD 端子の外部にプルアップ抵抗による制御をしていることを前提とします。

表 4.1 調歩同期式シリアル通信の条件

| 項目          | 送受信条件                    |                          |
|-------------|--------------------------|--------------------------|
|             | RX (RX261)               | H8S (H8S/2378)           |
| 周辺機能の動作クロック | PCLKB : 16MHz            | $\phi$ : 20MHz           |
| 通信速度        | 9600bps                  |                          |
| データ長        | 8 ビット                    |                          |
| parity      | なし                       |                          |
| ストップビット     | 1 ビット                    |                          |
| データフォーマット   | LSB ファースト                |                          |
| ハードウェアフロー制御 | 使用しない                    | 機能なし                     |
| 使用チャネル      | SCI5                     | チャネル 0                   |
| 使用端子        | RXD5 : PA3<br>TXD5 : PA4 | RXD0 : P32<br>TXD0 : P30 |

## 4.1 送信動作時の相違点

調歩同期式シリアル通信における、送信処理を行う場合の相違点について説明します。

前提条件として、送信割り込み、送信終了割り込みを使用します。

### 4.1.1 送信動作時のタイミング相違点



図 4.1 に、RX と H8S の送信タイミング相違点 (3 バイトずつ送信する場合) を示します。表 4.2 に、RX と H8S の各タイミングでの動作および処理内容の相違点 (3 バイトずつ送信する場合) を示します。



図 4.1 中の①～⑧の番号は、表 4.2 中の説明①～⑧に対応しています。



図 4.1 RX と H8S の送信タイミング相違点 (3 バイトずつ送信する場合)

表 4.2 RX と H8S の各タイミングでの動作および処理内容の相違点 (3 バイトずつ送信する場合)

| タイミング                        | RX (RX261)                                                                                                                                                                                                       | H8S (H8S/2378)                                                                                                                                                               |
|------------------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| ① 送信開始前                      | 端子の機能を TXDn に設定した状態では、SCR.TE ビットを“1”(送信許可) に設定するまで、TXD 端子はハイインピーダンスになります。 <sup>(注 1)</sup>                                                                                                                       | SCR.TE ビットを“1”(送信許可) に設定するまで、TXD 端子は汎用入出力ポートです。                                                                                                                              |
| ② 送信開始時                      | 割り込み許可にするため、以下のビットを設定します。<br>SCR.TIE ビットを“1”<br>TXI 割り込みの IEN ビットを“1”<br>また、送信許可にするため、以下のビットを設定します。<br>SCR.TE ビットを“1”<br>SCR.TE ビットを“1”にしたことにより、送信割り込み (TXI 割り込み) の IR フラグが“1”になります。送信割り込みで 1 バイト目の送信データを書き込みます。 | 割り込み許可にするため、以下のビットを設定します。<br>SCR.TIE ビットを“1”<br>また、送信許可にするため、以下のビットを設定します。<br>SCR.TE ビットを“1”<br>SCR.TE ビットを“1”にしたことにより、送信割り込み (TXI 割り込み) が発生します。送信割り込みで 1 バイト目の送信データを書き込みます。 |
| ③ 送信シフトレジスタに 1 バイト目の送信データ転送時 | 送信割り込みの IR フラグが“1”になり、送信割り込みが発生します。送信割り込み処理で、2 バイト目のデータを書き込みます。                                                                                                                                                  | SSR.TDRE ビットが“1”になり、送信割り込みが発生します。送信割り込み処理で、2 バイト目のデータを書き込み、SSR.TDRE ビットを“0”に設定します。                                                                                           |
| ④ 最終データ書き込み時の送信割り込み          | 送信割り込み禁止にするため、以下のビットを設定します。<br>SCR.TIE ビットを“0”<br>TXI 割り込みの IEN ビットを“0”<br>また、送信終了割り込み許可にするため、以下のビットを設定します。<br>SCR.TEIE ビットを“1”<br>TEI 割り込みの IEN ビットを“1”                                                         | 送信割り込み禁止にするため、以下のビットを設定します。<br>SCR.TIE ビットを“0”<br>また、送信終了割り込み許可にするため、以下のビットを設定します。<br>SCR.TEIE ビットを“1”                                                                       |
| ⑤ 最終データ書き込み後                 | 送信割り込みは発生しません。                                                                                                                                                                                                   |                                                                                                                                                                              |
| ⑥ 送信終了時                      | 送信終了割り込みが発生します。                                                                                                                                                                                                  |                                                                                                                                                                              |
| ⑦ 送信終了割り込み処理                 | 送信終了割り込み禁止にするため、以下のビットを設定します。<br>SCR.TEIE ビットを“0”<br>送信終了割り込みの IEN ビットを“0”<br>また、送信禁止にするため、以下のビットを設定します。<br>SCR.TE ビットを“0”<br>端子の機能を TXD に設定した状態で、送信禁止にすると、TXD 端子がハイインピーダンスになります。                                | 送信終了割り込み禁止にするため、以下のビットを設定します。<br>SCR.TEIE ビットを“0”<br>また、送信禁止にするため、以下のビットを設定します。<br>SCR.TE ビットを“0”<br>送信を禁止にすると、TXD 端子は汎用入出力ポートになります。                                         |
| ⑧ 再度送信開始時                    | 「②送信開始時」と同じ処理を行います。                                                                                                                                                                                              |                                                                                                                                                                              |

注 1. 詳細は、「9.4 トランスマットイネーブルビットに関する注意事項」を参照してください。

## 4.1.2 送信動作時の設定手順の相違点

表 4.3 に、送信動作時の初期設定手順の相違点を示します。H8S の初期設定手順は、割り込み制御モード 2 を使用する場合の手順を示します。

表 4.4 に、送信動作時の送信割り込み処理内容の相違点を示します。

表 4.5 に、送信動作時の送信終了割り込み処理内容の相違点を示します。

表 4.3 送信動作時の初期設定手順の相違点

| 手順                                | RX (RX261)                                                                                                                                                                          | H8S (H8S/2378)                                                           |
|-----------------------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--------------------------------------------------------------------------|
| 1 モジュールストップ状態を解除 <sup>(注 1)</sup> | SYSTEM.PRCR.WORD = 0xA502;<br>MSTPCR(SCI5) = 0;<br>SYSTEM.PRCR.WORD = 0xA500;                                                                                                       | MSTPCR.BIT._SCI0 = 0;                                                    |
| 2 送受信・割り込み禁止                      | SCI5.SCR.BYTE = 0x00;                                                                                                                                                               | SCI0.SCR.BYTE = 0x00;                                                    |
| 3 I/O ポート機能の設定 <sup>(注 2)</sup>   | PORTA.PMR.BIT.B4 = 0;<br>MPC.PWPR.BIT.B0WI = 0;<br>MPC.PWPR.BIT.PFSWE = 1;<br>MPC.PA4PFS.BYTE = 0x0A;<br>MPC.PWPR.BIT.PFSWE = 0;<br>MPC.PWPR.BIT.B0WI = 1;<br>PORTA.PMR.BIT.B4 = 1; | —<br>(処理なし)                                                              |
| 4 送信モード等の設定                       | SCI5.SCR.BIT.CKE = 0;<br>SCI5.SIMR1.BYTE = 0x00;<br>SCI5.SPMR.BYTE = 0x00;<br>SCI5.SMR.BYTE = 0x00;<br>SCI5.SCMR.BYTE = 0xF2;<br>SCI5.SEMR.BYTE = 0x00;                             | SCI0.SCR.BIT.CKE = 0;<br>SCI0.SMR.BYTE = 0x01;<br>SCI0.SCMR.BYTE = 0xF2; |
| 5 ビットレートの設定 <sup>(注 3)</sup>      | SCI5.BRR = 0x33;                                                                                                                                                                    | SCI0.BRR = 0x0F;                                                         |
| 6 1 ビット期間ウェイト                     | —<br>(処理なし)                                                                                                                                                                         | 1 ビット期間ウェイト処理                                                            |
| 7 割り込み制御モード設定 <sup>(注 4)</sup>    | —<br>(処理なし)                                                                                                                                                                         | INTC.INTCR.BIT.INTM = 10b;                                               |
| 8 割り込み優先レベル設定 <sup>(注 5)</sup>    | IPR(SCI5, ) = 0x01;                                                                                                                                                                 | INTC.IPRI.BIT._SCI0 = 001b;                                              |
| 9 割り込み要求をクリア                      | IR(SCI5,TXI5) = 0;                                                                                                                                                                  | —<br>(処理なし)                                                              |
| 10 周辺機能割り込み要求を許可                  | SCI5.SCR.BYTE  = 0xA0;                                                                                                                                                              | SCI0.SCR.BYTE  = 0xA0;                                                   |
| 11 送信許可                           |                                                                                                                                                                                     |                                                                          |
| 12 割り込み要求を許可 <sup>(注 6)</sup>     | IEN(SCI5,TXI5) = 1;                                                                                                                                                                 | —<br>(処理なし)                                                              |
| 13 プロセッサ割り込み優先レベル設定               | —<br>(処理なし)                                                                                                                                                                         | set_imask_exr(0);                                                        |
| 14 マスカブル割り込みの許可                   | setpsw_i();                                                                                                                                                                         | —<br>(処理なし)                                                              |

注 1. モジュールストップ機能については、「7. モジュールストップ機能」を参照してください。

注 2. RX では MPC で周辺機能の端子設定を行います。詳細は「9.1 入出力ポート」を参照してください。

注 3. ビットレートの詳細は、「5. ビットレートの算出方法」を参照してください。

注 4. RX には割り込み制御モードはありません。詳細は「6. 割り込みの相違点」を参照してください。

注 5. 割り込み優先レベルの設定方法の詳細は、「6. 割り込みの相違点」を参照してください。

注 6. 割り込み要求を許可にする方法が異なります。詳細は「6. 割り込みの相違点」を参照してください。

表 4.4 送信動作時の送信割り込み処理内容の相違点

| 手順                           | RX (RX261)                                                                            | H8S (H8S/2378)                                                  |
|------------------------------|---------------------------------------------------------------------------------------|-----------------------------------------------------------------|
| 1 TDRE フラグリード                | —<br>(処理なし)                                                                           | if(SCI0.SSR.BIT.TDRE == 1)<br>{                                 |
| 2 送信データの書き込み                 | /* SCI5.TDR レジスタに送信データを書き込む */                                                        | /* SCI0.TDR レジスタに送信データを書き込む */                                  |
| 3 TDRE フラグクリア                | —<br>(処理なし)                                                                           | SCI0.SSR.BIT.TDRE = 0;                                          |
| 4 最終データ書き込み確認                | if(最終データ書き込み済み?)<br>{                                                                 | if(最終データ書き込み済み?)<br>{                                           |
| 5 送信割り込みの禁止 (最終データ書き込み後のみ)   | SCI5.SCR.BIT.TIE = 0<br>IEN(SCI5,TXI5) = 0;<br>while(0 != SCI5.SCR.BIT.TIE)<br>{<br>} | SCI0.SCR.BIT.TIE = 0;<br>while(0 != SCI0.SCR.BIT.TIE)<br>{<br>} |
| 6 割り込み要求をクリア (最終データ書き込み後のみ)  | IR(SCI5,TXI5) = 0;<br>while(0 != IR(SCI5,TXI5))<br>{<br>}                             | —<br>(処理なし)                                                     |
| 7 送信終了割り込みを許可 (最終データ書き込み後のみ) | SCI5.SCR.BIT.TEIE = 1;<br>IEN(SCI5,TEI5) = 1;<br>}                                    | SCI0.SCR.BIT.TEIE = 1;<br>}                                     |

表 4.5 送信動作時の送信終了割り込み処理内容の相違点

| 手順             | RX (RX261)                                                                | H8S (H8S/2378)                                                            |
|----------------|---------------------------------------------------------------------------|---------------------------------------------------------------------------|
| 1 送信および割り込みの禁止 | SCI5.SCR.BYTE &= 0x0B;<br>while(0x00 != (SCI5.SCR.BYTE & 0xF4))<br>{<br>} | SCI0.SCR.BYTE &= 0x0B;<br>while(0x00 != (SCI0.SCR.BYTE & 0xF4))<br>{<br>} |
| 2 割り込み要求をクリア   | IR(SCI5,TEI5) = 0;<br>while(0 != SCI5,TEI5)<br>{<br>}                     | —<br>(処理なし) <sup>(注1)</sup>                                               |

注 1. SCR.TEIE ビットを"0"に設定すると、送信終了割り込み要求はクリアされます。

## 4.2 受信動作時の相違点

調歩同期式シリアル通信における、受信を行う場合の相違点について説明します。

前提条件として、受信割り込み、受信エラー割り込みを使用し、受信エラーが発生した場合の処理について説明します。

### 4.2.1 受信動作時のタイミング相違点



図 4.2 に、RX と H8S の受信タイミング相違点 (3 バイトずつ受信する場合) を示します。

表 4.6 に、RX と H8S の各タイミングでの動作および処理内容の相違点 (3 バイトずつ受信する場合) を示します。



図 4.2 中の①～⑥の番号は、表 4.6 中の説明①～⑥に対応しています。



図 4.2 RX と H8S の受信タイミング相違点 (3 バイトずつ受信する場合)

表 4.6 RX と H8S の各タイミングでの動作および処理内容の相違点 (3 バイトずつ受信する場合)

| タイミング          | RX (RX261)                                                                                                                                  | H8S (H8S/2378)                                                                                                                   |
|----------------|---------------------------------------------------------------------------------------------------------------------------------------------|----------------------------------------------------------------------------------------------------------------------------------|
| ① 受信許可設定       | 割り込み許可にするため、以下のビットを設定します。<br>SCR.RIE ビットを“1”<br>RXI 割り込みの IEN ビットを“1”<br>ERI 割り込みの IEN ビットを“1”<br>受信許可にするため、以下のビットを設定します。<br>SCR.RE ビットを“1” | 割り込み許可にするため、以下のビットを設定します。<br>SCR.RIE ビットを“1”<br>受信許可にするため、以下のビットを設定します。<br>SCR.RE ビットを“1”                                        |
| ② 受信開始         | スタートビットを検出すると、受信動作を開始します。                                                                                                                   | スタートビットを検出すると、受信動作を開始します。                                                                                                        |
| ③ 受信完了時        | 1 バイトのデータを受信すると、受信データが受信バッファに取り込まれ、受信割り込み (RXI 割り込み) の IR フラグが“1”になり、受信割り込みが発生します。受信割り込み処理で、受信バッファから値を読み出します。                               | 1 バイトのデータを受信すると、受信データが受信バッファに取り込まれ、SSR.RDRF フラグが“1”になり、受信割り込み (RXI 割り込み) が発生します。受信割り込み処理で、受信バッファから値を読み出し、SSR.RDRF フラグを“0”に設定します。 |
| ④ 受信エラー発生時     | オーバランエラー発生時、受信エラー割り込み (ERI 割り込み) の IR フラグが“1”になります。ERI 割り込み処理で、受信エラー処理を行います。                                                                | オーバランエラー発生時、SSR.ORER フラグが“1”になり、ERI 割り込みが発生します。ERI 割り込み処理で、受信エラー処理を行います。                                                         |
| ⑤ 受信エラーフラグのクリア | SSR レジスタのオーバランエラーフラグを読み出し後、“0”を書き込み、エラーフラグをクリアします。                                                                                          | SSR レジスタのオーバランエラーフラグを読み出し後、“0”を書き込み、エラーフラグをクリアします。                                                                               |
| ⑥ 再度受信許可設定時    | 全てのエラーフラグをクリアすると、ERI 割り込みの IR フラグが“0”になり、受信許可状態となります。                                                                                       | 全てのエラーフラグをクリアすると、受信許可状態となります。                                                                                                    |

## 4.2.2 受信動作時の設定手順の相違点

表 4.7 に、受信動作時の初期設定手順の相違点を示します。H8S の初期設定手順は、割り込み制御モード 2 を使用する場合の手順を示します。

表 4.8 に、受信動作時の受信割り込み処理内容の相違点を示します。

表 4.9 に、受信動作時の ERI 割り込み処理内容の相違点を示します。

表 4.7 受信動作時の初期設定手順の相違点

| 手順 |                                 | RX (RX261)                                                                                                                                                                          | H8S (H8S/2378)                                                           |
|----|---------------------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--------------------------------------------------------------------------|
| 1  | モジュールストップ状態を解除 <sup>(注 1)</sup> | SYSTEM.PRCR.WORD = 0xA502;<br>MSTPCR(SCI5) = 0;<br>SYSTEM.PRCR.WORD = 0xA500;                                                                                                       | MSTPCR.BIT._SCI0 = 0;                                                    |
| 2  | 送受信・割り込み禁止                      | SCI5.SCR.BYTE = 0x00;                                                                                                                                                               | SCI0.SCR.BYTE = 0x00;                                                    |
| 3  | I/O ポート機能の設定 <sup>(注 2)</sup>   | PORTA.PMR.BIT.B3 = 0;<br>MPC.PWPR.BIT.B0WI = 0;<br>MPC.PWPR.BIT.PFSWE = 1;<br>MPC.PA3PFS.BYTE = 0x0A;<br>MPC.PWPR.BIT.PFSWE = 0;<br>MPC.PWPR.BIT.B0WI = 1;<br>PORTA.PMR.BIT.B3 = 1; | —<br>(処理なし)                                                              |
| 4  | 受信モード等の設定                       | SCI5.SCR.BIT.CKE = 0;<br>SCI5.SIMR1.BYTE = 0x00;<br>SCI5.SPMR.BYTE = 0x00;<br>SCI5.SMR.BYTE = 0x00;<br>SCI5.SCMR.BYTE = 0xF2;<br>SCI5.SEMR.BYTE = 0x00;                             | SCI0.SCR.BIT.CKE = 0;<br>SCI0.SMR.BYTE = 0x01;<br>SCI0.SCMR.BYTE = 0xF2; |
| 5  | ビットレートの設定 <sup>(注 3)</sup>      | SCI5.BRR = 0x33;                                                                                                                                                                    | SCI0.BRR = 0x0F;                                                         |
| 6  | 1 ビット期間ウェイト                     | —<br>(処理なし)                                                                                                                                                                         | 1 ビット期間ウェイト処理                                                            |
| 7  | 割り込み制御モード設定 <sup>(注 4)</sup>    | <sup>3/4</sup><br>(処理なし)                                                                                                                                                            | INTC.INTCR.BIT.INTM = 10b;                                               |
| 8  | 割り込み優先レベル設定 <sup>(注 5)</sup>    | IPR(SCI5, ) = 0x01;                                                                                                                                                                 | INTC.IPRI.BIT._SCI0 = 001b;                                              |
| 9  | 割り込み要求をクリア                      | IR(SCI5,RXI5) = 0;<br>IR(SCI5,ERI5) = 0;                                                                                                                                            | —<br>(処理なし)                                                              |
| 10 | 周辺機能割り込み要求を許可                   | SCI5.SCR.BYTE  = 0x50;                                                                                                                                                              | SCI0.SCR.BYTE  = 0x50;                                                   |
| 11 | 送受信許可                           |                                                                                                                                                                                     |                                                                          |
| 12 | 割り込み要求を許可 <sup>(注 6)</sup>      | IEN(SCI5,RXI5) = 1;<br>IEN(SCI5,ERI5) = 1; /* <sup>(注 7)</sup> */                                                                                                                   | —<br>(処理なし)                                                              |
| 13 | プロセッサ割り込み優先レベル設定                | —<br>(処理なし)                                                                                                                                                                         | set_imask_exr(0);                                                        |
| 14 | マスカブル割り込みの許可                    | setpsw_i();                                                                                                                                                                         | —<br>(処理なし)                                                              |

注 1. モジュールストップ機能については、「7. モジュールストップ機能」を参照してください。

注 2. RX では MPC で周辺機能の端子設定を行います。詳細は「9.1 入出力ポート」を参照してください。

注 3. ビットレートの詳細は、「5. ビットレートの算出方法」を参照してください。

注 4. RX には割り込み制御モードはありません。詳細は「6. 割り込みの相違点」を参照してください。

注 5. 割り込み優先レベルの設定方法の詳細は、「6. 割り込みの相違点」を参照してください。

注 6. 割り込み要求を許可にする方法が異なります。詳細は「6. 割り込みの相違点」を参照してください。

注 7. 受信エラー割り込みの仕様はマイコンにより異なります。詳細はユーザーズマニュアル ハードウェア編を参照してください。

表 4.8 受信動作時の受信割り込み処理内容の相違点

| 手順                              | RX (RX261)                                                                     | H8S (H8S/2378)                                                                      |
|---------------------------------|--------------------------------------------------------------------------------|-------------------------------------------------------------------------------------|
| 1 RDRF フラグリード                   | —<br>(処理なし)                                                                    | if(SCI0.SSR.BIT.RDRF == 1)<br>{                                                     |
| 2 受信データの読み出し                    | /* SCI5.RDR レジスタから受信データを読み出し */                                                | /* SCI0.RDR レジスタから受信データを読み出し */                                                     |
| 3 RDRF フラグクリア                   | —<br>(処理なし)                                                                    | SCI0.SSR.BIT.RDRF = 0;                                                              |
| 4 最終データの受信確認                    | if( 最終データの受信? )<br>{                                                           | if( 最終データの受信? )<br>{                                                                |
| 5 送受信および割り込みの禁止<br>(最終データ受信後のみ) | SCI5.SCR.BYTE &= 0x0F;<br>while(0x00 != (SCI5.SCR.BYTE & 0xF0))<br>{<br>}<br>} | SCI0.SCR.BYTE &= 0x0F;<br>while(0x00 != (SCI0.SCR.BYTE & 0xF0))<br>{<br>}<br>}<br>} |
| 6 割り込み要求をクリア (最終データ書き込み後のみ)     | IR(SCI5,RXI5) = 0;<br>while(0 != IR(SCI5,RXI5))<br>{<br>}<br>}                 | —<br>(処理なし)                                                                         |

表 4.9 受信動作時の ERI 割り込み処理内容の相違点

| 手順 |                 | RX (RX261)                                                             | H8S (H8S/2378)                                                         |
|----|-----------------|------------------------------------------------------------------------|------------------------------------------------------------------------|
| 1  | ORER フラグリード     | dummy = SCI5.SSR.BIT.ORER;<br>/* (注1) */                               | dummy = SCI0.SSR.BIT.ORER;<br>/* (注1) */                               |
| 2  | オーバランエラー発生時の処理  | if(dummy== 1)<br>{<br>/* オーバランエラー発生時の処理を記載 (注2) */<br>}                | if(dummy== 1)<br>{<br>/* オーバランエラー発生時の処理を記載 */<br>}                     |
| 3  | FER フラグリード      | dummy = SCI5.SSR.BIT.FER;<br>/* (注1) */                                | dummy = SCI0.SSR.BIT.FER;<br>/* (注1) */                                |
| 4  | フレーミングエラー発生時の処理 | if(dummy== 1)<br>{<br>/* フレーミングエラー発生時の処理を記載 (注3) */<br>}               |                                                                        |
| 5  | PER フラグリード      | dummy = SCI5.SSR.BIT.PER;<br>/* (注1) */                                | dummy = SCI0.SSR.BIT.PER;<br>/* (注1) */                                |
| 6  | パリティエラー発生時の処理   | if(dummy== 1)<br>{<br>/* パリティエラー発生時の処理を記載 */<br>}                      |                                                                        |
| 7  | 受信バッファのダミーリード   | dummy_data = SCI5.RDR;                                                 | dummy_data = SCI0.RDR;                                                 |
| 8  | 受信エラーのクリア       | SCI5.SSR.BYTE &= 0xC7;<br>while(0 != (SCI5.SSR.BYTE & 0x38))<br>{<br>} | SCI0.SSR.BYTE &= 0xC7;<br>while(0 != (SCI0.SSR.BYTE & 0x38))<br>{<br>} |
| 9  | 割り込み要求をクリア      | IR(SCI5,ERI5) = 0;<br>while(0 != IR(SCI5,ERI5))<br>{<br>}              | —<br>(処理なし)                                                            |

注 1. ORER フラグ (オーバランエラーフラグ)、FER フラグ (フレーミングエラーフラグ)、PER フラグ (パリティエラーフラグ) をクリアする場合は、事前に“1”的状態を読み出してください。

注 2. RX のオーバランエラー処理では、RDR レジスタをリードしてください。

注 3. フレーミングエラーでブレークを検出した場合は、SCR.RE ビットを 0 に設定し、受信を禁止してください。

## 5. ビットレートの算出方法

表 5.1 に、BRR レジスタの設定値 N とビットレート B の関係を示します。また、表 5.1 に示す計算式は、RX と H8S で同一です。

表 5.1 BRR レジスタの設定値 N とビットレート B の関係

| モード     | RX (RX261)                                                                                                               | H8S (H8S/2378)                                             |
|---------|--------------------------------------------------------------------------------------------------------------------------|------------------------------------------------------------|
| クロック同期式 | $N = (PCLK \times 10^6 / (8 \times 2^{2n-1} \times B)) - 1$                                                              | $B = \phi \times 10^6 / (8 \times 2^{2n-1} \times (N+1))$  |
| 調歩同期式   | (SEMR の BDGM=0、ABCS=0 の場合)<br>$N = (PCLK \times 10^6 / (64 \times 2^{2n-1} \times B)) - 1$                               | $B = \phi \times 10^6 / (64 \times 2^{2n-1} \times (N+1))$ |
|         | (SEMR の BDGM=0、ABCS=1 の場合)<br>(SEMR の BDGM=1、ABCS=0 の場合)<br>$N = (PCLK \times 10^6 / (32 \times 2^{2n-1} \times B)) - 1$ |                                                            |
|         | (SEMR の BDGM=1、ABCS=1 の場合)<br>$N = (PCLK \times 10^6 / (16 \times 2^{2n-1} \times B)) - 1$                               |                                                            |

B : ビットレート [bps]

N : BRR レジスタの設定値 ( $0 \leq N \leq 255$ )

PCLK または  $\phi$  : 動作周波数 [MHz]

n : SMR の設定値によって決まります。SMR の設定値と n の関係を下表に示します。

SMR の設定値と n の関係は、RX と H8S で同一です。

| SMR の設定値 |      | n |
|----------|------|---|
| CKS1     | CKS0 |   |
| 0        | 0    | 0 |
| 0        | 1    | 1 |
| 1        | 0    | 2 |
| 1        | 1    | 3 |

表 5.2 に、表 5.1 中の SEMR.BDGM ビット、SEMR.ABCS ビットの機能を示します。

表 5.2 SEMR.BDGM ビット、SEMR.ABCS ビットの機能

| ビット名 | 機能                                                                                                                                 |
|------|------------------------------------------------------------------------------------------------------------------------------------|
| BDGM | ボーレートジェネレータ倍速モードセレクトビット<br>(調歩同期式モードで内蔵ボーレートジェネレータ使用時のみ有効)<br>0 : ボーレートジェネレータから通常の周波数のクロックを出力<br>1 : ボーレートジェネレータから 2 倍の周波数のクロックを出力 |
| ABCS | 調歩同期基本クロックセレクトビット<br>(調歩同期式モードのみ有効)<br>0 : 基本クロック 16 サイクルの期間が 1 ビット期間の転送レートになります<br>1 : 基本クロック 8 サイクルの期間が 1 ビット期間の転送レートになります       |

## 6. 割り込みの相違点

RX は H8S と異なり、周辺機能毎の割り込み許可ビット・割り込み要求ビットに加え、割り込みコントローラに周辺機能の割り込み許可ビット・割り込み要求ビットがあります。

表 6.1 に SCI1 の割り込み関連リソースの相違点を示します。

表 6.1 中の IERm レジスタ ( $m = 02h \sim 1Fh$ )、IRn レジスタ ( $n = \text{割り込みベクタ番号}$ ) は、割り込みコントローラのレジスタです。

IERm レジスタの各ビットと割り込み要因の対応、割り込みベクタ番号については、ユーザーズマニュアル ハードウェア編の割り込みコントローラの章を参照してください。

表 6.1 SCI1 の割り込み関連リソースの相違点

| 項目                        | RX (RX261)         |                |                |                | H8S (H8S/2378) |              |              |              |  |
|---------------------------|--------------------|----------------|----------------|----------------|----------------|--------------|--------------|--------------|--|
|                           | ERI1               | RXI1           | TXI1           | TEI1           | ERI1           | RXI1         | TXI1         | TEI1         |  |
| 割り込み許可<br>レジスタ<br>(許可ビット) | 周辺機能<br>(SCI1)     | SCR.RIE        |                | SCR.<br>TIE    | SCR.<br>TEIE   | SCR.RIE      |              | SCR.<br>TIE  |  |
|                           | 割り込み<br>コント<br>ローラ | IER1B.<br>IEN2 | IER1B.<br>IEN3 | IER1B.<br>IEN4 | IER1B.<br>IEN5 | なし           |              |              |  |
| 割り込み要求<br>レジスタ<br>(要因フラグ) | 周辺機能<br>(SCI1)     | SSR.<br>ORER   | SSR.<br>RDRF   | SSR.<br>TDRE   | SSR.<br>TEND   | SSR.<br>ORER | SSR.<br>RDRF | SSR.<br>TDRE |  |
|                           | 割り込み<br>コント<br>ローラ | SSR.<br>FER    |                |                |                | SSR.<br>FER  |              | SSR.<br>TEND |  |
|                           |                    | SSR.<br>PER    |                |                |                | SSR.<br>PER  |              |              |  |
|                           |                    | IR218.<br>IR   | IR219.<br>IR   | IR220.<br>IR   | IR221.<br>IR   | なし           |              |              |  |

RX では、下記の条件を満たすときに割り込みを受け付けることができます。

- I フラグ (PSW.I ビット) が“1”であること。
- ICU の IER、IPR レジスタで割り込み許可に設定されていること。
- 周辺機能の割り込み要求許可ビットで、割り込み要求が許可されていること。

表 6.2 に、RX と H8S の割り込みの発生条件についての比較表を示します。

表 6.2 RX と H8S の割り込みの発生条件についての比較表

| 項目                | RX (RX261)                                                                   | H8S (H8S/2378)                                                                                                                    |
|-------------------|------------------------------------------------------------------------------|-----------------------------------------------------------------------------------------------------------------------------------|
| 割り込み許可ビット (I ビット) | PSW レジスタの I ビットを“1”(許可) にすると、マスカブル割り込みの受け付けが許可されます。                          | 割り込み制御モード 0 の場合、CCR レジスタの I ビットを“0”(許可) にすると、マスカブル割り込みの受け付けが許可されます。<br>割り込み制御モード 2 の場合は、CCR レジスタの I ビットは使用しません。                   |
| プロセッサ割り込み優先レベル    | PSW レジスタの IPL[3:0] ビットが示すレベルより高いレベルの割り込み要求のみが受け付けられます。                       | 割り込み制御モード 2 の場合、EXR レジスタの I2~I0 ビットが示すレベルより高いレベルの割り込み要求のみが受け付けられます。<br>割り込み制御モード 0 の場合は、EXR レジスタの I2~I0 ビットは使用しません。               |
| 割り込み優先レベル         | IPR レジスタで設定します。<br>同じ IPR レベルの複数の割り込みが同時に発生した場合、ベクターテーブル番号の若い番号の割り込みが優先されます。 | 割り込み制御モード 0 の場合はデフォルトの設定となります。<br>割り込み制御モード 2 の場合は、IPR レジスタの設定となります。<br>同じ IPR レベルの複数の割り込みが同時に発生した場合、ベクターテーブル番号の若い番号の割り込みが優先されます。 |
| 割り込み要求フラグ         | 周辺機能、外部端子、NMI 割り込み等の全ての割り込みステータスフラグ(IR)を割り込みコントローラで管理します。                    | 外部割込みは、割り込みコントローラ、内部割り込み要因は、各内蔵周辺機能内で割り込みステータスフラグを管理します。                                                                          |
| 割り込み要求許可          | マスカブル割り込みは IER レジスタ、ノンマスカブル割り込みは NMIER レジスタで設定します。                           | IER レジスタで IRQ 割り込み許可を設定します。                                                                                                       |
| 周辺機能の割り込み許可       | 各周辺機能で割り込みの許可、禁止を設定できます。                                                     |                                                                                                                                   |

表 6.3 に、プロセッサ割り込み許可と優先レベルの相違点を示します。

RX では、PSW.I ビットを“1”(割り込み許可) に設定すると、プロセッサ割り込み優先レベルはデフォルトで優先レベル 0 (最低レベル) になっているため、マスカブル割り込み許可になります。

表 6.3 プロセッサ割り込み許可と優先レベルの相違点

| 項目                    | RX (RX261)                     | H8S (H8S/2378)             |                                 |
|-----------------------|--------------------------------|----------------------------|---------------------------------|
|                       |                                | 割り込み制御モード 0                | 割り込み制御モード 2                     |
| 割り込み許可 デフォルト値         | PSW.I ビット : 0<br>(割り込みマスク)     | CCR.I ビット : 1<br>(割り込みマスク) | 使用しない <sup>(注 1)</sup>          |
| プロセッサ割り込み優先レベル デフォルト値 | PSW.IPL[3:0]ビット : 0000b(最低レベル) | 使用しない <sup>(注 1)</sup>     | EXR.I2~I0 ビット : 111b<br>(最高レベル) |
| リセット後の動作              | マスカブル割り込みを受け付けない               |                            |                                 |

注 1. Don't care

表 6.4 に、割り込み許可に使用する組み込み関数 (一部) を示します。

表 6.4 割り込み許可に使用する組み込み関数 (一部)

| 項目                             | RX (RX261)                        | 記述                                      |                                         |
|--------------------------------|-----------------------------------|-----------------------------------------|-----------------------------------------|
|                                |                                   | H8S (H8S/2378)                          | 割り込み制御モード 0                             |
| プロセッサ割り込み許可設定                  | <code>setpsw_i();</code><br>(注 1) | <code>set_imask_ccr(0);</code><br>(注 1) | 使用しない                                   |
| プロセッサ割り込み優先レベルの設定 (“0”に設定する場合) | <code>set_ipl(0);</code><br>(注 1) | 使用しない                                   | <code>set_imask_exr(0);</code><br>(注 1) |

注 1. “machine.h”的インクルードが必要です。

詳細は、ユーザーズマニュアル ハードウェア編の割り込みコントローラ (ICU)、CPU、使用する周辺機能の章を参照してください。

## 7. モジュールストップ機能

H8S、RX は周辺モジュールごとに機能を停止させることができます。

使用しない周辺モジュールをモジュールストップ状態へ遷移させることで、消費電力を低減することができます。リセット解除後は、表 7.1 に示すモジュール以外はモジュールストップ状態になっています。

表 7.1 RX、H8S の初期設定時動作しているモジュール

| RX (RX261)   | H8S (H8S/2378)  |
|--------------|-----------------|
| DMAC、DTC、RAM | EXDMAC、DMAC、DTC |

モジュールストップ状態のモジュールのレジスタは、読み書きできません。

表 7.1 に示すモジュール以外のモジュールを使用する場合は、モジュールストップ状態を解除した後、初期設定等を行ってください。

詳細は、ユーザーズマニュアル ハードウェア編の消費電力低減機能の章を参照してください。

## 8. レジスタライトプロテクション機能

RX では、プログラムが暴走したときに備えて、重要なレジスタを書き換えられないように保護することができます。プロテクトレジスタ(PRCR)によって、保護するレジスタを設定します。

クロック発生回路関連レジスタ、動作モード関連レジスタ、消費電力低減機能関連レジスタ、ローパワータイマ関連レジスタ、LVD 関連レジスタ、ソフトウェアリセットレジスタを保護することができます。

詳細は、ユーザーズマニュアル ハードウェア編のレジスタライトプロテクション機能の章を参照ください。

## 9. H8S から RX へ置き換えるときのポイント

H8S から RX へ置き換えるときのポイントについて、以下に示します。

### 9.1 入出力ポート

RX では、周辺機能の入出力信号を端子に割り当てるには、MPC の設定を行う必要があります。

RX の端子の入出力制御を行う前に以下の 2 つの設定を行ってください。

- MPC の PFS レジスタ：該当端子に割り当てる周辺機能の選択
- I/O ポートの PMR レジスタ：該当端子に汎用入出力ポート/周辺機能を割り当てるかの選択

表 9.1 に、RX と H8S の周辺機能端子の入出力設定についての比較表を示します。

表 9.1 RX と H8S の周辺機能端子の入出力設定についての比較表

| 機能                 | RX (RX261)                                                  | H8S (H8S/2378)                                                                                   |
|--------------------|-------------------------------------------------------------|--------------------------------------------------------------------------------------------------|
| 端子の機能選択            | PFS レジスタを設定することで、周辺機能の入出力を複数の端子から選択して割り付けることができます。          | MCU 動作モード、SYSCR.EXPE ビット、PFCR レジスタ、DDR レジスタ、各周辺機能の設定の組み合わせにより、汎用入出力ポート/周辺機能の切り替え、また端子の機能選択が可能です。 |
| 汎用入出力ポート/周辺機能の切り替え | PMR レジスタを設定することで、対象端子を I/O ポートとして使用するか、周辺機能として使用するかを選択できます。 |                                                                                                  |

詳細は、ユーザーズマニュアル ハードウェア編のマルチファンクションピンコントローラ (MPC) と、I/O ポートの章を参照してください。

## 9.2 I/O レジスタマクロ

RX の I/O レジスタの定義 (iodefine.h) 内では、下記のマクロ定義を用意しています。

マクロ定義を使用することで可読性の高いプログラムを記載できます。

表 9.2 に、マクロの使用例を示します。

表 9.2 マクロの使用例

| マクロ                            | 使用例                                                                                           |
|--------------------------------|-----------------------------------------------------------------------------------------------|
| IR("module name","bit name")   | IR(MTU0,TGIA0) = 0;<br>MTU0 の TGIA0 に対応した IR フラグを“0”(割り込み要求をクリア) にします。                        |
| DTCE("module name","bit name") | DTCE(MTU0,TGIA0) = 1;<br>MTU0 の TGIA0 に対応した DTCE ビットを“1”(DTC 起動を許可) にします。                     |
| IEN("module name","bit name")  | IEN(MTU0,TGIA0) = 1;<br>MTU0 の TGIA0 に対応した IEN ビットを“1”(割り込みを許可) にします。                         |
| IPR("module name","bit name")  | IPR(MTU0,TGIA0) = 0x02;<br>MTU0 の TGIA0 に対応した IPR ビットを“2”(割り込み優先レベルを“2”) にします。                |
| MSTP("module name")            | MSTP(MTU) = 0;<br>MTU0 のモジュールストップ設定ビットを“0”(モジュールストップ状態を解除) にします。                              |
| VECT("module name","bit name") | #pragma interrupt(Excep_MTU0_TGIA0(vect=VECT(MTU0,TGIA0)))<br>MTU0 の TGIA0 に対応した割り込み関数を宣言します。 |

### 9.3 組み込み関数

RX では、制御レジスタの設定や特殊命令用に組み込み関数を用意しています。組み込み関数を使用する場合は、`machine.h` をインクルードしてください。

表 9.3 に、RX と H8S の制御レジスタの設定や特殊命令などの記述の相違点（一例）を示します。

表 9.3 RX と H8S の制御レジスタの設定や特殊命令などの記述の相違点（一例）

| 項目             | 記述                                |                                               |
|----------------|-----------------------------------|-----------------------------------------------|
|                | RX (RX261)                        | H8S (H8S/2378)                                |
| I フラグを"1"にする   | <code>setpsw_i();</code><br>(注 1) | <code>set_imask_ccr(1);</code><br>(注 1) (注 2) |
| I フラグを"0"にする   | <code>clrpsw_i();</code><br>(注 1) | <code>set_imask_ccr(0);</code><br>(注 1) (注 2) |
| WAIT 命令に展開します。 | <code>wait();</code><br>(注 1)     | なし                                            |
| NOP 命令に展開します。  | <code>nop();</code><br>(注 1)      | <code>nop();</code><br>(注 1)                  |

注 1. “`machine.h`”のインクルードが必要です。

注 2. RX では `I = 1` のとき割り込み許可、H8S では `I = 1` のとき割り込みマスクを意味します。

## 9.4 トランスマットイネーブルビットに関する注意事項

端子の機能を「TXDn」に設定した状態で、SCR.TE ビットを“0”(シリアル送信動作を禁止) にすると、端子の出力がハイインピーダンスになります。

以下のいずれかの方法により、TXDn ラインがハイインピーダンスにならないようにしてください。

(1) TXDn ラインにプルアップ抵抗を接続する。

(2) SCR.TE ビットを“0”にする前に、端子の機能を「汎用入出力ポート、出力」に変更する。

また、SCR.TE ビットを“1”にしてから、端子の機能を「TXDn」に変更する。

## 10. 参考ドキュメント

### ユーザーズマニュアル : ハードウェア

H8S/2378 グループ、H8S/2378R グループ ハードウェアマニュアル Rev.7.00 (RJJ09B0094-0700)

RX260 グループ、RX261 グループ ユーザーズマニュアル ハードウェア編 (R01UH1045JJ)

(最新の情報をルネサス エレクトロニクスホームページから入手してください。)

### アプリケーションノート

RX ファミリ、M16C ファミリ M16C から RX への置き換えガイド クロック同期式シリアル通信編

Rev.1.00 (R01AN1927JJ0100)

(最新の情報をルネサス エレクトロニクスホームページから入手してください。)

### テクニカルアップデート／テクニカルニュース

(最新の情報をルネサス エレクトロニクスホームページから入手してください。)

### ユーザーズマニュアル : 開発環境

CC-RX コンパイラ ユーザーズマニュアル Rev.1.03 (R20UT3248JJ0103)

H8S、H8/300 シリーズ C/C++コンパイラ、アセンブラー、最適化リンクエディタ コンパイラパッケージ Ver.7.00 ユーザーズマニュアル (RJJ10J2552-0100)

(最新の情報をルネサス エレクトロニクスホームページから入手してください。)

## 改訂記録

| Rev. | 発行日        | 改訂内容 |                                  |
|------|------------|------|----------------------------------|
|      |            | ページ  | ポイント                             |
| 1.00 | 2017.11.13 | —    | 初版発行                             |
| 2.00 | 2025.03.25 | —    | RX マイコンの比較対象機種を変更<br>RX231→RX261 |

## 製品ご使用上の注意事項

ここでは、マイコン製品全体に適用する「使用上の注意事項」について説明します。個別の使用上の注意事項については、本ドキュメントおよびテクニカルアップデートを参照してください。

### 1. 静電気対策

CMOS 製品の取り扱いの際は静電気防止を心がけてください。CMOS 製品は強い静電気によってゲート絶縁破壊を生じることがあります。運搬や保存の際には、当社が出荷梱包に使用している導電性のトレイやマガジンケース、導電性の緩衝材、金属ケースなどを利用し、組み立て工程にはアースを施してください。プラスチック板上に放置したり、端子を触ったりしないでください。また、CMOS 製品を実装したボードについても同様の扱いをしてください。

### 2. 電源投入時の処置

電源投入時は、製品の状態は不定です。電源投入時には、LSI の内部回路の状態は不確定であり、レジスタの設定や各端子の状態は不定です。外部リセット端子でリセットする製品の場合、電源投入からリセットが有効になるまでの期間、端子の状態は保証できません。同様に、内蔵パワーオンリセット機能を使用してリセットする製品の場合、電源投入からリセットのかかる一定電圧に達するまでの期間、端子の状態は保証できません。

### 3. 電源オフ時における入力信号

当該製品の電源がオフ状態のときに、入力信号や入出力プルアップ電源を入れないでください。入力信号や入出力プルアップ電源からの電流注入により、誤動作を引き起こしたり、異常電流が流れ内部素子を劣化させたりする場合があります。資料中に「電源オフ時における入力信号」についての記載のある製品は、その内容を守ってください。

### 4. 未使用端子の処理

未使用端子は、「未使用端子の処理」に従って処理してください。CMOS 製品の入力端子のインピーダンスは、一般に、ハイインピーダンスとなっています。未使用端子を開放状態で動作させると、誘導現象により、LSI 周辺のノイズが印加され、LSI 内部で貫通電流が流れたり、入力信号と認識されて誤動作を起こす恐れがあります。

### 5. クロックについて

リセット時は、クロックが安定した後、リセットを解除してください。プログラム実行中のクロック切り替え時は、切り替え先クロックが安定した後に切り替えてください。リセット時、外部発振子（または外部発振回路）を用いたクロックで動作を開始するシステムでは、クロックが十分安定した後、リセットを解除してください。また、プログラムの途中で外部発振子（または外部発振回路）を用いたクロックに切り替える場合は、切り替え先のクロックが十分安定してから切り替えてください。

### 6. 入力端子の印加波形

入力ノイズや反射波による波形歪みは誤動作の原因になりますので注意してください。CMOS 製品の入力がノイズなどに起因して、 $V_{IL}$  (Max.) から  $V_{IH}$  (Min.) までの領域にとどまるような場合は、誤動作を引き起こす恐れがあります。入力レベルが固定の場合はもちろん、 $V_{IL}$  (Max.) から  $V_{IH}$  (Min.) までの領域を通過する遷移期間中にチャタリングノイズなどが入らないように使用してください。

### 7. リザーブアドレス（予約領域）のアクセス禁止

リザーブアドレス（予約領域）のアクセスを禁止します。アドレス領域には、将来の拡張機能用に割り付けられている リザーブアドレス（予約領域）があります。これらのアドレスをアクセスしたときの動作については、保証できませんので、アクセスしないようにしてください。

### 8. 製品間の相違について

型名の異なる製品に変更する場合は、製品型名ごとにシステム評価試験を実施してください。同じグループのマイコンでも型名が違うと、フラッシュメモリ、レイアウトパターンの相違などにより、電気的特性の範囲で、特性値、動作マージン、ノイズ耐量、ノイズ幅射量などが異なる場合があります。型名が違う製品に変更する場合は、個々の製品ごとにシステム評価試験を実施してください。

## ご注意書き

1. 本資料に記載された回路、ソフトウェアおよびこれらに関連する情報は、半導体製品の動作例、応用例を説明するものです。回路、ソフトウェアおよびこれらに関連する情報を使用する場合、お客様の責任において、お客様の機器・システムを設計ください。これらの使用に起因して生じた損害（お客様または第三者いずれに生じた損害も含みます。以下同じです。）に関し、当社は、一切その責任を負いません。
  2. 当社製品または本資料に記載された製品データ、図、表、プログラム、アルゴリズム、応用回路例等の情報の使用に起因して発生した第三者の特許権、著作権その他の知的財産権に対する侵害またはこれらに関する紛争について、当社は、何らの保証を行ふものではなく、また責任を負うものではありません。
  3. 当社は、本資料に基づき当社または第三者の特許権、著作権その他の知的財産権を何ら許諾するものではありません。
  4. 当社製品を組み込んだ製品の輸出入、製造、販売、利用、配布その他の行為を行うにあたり、第三者保有の技術の利用に関するライセンスが必要となる場合、当該ライセンス取得の判断および取得はお客様の責任において行ってください。
  5. 当社製品を、全部または一部を問わず、改造、改変、複製、リバースエンジニアリング、その他、不適切に使用しないでください。かかる改造、改変、複製、リバースエンジニアリング等により生じた損害に関し、当社は、一切その責任を負いません。
  6. 当社は、当社製品の品質水準を「標準水準」および「高品質水準」に分類しており、各品質水準は、以下に示す用途に製品が使用されることを意図しております。

標準水準： コンピュータ、OA機器、通信機器、計測機器、AV機器、家電、工作機械、パーソナル機器、産業用ロボット等  
高品質水準： 輸送機器（自動車、電車、船舶等）、交通制御（信号）、大規模通信機器、金融端末基幹システム、各種安全制御装置等  
当社製品は、データシート等により高信頼性、Harsh environment 向け製品と定義しているものを除き、直接生命・身体に危害を及ぼす可能性のある機器・システム（生命維持装置、人体に埋め込み使用するもの等）、もしくは多大な物的損害を発生させるおそれのある機器・システム（宇宙機器と、海底中継器、原子力制御システム、航空機制御システム、プラント基幹システム、軍事機器等）に使用されることを意図しておらず、これらの用途に使用することは想定していません。たとえ、当社が想定していない用途に当社製品を使用したことにより損害が生じても、当社は一切その責任を負いません。
  7. あらゆる半導体製品は、外部攻撃からの安全性を 100% 保証されているわけではありません。当社ハードウェア／ソフトウェア製品にはセキュリティ対策が組み込まれているものもありますが、これによって、当社は、セキュリティ脆弱性または侵害（当社製品または当社製品が使用されているシステムに対する不正アクセス・不正使用を含みますが、これに限りません。）から生じる責任を負うものではありません。当社は、当社製品または当社製品が使用されたあらゆるシステムが、不正な改変、攻撃、ウイルス、干渉、ハッキング、データの破壊または窃盗その他の不正な侵入行為（「脆弱性問題」といいます。）によって影響を受けないことを保証しません。当社は、脆弱性問題に起因またはこれに関連して生じた損害について、一切責任を負いません。また、法令において認められる限りにおいて、本資料および当社ハードウェア／ソフトウェア製品について、商品性および特定目的との合致に関する保証ならびに第三者の権利を侵害しないことの保証を含め、明示または黙示のいかなる保証も行いません。
  8. 当社製品をご使用の際は、最新の製品情報（データシート、ユーザーズマニュアル、アプリケーションノート、信頼性ハンドブックに記載の「半導体デバイスの使用上の一般的な注意事項」等）をご確認の上、当社が指定する最大定格、動作電源電圧範囲、放熱特性、実装条件その他指定条件の範囲内でご使用ください。指定条件の範囲を超えて当社製品をご使用された場合の故障、誤動作の不具合および事故につきましては、当社は、一切その責任を負いません。
  9. 当社は、当社製品の品質および信頼性の向上に努めていますが、半導体製品はある確率で故障が発生したり、使用条件によっては誤動作したりする場合があります。また、当社製品は、データシート等において高信頼性、Harsh environment 向け製品と定義しているものを除き、耐放射線設計を行っておりません。仮に当社製品の故障または誤動作が生じた場合であっても、人身事故、火災事故その他社会的損害等を生じさせないよう、お客様の責任において、冗長設計、延焼対策設計、誤動作防止設計等の安全設計およびエージング処理等、お客様の機器・システムとしての出荷保証を行ってください。特に、マイコンソフトウェアは、単独での検証は困難なため、お客様の機器・システムとしての安全検証をお客様の責任で行ってください。
  10. 当社製品の環境適合性等の詳細につきましては、製品個別に必ず当社営業窓口までお問合せください。ご使用に際しては、特定の物質の含有・使用を規制する RoHS 指令等、適用される環境関連法令を十分調査のうえ、かかる法令に適合するようご使用ください。かかる法令を遵守しないことにより生じた損害に関して、当社は、一切その責任を負いません。
  11. 当社製品および技術を国内外の法令および規則により製造・使用・販売を禁止されている機器・システムに使用することはできません。当社製品および技術を輸出、販売または移転等する場合は、「外国為替及び外国貿易法」その他日本国および適用される外国の輸出管理関連法規を遵守し、それらの定めるところに従い必要な手続きを行ってください。
  12. お客様が当社製品を第三者に転売等される場合には、事前に当該第三者に対して、本ご注意書き記載の諸条件を通知する責任を負うものといたします。
  13. 本資料の全部または一部を当社の文書による事前の承諾を得ることなく転載または複製することを禁じます。
  14. 本資料に記載されている内容または当社製品についてご不明な点がございましたら、当社の営業担当者までお問合せください。
- 注 1. 本資料において使用されている「当社」とは、ルネサス エレクトロニクス株式会社およびルネサス エレクトロニクス株式会社が直接的、間接的に支配する会社をいいます。
- 注 2. 本資料において使用されている「当社製品」とは、注 1において定義された当社の開発、製造製品をいいます。

(Rev.5.0-1 2020.10)

## 本社所在地

〒135-0061 東京都江東区豊洲 3-2-24 (豊洲フォレシア)

[www.renesas.com](http://www.renesas.com)

## お問合せ窓口

弊社の製品や技術、ドキュメントの最新情報、最寄の営業お問合せ窓口に関する情報などは、弊社ウェブサイトをご覧ください。

[www.renesas.com/contact/](http://www.renesas.com/contact/)

## 商標について

ルネサスおよびルネサスロゴはルネサス エレクトロニクス株式会社の商標です。すべての商標および登録商標は、それぞれの所有者に帰属します。