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

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

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

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

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

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



# ご注意書き

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

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

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

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

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



# H8/38076R

# I<sup>2</sup>C バスインタフェース 2 によるマスタ/スレーブ間通信

# 要旨

H8/38076R の  $I^2C2$  (Inter IC Bus Interface 2) モジュールを用いて, $I^2C$  バスフォーマットのマスタ/スレーブ間通信を行います。

# 動作確認デバイス

H8/38076R

# 目次

| 1. | 仕様              | 2  |
|----|-----------------|----|
| 2. | 使用機能説明          | 3  |
| 3. | シーケンス図          | 6  |
| 4. | 動作説明            | 8  |
| 5. | ソフトウェア説明 (マスタ)  | 15 |
| 6. | ソフトウェア説明 (スレーブ) | 31 |



# 1. 仕様

- 図1に示すように, H8/38076RのI<sup>2</sup>C バスインタフェース2を用いて, マイコン間通信を行います。
- 本タスク例では,マスタモードの H8/38076R マイコンから 4 バイトのデータを送信し,スレーブモード の H8/38076R マイコンで受信します。
- スレーブモードのマイコンは,受信したデータをマスタモードのマイコンに送信します。
- 転送クロック周波数は,250kHzです。



図 1 I<sup>2</sup>C バスマスタ/スレーブ間通信の接続図



### 2. 使用機能説明

# 2.1 使用機能

本タスク例では, $I^2C$  バスインタフェース 2 を用いて,マスタ/スレーブ間通信をします。図 2 に  $I^2C$  バスインタフェース 2 のブロック図を示し,以下に機能説明をします。

- 1. I<sup>2</sup>C バスインタフェース 2 機能
  - $I^2$ C バスインタフェース 2 は , フィリップス社の提唱する  $I^2$ C (Inter IC Bus) インタフェース方式に準拠しており , サブセット機能を備えております。
- I<sup>2</sup>C バスコントロールレジスタ 1 (ICCR1)
   I<sup>2</sup>C バスインタフェース 2 の動作/停止,送信/受信制御,マスタモード/スレーブモード,送信/受信,マスタモード転送クロック周波数の選択をします。本タスク例では,転送クロック周波数を 250kHz に設定しています。
- I<sup>2</sup>C バスコントロールレジスタ 2 (ICCR2)
   開始/停止条件発行, SDA 端子の操作, SCL 端子のモニタ, I<sup>2</sup>C バスインタフェース 2 のコントロール部のリセットを制御します。
- I<sup>2</sup>C バスモードレジスタ (ICMR) MSB ファースト/LSB ファーストの選択,マスタモードウェイトの制御,転送ビット数の選択をします。
- I<sup>2</sup>C バスステータスレジスタ (ICSR)
   各種割り込み要求フラグおよびステータスの確認をします。
- I<sup>2</sup>C バス割り込み許可レジスタ (ICIER) 各種割り込み要因の許可,アクノリッジの有効/無効の選択,送信アクノリッジの設定および受信アクノリッジの確認をします。
- I<sup>2</sup>C バス送信データレジスタ (ICDRT)
  - 送信データを格納する 8 ビットのリード/ライト可能なレジスタで ,  $I^2$ C バスシフトレジスタ (ICDRS) の空きを検出すると ICDRT に書き込まれた送信データを ICDRS に転送し ,データ送信を開始します。ICDRS のデータ送信中に ,次に送信するデータを ICDRT にライトしておくと ,連続送信が可能です。 なお ,ICMR の MLS ビットを 1 に設定した場合 , ICDRT に書き込んだ後リードすると , MSB/LSB 反転したデータが読み出されます。
- I<sup>2</sup>C バス受信データレジスタ (ICDRR)
   受信データを格納する 8 ビットのレジスタです。1 バイトのデータの受信が終了すると,受信したデータを ICDRS から ICDRR へ転送し,次のデータを受信可能にします。なお,ICDRR は受信専用レジスタですので,CPU からライトできません。
- I<sup>2</sup>C バスシフトレジスタ (ICDRS)
   データを送信/受信するためのレジスタです。送信時は ICDRT から送信データが ICDRS に転送され ,データが SDA 端子から送出されます。受信時は 1 バイトのデータの受信が終了すると ,データが ICDRS から ICDRR へ転送されます。なお ,本レジスタは CPU から直接リードできません。
- スレーブアドレスレジスタ (SAR) フォーマットの選択,スレーブアドレスを設定します。 I<sup>2</sup>C バスフォーマットでスレーブモードの場合, 開始条件後に送られてくる第 1 フレームの上位 7 ビットと SAR の上位 7 ビットが一致したとき,スレーブデバイスとして動作します。





図 2  $I^2C$  バスインタフェース 2 のブロック図



#### 2.2 機能割り付け

本タスク例の機能割り付けを表1に示します。表1に示すように機能を割り付け,I<sup>2</sup>Cバスインタフェース 2によるマスタ/スレーブ間通信をします。

表1 機能割り付け

| 機能    | 分類                | 機能割り付け                                       |
|-------|-------------------|----------------------------------------------|
| SCL   | 端子                | l <sup>2</sup> C シリアルクロック入出力端子               |
| SDA   | 端子                | I <sup>2</sup> C シリアルデータ入出力端子                |
| ICRR1 | I <sup>2</sup> C2 | I <sup>2</sup> C バスインタフェース 2 の動作/停止,送信/受信制御, |
|       |                   | マスタモード/スレーブモード,マスタモード転送クロック周波数の選択            |
| ICRR2 | I <sup>2</sup> C2 | 開始/停止条件発行,SDA 端子の操作                          |
| ICMR  | I <sup>2</sup> C2 | MSB ファースト/LSB ファーストの選択,マスタモードウェイトの制御,        |
|       |                   | 転送ビット数の選択                                    |
| ICSR  | I <sup>2</sup> C2 | I <sup>2</sup> C の動作状態を示すステータスフラグ            |
| ICIER | I <sup>2</sup> C2 | アクノリッジの有効/無効の選択,送信アクノリッジの設定および受信アクノリッジの      |
|       |                   | 確認                                           |
| ICDRT | I <sup>2</sup> C2 | 送信データを格納するレジスタ                               |
| ICDRR | I <sup>2</sup> C2 | 受信データを格納するレジスタ                               |
| ICDRS | I <sup>2</sup> C2 | データを送信/受信するためのレジスタ                           |
| SAR   | I <sup>2</sup> C2 | フォーマットの選択,スレーブアドレスの設定                        |



# 3. シーケンス図

# 3.1 マスタ送信,スレーブ受信

本タスク例におけるマスタ送信,スレーブ受信のシーケンス図を図3に示します。



図3 マスタ送信,スレーブ受信のシーケンス図



### 3.2 マスタ受信,スレーブ送信

本タスク例におけるマスタ受信,スレーブ送信のシーケンス図を図4に示します。



図4 マスタ受信,スレーブ送信のシーケンス図



# 動作説明

#### マスタ送信モード 4.1

