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

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 において定義された当社の開発、製造製品をいいます。

# 資料中の「日立製作所」、「日立XX」等名称の株式会社ルネサス テクノロジへの変更について

2003年4月1日を以って三菱電機株式会社及び株式会社日立製作所のマイコン、ロジック、アナログ、ディスクリート半導体、及びDRAMを除くメモリ(フラッシュメモリ・SRAM等)を含む半導体事業は株式会社ルネサス テクノロジに承継されました。従いまして、本資料中には「日立製作所」、「株式会社日立製作所」、「日立半導体」、「日立XX」といった表記が残っておりますが、これらの表記は全で「株式会社ルネサス テクノロジ」に変更されておりますのでご理解の程お願い致します。尚、会社商標・ロゴ・コーポレートステートメント以外の内容については一切変更しておりませんので資料としての内容更新ではありません。

ルネサステクノロジ ホームページ (http://www.renesas.com)

2003年4月1日 株式会社ルネサス テクノロジ カスタマサポート部



#### ご注意

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

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

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

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

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

# トリガ入カカウント開始機能によるパルス出力

### 要旨

TRGV 入力に対する任意の遅延時間のパルス幅のパルス出力を行います。

# 動作確認デバイス

H8/300H Tiny シリーズーH8/3664ー

### 目次

| ごう  | 主意           | 2  |
|-----|--------------|----|
|     | <br>仕様       |    |
|     | 使用機能説明       |    |
|     | 動作原理         |    |
| 4.  | ソフトウェア説明     | 9  |
| 4.1 | 1 モジュール説明    | 9  |
| 4.2 | 2 引数の説明      | 9  |
|     | 3 使用内部レジスタ説明 |    |
| 4.4 | 4 使用 RAM 説明  | 10 |
| 5.  | フローチャート      | 11 |
| 6   | プログラムリスト     | 12 |

2003.02

ADJ-502-152 16-bit / H8/300H Tiny

#### ご注意

1. 本書に記載の製品及び技術のうち「外国為替及び外国貿易法」に基づき安全保障貿易管理関連貨物・技術に該当するものを輸出する場合、または国外に持ち出す場合は日本国政府の許可が必要です。

- 2. 本書に記載された情報の使用に際して,弊社もしくは第三者の特許権,著作権,商標権,その他の知的所有権等の権利に対する保証または実施権の許諾を行うものではありません。また本書に記載された情報を使用した事により第三者の知的所有権等の権利に関わる問題が生じた場合,弊社はその責を負いませんので予めご了承ください。
- 3. 製品及び製品仕様は予告無く変更する場合がありますので、最終的な設計、ご購入、ご使用に際しましては、事前に最新の製品規格または仕様書をお求めになりご確認ください。
- 4. 弊社は品質・信頼性の向上に努めておりますが、宇宙、航空、原子力、燃焼制御、運輸、交通、各種安全装置、ライフサポート関連の医療機器等のように、特別な品質・信頼性が要求され、その故障や誤動作が直接人命を脅かしたり、人体に危害を及ぼす恐れのある用途にご使用をお考えのお客様は、事前に弊社営業担当迄ご相談をお願い致します。
- 5. 設計に際しては、特に最大定格、動作電源電圧範囲、放熱特性、実装条件及びその他諸条件につきましては、弊社保証範囲内でご使用いただきますようお願い致します。保証値を越えてご使用された場合の故障及び事故につきましては、弊社はその責を負いません。また保証値内のご使用であっても半導体製品について通常予測される故障発生率、故障モードをご考慮の上、弊社製品の動作が原因でご使用機器が人身事故、火災事故、その他の拡大損害を生じないようにフェールセーフ等のシステム上の対策を講じて頂きますようお願い致します。
- 6. 本製品は耐放射線設計をしておりません。
- 7. 本書の一部または全部を弊社の文書による承認なしに転載または複製することを堅くお断り致します。
- 8. 本書をはじめ弊社半導体についてのお問い合わせ、ご相談は弊社営業担当迄お願い致します。

Copyright©Hitachi, Ltd., 2003. All rights reserved.

2003.02

ADJ-502-152 16-bit / H8/300H Tiny

Page 2 http://www.renesas.com

#### 1. 仕様

1. 図 1.1 に示すように、TRGV 入力に対する任意の遅延時間のパルス幅のパルス出力を行ないます。

- 2. 出力パルスは、タイマ V 出力 (TMOV) 端子より出力します。
- 3. カウント開始トリガ入力端子 (TRGV) 入力からの遅延時間は、タイムコンスタントレジスタ A (TCORA) により設定します。
- 4. 出力するパルスのパルス幅は、タイムコンスタントレジスタ B (TCORB) により設定します。
- 5. 本タスク例では、TRGV 入力からの遅延時間が 0.8ms、パルス幅が 0.2ms のパルスを出力します。



図 1.1 トリガ入力カウント開始機能によるパルス出力

2003.02

ADJ-502-152 16-bit / H8/300H Tiny

Page 3 http://www.renesas.com

#### 2. 使用機能説明

1. 本タスク例では、タイマ V トリガ入力によるカウント開始機能を使用して、TMOV 出力端子より、 TRGV入力に対する任意の遅延時間のパルス幅のパルス出力を行ないます。

- (a) 図 2.1 にタイマ V トリガ入力によるカウント開始機能のブロック図を示します。 以下にタイマVトリガ入力によるカウント開始機能ブロック図について説明します。
- システムクロック(φ)は、16MHzのOSCクロックで、CPUおよび周辺機能を動作させるための基
- プリスケーラ S (PSS) は、φを入力とする 13 ビットのカウンタで、1 サイクルごとにカウントアッ プします。
- タイマカウンタ V(TCNTV)は、8 ビットのリード/ライト可能なアップカウンタで、入力する内部 クロック/外部クロックによりカウントアップされます。入力するクロックは φを分周した 6 種類の クロックと、3種類の外部クロックより選択できます。
- タイマコントロールレジスタ V0 (TCRV0) は、8 ビットのリード/ライト可能なレジスタで、TCNTV の入力クロックの選択、TCNTV のクリア指定を行います。本タスク例では、TCNTV の入力クロッ クにゅの 64 分周のクロックを、TCNTV のクリア指定にコンペアマッチ B によるクリアを選択して います。
- タイマコントロールレジスタ V1(TCRV1)は、8 ビットのリード/ライト可能なレジスタで、TRGV 端子の入力エッジの選択、TRGV 端子入力による TCNTV カウントアップの開始と、コンペアマッチ による TCNTV クリア時の TCNTV カウントアップ停止の許可/禁止、TCRV0 とともに TCNTV 入力 クロックの選択を行ないます。
- タイマコントロール/ステータスレジスタ V(TCSRV)は、8 ビットのリード/ライト可能なレジスタ で、コンペアマッチ出力の制御を行ないます。本タスク例では、コンペアマッチBでTMOV端子よ り "0"を出力、ンペアマッチ A で TMOV 端子より "1"を出力するように設定しています。
- タイムコンスタントレジスタ A (TCORA) は、8 ビットのリード/ライト可能なレジスタで、TCORA の内容は TCNTV と常に比較されており、両者の値が一致するとコンペアマッチ A により、TMOV 端子より"1"を出力します。
- タイムコンスタントレジスタ B (TCORB) は、8 ビットのリード/ライト可能なレジスタで、TCORB の内容は TCNTV と常に比較されており、両者の値が一致するとコンペアマッチ B により、TMOV 端子より "0" を出力し、TCNTV を H'00 にクリアします。
- タイマ V 出力端子(TMOV)よりパルスを出力します。
- トリガ入力端子(TRGV)より、トリガを入力します。

ADJ-502-152 16-bit / H8/300H Tiny

http://www.renesas.com

2003.02



図 2.1 トリガ入力によるカウント開始機能ブロック図

2003.02

ADJ-502-152 16-bit / H8/300H Tiny

Page 5 http://www.renesas.com

(b) 図 2.2 に TRGV 入力から任意の遅延時間のパルス幅のパルス出力における遅延時間と、パルス幅の設定方法について示します。



図 2.2 TRGV 入力からの遅延時間、およびパルス幅の設定方法

2003.02

ADJ-502-152 16-bit / H8/300H Tiny

Page 6 http://www.renesas.com

2. 表 2.1 に本タスク例の機能割付けを示します。表 2.1 に示すように機能を割付け、タイマ V トリガ入力によるカウント開始機能によるパルス出力を行ないます。

表 2.1 機能割り付け

| 機能    | 機能割付け                                        |
|-------|----------------------------------------------|
| PSS   | システムクロックを入力とする 13 ビットのカウンタ                   |
| TCNTV | システムクロックの 64 分周のクロックを入力とする 8 ビットのカウンタ        |
| TCORA | 遅延時間設定によるコンペアマッチ A の設定                       |
| TCORB | パルス幅設定によるコンペアマッチ B の設定                       |
| TCRV0 | TCNTV の入力クロックの選択、および TCNTV のクリア指定の選択         |
| TCRV1 | TRGV 端子のエッジセレクト、TRGV 入力イネーブル、TCNTV 入力クロックの設定 |
| TCSRV | コンペアマッチ出力の制御                                 |
| TMOV  | パルス出力端子                                      |
| TRGV  | トリガ入力端子                                      |

2003.02

ADJ-502-152 16-bit / H8/300H Tiny

Page 7 http://www.renesas.com

#### 3. 動作原理

図 3.1 に動作原理を示します。図 3.1 に示すようなハードウェア処理、およびソフトウェア処理によりタイマ V トリガ入力カウント開始機能によるパルス出力を行ないます。



図 3.1 タイマ V トリガ入カカウントアップ開始機能によるパルス出力動作原理

2003.02

ADJ-502-152 16-bit / H8/300H Tiny

Page 8 http://www.renesas.com

# 4. ソフトウェア説明

#### 4.1 モジュール説明

表 4.1 に本タスク例におけるモジュール説明を示します。

表 4.1 モジュール説明

| モジュール名  | ラベル名 | 機能                                                               |
|---------|------|------------------------------------------------------------------|
| メインルーチン | main | コンペアマッチ A,B の設定、TCNTV のイニシャライズ、TRGV 入力<br>端子の設定、TMOV 出力端子の設定を行う。 |

# 4.2 引数の説明

本タスク例では、引数は使用していません。

2003.02

ADJ-502-152 16-bit / H8/300H Tiny

Page 9 http://www.renesas.com

### 4.3 使用内部レジスタ説明

表 4.2 に本タスク例における使用内部レジスタ説明を示します。

表 4.2 使用内部レジスタ説明

| レジスタ名 |      | 機能                                                                                                                                                                                              | アドレス           | 設定値  |
|-------|------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|----------------|------|
| TCRV0 |      | タイマコントロールレジスタ V0<br>: TCRV0=H'13 のとき、CMFB、CMFA、OVF による割り込み<br>の禁止、TCNTV のクリア指定をコンペアマッチ B による<br>クリアに設定、および TCNTV の入力をシステムクロックの<br>64 分周のクロックに設定                                                 | H'FFA0         | H'13 |
| TCSRV |      | タイマコントロール/ステータスレジスタ V<br>: TCSRV=H'16 のとき、コンペアマッチ A により TMOV 端子<br>より"1"を出力、コンペアマッチ B により TMOV 端子より"0"<br>を出力するように設定                                                                            | H'FFA1         | H'16 |
| TCORA |      | タイムコンスタントレジスタ A<br>: TCORA=H'C8 のとき、TCNTV のカウンタ値が H'C8 まで<br>カウントアップするとコンペアマッチ A が発生                                                                                                            | H'FFA2         | H'C8 |
| TCORB |      | タイムコンスタントレジスタ B<br>: TCORB=H'FA のとき、TCNTV のカウンタ値が H'FA まで<br>カウントアップするとコンペアマッチ B が発生                                                                                                            | H'FFA3         | H'FA |
| TCNTV |      | タイマカウンタ V<br>: システムクロックの 64 分周のクロックを入力とする 8 ビット<br>のアップカウンタ                                                                                                                                     | H'FFA4         | H'00 |
| TCRV1 |      | タイマコントロールレジスタ V1 : TCRV1=H'F6 のとき、TRGV 端子の入力エッジを<br>立ち下がりエッジに設定、TRGV 端子入力による<br>TCNTV カウントアップの開始とコンペアマッチによる<br>TCNTV クリア時の TCNTV カウントアップの停止を許可、<br>および TCNTV 入力クロックをシステムクロックの 64 分周の<br>クロックに設定 | H'FFA5         | H'F6 |
| PMR1  | IRQ3 | ポートモードレジスタ 1(P17/ĪRQ3/TRGV 端子機能切り替え)<br>: IRQ3="1"のとき、P17/ĪRQ3/TRGV 端子を<br>ĪRQ3/TRGV 入力端子機能に設定                                                                                                  | H'FFE0<br>ビット7 | 1    |

# 4.4 使用 RAM 説明

本タスク例では使用しません。

2003.02

ADJ-502-152 16-bit / H8/300H Tiny

Page 10 http://www.renesas.com

#### 5. フローチャート

(a) メインルーチン



2003.02

ADJ-502-152 16-bit / H8/300H Tiny

Page 11 http://www.renesas.com

# 6. プログラムリスト

INIT.SRC (プログラムリスト)

```
.EXPORT_INIT
.IMPORT_main
;
.SECTION P,CODE
_INIT:

MOV.W #H'FF80,R7

LDC.B #B'10000000,CCR

JMP @_main
;
.END
```

#include <machine.h>

2003.02

ADJ-502-152 16-bit / H8/300H Tiny

Page 12 http://www.renesas.com

```
Symbol Defnition
struct BIT {
 unsigned char b7:1;
               /* bit7
                                                        * /
 unsigned char b6:1;
               /* bit6
 unsigned char b5:1;
               /* bit5
               /* bit4
 unsigned char b4:1;
         b3:1;
               /* bit3
 unsigned char
 unsigned char b2:1;
               /* bit2
 unsigned char
         b1:1;
               /* bit1
 unsigned char
         b0:1;
               /* bit0
};
#define
     TCRV0
           *(volatile unsigned char *)0xFFA0 /* Time Constant Register V0
#define
     TCSRV
          *(volatile unsigned char *)0xFFA1 /* Timer Control/Status Register V
#define
     TCORA
           #define
     TCORB
          *(volatile unsigned char *)0xFFA3 /* Time Constant Reguster B
#define
     TCNTV
          *(volatile unsigned char *)0xFFA4 /* Timer Counter V
#define
     TCRV1
           #define
     PMR1_BIT (*(struct BIT *)0xFFE0)
                              /* TPort Mode Register 1
          PMR1 BIT.b7
                               /* P17/IRQ3/TRGV Terminal Function Change
#define
     IRO3
                                                        * /
関数定義
/* SP Set
                                                        * /
extern void INIT (void);
void
   main
         ( void );
void
   trgmn
        ( void );
Vector Address
#pragma section
            V1
                              /* VECTOR SECTOIN SET
void (*const VEC_TBL1[])(void) = {
/* 0x00 - 0x0f */
 INIT
                               /* 00 Reset
                                                        * /
};
```

2003.02

ADJ-502-152 16-bit / H8/300H Tiny

Page 13 http://www.renesas.com

```
#pragma section
/* Main Program
void main ( void )
{
  TCNTV = 0x00;
                                              /* Initialze TCNTV
                                                                                    * /
  IRQ3 = 1;
                                              /* Initialze TRGV Input Terminal Function
  TCORA = 0xC8;
                              /* Initialize Compare Match A(Set Output Pulse Delay Time)
  TCORB = 0xFA;
                              /* Initialize Compare Match B(Set Output Pulse Width)
                                                                                    * /
  TCSRV = 0x16;
                                              /* Initialize TMOV Terminal Output
  TCRV1 = 0xF6;
                                              /* Initialize Trigger Input Function
  TCRV0 = 0x13;
                             /* Initialize TCNTV Clear Condition & TCNTV Input Clock
                                                                                    * /
  while(1) {
}
```

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

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

ADJ-502-152 16-bit / H8/300H Tiny