本タスク例におけるマスタ送信モードの動作タイミングを図5,図6に示します。また,ソフトウェアお よびハードウェア処理の内容を示します。



図5 マスタ送信モード動作タイミング1





図6 マスタ送信モード動作タイミング2



### マスタ受信モード 4.2

本タスク例におけるマスタ受信モードの動作タイミングを図7,図8に示します。また,ソフトウェアお よびハードウェア処理の内容を示します。



図7 マスタ受信モード動作タイミング1





図8 マスタ受信モード動作タイミング2



### スレーブ送信モード 4.3

本タスク例におけるスレーブ送信モードの動作タイミングを図9,図10に示します。また,ソフトウェア およびハードウェア処理の内容を示します。



図9 スレーブ送信モード動作タイミング1





図 10 スレーブ送信モード動作タイミング 2



### スレーブ受信モード 4.4

本タスク例におけるスレーブ受信モードの動作タイミングを図 11,図 12に示します。また,ソフトウェ アおよびハードウェア処理の内容を示します。



図 11 スレーブ受信モード動作タイミング 1



図 12 スレーブ受信モード動作タイミング 2



# 5. ソフトウェア説明 (マスタ)

本タスク例では ,  $I^2C2$  の初期化 , スレーブデバイスおよび R/W の設定 , マスタ送信 , マスタ受信の処理を 行います。マスタプログラムで使用する関数の説明を以下に示します。

#### 関数一覧 5.1

# 表 2 マスタプログラム関数一覧

| 関数名            | 機能                     |
|----------------|------------------------|
| main           | マスタ通信の制御               |
| IIC2_init      | l <sup>2</sup> C2 の初期化 |
| set_slave_adrs | スレーブデバイスの設定,R/W の設定    |
| master_trs     | マスタ送信                  |
| master_rcv     | マスタ受信                  |

#### 使用定数説明 5.2

本タスク例で使用する定数を表3に示します。

表 3 使用定数

| ラベル名           | 定数值  | 説明              | 使用関数名      |
|----------------|------|-----------------|------------|
| SLAVE_ADRS     | H'00 | スレーブアドレス        | main       |
| IIC_DATA_WRITE | H'00 | R/W で WRITE を選択 | main       |
| IIC_DATA_READ  | H'01 | R/W で READ を選択  | main       |
| SIZE           | 4    | 送受信データサイズ       | master_trs |
|                |      |                 | master_rcv |

#### 5.3 使用 RAM 説明

本タスク例で使用する RAM を表 4 に示します。

表 4 使用 RAM

| ラベル名        | 説明          | メモリ消費量 | 使用関数名      |
|-------------|-------------|--------|------------|
| m_trs[SIZE] | 送信データ格納バッファ | 4 バイト  | master_trs |
| m_rcv[SIZE] | 受信データ格納バッファ | 4 バイト  | master_rcv |

### 5.4 モジュール説明

### 5.4.1 main()関数

- 1. モジュール仕様
- マスタ通信の制御

表 5 モジュール仕様

|    | 型  | 変数名 | 内容 |
|----|----|-----|----|
| 引数 | なし | なし  | なし |

- 2. 使用内部レジスタ説明 なし
- 3. フローチャート





#### 5.4.2 IIC2\_init()関数

- 1. モジュール仕様
- I<sup>2</sup>C2 の初期化

# 表 6 モジュール仕様

|    | 型  | 変数名 | 内容 |
|----|----|-----|----|
| 引数 | なし | なし  | なし |

### 2. 使用内部レジスタ説明

以下に,本タスク例で使用する内部レジスタを示します。なお,設定値は本タスク例において使用してい る値であり、初期値とは異なります。

• ICCR1 I<sup>2</sup>C バスコントロールレジスタ 1 アドレス: H'F078

| ビット | ビット名 | 設定値 | R/W | 機能                                                                                                                                                                                                                          |
|-----|------|-----|-----|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 7   | ICE  | 1   | R/W | I <sup>2</sup> C バスインタフェース 2 イネーブル<br>0 : 本モジュールは機能停止状態 (SCL/SDA 端子はポート/シリア<br>ル機能)                                                                                                                                         |
|     |      |     |     | 1 : 本モジュールは転送動作可能状態 (SCL/SDA はバス駆動状態)                                                                                                                                                                                       |
| 6   | RCVD | 0   | R/W | 受信ディスエーブル TRS = 0 の状態で ICDRR をリードしたときに,次の動作の継続/禁止を設定します。 0:次の受信動作を継続 1:次の受信動作を禁止                                                                                                                                            |
| 5   | MST  | 0   | R/W | マスタ/スレーブ選択                                                                                                                                                                                                                  |
| 4   | TRS  | 0   | R/W | 送信/受信選択 I <sup>2</sup> C バスフォーマットのマスタモードでバス競合負けをすると , MST, TRS ともにハードウェアによってリセットされて , スレーブ受信モードに変わります。なお , TRS の変更は転送フレーム間で行ってください。 MST と TRS との組み合わせにより , 以下の動作モードになります。 00:スレーブ受信モード 01:スレーブ送信モード 10:マスタ受信モード 11:マスタ送信モード |
| 3   | CKS3 | 0   | R/W | 転送クロック選択 3~0                                                                                                                                                                                                                |
| 2   | CKS2 | 0   | R/W | マスタモードのときのみ有効。必要な転送クロック周波数に合わ                                                                                                                                                                                               |
| 1   | CKS1 | 0   | R/W | せて設定してください。本タスク例では , 動作周波数φ = 10MHz                                                                                                                                                                                         |
| 0   | CKS0 | 1   | R/W | です。転送クロック周波数については ,表 7 を参照してください。                                                                                                                                                                                           |

# 表 7 転送クロック周波数

| ビット3 | ビット2 | ビット1 | ビット0 | クロック | 転送クロック周波数 |
|------|------|------|------|------|-----------|
| CKS3 | CKS2 | CKS1 | CKS0 |      | φ = 10MHz |
| 0    | 0    | 0    | 1    | φ/40 | 250kHz    |



• ICCR2 I<sup>2</sup>C バスコントロールレジスタ 2 アドレス: H'F079

| • ICCR | 2 FC//X | コンドロ・ | ールレン | / <b>スタ</b> 2                                                                                                                                                                                                                                                                                                                                                             |
|--------|---------|-------|------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| ビット    | ビット名    | 設定値   | R/W  | 機能                                                                                                                                                                                                                                                                                                                                                                        |
| 7      | BBSY    | 0     | R/W  | バスビジー I <sup>2</sup> C バスの占有/開放状態を示すフラグ機能とマスタモードの開始/ 停止条件発行機能の 2 つがあります。SCL = High レベルの状態で SDA が High レベルから Low レベルに変化すると , 開始条件が発 行されたと認識して 1 にセットされます。SCL = High レベルの状態で SDA が Low レベルから High レベルに変化すると , 停止条件が発行されたと認識して 0 にクリアされます。開始条件を発行する場合は BBSY に 1, SCP に 0 をライトします。開始条件再送時も同様に行います。停止条件の発行は BBSY に 0, SCP に 0 をライトすることで行います。なお ,開始条件/停止条件の発行は ,MOV 命令を用いてください。 |
| 6      | SCP     | 1     | R/W  | 開始/停止条件発行禁止ビット<br>SCP ビットはマスタモードで開始/停止条件の発行を制御しま<br>す。本ビットはリードすると常に 1 が読み出されます。1 をライトしてもデータは格納されません。                                                                                                                                                                                                                                                                      |
| 5      | SDAO    | 1     | R/W  | SDA 出力値制御 SDAOはSDAの出力レベルを変更する場合に、ビット4のSDAOP と組み合わせて使用します。なお、本ビットの操作は転送中に行わないでください。 0 をリード時、SDA 端子出力が Low レベル 0 をライト時、SDA 端子出力を Low レベルに変更 1 をリード時、SDA 端子出力が High レベル 1 をライト時、SDA 端子出力を Hi-Z に変更 (外部プルアップ抵抗により、High レベル出力)                                                                                                                                                 |
| 4      | SDAOP   | 0     | R/W  | SDAO ライトプロテクト<br>SDAO ビット書き換えによる SDA 端子の出力レベルの変更を制御<br>します。出力レベルを変更する場合には ,SDAO に 0 かつ SDAOP<br>に 0 , または SDAO に 1 かつ SDAOP に 0 を MOV 命令で行いま<br>す。本ビットはリードすると常に 1 が読み出されます。                                                                                                                                                                                               |



# I<sup>2</sup>C バスインタフェース 2 によるマスタ/スレーブ間通信

• ICMR I<sup>2</sup>C バスモードレジスタ アドレス: H'F07A

| ださい。              |
|-------------------|
|                   |
| 7クノリッジ            |
| を設定しま             |
| +->-              |
| ! 転送クロッ           |
| !続して転送            |
| #続して転送            |
|                   |
| き換える場             |
| C 1×/C 0-%        |
|                   |
|                   |
|                   |
|                   |
| すると ,残り           |
| -マットで             |
| されます。設            |
| トの値を設定            |
| iらのビット<br>10 に戻りま |
| りに戻りる             |
|                   |
|                   |
|                   |
|                   |
| ,<br>             |

• ICIER I<sup>2</sup>C バス割り込み許可レジスタ アドレス: H'F07B

| ビット | ビット名  | 設定値 | R/W | 機能                              |
|-----|-------|-----|-----|---------------------------------|
| 2   | ACKE  | 0   | R/W | アクノリッジビット判定選択                   |
|     |       |     |     | 0:受信アクノリッジの内容を無視して,連続的に転送を行う。   |
|     |       |     |     | 1:受信アクノリッジが1の場合,転送を中断する。        |
| 0   | ACKBT | 0   | R/W | 送信アクノリッジ                        |
|     |       |     |     | 受信モード時 ,アクノリッジのタイミングで送出するビットを設定 |
|     |       |     |     | します。                            |
|     |       |     |     | 0:アクノリッジのタイミングで 0 を送出           |
|     |       |     |     | 1:アクノリッジのタイミングで 1 を送出           |



# I<sup>2</sup>C バスインタフェース 2 によるマスタ/スレーブ間通信

• SAR スレーブアドレスレジスタ アドレス: H'F07D

| ビット | ビット名 | 設定値 | R/W | 機能                                          |
|-----|------|-----|-----|---------------------------------------------|
| 0   | FS   | 0   | R/W | フォーマットセレクト<br>0:I <sup>2</sup> C バスフォーマット選択 |
|     |      |     |     | 1:クロック同期シリアルフォーマット選択                        |





# 5.4.3 set\_slave\_adrs()関数

- 1. モジュール仕様
- スレーブデバイスの設定
- R/W の設定

# 表8 モジュール仕様

|    | 型             | 変数名        | 内容       |
|----|---------------|------------|----------|
| 引数 | unsigned char | slv_adrs   | スレープアドレス |
| 引数 | unsigned char | write_read | R/W の設定  |

# 2. 使用内部レジスタ

以下に,本タスク例で使用する内部レジスタを示します。なお,設定値は本タスク例において使用している値であり,初期値とは異なります。

• ICCR1 I<sup>2</sup>C バスコントロールレジスタ 1 アドレス: H'F078

| ビット | ビット名 | 設定値 | R/W | 機能                                                                                                                                                                                                             |
|-----|------|-----|-----|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 5   | MST  | 1   | R/W | マスタ/スレーブ選択                                                                                                                                                                                                     |
| 4   | TRS  | 1   | R/W | 送信/受信選択                                                                                                                                                                                                        |
|     |      |     |     | I <sup>2</sup> C バスフォーマットのマスタモードでバス競合負けをすると, MST, TRS ともにハードウェアによってリセットされて,スレーブ 受信モードに変わります。なお,TRS の変更は転送フレーム間で 行ってください。 MST と TRS との組み合わせにより,以下の動作モードになります。 00:スレーブ受信モード 01:スレーブ送信モード 10:マスタ受信モード 11:マスタ送信モード |

• ICCR2 I<sup>2</sup>C バスコントロールレジスタ 2 アドレス: H'F079

| ビット | ビット名 | 設定値 | R/W | 機能                                                                                                                                                                                                                                                                                                                                                              |
|-----|------|-----|-----|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 7   | BBSY | 1   | R/W | バスビジー I <sup>2</sup> C バスの占有/開放状態を示すフラグ機能とマスタモードの開始/停止条件発行機能の 2 つがあります。SCL = High レベルの状態で SDAが High レベルから Low レベルに変化すると ,開始条件が発行されたと認識して 1 にセットされます。SCL = High レベルの状態で SDAが Low レベルから High レベルに変化すると ,停止条件が発行されたと認識して 0 にクリアされます。開始条件を発行する場合は BBSYに 1, SCPに 0 をライトします。開始条件再送時も同様に行います。停止条件の発行は BBSYに 0, SCPに 0 をライトすることで行います。なお ,開始条件/停止条件の発行は ,MOV 命令を用いてください。 |
| 6   | SCP  | 0   | R/W | 開始/停止条件発行禁止ビット<br>SCP ビットはマスタモードで開始/停止条件の発行を制御します。本<br>ビットはリードすると常に 1 が読み出されます。1 をライトしても<br>データは格納されません。                                                                                                                                                                                                                                                        |



● ICIER I<sup>2</sup>C バス割り込み許可レジスタ アドレス: H'F07B

| ビット | ビット名  | 設定値 | R/W | 機能                                                                                                             |
|-----|-------|-----|-----|----------------------------------------------------------------------------------------------------------------|
| 1   | ACKBR | 0   | R   | 受信アクノリッジ<br>送信モード時 , 受信デバイスから受け取ったアクノリッジビット<br>の内容を格納しておくビットです。ライトは無効です。<br>0: 受信アクノリッジ = 0<br>1: 受信アクノリッジ = 1 |

• ICSR I<sup>2</sup>C バスステータスレジスタ アドレス: H'F07C

| ビット | ビット名 | 設定値 | R/W | 機能                                     |
|-----|------|-----|-----|----------------------------------------|
| 7   | TDRE | 不定  | R/W | トランスミットデータエンプティ                        |
|     |      |     |     | [セット条件]                                |
|     |      |     |     | ICDRT から ICDRS にデータ転送が行われ,ICDRT がエンプティ |
|     |      |     |     | になったとき                                 |
|     |      |     |     | TRS をセットしたとき                           |
|     |      |     |     | 開始条件 (再送含む) を発行したとき                    |
|     |      |     |     | [クリア条件]                                |
|     |      |     |     | 1 の状態をリードした後,0 をライトしたとき                |
|     |      |     |     | 命令で ICDRT ヘデータをライトしたとき                 |
| 6   | TEND | 不定  | R/W | トランスミットエンド                             |
|     |      |     |     | [セット条件]                                |
|     |      |     |     | TDRE が 1 の状態で SCL の 9 クロック目が立ち上がったとき   |
|     |      |     |     | [クリア条件]                                |
|     |      |     |     | 1 の状態をリードした後,0 をライトしたとき                |
|     |      |     |     | 命令で ICDRT ヘデータをライトしたとき                 |

• ICDRT I<sup>2</sup>C バス送信データレジスタ アドレス: H'F07E

| ビット | ビット名 | 設定値 | R/W | 機能                                                    |
|-----|------|-----|-----|-------------------------------------------------------|
| 7   | bit7 | 不定  | R/W | I <sup>2</sup> C バス送信データレジスタ                          |
| 6   | bit6 | 不定  | R/W | 送信データを格納する8ビットのリード/ライト可能なレジスタ                         |
| 5   | bit5 | 不定  | R/W | で ,I <sup>2</sup> C バスシフトレジスタ (ICDRS) の空きを検出すると ICDRT |
| 4   | bit4 | 不定  | R/W | に書き込まれた送信データを ICDRS に転送し , データ送信を開始                   |
| 3   | bit3 | 不定  | R/W | します。ICDRS のデータ送信中に次に送信するデータを ICDRT                    |
| 2   | bit2 | 不定  | R/W | にライトしておくと、連続送信が可能です。ICDRTの初期値はH'FF                    |
| 1   | bit1 | 不定  | R/W | です。                                                   |
| 0   | bit0 | 不定  | R/W |                                                       |





# 5.4.4 master\_trs()関数

- 1. モジュール仕様
- マスタ送信

# 表 9 モジュール仕様

|   | 型  | 変数名 | 内容 |
|---|----|-----|----|
| 数 | なし | なし  | なし |

### 2. 使用内部レジスタ

以下に,本タスク例で使用する内部レジスタを示します。なお,設定値は本タスク例において使用している値であり,初期値とは異なります。

• ICCR1 I<sup>2</sup>C バスコントロールレジスタ 1 アドレス: H'F078

| ビット | ビット名 | 設定値 | R/W | 機能                                                                                                                             |
|-----|------|-----|-----|--------------------------------------------------------------------------------------------------------------------------------|
| 5   | MST  | 1   | R/W | マスタ/スレーブ選択                                                                                                                     |
| 4   | TRS  | 1   | R/W | 送信/受信選択 I <sup>2</sup> C バスフォーマットのマスタモードでバス競合負けをすると, MST, TRS ともにハードウェアによってリセットされて,スレーブ受信モードに変わります。なお,TRS の変更は転送フレーム間で行ってください。 |
|     |      |     |     | MST と TRS との組み合わせにより,以下の動作モードになります。<br>00:スレーブ受信モード<br>01:スレーブ送信モード<br>10:マスタ受信モード<br>11:マスタ送信モード                              |

• ICCR2 I<sup>2</sup>C バスコントロールレジスタ 2 アドレス: H'F079

| ビット | ビット名 | 設定値 | R/W | 機能                                                                                                                                                                                                                                                                                                                                                                           |
|-----|------|-----|-----|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 7   | BBSY | 1   | R/W | バスビジー I <sup>2</sup> C バスの占有/開放状態を示すフラグ機能とマスタモードの開始/ 停止条件発行機能の 2 つがあります。SCL = High レベルの状態で SDA が High レベルから Low レベルに変化すると , 開始条件が発 行されたと認識して 1 にセットされます。SCL = High レベルの状態で SDA が Low レベルから High レベルに変化すると , 停止条件が発行されたと認識して 0 にクリアされます。開始条件を発行する場合は BBSY に 1, SCP に 0 をライトします。開始条件再送時も 同様に行います。停止条件の発行は BBSY に 0, SCP に 0 をライトすることで行います。なお , 開始条件/停止条件の発行は , MOV 命令を用いてください。 |
| 6   | SCP  | 0   | R/W | 開始/停止条件発行禁止ビット<br>SCP ビットはマスタモードで開始/停止条件の発行を制御します。 本ビットはリードすると常に 1 が読み出されます。 1 をライトしてもデータは格納されません。                                                                                                                                                                                                                                                                           |



● ICSR I<sup>2</sup>C バスステータスレジスタ アドレス: H'F07C

| ビット | ビット名 | 設定値 | R/W | 機能                                     |
|-----|------|-----|-----|----------------------------------------|
| 7   | TDRE | 不定  | R/W | トランスミットデータレジスタエンプティ                    |
|     |      |     |     | [セット条件]                                |
|     |      |     |     | ICDRT から ICDRS にデータ転送が行われ,ICDRT がエンプティ |
|     |      |     |     | になったとき                                 |
|     |      |     |     | TRS をセットしたとき                           |
|     |      |     |     | 開始条件 (再送含む) を発行したとき                    |
|     |      |     |     | [クリア条件]                                |
|     |      |     |     | 1 の状態をリードした後,0 をライトしたとき                |
|     |      |     |     | 命令で ICDRT ヘデータをライトしたとき                 |
| 6   | TEND | 不定  | R/W | トランスミットエンド                             |
|     |      |     |     | [セット条件]                                |
|     |      |     |     | TDRE が 1 の状態で SCL の 9 クロック目が立ち上がったとき   |
|     |      |     |     | [クリア条件]                                |
|     |      |     |     | 1 の状態をリードした後,0 をライトしたとき                |
|     |      |     |     | 命令で ICDRT ヘデータをライトしたとき                 |
| 3   | STOP | 不定  | R/W | 停止条件検出フラグ                              |
|     |      |     |     | [セット条件]                                |
|     |      |     |     | フレームの転送完了後に,停止条件を検出したとき                |
|     |      |     |     | [クリア条件]                                |
|     |      |     |     | 1 の状態をリードした後,0 をライトしたとき                |

### ● ICDRT I<sup>2</sup>C バス送信データレジスタ アドレス: H'F07E

| ビット | ビット名 | 設定値 | R/W | 機能                                                     |
|-----|------|-----|-----|--------------------------------------------------------|
| 7   | bit7 | 不定  | R/W | I <sup>2</sup> C バス送信データレジスタ                           |
| 6   | bit6 | 不定  | R/W | 送信データを格納する8ビットのリード/ライト可能なレジスタ                          |
| 5   | bit5 | 不定  | R/W | で , I <sup>2</sup> C バスシフトレジスタ (ICDRS) の空きを検出すると ICDRT |
| 4   | bit4 | 不定  | R/W | に書き込まれた送信データを ICDRS に転送し,データ送信を開始                      |
| 3   | bit3 | 不定  | R/W | します。ICDRS のデータ送信中に次に送信するデータを ICDRT に                   |
| 2   | bit2 | 不定  | R/W | ライトしておくと , 連続送信が可能です。ICDRT の初期値は H'FF                  |
| 1   | bit1 | 不定  | R/W | です。                                                    |
| 0   | bit0 | 不定  | R/W |                                                        |





#### 5.4.5 master\_rcv()関数

- 1. モジュール仕様
- マスタ受信

# 表 10 モジュール説明

|   | 型  | 変数名 | 内容 |
|---|----|-----|----|
| 数 | なし | なし  | なし |

### 2. 使用内部レジスタ

以下に,本タスク例で使用する内部レジスタを示します。なお,設定値は本タスク例において使用してい る値であり,初期値とは異なります。

• ICCR1 I<sup>2</sup>C バスコントロールレジスタ 1 アドレス: H'F078

| ビット | ビット名 | 設定値 | R/W | 機能                                                                                                                                                                                                              |
|-----|------|-----|-----|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 6   | RCVD | 0   | R/W | 受信ディスエーブル                                                                                                                                                                                                       |
|     |      |     |     | TRS = 0 の状態で ICDRR をリードしたときに,次の動作の継続/                                                                                                                                                                           |
|     |      |     |     | 禁止を設定します。                                                                                                                                                                                                       |
|     |      |     |     | 0:次の受信動作を継続                                                                                                                                                                                                     |
|     |      |     |     | 1:次の受信動作を禁止                                                                                                                                                                                                     |
| 5   | MST  | 1   | R/W | マスタ/スレーブ選択                                                                                                                                                                                                      |
| 4   | TRS  | 0   | R/W | 送信/受信選択                                                                                                                                                                                                         |
|     |      |     |     | I <sup>2</sup> C バスフォーマットのマスタモードでバス競合負けをすると, MST, TRS ともにハードウェアによってリセットされて,スレーブ 受信モードに変わります。なお, TRS の変更は転送フレーム間で 行ってください。 MST と TRS との組み合わせにより,以下の動作モードになります。 00:スレーブ受信モード 01:スレーブ送信モード 10:マスタ受信モード 11:マスタ送信モード |

• ICCR2 I<sup>2</sup>C バスコントロールレジスタ 2 アドレス: H'F079

| ビット | ビット名 | 設定値 | R/W | 機能                                                                                                                                                                                                                                                                                                                                                                          |
|-----|------|-----|-----|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 7   | BBSY | 1   | R/W | バスビジー I <sup>2</sup> C バスの占有/開放状態を示すフラグ機能とマスタモードの開始/ 停止条件発行機能の 2 つがあります。SCL = High レベルの状態で SDA が High レベルから Low レベルに変化すると , 開始条件が発行されたと認識して 1 にセットされます。SCL = High レベルの状態で SDA が Low レベルから High レベルに変化すると , 停止条件が発行されたと認識して 0 にクリアされます。開始条件を発行する 場合は BBSY に 1, SCP に 0 をライトします。開始条件再送時も同様に行います。停止条件の発行は BBSY に 0, SCP に 0 をライトすることで行います。なお , 開始条件/停止条件の発行は , MOV 命令を用いてください。 |
| 6   | SCP  | 0   | R/W | 開始/停止条件発行禁止ビット<br>SCP ビットはマスタモードで開始/停止条件の発行を制御します。<br>本ビットはリードすると常に 1 が読み出されます。1 をライトして<br>もデータは格納されません。                                                                                                                                                                                                                                                                    |



• ICSR I<sup>2</sup>C バスステータスレジスタ アドレス: H'F07C

| ビット | ビット名 | 設定値 | R/W | 機能                                     |
|-----|------|-----|-----|----------------------------------------|
| 7   | TDRE | 不定  | R/W | トランスミットデータエンプティ                        |
|     |      |     |     | [セット条件]                                |
|     |      |     |     | ICDRT から ICDRS にデータ転送が行われ,ICDRT がエンプティ |
|     |      |     |     | になったとき                                 |
|     |      |     |     | TRS をセットしたとき                           |
|     |      |     |     | 開始条件 (再送含む) を発行したとき                    |
|     |      |     |     | [クリア条件]                                |
|     |      |     |     | 1 の状態をリードした後,0 をライトしたとき                |
|     |      |     |     | 命令で ICDRT ヘデータをライトしたとき                 |
| 6   | TEND | 不定  | R/W | トランスミットエンド                             |
|     |      |     |     | [セット条件]                                |
|     |      |     |     | TDRE が 1 の状態で SCL の 9 クロック目が立ち上がったとき   |
|     |      |     |     | [クリア条件]                                |
|     |      |     |     | 1 の状態をリードした後,0 をライトしたとき                |
|     |      |     |     | 命令で ICDRT ヘデータをライトしたとき                 |
| 5   | RDRF | 不定  | R/W | レシーブデータレジスタフル                          |
|     |      |     |     | [セット条件]                                |
|     |      |     |     | ICDRS から ICDRR に受信データが転送されたとき          |
|     |      |     |     | [クリア条件]                                |
|     |      |     |     | 1 の状態をリードした後,0 をライトしたとき                |
|     |      |     |     | 命令で ICDRR をリードしたとき                     |
| 3   | STOP | 不定  | R/W | 停止条件検出フラグ                              |
|     |      |     |     | [セット条件]                                |
|     |      |     |     | フレームの転送完了後に,停止条件を検出したとき                |
|     |      |     |     | [クリア条件]                                |
|     |      |     |     | 1 の状態をリードした後,0 をライトしたとき                |

• ICIER I<sup>2</sup>C 割り込み許可レジスタ アドレス: H'F07B

| ビット | ビット名  | 設定値 | R/W | 機能                            |
|-----|-------|-----|-----|-------------------------------|
| 0   | ACKBT | 0   | R/W | 送信アクノリッジ                      |
|     |       |     |     | 受信モード時,アクノリッジのタイミングで送出するビットを設 |
|     |       |     |     | 定します。                         |
|     |       |     |     | 0:アクノリッジのタイミングで 0 を送出         |
|     |       |     |     | 1:アクノリッジのタイミングで 1 を送出         |

• ICDRR I<sup>2</sup>C バス受信データレジスタ アドレス: H'F07F

| ビット | ビット名 | 設定値 | R/W | 機能                                   |
|-----|------|-----|-----|--------------------------------------|
| 7   | bit7 | 不定  | R   | l <sup>2</sup> C バス受信データレジスタ         |
| 6   | bit6 | 不定  | R   | 受信データを格納する 8 ビットのレジスタです。1 バイトのデー     |
| 5   | bit5 | 不定  | R   | タの受信が終了すると,受信したデータを ICDRS から ICDRR へ |
| 4   | bit4 | 不定  | R   | 転送し,次のデータを受信可能にします。なお,ICDRR は受信専     |
| 3   | bit3 | 不定  | R   | 用レジスタですので ,CPU からライトできません。ICDRR の初期  |
| 2   | bit2 | 不定  | R   | 値は H'FF です。                          |
| 1   | bit1 | 不定  | R   |                                      |
| 0   | bit0 | 不定  | R   |                                      |







#### 5.5 リンクアドレス指定

| セクション名 | アドレス   |
|--------|--------|
| CVECT  | H'0000 |
| Р      | H'0100 |
| D, B   | H'F780 |



# 6. ソフトウェア説明 (スレーブ)

本タスク例では,  $I^2C2$  の初期化, スレーブ受信, スレーブ送信の処理を行います。スレーブプログラムで 使用する関数の説明を以下に示します。

### 関数一覧 6.1

表 11 スレーブプログラム関数一覧

| 関数名       | 機能                     |
|-----------|------------------------|
| main      | スレーブ通信の制御              |
| IIC2_init | l <sup>2</sup> C2 の初期化 |
| slave_rcv | スレーブ受信                 |
| slave_trs | スレーブ送信                 |

### 使用定数説明 6.2

本タスク例で使用する定数を表 12 に示します。

表 12 使用定数

| ラベル名 | 定数值 | 説明        | 使用関数名                  |
|------|-----|-----------|------------------------|
| SIZE | 4   | 送受信データサイズ | slave_trs<br>slave_rcv |

#### 使用 RAM 説明 6.3

本タスク例で使用する RAM を表 13 に示します。

表 13 使用 RAM

| ラベル名         | 説明           | メモリ消費量 | 使用関数名     |
|--------------|--------------|--------|-----------|
| s_data[SIZE] | 送受信データ格納バッファ | 4 バイト  | slave_trs |
|              |              |        | slave_rcv |



### モジュール説明 6.4

### 6.4.1 main()関数

- 1. モジュール仕様
- スレーブ通信の制御

表 14 モジュール仕様

|    | 型  | 変数名 | 内容 |
|----|----|-----|----|
| 引数 | なし | なし  | なし |

# 2. 使用内部レジスタ

以下に,本タスク例で使用する内部レジスタを示します。なお,設定値は本タスク例において使用してい る値であり,初期値とは異なります。

● ICIER I<sup>2</sup>C バス割り込み許可レジスタ アドレス: H'F07B

| ビット | ビット名  | 設定値 | R/W | 機能                            |
|-----|-------|-----|-----|-------------------------------|
| 0   | ACKBT | 0   | R/W | 送信アクノリッジ                      |
|     |       |     |     | 受信モード時,アクノリッジのタイミングで送出するビットを設 |
|     |       |     |     | 定します。                         |
|     |       |     |     | 0:アクノリッジのタイミングで 0 を送出         |
|     |       |     |     | 1:アクノリッジのタイミングで 1 を送出         |





# 6.4.2 IIC2\_init()

- 1. モジュール仕様
- I<sup>2</sup>C2 の初期化

# 表 15 モジュール仕様

|    | 型  | 変数名 | 内容 |
|----|----|-----|----|
| 引数 | なし | なし  | なし |

# 2. 使用内部レジスタ

以下に,本タスク例で使用する内部レジスタを示します。なお,設定値は本タスク例において使用している値であり,初期値とは異なります。

# • ICCR1 I<sup>2</sup>C バスコントロールレジスタ 1 アドレス: H'F078

|     | \$ 1 1 \$ 1 to 1 to 1 to 1 to 1 to 1 to 1 |     |     |                                       |  |  |
|-----|-------------------------------------------|-----|-----|---------------------------------------|--|--|
| ビット | ビット名                                      | 設定値 | R/W | 機能                                    |  |  |
| 7   | ICE                                       | 1   | R/W | l²C バスインタフェース 2 イネーブル                 |  |  |
|     |                                           |     |     | 0:本モジュールは機能停止状態 (SCL/SDA 端子はポート/シリア   |  |  |
|     |                                           |     |     | ル機能)                                  |  |  |
|     |                                           |     |     | 1:本モジュールは転送動作可能状態 (SCL/SDA はバス駆動状態)   |  |  |
| 6   | RCVD                                      | 0   | R/W | 受信ディスエーブル                             |  |  |
|     |                                           |     |     | TRS = 0 の状態で ICDRR をリードしたときに,次の動作の継続/ |  |  |
|     |                                           |     |     | 禁止を設定します。                             |  |  |
|     |                                           |     |     | 0:次の受信動作を継続                           |  |  |
|     |                                           |     |     | 1:次の受信動作を禁止                           |  |  |
| 5   | MST                                       | 0   | R/W | マスタ/スレーブ選択                            |  |  |
| 4   | TRS                                       | 0   | R/W | 送信/受信選択                               |  |  |
|     |                                           |     |     | $I^2C$ バスフォーマットのマスタモードでバス競合負けをすると,    |  |  |
|     |                                           |     |     | MST, TRS ともにハードウェアによってリセットされて ,スレーブ   |  |  |
|     |                                           |     |     | 受信モードに変わります。なお,TRS の変更は転送フレーム間で       |  |  |
|     |                                           |     |     | 行ってください。                              |  |  |
|     |                                           |     |     | MST と TRS との組み合わせにより,以下の動作モードになります。   |  |  |
|     |                                           |     |     | 00:スレーブ受信モード                          |  |  |
|     |                                           |     |     | 01:スレーブ送信モード                          |  |  |
|     |                                           |     |     | 10:マスタ受信モード                           |  |  |
|     |                                           |     |     | 11:マスタ送信モード                           |  |  |





 ICCR2 I<sup>2</sup>C バスコントロールレジスタ 2 アドレス: H'F079

| ビット | ビット名  | 設定値 | R/W | 機能                                                                                                                                                                                                                              |
|-----|-------|-----|-----|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 5   | SDAO  | 1   | R/W | SDA 出力値制御                                                                                                                                                                                                                       |
|     |       |     |     | SDAO は SDA の出力レベルを変更する場合に ,ビット4の SDAOP と組み合わせて使用します。なお ,本ビットの操作は転送中に行わないでください。 0 をリード時 , SDA 端子出力が Low レベル 0 をライト時 , SDA 端子出力を Low レベルに変更 1 をリード時 , SDA 端子出力が High レベル 1 をライト時 , SDA 端子出力を Hi-Z に変更 (外部プルアップ抵抗により , High レベル出力) |
| 4   | SDAOP | 0   | R/W | SDAO ライトプロテクト<br>SDAO ビット書き換えによる SDA 端子の出力レベルの変更を制御<br>します。出力レベルを変更する場合には , SDAO に 0 かつ SDAOP<br>に 0, または SDAO に 1 かつ SDAOP に 0 を MOV 命令で行います。<br>本ビットはリードすると常に 1 が読み出されます。                                                     |

● ICMR I<sup>2</sup>C バスモードレジスタ アドレス: H'F07A

| • ICMIN | 10ハス | - 1 / / | /// | )   DX : 1110/A                              |
|---------|------|---------|-----|----------------------------------------------|
| ビット     | ビット名 | 設定値     | R/W | 機能                                           |
| 7       | MLS  | 0       | R/W | MSB ファースト/LSB ファースト選択                        |
|         |      |         |     | 0: MSB ファースト                                 |
|         |      |         |     | 1 : LSB ファースト                                |
|         |      |         |     | $I^2C$ バスフォーマットで使用するときには $0$ に設定してください。      |
| 3       | BCWP | 1       | R/W | BC ライトプロテクト                                  |
|         |      |         |     | BC2~BC0 の書き込みを制御します。BC2~BC0 を書き換える場          |
|         |      |         |     | 合は , 本ビットを 0 にして MOV 命令で行います。                |
|         |      |         |     | 0 をライト時,BC2~BC0 の値を設定                        |
|         |      |         |     | 1 をリード時,常に 1 をリード                            |
|         |      |         |     | 1 をライト時,BC2~BC0 の設定値は無効                      |
| 2       | BC2  | 0       | R/W | ビットカウンタ 2~0                                  |
| 1       | BC1  | 0       | R/W | 次に転送するデータのビット数を指定します。 リードすると ,残り             |
| 0       | BC0  | 0       | R/W | の転送ビット数を知ることができます。I <sup>2</sup> C バスフォーマットで |
|         |      |         |     | は,データにアクノリッジ1ビットが加算されて転送されます。                |
|         |      |         |     | 設定は転送フレーム間で行ってください。また,000以外の値を設              |
|         |      |         |     | 定する場合は, SCL が Low 状態で行ってください。これらのビッ          |
|         |      |         |     | トはアクノリッジを含むデータ転送終了後,自動的に 000 に戻り             |
|         |      |         |     | ます。                                          |
|         |      |         |     | 000:9ビット 100:5ビット                            |
|         |      |         |     | 001:2ビット 101:6ビット                            |
|         |      |         |     | 010:3 ビット 110:7 ビット                          |
|         |      |         |     | 011:4 ビット 111:8 ビット                          |



# I<sup>2</sup>C バスインタフェース 2 によるマスタ/スレーブ間通信

# • ICIER I<sup>2</sup>C バス割り込み許可レジスタ アドレス: H'F07B

| ビット | ビット名  | 設定値 | R/W | 機能                            |
|-----|-------|-----|-----|-------------------------------|
| 2   | ACKE  | 0   | R/W | アクノリッジビット判定選択                 |
|     |       |     |     | 0:受信アクノリッジの内容を無視して,連続的に転送を行う。 |
|     |       |     |     | 1:受信アクノリッジが1の場合,転送を中断する。      |
| 0   | ACKBT | 0   | R/W | 送信アクノリッジ                      |
|     |       |     |     | 受信モード時,アクノリッジのタイミングで送出するビットを設 |
|     |       |     |     | 定します。                         |
|     |       |     |     | 0:アクノリッジのタイミングで 0 を送出         |
|     |       |     |     | 1:アクノリッジのタイミングで 1 を送出         |

# • SAR スレーブアドレスレジスタ アドレス: H'F07D

| ビット | ビット名   | 設定値 | R/W | 機能                                                                    |
|-----|--------|-----|-----|-----------------------------------------------------------------------|
| 7~1 | SVA6~0 | すべて | R/W | スレーブアドレス 6~0                                                          |
|     |        | 0   |     | I <sup>2</sup> C バスにつながる他のスレーブと異なるユニークなアドレスを<br>設定します。                |
| 0   | FS     | 0   | R/W | フォーマットセレクト<br>0: I <sup>2</sup> C バスフォーマット選択<br>1: クロック同期シリアルフォーマット選択 |





#### 6.4.3 slave\_rcv()関数

- 1. モジュール仕様
- スレーブ受信

# 表 16 モジュール仕様

|   | 型  | 変数名 | 内容 |
|---|----|-----|----|
| 数 | なし | なし  | なし |

### 2. 使用内部レジスタ

以下に,本タスク例で使用する内部レジスタを示します。なお,設定値は本タスク例において使用してい る値であり,初期値とは異なります。

● ICIER I<sup>2</sup>C バス割り込み許可レジスタ アドレス: H'F07B

| ビット | ビット名  | 設定値 | R/W | 機能                                       |
|-----|-------|-----|-----|------------------------------------------|
| 0   | ACKBT | 0   | R/W | 送信アクノリッジ                                 |
|     |       |     |     | 受信モード時 , アクノリッジのタイミングで送出するビットを設定<br>します。 |
|     |       |     |     | 0:アクノリッジのタイミングで 0 を送出                    |
|     |       |     |     | 1:アクノリッジのタイミングで 1 を送出                    |

• ICSR I<sup>2</sup>C バスステータスレジスタ アドレス: H'F07C

| ビット | ビット名 | 設定値 | R/W | 機能                                                           |
|-----|------|-----|-----|--------------------------------------------------------------|
| 5   | RDRF | 不定  | R/W |                                                              |
|     |      |     |     | [セット条件]                                                      |
|     |      |     |     | ICDRS から ICDRR に受信データが転送されたとき                                |
|     |      |     |     | [クリア条件]                                                      |
|     |      |     |     | 1 の状態をリードした後,0 をライトしたとき                                      |
|     |      |     |     | 命令で ICDRR をリードしたとき                                           |
| 1   | AAS  | 0   | R/W | スレーブアドレス認識フラグ                                                |
|     |      |     |     | スレーブ受信モードで開始条件直後の第一フレームが SAR の<br>SVA6~SVA0 と一致した場合にセットされます。 |
|     |      |     |     | [セット条件]                                                      |
|     |      |     |     | スレーブ受信モードでスレーブアドレスを検出したとき                                    |
|     |      |     |     | [クリア条件]                                                      |
|     |      |     |     | 1 の状態をリードした後,0 をライトしたとき                                      |

● ICDRR I<sup>2</sup>C バス受信データレジスタ アドレス: H'F07F

| ビット | ビット名 | 設定値 | R/W | 機能                                     |
|-----|------|-----|-----|----------------------------------------|
| 7   | bit7 | 不定  | R   | I <sup>2</sup> C バス受信データレジスタ           |
| 6   | bit6 | 不定  | R   | 受信データを格納する 8 ビットのレジスタです。1 バイトのデータ      |
| 5   | bit5 | 不定  | R   | の受信が終了すると ,受信したデータを ICDRS から ICDRR へ転送 |
| 4   | bit4 | 不定  | R   | し,次のデータを受信可能にします。なお,ICDRR は受信専用レ       |
| 3   | bit3 | 不定  | R   | ジスタですので,CPU からライトできません。ICDRR の初期値は     |
| 2   | bit2 | 不定  | R   | H'FF です。                               |
| 1   | bit1 | 不定  | R   |                                        |
| 0   | bit0 | 不定  | R   |                                        |





# 6.4.4 slave\_trs()関数

- 1. モジュール仕様
- スレーブ送信

# 表 17 モジュール仕様

|    | 型  | 変数名 | 内容 |
|----|----|-----|----|
| 引数 | なし | なし  | なし |

### 2. 使用内部レジスタ

以下に,本タスク例で使用する内部レジスタを示します。なお,設定値は本タスク例において使用している値であり,初期値とは異なります。

• ICCR1 I<sup>2</sup>C バスコントロールレジスタ 1 アドレス: H'F078

| ビット | ビット名 | 設定値 | R/W | 機能                                                                                                          |
|-----|------|-----|-----|-------------------------------------------------------------------------------------------------------------|
| 4   | TRS  | 1   | R/W | 送信/受信選択<br>開始条件を検出した後の第1フレームでスレーブアドレスが一致<br>したとき,8ビット目のデータ(R/W)が1のとき,TRSがセット<br>されます。<br>0:受信モード<br>1:送信モード |

● ICSR I<sup>2</sup>C バスステータスレジスタ アドレス: H'F07C

| ビット | ビット名 | 設定値 | R/W | 機能                                            |  |
|-----|------|-----|-----|-----------------------------------------------|--|
| 7   | TDRE | 不定  | R/W | トランスミットデータレジスタエンプティ<br>[セット条件]                |  |
|     |      |     |     | ICDRT から ICDRS にデータ転送が行われ,ICDRT がエンプティーになったとき |  |
|     |      |     |     | TRS をセットしたとき                                  |  |
|     |      |     |     | [クリア条件]                                       |  |
|     |      |     |     | 1 の状態をリードした後,0 をライトしたとき                       |  |
|     |      |     |     | 命令で ICDRT ヘデータをライトしたとき                        |  |
| 6   | TEND | 不定  | R/W | トランスミットエンド                                    |  |
|     |      |     |     | [セット条件]                                       |  |
|     |      |     |     | TDRE が 1 の状態で SCL の 9 クロック目が立ち上がったとき          |  |
|     |      |     |     | [クリア条件]                                       |  |
|     |      |     |     | 1 の状態をリードした後,0 をライトしたとき                       |  |
|     |      |     |     | 命令で ICDRT ヘデータをライトしたとき                        |  |
| 1   | AAS  | 0   | R/W | スレープアドレス認識フラグ                                 |  |
|     |      |     |     | スレーブ受信モードで開始条件直後の第 1 フレームが SAR の              |  |
|     |      |     |     | SVA6~SVA0 と一致した場合にセットされます。                    |  |
|     |      |     |     | [セット条件]                                       |  |
|     |      |     |     | スレーブ受信モードでスレーブアドレスを検出したとき                     |  |
|     |      |     |     | [クリア条件]                                       |  |
|     |      |     |     | 1 の状態をリードした後,0 をライトしたとき                       |  |



• ICDRT I<sup>2</sup>C バス送信データレジスタ アドレス: H'F07E

| ビット | ビット名 | 設定値 | R/W | 機能                                                 |
|-----|------|-----|-----|----------------------------------------------------|
| 7   | bit7 | 不定  | R/W | I <sup>2</sup> C バス送信データレジスタ                       |
| 6   | bit6 | 不定  | R/W | 送信データを格納する8ビットのリード/ライト可能なレジスタ                      |
| 5   | bit5 | 不定  | R/W | で,I <sup>2</sup> C バスシフトレジスタ(ICDRS)の空きを検出すると ICDRT |
| 4   | bit4 | 不定  | R/W | に書き込まれた送信データを ICDRS に転送し , データ送信を開始                |
| 3   | bit3 | 不定  | R/W | します。ICDRS のデータ送信中に次に送信するデータを ICDRT に               |
| 2   | bit2 | 不定  | R/W | ライトしておくと,連続送信が可能です。ICDRT の初期値は H'FF                |
| 1   | bit1 | 不定  | R/W | です。                                                |
| 0   | bit0 | 不定  | R/W |                                                    |





### 6.5 リンクアドレス指定

| セクション名 | アドレス   |
|--------|--------|
| CVECT  | H'0000 |
| Р      | H'0100 |
| В      | H'F780 |



# 改訂記録

|      |            | 改訂内容 |      |  |  |  |
|------|------------|------|------|--|--|--|
| Rev. | 発行日        | ページ  | ポイント |  |  |  |
| 1.00 | 2005.03.18 | _    | 初版発行 |  |  |  |
|      |            |      |      |  |  |  |
|      |            |      |      |  |  |  |
|      |            |      |      |  |  |  |
|      |            |      |      |  |  |  |



# 安全設計に関するお願い =

1. 弊社は品質、信頼性の向上に努めておりますが、半導体製品は故障が発生したり、誤動作する場合があります。弊社の半導体製品の故障又は誤動作によって結果として、人身事故、火災事故、社会的損害などを生じさせないような安全性を考慮した冗長設計、延焼対策設計、誤動作防止設計などの安全設計に十分ご留意ください。

### 本資料ご利用に際しての留意事項 -

- 1. 本資料は、お客様が用途に応じた適切なルネサス テクノロジ製品をご購入いただくための参考資料であり、本資料中に記載の技術情報についてルネサス テクノロジが所有する知的財産権その他の権利の実施、使用を許諾するものではありません。
- 2. 本資料に記載の製品データ、図、表、プログラム、アルゴリズムその他応用回路例の使用に起因する損害、第三者所有の権利に対する侵害に関し、ルネサステクノロジは責任を負いません。
- 3. 本資料に記載の製品データ、図、表、プログラム、アルゴリズムその他全ての情報は本資料発行時点のものであり、ルネサステクノロジは、予告なしに、本資料に記載した製品または仕様を変更することがあります。ルネサステクノロジ半導体製品のご購入に当たりましては、事前にルネサステクノロジ、ルネサス販売または特約店へ最新の情報をご確認頂きますとともに、ルネサステクノロジホームページ(http://www.renesas.com)などを通じて公開される情報に常にご注意ください。
- 4. 本資料に記載した情報は、正確を期すため、慎重に制作したものですが万一本資料の記述誤りに起因する損害がお客様に生じた場合には、ルネサステクノロジはその責任を負いません。
- 5. 本資料に記載の製品データ、図、表に示す技術的な内容、プログラム及びアルゴリズムを流用する場合は、技術内容、プログラム、アルゴリズム単位で評価するだけでなく、システム全体で十分に評価し、お客様の責任において適用可否を判断してください。ルネサステクノロジは、適用可否に対する責任は負いません。
- 6. 本資料に記載された製品は、人命にかかわるような状況の下で使用される機器あるいはシステムに用いられることを目的として設計、製造されたものではありません。本資料に記載の製品を運輸、移動体用、医療用、航空宇宙用、原子力制御用、海底中継用機器あるいはシステムなど、特殊用途へのご利用をご検討の際には、ルネサステクノロジ、ルネサス販売または特約店へご照会ください。
- 7. 本資料の転載、複製については、文書によるルネサス テクノロジの事前の承諾が必要です。
- 8. 本資料に関し詳細についてのお問い合わせ、その他お気付きの点がございましたらルネサステクノロジ、ルネサス販売または特約店までご照会ください。