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

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



## ユーザーズ・マニュアル

# μPD780024AS, 780034ASサブシリーズ

8ビット・シングルチップ・マイクロコンピュータ

 $\mu$ PD780021AS  $\mu$ PD780021AS(A)

 $\mu$ PD780022AS  $\mu$ PD780022AS(A)

 $\mu$ PD780023AS  $\mu$ PD780023AS(A)

 $\mu$ PD780024AS  $\mu$ PD780024AS(A)

 $\mu$ PD780031AS  $\mu$ PD780031AS(A)

 $\mu$ PD780032AS  $\mu$ PD780032AS(A)

 $\mu$ PD780033AS  $\mu$ PD780033AS(A)

 $\mu$ PD780034AS  $\mu$ PD780034AS(A)

 $\mu$ PD78F0034BS  $\mu$ PD78F0034BS(A)

資料番号 U16035JJ4V1UD00 (第 4 版) 発行年月 January 2005 N CP(K) (メ モ)

## 目次要約

第1章 概 説 … 16 第 2 章 端子機能 … 27 第3章 CPUアーキテクチャ … 37 第4章 ポート機能 … 70 第5章 クロック発生回路 … 91 第6章 16ビット・タイマ/イベント・カウンタ0 … 106 第7章 8ビット・タイマ/イベント・カウンタ50,51 … 142 第8章 時計用タイマ … 166 第9章 ウォッチドッグ・タイマ … 171 第10章 クロック出力/ブザー出力制御回路 … 176 第11章 8ビットA/Dコンバータ(μPD780024ASサブシリーズ) ··· 181 第12章 10ビットA/Dコンバータ(μPD780034ASサブシリーズ) ··· 203 第13章 シリアル・インタフェースUARTO … 225 第14章 シリアル・インタフェースSIO30, SIO31 ··· 253 第15章 割り込み機能 … 264 第16章 スタンバイ機能 … 286 第17章 リセット機能 … 294 第**18**章 μ PD78F0034BS ··· 298 第19章 命令セットの概要 … 312 第20章 電気的特性 … 327 第21章 外形図 … 349 第22章 半田付け推奨条件 … 350 付録 A μ PD780024A, 780024AS, 780034A, 780034ASサブシリーズ間の違い ... 352 付録B 開発ツール … 354 付録C ターゲット・システム設計上の注意 … 361

付録D レジスタ索引 … 363

付録 E 改版履歴 … 369

## CMOSデバイスの一般的注意事項・

#### ① 入力端子の印加波形

入力ノイズや反射波による波形歪みは誤動作の原因になりますので注意してください。

CMOSデバイスの入力がノイズなどに起因して、 $V_{\text{IL}}$ (MAX.)から $V_{\text{IH}}$ (MIN.)までの領域にとどまるような場合は、誤動作を引き起こす恐れがあります。入力レベルが固定な場合はもちろん、 $V_{\text{IL}}$ (MAX.)から $V_{\text{IH}}$ (MIN.)までの領域を通過する遷移期間中にチャタリングノイズ等が入らないようご使用ください。

## ② 未使用入力の処理

CMOSデバイスの未使用端子の入力レベルは固定してください。

未使用端子入力については、CMOSデバイスの入力に何も接続しない状態で動作させるのではなく、プルアップかプルダウンによって入力レベルを固定してください。また、未使用の入出力端子が出力となる可能性(タイミングは規定しません)を考慮すると、個別に抵抗を介してVoDまたはGNDに接続することが有効です。

資料中に「未使用端子の処理 | について記載のある製品については、その内容を守ってください。

#### ③ 静電気対策

MOSデバイス取り扱いの際は静電気防止を心がけてください。

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

また、MOSデバイスを実装したボードについても同様の扱いをしてください。

## ④ 初期化以前の状態

電源投入時, MOSデバイスの初期状態は不定です。

電源投入時の端子の出力状態や入出力設定、レジスタ内容などは保証しておりません。ただし、リセット動作やモード設定で定義している項目については、これらの動作ののちに保証の対象となります。

リセット機能を持つデバイスの電源投入後は、まずリセット動作を実行してください。

#### ⑤ 電源投入切断順序

内部動作および外部インタフェースで異なる電源を使用するデバイスの場合,原則として内部電源を投入した後に外部電源を投入してください。切断の際には、原則として外部電源を切断した後に内部電源を切断してください。逆の電源投入切断順により、内部素子に過電圧が印加され、誤動作を引き起こしたり、異常電流が流れ内部素子を劣化させたりする場合があります。

資料中に「電源投入切断シーケンス」についての記載のある製品については、その内容を守ってください。

## ⑥ 電源OFF時における入力信号

当該デバイスの電源がOFF状態の時に、入力信号や入出力プルアップ電源を入れないでください。 入力信号や入出力プルアップ電源からの電流注入により、誤動作を引き起こしたり、異常電流が流れ内部素子を劣化させたりする場合があります。

資料中に「電源OFF時における入力信号」についての記載のある製品については、その内容を守ってください。

FIP, IEBusは, NECエレクトロニクス株式会社の登録商標です。

WindowsおよびWindowsNTは、米国Microsoft Corporationの米国およびその他の国における登録商標または商標です。

PC/ATは、米国IBM社の商標です。

HP9000シリーズ700, HP-UXは, 米国ヒューレット・パッカード社の商標です。

SPARCstationは、米国SPARC International, Inc.の商標です。

Solaris, SunOSは、米国サン・マイクロシステムズ社の商標です。

TRONは、The Realtime Operating system Nucleusの略称です。

ITRONは、Industrial TRONの略称です。

本製品のうち、外国為替及び外国貿易法の規定により規制貨物等(または役務)に該当するものについては、日本国外に輸出する際に、同法に基づき日本国政府の輸出許可が必要です。

非 該 当 品: μPD78F0034BSGB-8ET, 78F0034BSGB(A)-8ET

ユーザ判定品:  $\mu$  PD780021ASGB- $\times$  $\times$  $\times$ -8ET, 780022ASGB- $\times$  $\times$  $\times$ -8ET, 780023ASGB- $\times$  $\times$  $\times$ -8ET,  $\mu$  PD780024ASGB- $\times$  $\times$  $\times$ -8ET, 780031ASGB- $\times$  $\times$  $\times$ -8ET, 780032ASGB- $\times$  $\times$  $\times$ -8ET,  $\mu$  PD780033ASGB- $\times$  $\times$  $\times$ -8ET, 780034ASGB- $\times$  $\times$  $\times$ -8ET,  $\mu$  PD780021ASGB(A)- $\times$  $\times$  $\times$ -8ET, 780022ASGB(A)- $\times$  $\times$  $\times$ -8ET, 780032ASGB(A)- $\times$  $\times$  $\times$ -8ET,  $\mu$  PD780024ASGB(A)- $\times$  $\times$  $\times$ -8ET, 780031ASGB(A)- $\times$  $\times$  $\times$ -8ET, 780033ASGB(A)- $\times$  $\times$  $\times$ -8ET, 780034ASGB(A)- $\times$  $\times$  $\times$ -8ET, 780033ASGB(A)- $\times$  $\times$  $\times$ -8ET, 780034ASGB(A)- $\times$  $\times$  $\times$ -8ET

- ◆本資料に記載されている内容は2004年11月現在のもので、今後、予告なく変更することがあります。量産設計の際には最新の個別データ・シート等をご参照ください。
- 文書による当社の事前の承諾なしに本資料の転載複製を禁じます。当社は、本資料の誤りに関し、一切 その責を負いません。
- 当社は、本資料に記載された当社製品の使用に関連し発生した第三者の特許権、著作権その他の知的財産権の侵害等に関し、一切その責を負いません。当社は、本資料に基づき当社または第三者の特許権、著作権その他の知的財産権を何ら許諾するものではありません。
- ◆本資料に記載された回路、ソフトウェアおよびこれらに関する情報は、半導体製品の動作例、応用例を 説明するものです。お客様の機器の設計において、回路、ソフトウェアおよびこれらに関する情報を使 用する場合には、お客様の責任において行ってください。これらの使用に起因しお客様または第三者に 生じた損害に関し、当社は、一切その責を負いません。
- 当社は、当社製品の品質、信頼性の向上に努めておりますが、当社製品の不具合が完全に発生しないことを保証するものではありません。当社製品の不具合により生じた生命、身体および財産に対する損害の危険を最小限度にするために、冗長設計、延焼対策設計、誤動作防止設計等安全設計を行ってください。
- 当社は、当社製品の品質水準を「標準水準」、「特別水準」およびお客様に品質保証プログラムを指定 していただく「特定水準」に分類しております。また、各品質水準は、以下に示す用途に製品が使われ ることを意図しておりますので、当社製品の品質水準をご確認ください。

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

特別水準:輸送機器(自動車,電車,船舶等),交通用信号機器,防災・防犯装置,各種安全装置, 生命維持を目的として設計されていない医療機器

特定水準: 航空機器, 航空宇宙機器, 海底中継機器, 原子力制御システム, 生命維持のための医療機器, 生命維持のための装置またはシステム等

当社製品のデータ・シート、データ・ブック等の資料で特に品質水準の表示がない場合は、標準水準製品であることを表します。意図されていない用途で当社製品の使用をお客様が希望する場合には、事前に当社販売窓口までお問い合わせください。

(注)

- (1) 本事項において使用されている「当社」とは、NECエレクトロニクス株式会社およびNECエレクトロニクス株式会社がその総株主の議決権の過半数を直接または間接に保有する会社をいう。
- (2) 本事項において使用されている「当社製品」とは、(1) において定義された当社の開発、製造製品をいう。

M8E 02.11

## はじめに

対象者 このマニュアルは、 $\mu$ PD780024AS, 780034ASサブシリーズの機能を理解し、その応用システムや応用プログラムを設計、開発するユーザのエンジニアを対象としています。

対象製品は、次に示すサブシリーズの各製品です。

・ $\mu$ PD780024ASサブシリーズ :  $\mu$ PD780021AS, 780022AS, 780023AS, 780024AS,

780021AS(A), 780022AS(A), 780023AS(A), 780024AS(A)

・ $\mu$ PD780034ASサブシリーズ :  $\mu$ PD780031AS, 780032AS, 780033AS, 780034AS, 78F0034BS,

780031AS(A), 780032AS(A), 780033AS(A), 780034AS(A),

78F0034BS(A)

- 目 的 このマニュアルは、次の構成に示す機能をユーザに理解していただくことを目的としています。
- 構 成  $\mu$  PD780024AS, 780034ASサブシリーズのマニュアルは、このマニュアルと命令編(78K/0シリーズ 共通)の 2 冊に分かれています。

μ PD780024AS, 780034ASサブシリーズ ユーザーズ・マニュアル (このマニュアル) 78K/0シリーズ ユーザーズ・マニュアル 命令編

- ●端子機能
- ●内部ブロック機能
- ●割り込み
- ●その他の内蔵周辺機能
- ●電気的特性

- ●CPU機能
- ●命令セット
- ●命令の説明
- 読み方 このマニュアルを読むにあたっては、電気、論理回路、マイクロコンピュータの一般知識を必要とします。
  - □ (A) 製品のマニュアルとしてお使いになる方へ
    - →標準製品と(A)製品は、品質水準のみが異なります。(A)製品については、品名を次のように読み替えてください。

 $\mu$  PD780021AS  $\rightarrow \mu$  PD780021AS(A)

 $\mu$  PD780032AS  $\rightarrow \mu$  PD780032AS(A)

 $\mu PD780022AS \rightarrow \mu PD780022AS(A)$ 

 $\mu PD780033AS \rightarrow \mu PD780033AS(A)$ 

 $\mu$  PD780023AS  $\rightarrow \mu$  PD780023AS(A)

 $\mu PD780034AS \rightarrow \mu PD780034AS(A)$ 

 $\mu$  PD780024AS  $\rightarrow \mu$  PD780024AS(A)

 $\mu$  PD78F0034BS  $\rightarrow \mu$  PD78F0034BS(A)

 $\mu$  PD780031AS  $\rightarrow \mu$  PD780031AS(A)

- □一通りの機能を理解しようとするとき
  - →目次に従って読んでください。本文欄外の★印は、本版で改訂された主な箇所を示しています。
- □レジスタ・フォーマットの見方
  - →ビット番号を $\square$ で囲んでいるものは、そのビット名称がRA78K0では予約語に、CC78K0では #pragma sfr指令で、sfr変数として定義されているものです。
- □レジスタ名が分かっていて、レジスタの詳細を確認するとき
  - →付録D レジスタ索引を利用してください。

## μPD780024AS, 780034ASサブシリーズ間の違い

 $\mu$ PD780024AS, 780034ASサブシリーズ間では、A/Dコンバータの分解能が異なります。

| サブシリーズ名  | μPD780024AS | μPD780034AS |
|----------|-------------|-------------|
| 項目       |             |             |
| A/Dコンバータ | 8ビット分解能     | 10ビット分解能    |

凡 例 データ表記の重み : 左が上位桁, 右が下位桁

アクティブ・ロウの表記: $\overline{XXX}$ (端子,信号名称に上線)

注 :本文中につけた注の説明

注意 :気をつけて読んでいただきたい内容

備考 : 本文の補足説明

数の表記 :2進数···×××stcは×××xB

> 10進数···××× 16進数···××××H

関連資料 関連資料は暫定版の場合がありますが、この資料では「暫定」の表示をしておりません。あらかじめご 了承ください。

## デバイスの関連資料

| 資 料 名                                   | 資料番号    |         |  |
|-----------------------------------------|---------|---------|--|
|                                         | 和文      | 英 文     |  |
| μPD780024AS, 780034ASサブシリーズ ユーザーズ・マニュアル | このマニュアル | U16035E |  |
| 78K/0シリーズ ユーザーズ・マニュアル 命令編               | U12326J | U12326E |  |
| 78K/0シリーズ アプリケーション・ノート 基礎編( I )         | U12704J | U12704E |  |

## 開発ツール(ソフトウエア)の資料(ユーザーズ・マニュアル)

| 資 料 名                          | 資 料 名         |         |         |  |  |  |
|--------------------------------|---------------|---------|---------|--|--|--|
|                                |               | 和文      | 英 文     |  |  |  |
| RA78K0 アセンブラ・パッケージ             | 操作編           | U16629J | U16629E |  |  |  |
|                                | 言語編           | U14446J | U14446E |  |  |  |
|                                | 構造化アセンブリ言語編   | U11789J | U11789E |  |  |  |
| CC78K0 Cコンパイラ                  | 操作編           | U16613J | U16613E |  |  |  |
|                                | 言語編           | U14298J | U14298E |  |  |  |
| SM78Kシリーズ Ver.2.52 システム・シミュレータ | 操作編           | U16768J | U16768E |  |  |  |
|                                | 外部部品ユーザ・オープン・ | U15802J | U15802E |  |  |  |
|                                | インタフェース仕様編    |         |         |  |  |  |
| ID78K0-NS Ver.2.52 統合ディバッガ     | 操作編           | U16488J | U16488E |  |  |  |
| ID78K0 統合ディバッガ EWSベース          | レファレンス編       | U11151J |         |  |  |  |
| PM plus Ver.5.20               |               | U16934J | U16934E |  |  |  |

注意 上記関連資料は予告なしに内容を変更することがあります。設計などには必ず最新の資料をご使用ください。

## 開発ツール(ハードウエア)の資料(ユーザーズ・マニュアル)

| 資料 名                          | 資料番号    |         |  |  |
|-------------------------------|---------|---------|--|--|
|                               | 和文      | 英 文     |  |  |
| IE-78K0-NS インサーキット・エミュレータ     | U13731J | U13731E |  |  |
| IE-78K0-NS-A インサーキット・エミュレータ   | U14889J | U14889E |  |  |
| IE-78K0-NS-PA パフォーマンス・ボード     | U16109J | 作成予定    |  |  |
| IE-780034-NS-EM1 エミュレーション・ボード | U14642J | U14642E |  |  |

## フラッシュ・メモリ書き込み用の資料

| 資 料 名                              | 資料番号    |         |  |
|------------------------------------|---------|---------|--|
|                                    | 和文      | 英 文     |  |
| PG-FP3 フラッシュ・メモリ・プログラマ ユーザーズ・マニュアル | U13502J | U13502E |  |
| PG-FP4 フラッシュ・メモリ・プログラマ ユーザーズ・マニュアル | U15260J | U15260E |  |

## その他の資料

| 資 料 名                                                 | 資料番号    |         |  |  |
|-------------------------------------------------------|---------|---------|--|--|
|                                                       | 和文      | 英 文     |  |  |
| SEMICONDUCTOR SELECTION GUIDE -Products and Packages- | X13769X |         |  |  |
| 半導体デバイス 実装マニュアル                                       | 注       |         |  |  |
| NEC半導体デバイスの品質水準                                       | C11531J | C11531E |  |  |
| NEC半導体デバイスの信頼性品質管理                                    | C10983J | C10983E |  |  |
| 静電気放電(ESD)破壊対策ガイド                                     | C11892J | C11892E |  |  |
| 半導体 品質/信頼性ハンドブック                                      | C12769J | _       |  |  |
| マイクロコンピュータ関連製品ガイド 社外メーカ編                              | U11416J | _       |  |  |

注 「半導体デバイス実装マニュアル」のホーム・ページ参照

和文:http://www.necel.com/pkg/ja/jissou/index.html 英文:http://www.necel.com/pkg/en/mount/index.html

注意 上記関連資料は予告なしに内容を変更することがあります。設計などには必ず最新の資料をご使用ください。

## 目 次

第1章 概 説 … 16

|     | 1.2<br>1.3<br>1.4<br>1.5<br>1.6 | 特 徴 … 16<br>応用分野 … 17<br>オーダ情報 … 17<br>品質水準 … 18<br>端子接続図(Top View) … 19<br>78K/0シリーズの展開 … 21<br>ブロック図 … 24<br>機能概要 … 25<br>標準水準品と特別水準品との違いについて … 26 |
|-----|---------------------------------|------------------------------------------------------------------------------------------------------------------------------------------------------|
| 第 2 | 章                               | <b>端子機能</b> … 27                                                                                                                                     |
|     | 2.1                             | 端子機能一覧 … 27                                                                                                                                          |
|     |                                 | 端子機能の説明 … 29                                                                                                                                         |
|     |                                 | 2.2.1 P00-P03 (Port0) ··· 29                                                                                                                         |
|     |                                 | 2.2.2 P10-P13 (Port1) ··· 29                                                                                                                         |
|     |                                 | 2.2.3 P20-P25 (Port2) ··· 30                                                                                                                         |
|     |                                 | 2.2.4 P34-P36 (Port3) ··· 30                                                                                                                         |
|     |                                 | 2.2.5 P40-P47 (Port4) ··· 31                                                                                                                         |
|     |                                 | 2.2.6 P50-P57 (Port5) ··· 31                                                                                                                         |
|     |                                 | 2.2.7 P70-P75 (Port7) ··· 32                                                                                                                         |
|     |                                 | 2.2.8 AVREF 32                                                                                                                                       |
|     |                                 | 2.2.9 AV <sub>DD</sub> ··· 32                                                                                                                        |
|     |                                 | 2.2.10 AVss ··· 33                                                                                                                                   |
|     |                                 | 2.2.11 RESET ··· 33                                                                                                                                  |
|     |                                 | 2.2.12 X1, X2 ··· 33                                                                                                                                 |
|     |                                 | 2.2.13 XT1, XT2 ··· 33                                                                                                                               |
|     |                                 | 2.2.14 VDD0, VDD1 ··· 33                                                                                                                             |
|     |                                 | 2.2.15 Vsso, Vss1 ··· 33                                                                                                                             |
|     |                                 | 2.2.16 Vpp(フラッシュ・メモリ製品のみ) … 33                                                                                                                       |
|     |                                 | 2.2.17 IC(マスクROM製品のみ) ··· 34                                                                                                                         |
|     | 2.3                             |                                                                                                                                                      |
| 第3  | 章                               | CPUアーキテクチャ … 37                                                                                                                                      |
|     | 3.1                             | メモリ空間 … 37                                                                                                                                           |
|     |                                 | 3.1.1 内部プログラム・メモリ空間 … 43                                                                                                                             |
|     |                                 | 3.1.2 内部データ・メモリ空間 … 44                                                                                                                               |
|     |                                 | 3.1.3 特殊機能レジスタ(SFR:Special Function Register)領域 ··· 44                                                                                               |
|     |                                 | 3.1.4 外部メモリ空間 … 44                                                                                                                                   |
|     |                                 | 3.1.5 データ・メモリ・アドレシング … 45                                                                                                                            |
|     | 2 2                             | プロセッサ・レジスタ … 50                                                                                                                                      |
|     | J . Z                           |                                                                                                                                                      |
|     | J. Z                            | 3.2.1 制御レジスタ … 50                                                                                                                                    |
|     | J. Z                            | 3.2.1 制御レジスタ … 50                                                                                                                                    |
|     | J. Z                            |                                                                                                                                                      |

- 3.3.1 レラティブ・アドレシング … 58
- 3.3.2 イミーディエト・アドレシング … 59
- 3.3.3 テーブル・インダイレクト・アドレシング … 60
- 3.3.4 レジスタ・アドレシング … 60
- 3.4 オペランド・アドレスのアドレシング … 61
  - 3.4.1 インプライド・アドレシング … 61
  - 3.4.2 レジスタ・アドレシング … 62
  - 3.4.3 ダイレクト・アドレシング … 63
  - 3.4.4 ショート・ダイレクト・アドレシング … 64
  - 3.4.5 特殊機能レジスタ (SFR) アドレシング … 65
  - 3.4.6 レジスタ・インダイレクト・アドレシング … 66
  - 3.4.7 ベースト・アドレシング … 67
  - 3.4.8 ベースト・インデクスト・アドレシング … 68
  - 3.4.9 スタック・アドレシング … 69

## 第4章 ポート機能 … 70

- 4.1 ポートの機能 … 70
- 4.2 ポートの構成 … 72
  - 4.2.1 ポート0 … 72
  - 4.2.2 ポート1 … 74
  - 4.2.3 ポート2 … 75
  - 4.2.4 ポート3 … 78
  - 4.2.5 ポート4 … 81
  - 4.2.6 ポート5 … 82
  - 4.2.7 ポート7 … 83
- 4.3 ポート機能を制御するレジスタ … 86
- 4.4 ポート機能の動作 … 90
  - 4.4.1 入出力ポートへの書き込み … 90
  - 4.4.2 入出力ポートからの読み出し … 90
  - 4.4.3 入出力ポートでの演算 … 90

## 第5章 クロック発生回路 … 91

- 5.1 クロック発生回路の機能 … 91
- 5.2 クロック発生回路の構成 … 91
- 5.3 クロック発生回路を制御するレジスタ … 93
- 5.4 システム・クロック発振回路 … 96
  - 5.4.1 メイン・システム・クロック発振回路 … 96
  - 5.4.2 サブシステム・クロック発振回路 … 97
  - 5.4.3 サブシステム・クロックを使用しない場合 … 100
- 5.5 クロック発生回路の動作 … 101
  - 5.5.1 メイン・システム・クロックの動作 … 102
  - 5.5.2 サブシステム・クロックの動作 … 103
- 5.6 システム・クロックとCPUクロックの設定の変更 … 103
  - 5.6.1 システム・クロックとCPUクロックの切り替えに要する時間 … 103
  - 5.6.2 システム・クロックとCPUクロックの切り替え手順 … 105

## 第6章 16ビット・タイマ/イベント・カウンタ0 … 106

- 6.1 16ビット・タイマ/イベント・カウンタ 0 の機能 … 106
- 6.2 16ビット・タイマ/イベント・カウンタ 0 の構成 … 107

- 6.3 16ビット・タイマ/イベント・カウンタ0を制御するレジスタ … 110
- 6.4 16ビット・タイマ/イベント・カウンタ 0 の動作 … 116
  - 6.4.1 インターバル・タイマとしての動作 … 116
  - 6.4.2 外部イベント・カウンタとしての動作 … 119
  - 6.4.3 パルス幅測定としての動作 … 121
  - 6.4.4 方形波出力としての動作 … 128
  - 6.4.5 PPG出力としての動作 … 129
- 6.5 プログラム・リスト … 131
  - 6.5.1 インターバル・タイマ … 132
  - 6.5.2 フリー・ランニング・カウンタとキャプチャ・レジスタ 1 本によるパルス幅測定 … 133
  - 6.5.3 フリー・ランニング・カウンタによる2つのパルス幅測定 … 134
  - 6.5.4 リスタートによるパルス幅測定 … 136
  - 6.5.5 PPG出力 ··· 137
- 6.6 16ビット・タイマ/イベント・カウンタ 0 の注意事項 … 138

## 第7章 8ビット・タイマ/イベント・カウンタ50,51 ··· 142

- 7.1 8ビット・タイマ/イベント・カウンタ50.51の機能 … 142
- 7.2 8ビット・タイマ/イベント・カウンタ50,51の構成 … 144
- 7.3 8ビット・タイマ/イベント・カウンタ50,51を制御するレジスタ … 146
- 7.4 8ビット・タイマ/イベント・カウンタ50,51の動作 … 151
  - 7.4.1 インターバル・タイマ(8ビット)としての動作 … 151
  - 7.4.2 外部イベント・カウンタとしての動作 … 155
  - 7.4.3 方形波出力(8ビット分解能)としての動作 … 156
  - 7.4.4 8ビットPWM出力としての動作 … 157
  - 7.4.5 インターバル・タイマ(16ビット)としての動作 … 161
- 7.5 プログラム・リスト … 162
  - 7.5.1 インターバル・タイマ(8ビット) … 162
  - 7.5.2 外部イベント・カウンタ … 163
  - 7.5.3 インターバル・タイマ(16ビット) … 164
- 7.6 8ビット・タイマ/イベント・カウンタ50,51の注意事項 … 165

## 第8章 時計用タイマ … 166

- 8.1 時計用タイマの機能 … 166
- 8.2 時計用タイマの構成 … 167
- 8.3 時計用タイマを制御するレジスタ … 168
- 8.4 時計用タイマの動作 … 169
  - 8.4.1 時計用タイマとしての動作 … 169
  - 8.4.2 インターバル・タイマとしての動作 … 169

## 第9章 ウォッチドッグ・タイマ … 171

- 9.1 ウォッチドッグ・タイマの機能 … 171
- 9.2 ウォッチドッグ・タイマの構成 … 172
- 9.3 ウォッチドッグ・タイマを制御するレジスタ … 172
- 9.4 ウォッチドッグ・タイマの動作 … 174
  - 9.4.1 ウォッチドッグ・タイマとしての動作 … 174
  - 9.4.2 インターバル・タイマとしての動作 … 175

| 第10章                    | クロック出力/ブザー出力制御回路 … 176                                                                                                                                                                                                        |     |
|-------------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-----|
| 10. 2<br>10. 3          | クロック出力/ブザー出力制御回路の機能 … 176<br>クロック出力/ブザー出力制御回路の構成 … 177<br>クロック出力/ブザー出力制御回路を制御するレジスタ … 177<br>クロック出力/ブザー出力制御回路の動作 … 180<br>10.4.1 クロック出力としての動作 … 180<br>10.4.2 ブザー出力としての動作 … 180                                               |     |
| 第11章                    | 8 ビットA/Dコンバータ( μ PD780024ASサブシリーズ) …                                                                                                                                                                                          | 181 |
| 11. 2<br>11. 3<br>11. 4 | A/Dコンバータの機能 … 181<br>A/Dコンバータの構成 … 183<br>A/Dコンバータを制御するレジスタ … 185<br>A/Dコンバータの動作 … 188<br>11.4.1 A/Dコンバータの基本動作 … 188<br>11.4.2 入力電圧と変換結果 … 190<br>11.4.3 A/Dコンバータの動作モード … 191                                                 |     |
|                         | A/Dコンバータ特性表の読み方 ··· 194<br>A/Dコンバータの注意事項 ··· 197                                                                                                                                                                              |     |
| 第12章                    | 10ビットA/Dコンバータ( μ PD780034ASサブシリーズ) ··· 2                                                                                                                                                                                      | 203 |
| 12. 2<br>12. 3<br>12. 4 | A/Dコンバータの機能 … 203<br>A/Dコンバータの構成 … 205<br>A/Dコンバータを制御するレジスタ … 207<br>A/Dコンバータの動作 … 210<br>12.4.1 A/Dコンバータの基本動作 … 210<br>12.4.2 入力電圧と変換結果 … 212<br>12.4.3 A/Dコンバータの動作モード … 213<br>A/Dコンバータ特性表の読み方 … 216<br>A/Dコンバータの注意事項 … 219 |     |
| 第13章                    | シリアル・インタフェース <b>UARTO</b> … 225                                                                                                                                                                                               |     |
| 13. 2<br>13. 3          | シリアル・インタフェースUARTOの機能 … 225<br>シリアル・インタフェースUARTOの構成 … 227<br>シリアル・インタフェースUARTOを制御するレジスタ … 229<br>シリアル・インタフェースUARTOの動作 … 233<br>13.4.1 動作停止モード … 233<br>13.4.2 アシンクロナス・シリアル・インタフェース(UART)モード … 13.4.3 赤外線データ転送モード … 245         | 234 |
| 第14章                    | シリアル・インタフェースSIO30, SIO31 ··· 253                                                                                                                                                                                              |     |
| 14. 2<br>14. 3          | シリアル・インタフェースSIO30, SIO31の機能 … 253<br>シリアル・インタフェースSIO30, SIO31の構成 … 254<br>シリアル・インタフェースSIO30, SIO31を制御するレジスタ … 254<br>シリアル・インタフェースSIO30, SIO31の動作 … 258<br>14.4.1 動作停止モード … 258<br>14.4.2 3線式シリアルI/Oモード … 259                  |     |

## 第15章 割り込み機能 … 264

- 15.1 割り込み機能の種類 … 264
- 15.2 割り込み要因と構成 … 264
- 15.3 割り込み機能を制御するレジスタ … 268
- 15.4 割り込み処理動作 … 275
  - 15.4.1 ノンマスカブル割り込み要求の受け付け動作 … 275
  - 15.4.2 マスカブル割り込み要求の受け付け動作 … 278
  - 15.4.3 ソフトウエア割り込み要求の受け付け動作 … 281
  - 15.4.4 多重割り込み処理 … 281
  - 15.4.5 割り込み要求の保留 … 285

## 第16章 スタンバイ機能 … 286

- 16.1 スタンバイ機能と構成 … 286
  - 16.1.1 スタンバイ機能 … 286
  - 16.1.2 スタンバイ機能を制御するレジスタ … 287
- 16.2 スタンバイ機能の動作 … 288
  - 16.2.1 HALTモード … 288
  - 16.2.2 STOPモード … 291

## 第17章 リセット機能 … 294

## 第**18**章 μ PD78F0034BS ··· 298

- 18.1 メモリ・サイズ切り替えレジスタ … 299
- 18.2 フラッシュ・メモリの特徴 … 300
  - 18.2.1 プログラミング環境 ··· 300
    - 18.2.2 通信方式 … 301
    - 18.2.3 オンボード上の端子処理 … 304
    - 18.2.4 フラッシュ書き込み用アダプタの接続 … 307

## 第19章 命令セットの概要 … 312

- 19.1 凡 例 … 313
  - 19.1.1 オペランドの表現形式と記述方法 … 313
  - 19.1.2 オペレーション欄の説明 … 314
  - 19.1.3 フラグ動作欄の説明 … 314
- 19.2 オペレーション一覧 … 315
- 19.3 アドレシング別命令一覧 … 323

## **第20章 電気的特性 … 327**

第21章 外形図 … 349

第22章 半田付け推奨条件 … 350

付録 A μ PD780024A, 780024AS, 780034A, 780034ASサブシリーズ間の違い … 352

付録B 開発ツール … 354

B.1 ソフトウエア・パッケージ … 356

- B.2 言語処理用ソフトウエア … 356
- B.3 制御ソフトウエア ··· 357
- B.4 フラッシュ・メモリ書き込み用ツール … 357
- B.5 ディバグ用ツール (ハードウエア) … 358
- B.6 ディバグ用ツール (ソフトウエア) ··· 359
- B.7 組み込み用ソフトウエア … 360

## 付録C ターゲット・システム設計上の注意 … 361

## 付録D レジスタ索引 … 363

- D.1 レジスタ索引(50音順) … 363
- D.2 レジスタ索引 (アルファベット順) … 366

## 付録E 改版履歴 … 369

- E.1 本版で改訂された主な箇所 … 369
- E.2 前版までの改版履歴 … 370

## 第1章 概 説

## 1.1 特 徵

## ○内部メモリ

|                       | 項 | 目 プログラム・メモリ          | データ・メモリ              |
|-----------------------|---|----------------------|----------------------|
| 品名                    |   | (ROM/フラッシュ・メヨ        | Eリ) (高速RAM)          |
| μPD780021AS, 780031AS |   | 8 Kバイト               | 512バイト               |
| μPD780022AS, 780032AS |   | 16 Kバイト              |                      |
| μPD780023AS, 780033AS |   | 24 Kバイト              | 1024バイト              |
| μPD780024AS, 780034AS |   | 32 Kバイト              |                      |
| μPD78F0034BS          |   | 32 Kバイト <sup>注</sup> | 1024バイト <sup>注</sup> |

- 注 メモリ・サイズ切り替えレジスタ(IMS)により、内部フラッシュ・メモリ、内部高速RAM容量の変更可能。
- ○外部メモリ拡張空間:64 Kバイト
- ○高速( $0.166 \, \mu s$ :メイン・システム・クロック12 MHz,  $V_{DD} = 4.5 \sim 5.5 \, V$ 動作時)から超低速( $122 \, \mu s$ :サブシステム・クロック $32.768 \, k$ Hz動作時)まで最小命令実行時間変更可能
- ○システム制御に適した命令セット
  - ・全アドレス空間でビット処理可能
  - · 乗除算命令内蔵
- ○I/Oポート:39本
- $\bigcirc$  8 ビット分解能A/Dコンバータ : 4 チャネル(  $\mu$  PD780024ASサブシリーズのみ)
- ○10ビット分解能A/Dコンバータ : 4 チャネル (μPD780034ASサブシリーズのみ)
- ○シリアル・インタフェース : 3チャネル・3線式シリアルI/Oモード : 2チャネル・UARTモード : 1チャネル
- ○タイマ:5チャネル
  - ・16ビット・タイマ/イベント・カウンタ:1 チャネル
  - ・8ビット・タイマ/イベント・カウンタ:2チャネル
  - ・時計用タイマ : 1 チャネル・ウォッチドッグ・タイマ : 1 チャネル
- ○ベクタ割り込み要因:20
- 2 種類のクロック発振回路内蔵(メイン・システム・クロックとサブシステム・クロック)
- ○電源電圧: V<sub>DD</sub> = 1.8~5.5 V

## 1.2 応用分野

μPD780021AS, 780022AS, 780023AS, 780024AS μPD780031AS, 780032AS, 780033AS, 780034AS, 78F0034BSの場合 家電製品, ページャ, AV機器, カー・オーディオ, OA機器など

 $\mu$ PD780021AS(A), 780022AS(A), 780023AS(A), 780024AS(A)  $\mu$ PD780031AS(A), 780032AS(A), 780033AS(A), 780034AS(A), 78F0034BS(A)の場合

★ 輸送機器の制御装置、ガス検知遮断機、各種安全装置、自動車電装など

## 1.3 オーダ情報

| オーダ名称                                         | パッケージ                  | 内部ROM     |
|-----------------------------------------------|------------------------|-----------|
| μPD780021ASGB-XXX-8ET                         | 52ピン・プラスチックLQFP(10x10) | マスクROM    |
| $\mu$ PD780022ASGB- $\times$ $\times$ -8ET    | "                      | "         |
| $\mu$ PD780023ASGB- $\times$ $\times$ -8ET    | "                      | "         |
| $\mu$ PD780024ASGB- $\times$ $\times$ -8ET    | "                      | "         |
| $\mu$ PD780031ASGB- $\times$ $\times$ -8ET    | //                     | "         |
| $\mu$ PD780032ASGB- $\times$ $\times$ -8ET    | "                      | "         |
| $\mu$ PD780033ASGB- $\times$ $\times$ -8ET    | //                     | "         |
| $\mu$ PD780034ASGB- $\times$ $\times$ -8ET    | //                     | "         |
| $\mu$ PD780021ASGB(A)- $\times$ $\times$ -8ET | //                     | "         |
| $\mu$ PD780022ASGB(A)- $\times$ $\times$ -8ET | //                     | "         |
| $\mu$ PD780023ASGB(A)- $\times$ $\times$ -8ET | //                     | "         |
| $\mu$ PD780024ASGB(A)- $\times$ $\times$ -8ET | //                     | "         |
| $\mu$ PD780031ASGB(A)- $\times$ $\times$ -8ET | //                     | "         |
| $\mu$ PD780032ASGB(A)- $\times$ $\times$ -8ET | //                     | "         |
| $\mu$ PD780033ASGB(A)- $\times$ $\times$ -8ET | //                     | "         |
| $\mu$ PD780034ASGB(A)- $\times$ $\times$ -8ET | //                     | "         |
| $\mu$ PD78F0034BSGB-8ET                       | "                      | フラッシュ・メモリ |
| $\mu$ PD78F0034BSGB(A)-8ET                    | //                     | "         |

備考 ×××はROMコード番号です。

## 1.4 品質水準

| オーダ名称                                         | パッケージ                  | 品質水準          |
|-----------------------------------------------|------------------------|---------------|
| μPD780021ASGB-XXX-8ET                         | 52ピン・プラスチックLQFP(10x10) | 標準(一般電子機器用)   |
| $\mu$ PD780022ASGB- $\times$ $\times$ -8ET    | ,                      | "             |
| $\mu$ PD780023ASGB- $\times$ $\times$ -8ET    | ,                      | "             |
| $\mu$ PD780024ASGB- $\times$ $\times$ -8ET    | "                      | "             |
| $\mu$ PD780031ASGB- $\times$ $\times$ -8ET    | ,                      | "             |
| $\mu$ PD780032ASGB- $\times$ $\times$ -8ET    | ,                      | "             |
| $\mu$ PD780033ASGB- $\times$ $\times$ -8ET    | "                      | "             |
| $\mu$ PD780034ASGB- $\times$ $\times$ -8ET    | ,                      | "             |
| $\mu$ PD78F0034BSGB-8ET                       | ,                      | "             |
| $\mu$ PD780021ASGB(A)- $\times$ $\times$ -8ET | "                      | 特別(高信頼度電子機器用) |
| $\mu$ PD780022ASGB(A)- $\times$ $\times$ -8ET | ,                      | "             |
| $\mu$ PD780023ASGB(A)- $\times$ $\times$ -8ET | "                      | "             |
| $\mu$ PD780024ASGB(A)- $\times$ $\times$ -8ET | "                      | "             |
| $\mu$ PD780031ASGB(A)- $\times$ $\times$ -8ET | "                      | "             |
| $\mu$ PD780032ASGB(A)- $\times$ $\times$ -8ET | "                      | "             |
| $\mu$ PD780033ASGB(A)- $\times$ $\times$ -8ET | "                      | "             |
| $\mu$ PD780034ASGB(A)- $\times$ $\times$ -8ET | "                      | "             |
| $\mu$ PD78F0034BSGB(A)-8ET                    | "                      | "             |

備考 ×××はROMコード番号です。

品質水準とその応用分野の詳細については当社発行の資料  $\lceil NEC +$  半導体デバイスの品質水準  $\rfloor$  (C11531J) をご覧ください。

## 1.5 端子接続図(Top View)

・52ピン・プラスチックLQFP(10x10)

 $\mu$ PD780021ASGB- $\times$  $\times$  $\times$ -8ET, 780022ASGB- $\times$  $\times$  $\times$ -8ET, 780023ASGB- $\times$  $\times$  $\times$ -8ET, 780024ASGB- $\times$  $\times$  $\times$ -8ET, 780031ASGB- $\times$  $\times$  $\times$ -8ET, 780032ASGB- $\times$  $\times$  $\times$ -8ET, 780033ASGB- $\times$  $\times$  $\times$ -8ET, 780034ASGB- $\times$  $\times$  $\times$ -8ET, 780034ASGB-8ET, 780021ASGB(A)- $\times$  $\times$  $\times$ -8ET, 780022ASGB(A)- $\times$  $\times$  $\times$ -8ET, 780032ASGB(A)- $\times$  $\times$  $\times$ -8ET, 780034ASGB(A)- $\times$  $\times$  $\times$ -8ET, 780034BSGB(A)-8ET



- 注意 1. IC(Internally Connected)端子はVssoまたはVssoに直接接続してください。
  - 2. AVssはVssoに接続してください。
- **備考1.** マイコン内部から発生するノイズを低減する必要がある応用分野で使用する場合、VDDOとVDD1に個別の電源を供給し、VSSOとVSS1を別々のグランド・ラインに接続するなどのノイズ対策を行うことを推奨します。
  - 2. ( )内は $\mu$ PD78F0034BS, 78F0034BS(A)のとき。

ADTRG : AD Trigger Input P70-P75 : Port7

ANI0-ANI3 : Analog Input PCL : Programmable Clock

ASCK0 : Asynchronous Serial Clock RESET : Reset

 $AV_{DD}$ : Analog Power Supply RxD0 : Receive Data AVREF SCK30, SCK31 : Serial Clock : Analog Reference Voltage AVss SI30, SI31 : Analog Ground : Serial Input BUZ : Buzzer Clock SO30,SO31 : Serial Output IC : Internally Connected TI00, TI01, TI50, TI51: Timer Input INTP0-INTP3 : External Interrupt Input TO0, TO50, TO51 : Timer Output

P00-P03 : Port0 TxD0 : Transmit Data
P10-P13 : Port1 VDD0, VDD1 : Power Supply

P20-P25 : Port2 VPP : Programming Power Supply

P34-P36 : Port3 Vsso, Vss1 : Ground

P40-P47 : Port4 X1, X2 : Crystal (Main System Clock)
P50-P57 : Port5 XT1, XT2 : Crystal (Subsystem Clock)

## 1.6 78K/0シリーズの展開

78K/0シリーズの製品展開を次に示します。枠内はサブシリーズ名称です。



備考 蛍光表示管の一般的な英語名称はVFD(Vacuum Fluorescent Display)ですが、ドキュメントによってはFIP®(Fluorescent Indicator Panel)と記述しているものがあります。VFDとFIPは同等の機能です。

各サブシリーズ間の主な機能の違いを次に示します。

## ・Yなしサブシリーズ

|        | 機能          | ROM容量     |       | タイ     | (マ  |     | 8-bit | 10-bit | 8-bit | シリアル・            | I/O | V <sub>DD</sub> | 外部 |
|--------|-------------|-----------|-------|--------|-----|-----|-------|--------|-------|------------------|-----|-----------------|----|
| サブシリ-  | -ズ名         | (バイト)     | 8-bit | 16-bit | 時計  | WDT | A/D   | A/D    | D/A   | インタフェース          |     | MIN.值           | 拡張 |
| 制御用    | μPD78075B   | 32 K-40 K | 4ch   | 1ch    | 1ch | 1ch | 8ch   | _      | 2ch   | 3ch(UART:1ch)    | 88本 | 1.8 V           | 0  |
|        | μPD78078    | 48 K-60 K |       |        |     |     |       |        |       |                  |     |                 |    |
|        | μPD78070A   | _         |       |        |     |     |       |        |       |                  | 61本 | 2.7 V           |    |
|        | μPD780058   | 24 K-60 K | 2ch   |        |     |     |       |        |       | 3ch(時分割UART:1ch) | 68本 | 1.8 V           | -  |
|        | μPD78058F   | 48 K-60 K |       |        |     |     |       |        |       | 3ch(UART:1ch)    | 69本 | 2.7 V           |    |
|        | μPD78054    | 16 K-60 K |       |        |     |     |       |        |       |                  |     | 2.0 V           |    |
|        | μPD780065   | 40 K-48 K |       |        |     |     |       |        | _     | 4ch(UART:1ch)    | 60本 | 2.7 V           |    |
|        | μPD780078   | 48 K-60K  |       | 2ch    |     |     | -     | 8ch    |       | 3ch(UART:2ch)    | 52本 | 1.8 V           |    |
|        | μPD780034A  | 8 K-32 K  |       | 1ch    |     |     |       |        |       | 3ch(UART:1ch)    | 51本 | 1               |    |
|        | μPD780024A  |           |       |        |     |     | 8ch   | _      |       |                  |     |                 |    |
|        | μPD780034AS |           |       |        |     |     | _     | 4ch    |       |                  | 39本 | 1               | _  |
|        | μPD780024AS |           |       |        |     |     | 4ch   | _      |       |                  |     |                 |    |
|        | μPD78014H   |           |       |        |     |     | 8ch   |        |       | 2ch              | 53本 |                 | 0  |
|        | μPD78018F   | 8 K-60 K  |       |        |     |     |       |        |       |                  |     |                 |    |
|        | μPD78083    | 8 K-16 K  |       | _      | _   |     |       |        |       | 1ch(UART:1ch)    | 33本 | ]               | _  |
| インバータ  | μPD780988   | 16 K-60 K | 3ch   | 注      | _   | 1ch | _     | 8ch    | _     | 3ch(UART:2ch)    | 47本 | 4.0 V           | 0  |
| 制御用    |             |           |       |        |     |     |       |        |       |                  |     |                 |    |
| VFD    | μPD780208   | 32 K-60 K | 2ch   | 1ch    | 1ch | 1ch | 8ch   | _      | _     | 2ch              | 74本 | 2.7 V           | _  |
| 駆動用    | μPD780232   | 16 K-24 K | 3ch   | _      | _   |     | 4ch   |        |       |                  | 40本 | 4.5 V           |    |
|        | μPD78044H   | 32 K-48 K | 2ch   | 1ch    | 1ch |     | 8ch   |        |       | 1ch              | 68本 | 2.7 V           |    |
|        | μPD78044F   | 16 K-40 K |       |        |     |     |       |        |       | 2ch              |     |                 |    |
| LCD    | μPD780354   | 24K-32 K  | 4ch   | 1ch    | 1ch | 1ch | _     | 8ch    | _     | 3ch(UART:1ch)    | 66本 | 1.8 V           | _  |
| 駆動用    | μPD780344   |           |       |        |     |     | 8ch   | _      |       |                  |     |                 |    |
|        | μPD780338   | 48 K-60 K | 3ch   | 2ch    |     |     | -     | 10ch   | 1ch   | 2ch (UART:1ch)   | 54本 |                 |    |
|        | μPD780328   |           |       |        |     |     |       |        |       |                  | 62本 |                 |    |
|        | μPD780318   |           |       |        |     |     |       |        |       |                  | 70本 |                 |    |
|        | μPD780308   | 48 K-60 K | 2ch   | 1ch    |     |     | 8ch   | _      | _     | 3ch(時分割UART:1ch) | 57本 | 2.0 V           |    |
|        | μPD78064B   | 32 K      |       |        |     |     |       |        |       | 2ch (UART:1ch)   |     |                 |    |
|        | μPD78064    | 16 K-32 K |       |        |     |     |       |        |       |                  |     |                 |    |
| バス・イン  | μPD780948   | 60 K      | 2ch   | 2ch    | 1ch | 1ch | 8ch   | _      | _     | 3ch(UART:1ch)    | 79本 | 4.0 V           | 0  |
| タフェース  | μPD78098B   | 40 K-60 K |       | 1ch    |     |     |       |        | 2ch   |                  | 69本 | 2.7 V           | _  |
| 対応     | μPD780816   | 32 K-60 K |       | 2ch    |     |     | 12ch  |        | _     | 2ch (UART:1ch)   | 46本 | 4.0 V           | L  |
| メータ    | μPD780958   | 48 K-60 K | 4ch   | 2ch    | _   | 1ch | _     | _      | _     | 2ch (UART:1ch)   | 69本 | 2.2 V           | _  |
| 制御用    |             |           |       |        |     |     |       |        |       |                  |     |                 |    |
| ダッシュ   | μPD780852   | 32 K-40 K | 3ch   | 1ch    | 1ch | 1ch | 5ch   | _      | _     | 3ch(UART:1ch)    | 56本 | 4.0 V           | -  |
| ボード制御用 | μPD780828B  | 32 K-60 K |       |        |     |     |       |        |       |                  | 59本 | ]               |    |

注 16ビット・タイマ: 2チャネル

10ビット・タイマ:1 チャネル

## ・Yサブシリーズ

| 機能F     |             | ROM容量     | タイマ   |        | 8-bit | 10-bit | 8-bit | シリアル・ | I/O | V <sub>DD</sub>            | 外部  |       |    |
|---------|-------------|-----------|-------|--------|-------|--------|-------|-------|-----|----------------------------|-----|-------|----|
| サブシリーズ名 |             | (バイト)     | 8-bit | 16-bit | 時計    | WDT    | A/D   | A/D   | D/A | インタフェース                    |     | MIN.值 | 拡張 |
| 制御用     | μPD78078Y   | 48 K-60 K | 4ch   | 1ch    | 1ch   | 1ch    | 8ch   | _     | 2ch | 3ch(UART:1ch,              | 88本 | 1.8 V | 0  |
|         | μ PD78070AY | _         |       |        |       |        |       |       |     | I <sup>2</sup> C:1ch)      | 61本 | 2.7 V |    |
|         | μPD780018AY | 48 K-60 K |       |        |       |        |       |       | _   | 3ch (I <sup>2</sup> C:1ch) | 88本 |       |    |
|         | μPD780058Y  | 24 K-60 K | 2ch   |        |       |        |       |       | 2ch | 3ch(時分割UART:               | 68本 | 1.8 V |    |
|         |             |           |       |        |       |        |       |       |     | 1ch, I <sup>2</sup> C:1ch) |     |       |    |
|         | μ PD78058FY | 48 K-60 K |       |        |       |        |       |       |     | 3ch(UART:1ch,              | 69本 | 2.7 V |    |
|         | μ PD78054Y  | 16 K-60 K |       |        |       |        |       |       |     | I <sup>2</sup> C:1ch)      |     | 2.0 V |    |
|         | μ PD780078Y | 48 K-60 K |       | 2ch    |       |        | _     | 8ch   | _   | 4ch(UART:2ch,              | 52本 | 1.8 V |    |
|         |             |           |       |        |       |        |       |       |     | I <sup>2</sup> C:1ch)      |     |       |    |
|         | μPD780034AY | 8 K-32 K  |       | 1ch    |       |        |       |       |     | 3ch(UART:1ch,              | 51本 |       |    |
|         | μPD780024AY |           |       |        |       |        | 8ch   | _     |     | I <sup>2</sup> C:1ch)      |     |       |    |
|         | μPD78018FY  | 8 K-60 K  |       |        |       |        |       |       |     | 2ch (I <sup>2</sup> C:1ch) | 53本 |       |    |
| LCD     | μPD780354Y  | 24 K-32 K | 4ch   | 1ch    | 1ch   | 1ch    | _     | 8ch   | _   | 4ch(UART:1ch,              | 66本 | 1.8 V | _  |
| 駆動用     | μPD780344Y  |           |       |        |       |        | 8ch   | _     |     | I <sup>2</sup> C:1ch)      |     |       |    |
|         | μPD780308Y  | 48 K-60 K | 2ch   |        |       |        |       |       |     | 3ch(時分割UART:               | 57本 | 2.0 V |    |
|         |             |           |       |        |       |        |       |       |     | 1ch, I <sup>2</sup> C:1ch) |     |       |    |
|         | μPD78064Y   | 16 K-32 K |       |        |       |        |       |       |     | 2ch(UART:1ch,              |     |       |    |
|         |             |           |       |        |       |        |       |       |     | I <sup>2</sup> C:1ch)      |     |       |    |
| バス・イン   | μPD780702Y  | 60 K      | 3ch   | 2ch    | 1ch   | 1ch    | 16ch  | _     | _   | 4ch(UART:1ch,              | 67本 | 3.5 V | _  |
| タフェース   | μPD780703AY | 59.5 K    |       |        |       |        |       |       |     | I <sup>2</sup> C:1ch)      |     |       |    |
| 対応      | μPD780833Y  | 60 K      |       |        |       |        |       |       |     |                            | 65本 | 4.5 V |    |

備考 YなしサブシリーズとYサブシリーズは、シリアル・インタフェース以外の機能は共通です(Yなしサブシリーズがある場合)。

## 1.7 ブロック図



備考1. 内部ROM, RAM容量は製品によって異なります。

**2.** ( )内はμPD78F0034BSのとき。

## 1.8 機能概要

| 品名               | μPD780021AS                                                                                                                              | μPD780022AS                        | μPD780023AS | μPD780024AS | μPD78F0034BS         |  |  |  |  |
|------------------|------------------------------------------------------------------------------------------------------------------------------------------|------------------------------------|-------------|-------------|----------------------|--|--|--|--|
| 項目               | μPD780031AS                                                                                                                              | μPD780032AS                        | μPD780033AS | μPD780034AS |                      |  |  |  |  |
| 内部メモリ ROM        | 8 Kバイト                                                                                                                                   | 16 Kバイト                            | 24 Kバイト     | 32 Kバイト     | 32 Kバイト <sup>注</sup> |  |  |  |  |
|                  | (マスクROM)                                                                                                                                 | (マスクROM)                           | (マスクROM)    | (マスクROM)    | (フラッシュ・メモリ)          |  |  |  |  |
| 高速RAM            | 512バイト                                                                                                                                   |                                    | 1024バイト     |             | 1024バイト <sup>注</sup> |  |  |  |  |
| メモリ空間            | 64 Kバイト                                                                                                                                  | 64 Kバイト                            |             |             |                      |  |  |  |  |
| 汎用レジスタ           | 8ビット×32レジスタ(8ビット×8レジスタ×4バンク)                                                                                                             |                                    |             |             |                      |  |  |  |  |
| 最小命令実行時間         | 最小命令実行時間の可変機能内蔵                                                                                                                          |                                    |             |             |                      |  |  |  |  |
| メイン・システム・クロック選択時 | $0.166 \mu\text{s}/0.333 \mu\text{s}/0.666 \mu\text{s}/1.33 \mu\text{s}/2.66 \mu\text{s}$ (12 MHz, $V_{DD} = 4.5 \sim 5.5 \text{V}$ 動作時) |                                    |             |             |                      |  |  |  |  |
| サブシステム・クロック選択時   | 122 μs (32.768 k                                                                                                                         | Hz動作時)                             |             |             |                      |  |  |  |  |
| 命令セット            | ・16ビット演算                                                                                                                                 |                                    |             |             |                      |  |  |  |  |
|                  | ・乗除算(8ビッ                                                                                                                                 | ト×8ビット, 16년                        | ビット÷8ビット)   |             |                      |  |  |  |  |
|                  | ・ビット操作(セ                                                                                                                                 | ・ビット操作(セット,リセット,テスト,ブール演算)・BCD補正など |             |             |                      |  |  |  |  |
| I/Oポート           | 合計                                                                                                                                       | 合計 : 39本                           |             |             |                      |  |  |  |  |
|                  | ・CMOS入力                                                                                                                                  |                                    | : 4本        |             |                      |  |  |  |  |
|                  | ・CMOS入出力                                                                                                                                 |                                    | : 35本       |             |                      |  |  |  |  |
| A/Dコンバータ         | ・ 8 ビット分解能× 4 チャネル( µ PD780021AS, 780022AS, 780023AS, 780024ASのみ)                                                                        |                                    |             |             |                      |  |  |  |  |
|                  | ・10ビット分解能×4チャネル(μPD780031AS, 780032AS, 780033AS, 780034AS, 78F0034BSのみ)                                                                  |                                    |             |             |                      |  |  |  |  |
|                  | ・低電圧動作可能:AV <sub>DD</sub> = 1.8~5.5 V                                                                                                    |                                    |             |             |                      |  |  |  |  |
| シリアル・インタフェース     | ・3線式シリアルI/Oモード:2チャネル                                                                                                                     |                                    |             |             |                      |  |  |  |  |
|                  | ・UARTモード : 1チャネル                                                                                                                         |                                    |             |             |                      |  |  |  |  |
| タイマ              | ・16ビット・タイマ/イベント・カウンタ:1 チャネル                                                                                                              |                                    |             |             |                      |  |  |  |  |
|                  | ・8ビット・タイマ/イベント・カウンタ:2チャネル                                                                                                                |                                    |             |             |                      |  |  |  |  |
|                  | ・時計用タイマ・・・・・・・・・・・・・・・・・・・・・・・・・・・・・・・・・・・・                                                                                              |                                    |             |             |                      |  |  |  |  |
|                  | ・ウォッチドッグ・タイマ・・・・・・・・・・・・・・・・・・・・・・・・・・・・・・・・・・・                                                                                          |                                    |             |             |                      |  |  |  |  |
| タイマ出力            | 3本 (8ビットPWM出力可能: 2本)                                                                                                                     |                                    |             |             |                      |  |  |  |  |
| クロック出力           | • 93.7 kHz, 187 kHz, 375 kHz, 750 kHz, 1.5 MHz, 3 MHz, 6 MHz, 12 MHz                                                                     |                                    |             |             |                      |  |  |  |  |
|                  | (メイン・システム・クロック:12 MHz, V <sub>DD</sub> = 4.5~5.5 V動作時)                                                                                   |                                    |             |             |                      |  |  |  |  |
|                  | ・32.768 kHz(サブシステム・クロック:32.768 kHz動作時)                                                                                                   |                                    |             |             |                      |  |  |  |  |
| ブザー出力            | 1.46 kHz, 2.92 kHz, 5.85 kHz, 11.7 kHz(メイン・システム・クロック:12 MHz, Vdd = 4.5~5.5 V動作時)                                                         |                                    |             |             |                      |  |  |  |  |
| ベクタ マスカブル        | 内部:13, 外部:5                                                                                                                              |                                    |             |             |                      |  |  |  |  |
| 割り込み ノンマスカブル     | 内部: 1                                                                                                                                    |                                    |             |             |                      |  |  |  |  |
| 要因 ソフトウエア        | 1                                                                                                                                        |                                    |             |             |                      |  |  |  |  |
| 電源電圧             | V <sub>DD</sub> = 1.8∼5.5 V                                                                                                              |                                    |             |             |                      |  |  |  |  |
| 動作周囲温度           | T <sub>A</sub> = −40~+85 °C                                                                                                              |                                    |             |             |                      |  |  |  |  |
|                  |                                                                                                                                          |                                    |             |             |                      |  |  |  |  |

注 メモリ・サイズ切り替えレジスタ (IMS) により、内部フラッシュ・メモリ、内部高速RAM容量の変更可能。

タイマ/イベント・カウンタの概要(詳細は第6章 16ビット・タイマ/イベント・カウンタ 0, 第7章 8ビット・タイマ/イベント・カウンタ50,51, 第8章 時計用タイマ, 第9章 ウォッチドッグ・タイマを参照)を次に示します。

|     |             | 16ビット・タイマ/イベント・カウンタ | 8ビット・タイマ/イベント・カウンタ | 時計用タイマ                | ウォッチドッグ・タイマ           |
|-----|-------------|---------------------|--------------------|-----------------------|-----------------------|
| 動作  | インターバル・タイマ  | 1 チャネル              | 2 チャネル             | 1 チャネル <sup>注 1</sup> | 1 チャネル <sup>注 2</sup> |
| モード | 外部イベント・カウンタ | 0                   | 0                  | _                     | _                     |
| 機能  | タイマ出力       | 0                   | 0                  | _                     | _                     |
|     | PPG出力       | 0                   | _                  | _                     | _                     |
|     | PWM出力       | _                   | 0                  | _                     | _                     |
|     | パルス幅測定      | 0                   | _                  | _                     | _                     |
|     | 方形波出力       | 0                   | 0                  | _                     | _                     |
|     | 割り込み要求      | 0                   | 0                  | 0                     | 0                     |

- 注1. 時計用タイマは時計用タイマとインターバル・タイマの機能を同時に使用可能です。
  - 2. ウォッチドッグ・タイマはウォッチドッグ・タイマとインターバル・タイマの機能がありますが、いずれか一方を選択して使用してください。

## 1.9 標準水準品と特別水準品との違いについて

標準水準品: μPD780021AS, 780022AS, 780023AS, 780024AS μPD780031AS, 780032AS, 780033AS, 780034AS, 78F0034BS

特別水準品: μPD780021AS(A), 780022AS(A), 780023AS(A), 780024AS(A)
μPD780031AS(A), 780032AS(A), 780033AS(A), 780034AS(A), 780034BS(A)

標準製品と特別製品は、品質水準のみが異なります。

## 第2章 端子機能

## 2.1 端子機能一覧

## (1)ポート端子

| 端子名称    | 入出力 | 機能                                  | リセット時 | 兼用端子        |
|---------|-----|-------------------------------------|-------|-------------|
| P00     | 入出力 | ポート0。                               | 入力    | INTP0       |
| P01     | 1   | 4ビット入出力ポート。                         |       | INTP1       |
| P02     | 1   | 1ビット単位で入力/出力の指定可能。                  |       | INTP2       |
| P03     | 1   | ソフトウエアの設定により、内蔵プルアップ抵抗を使用可能。        |       | INTP3/ADTRG |
| P10-P13 | 入力  | ポート1。                               | 入力    | ANI0-ANI3   |
|         |     | 4ビット入力専用ポート。                        |       |             |
| P20     | 入出力 | ポート2。                               | 入力    | SI30        |
| P21     | 1   | 6ビット入出力ポート。                         |       | SO30        |
| P22     | 1   | 1ビット単位で入力/出力の指定可能。                  |       | SCK30       |
| P23     | 1   | ソフトウエアの設定により、内蔵プルアップ抵抗を使用可能。        |       | RxD0        |
| P24     | 1   |                                     |       | TxD0        |
| P25     | 1   |                                     |       | ASCK0       |
| P34     | 入出力 | ポート3。                               | 入力    | SI31        |
| P35     | 1   | 3ビット入出力ポート。                         |       | SO31        |
| P36     | 1   | 1ビット単位で入力/出力の指定可能。                  |       | SCK31       |
|         |     | ソフトウエアの設定により、内蔵プルアップ抵抗を使用可能。        |       |             |
| P40-P47 | 入出力 | ポート4。                               | 入力    | _           |
|         |     | 8ビット入出力ポート。                         |       |             |
|         |     | 1ビット単位で入力/出力の指定可能。                  |       |             |
|         |     | ソフトウエアの設定により、内蔵プルアップ抵抗を使用可能。        |       |             |
|         |     | 立ち下がりエッジの検出により、割り込み要求フラグ(KRIF)を1にセッ |       |             |
|         |     | ١,٠                                 |       |             |
| P50-P57 | 入出力 | ポート5。                               | 入力    | _           |
|         |     | 8ビット入出力ポート。                         |       |             |
|         |     | LEDを直接駆動可能。                         |       |             |
|         |     | 1ビット単位で入力/出力の指定可能。                  |       |             |
|         |     | ソフトウエアの設定により,内蔵プルアップ抵抗を使用可能。        |       |             |
| P70     | 入出力 | ポート7。                               | 入力    | TI00/TO0    |
| P71     | 1   | 6ビット入出力ポート。                         |       | TI01        |
| P72     | 1   | 1ビット単位で入力/出力の指定可能。                  |       | TI50/TO50   |
| P73     | 1   | ソフトウエアの設定により、内蔵プルアップ抵抗を使用可能。        |       | TI51/TO51   |
| P74     | 1   |                                     |       | PCL         |
| P75     | 1   |                                     |       | BUZ         |

## (2) ポート以外の端子

| 端子名称             | 入出力 | 機能                                      | リセット時 | 兼用端子      |
|------------------|-----|-----------------------------------------|-------|-----------|
| INTP0            | 入力  | 有効エッジ(立ち上がりエッジ、立ち下がりエッジ、立ち上がりエッジおよ      | 入力    | P00       |
| INTP1            |     | び立ち下がりエッジの両エッジ)指定可能な外部割り込み要求入力。         |       | P01       |
| INTP2            |     |                                         |       | P02       |
| INTP3            |     |                                         |       | P03/ADTRG |
| SI30             | 入力  | シリアル・インタフェースのシリアル・データ入力。                | 入力    | P20       |
| SI31             |     |                                         |       | P34       |
| SO30             | 出力  | シリアル・インタフェースのシリアル・データ出力。                | 入力    | P21       |
| SO31             |     |                                         |       | P35       |
| SCK30            | 入出力 | シリアル・インタフェースのシリアル・クロック入力/出力。            | 入力    | P22       |
| SCK31            |     |                                         |       | P36       |
| RxD0             | 入力  | アシンクロナス・シリアル・インタフェース用シリアル・データ入力。        | 入力    | P23       |
| TxD0             | 出力  | アシンクロナス・シリアル・インタフェース用シリアル・データ出力。        | 入力    | P24       |
| ASCK0            | 入力  | アシンクロナス・シリアル・インタフェース用シリアル・クロック入力。       | 入力    | P25       |
| TI00             | 入力  | 16ビット・タイマ/イベント・カウンタ 0 への外部カウント・クロック入力。  | 入力    | P70/TO0   |
|                  |     | 16ビット・タイマ/イベント・カウンタ 0 のキャプチャ・レジスタ(CR00, |       |           |
|                  |     | CR01) へのキャプチャ・トリガ入力。                    |       |           |
| TI01             |     | 16ビット・タイマ/イベント・カウンタ 0 のキャプチャ・レジスタ(CR00) |       | P71       |
|                  |     | へのキャプチャ・トリガ入力。                          |       |           |
| TI50             |     | 8ビット・タイマ/イベント・カウンタ50への外部カウント・クロック入力。    |       | P72/TO50  |
| TI51             |     | 8ビット・タイマ/イベント・カウンタ51への外部カウント・クロック入力。    |       | P73/TO51  |
| TO0              | 出力  | 16ビット・タイマ/イベント・カウンタ 0 出力。               | 入力    | P70/TI00  |
| TO50             |     | 8ビット・タイマ/イベント・カウンタ50出力(8ビットPWM出力と兼      | 入力    | P72/TI50  |
|                  |     | 用)。                                     |       |           |
| TO51             |     | 8ビット・タイマ/イベント・カウンタ51出力(8ビットPWM出力と兼      |       | P73/TI51  |
|                  |     | 用)。                                     |       |           |
| PCL              | 出力  | クロック出力(メイン・システム・クロック、サブシステム・クロックのト      | 入力    | P74       |
|                  |     | リミング用)。                                 |       |           |
| BUZ              | 出力  | ブザー出力。                                  | 入力    | P75       |
| ANI0-ANI3        | 入力  | A/Dコンバータのアナログ入力。                        | 入力    | P10-P13   |
| ADTRG            | 入力  | A/Dコンバータのトリガ信号入力。                       | 入力    | P03/INTP3 |
| AVREF            | 入力  | A/Dコンバータの基準電圧入力。                        | 入力    | _         |
| AVDD             | _   | A/Dコンバータのアナログ電源。VppgまたはVppgと同電位にしてください。 | _     | _         |
| AVss             | _   | A/Dコンバータのグランド電位。VssoまたはVss1と同電位にしてください。 | _     | _         |
| RESET            | 入力  | システム・リセット入力。                            | 入力    | _         |
| X1               | 入力  | メイン・システム・クロック発振用水晶/セラミック接続。             |       | _         |
| X2               | _   |                                         | _     | _         |
| XT1              | 入力  | サブシステム・クロック発振用水晶接続。                     | _     | _         |
| XT2              | _   |                                         | _     | _         |
| V <sub>DD0</sub> | _   | ポート部の正電源。                               | _     | _         |
| V <sub>DD1</sub> |     | 正電源(ポート部を除く)。                           |       | _         |
| V <sub>SS0</sub> | _   | ポート部のグランド電位。                            | _     | _         |
| V <sub>SS1</sub> |     | グランド電位(ポート部を除く)。                        |       | _         |
| IC               | _   | 内部接続されています。VssoまたはVss1に直接接続してください。      | _     | _         |
| V <sub>PP</sub>  |     | プログラム書き込み/ベリファイ時の高電圧印加。                 |       |           |

\*

## 2.2 端子機能の説明

## 2.2.1 P00-P03(Port0)

4 ビットの入出力ポートです。入出力ポートのほかに、外部割り込み入力、A/Dコンバータの外部トリガ入力があります。

1ビット単位で次のような動作モードを指定できます。

#### (1) ポート・モード

4ビットの入出力ポートとして機能します。

P00-P03はポート・モード・レジスタ 0 (PM0) により、1 ビット単位で入力ポートまたは出力ポートに指定できます。プルアップ抵抗オプション・レジスタ0 (PU0) により、内蔵プルアップ抵抗を使用できます。

#### (2) コントロール・モード

外部割り込み要求入力、A/Dコンバータの外部トリガ入力として機能します。

#### (a) INTP0-INTP3

INTPO-INTP3は、有効エッジ(立ち上がりエッジ、立ち下がりエッジ、立ち上がりおよび立ち下がりの両エッジ)指定可能な外部割り込み要求入力端子です。

#### (b) ADTRG

A/Dコンバータの外部トリガ入力端子です。

注意 P03をA/Dコンバータの外部トリガ入力として使用する場合は、A/Dコンバータ・モード・レジスタ(ADM0)のビット1、2(EGA00, EGA01)で有効エッジを指定し、割り込みマスク・フラグ(PMK3)を1に設定してください。

## 2.2.2 P10-P13(Port1)

4 ビットの入力専用ポートです。入力ポートのほかにA/Dコンバータのアナログ入力機能があります。 1 ビット単位で次のような動作モードを指定できます。

## (1) ポート・モード

4ビットの入力専用ポートとして機能します。

#### (2) コントロール・モード

A/Dコンバータのアナログ入力端子(ANIO-ANI3)として機能します。

## 2.2.3 P20-P25(Port2)

6 ビットの入出力ポートです。入出力ポートのほかにシリアル・インタフェースのデータ入出力、クロック入出力機能があります。

1ビット単位で次のような動作モードを指定できます。

## (1) ポート・モード

6 ビットの入出力ポートとして機能します。ポート・モード・レジスタ 2 (PM2) により、1 ビット単位で入力ポートまたは出力ポートに指定できます。プルアップ抵抗オプション・レジスタ 2 (PU2) により、内蔵プルアップ抵抗を使用できます。

#### (2) コントロール・モード

シリアル・インタフェースのデータ入出力、クロック入出力として機能します。

#### (a) SI30, SO30

シリアル・インタフェースのシリアル・データの入出力端子です。

#### (b) SCK30

シリアル・インタフェースのシリアル・クロックの入出力端子です。

#### (c) RxD0, TxD0

アシンクロナス・シリアル・インタフェースのシリアル・データの入出力端子です。

#### (d) ASCK0

アシンクロナス・シリアル・インタフェースのシリアル・クロックの入力端子です。

#### 2.2.4 P34-P36(Port3)

3 ビットの入出力ポートです。入出力ポートのほかにシリアル・インタフェースのデータ入出力、クロック入出力機能があります。

1ビット単位で次のような動作モードを指定できます。

#### (1) ポート・モード

3ビットの入出力ポートとして機能します。ポート・モード・レジスタ 3 (PM3) により、1ビット単位で入力ポートまたは出力ポートに指定できます。

プルアップ抵抗オプション・レジスタ 3 (PU3) により、内蔵プルアップ抵抗を使用できます。

#### (2) コントロール・モード

シリアル・インタフェースのデータ入出力、クロック入出力として機能します。

(a) SI31, SO31

シリアル・インタフェースのシリアル・データの入出力端子です。

## (b) SCK31

シリアル・インタフェースのシリアル・クロックの入出力端子です。

## 2.2.5 P40-P47(Port4)

8ビットの入出力ポートです。

立ち下がりエッジの検出により、割り込み要求フラグ(KRIF)を1にセットできます。

1ビット単位で次のような動作モードを指定できます。

注意 立ち下がりエッジ検出割り込み (INTKR) を使用する場合,メモリ拡張モード・レジスタ (MEM) を 必ず01Hに設定してください。

## (1) ポート・モード

8 ビットの入出力ポートとして機能します。ポート・モード・レジスタ 4 (PM4) により、1 ビット単位で入力ポートまたは出力ポートに指定できます。プルアップ抵抗オプション・レジスタ 4 (PU4) により、内蔵プルアップ抵抗を使用できます。

#### 2.2.6 P50-P57(Port5)

8ビットの入出力ポートです。

LEDを直接駆動可能です。

1ビット単位で次のような動作モードを指定できます。

## (1) ポート・モード

8 ビットの入出力ポートとして機能します。ポート・モード・レジスタ 5 (PM5) により、1 ビット単位で入力ポートまたは出力ポートに指定できます。プルアップ抵抗オプション・レジスタ 5 (PU5) により、内蔵プルアップ抵抗を使用できます。

## 2.2.7 P70-P75(Port7)

6 ビットの入出力ポートです。入出力ポートのほかにタイマの入出力、クロック出力、ブザー出力機能があります。

1ビット単位で次のような動作モードを指定できます。

#### (1) ポート・モード

6 ビットの入出力ポートとして機能します。ポート・モード・レジスタ 7 (PM7) により、1 ビット単位で入力ポートまたは出力ポートに指定できます。プルアップ抵抗オプション・レジスタ 7 (PU7) により、内蔵プルアップ抵抗を使用できます。また、P70、P71は、有効エッジの入力により、16ビット・タイマ/イベント・カウンタのキャプチャ・トリガ信号入力端子にもなります。

#### (2) コントロール・モード

タイマの入出力、クロック出力、ブザー出力として機能します。

#### (a) TI00

16ビット・タイマ/イベント・カウンタへの外部カウント・クロック入力端子および16ビット・タイマ/イベント・カウンタのキャプチャ・レジスタ(CR00, CR01)へのキャプチャ・トリガ信号入力端子です。

#### (b) TI01

16ビット・タイマ/イベント・カウンタのキャプチャ・レジスタ(CR00)へのキャプチャ・トリガ信 号入力端子です。

#### (c) TI50, TI51

8ビット・タイマ/イベント・カウンタへの外部カウント・クロック入力端子です。

## (d) TO0, TO50, TO51

タイマ出力端子です。

#### (e) PCL

クロック出力端子です。

## (f) BUZ

ブザー出力端子です。

## 2.2.8 AVREF

A/Dコンバータの基準電圧入力端子です。

A/Dコンバータを使用しない場合は、VssoまたはVss1に直接接続してください。

## 2.2.9 AVDD

A/Dコンバータのアナログ電源端子です。A/Dコンバータを使用しないときでも、常にVDDO端子またはVDD1端子と同電位で使用してください。

## 2.2.10 AVss

A/Dコンバータのグランド電位端子です。A/Dコンバータを使用しないときでも、常にVsso端子またはVssi端子と同電位で使用してください。

## 2.2.11 RESET

ロウ・レベル・アクティブのシステム・リセット入力端子です。

## 2.2.12 X1, X2

メイン・システム・クロック発振用水晶/セラミック振動子接続端子です。 外部クロックを供給するときは、X1に入力し、X2にその反転信号を入力してください。

## 2.2.13 XT1, XT2

サブシステム・クロック発振用水晶振動子接続端子です。

外部クロックを供給するときは、XT1に入力し、XT2にその反転信号を入力してください。

## 2.2.14 VDD0, VDD1

VDD0は、ポート部の正電源供給端子です。

VDD1は、ポート部以外の正電源供給端子です。

## 2.2.15 Vsso, Vss1

Vssoは、ポート部のグランド電位端子です。

Vss1は、ポート部以外のグランド電位端子です。

## 2.2.16 Vpp(フラッシュ・メモリ製品のみ)

フラッシュ・メモリ・プログラミング・モード設定およびプログラム書き込み/ベリファイ時の高電圧印加端 子です。

次のどちらかの端子処理をしてください。

- ・個別に10 kΩのプルダウン抵抗を接続する。
- ・ボード上のジャンパで、プログラミング・モード時は専用フラッシュ・ライタに、通常動作モード時はVsso またはVss1に直接接続するように切り替える。

VPP端子とVsso端子またはVss1端子間の配線の引き回しが長い場合や、VPP端子に外来ノイズが加わった場合などで、VPP端子とVsso端子またはVss1端子間に電位差が生じたときには、お客様のプログラムが正常に動作しないことがあります。

## 2.2.17 IC(マスクROM製品のみ)

IC(Internally Connected)端子は、当社出荷時に  $\mu$  PD780024AS, 780034ASサブシリーズを検査するためのテスト・モードに設定するための端子です。通常動作モード時には、IC端子をVsso端子またはVsst端子に直接接続し、その配線長を極力短くしてください。

IC端子とVsso端子またはVss1端子間の配線の引き回しが長い場合や、IC端子に外来ノイズが加わった場合などで、IC端子とVsso端子またはVss1端子間に電位差が生じたときには、お客様のプログラムが正常に動作しないことがあります。

## ○IC端子をVsso端子またはVss1端子に直接接続してください。



## 2.3 端子の入出力回路と未使用端子の処理

各端子の入出力回路タイプと、未使用端子の処理を表 2-1 に示します。 また、各タイプの入出力回路の構成は、図 2-1 を参照してください。

表 2 - 1 各端子の入出力回路タイプ

| 端子名                 | 入出力回路タイプ | 入出力 | 未使用時の推奨接続方法                                                                                 |
|---------------------|----------|-----|---------------------------------------------------------------------------------------------|
| P00/INTP0-P02/INTP2 | 8-C      | 入出力 | 入力時:個別に抵抗を介して、VssoまたはVss1に接続してく                                                             |
| P03/INTP3/ADTRG     |          |     | ださい。                                                                                        |
|                     |          |     | 出力時:オープンにしてください。                                                                            |
| P10/ANI0-P13/ANI3   | 25       | 入力  | V <sub>DD0</sub> , V <sub>DD1</sub> , V <sub>SS0</sub> , V <sub>SS1</sub> のいずれかに直接接続してください。 |
| P20/SI30            | 8-C      | 入出力 | 入力時:個別に抵抗を介して、VDDO, VDD1, VSSO, VSS1のいず                                                     |
| P21/SO30            | 5-H      |     | れかに接続してください                                                                                 |
| P22/SCK30           | 8-C      |     | 出力時:オープンにしてください。                                                                            |
| P23/RxD0            |          |     |                                                                                             |
| P24/TxD0            | 5-H      |     |                                                                                             |
| P25/ASCK0           | 8-C      |     |                                                                                             |
| P34/SI31            | 8-C      |     | 入力時:個別に抵抗を介して, VDD0, VDD1, VSS0, VSS1のいず                                                    |
| P35/SO31            | 5-H      |     | れかに接続してください。                                                                                |
| P36/SCK31           | 8-C      |     | 出力時:オープンにしてください。                                                                            |
| P40-P47             | 5-H      |     | 入力時:個別に抵抗を介して、VDDOまたはVDD1に接続してく                                                             |
|                     |          |     | ださい。                                                                                        |
|                     |          |     | 出力時:オープンにしてください。                                                                            |
| P50-P57             | 5-H      |     | 入力時:個別に抵抗を介して, VDDO, VDD1, VSSO, VSS1のいず                                                    |
| P70/TI00/TO0        | 8-C      |     | れかに接続してください。                                                                                |
| P71/TI01            |          |     | 出力時:オープンにしてください。                                                                            |
| P72/TI50/TO50       |          |     |                                                                                             |
| P73/TI51/TO51       |          |     |                                                                                             |
| P74/PCL             | 5-H      |     |                                                                                             |
| P75/BUZ             |          |     |                                                                                             |
| RESET               | 2        | 入力  | -                                                                                           |
| XT1                 | 16       |     | VDD0またはVDD1に直接接続してください。                                                                     |
| XT2                 |          | _   | オープンにしてください。                                                                                |
| AVDD                | _        |     | VDDOまたはVDD1に直接接続してください。                                                                     |
| AVREF               | ]        |     | VssoまたはVss1に直接接続してください。                                                                     |
| AVss                |          |     |                                                                                             |
| IC(マスクROM製品)        | ]        |     |                                                                                             |
| Vpp(フラッシュ・メモリ製品)    |          |     | 個別に10 kΩのプルダウン抵抗を接続するか,Vssoまたは                                                              |
|                     |          |     | Vss1に直接接続してください。                                                                            |

図2-1 端子の入出力回路一覧



## 第3章 CPUアーキテクチャ

## 3.1 メモリ空間

 $\mu$ PD780024AS, 780034ASサブシリーズは、それぞれ64 Kバイトのメモリ空間をアクセスできます。図 3-1 から図 3-5 に、メモリ・マップを示します。

注意 メモリ・サイズ切り替えレジスタ (IMS) の初期値は、内部メモリ容量にかかわらず、 $\mu$ PD780024AS、780034ASサブシリーズすべての製品において一定 (IMS = CFH) となっています。したがって、初期設定で各製品ごとに次に示す値を設定して使用してください。

 $\mu$  PD780021AS, 780031AS : 42H  $\mu$  PD780022AS, 780032AS : 44H  $\mu$  PD780023AS, 780033AS : C6H  $\mu$  PD780024AS, 780034AS : C8H

μ PD78F0034BS :マスクROM製品に対応した値

#### 図 3 -1 メモリ・マップ ( $\mu$ PD780021AS, 780031AS)



## 図 3 -2 メモリ・マップ ( $\mu$ PD780022AS, 780032AS)



## 図 3 - 3 メモリ・マップ ( $\mu$ PD780023AS, 780033AS)



#### 図 3 -4 メモリ・マップ ( $\mu$ PD780024AS, 780034AS)



## 図 3 -5 メモリ・マップ ( $\mu$ PD78F0034BS)



## 3.1.1 内部プログラム・メモリ空間

内部プログラム・メモリ空間にはプログラムおよびテーブル・データなど格納します。通常、プログラム・カウンタ(PC)でアドレスします。

 $\mu$ PD780024AS, 780034ASサブシリーズは、各製品ごとに次に示す内部ROM(マスクROMまたはフラッシュ・メモリ)を内蔵しています。

| 製 品                   | 構造        | 容量                       |
|-----------------------|-----------|--------------------------|
| μPD780021AS, 780031AS | マスクROM    | 8192×8ビット(0000H-1FFFH)   |
| μPD780022AS, 780032AS |           | 16384×8ビット (0000H-3FFFH) |
| μPD780023AS, 780033AS |           | 24576×8ビット (0000H-5FFFH) |
| μPD780024AS, 780034AS |           | 32768×8ビット (0000H-7FFFH) |
| μPD78F0034BS          | フラッシュ・メモリ | 32768×8ビット (0000H-7FFFH) |

表 3 - 1 内部ROM容量

内部プログラム・メモリ空間には、次に示す領域を割り付けています。

#### (1) ベクタ・テーブル領域

0000H-003FHの64バイト領域はベクタ・テーブル領域として予約されています。ベクタ・テーブル領域には、RESET入力、各割り込み要求発生により分岐するときのプログラム・スタート・アドレスを格納しておきます。

16ビット・アドレスのうち下位8ビットが偶数アドレスに、上位8ビットが奇数アドレスに格納されます。

| ベクタ・テーブル・アドレス | 割り込み要因   | ベクタ・テーブル・アドレス | 割り込み要因   |
|---------------|----------|---------------|----------|
| 0000H         | RESET入力  | 0016H         | INTCSI31 |
| 0004H         | INTWDT   | 001AH         | INTWTI   |
| 0006H         | INTP0    | 001CH         | INTTM00  |
| 0008H         | INTP1    | 001EH         | INTTM01  |
| 000AH         | INTP2    | 0020H         | INTTM50  |
| 000CH         | INTP3    | 0022H         | INTTM51  |
| 000EH         | INTSER0  | 0024H         | INTAD0   |
| 0010H         | INTSR0   | 0026H         | INTWT    |
| 0012H         | INTST0   | 0028H         | INTKR    |
| 0014H         | INTCSI30 | 003EH         | BRK      |

表 3 - 2 ベクタ・テーブル

#### (2) CALLT命令テーブル領域

0040H-007FHの64バイト領域には、1 バイト・コール命令(CALLT)のサブルーチン・エントリ・アドレスを格納できます。

#### (3) CALLF命令エントリ領域

0800H-0FFFHの領域は、2バイト・コール命令(CALLF)で直接サブルーチン・コールできます。

## 3.1.2 内部データ・メモリ空間

μPD780024AS, 780034ASサブシリーズは、次に示す内部高速RAMを内蔵しています。

表 3 一 3 内部高速RAM容量

| 製 品                   | 内部高速RAM                |
|-----------------------|------------------------|
| μPD780021AS, 780031AS | 512×8ビット(FD00H-FEFFH)  |
| μPD780022AS, 780032AS |                        |
| μPD780023AS, 780033AS | 1024×8ビット(FB00H-FEFFH) |
| μPD780024AS, 780034AS |                        |
| μPD78F0034BS          |                        |

このうちFEE0H-FEFFHの32バイトの領域には、8ビット・レジスタ8個を1バンクとする汎用レジスタが、4バンク割り付けられます。

プログラム領域として命令を書いて実行することはできません。

また、内部高速RAMはスタック・メモリとしても使用できます。

## 3.1.3 特殊機能レジスタ(SFR: Special Function Register)領域

FF00H-FFFFHの領域には、オン・チップ周辺ハードウエアの特殊機能レジスタ(SFR)が割り付けられています (3.2.3 特殊機能レジスタ(SFR: Special Function Register)の表 3 - 5 特殊機能レジスタ一覧参照)。

注意 SFRを割り付けていないアドレスをアクセスしないでください。

## 3.1.4 外部メモリ空間

メモリ拡張モード・レジスタ (MEM) の設定によりアクセスが可能な外部メモリ空間です。プログラム、テーブル・データなどの格納、および周辺デバイスを割り付けることができます。

## 3.1.5 データ・メモリ・アドレシング

次に実行する命令のアドレスを指定したり、命令を実行する際に操作対象となるレジスタやメモリなどのアドレスを指定する方法をアドレシングといいます。

命令を実行する際に操作対象となるメモリのアドレシングについて、 $\mu$ PD780024AS, 780034ASサブシリーズでは、その操作性などを考慮して豊富なアドレシング・モードを備えました。特にデータ・メモリを内蔵している領域では、特殊機能レジスタ(SFR)や汎用レジスタなど、それぞれの持つ機能にあわせて特有のアドレシングが可能です。図 3 -6 から図 3 -10にデータ・メモリとアドレシングの対応を示します。各アドレシングの詳細については、3.4 オペランド・アドレスのアドレシングを参照してください。

図 3 - 6 データ・メモリとアドレシングの対応 (μPD780021AS, 780031AS)



#### 図 3 - 7 データ・メモリとアドレシングの対応 (µPD780022AS, 780032AS)



図 3 - 8 データ・メモリとアドレシングの対応 ( µ PD780023AS, 780033AS)



#### 図 3 - 9 データ・メモリとアドレシングの対応 (µPD780024AS, 780034AS)



図 3 -10 データ・メモリとアドレシングの対応 (μPD78F0034BS)



## 3.2 プロセッサ・レジスタ

 $\mu$ PD780024AS, 780034ASサブシリーズは、次のプロセッサ・レジスタを内蔵しています。

#### 3.2.1 制御レジスタ

プログラム・シーケンス、ステータス、スタック・メモリの制御など専用の機能を持ったレジスタです。制御レジスタには、プログラム・カウンタ(PC)、プログラム・ステータス・ワード(PSW)、スタック・ポインタ (SP) があります。

#### (1) プログラム・カウンタ(PC)

プログラム・カウンタは、次に実行するプログラムのアドレス情報を保持する16ビット・レジスタです。 通常動作時には、フェッチする命令のバイト数に応じて、自動的にインクリメントされます。分岐命令実 行時には、イミーディエト・データやレジスタの内容がセットされます。

RESET入力により、0000Hと0001H番地のリセット・ベクタ・テーブルの値がプログラム・カウンタにセットされます。

図3-11 プログラム・カウンタの構成

|    | 15   |      |      |      |      |      |     |     |     |     |     |     |     |     |     | 0   |
|----|------|------|------|------|------|------|-----|-----|-----|-----|-----|-----|-----|-----|-----|-----|
| PC | PC15 | PC14 | PC13 | PC12 | PC11 | PC10 | PC9 | PC8 | PC7 | PC6 | PC5 | PC4 | РС3 | PC2 | PC1 | PC0 |

#### (2) プログラム・ステータス・ワード(PSW)

プログラム・ステータス・ワードは、命令の実行によってセット、リセットされる各種フラグで構成される8ビット・レジスタです。

プログラム・ステータス・ワードの内容は、割り込み要求発生時およびPUSH PSW命令の実行時に自動的にスタックされ、RETB、RETI命令およびPOP PSW命令の実行時に自動的に復帰されます。

RESET入力により、02Hになります。

図 3-12 プログラム・ステータス・ワードの構成

|     | 7 |   |      |    |      |   |     | 0  |
|-----|---|---|------|----|------|---|-----|----|
| PSW | E | Z | RBS1 | AC | RBS0 | 0 | ISP | CY |

#### (a)割り込み許可フラグ(IE)

CPUの割り込み要求受け付け動作を制御するフラグです。

IE = 0のときは割り込み禁止(DI)状態となり、ノンマスカブル割り込み以外の割り込みはすべて禁止されます。

IE = 1のときは割り込み許可(EI)状態となります。このとき割り込み要求の受け付けは、インサービス・プライオリティ・フラグ(ISP)、各割り込み要因に対する割り込みマスク・フラグおよび優先順位指定フラグにより制御されます。

このフラグは、DI命令の実行または割り込みの受け付けでリセット(0)され、EI命令の実行によりセット(1)されます。

#### (b) ゼロ・フラグ(Z)

演算結果がゼロのときセット(1)され、それ以外のときにリセット(0)されるフラグです。

## (c) レジスタ・バンク選択フラグ(RBS0, RBS1)

4個のレジスタ・バンクのうちの1つを選択する2ビットのフラグです。

SEL RBn命令の実行によって選択されたレジスタ・バンクを示す2ビットの情報が格納されています。

## (d)補助キャリー・フラグ(AC)

演算結果が、ビット3からキャリーがあったとき、またはビット3へのボローがあったときセット(1) され、それ以外のときリセット(0) されるフラグです。

#### (e) インサービス・プライオリティ・フラグ(ISP)

受け付け可能なマスカブル・ベクタ割り込みの優先順位を管理するフラグです。ISP = 0のときは優先順位指定フラグ・レジスタ(PROL, PROH, PR1L)(15.3(3)優先順位指定フラグ・レジスタ(PROL, PR0H, PR1L)参照)で低位に指定されたベクタ割り込み要求は受け付け禁止となります。なお、実際に割り込み要求が受け付けられるかどうかは、割り込み許可フラグ(IE)の状態により制御されます。

#### (f) キャリー・フラグ(CY)

加減算命令実行時のオーバフロー、アンダフローを記憶するフラグです。また、ローテート命令実行時はシフト・アウトされた値を記憶し、ビット演算命令実行時には、ビット・アキュームレータとして機能します。

#### (3) スタック・ポインタ(SP)

メモリのスタック領域の先頭アドレスを保持する16ビットのレジスタです。スタック領域としては内部高速RAM領域のみ設定可能です。各製品の内部高速RAM領域は次のとおりです。

表 3 一 4 内部高速RAM領域

| 製 品                                                  | 内部高速RAM領域   |
|------------------------------------------------------|-------------|
| μPD780021AS, 780022AS, 780031AS, 780032AS            | FD00H-FEFFH |
| μPD780023AS, 780024AS, 780033AS, 780034AS, 78F0034BS | FB00H-FEFFH |

図3-13 スタック・ポインタの構成

15 0 SP SP15 SP14 SP13 SP12 SP11 SP10 SP9 SP8 SP7 SP6 SP5 SP4 SP3 SP2 SP1 SP0

スタック・メモリへの書き込み(退避)動作に先立ってデクリメントされ、スタック・メモリからの読み取り(復帰)動作のあとインクリメントされます。

各スタック動作によって退避/復帰されるデータは図3-14.3-15のようになります。

注意 SPの内容はRESET入力により、不定になりますので、必ずスタック使用前にイニシャライズしてください。

#### 図3-14 スタック・メモリへ退避されるデータ

## (a) PUSH rp命令(SPがFEE0Hの場合)



## (b) CALL, CALLF, CALLT命令(SPがFEE0Hの場合)



## (c) 割り込み, BRK命令(SPがFEE0Hの場合)



#### 図 3 -15 スタック・メモリから復帰されるデータ

#### (a) POP rp命令 (SPがFEDEHの場合)



#### (b) RET命令(SPがFEDEHの場合)



#### (c) RETI, RETB命令(SPがFEDDHの場合)



## 3.2.2 汎用レジスタ

汎用レジスタは、データ・メモリの特定番地(FEE0H-FEFFH)にマッピングされており、 8 ビット・レジスタ 8 個(X, A, C, B, E, D, L, H)を 1 バンクとして 4 バンクのレジスタで構成されています。

各レジスタは、それぞれ8ビット・レジスタとして使用できるほか、2個の8ビット・レジスタをペアとして16ビット・レジスタとしても使用できます(AX, BC, DE, HL)。

また、機能名称(X, A, C, B, E, D, L, H, AX, BC, DE, HL)のほか、絶対名称(R0-R7, RP0-RP3)ででも記述できます。

命令実行時に使用するレジスタ・バンクは、CPU制御命令(SEL RBn)によって設定します。 4 レジスタ・バンク構成になっていますので、通常処理で使用するレジスタと割り込み時で使用するレジスタをバンクごとに切り替えることにより、効率のよいプログラムを作成できます。

## 図 3-16 汎用レジスタの構成

## (a)絶対名称

| _         |        |     | 16ビット処理 |    | 8 ビット処理 |
|-----------|--------|-----|---------|----|---------|
| FEFFH     | DANIKO |     | DDG     |    | R7      |
| FEF8H     |        |     | RP3     |    | R6      |
|           |        | DDo |         | R5 |         |
| F E F O H | BANK1  |     | RP2     |    | R4      |
|           | DANIKO |     |         |    | R3      |
| FEE8H     | BANK2  |     | RP1     |    | R2      |
|           |        | 222 |         | R1 |         |
| F E E O H | BANK3  |     | RP0     |    | R0      |
|           |        |     | 15 0    |    | 7 0     |

## (b)機能名称



## 3.2.3 特殊機能レジスタ(SFR: Special Function Register)

特殊機能レジスタは、汎用レジスタとは異なり、それぞれ特別な機能を持つレジスタです。

FF00H-FFFFHの領域に割り付けられています。

特殊機能レジスタは、演算命令、転送命令、ビット操作命令などにより、汎用レジスタと同じように操作できます。操作可能なビット単位(1,8,16)は、各特殊機能レジスタで異なります。

各操作ビット単位ごとの指定方法を次に示します。

#### ・1ビット操作

1ビット操作命令のオペランド(sfr.bit)にアセンブラで予約されている略号を記述します。アドレスでも指定できます。

#### ・8ビット操作

8ビット操作命令のオペランド(sfr)にアセンブラで予約されている略号を記述します。アドレスでも指定できます。

#### ・16ビット操作

16ビット操作命令のオペランド(sfrp)にアセンブラで予約されている略号を記述します。アドレスを指定するときは偶数アドレスを記述してください。

表3-5に特殊機能レジスタの一覧を示します。表中の項目の意味は次のとおりです。

#### ・略号

◆ 特殊機能レジスタのアドレスを示す略号です。RA78K0で予約語に、CC78K0では#pragma sfr指令で、sfr変数として定義されているものです。RA78K0, ID78K0-NS, ID78K0およびSM78K0使用時に命令のオペランドとして記述できます。

#### · R/W

該当する特殊機能レジスタが読み出し(Read)/書き込み(Write)可能かどうかを示します。

R/W :読み出し/書き込みがともに可能

R :読み出しのみ可能W :書き込みのみ可能

#### ・操作可能ビット単位

操作可能なビット単位(1,8,16)を○で示します。一は操作できないビット単位であることを示します。

#### ・リセット時

RESET入力時の各レジスタの状態を示します。

表 3 - 5 特殊機能レジスタ一覧 (1/2)

| アドレス  | ス 特殊機能レジスタ(SFR)名称           |       | 略号   |     | 操作   | リセット時 |                |       |
|-------|-----------------------------|-------|------|-----|------|-------|----------------|-------|
|       |                             |       |      |     | 1ビット | 8ビット  | 16ビット          |       |
| FF00H | ポートロ                        | P0    |      | R/W | 0    | 0     | _              | 00 H  |
| FF01H | ポート1                        | P1    |      | R   | 0    | 0     | _              | 注1    |
| FF02H | ポート2                        | P2    |      | R/W | 0    | 0     | _              | 00H   |
| FF03H | ポート3                        | P3    |      |     | 0    | 0     | _              | 注 2   |
| FF04H | ポート4                        | P4    |      |     | 0    | 0     | _              | 00H   |
| FF05H | ポート5                        | P5    |      |     | 0    | 0     | _              |       |
| FF07H | ポート7                        | P7    |      |     | 0    | 0     | _              |       |
| FF0AH | 16ビット・タイマ・キャプチャ/コンペア・       | CR00  |      |     | _    | _     | 0              | 不定    |
| FF0BH | レジスタ00                      |       |      |     |      |       |                |       |
| FF0CH | 16ビット・タイマ・キャプチャ/コンペア・       | CR01  |      |     | _    | _     | 0              |       |
| FF0DH | レジスタ01                      |       |      |     |      |       |                |       |
| FF0EH | 16ビット・タイマ・カウンタ 0            | TM0   |      | R   | _    | _     | 0              | 0000H |
| FF0FH |                             |       |      |     |      |       |                |       |
| FF10H | 8 ビット・タイマ・コンペア・レジスタ50       | CR50  |      | R/W | _    | 0     | _              | 不定    |
| FF11H | 8 ビット・タイマ・コンペア・レジスタ51       | CR51  |      |     | _    | 0     | _              |       |
| FF12H | 8 ビット・タイマ・カウンタ50            | TM5   | TM50 | R   | _    | 0     | 0              | 00H   |
| FF13H | 8 ビット・タイマ・カウンタ51            |       | TM51 |     | _    | 0     |                |       |
| FF16H | A/D変換結果レジスタ0                | ADCR0 |      |     | _    | _     | 0              |       |
| FF17H |                             |       |      |     | _    | _     |                |       |
| FF18H | 送信シフト・レジスタ 0                | TXS0  |      | W   | _    | 0     | _              | FFH   |
|       |                             | RXB0  |      | R   | T    | 0     | [ <del>-</del> |       |
| FF1AH | シリアルI/Oシフト・レジスタ30           | SIO30 |      | R/W | _    | 0     | _              | 不定    |
| FF1BH | シリアルI/Oシフト・レジスタ31           | SIO31 |      |     | _    | 0     | _              |       |
| FF20H | ポート・モード・レジスタ 0              | PM0   |      |     | 0    | 0     | _              | FFH   |
| FF22H | ポート・モード・レジスタ 2              | PM2   |      |     | 0    | 0     | _              |       |
| FF23H | ポート・モード・レジスタ 3              | РМ3   |      |     | 0    | 0     | _              |       |
| FF24H | ポート・モード・レジスタ 4              | PM4   |      |     | 0    | 0     | _              |       |
| FF25H | ポート・モード・レジスタ 5              | PM5   |      |     | 0    | 0     | _              |       |
| FF27H | ポート・モード・レジスタ 7              | PM7   |      |     | 0    | 0     | _              |       |
| FF30H | プルアップ抵抗オプション・レジスタ 0         | PU0   |      |     | 0    | 0     | _              | 00H   |
| FF32H | プルアップ抵抗オプション・レジスタ 2         | PU2   |      |     | 0    | 0     | _              |       |
| FF33H | プルアップ抵抗オプション・レジスタ 3         | PU3   |      |     | 0    | 0     | _              |       |
| FF34H | プルアップ抵抗オプション・レジスタ 4         | PU4   |      |     | 0    | 0     | _              |       |
| FF35H | プルアップ抵抗オプション・レジスタ 5         | PU5   |      |     | 0    | 0     | _              |       |
| FF37H | プルアップ抵抗オプション・レジスタ7          | PU7   |      |     | 0    | 0     | _              |       |
| FF40H | クロック出力選択レジスタ                | CKS   |      |     | 0    | 0     | _              |       |
| FF41H | 時計用タイマ動作モード・レジスタ            | WTM   |      |     | 0    | 0     | _              |       |
| FF42H | ウォッチドッグ・タイマ・クロック選択レジスタ      | WDCS  |      |     | _    | 0     | _              |       |
| FF47H | メモリ拡張モード・レジスタ               | MEM   |      |     | 0    | 0     | _              |       |
| FF48H | 外部割り込み立ち上がりエッジ許可レジスタ        | EGP   |      |     | 0    | 0     | _              |       |
| FF49H | 外部割り込み立ち下がりエッジ許可レジスタ        | EGN   |      |     | 0    | 0     | _              |       |
| FF60H | 16ビット・タイマ・モード・コントロール・レジスタ 0 | TMC0  |      |     | 0    | 0     | _              |       |

注1. 上位4ビット:不定,下位4ビット:0H

2. 上位 4 ビット: OH, 下位 4 ビット: 不定

表 3 - 5 特殊機能レジスタ一覧 (2/2)

| アドレス  | 特殊機能レジスタ(SFR)名称                    | 略      | 号    | R/W | 操作   | 可能ビット | 単位    | リセット時            |
|-------|------------------------------------|--------|------|-----|------|-------|-------|------------------|
|       |                                    |        |      |     | 1ビット | 8ビット  | 16ビット |                  |
| FF61H | プリスケーラ・モード・レジスタ 0                  | PRM0   |      | R/W | _    | 0     | _     | 00H              |
| FF62H | キャプチャ/コンペア・コントロール・レジスタ 0           | CRC0   |      |     | 0    | 0     | _     |                  |
| FF63H | 16ビット・タイマ出力コントロール・レジスタ 0           | TOC0   |      |     | 0    | 0     | _     |                  |
| FF70H | 8ビット・タイマ・モード・コントロール・レジスタ50         | TMC50  |      |     | 0    | 0     | _     |                  |
| FF71H | タイマ・クロック選択レジスタ50                   | TCL50  |      |     | _    | 0     | _     |                  |
| FF78H | 8ビット・タイマ・モード・コントロール・レジスタ51         | TMC51  |      |     | 0    | 0     | _     |                  |
| FF79H | タイマ・クロック選択レジスタ51                   | TCL51  |      |     | _    | 0     | _     |                  |
| FF80H | A/Dコンバータ・モード・レジスタ O                | ADM0   |      |     | 0    | 0     | _     |                  |
| FF81H | アナログ入力チャネル指定レジスタ0                  | ADS0   |      |     | _    | 0     | _     |                  |
| FFA0H | アシンクロナス・シリアル・インタフェース・モード・レジスタの     | ASIM0  |      |     | 0    | 0     | _     |                  |
| FFA1H | アシンクロナス・シリアル・インタフェース・ステータス・レジスタ () | ASIS0  |      | R   | _    | 0     | _     |                  |
| FFA2H | ボー・レート・ジェネレータ・コントロール・レジスタの         | BRGC0  |      | R/W | _    | 0     | _     |                  |
| FFB0H | シリアル動作モード・レジスタ30                   | CSIM30 |      |     | 0    | 0     | _     |                  |
| FFB8H | シリアル動作モード・レジスタ31                   | CSIM31 | _    |     | 0    | 0     | _     |                  |
| FFE0H | 割り込み要求フラグ・レジスタ0L                   | IF0    | IF0L |     | 0    | 0     | 0     |                  |
| FFE1H | 割り込み要求フラグ・レジスタ0H                   |        | IF0H |     | 0    | 0     |       |                  |
| FFE2H | 割り込み要求フラグ・レジスタ1L                   | IF1L   |      |     | 0    | 0     | _     |                  |
| FFE4H | 割り込みマスク・フラグ・レジスタOL                 | MK0    | MK0L |     | 0    | 0     | 0     | FFH              |
| FFE5H | 割り込みマスク・フラグ・レジスタ0H                 |        | MK0H |     | 0    | 0     |       |                  |
| FFE6H | 割り込みマスク・フラグ・レジスタ1L                 | MK1L   | _    |     | 0    | 0     | _     |                  |
| FFE8H | 優先順位指定フラグ・レジスタ0L                   | PR0    | PR0L |     | 0    | 0     | 0     |                  |
| FFE9H | 優先順位指定フラグ・レジスタ0H                   |        | PR0H |     | 0    | 0     |       |                  |
| FFEAH | 優先順位指定フラグ・レジスタ1L                   | PR1L   |      |     | 0    | 0     | _     |                  |
| FFF0H | メモリ・サイズ切り替えレジスタ                    | IMS    |      |     | _    | 0     | _     | CFH <sup>注</sup> |
| FFF9H | ウォッチドッグ・タイマ・モード・レジスタ               | WDTM   |      |     | 0    | 0     | _     | 00H              |
| FFFAH | 発振安定時間選択レジスタ                       | OSTS   |      |     | _    | 0     | _     | 04H              |
| FFFBH | プロセッサ・クロック・コントロール・レジスタ             | PCC    |      |     | 0    | 0     | _     |                  |

注 初期値はCFHですが、初期設定で各製品ごとに次に示す値を設定して使用してください。

 $\mu$  PD780021AS, 780031AS : 42H  $\mu$  PD780022AS, 780032AS : 44H  $\mu$  PD780023AS, 780033AS : C6H  $\mu$  PD780024AS, 780034AS : C8H

 $\mu$ PD78F0034BS:マスクROM製品に対応した値

## 3.3 命令アドレスのアドレシング

命令アドレスは、プログラム・カウンタ(PC)の内容によって決定されます。PCの内容は、通常、命令を1つ実行するごとにフェッチする命令のバイト数に応じて自動的にインクリメント(1バイトに対して十1)されます。しかし、分岐を伴う命令を実行する際には、次に示すようなアドレシングにより分岐先アドレス情報がPCにセットされて分岐します(各命令についての詳細は78K/0シリーズ ユーザーズ・マニュアル 命令編(U12326J)を参照してください)。

## 3.3.1 レラティブ・アドレシング

#### 【機 能】

次に続く命令の先頭アドレスに命令コードの8ビット・イミーディエト・データ(ディスプレースメント値: jdisp8)を加算した値が、プログラム・カウンタ(PC)に転送されて分岐します。ディスプレースメント値は、符号付きの2の補数データ(一128~十127)として扱われ、ビット7が符号ビットとなります。つまり、レラティブ・アドレシングでは、次に続く命令の先頭アドレスから相対的に一128~十127の範囲に分岐するということです。

BR \$addr16命令および条件付き分岐命令を実行する際に行われます。

#### 【図解】



S = 0のとき、 $\alpha$ は全ビット0

S = 1のとき、 $\alpha$ は全ビット1

## 3.3.2 イミーディエト・アドレシング

## 【機 能】

命令語中のイミーディエト・データがプログラム・カウンタ (PC) に転送され、分岐します。

CALL !addr16, BR !addr16, CALLF !addr11命令を実行する際に行われます。

CALL !addr16, BR !addr16命令は、全メモリ空間に分岐できます。CALLF !addr11命令は、0800H-0FFFH の領域に分岐します。

## 【図 解】

## CALL !addr16, BR !addr16命令の場合



#### CALLF!addr11命令の場合



## 3.3.3 テーブル・インダイレクト・アドレシング

#### 【機 能】

命令コードのビット1からビット5のイミーディエト・データによりアドレスされる特定ロケーションのテーブルの内容(分岐先アドレス)がプログラム・カウンタ(PC)に転送され、分岐します。

CALLT [addr5] 命令を実行する際にテーブル・インダイレクト・アドレシングが行われます。この命令では40H-7FHのメモリ・テーブルに格納されたアドレスを参照し、全メモリ空間に分岐できます。

## 【図 解】



## 3.3.4 レジスタ・アドレシング

## 【機 能】

命令語によって指定されるレジスタ・ペア(AX)の内容がプログラム・カウンタ(PC)に転送され、分岐します。

BR AX命令を実行する際に行われます。

#### 【図解】



## 3.4 オペランド・アドレスのアドレシング

命令を実行する際に操作対象となるレジスタやメモリなどを指定する方法 (アドレシング) として次に示すいく つかの方法があります。

## 3.4.1 インプライド・アドレシング

## 【機 能】

汎用レジスタの領域にあるアキュームレータ(A, AX)として機能するレジスタを自動的(暗黙的)にアドレスするアドレシングです。

 $\mu$ PD780024AS, 780034ASサブシリーズの命令語中でインプライド・アドレシングを使用する命令は次のとおりです。

| 命 令         | インプライド・アドレシングで指定されるレジスタ                     |
|-------------|---------------------------------------------|
| MULU        | 被乗数としてAレジスタ、積が格納されるレジスタとしてAXレジスタ            |
| DIVUW       | 被除数および商を格納するレジスタとしてAXレジスタ                   |
| ADJBA/ADJBS | 10進補正の対象となる数値を格納するレジスタとしてAレジスタ              |
| ROR4/ROL4   | ディジット・ローテートの対象となるディジット・データを格納するレジスタとしてAレジスタ |

#### 【オペランド形式】

命令によって自動的に使用できるため、特定のオペランド形式を持ちません。

## 【記 述 例】

#### MULU Xの場合

8 ビット×8 ビットの乗算命令において、A レジスタと X レジスタの積をAXに格納する。ここで、A, AX レジスタがインプライド・アドレシングで指定されている。

## 3.4.2 レジスタ・アドレシング

#### 【機 能】

オペランドとして汎用レジスタをアクセスするアドレシングです。アクセスされる汎用レジスタは、レジスタ・バンク選択フラグ(RBSO, RBS1)および、命令コード中のレジスタ指定コード(Rn, PRn)により指定されます。

レジスタ・アドレシングは、次に示すオペランド形式を持つ命令を実行する際に行われ、8 ビット・レジスタを指定する場合は命令コード中の3 ビットにより8 本中の1 本を指定します。

## 【オペランド形式】

| 表現形式 | 記 述 方 法                |
|------|------------------------|
| r    | X, A, C, B, E, D, L, H |
| rp   | AX, BC, DE, HL         |

r , rpは,機能名称(X , A , C , B , E , D , L , H , AX , BC , DE , HL)のほかに絶対名称(R0-R7 , RP0-RP3)で記述できます。

#### 【記 述 例】

MOV A, C; rにCレジスタを選択する場合



INCW DE; rpにDEレジスタ・ペアを選択する場合



## 3.4.3 ダイレクト・アドレシング

## 【機 能】

命令語中のイミーディエト・データが示すメモリを直接アドレスするアドレシングです。

## 【オペランド形式】

| 表現形式   | 記 述 方 法                  |
|--------|--------------------------|
| addr16 | レーベルまたは16ビット・イミーディエト・データ |

## 【記 述 例】

MOV A, !0FE00H; !addr16をFE00Hとする場合



## 【図解】



## 3.4.4 ショート・ダイレクト・アドレシング

#### 【機 能】

命令語中の8ビット・データで、固定空間の操作対象メモリを直接アドレスするアドレシングです。

このアドレシングが適用される固定空間とは、FE20H-FF1FHの256バイト空間です。FE20H-FEFFHには内部RAMが、FF00H-FF1FHには特殊機能レジスタ(SFR)がマッピングされています。

ショート・ダイレクト・アドレシングが適用されるSFR領域(FF00H-FF1FH)は、全SFR領域の一部分です。この領域には、プログラム上でひんぱんにアクセスされるポートや、タイマ/イベント・カウンタのコンペア・レジスタ、キャプチャ・レジスタがマッピングされており、短いバイト数、短いクロック数でこれらのSFRを操作できます。

実効アドレスのビット 8 は、8 ビット・イミーディエト・データが20H-FFHの場合は 0 になり、00H-1FH の場合は 1 になります。 【図解】を参照してください。

#### 【オペランド形式】

| 表現形式   | 記 述 方 法                                    |  |
|--------|--------------------------------------------|--|
| saddr  | レーベルまたはFE20H-FF1FHを示すイミーディエト・データ           |  |
| saddrp | レーベルまたはFE20H-FF1FHを示すイミーディエト・データ(偶数アドレスのみ) |  |

#### 【記述例】

MOV 0FE30H, A; saddr (FE30H) にAレジスタの値を転送する場合



#### 【図 解】



8 ビット・イミーディエト・データが20H-FFHのとき、 $\alpha$  = 0 8 ビット・イミーディエト・データが00H-1FHのとき、 $\alpha$  = 1

## 3.4.5 特殊機能レジスタ(SFR)アドレシング

#### 【機 能】

命令語中の8ビット・イミーディエト・データでメモリ・マッピングされている特殊機能レジスタ(SFR)をアドレスするアドレシングです。

このアドレシングが適用されるのはFF00H-FFCFH, FFE0H-FFFFHの240バイト空間です。ただし、FF00H-FF1FHにマッピングされているSFRは、ショート・ダイレクト・アドレシングでもアクセスできます。

## 【オペランド形式】

| 表現形式 | 記 述 方 法                       |
|------|-------------------------------|
| sfr  | 特殊機能レジスタ名                     |
| sfrp | 16ビット操作可能な特殊機能レジスタ名(偶数アドレスのみ) |

#### 【記 述 例】

MOV PM0, A; sfrにPM0 (FF20H) を選択する場合



## 【図 解】



## 3.4.6 レジスタ・インダイレクト・アドレシング

#### 【機 能】

オペランドとして指定されるレジスタ・ペアの内容でメモリをアドレスするアドレシングです。アクセスされるレジスタ・ペアは、レジスタ・バンク選択フラグ(RBSO, RBS1)および、命令コード中のレジスタ・ペア指定コードにより指定されます。すべてのメモリ空間に対してアドレシングできます。

## 【オペランド形式】

| 表現形式 | 記述方法        |
|------|-------------|
| _    | [DE] , [HL] |

#### 【記 述 例】

MOV A, [DE];レジスタ・ペアに [DE] を選択する場合

## 【図解】



## 3.4.7 ベースト・アドレシング

#### 【機 能】

HLレジスタ・ペアをベース・レジスタとし、この内容に8ビットのイミーディエト・データを加算した結果でメモリをアドレスするアドレシングです。アクセスされるHLレジスタ・ペアは、レジスタ・バンク選択フラグ(RBS0, RBS1)で指定されるレジスタ・バンク中のものです。加算は、オフセット・データを正の数として16ビットに拡張して行います。16ビット目からの桁上がりは無視します。すべてのメモリ空間に対してアドレシングできます。

## 【オペランド形式】

| 表現形式 |           | 記 | 述 | 方 | 法 |
|------|-----------|---|---|---|---|
| _    | [HL+byte] |   |   |   |   |

## 【記 述 例】

MOV A, [HL+10H] ; byteを10Hとする場合



## 【図 解】



## 3.4.8 ベースト・インデクスト・アドレシング

#### 【機 能】

HLレジスタ・ペアをベース・レジスタとし、この内容に命令語中で指定されるBレジスタまたはCレジスタの内容を加算した結果でメモリをアドレスするアドレシングです。アクセスされるHL, B, Cレジスタは、レジスタ・バンク選択フラグ(RBS0, RBS1)で指定されるレジスタ・バンク中のレジスタです。加算は、BレジスタまたはCレジスタの内容を正の数として16ビットに拡張して行います。16ビット目からの桁上がりは無視します。すべてのメモリ空間に対してアドレシングできます。

## 【オペランド形式】

| 表現形式 | 記 述 方 法         |
|------|-----------------|
| _    | [HL+B] , [HL+C] |

## 【記 述 例】

MOV A, [HL+B] (Bレジスタを選択) の場合



## 【図 解】



## 3.4.9 スタック・アドレシング

## 【機 能】

スタック・ポインタ(SP)の内容により、スタック領域を間接的にアドレスするアドレシングです。 PUSH, POP, サブルーチン・コール、リターン命令の実行時および割り込み要求発生によるレジスタの退 避/復帰時に自動的に用いられます。

スタック・アドレシングは、内部高速RAM領域のみアクセスできます。

## 【記 述 例】

PUSH DE(DEレジスタをセーブ)の場合

## 【図解】



# 第4章 ポート機能

## 4.1 ポートの機能

 $\mu$ PD780024AS, 780034ASサブシリーズは、 4本の入力ポートと35本の入出力ポートを内蔵しています。図 4ー1 にポートの構成を示します。いずれのポートも1 ビット操作、8 ビット操作が可能で、きわめて多様に制御できます。また、ポートとしての機能のほかに、内蔵ハードウエアの入出力端子としての機能などを持っています。

P50 P00 P03 P10 P57 P13 P70 P20 ポート2 P75 P25 P34 P36 P40 ポート4 P47

図 4 - 1 ポートの種類

表 4-1 ポートの機能

| 端子名称    | 機能                               | 兼用端子        |
|---------|----------------------------------|-------------|
| P00     | ポート0。                            | INTP0       |
| P01     |                                  | INTP1       |
| P02     | 1 ビット単位で入力/出力の指定可能。              | INTP2       |
| P03     |                                  | INTP3/ADTRG |
| P10-P13 | ポート1。                            | ANI0-ANI3   |
|         | 4 ビット入力専用ポート。                    |             |
| P20     | ポート2。                            | SI30        |
| P21     | 6 ビット入出力ポート。                     | SO30        |
| P22     | 1 ビット単位で入力/出力の指定可能。              | SCK30       |
| P23     |                                  | RxD0        |
| P24     |                                  | TxD0        |
| P25     |                                  | ASCK0       |
| P34     | ポート3。                            | SI31        |
| P35     | 3 ビット入出力ポート。                     | SO31        |
| P36     | 1 ビット単位で入力/出力の指定可能。              | SCK31       |
|         | ソフトウエアの設定により、内蔵プルアップ抵抗を使用可能。     |             |
| P40-P47 | ポート4。                            | _           |
|         | 8ビット入出力ポート。                      |             |
|         | 1 ビット単位で入力/出力の指定可能。              |             |
|         | ソフトウエアの設定により,内蔵プルアップ抵抗を使用可能。     |             |
|         | 立ち下がりエッジの検出により、割り込み要求フラグ(KRIF)を1 |             |
|         | にセット。                            |             |
| P50-P57 | ポート5。                            | _           |
|         | 8ビット入出力ポート。                      |             |
|         | LEDを直接駆動可能。                      |             |
|         | 1 ビット単位で入力/出力の指定可能。              |             |
|         | ソフトウエアの設定により,内蔵プルアップ抵抗を使用可能。     |             |
| P70     | ポート7。                            | TI00/TO0    |
| P71     | 6 ビット入出力ポート。                     | TI01        |
| P72     | 1 ビット単位で入力/出力の指定可能。              | TI50/TO50   |
| P73     | ソフトウエアの設定により,内蔵プルアップ抵抗を使用可能。     | TI51/TO51   |
| P74     |                                  | PCL         |
| P75     |                                  | BUZ         |

## 4.2 ポートの構成

ポートは、次のハードウエアで構成しています。

表 4 - 2 ポートの構成

| 項目      | 構 成                                   |  |  |  |
|---------|---------------------------------------|--|--|--|
| 制御レジスタ  | ポート・モード・レジスタ $(PMm: m = 0, 2-5, 7)$   |  |  |  |
|         | プルアップ抵抗オプション・レジスタ (PUm:m = 0, 2-5, 7) |  |  |  |
| ポート     | 合計:39本(入力:4本,入出力:35本)                 |  |  |  |
| プルアップ抵抗 | 合計:39本(ソフトウエア制御)                      |  |  |  |

## 4.2.1 ポート0

出力ラッチ付き 4 ビット入出力ポートです。P00-P03端子は、ポート・モード・レジスタ 0 (PM0) により、1 ビット単位で入力モード/出力モードの指定ができます。P00-P03端子は、プルアップ抵抗オプション・レジスタ 0 (PU0) により、1 ビット単位で内蔵プルアップ抵抗を使用できます。

また、兼用機能として外部割り込み要求入力、A/Dコンバータの外部トリガ入力があります。

RESET入力により、入力モードになります。

図4-2 にポート0 のブロック図を示します。

- 注意 1. ポート 0 は外部割り込み要求入力と兼用になっているため、外部割り込み立ち上がりエッジ許可レジスタ (EGP) と外部割り込み立ち下がりエッジ許可レジスタ (EGN) で割り込み禁止に設定していないときに、ポート機能の出力モードを指定し出力レベルを変化させると、割り込み要求フラグがセットされます。したがって、出力モードを使用するとき、割り込みマスク・フラグに 1 を設定してください。
  - 2. 外部割り込み要求機能からポート機能に切り替える場合に、エッジ検出を行う可能性があるため、外部割り込み立ち上がりエッジ許可レジスタ(EGP)のビットn(EGPn)と外部割り込み立ち下がりエッジ許可レジスタ(EGN)のビットn(EGNn)に0を設定してから、ポート・モードに設定してください。
  - 3. P03/INTP3/ADTRGをA/Dコンバータの外部トリガ入力として使用する場合、A/Dコンバータ・モード・レジスタ 0 (ADM0)のビット 1 、2 (EGA00、EGA01)にて有効エッジの指示をし、割り込みマスク・フラグ(PMK3)に 1 を設定してください。

備考 n = 0-3

図 4 - 2 P00-P03のブロック図



RD :ポート0のリード信号

WR :ポート0のライト信号

## 4.2.2 ポート1

4ビット入力専用ポートです。

また、兼用機能としてA/Dコンバータのアナログ入力があります。

図4-3 P10-P13のブロック図



RD:ポート1のリード信号

注意 ポート1を入力ポートとして使用する場合,8ビット・メモリ操作命令で入力値を読み出すことができます。しかし、この場合上位4ビット(P17-P14)は不定となるので、上位4ビットの値は使用しないでください。またこの上位4ビットを1ビット・メモリ操作命令で読み出さないでください。

## 4.2.3 ポート2

出力ラッチ付き6ビット入出力ポートです。P20-P25端子は、ポート・モード・レジスタ2 (PM2) により、1ビット単位で入力モード/出力モードの指定ができます。P20-P25端子は、プルアップ抵抗オプション・レジスタ2 (PU2) により、1ビット単位で内蔵プルアップ抵抗を使用できます。

図4-4から図4-6にポート2のブロック図を示します。

図 4 - 4 P20, P23, P25のブロック図



PU :プルアップ抵抗オプション・レジスタ

PM :ポート・モード・レジスタ

RD :ポート2のリード信号

WR :ポート2のライト信号

図 4 - 5 P21, P24のブロック図



PM :ポート・モード・レジスタ

RD :ポート2のリード信号

WR :ポート2のライト信号

図 4 - 6 P22のブロック図



PM :ポート・モード・レジスタ

RD :ポート2のリード信号

WR :ポート2のライト信号

## 4.2.4 ポート3

出力ラッチ付き3ビット入出力ポートです。P34-P36端子は、ポート・モード・レジスタ3 (PM3) により、1ビット単位で入力モード/出力モードの指定ができます。P34-P36端子は、プルアップ抵抗オプション・レジスタ3 (PU3) により、1ビット単位で内蔵プルアップ抵抗を使用できます。

また、兼用機能としてシリアル・インタフェースのデータ入出力,クロック入出力機能があります。 RESET入力により、入力モードになります。

図4-7から図4-9にポート3のブロック図を示します。

- 注意 1. ポート 3 を 8 ビット・メモリ操作命令で読み出した場合,下位 4 ビット (P33-P30) は不定となるので,下位 4 ビットの値を使用しないでください。ポート 3 に 8 ビット・メモリ操作命令で書き込む場合,下位 4 ビットに任意の値を書き込むことができます。またこの下位 4 ビットへの 1 ビット・メモリ操作命令は禁止です。
  - 2. ポート・モード・レジスタ 3 (PM3) の下位 4 ビット (PM33-PM30) には必ず 1 を設定してください。



図4-7 P34のブロック図

PU :プルアップ抵抗オプション・レジスタ

PM : ポート・モード・レジスタ RD : ポート 3 のリード信号 WR : ポート 3 のライト信号

図4-8 P35のブロック図



RD :ポート3のリード信号

WR :ポート3のライト信号

図 4 - 9 P36のブロック図



PM :ポート・モード・レジスタ

RD :ポート3のリード信号

WR :ポート3のライト信号

## 4.2.5 ポート4

出力ラッチ付き8ビット入出力ポートです。P40-P47端子は、ポート・モード・レジスタ4 (PM4) により、1ビット単位で入力モード/出力モードの指定ができます。P40-P47端子は、プルアップ抵抗オプション・レジスタ4 (PU4) により、1ビット単位で内蔵プルアップ抵抗を使用できます。

立ち下がりエッジの検出により、割り込み要求フラグ(KRIF)を1にセットできます。

RESET入力により、入力モードになります。

図4-10にポート4のブロック図、図4-11に立ち下がりエッジ検出回路のブロック図を示します。

注意 立ち下がりエッジ検出割り込み (INTKR) を使用する場合,メモリ拡張モード・レジスタ (MEM) を 必ず01Hに設定してください。



図 4-10 P40-P47のブロック図

PU :プルアップ抵抗オプション・レジスタ

PM : ポート・モード・レジスタ RD : ポート 4 のリード信号 WR : ポート 4 のライト信号



図4-11 立ち下がりエッジ検出回路のブロック図

## 4.2.6 ポート5

出力ラッチ付き8ビット入出力ポートです。P50-P57端子は、ポート・モード・レジスタ5 (PM5) により、1ビット単位で入力モード/出力モードの指定ができます。P50-P57端子は、プルアップ抵抗オプション・レジスタ5 (PU5) により、1ビット単位で内蔵プルアップ抵抗を使用できます。

ポート5はLEDを直接駆動可能です。

RESET入力により、入力モードになります。

図4-12にポート5のブロック図を示します。

図 4-12 P50-P57のブロック図



PU :プルアップ抵抗オプション・レジスタ

PM :ポート・モード・レジスタ

RD :ポート5のリード信号

WR :ポート5のライト信号

## 4.2.7 ポート7

出力ラッチ付き 6 ビット入出力ポートです。ポート・モード・レジスタ 7 (PM7) により、1 ビット単位で入力モード/出力モードの指定ができます。P70-P75端子は、プルアップ抵抗オプション・レジスタ 7 (PU7) により、1 ビット単位で内蔵プルアップ抵抗を使用できます。

また、兼用機能としてタイマの入出力、クロック出力、ブザー出力があります。

RESET入力により、入力モードになります。

図4-13から図4-15にポート7のブロック図を示します。

図 4 -13 P70, P72, P73のブロック図



PU :プルアップ抵抗オプション・レジスタ

RD :ポート7のリード信号

WR :ポート7のライト信号

図4-14 P71のブロック図



PM :ポート・モード・レジスタ

RD :ポート7のリード信号

WR :ポート7のライト信号

図 4-15 P74, P75のブロック図



RD :ポート7のリード信号

WR :ポート7のライト信号

## 4.3 ポート機能を制御するレジスタ

ポートは、次の2種類のレジスタで制御します。

- ・ポート・モード・レジスタ (PM0, PM2-PM5, PM7)
- ・プルアップ抵抗オプション・レジスタ(PU0, PU2-PU5, PU7)
- (1) ポート・モード・レジスタ (PM0, PM2-PM5, PM7)

ポートの入力/出力を1ビット単位で指定するレジスタです。

PM0, PM2-PM5, PM7は、それぞれ 1 ビット・メモリ操作命令または 8 ビット・メモリ操作命令で設定します。

RESET入力により、FFHになります。

ポート端子を兼用機能の端子として使用する場合、ポート・モード・レジスタ、出力ラッチを表4-3のように設定してください。

注意 1. P10-P17端子は,入力専用端子です。

2. ポート 0 は、外部割り込み要求入力と兼用になっているため、外部割り込み立ち上がりエッジ 許可レジスタ(EGP)と外部割り込み立ち下がりエッジ許可レジスタ(EGN)で割り込み禁止 に設定していないときに、ポート機能の出力モードを指定し、出力レベルを変化させると、割り 込み要求フラグがセットされてしまいます。したがって、出力モードを使用するときは、あらか

じめ割り込みマスク・フラグに1を設定してください。

3. ポートに兼用端子がある場合、兼用出力機能として使用するときは、対応する出力ラッチ (P0, P2-7) に 0 を設定してください。

### 図 4 -16 ポート・モード・レジスタ (PM0, PM2-PM5, PM7) のフォーマット

| アドレス | : FF20H | リセット時:FFH R/W |                  |       |                |                |                     |                |
|------|---------|---------------|------------------|-------|----------------|----------------|---------------------|----------------|
| 略号   | 7       | 6             | 5                | 4     | 3              | 2              | 1                   | 0              |
| PM0  | 1       | 1             | 1                | 1     | PM03           | PM02           | PM01                | PM00           |
| アドレス | : FF22H | リセッ           | ト時:FF            | H R/V | V              |                |                     |                |
| 略号   | 7       | 6             | 5                | 4     | 3              | 2              | 1                   | 0              |
| PM2  | 1       | 1             | PM25             | PM24  | PM23           | PM22           | PM21                | PM20           |
| アドレス | : FF23H | リセッ           | 卜時:FF            | H R/V | V              |                |                     |                |
| 略号   | 7       | 6             | 5                | 4     | 3              | 2              | 1                   | 0              |
| РМ3  | 1       | PM36          | PM35             | PM34  | 1 <sup>注</sup> | 1 <sup>注</sup> | 1 <sup>注</sup>      | 1 <sup>注</sup> |
| アドレス | : FF24H | リセッ           | 卜時:FF            | H R/V | V              |                |                     |                |
| 略号   | 7       | 6             | 5                | 4     | 3              | 2              | 1                   | 0              |
| PM4  | PM47    | PM46          | PM45             | PM44  | PM43           | PM42           | PM41                | PM40           |
| アドレス | : FF25H | リセッ           | 卜時:FF            | H R/V | V              |                |                     |                |
| 略号   | 7       | 6             | 5                | 4     | 3              | 2              | 1                   | 0              |
| PM5  | PM57    | PM56          | PM55             | PM54  | PM53           | PM52           | PM51                | PM50           |
| アドレス | : FF27H | リセッ           | 卜時:FF            | H R/V | V              |                |                     |                |
| 略号   | 7       | 6             | 5                | 4     | 3              | 2              | 1                   | 0              |
| PM7  | 1       | 1             | PM75             | PM74  | PM73           | PM72           | PM71                | PM70           |
|      |         |               |                  |       |                |                |                     |                |
|      | PMmn    | Pmn           | 端子の入出            | 力モード  | の選択(           | m = 0, 2-5     | 5, 7 <b>;</b> n = 0 | )-7)           |
|      | 0       | 出力モー          | 出力モード(出力バッファ・オン) |       |                |                |                     |                |

入力モード(出力バッファ・オフ)

注 PM3の下位 4 ビット (PM33-PM30) は 1 に固定されていないので、8 ビット・メモリ操作命令で値を設定する場合、下位の 4 ビットには必ず 1 を設定してください。

表 4-3 兼用機能使用時のポート・モード・レジスタ、出力ラッチの設定

| 端子名称    | 兼用          | 機能  | PM××   | PXX |
|---------|-------------|-----|--------|-----|
|         | 名 称         | 入出力 | -      |     |
| P00-P02 | INTP0-INTP2 | 入力  | 1      | ×   |
| P03     | INTP3       | 入力  | 1      | ×   |
|         | ADTRG       | 入力  | 1      | ×   |
| P10-P13 | ANI0-ANI3   | 入力  | 1 (固定) | ×   |
| P20     | SI30        | 入力  | 1      | ×   |
| P21     | SO30        | 出力  | 0      | 0   |
| P22     | SCK30       | 入力  | 1      | ×   |
|         |             | 出力  | 0      | 0   |
| P23     | RxD0        | 入力  | 1      | ×   |
| P24     | TxD0        | 出力  | 0      | 0   |
| P25     | ASCK0       | 入力  | 1      | ×   |
| P34     | SI31        | 入力  | 1      | ×   |
| P35     | SO31        | 出力  | 0      | 0   |
| P36     | SCK31       | 入力  | 1      | ×   |
|         |             | 出力  | 0      | 0   |
| P70     | T100        | 入力  | 1      | ×   |
|         | TO0         | 出力  | 0      | 0   |
| P71     | TI01        | 入力  | 1      | ×   |
| P72     | TI50        | 入力  | 1      | ×   |
|         | TO50        | 出力  | 0      | 0   |
| P73     | TI51        | 入力  | 1      | ×   |
|         | TO51        | 出力  | 0      | 0   |
| P74     | PCL         | 出力  | 0      | 0   |
| P75     | BUZ         | 出力  | 0      | 0   |

備考 × :don't care

PM××:ポート・モード・レジスタ

P×× :ポートの出力ラッチ

(2) プルアップ抵抗オプション・レジスタ (PU0, PU2-PU5, PU7)

各ポートの内蔵プルアップ抵抗を使用するか、使用しないかを設定するレジスタです。PU0, PU2-PU5, PU7を設定することにより、PU0, PU2-PU5, PU7内のビットに対応するポート端子の内蔵プルアップ抵抗を使用できます。

PU0, PU2-PU5, PU7は、それぞれ 1 ビット・メモリ操作命令または 8 ビット・メモリ操作命令で設定します。

RESET入力により、00Hになります。

- 注意 1. P10-P13端子は、プルアップ抵抗を内蔵していません。
  - 2. PUmに 1 を設定すると,入力/出力モードにかかわらず,内蔵プルアップ抵抗が接続されます。 よって,出力モードで使用する場合は対応するPUmのビットを 0 にしてください(m=0,2-5,7)。

図 4-17 プルアップ抵抗オプション・レジスタ (PU0, PU2-PU5, PU7) のフォーマット

| アドレス | : FF30H | リセット時:00H R/W |        |       |      |      |      |      |
|------|---------|---------------|--------|-------|------|------|------|------|
| 略号   | 7       | 6             | 5      | 4     | 3    | 2    | 1    | 0    |
| PU0  | 0       | 0             | 0      | 0     | PU03 | PU02 | PU01 | PU00 |
| アドレス | : FF32H | リセッ           | ,ト時:00 | H R/V | V    |      |      |      |
| 略号   | 7       | 6             | 5      | 4     | 3    | 2    | 1    | 0    |
| PU2  | 0       | 0             | PU25   | PU24  | PU23 | PU22 | PU21 | PU20 |
| アドレス | : FF33H | リセッ           | √ト時:00 | H R/V | V    |      |      |      |
| 略号   | 7       | 6             | 5      | 4     | 3    | 2    | 1    | 0    |
| PU3  | 0       | PU36          | PU35   | PU34  | 0    | 0    | 0    | 0    |
| アドレス | : FF34H | リセッ           | ,ト時:00 | H R/V | V    |      |      |      |
| 略号   | 7       | 6             | 5      | 4     | 3    | 2    | 1    | 0    |
| PU4  | PU47    | PU46          | PU45   | PU44  | PU43 | PU42 | PU41 | PU40 |
| アドレス | : FF35H | リセッ           | ,ト時:00 | H R/V | V    |      |      |      |
| 略号   | 7       | 6             | 5      | 4     | 3    | 2    | 1    | 0    |
| PU5  | PU57    | PU56          | PU55   | PU54  | PU53 | PU52 | PU51 | PU50 |
| アドレス | : FF37H | リセット時:00H R/W |        |       |      |      |      |      |
| 略号   | 7       | 6             | 5      | 4     | 3    | 2    | 1    | 0    |
| PU7  | 0       | 0             | PU75   | PU74  | PU73 | PU72 | PU71 | PU70 |

| PUmn | Pmn端子の内蔵プルアップ抵抗の選択(m = 0, 2-5, 7;n = 0-7) |
|------|-------------------------------------------|
| 0    | 内蔵プルアップ抵抗を使用しない                           |
| 1    | 内蔵プルアップ抵抗を使用する                            |

## 4.4 ポート機能の動作

ポートの動作は、次に示すように入出力モードの設定によって異なります。

注意 1 ビット・メモリ操作命令の場合,操作対象は1 ビットですが,ポートを8 ビット単位でアクセスします。したがって,入力/出力が混在しているポートでは,操作対象のビット以外でも入力に指定されている端子の出力ラッチの内容が不定になります。

### 4.4.1 入出力ポートへの書き込み

#### (1) 出力モードの場合

転送命令により、出力ラッチに値を書き込めます。また、出力ラッチの内容が端子より出力されます。 一度出力ラッチに書き込まれたデータは、もう一度出力ラッチにデータを書き込むまで保持されます。 リセットによって、出力ラッチのデータはクリアされます。

#### (2) 入力モードの場合

転送命令により、出力ラッチに値を書き込めます。しかし、出力バッファがオフしていますので、端子の 状態は変化しません。

一度出力ラッチに書き込まれたデータは、もう一度出力ラッチにデータを書き込むまで保持されます。

## 4.4.2 入出力ポートからの読み出し

#### (1) 出力モードの場合

転送命令により、出力ラッチの内容が読み出せます。出力ラッチの内容は変化しません。

#### (2)入力モードの場合

転送命令により、端子の状態が読み出せます。出力ラッチの内容は変化しません。

### 4.4.3 入出力ポートでの演算

#### (1) 出力モードの場合

出力ラッチの内容と演算を行い、結果を出力ラッチに書き込みます。また、出力ラッチの内容が端子より 出力されます。

一度出力ラッチに書き込まれたデータは、もう一度出力ラッチにデータを書き込むまで保持されます。 リセットによって、出力ラッチのデータはクリアされます。

### (2)入力モードの場合

出力ラッチの内容が不定になります。しかし、出力バッファがオフしていますので、端子の状態は変化しません。

## 第5章 クロック発生回路

## 5.1 クロック発生回路の機能

クロック発生回路は、CPUおよび周辺ハードウエアに供給するクロックを発生する回路です。 システム・クロック発振回路には、次の2種類があります。

#### (1)メイン・システム・クロック発振回路

1~12 MHzの周波数のクロックを発振します。STOP命令の実行およびプロセッサ・クロック・コントロール・レジスタ(PCC)の設定により、発振を停止できます。

#### (2) サブシステム・クロック発振回路

32.768 kHzの周波数のクロックを発振します。発振の停止はできません。サブシステム・クロック発振回路を使用しないとき、プロセッサ・クロック・コントロール・レジスタ(PCC)により、内蔵フィードバック抵抗を使用しない設定ができます。これによって、STOPモード時の消費電力を低減できます。

## 5.2 クロック発生回路の構成

クロック発生回路は、次のハードウエアで構成しています。

 項目
 構成

 制御レジスタ
 プロセッサ・クロック・コントロール・レジスタ (PCC)

 発振安定時間選択レジスタ (OSTS)

 発振回路
 メイン・システム・クロック発振回路

 サブシステム・クロック発振回路

 制御回路
 プリスケーラ

 スタンバイ制御回路

 ウェイト制御回路

表5-1 クロック発生回路の構成

図 5 - 1 クロック発生回路のブロック図



## 5.3 クロック発生回路を制御するレジスタ

クロック発生回路は、次の2種類のレジスタで制御します。

- ・プロセッサ・クロック・コントロール・レジスタ (PCC)
- ・発振安定時間選択レジスタ(OSTS)
- (1) プロセッサ・クロック・コントロール・レジスタ (PCC)

CPUクロックの選択、分周比、メイン・システム・クロック発振回路の動作/停止、サブシステム・クロック発振回路の内蔵フィードバック抵抗注を使用するか、しないかを設定するレジスタです。

PCCは、1ビット・メモリ操作命令または8ビット・メモリ操作命令で設定します。

RESET入力により、04Hになります。

**注** フィードバック抵抗は発振波形のバイアス点を電源電圧の中間付近に調整するために必要なものです。

サブシステム・クロックを使用しない場合のみ、PCCのビット 6 (FRC) に 1 を設定することで STOPモード時の消費電力をさらに抑えることが可能です(図 5-7 サブシステム・クロックの フィードバック抵抗を参照)。

#### 図5-2 プロセッサ・クロック・コントロール・レジスタ(PCC)のフォーマット

アドレス:FFFBH リセット時:04H R/W<sup>注1</sup>

| 略号  | 7   | 6   | 5   | 4   | 3 | 2    | 1    | 0    |
|-----|-----|-----|-----|-----|---|------|------|------|
| PCC | MCC | FRC | CLS | CSS | 0 | PCC2 | PCC1 | PCC0 |

| MCC | メイン・システム・クロックの発振の制御 <sup>注2</sup> |
|-----|-----------------------------------|
| 0   | 発振可能                              |
| 1   | 発振停止                              |

| FRC | サブシステム・クロックのフィードバック抵抗の選択         |
|-----|----------------------------------|
| 0   | 内蔵フィードバック抵抗を使用する                 |
| 1   | 内蔵フィードバック抵抗を使用しない <sup>注 3</sup> |

| CLS | CPUクロックのステータス |
|-----|---------------|
| 0   | メイン・システム・クロック |
| 1   | サブシステム・クロック   |

| CSS  | PCC2 | PCC1 | PCC0 | CPUクロック(fcPU)の選択  |
|------|------|------|------|-------------------|
| 0    | 0    | 0    | 0    | fx                |
|      | 0    | 0    | 1    | fx/2              |
|      | 0    | 1    | 0    | fx/2 <sup>2</sup> |
|      | 0    | 1    | 1    | fx/2 <sup>3</sup> |
|      | 1    | 0    | 0    | fx/2 <sup>4</sup> |
| 1    | 0    | 0    | 0    | fхт/2             |
|      | 0    | 0    | 1    |                   |
|      | 0    | 1    | 0    |                   |
|      | 0    | 1    | 1    |                   |
|      | 1    | 0    | 0    |                   |
| 上記以外 |      |      |      | 設定禁止              |

- 注1. ビット5は、Read Onlyです。
  - 2. CPUがサブシステム・クロックで動作しているとき、メイン・システム・クロックの発振の停止はMCC を使用してください。STOP命令は使用しないでください。
  - 3. サブシステム・クロックを使用しない場合のみ1に設定可能です。
- 注意1. ビット3には、必ず0を設定してください。
  - 2. 外部クロックを入力しているとき、MCCをセットしないでください。これはX2端子がVpD1にプルアップされるためです。
- 備考1. fx :メイン・システム・クロック発振周波数
  - 2. fxT:サブシステム・クロック発振周波数

 $\mu$ PD780024AS, 780034ASサブシリーズの一番速い命令は、CPUクロック 2 クロックで実行されます。したがって、CPUクロック(fcpu)と最小命令実行時間の関係は、表 5 - 2 のようになります。

表5-2 CPUクロックと最小命令実行時間の関係

| CPUクロック(fcpu)     | 最小命令実行時間:2/fcpu |
|-------------------|-----------------|
| fx                | 0.166 μs        |
| fx/2              | 0.333 μs        |
| fx/2 <sup>2</sup> | 0.666 μs        |
| fx/2 <sup>3</sup> | 1.33 μs         |
| fx/2 <sup>4</sup> | 2.66 μs         |
| fхт/2             | 122 μs          |

fx = 12 MHz, fxT = 32.768 kHz

fx :メイン・システム・クロック発振周波数

fxt : サブシステム・クロック発振周波数

#### (2)発振安定時間選択レジスタ (OSTS)

リセット時またはSTOPモードを解除してから発振が安定するまでの発振安定時間を選択するレジスタです。

OSTSは、8ビット・メモリ操作命令で設定します。

RESET 入力により、04Hになります。したがって、 $\overline{RESET}$  入力でSTOPモードを解除するとき、解除までの時間は $2^{17}$ /fxです。

図5-3 発振安定時間選択レジスタ (OSTS) のフォーマット

アドレス:FFFAH リセット時:04H R/W

| 略号   | 7 | 6 | 5 | 4 | 3 | 2     | 1     | 0     |
|------|---|---|---|---|---|-------|-------|-------|
| OSTS | 0 | 0 | 0 | 0 | 0 | OSTS2 | OSTS1 | OSTS0 |

| OSTS2 | OSTS1 | OSTS0 | 発振安定時間の選択                     |
|-------|-------|-------|-------------------------------|
| 0     | 0     | 0     | 2 <sup>12</sup> /fx (341 μs)  |
| 0     | 0     | 1     | 2 <sup>14</sup> /fx (1.36 ms) |
| 0     | 1     | 0     | 2 <sup>15</sup> /fx (2.73 ms) |
| 0     | 1     | 1     | 2 <sup>16</sup> /fx (5.46 ms) |
| 1     | 0     | 0     | 2 <sup>17</sup> /fx (10.9 ms) |
| 上記以外  |       |       | 設定禁止                          |

注意 STOPモード解除時のウエイト時間には、STOPモード解除後にクロックが発振を開始するまでの時間(下図 a)は含みません。これは、RESET入力による場合も、割り込み要求発生による場合も同様です。



備考1. fx:メイン・システム・クロック発振周波数

2. ( ) 内は、fx = 12 MHz動作時。

## 5.4 システム・クロック発振回路

### 5.4.1 メイン・システム・クロック発振回路

メイン・システム・クロック発振回路はX1, X2端子に接続されたクリスタル振動子またはセラミック発振子(標準:12 MHz)によって発振します。

また、外部クロックを入力することもできます。その場合、X1端子にクロック信号を入力し、X2端子には、その反転した信号を入力してください。

図5-4にメイン・システム・クロック発振回路の外付け回路を示します。

図5-4 メイン・システム・クロック発振回路の外付け回路

(a) クリスタル, セラミック発振







注意 外部クロックを入力しているとき、STOP命令の実行およびMCC(プロセッサ・クロック・コントロール・レジスタ(PCC)のビット 7)に 1 を設定しないでください。これは、STOP命令およびMCCに1を設定すると、メイン・システム・クロックの動作が停止され、X2端子がVpp1にプルアップされるためです。

## 5.4.2 サブシステム・クロック発振回路

サブシステム・クロック発振回路はXT1, XT2端子に接続された水晶振動子(標準:32.768 kHz)によって発振します。

また、外部クロックを入力することもできます。その場合、XT1端子にクロック信号を入力し、XT2端子には、その反転した信号を入力してください。

図5-5にサブシステム・クロック発振回路の外付け回路を示します。

### 図5-5 サブシステム・クロック発振回路の外付け回路

### (a) 水晶発振

## (b)外部クロック





注意を次ページに示します。

- 注意1. メイン・システム・クロックおよびサブシステム・クロック発振回路を使用する場合は、配線容量 などの影響を避けるために、図5-4、5-5の破線の部分を次のように配線してください。
  - ・配線は極力短くする。
  - ・他の信号線と交差させない。また、変化する大電流が流れる線と接近させない。
  - ・発振回路のコンデンサの接地点は、常にVss1と同電位となるようにする。大電流が流れるグランド・パターンに接地しない。
  - ・発振回路から信号を取り出さない。

特に、サブシステム・クロック発振回路は、低消費電力にするために増幅度の低い回路になっていますのでご注意ください。

図5-6に発振子の接続の悪い例を示します。

図5-6 発振子の接続の悪い例(1/2)

#### (a)接続回路の配線が長い

#### (b) 信号線が交差している



**備考** サブシステム・クロックをご使用の場合は、X1, X2をXT1, XT2と読み替えてください。また、XT2側に直列に抵抗を挿入してください。

図5-6 発振子の接続の悪い例(2/2)

- (c)変化する大電流が信号線に 近接している
- (d)発振回路部のグランド・ライン上に電流が流れる (A点, B点, C点の電位が変動する)





(e) 信号を取り出している



- **備考** サブシステム・クロックをご使用の場合は、X1, X2をXT1, XT2と読み替えてください。また、XT2側に直列に抵抗を挿入してください。
- 注意 2. X2とXT1が平行に配線されている場合, X2のクロストーク・ノイズがXT1に相乗し誤動作を引き起こすことがあります。

これを避けるために、X2とXT1の配線を平行にしないとともに、X2, XT1の間にあるIC端子をVss1に 直接接続してください。

## 5.4.3 サブシステム・クロックを使用しない場合

低消費電力動作や時計動作等のためにサブシステム・クロックを使用する必要のない場合、XT1, XT2端子を次のように処置してください。

XT1: VDD0またはVDD1に直接接続してください

XT2:オープンにしてください

ただし、この状態では、メイン・システム・クロックの停止時に、サブシステム・クロック発振回路の内蔵フィードバック抵抗を介して若干のリーク電流を流してしまいます。これを抑えるには、プロセッサ・クロック・コントロール・レジスタ(PCC)のビット6(FRC)により上述の内蔵フィードバック抵抗を使用しない設定をしてください。このときも、XT1、XT2端子の処理は上記と同じです。

図5-7 サブシステム・クロックのフィードバック抵抗



備考 フィードバック抵抗は発振波形のバイアス点を電源電圧の中間付近に調整するために必要なものです。

## 5.5 クロック発生回路の動作

クロック発生回路は次に示す各種クロックを発生し、かつ、スタンバイ・モードなどのCPUの動作モードを制御します。

- ・メイン・システム・クロック fx
- ・サブシステム・クロック fxт
- ・CPUクロック fcpu
- ・周辺ハードウエアへのクロック

クロック発生回路の動作はプロセッサ・クロック・コントロール・レジスタ(PCC)により決定され、次のような機能、動作となります。

- (a)  $\overline{\text{RESET}}$ 信号発生によりメイン・システム・クロックの最低速モード(2.66  $\mu$ s:12 MHz動作時)が選択されます(PCC = 04H)。なお、 $\overline{\text{RESET}}$ 端子にロウ・レベルを入力している間、メイン・システム・クロックの発振は停止します。
- (b) メイン・システム・クロックを選択した状態でPCCの設定により 5 段階の最小命令実行時間 (0.166  $\mu$ s, 0.333  $\mu$ s, 0.666  $\mu$ s, 1.33  $\mu$ s, 2.66  $\mu$ s: 12 MHz動作時) を選択できます。
- (c) メイン・システム・クロックを選択した状態でSTOPモード、HALTモードの2つのスタンバイ・モードが使用できます。また、サブシステム・クロックを使用していないシステムの場合、PCCのビット6 (FRC)で内蔵フィードバック抵抗を使用しない設定をすることにより、STOPモード時の消費電流をさらに低減できます。
- (d) PCCにより、サブシステム・クロックを選択し、低消費電力で動作(122  $\mu$ s:32.768 kHz動作時)できます。
- (e) サブシステム・クロックを選択した状態で、PCCによりメイン・システム・クロックの発振を停止できます。また、HALTモードを使用できます。しかし、STOPモードは使用できません(サブシステム・クロックの発振を停止させることはできません)。
- (f) 周辺ハードウエアへのクロックはメイン・システム・クロックを分周して供給されますが、時計用タイマ、クロック出力機能にのみサブシステム・クロックも供給しています。このため、スタンバイ状態でも時計機能、クロック出力機能は、継続して使用できます。しかし、そのほかの周辺ハードウエアはメイン・システム・クロックによって動作していますので、メイン・システム・クロックを停止させたときは周辺ハードウエアも停止します(ただし、外部からの入力クロック動作は除く)。

### 5.5.1 メイン・システム・クロックの動作

メイン・システム・クロック動作時(プロセッサ・クロック・コントロール・レジスタ(PCC)のビット 5 (CLS) が 0 のとき)、PCCの設定により次のように動作します。

- (a) 電源電圧により動作保証命令実行速度が異なるため、PCCのビット0-2 (PCC0-PCC2) により最小命令実行時間を変更できます。
- (b) メイン・システム・クロックで動作しているとき、PCCのビット4(CSS)を1に設定し、サブシステム・クロック動作に切り替わったあと(CLS = 1)、PCCのビット7(MCC)を1に設定すると、メイン・システム・クロックの発振が停止します(図5-8(1)参照)
- (c) メイン・システム・クロックで動作しているとき、PCCのビット7(MCC)を1に設定してもメイン・システム・クロックの発振は停止しません。そのあとPCCのビット4(CSS)を1に設定し、サブシステム・クロック動作に切り替わったあと(CLS = 1)、メイン・システム・クロックの発振が停止します(図 5-8(2)参照)。

図5-8 メイン・システム・クロックの停止機能

(1)メイン・システム・クロック動作時にCSSをセットしたあと、MCCをセットしたときの動作



(2) メイン・システム・クロック動作時にMCCをセットしたあと、CSSをセットしたときの動作



## 5.5.2 サブシステム・クロックの動作

サブシステム・クロック動作時(プロセッサ・クロック・コントロール・レジスタ(PCC)のビット 5(CLS)が 1 のとき)、次のように動作します。

- (a) PCCのビット0-2 (PCC0-PCC2) に関係なく最小命令実行時間は一定(122 μs:32.768 kHz動作時)です。
- (b) ウォッチドッグ・タイマのカウントが停止します。

注意 サブシステム・クロック動作中はSTOP命令を実行しないでください。

## 5.6 システム・クロックとCPUクロックの設定の変更

### 5.6.1 システム・クロックとCPUクロックの切り替えに要する時間

システム・クロックとCPUクロックは、プロセッサ・クロック・コントロール・レジスタ(PCC)のビット0-2(PCC0-PCC2)とビット4(CSS)により切り替えることができます。

実際の切り替え動作は、PCCを書き換えた直後ではなく、PCCを変更したのち、数命令は切り替え前のクロックで動作します(表5-3参照)。

メイン・システム・クロックで動作しているのか、サブシステム・クロックで動作しているのかは、PCCのビット5 (CLS)で判定できます。

\*

表5-3 CPUクロックの切り替えに要する最大時間

| 切り  | 替え前  | 前の設定 | 定値   |       |      |      |       | 切り替え後の設定値 |      |      |       |      |      |       |      |     |      |      |      |     |      |            |           |     |     |        |      |
|-----|------|------|------|-------|------|------|-------|-----------|------|------|-------|------|------|-------|------|-----|------|------|------|-----|------|------------|-----------|-----|-----|--------|------|
| CSS | PCC2 | PCC1 | PCC0 | css   | PCC2 | PCC1 | PCC0  | css       | PCC2 | PCC1 | PCC0  | css  | PCC2 | PCC1  | PCC0 | css | PCC2 | PCC1 | PCC0 | css | PCC2 | PCC1       | PCC0      | css | PCC | 2 PCC1 | PCC0 |
|     |      |      |      | 0     | 0    | 0    | 0     | 0         | 0    | 0    | 1     | 0    | 0    | 1     | 0    | 0   | 0    | 1    | 1    | 0   | 1    | 0          | 0         | 1   | ×   | ×      | ×    |
| 0   | 0    | 0    | 0    |       |      |      |       | 8 命令      |      |      |       | 8 命令 |      |       | 8 命令 |     |      |      | 8 命令 |     |      |            | fx/fxт命令  |     |     |        |      |
|     | 0    | 0    | 1    | 4 命令  |      |      |       |           |      |      |       | 4 命令 |      |       | 4 命令 |     |      |      | 4 命令 |     |      |            | fx/2fxт命令 |     |     |        |      |
|     | 0    | 1    | 0    | 2 命令  |      |      | 2 命令  |           |      |      |       |      |      | 2 命令  |      |     |      | 2 命令 |      |     |      | fx/4fxт命令  |           |     |     |        |      |
|     | 0    | 1    | 1    | 1 命令  |      |      | 1 命令  |           |      |      |       | 1 命令 |      |       |      |     |      |      | 1 命令 |     |      |            | fx/8fxт命令 |     |     |        |      |
|     | 1    | 0    | 0    | 0.5命令 |      |      | 0.5命令 |           |      |      | 0.5命令 |      |      | 0.5命令 |      |     |      |      |      |     |      | fx/16fxт命令 |           |     |     |        |      |
| 1   | ×    | ×    | ×    |       | 1 台  | 命令   |       | 1 命令      |      |      |       | 1 命令 |      |       | 1 命令 |     |      | 1 命令 |      |     |      |            |           |     |     |        |      |

備考 1命令は、切り替え前のCPUクロックの最小命令実行時間となります。

注意 CPUクロックの分周の選択(PCC0-PCC2)とメイン・システム・クロックからサブシステム・クロックへの切り替え(CSSを $0 \rightarrow 1$ )を同時に設定しないでください。

ただし、CPUクロックの分周の選択(PCC0-PCC2)とサブシステム・クロックからメイン・システム・クロックへの切り替え(CSSを  $1 \rightarrow 0$ )は同時に設定可能です。

## 5.6.2 システム・クロックとCPUクロックの切り替え手順

システム・クロックとCPUクロックの切り替えについて説明します。

図5-9 システム・クロックとCPUクロックの切り替え



- ① 電源投入後、RESET端子をロウ・レベルにすることでCPUにリセットがかかります。その後、RESET端子をハイ・レベルにするとリセットが解除され、メイン・システム・クロックが発振開始します。このとき、自動的に発振安定時間( $2^{17}/fx$ )を確保します。
  - その後、CPUはメイン・システム・クロックの最低速(2.66  $\mu$  s:12 MHz動作時)で命令の実行を開始します。
- ② VDD電圧が最高速で動作できる電圧まで上昇するのに十分な時間経過後、プロセッサ・クロック・コントロール・レジスタ(PCC)を書き換えて最高速動作を行います。
- ③ VDD電圧が低下したことを割り込み要求信号などにより検出し、サブシステム・クロックに切り替えます (このとき、サブシステム・クロックが発振安定状態になっていなければなりません)。
- ④ VDD電圧が復帰したことを割り込み要求信号などにより検出し、PCCのビット7(MCC)に0を設定してメイン・システム・クロックを発振開始させ、発振が安定するのに必要な時間経過後、PCCを書き換えて最高速動作に戻します。
  - 注意 メイン・システム・クロックを停止させサブシステム・クロックで動作させている場合に、再度メイン・システム・クロックに切り替えるときには、プログラムで発振安定時間を確保したあとに切り替えてください。

# 第6章 16ビット・タイマ/イベント・カウンタ0

## 6.1 16ビット・タイマ/イベント・カウンタ 0 の機能

16ビット・タイマ/イベント・カウンタ0には、次のような機能があります。

### (1) インターバル・タイマ

あらかじめ設定した任意の時間間隔で割り込み要求を発生します。

・カウント数:2~65536カウント

#### (2) 外部イベント・カウンタ

外部から入力される信号の、ハイ/ロウ・レベル幅を持ったパルス数を測定できます。

・有効レベル・パルス幅:16/fx以上

#### (3)パルス幅測定

外部から入力される信号のパルス幅を測定できます。

・有効レベル・パルス幅:2/fx以上

#### (4)方形波出力

任意の周波数の方形波を出力できます。

・周期(2×2~65536×2)×カウント・クロックの周期

#### (5) PPG出力

任意の周期とパルス幅を持った矩形波を出力できます。

・2 <パルス幅<周期≦ (FFFF+1) H

## 6.2 16ビット・タイマ/イベント・カウンタ 0 の構成

16ビット・タイマ/イベント・カウンタ0は、次のハードウエアで構成されています。

プリスケーラ・モード・レジスタ0 (PRMO) ポート・モード・レジスタ 7 (PM7)

ポート7 (P7)

項目構成タイマ・カウンタ16ビット・タイマ・カウンタ 0 (TM0)レジスタ16ビット・タイマ・キャプチャ/コンペア・レジスタ00, 01 (CR00, CR01)タイマ入力TI00, TI01タイマ出力TO0制御レジスタ16ビット・タイマ・モード・コントロール・レジスタ0 (TMC0)<br/>キャプチャ/コンペア・コントロール・レジスタ0 (CRC0)<br/>16ビット・タイマ出力コントロール・レジスタ0 (TOC0)

表 6 - 1 16ビット・タイマ/イベント・カウンタ 0 の構成

図6-1にブロック図を示します。



図6-1 16ビット・タイマ/イベント・カウンタ0のブロック図

注 TIOO入力とTOO出力は同時に使用できません。

#### (1) 16ビット・タイマ・カウンタ 0 (TMO)

TMOは、カウント・パルスをカウントする16ビットのリード専用レジスタです。

カウント・クロックの立ち上がりに同期して、カウンタをインクリメントします。また、動作中にカウント値を読み出した場合、カウント・クロックの入力を一時停止し、その時点でのカウント値を読み出します。次の場合、カウント値は0000Hになります。

- ① RESET入力
- ② TMC03, TMC02をクリア
- ③ TI00有効エッジ入力でクリア&スタート・モード時のTI00有効エッジが入力されたとき
- ④ CR00の一致でクリア&スタート・モード時のTM0とCR00の一致

#### (2) 16ビット・タイマ・キャプチャ/コンペア・レジスタ00 (CR00)

CR00は、キャプチャ・レジスタとコンペア・レジスタの機能をあわせ持った16ビットのレジスタです。 キャプチャ/コンペア・コントロール・レジスタ 0 (CRC0) のビット 0 (CRC00) により、キャプチャ・レ ジスタとして使用するのか、コンペア・レジスタとして使用するのかを設定します。

#### ・CR00をコンペア・レジスタとして使用するとき

CR00に設定した値と16ビット・タイマ・カウンタ 0 (TM0) のカウント値を常に比較し、一致したときに割り込み要求(INTTM00)を発生します。TM0をインターバル・タイマ動作に設定したとき、インターバル時間を保持するレジスタとしても使用できます。

#### ・CR00をキャプチャ・レジスタとして使用するとき

キャプチャ・トリガとしてTI00端子、またはTI01端子の有効エッジが選択できます。TI00, TI01の有効エッジは、プリスケーラ・モード・レジスタ 0 (PRM0) で設定します(表 6-2 を参照)。

## 表 6-2 CR00のキャプチャ・トリガとTI00端子とTI01端子の有効エッジ

#### (1) キャプチャ・トリガとしてTI00端子の有効エッジを選択(CRC01 = 1, CRC00 = 1)

| CR00のキャプチャ・トリガ | TI00端子の有効エッジ     |      |      |
|----------------|------------------|------|------|
|                |                  | ES01 | ES00 |
| 立ち下がりエッジ       | 立ち上がりエッジ         | 0    | 1    |
| 立ち上がりエッジ       | 立ち下がりエッジ         | 0    | 0    |
| キャプチャ動作しない     | 立ち上がり、立ち下がりの両エッジ | 1    | 1    |

### (2) キャプチャ・トリガとしてTI01端子の有効エッジを選択(CRC01 = 0, CRC00 = 1)

| CR00のキャプチャ・トリガ   | TI01端子の有効エッジ     |      |      |
|------------------|------------------|------|------|
|                  |                  | ES11 | ES10 |
| 立ち下がりエッジ         | 立ち下がりエッジ         | 0    | 0    |
| 立ち上がりエッジ         | 立ち上がりエッジ         | 0    | 1    |
| 立ち上がり、立ち下がりの両エッジ | 立ち上がり、立ち下がりの両エッジ | 1    | 1    |

**備考1.** ES01, ES00 = 1, 0およびES11, ES10 = 1, 0は設定禁止です。

2. ES01, ES00 :プリスケーラ・モード・レジスタ 0 (PRM0) のビット5, 4

ES11, ES10 : プリスケーラ・モード・レジスタ 0 (PRM0) のビット7, 6

 $CRC01, CRC00: + r J + r / 1 \rightarrow r / 1$ 

CR00は、16ビット・メモリ操作命令で設定します。

RESET入力により、不定になります。

注意 1. TM0とCR00の一致でクリア & スタート・モードでは、CR00には0000H以外の値を設定してください。

フリー・ランニング・モードおよびTIOOの有効エッジのクリア・モードにおいて, CROOに 0000Hを設定した場合は, オーバフロー (FFFFH)後, 0000Hから0001Hになるときに, 割り込み要求 (INTTM00)を発生します。

- 2. CR00の変更値が16ビット・タイマ・カウンタ 0 (TM0) の値より小さいとき, TM0はカウントを継続しオーバフローして 0 から再カウントします。したがってCR00の変更後の値が変更前の値より小さいときは, CR00を変更後, タイマをリセットし, 再スタートさせる必要があります。
- 3. P70をTI00有効エッジの入力端子として使用するときは、タイマ出力(TO0)として使用できません。また、TO0として使用するときは、TI00有効エッジの入力端子として使用できません。
- (3) 16ビット・タイマ・キャプチャ/コンペア・レジスタ01 (CR01)

キャプチャ・レジスタとコンペア・レジスタの機能をあわせ持った16ビットのレジスタです。キャプチャ /コンペア・コントロール・レジスタ 0 (CRCO) のビット 2 (CRCO2) により、キャプチャ・レジスタと して使用するのか、コンペア・レジスタとして使用するのかを設定します。

・CR01をコンペア・レジスタとして使用するとき CR01に設定した値と16ビット・タイマ・カウンタ 0 (TM0) のカウント値を常に比較し、一致したと きに割り込み要求 (INTTM01) を発生します。

・CR01をキャプチャ・レジスタとして使用するとき

キャプチャ・トリガとしてTI00端子の有効エッジが選択できます。TI00の有効エッジは、プリスケーラ・モード・レジスタ 0 (PRM0) で設定します(表 6-3 を参照)。

| 表6-3 ( | CR01のキャプチャ・ | トリガとTI00端子の有効エッジ | (CRC02 = 1) |
|--------|-------------|------------------|-------------|
|--------|-------------|------------------|-------------|

| CR01のキャプチャ・トリガ   | TI00端子の有効エッジ     |      |      |
|------------------|------------------|------|------|
|                  |                  | ES01 | ES00 |
| 立ち下がりエッジ         | 立ち下がりエッジ         | 0    | 0    |
| 立ち上がりエッジ         | 立ち上がりエッジ         | 0    | 1    |
| 立ち上がり、立ち下がりの両エッジ | 立ち上がり、立ち下がりの両エッジ | 1    | 1    |

**備考1.** ES01, ES00 = 1, 0は設定禁止です。

 CR01は、16ビット・メモリ操作命令で設定します。

RESET入力により不定になります。

注意 TM0とCR00の一致でクリア&スタート・モードでは, CR01には0000H以外の値を設定してください。

フリー・ランニング・モードおよびTIOOの有効エッジのクリア・モードにおいて、CR01に0000Hを設定した場合は、オーバフロー(FFFFH)後、0000Hから0001Hになるときに、割り込み要求(INTTM01)を発生します。

## 6.3 16ビット・タイマ/イベント・カウンタ 0 を制御するレジスタ

16ビット・タイマ/イベント・カウンタ0を制御するレジスタには、次の6種類があります。

- ・16ビット・タイマ・モード・コントロール・レジスタ 0 (TMC0)
- ・キャプチャ/コンペア・コントロール・レジスタ 0 (CRC0)
- ・16ビット・タイマ出力コントロール・レジスタ 0 (TOC0)
- ・プリスケーラ・モード・レジスタ 0 (PRMO)
- ・ポート・モード・レジスタ7 (PM7)
- ・ポート7 (P7)
- (1) 16ビット・タイマ・モード・コントロール・レジスタ 0 (TMC0)

16ビット・タイマの動作モード、16ビット・タイマ・カウンタ 0 (TMO) のクリア・モード、出力タイミングの設定およびオーバフローを検出するレジスタです。

TMC0は、1ビット・メモリ操作命令または8ビット・メモリ操作命令で設定します。

RESET入力により00Hになります。

注意 16ビット・タイマ・カウンタ 0 (TMO) は, TMC02, TMC03に 0,0 (動作停止モード) 以外の値 を設定した時点で動作を開始します。動作を停止させるには, TMC02, TMC03に 0,0 を設定して ください。

#### 図 6 - 2 16ビット・タイマ・モード・コントロール・レジスタ 0 (TMC0) のフォーマット

アドレス:FF60H リセット時:00H R/W

| 略号   | 7 | 6 | 5 | 4 | 3     | 2     | 1 | 0    |
|------|---|---|---|---|-------|-------|---|------|
| TMC0 | 0 | 0 | 0 | 0 | TMC03 | TMC02 | 0 | OVF0 |

| TMC03 | TMC02 | 動作モードおよび                | TO0の出力         | 割り込み要求の発生   |
|-------|-------|-------------------------|----------------|-------------|
|       |       | クリア・モードの選択              | タイミングの選択       |             |
| 0     | 0     | 動作停止                    | 変化なし           | 発生しない       |
|       |       | (TM0は0にクリア)             |                |             |
| 0     | 1     | フリー・ランニング・モード           | TM0とCR00の一致または | TM0とCR00の一致 |
|       |       |                         | TM0とCR01の一致    | または         |
| 1     | 0     | TI00の有効エッジで             | _              | TM0とCR01の一致 |
|       |       | クリア&スタート <sup>注1</sup>  |                | で発生         |
| 1     | 1     | TM0とCR00の一致で            | TM0とCR00の一致または |             |
|       |       | クリア&スタート <sup>注 2</sup> | TM0とCR01の一致    |             |

| OVF0 | 16ビット・タイマ・カウンタ 0 (TM0)のオーバフロー検出 |
|------|---------------------------------|
| 0    | オーバフローなし                        |
| 1    | オーバフローあり                        |

- 注1. TI00/TO0/P70端子の有効エッジは、プリスケーラ・モード・レジスタ 0 (PRM0) で設定します。
  - 2. TM0とCR00の一致でクリア&スタートするモードを選択した場合、CR00の設定値がFFFFHで、TM0の値がFFFFHから0000Hに変化するとき、OVF0フラグが1に設定されます。
- 注意 1. TMC0を同一データ以外に書き換える場合は、いったんタイマ動作を停止させてから書き換えてください。
  - 2. OVF0フラグ以外のビットには、タイマ動作を停止してから書き込んでください。

備考 TOO :16ビット・タイマ/イベント・カウンタ 0 の出力端子

TI00 : 16ビット・タイマ/イベント・カウンタ 0 の入力端子

TMO :16ビット・タイマ・カウンタ 0

CR00 : 16ビット・タイマ・キャプチャ/コンペア・レジスタ00 CR01 : 16ビット・タイマ・キャプチャ/コンペア・レジスタ01

(2) キャプチャ/コンペア・コントロール・レジスタ 0 (CRC0)

16ビット・タイマ・キャプチャ/コンペア・レジスタ(CR00, CR01)の動作を制御するレジスタです。
CRC0は、1ビット・メモリ操作命令または8ビット・メモリ操作命令で設定します。
RESET入力により00Hになります。

図 6-3 キャプチャ/コンペア・コントロール・レジスタ 0 (CRC0) のフォーマット

アドレス:FF62H リセット時:00H R/W 略号 7 6 5 4 3 2 1 0 CRC0 0 0 0 0 CRC02 CRC01 CRC00

| CRC02 | CR01の動作モードの選択   |
|-------|-----------------|
| 0     | コンペア・レジスタとして動作  |
| 1     | キャプチャ・レジスタとして動作 |

| CRC01 | CR00のキャプチャ・トリガの選択                  |
|-------|------------------------------------|
| 0     | TI01の有効エッジでキャプチャする                 |
| 1     | TI00の有効エッジの逆相でキャプチャする <sup>注</sup> |

| CRC00 | CR00の動作モードの選択   |
|-------|-----------------|
| 0     | コンペア・レジスタとして動作  |
| 1     | キャプチャ・レジスタとして動作 |

**注** TI00の有効エッジに立ち上がり、立ち下がりの両エッジを選択した場合には、キャプチャは動作しません。

注意1. CRC0は、必ずタイマ動作を停止させてから設定してください。

- 2. 16ビット・タイマ・モード・コントロール・レジスタ 0 (TMC0) で, TM0とCR00の一致でクリア&スタート・モードを選択したとき, CR00をキャプチャ・レジスタに指定しないでください。
- 3. キャプチャを確実に行うために、キャプチャ・トリガはプリスケーラ・モード・レジスタ 0 (PRM0) で選択したカウント・クロックの 2 周期分より長いパルスを必要とします (図 6 -31 を参照)。

## (3) 16ビット・タイマ出力コントロール・レジスタ 0 (TOC0)

16ビット・タイマ/イベント・カウンタ 0 出力制御回路の動作を制御するレジスタです。R-S型フリップフロップ(LVO)のセット/リセット、出力の反転許可/禁止、16ビット・タイマ/イベント・カウンタ 0 のタイマ出力許可/禁止を設定します。

TOC0は、1 ビット・メモリ操作命令または8 ビット・メモリ操作命令で設定します。 RESET入力により00Hになります。

## 図 6 - 4 16ビット・タイマ出力コントロール・レジスタ 0 (TOC0) のフォーマット

 アドレス:FF63H
 リセット時:00H
 R/W

 略号
 7
 6
 5
 4
 3
 2
 1
 0

 TOC0
 0
 0
 0
 TOC04
 LVS0
 LVR0
 TOC01
 TOE0

| TOC04 | CR01とTM0の一致によるタイマ出力F/Fの制御 |  |
|-------|---------------------------|--|
| 0     | 反転動作禁止                    |  |
| 1     | 反転動作許可                    |  |

| LVS0 | LVR0 | 16ビット・タイマ/イベント・カウンタ 0 のタイマ出力F/Fの状態の設定 |
|------|------|---------------------------------------|
| 0    | 0    | 変化しない                                 |
| 0    | 1    | タイマ出力F/Fをリセット(0)                      |
| 1    | 0    | タイマ出力F/Fをセット(1)                       |
| 1    | 1    | 設定禁止                                  |

| TOC01 | CR00とTM0の一致によるタイマ出力F/Fの制御 |
|-------|---------------------------|
| 0     | 反転動作禁止                    |
| 1     | 反転動作許可                    |

| TOE0 | 16ビット・タイマ/イベント・カウンタ 0 の出力の制御 |
|------|------------------------------|
| 0    | 出力禁止(出力は0レベルに固定)             |
| 1    | 出力許可                         |

注意1. TOC0は、必ずタイマ動作を停止させてから設定してください。

- 2. LVS0, LVR0は, 読み出すと0になっています。
- 3. TOCOのビット5-7には、必ず0を設定してください。

#### (4) プリスケーラ・モード・レジスタ 0 (PRM0)

16ビット・タイマ・カウンタ 0 (TMO) のカウント・クロックおよびTIOO, TIO1入力の有効エッジを設定するレジスタです。PRMOは、8 ビット・メモリ操作命令で設定します。

RESET入力により00Hになります。

## 図6-5 プリスケーラ・モード・レジスタ0 (PRMO) のフォーマット

アドレス:FF61H リセット時:00H R/W

 略号
 7
 6
 5
 4
 3
 2
 1
 0

 PRM0
 ES11
 ES10
 ES01
 ES00
 0
 0
 PRM01
 PRM00

| ES11 | ES10 | TI01有効エッジの選択     |
|------|------|------------------|
| 0    | 0    | 立ち下がりエッジ         |
| 0    | 1    | 立ち上がりエッジ         |
| 1    | 0    | 設定禁止             |
| 1    | 1    | 立ち上がり、立ち下がりの両エッジ |

| ES01 | ES00 | TI00有効エッジの選択     |
|------|------|------------------|
| 0    | 0    | 立ち下がりエッジ         |
| 0    | 1    | 立ち上がりエッジ         |
| 1    | 0    | 設定禁止             |
| 1    | 1    | 立ち上がり、立ち下がりの両エッジ |

| PRM01 | PRM00 | カウント・クロックの選択                |
|-------|-------|-----------------------------|
| 0     | 0     | fx (12 MHz)                 |
| 0     | 1     | fx/2 <sup>2</sup> (3 MHz)   |
| 1     | 0     | fx/2 <sup>6</sup> (187 kHz) |
| 1     | 1     | TI00有効エッジ <sup>注 1, 2</sup> |

- 注1. 外部クロックは内部クロック(fx/23)の2周期分より長いパルスを必要とします。
  - 2. TIOO有効エッジ選択時は、ノイズ除去用のサンプリング・クロックにメイン・システム・クロックを使用しているため、メイン・システム・クロック動作時のみ使用できます。
- 注意1. PRMOは、必ずタイマ動作を停止させてからデータを設定してください。
  - 2. カウント・クロックにTIOOの有効エッジを設定する場合,TIOO有効エッジでクリア&スタート・モードおよびキャプチャ・トリガに設定しないでください。

また、P70/TI00/TO0端子をタイマ出力(TO0)として使用できません。

- 3. システム・リセット直後にTIOO端子またはTIO1端子がハイ・レベルの場合, TIOO端子またはTIO1端子の有効エッジを立ち上がりまたは両エッジに指定し, 16ビット・タイマ・カウンタ 0 (TMO)の動作を許可すると, その直後に立ち上がりエッジを検出します。TIOO端子またはTIO1端子をプルアップしている場合などは注意してください。ただし, いったん動作を停止させたあとの再動作許可時には,立ち上がりエッジは検出されません。
- 備考1. fx:メイン・システム・クロック発振周波数
  - 2. TIOO, TIO1:16ビット・タイマ/イベント・カウンタ 0 の入力端子
  - 3. ( )内は, fx = 12 MHz動作時。

### (5) ポート・モード・レジスタ7 (PM7)

ポート7の入力/出力を1ビット単位で設定するレジスタです。

P70/TO0/TI00端子をタイマ出力として使用するとき、PM70およびP70の出力ラッチに 0 を設定してください。

P70/TO0/TI00端子をタイマ入力として使用するとき、PM70に1を設定してください。このときP70の出力 ラッチは、0 または1 のどちらでもかまいません。

PM7は、1ビット・メモリ操作命令または8ビット・メモリ操作命令で設定します。

RESET入力により、FFHになります。

図6-6 ポート・モード・レジスタ7 (PM7) のフォーマット

アドレス:FF27H リセット時:FFH R/W

 略号
 7
 6
 5
 4
 3
 2
 1
 0

 PM7
 1
 1
 PM75
 PM74
 PM73
 PM72
 PM71
 PM70

| Р | M7n | P7n端子の入出力モードの選択(n = 0-5) |
|---|-----|--------------------------|
| Г | 0   | 出力モード(出力バッファ・オン)         |
|   | 1   | 入力モード(出力バッファ・オフ)         |

# 6.4 16ビット・タイマ/イベント・カウンタ 0 の動作

## 6.4.1 インターバル・タイマとしての動作

16ビット・タイマ・モード・コントロール・レジスタ 0(TMC0)と、キャプチャ/コンペア・コントロール・レジスタ 0(CRC0)を図 6-7 のように設定することにより、インターバル・タイマとして動作します。16ビット・タイマ・キャプチャ/コンペア・レジスタ00(CR00)にあらかじめ設定したカウント値をインターバルとし、繰り返し割り込み要求を発生します。

16ビット・タイマ・カウンタ 0 (TMO) のカウント値がCR00に設定した値と一致したとき、TM0の値を 0 にクリアしてカウントを継続するとともに割り込み要求信号(INTTM00)を発生します。

プリスケーラ・モード・レジスタ 0 (PRM0) のビット 0 、1 (PRM00, PRM01) で16ビット・タイマ/イベント・カウンタ 0 のカウント・クロックを選択できます。

#### 図6-7 インターバル・タイマ動作時の制御レジスタ設定内容

#### (a) 16ビット・タイマ・モード・コントロール・レジスタ 0 (TMC0)



### (b) キャプチャ/コンペア・コントロール・レジスタ 0 (CRC0)

|      |   |   |   |   |   | CRC02 | CRC01 | CRC00 |
|------|---|---|---|---|---|-------|-------|-------|
| CRC0 | 0 | 0 | 0 | 0 | 0 | 0/1   | 0/1   | 0     |
|      |   |   |   |   |   |       |       |       |

#### 図6-8 インターバル・タイマの構成図



注 16ビット・タイマ・キャプチャ/コンペア・レジスタ00にFFFFHを設定した場合のみ、OVF0は1になります。

図 6 - 9 インターバル・タイマ動作のタイミング



備考 インターバル時間 = (N+1)×t N = 0001H-FFFFH タイマ・カウント動作中にコンペア・レジスタを変更したときに、16ビット・タイマ・キャプチャ/コンペア・レジスタ00(CR00)の変更後の値が、16ビット・タイマ・カウンタ 0(TM0)の値よりも小さい場合は、TM0はカウントを継続しオーバフローして 0 から再カウントします。したがって、CR00の変更後の値(M)が変更前の値(N)より小さい場合は、CR00を変更後、タイマを再スタートさせる必要があります。

図6-10 タイマ・カウント動作中のコンペア・レジスタの変更後のタイミング



備考 N>X>M

## 6.4.2 外部イベント・カウンタとしての動作

外部イベント・カウンタは、TI00/TO0/P70端子に入力される外部からのクロック・パルス数を16ビット・タイマ・カウンタ 0 (TM0) でカウントするものです。

プリスケーラ・モード・レジスタ 0 (PRMO) で指定した有効エッジが入力されるたびに、TMOがインクリメントされます。

TM0の計数値が16ビット・タイマ・キャプチャ/コンペア・レジスタ00(CR00)の値と一致すると、TM0は 0 にクリアされ、割り込み要求信号(INTTM00)が発生します。

なお、CR00には0000H以外の値を入れてください(1パルスのカウント動作はできません)。

エッジ指定は、プリスケーラ・モード・レジスタ 0 (PRM0) のビット 4, 5 (ES00, ES01) により、立ち上がり、立ち下がり、両エッジの 3 種類から選択できます。

内部クロック(fx/2³)でサンプリングを行い、TIOO端子の有効レベルを2回検出することではじめて動作するため、短いパルス幅のノイズを除去できます。

注意 外部イベント・カウンタとして使用するとき, P70/TI00/TO0端子をタイマ出力(TO0)として使用できません。

図 6-11 外部イベント・カウンタ・モード時の制御レジスタ設定内容

(a) 16ビット・タイマ・モード・コントロール・レジスタ 0 (TMC0)



(b) キャプチャ/コンペア・コントロール・レジスタ 0 (CRC0)



図6-12 外部イベント・カウンタの構成図



注 16ビット・タイマ・キャプチャ/コンペア・レジスタ00にFFFFHを設定した場合のみ、OVF0は1になります。

図6-13 外部イベント・カウンタ動作のタイミング(立ち上がりエッジ指定時)



注意 外部イベント・カウンタのカウント値を読み出す場合は、TMOを読み出してください。

## 6.4.3 パルス幅測定としての動作

16ビット・タイマ・カウンタ 0 (TMO) を使用し、TI00/TO0/P70端子およびTI01/P71端子に入力される信号の パルス幅を測定できます。

測定方法は、TMOをフリー・ランニングさせて測定する方法とTIOO端子に入力される信号のエッジに同期してタイマをリスタートさせて測定する方法があります。

### (1) フリー・ランニング・カウンタとキャプチャ・レジスタ1本によるパルス幅測定

16ビット・タイマ・カウンタ 0 (TM0) をフリー・ランニングで動作させているとき (図 6 -14のレジスタの設定参照), TI00端子にプリスケーラ・モード・レジスタ 0 (PRM0) で指定したエッジが入力されると TM0の値を16ビット・タイマ・キャプチャ/コンペア・レジスタ01 (CR01) に取り込み、外部割り込み要求 信号 (INTTM01) をセットします。

エッジはPRM0のビット 4 、5 (ES00, ES01)で指定し、立ち上がり、立ち下がり、両エッジの 3 種類の選択ができます。

PRMOで選択したカウント・クロックでサンプリングを行い、TIOO端子の有効レベルを2回検出することではじめてキャプチャ動作を行うため、短いパルス幅のノイズを除去できます。

## 図 6 -14 フリー・ランニング・カウンタとキャプチャ・レジスタ 1 本による パルス幅測定時の制御レジスタ設定内容

#### (a) 16ビット・タイマ・モード・コントロール・レジスタ 0 (TMC0)



## (b) キャプチャ/コンペア・コントロール・レジスタ 0 (CRC0)



### 図6-15 フリーランニング・カウンタによるパルス幅測定の構成図



図 6 -16 フリー・ランニング・カウンタとキャプチャ・レジスタ 1 本によるパルス幅測定動作のタイミング (両エッジ指定時)



注 OVF0のクリアはソフトウエアで行ってください。

#### (2) フリー・ランニング・カウンタによる2つのパルス幅測定

16ビット・タイマ・カウンタ 0 (TMO) をフリー・ランニングで動作させているとき (図 6-17参照), TI00端子およびTI01端子に入力される 2 つの信号のパルス幅を同時に測定できます。

TI00端子にプリスケーラ・モード・レジスタ 0 (PRM0) のビット 4, 5 (ES00, ES01) で指定したエッジが入力されると、TM0の値を16ビット・タイマ・キャプチャ/コンペア・レジスタ01 (CR01) に取り込み、割り込み要求信号 (INTTM01) をセットします。

また、TI01端子にPRM0のビット 6、 7(ES10, ES11)で指定したエッジが入力されると、TM0の値を16 ビット・タイマ・キャプチャ/コンペア・レジスタ00(CR00)に取り込み、割り込み要求信号(INTTM00)をセットします。

TI00端子とTI01端子のエッジは、PRM0のビット 4 、5 (ES00、ES01)およびビット 6 、7 (ES10、ES11)でそれぞれ指定し、立ち上がり、立ち下がり、両エッジの 3 種類の選択ができます。

プリスケーラ・モード・レジスタ 0 (PRM0) で選択したカウント・クロック周期でサンプリングを行い、TI00端子またはTI01端子の有効レベル 2 回検出することではじめてキャプチャ動作を行うため、短いパルス幅のノイズを除去できます。

## 図 6-17 フリー・ランニング・カウンタによる 2 つのパルス幅測定時の制御レジスタ設定内容

#### (a) 16ビット・タイマ・モード・コントロール・レジスタ 0 (TMC0)



#### (b) キャプチャ/コンペア・コントロール・レジスタ 0 (CRC0)



図6-18 フリー・ランニング・カウンタによるパルス幅測定動作のタイミング(両エッジ指定時)



注 OVF0のクリアはソフトウエアで行ってください。

#### (3) フリー・ランニング・カウンタとキャプチャ・レジスタ2本によるパルス幅測定

16ビット・タイマ・カウンタ 0 (TMO) をフリー・ランニングで動作させているとき (図 6-19参照), TI00端子に入力する信号のパルス幅を測定できます。

TI00端子にプリスケーラ・モード・レジスタ 0 (PRM0) のビット 4, 5 (ES00, ES01) で指定したエッジが入力されると、TM0の値を16ビット・タイマ・キャプチャ/コンペア・レジスタ01 (CR01) に取り込み、割り込み要求信号 (INTTM01) をセットします。

また、CR01へのキャプチャ動作と逆のエッジ入力で、TM0の値を16ビット・タイマ・キャプチャ/コンペア・レジスタ00(CR00)に取り込みます

TI00端子のエッジは、プリスケーラ・モード・レジスタ 0 (PRM0) のビット 4, 5 (ES00, ES01) で指定し、立ち上がりエッジまたは立ち下がりエッジの選択ができます。

プリスケーラ・モード・レジスタ 0 (PRMO) で選択したカウント・クロック周期でサンプリングを行い、TIOO端子の有効レベルを 2 回検出することではじめてキャプチャ動作を行うため、短いパルス幅のノイズを除去できます。

注意 TI00端子の有効エッジを,立ち上がり,立ち下がりの両エッジに指定した場合,16ビット・タイマ・キャプチャ/コンペア・レジスタ00 (CR00) はキャプチャ動作を行えません。

## 図 6 -19 フリー・ランニング・カウンタとキャプチャ・レジスタ 2 本による パルス幅測定時の制御レジスタ設定内容

(a) 16ビット・タイマ・モード・コントロール・レジスタ 0 (TMC0)



(b) キャプチャ/コンペア・コントロール・レジスタ 0 (CRC0)







注 OVF0のクリアはソフトウェアで行ってください。

#### (4) リスタートによるパルス幅測定

TI00端子への有効エッジを検出したとき、16ビット・タイマ・カウンタ 0(TM0)のカウント値を16ビット・タイマ・キャプチャ/コンペア・レジスタ01(CR01)に取り込んだあと、TM0をクリアしてカウントを再開することにより、TI00端子に入力された信号のパルス幅を測定します(図 6-22参照)。

エッジ指定は、プリスケーラ・モード・レジスタ 0 (PRM0) のビット 4 、5 (ES00, ES01) により、立ち上がりエッジまたは立ち下がりエッジの選択ができます。

プリスケーラ・モード・レジスタ 0 (PRMO) で選択したカウント・クロック周期でサンプリングを行い、TIOO端子の有効レベルを 2 回検出することではじめてキャプチャ動作を行うため、短いパルス幅のノイズを除去できます。

注意 TI00端子の有効エッジを,立ち上がり,立ち下がりの両エッジに指定した場合,16ビット・タイマ・キャプチャ/コンペア・レジスタ00(CR00)はキャプチャ動作を行えません。

#### 図6-21 リスタートによるパルス幅測定時の制御レジスタ設定内容

#### (a) 16ビット・タイマ・モード・コントロール・レジスタ 0 (TMC0)



## (b) キャプチャ/コンペア・コントロール・レジスタ 0 (CRC0)



## 図6-22 リスタートによるパルス幅測定動作のタイミング(立ち上がりエッジ指定時)



## 6.4.4 方形波出力としての動作

16ビット・タイマ・キャプチャ/コンペア・レジスタ00(CR00)にあらかじめ設定したカウント値で決まるインターバルの、任意の周波数の方形波出力として動作します。

16ビット・タイマ出力コントロール・レジスタ 0 (TOC0) のビット 0 (TOE0) とビット 1 (TOC01) に 1 を設定することにより、CR00にあらかじめ設定したカウント値で決まるインターバルでTOO端子の出力状態が反転します。これによって、任意の周波数の方形波出力が可能です。

図6-23 方形波出力モード時の制御レジスタ設定内容

(a) 16ビット・タイマ・モード・コントロール・レジスタ 0 (TMC0)



(b) キャプチャ/コンペア・コントロール・レジスタ 0 (CRC0)



## (c) 16ビット・タイマ出力コントロール・レジスタ 0 (TOC0)



図6-24 方形波出力動作のタイミング



## 6.4.5 PPG出力としての動作

16ビット・タイマ・モード・コントロール・レジスタ 0(TMC0)と、キャプチャ/コンペア・コントロール・レジスタ 0(CRC0)を図 6 -25のように設定することにより、PPG(Programmable Pulse Generator)出力として動作します。

PPG出力パルスは、16ビット・タイマ・キャプチャ/コンペア・レジスタ00(CR00)にあらかじめ設定したカウント値を1周期とし、16ビット・タイマ・キャプチャ/コンペア・レジスタ01(CR01)にあらかじめ設定したカウント値をパルス幅とする矩形波をTO0端子から出力します。

図 6-25 PPG出力動作時の制御レジスタ設定内容

(a) 16ビット・タイマ・モード・コントロール・レジスタ 0 (TMC0)



(b) キャプチャ/コンペア・コントロール・レジスタ 0 (CRC0)



(c) 16ビット・タイマ出力コントロール・レジスタ 0 (TOC0)



注意 1. CR00とCR01には次の範囲の値を設定してください。

0000H<CR01<CR00≦FFFFH

PPG出力によって生成されるパルスの周期は(CR00の設定値十1),デューティは(CR01の設定値十1)/(CR00の設定値十1)になります。

備考 ×:don't care

図6-26 PPG出力の構成図



図 6 -27 PPG出力動作のタイミング



備考 0000H<M<N≤FFFFH

# 6.5 プログラム・リスト

注意 このサンプル・プログラムは、半導体製品の動作例、応用例を説明するために、例示的に示したものです。 したがって、これらの情報をお客様の機器に使用される場合には、お客様の責任において評価を実施し設計 をしてください。

## 6.5.1 インターバル・タイマ

```
タイマ0 インターバルタイマモード設定例
      周期をintervalTM0として130に設定(8.38MHzで1mS)
      変数 ppgdataを書き換え用データ領域として準備
       : 周期(0000なら変更無し)
       INTTM00毎にppgdataをチェックし、必要なら変更する
       従って、変更したければ、ppgdataに変更データを設定
       変更されれば、ppgdataは0000にクリアされる
/******************
#pragma sfr
#pragma EI
#pragma DI
                             /* CR00にセットする周期データ */
#define intervalTM0 130
#pragma interrupt INTTM00 intervalint rb2
                             /* タイマ0にセットするデータ領域 */
     unsigned int ppgdata;
void main(void)
                             /* 高速動作モード設定 */
     PCC = 0x0;
     ppgdata = 0;
                              /* ポート設定 */
                              /* 出力を行うなら以下の設定を行う */
     P7 = 0b111111110;
                              /* P70をクリア */
     PM7.0 = 0;
                              /* P70を出力に設定 */
                              /* 割り込み設定 */
     TMMK00 = 0;
                              /* INTTM00割り込みマスク解除 */
                             /* タイマ0の設定 */
                             /* カウント・クロックはfx/2^6 */
     PRM0 = 0b00000010;
                             /* CR00,CR01をコンペア・レジスタに設定 */
     CRC0 = 0b00000000;
                             /* CR00に周期初期値を設定 */
     CR00 = intervalTM00;
                             /* CR00との一致で反転,初期値L */
     TOC0 = 0b00000111;
                              /* TM0とCR00の一致でクリア&スタート */
     TMC0 = 0b00001100;
     EI();
     while (1);
                             /* ここではダミーでループさせている */
}
/* タイマ0割り込み関数 */
void intervalint()
     unsigned int work;
/*
                             * /
/* 割り込みで必要な変数をここで定義する
                             * /
     work = ppgdata;
     if (work != 0)
      {
           CR00 = work;
           ppgdata = 0;
           if (work == 0xffff)
            {
                 TMC0 = 0b00000000; /* タイマ停止 */
/*
/* 割り込みで必要な処理をここから後に記述する
    *************
}
```

## 6.5.2 フリー・ランニング・カウンタとキャプチャ・レジスタ1本によるパルス幅測定

```
タイマ0動作サンプル
     フリーランとCR01でのパルス幅測定例
     測定結果は16ビットまでとし、エラーチェックしない
     data[0] :完了フラグ
     data[1] :測定結果(パルス幅)
     data[2] :前回の読み取り値
#pragma sfr
#pragma EI
#pragma DI
#pragma interrupt INTTM01 intervalint rb2
    unsigned int data[3]; /* データ領域 */
void main(void)
    unsigned int length;
    PCC = 0x0;
                        /* 高速動作モード設定 */
    data[0] = 0;
    data[1] = 0;
    data[2] = 0;
                         /* ポート設定 */
    PM7.0 = 1;
                         /* P70を入力に設定 */
                         /* 割り込み設定 */
                         /* INTTM01割り込みマスク解除 */
    TMMK01 = 0;
                         /* タイマ0の設定 */
                         /* TI00は立ち上がり,立ち下がりの両エッジ */
    PRM0 = 0b00110010;
                         /* カウント・クロックはfx/2^6
    CRC0 = 0b00000100;
                        /* CR01をキャプチャ・レジスタに設定 */
                         /* フリーラン・モードでスタート */
     TMC0 = 0b00000100;
    EI();
                         /* ダミーのループ */
     while(1){
         while(data[0] == 0); /* 測定完了待ち */
                         /* 排他処理のために割り込み禁止 */
          DI();
                        /* 測定結果の読み出し */
          length = data[1];
                         /* 完了フラグのクリア */
          data[0] = 0;
                         /* 排他処理完了 */
          EI();
    }
}
/* タイマ0割り込み関数 */
void intervalint()
{
    unsigned int work;
/************/
/*
/* 割り込みで必要な変数をここで定義する
/*************/
    work = CR01;
                        /* キャプチャ値の読み出し */
                       data[1] = work - data[2];
    data[2] = work;
                        /* 読み取り値の更新 */
                         /* 測定完了フラグ・セット*/
    data[0] = 0xffff;
/****************
                             * /
/* 割り込みで必要な処理をここから後に記述する
/*
```

## 6.5.3 フリー・ランニング・カウンタによる2つのパルス幅測定

```
/*
         タイマ0動作サンプル
      フリーランでの2つのパルス幅測定例
      測定結果は16ビットまでとし、エラーチェックしない
       TI00側結果領域
      data[0] :完了フラグ
      data[1] :測定結果(パルス幅)
data[2] :前回の読み取り値
       TI01側結果領域
      data[3] :完了フラグ
data[4] :測定結果(パルス幅)
data[5] :前回の読み取り値
/*
#pragma EI
#pragma DI
#pragma interrupt INTTM00 intervalint rb2
#pragma interrupt INTTM01 intervalint2 rb2
     unsigned int data[6]; /* データ領域 */
void main(void)
{
      unsigned int length, length2;
                               /* 高速動作モード設定 */
      PCC = 0x0;
                               /* データ領域クリア */
      data[0] = 0;
      data[1] = 0;
      data[2] = 0;
      data[3] = 0;
      data[4] = 0;
      data[5] = 0;
                               /* ポート設定 */
                              /* P70を入力に設定 */
      PM7.0 = 1;
      PM7.1 = 1;
                               /* P71を入力に設定 */
                               /* 割り込み設定 */
                               /* INTTM01割り込みマスク解除 */
      TMMK01 = 0;
                               /* INTTM00割り込みマスク解除 */
/* タイマ0の設定 */
/* 立ち上がり、立ち下がりの両エッジ */
      TMMK00 = 0;
      PRM0 = 0b11110010;
                               /* カウント・クロックはfx/2^6
                               /* CR00, CR01をキャプチャ・レジスタに設定 */
      CRC0 = 0b00000101;
                               /* フリーラン・モードでスタート */
      TMC0 = 0b00000100;
      EI();
                               /* ダミーのループ */
      while(1){
            if(data[0] != 0)
                               /* TI00測定完了チェック */
            {
                   TMMK01 = 1;
                                     /* 排他処理の為にINTTM01割り込み禁止 */
                   length = data[1];
                                     /* 測定結果の読み出し */
                   data[0] = 0;
                                     /* 完了フラグのクリア */
                                     /* 排他処理完了 */
                   TMMK01 = 0;
            if(data[3]!= 0) /* TI01測定完了チェック */
                  {
            }
      }
}
```

```
/* INTTM00割り込み関数 */
void intervalint()
     unsigned int work;
/*********************************
    */
/*
/* 割り込みで必要な変数をここで定義する
/**************
     work = CR00;
                             ,
/* キャプチャ値の読み出し */
/* 間隔の計算と更新 */
/* 読み取り値の更新 */
/* 測定完了フラグ・セット*/
      data[4] = work - data[5];
      data[5] = work;
data[3] = 0xffff;
      data[3] = 0xffff;
                                   * /
/* 割り込みで必要な処理をここから後に記述する
                                    * /
}
/* INTTM01割り込み関数 */
void intervalint2()
{
     unsigned int work;
/**********************************
/* 割り込みで必要な変数をここで定義する
                              * /
* /
/************/
      work = CR01; /* キャプチャ値の読み出し */
                            /* 間隔の計算と更新 */
/* 読み取り値の更新 */
      data[1] = work - data[2];
      data[2] = work;
      data[0] = 0xffff;
                              /* 測定完了フラグ・セット*/
                                    */
/* 割り込みで必要な処理をここから後に記述する
                                    * /
/*
}
```

## 6.5.4 リスタートによるパルス幅測定

```
タイマ0動作サンプル
      リスタートによるパルス幅測定例
      測定結果は16ビットまでとし、エラーチェックしない
       data[0] :完了フラグ
      data[1] :測定結果(パルス幅)
       data[2] :前回の読み取り値
#pragma sfr
#pragma EI
#pragma DI
#pragma interrupt INTTM01 intervalint rb2
     unsigned int data[3]; /* データ領域 */
void main(void)
{
      unsigned int length;
                               /* 高速動作モード設定 */
      PCC = 0x0;
      data[0] = 0;
      data[1] = 0;
      data[2] = 0;
                                /* ポート設定 */
      PM7.0 = 1;
                                /* P70を入力に設定 */
                                /* 割り込み設定 */
                                /* INTTM01割り込みマスク解除 */
      TMMK01 = 0;
                                /* タイマ0の設定 */
                               /* 立ち上がり,立ち下がりの両エッジ */
      PRM0 = 0b00110010;
                               /* カウント・クロックはfx/2^6 */
/* CR01をキャプチャ・レジスタに設定 */
      CRC0 = 0b00000100;
                                /* TIOO有効エッジでクリア&スタート */
      TMC0 = 0b00001000;
      EI();
            ){ /* ダミーのループ */
if(data[0] != 0) /* TIOO測定完了待ち */
      while(1){
             {
                   TMMK01 = 1;
                                      /* 排他処理の為にINTTM01割り込み禁止 */

      length = data[1]+data[2];
      /* 測定結果から周期計算 */

      data[0] = 0;
      /* 完了フラグのクリア */

      TMMK01 = 0;
      /* 排他処理完了 */

             }
      }
}
/* タイマ0割り込み関数 */
void intervalint()
/*
/* 割り込みで必要な変数をここで定義する
/**************
     data[2] = data[1];/* 旧データの更新 */data[1] = CR01;/* 読み取り値の更新 */
     data[0] = 0xffff;
                               /* 測定完了フラグ・セット*/
/* 割り込みで必要な処理をここから後に記述する
/*
```

## 6.5.5 PPG出力

```
/*
          タイマ0 PPGモード設定例
       周期をintervalTMOとして130に設定
       アクティブ期間をactive_timeとして65に設定
      配列 ppgdataを書き換え用データ領域として準備
       [0] :アクティブ期間(0000なら変更無し,Oxffffで停止)
       [1] :周期(0000なら変更無し)
       INTTM00毎にppgdataをチェックし、必要なら変更する
       従って、変更したければ、ppgdataに変更データを設定
        変更されれば、ppgdataは0000にクリアされる
/********************
#pragma sfr
#pragma EI
#pragma DI
#define intervalTM0 130
                               /* CR00にセットする周期データ */
#define active_time 65
                                /* CR01の初期値データ */
#pragma interrupt INTTM00 ppgint rb2
      unsigned int ppgdata[2];
                               /* タイマ0にセットするデータ領域 */
void main(void)
{
      PCC = 0x0;
                                /* 高速動作モード設定 */
      ppqdata[0] = 0;
      ppgdata[1] = 0;
                                /* ポート設定 */
                                /* P70をクリア */
      P7 = 0b111111110;
                                /* P70を出力に設定 */
      PM7.0 = 0;
                                /* 割り込み設定 */
                                /* INTTM00割り込みマスク解除 */
      TMMK00 = 0;
                               /* タイマ0の設定 */
                               /* カウント・クロックはfx/2^6 */
      PRM0 = 0b00000010;
                               /* CR00,CR01をコンペア・レジスタに設定 */
      CRC0 = 0b000000000;
                               /* 周期初期値を設定 */
      CR00 = intervalTM0;
                               /* アクティブ期間初期値設定 */
      CR01 = active_time;
      TOC0 = 0b00010111;
                               /* CR00,CR01との一致で反転,初期値L */
/* TM0とCR00の一致でクリア&スタート */
      TMC0 = 0b00001100;
      EI();
      while(1);
}
/* タイマ0割り込み関数 */
void ppgint()
      unsigned int work;
      work = ppgdata[0];
      if (work != 0)
      {
             CR01 = work;
            ppgdata[0] = 0;
            if (work == 0xffff)
                   TMC0 = 0b00000000; /* タイマ停止 */
             }
      }
      work = ppgdata[1];
      if (work != 0)
      {
            CR00 = work;
             ppgdata[1]=0;
      }
}
```

## 6.6 16ビット・タイマ/イベント・カウンタ 0 の注意事項

#### (1) タイマ・スタート時の誤差

タイマ・スタート後、一致信号が発生するまでの時間は、最大で1クロック分の誤差が生じます。これはカウント・クロックに対して16ビット・タイマ・カウンタ0 (TMO) が非同期でスタートするためです。

図 6-28 16ビット・タイマ・カウンタ 0 (TMO) のスタート・タイミング



(2) 16ビット・タイマ・キャプチャ/コンペア・レジスタの設定(TM0とCR00の一致でクリア&スタート・モードの場合)

16ビット・タイマ・キャプチャ/コンペア・レジスタ00,01(CR00, CR01)には、0000H以外の値を設定してください。したがって、1 パルスのカウント動作はできません。

#### (3) キャプチャ・レジスタのデータ保持タイミング

16ビット・タイマ・キャプチャ/コンペア・レジスタ01 (CR01) の読み出し中にTI00端子の有効エッジが入力したとき、CR01はキャプチャ動作を行いますが、このときのリード値は保証されません。ただし、有効エッジの検出による割り込み要求信号(INTTM01) は発生します。



図 6-29 キャプチャ・レジスタのデータ保持タイミング

## (4) 有効エッジの設定

TI00端子の有効エッジは、16ビット・タイマ・モード・コントロール・レジスタ 0 (TMC0)のビット 2,3 (TMC02, TMC03)に 0, 0 を設定し、タイマ動作を停止させたあとに設定してください。有効エッジは、プリスケーラ・モード・レジスタ 0 (PRM0)のビット 4, 5 (ES00, ES01)で設定します。

#### (5) OVF0フラグの動作

① OVFOフラグは、次のときにも"1"に設定されます。

TM0とCR00の一致でクリア&スタートするモード、TI00の有効エッジでクリア&スタート、フリー・ランニング・モードのいずれかを選択

↓ CR00をFFFFHに設定

TMOがFFFFHから0000Hにカウント・アップするとき

図 6 -30 OVF0フラグの動作タイミング



② TMOがオーバフロー後、次のカウント・クロックがカウントされる(TMOが0001Hになる)前にOVF0フラグをクリアしても、再度セットされ、クリアは無効となります。

### (6) 競合動作について

16ビット・タイマ・キャプチャ/コンペア・レジスタ(CR00/CR01)をコンペア・レジスタとして使用しているとき、ライト期間と16ビット・タイマ・カウンタ 0 (TM0) との一致タイミングが競合した場合、一致判別は正常に行われません。一致タイミング付近でCR00/CR01のライト動作は行わないでください。

## (7) タイマ動作について

- ① 16ビット・タイマ・カウンタ 0 (TM0) をリードしても、16ビット・タイマ・キャプチャ/コンペア・レジスタ01 (CR01) にはキャプチャしません。
- ② CPUの動作モードに関係なく、タイマが停止していると、TI00/TI01端子への入力信号は受け付けられません。

#### (8) キャプチャ動作について

- ① カウント・クロックにTI00の有効エッジを指定した場合、TI00をトリガに指定したキャプチャ・レジスタは正常に動作できません。
- ② TI00の有効エッジに立ち上がり、立ち下がりの両エッジを選択した場合には、キャプチャ動作しません。
- ③ 確実にキャプチャするためのキャプチャ・トリガは、プリスケーラ・モード・レジスタ 0 (PRM0) で選択したカウント・クロックの 2 周期分より長いパルスを必要とします。

図 6-31 立ち上がりエッジ指定時のCR01キャプチャ動作



④ キャプチャ動作はカウント・クロックの立ち下がりで行われますが、割り込み要求入力(INTTMon)は次のカウント・クロックの立ち上がりで発生します。

#### (9) コンペア動作について

- ① タイマ動作中に16ビット・タイマ・キャプチャ/コンペア・レジスタ(CR00/CR01)を書き換えたとき、その値がタイマ値に近く、かつタイマ値より大きい場合、一致割り込みの発生やクリア動作が正常に行われない可能性があります。
- ② コンペア・モードに設定したCR00/CR01は、キャプチャ・トリガが入力されてもキャプチャ動作を行いません。

備考 n = 0, 1

#### (10) エッジ検出について

- ① システム・リセット直後にTIO0端子またはTIO1端子がハイ・レベルの場合、TIO0端子またはTIO1端子の有効エッジを立ち上がりまたは両エッジに指定し、16ビット・タイマ・カウンタ 0 (TMO) の動作を許可すると、その直後に立ち上がりエッジを検出します。TIO0端子またはTIO1端子をプルアップしている場合などは注意してください。ただし、いったん動作を停止させたあとの再動作許可時には、立ち上がりエッジは検出されません。
- ② TIOOの有効エッジをカウント・クロックで使用する場合とキャプチャ・トリガとして使用する場合とで、 ノイズ除去のためのサンプリング・クロックが異なります。前者はfx/2³で、後者はプリスケーラ・モード・ レジスタ 0 (PRMO) で選択したカウント・クロックでサンプリングします。有効エッジをサンプリングし て、有効レベル 2 回を検出することではじめてキャプチャ動作するため、短いパルス幅のノイズを除去でき ます。
- (11) STOPモードまたはメイン・システム・クロック停止モードの設定について

TIOO, TIO1入力を選択している場合を除き、STOPモードまたはメイン・システム・クロック停止モードに設定する前に必ずタイマ動作を停止してください。メイン・システム・クロック開始時に、タイマが誤動作する可能性があります。

# 第7章 8ビット・タイマ/イベント・カウンタ50,51

## 7.1 8ビット・タイマ/イベント・カウンタ50,51の機能

8ビット・タイマ/イベント・カウンタ50,51 (TM50, TM51) には,次の2つのモードがあります。

(1) 8 ビット・タイマ/イベント・カウンタ50, 51を単体で使用するモード(単体モード) 8 ビットのタイマ/イベント・カウンタ50, 51として動作します。 次のような機能として使用できます。

① インターバル・タイマ

あらかじめ設定した任意の時間間隔で割り込み要求を発生します。

・カウント数:1~256カウント

② 外部イベント・カウンタ

外部から入力される信号の、ハイ/ロウ・レベル幅を持ったパルス数を測定できます。

③ 方形波出力

任意の周波数の方形波を出力できます。

・周期: (1×2~256×2) × カウント・クロックの周期

④ PWM出力

任意のデューティ比を持ったパルスを出力できます。

- ・周期:カウント・クロック×256
- ・デューティ比: コンペア・レジスタの設定値/256
- (2) カスケード接続して使用するモード(16ビット分解能:カスケード接続モード)

2つの8ビット・タイマ/イベント・カウンタを組み合わせて、16ビットのタイマ/イベント・カウンタとして動作します。

次のような機能として使用できます。

- ・16ビット分解能のインターバル・タイマ
- ・16ビット分解能の外部イベント・カウンタ
- ・16ビット分解能の方形波出力

図7-1, 7-2に、8ビット・タイマ/イベント・カウンタ50,51のブロック図を示します。

図 7-1 8ビット・タイマ/イベント・カウンタ50のブロック図



図 7 - 2 8 ビット・タイマ/イベント・カウンタ51のブロック図



- 注1. TI50入力とTO50出力, TI51入力とTO51出力は, それぞれ同時に使用できません。
  - 2. タイマ出力F/F
  - 3. PWM出力F/F

# 7.2 8ビット・タイマ/イベント・カウンタ50,51の構成

8ビット・タイマ/イベント・カウンタ50,51は、次のハードウエアで構成されています。

表 7 - 1 8ビット・タイマ/イベント・カウンタ50,51の構成

| 項目       | 構成                                |
|----------|-----------------------------------|
| タイマ・カウンタ | 8 ビット・タイマ・カウンタ5n(TM5n)            |
| レジスタ     | 8ビット・タイマ・コンペア・レジスタ5n(CR5n)        |
| タイマ入力    | TI5n                              |
| タイマ出力    | TO5n                              |
| 制御レジスタ   | タイマ・クロック選択レジスタ5n(TCL5n)           |
|          | 8ビット・タイマ・モード・コントロール・レジスタ5n(TMC5n) |
|          | ポート・モード・レジスタ7 (PM7)               |
|          | ポート7 (P7)                         |

### (1) 8 ビット・タイマ・カウンタ5n (TM5n: n = 0, 1)

TM5nは、カウント・パルスをカウントする8ビットのリード専用レジスタです。 カウント・クロックの立ち上がりに同期して、カウンタをインクリメントします。

TM50, TM51をカスケード接続し、16ビット・タイマとして使用した場合、16ビット・メモリ操作命令により読み出せます。しかし、内部8ビット・バスで接続されていますので、TM50, TM51の順で2回に分けて読み出します。したがって、カウント変化中の読み出しを考慮し、2度読みにより比較してください。

動作中にカウント値を読み出した場合、カウント・クロックの入力を一時停止し<sup>注</sup>、その時点でのカウント値を読み出します。

次の場合、カウント値は00Hになります。

- ① RESET入力
- ② TCE5nをクリア
- ③ TM5nとCR5nの一致でクリア&スタート・モード時のTM5nとCR5nの一致
- 注 このとき、カウントに誤差が生じる場合がありますので、カウント・クロックはCPUクロックの 2 周期分より長いハイ/ロウ・レベルのある波形を選択してください。

注意 カスケード接続時は、最下位タイマのTCE50をクリアしても0000Hとなります。

備考 n = 0, 1

#### (2) 8 ビット・タイマ・コンペア・レジスタ5n (CR5n: n = 0, 1)

PWMモード以外では、CR5nに設定した値と、8 ビット・タイマ・カウンタ5n(TM5n)のカウント値を常に比較し、その2つの値が一致したときに、割り込み要求(INTTM5n)を発生します。

PWMモード時は、TM5nのオーバフローによりTO5n端子がアクティブ・レベルになり、TM5nとCR5nの値が一致するとTO5n端子はインアクティブ・レベルになります。

CR5nの値は、00H-FFHの範囲で設定でき、カウント動作中の書き換えが可能です。

TM50, TM51をカスケード接続し、16ビット・タイマとして使用した場合、CR50, CR51は、16ビット・コンペア・レジスタとして動作します。16ビット長でカウンタ値とレジスタ値を比較し、一致すると割り込み要求(INTTM50)を発生します。そのとき、INTTM51割り込み要求も発生しますので、INTTM51割り込み要求をマスクしてください。

CR5nは、8ビット・メモリ操作命令で設定します。

RESET入力により、不定になります。

注意 カスケード接続時は、必ずタイマ動作を停止させてからデータを設定してください。

備考 n = 0, 1

# 7.3 8ビット・タイマ/イベント・カウンタ50,51を制御するレジスタ

8ビット・タイマ/イベント・カウンタ50,51を制御するレジスタには、次の4種類があります。

- ・タイマ・クロック選択レジスタ5n(TCL5n)
- ・8ビット・タイマ・モード・コントロール・レジスタ5n(TMC5n)
- ・ポート・モード・レジスタ 7 (PM7)
- ・ポート7 (P7)

備考 n = 0, 1

#### (1) タイマ・クロック選択レジスタ5n (TCL5n:n=0,1)

8 ビット・タイマ/イベント・カウンタ5nのカウント・クロックおよびTl50, Tl51入力の有効エッジを設定するレジスタです。

TCL5nは、8ビット・メモリ操作命令で設定します。

RESET入力により00Hになります。

### 図 7 - 3 タイマ・クロック選択レジスタ50(TCL50)のフォーマット

 アドレス:FF71H
 リセット時:00H
 R/W

 略号
 7
 6
 5
 4
 3
 2
 1
 0

 TCL50
 0
 0
 0
 0
 TCL502
 TCL501
 TCL500

| TCL502 | TCL501 | TCL500 | カウント・クロックの選択                  |
|--------|--------|--------|-------------------------------|
| 0      | 0      | 0      | TI50の立ち下がりエッジ                 |
| 0      | 0      | 1      | TI50の立ち上がりエッジ                 |
| 0      | 1      | 0      | fx(12 MHz)                    |
| 0      | 1      | 1      | fx/2 <sup>2</sup> (3 MHz)     |
| 1      | 0      | 0      | fx/2 <sup>4</sup> (750 kHz)   |
| 1      | 0      | 1      | fx/2 <sup>6</sup> (187 kHz)   |
| 1      | 1      | 0      | fx/2 <sup>8</sup> (46.8 kHz)  |
| 1      | 1      | 1      | fx/2 <sup>10</sup> (11.7 kHz) |

- 注意 1. TCL50を同一データ以外に書き換える場合は、いったんタイマ動作を停止させてから書き換えてください。
  - 2. ビット3-7には必ず"0"を設定してください。
- 備考1. カスケード接続時、カウント・クロックの設定はTCL50のみ有効となります。
  - 2. fx:メイン・システム・クロック発振周波数
  - 3. ( )内は.fx = 12 MHz動作時。

#### 図 7 - 4 タイマ・クロック選択レジスタ51 (TCL51) のフォーマット

アドレス:FF79H リセット時:00H R/W 略号 7 6 5 4 3 2 1 0 TCL51 0 0 0 0 TCL512 TCL511 TCL510

| TCL512 | TCL511 | TCL510 | カウント・クロックの選択                  |
|--------|--------|--------|-------------------------------|
| 0      | 0      | 0      | TI51の立ち下がりエッジ                 |
| 0      | 0      | 1      | TI51の立ち上がりエッジ                 |
| 0      | 1      | 0      | fx/2 (6 MHz)                  |
| 0      | 1      | 1      | fx/2 <sup>3</sup> (1.5 MHz)   |
| 1      | 0      | 0      | fx/2 <sup>5</sup> (375 kHz)   |
| 1      | 0      | 1      | fx/2 <sup>7</sup> (93.7 kHz)  |
| 1      | 1      | 0      | fx/2 <sup>9</sup> (23.4 kHz)  |
| 1      | 1      | 1      | fx2/ <sup>11</sup> (5.85 kHz) |

- 注意 1. TCL51を同一データ以外に書き換える場合は、いったんタイマ動作を停止させてから書き換えてください。
  - 2. ビット3-7には必ず"0"を設定してください。
- 備考1.カスケード接続時、カウント・クロックの設定はTCL50のみ有効となります。
  - 2. fx:メイン・システム・クロック発振周波数
  - 3. ( ) 内は. fx = 12 MHz動作時。
- (2) 8 ビット・タイマ・モード・コントロール・レジスタ5n(TMC5n:n = 0, 1) TMC5nは、次の6種類の設定を行うレジスタです。
  - ① 8ビット・タイマ・カウンタ5n (TM5n) のカウント動作制御
  - ② 8ビット・タイマ・カウンタ5n(TM5n)の動作モードの選択
  - ③ 単体モード/カスケード接続モードの選択(TMC51のみ)
  - ④ タイマ出力F/F(フリップフロップ)の状態設定
  - ⑤ タイマF/Fの制御またはPWM (フリー・ランニング) モード時のアクティブ・レベルの選択
  - ⑥ タイマ出力の制御

TMC5nは、1 ビット・メモリ操作命令または8 ビット・メモリ操作命令で設定します。 RESET入力により00Hになります。

### 図 7 - 5 8 ビット・タイマ・モード・コントロール・レジスタ 50 (TMC50) のフォーマット

アドレス:FF70H リセット時:00H R/W

略号 7 6 5 4 3 2 1 0 TMC50 TMC506 0 0 LVS50 LVR50 TMC501 TOE50

| TCE50 | TM50のカウント動作制御                    |  |  |
|-------|----------------------------------|--|--|
| 0     | カウンタを 0 にクリア後,カウント動作禁止(プリスケーラ禁止) |  |  |
| 1     | カウント動作開始                         |  |  |

| TMC: | 506 | TM50の動作モード選択              |
|------|-----|---------------------------|
| 0    |     | TM50とCR50の一致でクリア&スタート・モード |
| 1    |     | PWM (フリー・ランニング) モード       |

| LVS50 | LVR50 | タイマ出力F/Fの状態設定    |
|-------|-------|------------------|
| 0     | 0     | 変化しない            |
| 0     | 1     | タイマ出力F/Fをリセット(0) |
| 1     | 0     | タイマ出力F/Fをセット(1)  |
| 1     | 1     | 設定禁止             |

| TMC501 | PWMモード以外(TMC506 = 0) | PWMモード (TMC506 = 1) |
|--------|----------------------|---------------------|
|        | タイマF/Fの制御            | アクティブ・レベルの選択        |
| 0      | 反転動作禁止               | ハイ・アクティブ            |
| 1      | 反転動作許可               | ロウ・アクティブ            |

| TOE50 | タイマ出力の制御       |
|-------|----------------|
| 0     | 出力禁止 (ポート・モード) |
| 1     | 出力許可           |

備考1. PWMモード時は、TCE50 = 0により、PWM出力はインアクティブ・レベルになります。

2. データ設定後にLVS50, LVR50を読み出すと、0 が読み出せます。

### 図 7 - 6 8 ビット・タイマ・モード・コントロール・レジスタ 51 (TMC51) のフォーマット

アドレス:FF78H リセット時:00H R/W

 略号
 7
 6
 5
 4
 3
 2
 1
 0

 TMC51
 TCE51
 TMC516
 0
 TMC514
 LVS51
 LVR51
 TMC511
 TOE51

| TCE51 | TM51のカウント動作制御                    |  |  |
|-------|----------------------------------|--|--|
| 0     | カウンタを 0 にクリア後,カウント動作禁止(プリスケーラ禁止) |  |  |
| 1     | カウント動作開始                         |  |  |

| TMC516 | TM51の動作モード選択              |
|--------|---------------------------|
| 0      | TM51とCR51の一致でクリア&スタート・モード |
| 1      | PWM(フリー・ランニング)モード         |

| TMC514 | 単体モード/カスケード接続モードの選択                |  |
|--------|------------------------------------|--|
| 0      | 単体モード                              |  |
| 1      | カスケード接続モード(TM50:下位タイマ, TM51:上位タイマ) |  |

| LVS51 | LVR51 | タイマ出力F/Fの状態設定    |
|-------|-------|------------------|
| 0     | 0     | 変化しない            |
| 0     | 1     | タイマ出力F/Fをリセット(0) |
| 1     | 0     | タイマ出力F/Fをセット(1)  |
| 1     | 1     | 設定禁止             |

| TMC511 | PWMモード以外(TMC516 = 0) | PWMモード (TMC516 = 1) |  |  |
|--------|----------------------|---------------------|--|--|
|        | タイマF/Fの制御            | アクティブ・レベルの選択        |  |  |
| 0      | 反転動作禁止               | ハイ・アクティブ            |  |  |
| 1      | 反転動作許可               | ロウ・アクティブ            |  |  |

| TOE51 | タイマ出力の制御       |
|-------|----------------|
| 0     | 出力禁止 (ポート・モード) |
| 1     | 出力許可           |

備考1. PWMモード時は、TCE51 = 0により、PWM出力はインアクティブ・レベルになります。

2. データ設定後にLVS51, LVR51を読み出すと, 0 が読み出せます。

### (3) ポート・モード・レジスタ7 (PM7)

ポート7の入力/出力を1ビット単位で設定するレジスタです。

P72/TO50/TI50, P73/TI51/TO51端子をタイマ出力として使用するとき, PM72, PM73およびP72, P73の 出力ラッチに 0 を設定してください。

P72/TO50/TI50, P73/TI51/TO51端子をタイマ入力として使用するとき、PM72, PM73に1を設定してください。このときP72, P73の出力ラッチは、0または1のどちらでもかまいません。

PM7は、1ビット・メモリ操作命令または8ビット・メモリ操作命令で設定します。

RESET入力により、FFHになります。

### 図7-7 ポート・モード・レジスタ7 (PM7) のフォーマット

アドレス:FF27H リセット時:FFH R/W

 略号
 7
 6
 5
 4
 3
 2
 1
 0

 PM7
 1
 1
 PM75
 PM74
 PM73
 PM72
 PM71
 PM70

| PM7n | P7n端子の入出力モードの選択(n = 0-5) |
|------|--------------------------|
| 0    | 出力モード(出力バッファ・オン)         |
| 1    | 入力モード(出力バッファ・オフ)         |

# 7.4 8ビット・タイマ/イベント・カウンタ50,51の動作

### 7.4.1 インターバル・タイマ(8ビット)としての動作

8ビット・タイマ・コンペア・レジスタ5n(CR5n)にあらかじめ設定したカウント値をインターバルとし、繰り返し割り込み要求を発生するインターバル・タイマとして動作します。

8 ビット・タイマ・カウンタ5n(TM5n)のカウント値がCR5nに設定した値と一致したとき、TM5nの値を 0 に クリアしてカウントを継続すると同時に、割り込み要求信号(INTTM5n)を発生します。

タイマ・クロック選択レジスタ5n(TCL5n)のビット0-2(TCL5n0-TCL5n2)でTM5nのカウント・クロックを選択できます。

#### [設定方法]

① 各レジスタの設定を行います。

・TCL5n : カウント・クロックの選択

・CR5n :コンペア値

・TMC5n : カウント動作停止、TM5nとCR5nの一致でクリア&スタート・モードを選択

 $(TMC5n = 0000 \times \times \times 0B \times = don't care)$ 

- ② TCE5n = 1を設定すると、カウント動作を開始します。
- ③ TM5nとCR5nの値が一致すると、INTTM5nが発生します(TM5nは00Hにクリアされます)。
- ④ 以後、同一間隔でINTTM5nが繰り返し発生します。カウント動作を停止するときは、TCE5n = 0にしてください。

備考 n = 0, 1

### 図7-8 インターバル・タイマ動作のタイミング (1/3)

### (a)基本動作



**備考1.** インターバル時間 =(N+1)×t N = 00H-FFH

2. n = 0, 1

### 図7-8 インターバル・タイマ動作のタイミング (2/3)

### (b) CR5n = 00Hの場合



### (c) CR5n = FFHの場合



備考 n = 0, 1

### 図7-8 インターバル・タイマ動作のタイミング (3/3)

### (d) CR5n変更による動作(M<N)



### (e) CR5n変更による動作(M>N)



備考 n = 0, 1

### 7.4.2 外部イベント・カウンタとしての動作

外部イベント・カウンタは、TI5nに入力される外部からのクロック・パルス数を 8 ビット・タイマ・カウンタ 5n (TM5n) でカウントするものです。

タイマ・クロック選択レジスタ5n(TCL5n)で指定した有効エッジが入力されるたびに、TM5nがインクリメントされます。エッジ指定は、立ち上がりまたは立ち下がりのいずれかを選択できます。

TM5nの計数値が 8 ビット・タイマ・コンペア・レジスタ5n(CR5n)の値と一致すると、TM5nは 0 にクリアされ、割り込み要求信号(INTTM5n)が発生します。

以後、TM5nの値とCR5nの値が一致するたびに、INTTM5nが発生します。

#### [設定方法]

- ① 各レジスタの設定を行います。
  - ・TCL5n : TI5n入力のエッジ選択

TI5nの立ち下がり→TCL5n = 00H

TI5nの立ち上がり→TCL5n = 01H

- ・CR5n :コンペア値
- ・TMC5n:カウント動作停止、TM5nとCR5nの一致でクリア&スタート・モード選択、タイマF/F反転動作禁止、タイマ出力禁止

 $(TMC5n = 0000 \times \times 00B \times = don't care)$ 

- ② TCE5n = 1を設定すると、TI5nから入力されるパルス数をカウントします。
- ③ TM5nとCR5nの値が一致すると、INTTM5nが発生します(TM5nは00Hにクリアされます)。
- ④ 以後、TM5nとCR5nの値が一致するたびに、INTTM5nが発生します。

図 7 - 9 外部イベント・カウンタ動作のタイミング(立ち上がりエッジ指定時)



備考1. N = 00H-FFH

2. n = 0, 1

### 7.4.3 方形波出力(8ビット分解能)としての動作

8 ビット・タイマ・コンペア・レジスタ5n(CR5n)にあらかじめ設定した値で決まるインターバルの、任意の 周波数の方形波出力として動作します。

8 ビット・タイマ・モード・コントロール・レジスタ5n(TMC5n)のビット 0(TOE5n)に 1 を設定することにより、CR5nにあらかじめ設定したカウント値で決まるインターバルでTO5nの出力状態が反転します。これにより、任意の周波数の方形波出力(デューティ= 50%)が可能です。

### [設定方法]

① 各レジスタの設定を行います。

・ポート・ラッチ(P72, P73)<sup>注</sup>、ポート・モード・レジスタ(PM72, PM73)<sup>注</sup>に" 0"を設定

・TCL5n : カウント・クロックの選択

・CR5n :コンペア値

・TMC5n : カウント動作停止、TM5nとCR5nの一致でクリア&スタート・モード

| LVS5n | LVR5n | タイマ出力F/Fの状態設定 |  |
|-------|-------|---------------|--|
| 1     | 0     | ハイ・レベル出力      |  |
| 0     | 1     | ロウ・レベル出力      |  |

タイマ出力F/Fの反転許可

タイマ出力許可→TOE5n = 1

- ② TCE5n = 1を設定すると、カウント動作を開始します。
- ③ TM5nとCR5nの値が一致すると、タイマ出力F/Fが反転します。

また、INTTM5nが発生し、TM5nは00Hにクリアされます。

④ 以後、同一間隔でタイマ出力F/Fが反転し、TO5nから方形波が出力されます。 周波数は次のようになります。

• 周波数 = fcnt/2 (N+1)

(N = 00H-FFH, fcnt : カウント・クロック)

注 8 ビット・タイマ/イベント・カウンタ50: P72, PM72 8 ビット・タイマ/イベント・カウンタ51: P73, PM73

#### 図7-10 方形波出力動作のタイミング



注 TO5n出力の初期値は、8 ビット・タイマ・モード・コントロール・レジスタ5n(TMC5n)のビット 2、3 (LVR5n, LVS5n) で設定できます。

備考1. N = 00H-FFH

2. n = 0, 1

### 7.4.4 8ビットPWM出力としての動作

8 ビット・タイマ・モード・コントロール・レジスタ5n(TMC5n)のビット6(TMC5n6)を"1"に設定することにより、PWM出力として動作します。

8 ビット・タイマ・コンペア・レジスタ5n(CR5n)に設定した値で決まるデューティ比のパルスを、TO5nから出力します。

PWMパルスのアクティブ・レベルの幅は、CR5nに設定してください。また、アクティブ・レベルは、TMC5nのビット1(TMC5n1)により選択できます。

カウント・クロックは、タイマ・クロック選択レジスタ5n(TCL5n)のビット0-2(TCL5n0-TCL<math>5n2)で選択できます。

TMC5nのビット0(TOE5n)により、PWM出力の許可/禁止が選択できます。

・周期 = カウント・クロック×256

注意 PWMモード時のCR5nの書き換えは、1周期に1回のみ可能です。

備考 n = 0, 1

#### (1) PWM出力の基本動作

#### [設定方法]

① 各レジスタの設定を行います。

・ポート・ラッチ(P72, P73)<sup>注</sup>、ポート・モード・レジスタ(PM72, PM73)<sup>注</sup>に" 0"を設定

・TCL5n : カウント・クロックの選択

・CR5n :コンペア値

・TMC5n :カウント動作停止、PWMモード選択、タイマ出力F/F変化なし

| TMC5n1 | アクティブ・レベルの選択 |
|--------|--------------|
| 0      | ハイ・アクティブ     |
| 1      | ロウ・アクティブ     |

タイマ出力許可

② TCE5n = 1に設定すると、カウント動作を開始します。 カウント動作を停止するときは、TCE5nに"0"を設定してください。

注 8 ビット・タイマ/イベント・カウンタ50: P72, PM72 8 ビット・タイマ/イベント・カウンタ51: P73, PM73

#### [PWM出力の動作]

- ① カウント動作を開始すると、PWM出力(TO5nからの出力)はオーバフローが発生するまでインアクティブ・レベルを出力します。
- ② オーバフローが発生すると、アクティブ・レベルを出力します。アクティブ・レベルは、CR5nと 8 ビット・タイマ・カウンタ5n (TM5n) のカウント値が一致するまで出力されます。
- ③ CR5nとカウント値が一致したあとのPWM出力は、再度オーバフローが発生するまでインアクティブ・レベルを出力します。
- ④ 以後、カウント動作が停止されるまで②、③を繰り返します。
- ⑤ TCE5n = 0によりカウント動作を停止すると、PWM出力はインアクティブ・レベルになります。

備考 n = 0, 1

#### 図7-11 PWM出力の動作タイミング

### (a) 基本動作(アクティブ・レベル = Hのとき)



#### (b) CR5n = 0の場合



### (c) CR5n = FFHの場合



備考 n = 0, 1

### (2) CR5n変更による動作

図7-12 CR5n変更による動作のタイミング

(a) TM5n>CR5nのときに、CR5nの値をN→Mに変更した場合



(b) TM5n < CR5nのときに, CR5nの値をN→Mに変更した場合



備考 n = 0, 1

### 7.4.5 インターバル・タイマ(16ビット)としての動作

8 ビット・タイマ・モード・コントロール・レジスタ51(TMC51)のビット 4 (TMC514)に"1"を設定することにより、16ビット分解能のタイマ/カウンタ・モードになります。

8 ビット・タイマ・コンペア・レジスタ(CR50, CR51)にあらかじめ設定したカウント値をインターバルとし、繰り返し割り込み要求を発生するインターバル・タイマとして動作します。

### [設定方法]

- ① 各レジスタの設定を行います。
  - ・TCL50 : TM50はカウント・クロック選択
  - カスケード接続するTM51は設定不要
    ・CR50、CR51 : コンペア値(各コンペア値とも00H-FFHの設定が可能)
  - ・TMC50, TMC51: TM50とCR50 (TM51とCR51) の一致でクリア&スタート・モードを選択

TM50→TMC50 = 0000 $\times$  $\times$  $\times$ 0B  $\times$ : don't care
TM51→TMC51 = 0001 $\times$  $\times$  $\times$ 0B  $\times$ : don't care

- ② 先にTMC51をTCE51 = 1に設定し、そのあとTMC50をTCE50 = 1に設定することにより、カウント動作を開始します。
- ③ カスケード接続されたタイマのTM50とCR50の値が一致すると、TM50のINTTM50が発生します(TM50、TM51は00Hにクリアされます)。
- ④ 以後、同一間隔でINTTM50が繰り返し発生します。
- 注意1. コンペア・レジスタ (CR50, CR51) は、必ずタイマ動作を停止させてから設定してください。
  - 2. カスケード接続で使用している場合でも、TM51のカウント値がCR51と一致すると、TM51のINTTM51が発生してしまいます。TM51は、割り込み禁止のため必ずマスクしてください。
  - 3. TCE50, TCE51は, TM51, TM50の順にセットしてください。
  - 4. カウントの再スタート/ストップは, TM50のTCE50のみ1/0に設定することにより, 動作/停止できます。

図7-13に、16ビット分解能カスケード接続モードのタイミング例を示します。

図 7-13 16ビット分解能カスケード接続モード



## 7.5 プログラム・リスト

注意 このサンプル・プログラムは、半導体製品の動作例、応用例を説明するために、例示的に示したものです。 したがって、これらの情報をお客様の機器に使用される場合には、お客様の責任において評価を実施し設計 をしてください。

### 7.5.1 インターバル・タイマ(8ビット)

```
/*
         タイマ50動作サンプル
     インターバルタイマ設定例(周期変更は割り込み処理で)
      data[0]:データ設定フラグ(00以外で値変更)
      data[1]:設定データ
#pragma sfr
#pragma EI
#pragma DI
#pragma interrupt INTTM50 intervalint rb2
    unsigned char data[2]; /* データ領域 */
void main(void)
{
                            /* 高速動作モード設定 */
     PCC = 0x0;
     data[0] = 0;
                            /* データ領域クリア */
     data[1] = 0;
                            /* ポート設定
     P7 = 0b11111011;
                            /* TO50を使用する場合 */
     PM7.2 = 0;
                            /* P72を出力に設定 */
                            /* 割り込み設定
     TMMK50 = 0;
                            /* INTTM50割り込みマスク解除 */
                            /* タイマ50の設定
     TMC50 = 0b00000111;
                            /* クリア&スタート・モード, 初期値□
                            /* 立ち上がり,立ち下がりの両エッジ */
     TCL50 = 0b00000101;
                            /* カウント・クロックはfx/2^6
                            /* 初期値として1msのインターバル設定 */
     CR50 = 131;
                            /* タイマ・スタート
     TCE50 = 1;
     EI();
                            /* ダミーのループ */
     while(1);
}
/* INTTM50割り込み関数 */
void intervalint()
     if(data[0] != 0)
           CR50 = data[1]; /* 新しい設定値をセット */data[0] = 0; /* 要求フラグをクリア */
     }
}
```

### 7.5.2 外部イベント・カウンタ

```
タイマ50動作サンプル
イベントカウンタ設定例
     data :カウントアップフラグ
#pragma sfr
#pragma EI
#pragma DI
#pragma interrupt INTTM50 intervalint rb2
  unsigned char data; /* データ領域 */
void main(void)
                         /* 高速動作モード設定 */
/* データ領域クリア */
     PCC = 0x0;
     data = 0;
                           /* ポート設定
     PM7.2 = 1;
                           /* P72を入力に設定 */
                           /* 割り込み設定
     TMMK50 = 0;
                           /* INTTM50割り込みマスク解除 */
                        /* タイマ50の設定
/* クリア&スタート・モード
/* TI50の立ち上がりエッジを指定
     TMC50 = 0b00000000;
TCL50 = 0b00000001;
                          /* 初期値として, N=16を設定 */
     CR50 = 0x10;
                           /* タイマ・スタート
     TCE50 = 1;
     EI();
    実行させたい処理を記述する
                                * /
     while(data == 0);
                          /* カウント・アップ待ち */
/*
 以降にカウントアップ後の処理を記述する
                               * /
/* INTTM50割り込み関数 */
void intervalint()
                         /* カウント・アップ・フラグをセット */
    data = 0xff;
    TCE50 = 0;
                           /* タイマ停止
}
```

### 7.5.3 インターバル・タイマ(16ビット)

```
/*
                 タイマ5動作サンプル
                カスケード接続設定例
                                                 * /
/*
#pragma sfr
#pragma EI
#pragma DI
                              /* CRにセットする周期データ */
#define intervalTM5 130
#pragma interrupt INTTM50 ppgint rb2
     unsigned char ppgdata[2];
                              /* タイマ5にセットするデータ領域 */
void main(void)
      int interval;
      interval = intervalTM5;
      PCC = 0x0;
                              /* 高速動作モード選択 */
                              /* CR50データ・クリア */
      ppgdata[0] = 0;
                              /* CR51データ・クリア */
      ppgdata[1] = 0;
                              /* ポート設定 */
                              /* P72をクリア */
      P7 = 0b11111011;
                              /* P72を出力に設定 */
      PM7.2 = 0;
                              /* 割り込み設定 */
      TMMK50 = 0;
                              /* INTTM50割り込みマスク解除 */
                              /* INTTM51割り込みマスク設定 */
      TMMK51 = 1;
                              /* タイマ5の設定 */
                              /* カウント・クロックはfx/2^6 */
      TCL50 = 0b00000101;
                              /* CR50にコンペア・レジスタ下位を設定 */
      CR50 = interval & 0xff;
                              /* CR51にコンペア・レジスタ上位を設定 */
      CR51 = interval >> 8;
                              /* 一致で反転,初期値1 */
      TMC50 = 0b00000111;
      TMC51 = 0b00010000;
                              /* カスケード・モード */
      TCE51 = 1;
      TCE50 = 1;
                              /* タイマ・スタート */
      EI();
      while (1);
}
/* タイマ5割り込み関数 */
void ppgint()
      unsigned int work;
      work = ppgdata[0]+ppgdata[1]*0x100;
      if (work != 0)
            TCE50 = 0;
            CR51 = work >> 8;
            CR50 = work & 0xff;
            ppgdata[0] = 0;
            ppgdata[1] = 0;
            if (work != 0xffff)
                  TCE50 = 1; /* タイマ再開 */
            }
      }
}
```

# 7.6 8ビット・タイマ/イベント・カウンタ50,51の注意事項

#### (1) タイマ・スタート時の誤差

タイマ・スタート後、一致信号が発生するまでの時間は、最大で1クロック分の誤差が生じます。これは、カウント・パルスに対して8ビット・タイマ・カウンタ5n(TM5n)が非同期でスタートするためです。

### 図7-14 8ビット・タイマ・カウンタ5n (TM5n) のスタート・タイミング



#### (2) STOPモードまたはメイン・システム・クロック停止モードの設定について

TI5n入力を選択している場合を除き、STOPモードまたはメイン・システム・クロック停止モードに設定する前は必ずTCE5n = 0にしてください。

メイン・システム・クロック発振開始時に、タイマが誤動作する可能性があります。

#### (3) タイマ動作中のTM5n (n = 0, 1) 読み出しについて

動作中のTM5nを読み出す場合、カウント・クロックが一時停止するため、選択するカウント・クロックは、CPUクロックの2周期分より長いハイ/ロウ・レベルのある波形を選択してください。たとえば、CPU クロック(fcpu)がfxのとき、選択するカウント・クロックがfx/4以下であれば読み出すことができます。

備考 n = 0, 1

# 第8章 時計用タイマ

## 8.1 時計用タイマの機能

時計用タイマには、次のような機能があります。

### (1) 時計用タイマ

メイン・システム・クロックまたはサブシステム・クロックを使用することで、2<sup>14</sup>/fw秒の時間間隔で割り込み要求(INTWT)を発生します。

### (2) インターバル・タイマ

あらかじめ設定した時間間隔で、割り込み要求(INTWTI)を発生します。 インターバル時間は表8-2を参照してください。

時計用タイマとインターバル・タイマは、同時に使用できます。

図8-1に、時計用タイマのブロック図を示します。

クリア  $fx/2^7$ 5ビット・カウンタ → INTWT 9 ビット・プリスケーラ fw レクタ  $\frac{fw}{2^4}$  $\frac{\text{fw}}{2^5}$ クリア 27 28 29 セ レクタ ► INTWTI WTM7 WTM6 WTM5 WTM4 WTM1 WTM0 時計用タイマ動作モード・ レジスタ(WTM) 内部バス

図8-1 時計用タイマのブロック図

備考 fw :時計用タイマ・クロック周波数( $fx/2^7$ またはfxT)

fx :メイン・システム・クロック発振周波数

fxT :サブシステム・クロック発振周波数

# 8.2 時計用タイマの構成

時計用タイマは、次のハードウエアで構成されています。

表8-1 時計用タイマの構成

| 項目     | 構成                    |
|--------|-----------------------|
| カウンタ   | 5 ビット× 1 本            |
| プリスケーラ | 9ビット×1本               |
| 制御レジスタ | 時計用タイマ動作モード・レジスタ(WTM) |

# 8.3 時計用タイマを制御するレジスタ

時計用タイマを制御するレジスタには、時計用タイマ動作モード・レジスタ(WTM)があります。

### ・時計用タイマ動作モード・レジスタ(WTM)

時計用タイマのカウント・クロックおよび動作の許可/禁止、プリスケーラのインターバル時間、5 ビット・カウンタの動作制御を設定するレジスタです。

WTMは、1 ビット・メモリ操作命令または8 ビット・メモリ操作命令で設定します。 RESET入力により00Hになります。

#### 図8-2 時計用タイマ動作モード・レジスタ(WTM)のフォーマット

 アドレス: FF41H
 リセット時: 00H
 R/W

 略号
 7
 6
 5
 4
 3
 2
 1
 0

 WTM
 WTM7
 WTM6
 WTM5
 WTM4
 0
 0
 WTM1
 WTM0

| WTM7 | 時計用タイマのカウント・クロック選択           |
|------|------------------------------|
| 0    | fx/2 <sup>7</sup> (93.7 kHz) |
| 1    | fxт (32.768 kHz)             |

| WTM6 | WTM5 | WTM4 | プリスケーラのインターバル時間の選択 |
|------|------|------|--------------------|
| 0    | 0    | 0    | 2 <sup>4</sup> /fw |
| 0    | 0    | 1    | 2 <sup>5</sup> /fw |
| 0    | 1    | 0    | 2 <sup>6</sup> /fw |
| 0    | 1    | 1    | 2 <sup>7</sup> /fw |
| 1    | 0    | 0    | 2 <sup>8</sup> /fw |
| 1    | 0    | 1    | 2 <sup>9</sup> /fw |
| 上記以外 |      |      | 設定禁止               |

| WTM1 | 5 ビット・カウンタの動作制御 |
|------|-----------------|
| 0    | 動作停止後クリア        |
| 1    | スタート            |

| WTM0 | 時計用タイマの動作許可            |  |  |  |
|------|------------------------|--|--|--|
| 0    | 動作停止(プリスケーラ、タイマともにクリア) |  |  |  |
| 1    | 動作許可                   |  |  |  |

注意 時計用タイマ動作中に、カウント・クロック、インターバル時間の変更(WTMのビット4-7 (WTM4-WTM7) で設定)をしないでください。

備考1. fw :時計用タイマ・クロック周波数  $(fx/2^7$ またはfxT)

- 2. fx :メイン・システム・クロック発振周波数
- 3. fxT:サブシステム・クロック発振周波数
- 4. ( ) 内は、fx = 12 MHz、fxT = 32.768 kHz動作時

### 8.4 時計用タイマの動作

### 8.4.1 時計用タイマとしての動作

時計用タイマは、メイン・システム・クロックまたはサブシステム・クロックを使用し、一定の時間間隔(2<sup>14</sup>/fw秒)ごとに、割り込み要求(INTWT)を発生します。

割り込み要求の時間間隔は、次のようになります。

・メイン・システム・クロック(8.38 MHz)選択時 : 0.25秒

・サブシステム・クロック(32.768 KHz) 選択時 : 0.5秒

時計用タイマ動作モード・レジスタ(WTM)のビット 0(WTM0)とビット 1(WTM1)に 1 を設定するとカウント動作がスタートし、 0 を設定することにより、 5 ビット・カウンタがクリアされ、カウント動作が停止します。

また、インターバル・タイマを同時に動作させているときは、一度WTM1に0を設定したあとに再度WTM1に1を設定することにより、時計用タイマのみをゼロ秒スタートさせることができます。ただし、この場合、9 ビット・プリスケーラはクリアされないため、時計用タイマのゼロ秒スタート後最初のオーバフロー(INTWT)には、最大で $2^9$ /fw秒の誤差が発生します。

備考 fw: 時計用タイマ・クロック周波数  $(fx/2^7$  またはfxT)

### 8.4.2 インターバル・タイマとしての動作

あらかじめ設定したカウント値をインターバルとし、繰り返し割り込み要求(INTWTI)を発生するインターバル・タイマとして動作します。

時計用タイマ動作モード・レジスタ(WTM)のビット 4-6(WTM4-WTM6)により、インターバル時間を選択できます。

| WTM6 | WTM5 | WTM4 | インターバル時間           | fx = 12 MHz動作時 | fx = 8.38 MHz動作時 | fx = 4.19 MHz動作時 | fxT = 32.768 kHz動作時 |
|------|------|------|--------------------|----------------|------------------|------------------|---------------------|
| 0    | 0    | 0    | 2 <sup>4</sup> /fw | 170 μs         | 244 μs           | 488 μs           | 488 μs              |
| 0    | 0    | 1    | 2 <sup>5</sup> /fw | 341 μs         | 488 μs           | 977 μs           | 976 μs              |
| 0    | 1    | 0    | 2 <sup>6</sup> /fw | 682 μs         | 977 μs           | 1.95 ms          | 1.95 ms             |
| 0    | 1    | 1    | 2 <sup>7</sup> /fw | 1.36 ms        | 1.95 ms          | 3.91 ms          | 3.90 ms             |
| 1    | 0    | 0    | 2 <sup>8</sup> /fw | 2.73 ms        | 3.91 ms          | 7.82 ms          | 7.81 ms             |
| 1    | 0    | 1    | 2 <sup>9</sup> /fw | 5.46 ms        | 7.82 ms          | 15.6 ms          | 15.6 ms             |
| 上記以外 |      |      | 設定禁止               | •              |                  |                  |                     |

表 8 - 2 インターバル・タイマのインターバル時間

備考 fx :メイン・システム・クロック発振周波数

fxT:サブシステム・クロック発振周波数

fw : 時計用タイマ・クロック周波数( $fx/2^7$ またはfxT)

図8-3 時計用タイマ/インターバル・タイマの動作タイミング



注意 時計用タイマ・モード・コントロール・レジスタ (WTM) で時計用タイマおよび 5 ビット・カウンタ を動作許可 (WTMのビット 0 (WTM0) およびビット 1 (WTM1) を 1 にセット) したとき,設定後 の最初の割り込み要求 (INTWT) までの時間は,正確に時計用タイマの割り込み時間 (0.25秒または 0.5秒) にはなりません。これは 5 ビット・カウンタのカウント開始が 9 ビット・プリスケーラの出力 1 周期分遅れるからです。 2 回目以降は設定時間ごとにINTWT信号が発生します。

備考 fw:時計用タイマ・クロック周波数  $(fx/2^7$ またはfxT)

n:インターバル・タイマ動作の回数

( )内は、fw=32.768 kHz動作時。

# 第9章 ウォッチドッグ・タイマ

### 9.1 ウォッチドッグ・タイマの機能

ウォッチドッグ・タイマには、次のような機能があります。

### (1) ウォッチドッグ・タイマ

プログラムの暴走を検出します。暴走検出時、ノンマスカブル割り込み要求またはRESET を発生できます。

暴走検出時間は表9-2を参照してください。

#### (2) インターバル・タイマ

あらかじめ設定した時間間隔で、割り込み要求を発生します。 インターバル時間は**表 9-3** を参照してください。

注意 ウォッチドッグ・タイマ・モードとして使用するか、インターバル・タイマ・モードとして使用するか は、ウォッチドッグ・タイマ・モード・レジスタ (WDTM) で選択してください (ウォッチドッグ・タ イマとインターバル・タイマは同時に使用できません)。

図9-1にブロック図を示します。

図9-1 ウォッチドッグ・タイマのブロック図



# 9.2 ウォッチドッグ・タイマの構成

ウォッチドッグ・タイマは、次のハードウエアで構成されています。

表9-1 ウォッチドッグ・タイマの構成

| 項目     | 構成                           |
|--------|------------------------------|
| 制御レジスタ | ウォッチドッグ・タイマ・クロック選択レジスタ(WDCS) |
|        | ウォッチドッグ・タイマ・モード・レジスタ (WDTM)  |

# 9.3 ウォッチドッグ・タイマを制御するレジスタ

ウォッチドッグ・タイマを制御するレジスタには、次の2種類があります。

- ・ウォッチドッグ・タイマ・クロック選択レジスタ(WDCS)
- ・ウォッチドッグ・タイマ・モード・レジスタ (WDTM)
- (1)ウォッチドッグ・タイマ・クロック選択レジスタ(WDCS)

ウォッチドッグ・タイマおよびインターバル・タイマのオーバフロー時間を設定するレジスタです。

WDCSは、8ビット・メモリ操作命令で設定します。

RESET 入力により00Hになります。

図9-2 ウォッチドッグ・タイマ・クロック選択レジスタ (WDCS) のフォーマット

アドレス:FF42H リセット時:00H R/W

| 略号   | 7 | 6 | 5 | 4 | 3 | 2     | 1     | 0     |
|------|---|---|---|---|---|-------|-------|-------|
| WDCS | 0 | 0 | 0 | 0 | 0 | WDCS2 | WDCS1 | WDCS0 |

| WDCS2 | WDCS1 | WDCS0 | ウォッチドッグ・タイマ/インターバル・タイマのオーバフロー時間 |
|-------|-------|-------|---------------------------------|
| 0     | 0     | 0     | 2 <sup>12</sup> /fx (341 μs)    |
| 0     | 0     | 1     | 2 <sup>13</sup> /fx (682 μs)    |
| 0     | 1     | 0     | 2 <sup>14</sup> /fx (1.36 ms)   |
| 0     | 1     | 1     | 2 <sup>15</sup> /fx (2.73 ms)   |
| 1     | 0     | 0     | 2 <sup>16</sup> /fx (5.46 ms)   |
| 1     | 0     | 1     | 2 <sup>17</sup> /fx (10.9 ms)   |
| 1     | 1     | 0     | 2 <sup>18</sup> /fx (21.8 ms)   |
| 1     | 1     | 1     | 2 <sup>20</sup> /fx (87.3 ms)   |

備考1. fx:メイン・システム・クロック発振周波数

2. ( ) 内は, fx = 12 MHz動作時。

(2) ウォッチドッグ・タイマ・モード・レジスタ (WDTM)

ウォッチドッグ・タイマの動作モード、カウント許可/禁止を設定するレジスタです。 WDTMは、1ビット・メモリ操作命令または8ビット・メモリ操作命令で設定します。 RESET 入力により00Hになります。

図9-3 ウォッチドッグ・タイマ・モード・レジスタ (WDTM) のフォーマット

アドレス:FFF9H リセット時:00H R/W

| 略号   | 7   | 6 | 5 | 4     | 3     | 2 | 1 | 0 |
|------|-----|---|---|-------|-------|---|---|---|
| WDTM | RUN | 0 | 0 | WDTM4 | WDTM3 | 0 | 0 | 0 |

| RUN | ウォッチドッグ・タイマの動作モードの選択 <sup>注 1</sup> |
|-----|-------------------------------------|
| 0   | カウントの停止                             |
| 1   | カウンタをクリアし、カウントを開始                   |

| WDTM4 | WDTM3 | ウォッチドッグ・タイマの動作モードの選択 <sup>注 2</sup> |
|-------|-------|-------------------------------------|
| 0     | ×     | インターバル・タイマ・モード <sup>注 3</sup>       |
|       |       | (オーバフロー発生時,マスカブル割り込み要求発生)           |
| 1     | 0     | ウォッチドッグ・タイマ・モード1                    |
|       |       | (オーバフロー発生時,ノンマスカブル割り込み要求発生)         |
| 1     | 1     | ウォッチドッグ・タイマ・モード 2                   |
|       |       | (オーバフロー発生時,リセット動作を起動)               |

- 注 1. RUNは、一度 1 にセットされると、ソフトウェアで 0 にクリアすることはできません。したがって、カウントを開始すると、 $\overline{\text{RESET}}$  入力以外で停止させることはできません。
  - 2. WDTM3, WDTM4は、一度 1 にセットされると、ソフトウエアで 0 にクリアすることはできません。
  - 3. RUNに1を設定した時点でインターバル・タイマとして動作を開始します。
- 注意 RUNに1をセットし、ウォッチドッグ・タイマをクリアしたとき、実際のオーバフロー時間は、ウォッチドッグ・タイマ・クロック選択レジスタ(WDCS)で設定した時間より最大2º/fx秒短くなります。

備考 X:don't care

## 9.4 ウォッチドッグ・タイマの動作

### 9.4.1 ウォッチドッグ・タイマとしての動作

ウォッチドッグ・タイマ・モード・レジスタ(WDTM)のビット4(WDTM4)に1を設定することにより、プログラムの暴走を検出するウォッチドッグ・タイマとして動作します。

ウォッチドッグ・タイマ・クロック選択レジスタ(WDCS)のビット0-2(WDCS0-WDCS2)でウォッチドッグ・タイマの暴走検出時間間隔を選択できます。WDTMのビット7(RUN)に1を設定することにより、カウント動作を開始します。カウント動作を開始したあと、設定した暴走検出時間間隔内にRUNに再度1を設定すると、ウォッチドッグ・タイマはクリアされ、再度カウント動作を開始します。

RUNに1がセットされず、暴走検出時間を越えてしまった場合は、WDTMのビット3(WDTM3)の値により、システム・リセットまたはノンマスカブル割り込み要求が発生します。

ウォッチドッグ・タイマは、HALTモード時では動作を継続しますが、STOPモード時では動作を停止します。 したがって、STOPモードに入る前にRUNを1に設定し、ウォッチドッグ・タイマをクリアしたあと、STOP命令 を実行してください。

- 注意1. 実際の暴走検出時間は、設定時間に対して最大2<sup>8</sup>/fx秒短くなる場合があります。
  - 2. CPUクロックにサブシステム・クロックを選択しているとき、ウォッチドッグ・タイマのカウント動作を停止します。

表9-2 ウォッチドッグ・タイマの暴走検出時間

| 暴走検出時間                        |  |  |  |  |  |
|-------------------------------|--|--|--|--|--|
| 2 <sup>12</sup> /fx (341 μs)  |  |  |  |  |  |
| 2 <sup>13</sup> /fx (682 μs)  |  |  |  |  |  |
| 2 <sup>14</sup> /fx (1.36 ms) |  |  |  |  |  |
| 2 <sup>15</sup> /fx (2.73 ms) |  |  |  |  |  |
| 2 <sup>16</sup> /fx (5.46 ms) |  |  |  |  |  |
| 2 <sup>17</sup> /fx (10.9 ms) |  |  |  |  |  |
| 2 <sup>18</sup> /fx (21.8 ms) |  |  |  |  |  |
| 2 <sup>20</sup> /fx (87.3 ms) |  |  |  |  |  |

備考1. fx:メイン・システム・クロック発振周波数

2. ( ) 内は. fx = 12 MHz動作時。

### 9.4.2 インターバル・タイマとしての動作

ウォッチドッグ・タイマ・レジスタ(WDTM)のビット4(WDTM4)に0を設定することにより、あらかじめ設定したカウント値をインターバルとし、繰り返し割り込み要求を発生するインターバル・タイマとして動作します。

ウォッチドッグ・タイマ・クロック選択レジスタ(WDCS)のビット 0-2(WDCS0-WDCS2)でインターバル・タイマのインターバル時間を選択できます。WDTMのビット 7(RUN)に 1 を設定することにより、インターバル・タイマとして動作を開始します。

インターバル・タイマとして動作しているとき、割り込みマスク・フラグ(WDTMK)と優先順位指定フラグ (WDTPR) が有効となり、マスカブル割り込み要求(INTWDT)を発生させることができます。INTWDTのディフォールト優先順位は、マスカブル割り込みの中で最も高く設定されています。

インターバル・タイマは、HALTモード時では動作を継続しますが、STOPモード時では動作を停止します。したがって、STOPモードに入る前にRUNを 1 に設定し、インターバル・タイマをクリアしたあと、STOP命令を実行してください。

- 注意 1. 一度WDTMのビット 4 (WDTM4) に 1 を設定する (ウォッチドッグ・タイマ・モードを選択する) と、 $\overline{\text{RESET}}$  入力されないかぎり、インターバル・タイマ・モードにはなりません。
  - 2. WDTMで設定した直後のインターバル時間は、設定時間に対して最大2º/fx秒短くなる場合があります。
  - 3. CPUクロックにサブシステム・クロックを選択しているとき、ウォッチドッグ・タイマのカウント動作を停止します。

表9-3 インターバル・タイマのインターバル時間

| インターバル時間                      |
|-------------------------------|
| 2 <sup>12</sup> /fx (341 μs)  |
| 2 <sup>13</sup> /fx (682 μs)  |
| 2 <sup>14</sup> /fx (1.36 ms) |
| 2 <sup>15</sup> /fx (2.73 ms) |
| 2 <sup>16</sup> /fx (5.46 ms) |
| 2 <sup>17</sup> /fx (10.9 ms) |
| 2 <sup>18</sup> /fx (21.8 ms) |
| 2 <sup>20</sup> /fx (87.3 ms) |

備考1. fx:メイン・システム・クロック発振周波数

2. ( ) 内は, fx = 12 MHz動作時。

# 第10章 クロック出力/ブザー出力制御回路

# 10.1 クロック出力/ブザー出力制御回路の機能

クロック出力はリモコン送信時のキャリア出力や周辺ICに供給するクロックを出力する機能です。クロック出力選択レジスタ(CKS)で選択したクロックを出力します。

また、ブザー出力はCKSで選択したブザー周波数の方形波を出力する機能です。

図10-1にクロック出力/ブザー出力制御回路のブロック図を示します。

図10-1 クロック出力/ブザー出力制御回路のブロック図



# 10.2 クロック出力/ブザー出力制御回路の構成

クロック出力/ブザー出力制御回路は、次のハードウエアで構成されています。

表10-1 クロック出力/ブザー出力制御回路の構成

| 項目     | 構 成               |
|--------|-------------------|
| 制御レジスタ | クロック出力選択レジスタ(CKS) |
|        | ポート・モード・レジスタ(PM7) |
|        | ポート7 (P7)         |

# 10.3 クロック出力/ブザー出力制御回路を制御するレジスタ

クロック出力/ブザー出力制御回路は、次の3種類のレジスタで制御します。

- ・クロック出力選択レジスタ(CKS)
- ・ポート・モード・レジスタ (PM7)
- ・ポート7 (P7)

#### (1) クロック出力選択レジスタ (CKS)

クロック出力(PCL),ブザー周波数出力(BUZ)の出力許可/禁止、および出力クロックを設定するレジスタです。

CKSは、1 ビット・メモリ操作命令または8 ビット・メモリ操作命令で設定します。 RESET 入力により、00Hになります。

### 図10-2 クロック出力選択レジスタ (CKS) のフォーマット

アドレス:FF40H リセット時:00H R/W

| 略号  | 7    | 6    | 5    | 4    | 3    | 2    | 1    | 0    |
|-----|------|------|------|------|------|------|------|------|
| CKS | BZOE | BCS1 | BCS0 | CLOE | CCS3 | CCS2 | CCS1 | CCS0 |

| BZOE | BUZの出力許可/禁止の指定               |
|------|------------------------------|
| 0    | クロック分周回路動作停止。BUZ = ロウ・レベル固定。 |
| 1    | クロック分周回路動作許可。BUZ出力許可。        |

| BCS1 | BCS0 | BUZの出力クロックの選択                 |
|------|------|-------------------------------|
| 0    | 0    | fx/2 <sup>10</sup> (11.7 kHz) |
| 0    | 1    | fx/2 <sup>11</sup> (5.85 kHz) |
| 1    | 0    | fx/2 <sup>12</sup> (2.92 kHz) |
| 1    | 1    | fx/2 <sup>13</sup> (1.46 kHz) |

| CLOE | PCLの出力許可/禁止の指定               |
|------|------------------------------|
| 0    | クロック分周回路動作停止。PCL = ロウ・レベル固定。 |
| 1    | クロック分周回路動作許可。PCL出力許可。        |

| CCS3 | CCS2 | CCS1 | CCS0 | PCLの出力クロックの選択                |
|------|------|------|------|------------------------------|
| 0    | 0    | 0    | 0    | fx (12 MHz)                  |
| 0    | 0    | 0    | 1    | fx/2 (6 MHz)                 |
| 0    | 0    | 1    | 0    | fx/2 <sup>2</sup> (3 MHz)    |
| 0    | 0    | 1    | 1    | fx/2 <sup>3</sup> (1.5 MHz)  |
| 0    | 1    | 0    | 0    | fx/2 <sup>4</sup> (750 kHz)  |
| 0    | 1    | 0    | 1    | fx/2 <sup>5</sup> (375 kHz)  |
| 0    | 1    | 1    | 0    | fx/2 <sup>6</sup> (187 kHz)  |
| 0    | 1    | 1    | 1    | fx/2 <sup>7</sup> (93.7 kHz) |
| 1    | 0    | 0    | 0    | fxT (32.768 kHz)             |
| 上記以外 |      |      |      | 設定禁止                         |

備考1. fx :メイン・システム・クロック発振周波数

2. fxT:サブシステム・クロック発振周波数

3. ( )内は、fx = 12 MHzまたはfxT = 32.768 kHz動作時。

## (2) ポート・モード・レジスタ (PM7)

ポート7の入力/出力を1ビット単位で設定するレジスタです。

P74/PCL端子をクロック出力機能として、P75/BUZ端子をブザー出力機能として使用するとき、PM74、PM75およびP74、P75の出力ラッチに0を設定してください。

PM7は、1ビット・メモリ操作命令または8ビット・メモリ操作命令で設定します。

RESET 入力により、FFHになります。

図10-3 ポート・モード・レジスタ7 (PM7) のフォーマット

アドレス:FF27H リセット時:FFH R/W

| 略号  | 7 | 6 | 5    | 4    | 3    | 2    | 1    | 0    |
|-----|---|---|------|------|------|------|------|------|
| PM7 | 1 | 1 | PM75 | PM74 | PM73 | PM72 | PM71 | PM70 |

| PM7n | P7n端子の入出カモードの選択(n = 0-5) |
|------|--------------------------|
| 0    | 出力モード(出力バッファ・オン)         |
| 1    | 入力モード(出力バッファ・オフ)         |

# 10.4 クロック出力/ブザー出力制御回路の動作

## 10.4.1 クロック出力としての動作

クロック・パルスは、次の手順で出力します。

- ① クロック出力選択レジスタ(CKS)のビット 0-3(CCS0-CCS3)でクロック・パルスの出力周波数を選択する(クロック・パルスの出力は禁止の状態)。
- ② CKSのビット4 (CLOE) に1を設定し、クロック出力を許可する。
  - **備考** クロック出力制御回路は、クロック出力の出力許可/禁止を切り替えるときに、幅の狭いパルスは出力されないようになっています。図10-4に示すように、必ずクロックのロウ期間から出力を開始します(図中の\*印参照)。また、停止する場合には、クロックのハイ・レベルを保証してから出力を停止します。

図10-4 リモコン出力応用例



## 10.4.2 ブザー出力としての動作

ブザー周波数は、次の手順で出力します。

- ① クロック出力選択レジスタ (CKS) のビット 5, 6 (BCS0, BCS1) でブザー出力周波数を選択する (ブザー出力は禁止の状態)。
- ② CKSのビット7 (BZOE) に1を設定し、ブザー出力を許可する。

# 第11章 8 ビットA/Dコンバータ ( μ PD780024ASサブシリーズ)

# 11.1 A/Dコンバータの機能

A/Dコンバータは、アナログ入力をディジタル値に変換する8ビット分解能コンバータで、最大4チャネル(ANIO-ANI3)のアナログ入力を制御できる構成になっています。

## (1) ハードウエア・スタート

トリガ入力(ADTRG:立ち上がり、立ち下がり、立ち上がりと立ち下がりの両エッジの指定が可能)により変換開始。

## (2) ソフトウエア・スタート

A/Dコンバータ・モード・レジスタ 0 (ADMO) を設定することにより変換開始。

アナログ入力をANIO-ANI3から1チャネル選択し、A/D変換を行ってください。A/D変換の動作は、ハードウエア・スタート時ではA/D変換動作終了後停止し、割り込み要求(INTADO)を発生します。ソフトウエア・スタート時では、A/D変換動作を繰り返し行います。A/D変換を1回終了するたびに、INTADOを発生します。

注意  $\mu$  PD78F0034BSは10ビットA/Dコンバータを内蔵していますが、デバイス・ファイル DF780024を使用 することにより、8 ビットA/Dコンバータとして動作可能になります。



注

ADS01 ADS00

アナログ入力チャネル指定

レジスタ 0 (ADS0)

トリガ・イネーブル

ADCS0 TRG0 FR02 FR01 FR00 EGA01 EGA00

内部バス

図11-1 8ビットA/Dコンバータのブロック図

注 EGP, EGNレジスタのビット 3 で外部割り込みの有効エッジ指定(図15-5 外部割り込み立ち上がりエッジ許可レジスタ(EGP),外部割り込み立ち下がりエッジ許可レジスタ(EGN)のフォーマット参照)。

A/Dコンバータ・モード・

レジスタ 0 (ADMO)

(ADCR0)

# 11.2 A/Dコンバータの構成

A/Dコンバータは、次のハードウエアで構成しています。

表11-1 A/Dコンバータの構成

| 項目       | 構成                         |
|----------|----------------------------|
| アナログ入力   | 4 チャネル(ANIO-ANI3)          |
| ハードトリガ入力 | 1本 (ADTRG)                 |
| レジスタ     | 逐次変換レジスタ(SAR)              |
|          | A/D変換結果レジスタ 0 (ADCR0)      |
| 制御レジスタ   | A/Dコンバータ・モード・レジスタ 0 (ADMO) |
|          | アナログ入力チャネル指定レジスタ 0 (ADS0)  |

#### (1)逐次変換レジスタ(SAR)

アナログ入力の電圧値と直列抵抗ストリングからの電圧タップ(比較電圧)の値を比較し、その結果を最上位ビット(MSB)から保持するレジスタです。

最下位ビット(LSB)まで保持すると(A/D変換終了), SARの内容はA/D変換結果レジスタ 0(ADCR0)に転送されます。

#### (2) A/D変換結果レジスタ 0 (ADCRO)

A/D変換結果を格納する8ビットのレジスタです。A/D変換が終了するたびに、逐次変換レジスタから変換結果がロードされます。

ADCROは、8ビット・メモリ操作命令で読み出します。

RESET 入力により、00Hになります。

注意 A/Dコンバータ・モード・レジスタ 0 (ADMO), アナログ入力チャネル指定レジスタ 0 (ADSO) に対して書き込み動作を行ったとき, ADCROの内容は不定となることがあります。変換結果は,変換動作終了後, ADMO, ADSOに対して書き込み動作を行う前に読み出してください。上記以外のタイミングでは,正しい変換結果が読み出されないことがあります。

## (3) サンプル&ホールド回路

サンプル&ホールド回路は、セレクタで選択されたアナログ入力端子の入力信号をA/D変換開始時にサンプリングし、そのサンプリングしたアナログ入力電圧値をA/D変換中は保持します。

## (4) 電圧コンパレータ

電圧コンパレータは、サンプリングしたアナログ入力電圧と直列抵抗ストリングの出力電圧を比較します。

## (5) 直列抵抗ストリング

直列抵抗ストリングはAVREF-AVss間に接続されており、アナログ入力と比較する電圧を発生します。

#### (6) ANIO-ANI3端子

A/Dコンバータへの4チャネルのアナログ入力端子です。A/D変換するアナログ信号を入力します。ANIO-ANI3は、ディジタル入力兼用のアナログ入力端子です。

- 注意 1. ANIO-ANI3入力電圧は規格の範囲内でご使用ください。特にAVREF以上, AVSS以下(絶対最大定格の範囲内でも)の電圧が入力されると、そのチャネルの変換値が不定となり、またほかのチャネルの変換値にも影響を与えることがあります。
  - 2. アナログ入力(ANIO-ANI3)端子は入力ポート(P10-P13)端子と兼用になっています。ANIO-ANI3のいずれかを選択してA/D変換をする場合,変換中にポート1に対してアクセスしないでください。変換分解能が低下することがあります。
  - 3. A/D変換中の端子に隣接する端子へディジタル・パルスを印加すると、カップリング・ノイズによってA/D変換値が期待どおりに得られないことがあります。したがって、A/D変換中の端子に 隣接する端子へのパルス印加はしないようにしてください。

#### (7) AVREF端子

A/Dコンバータの基準電圧を入力する端子です。

AVREF、AVss間にかかる電圧に基づいて、ANIO-ANI3に入力される信号をディジタル信号に変換します。

注意 AVREF端子とAVss端子の間には数十kΩの直列抵抗ストリングが接続されています。したがって、 基準電圧源の出力インピーダンスが高い場合、AVREF端子とAVss端子の間の直列抵抗ストリングと 直列接続することになり、基準電圧の誤差が大きくなります。

#### (8) AVss端子

A/Dコンバータのクランド電位端子です。A/Dコンバータを使用しないときでも、常にVssoまたはVss1端子と同電位で使用してください。

## (9) AVDD端子

A/Dコンバータのアナログ電源端子です。A/Dコンバータを使用しないときでも、常にV<sub>DD0</sub>またはV<sub>DD1</sub>端子と同電位で使用してください。

## (10)ADTRG端子

A/Dコンバータをハードウエア・スタートするために使用する端子です。

# 11.3 A/Dコンバータを制御するレジスタ

A/Dコンバータは、次の2種類のレジスタで制御します。

- ・A/Dコンバータ・モード・レジスタ 0 (ADMO)
- ・アナログ入力チャネル指定レジスタ 0 (ADS0)
- (1) A/Dコンバータ・モード・レジスタ 0 (ADM0)

A/D変換するアナログ入力の変換時間、変換動作の開始/停止、外部トリガを設定するレジスタです。 ADMOは、1 ビット・メモリ操作命令または8 ビット・メモリ操作命令で設定します。 RESET 入力により、00Hになります。

## 図11-2 A/Dコンバータ・モード・レジスタ 0 (ADM0) のフォーマット

アドレス:FF80H リセット時:00H R/W

| 略号   | 7     | 6    | 5    | 4    | 3    | 2     | 1     | 0 |
|------|-------|------|------|------|------|-------|-------|---|
| ADM0 | ADCS0 | TRG0 | FR02 | FR01 | FR00 | EGA01 | EGA00 | 0 |

| ADCS0 | A/D変換動作の制御 |
|-------|------------|
| 0     | 変換動作停止     |
| 1     | 変換動作許可     |

| TRG0 | ソフトウエア・スタート/ハードウエア・スタートの選択 |
|------|----------------------------|
| 0    | ソフトウエア・スタート                |
| 1    | ハードウエア・スタート                |

| FR02 | FR01 | FR00 | 変換時間の選択 <sup>注 1</sup>       |
|------|------|------|------------------------------|
| 0    | 0    | 0    | 144/fx (12.0 μs)             |
| 0    | 0    | 1    | 120/fx(設定禁止 <sup>注 2</sup> ) |
| 0    | 1    | 0    | 96/fx(設定禁止 <sup>注 2</sup> )  |
| 1    | 0    | 0    | 72/fx(設定禁止 <sup>注 2</sup> )  |
| 1    | 0    | 1    | 60/fx(設定禁止 <sup>注 2</sup> )  |
| 1    | 1    | 0    | 48/fx(設定禁止 <sup>注 2</sup> )  |
| 上記以外 |      |      | 設定禁止                         |

| EGA01 | EGA00 | 外部トリガ信号,エッジ指定      |
|-------|-------|--------------------|
| 0     | 0     | エッジ検出なし            |
| 0     | 1     | 立ち下がりエッジ検出         |
| 1     | 0     | 立ち上がりエッジ検出         |
| 1     | 1     | 立ち下がり、立ち上がりの両エッジ検出 |

- 注1. A/D変換時間が、 $12 \mu$ s以上になるように設定してください。
  - 2. A/D変換時間が $12 \mu s$ 未満となりますので、設定禁止です。
- 注意 FR00-FR02を同一データ以外に書き換える場合は、いったんA/D変換動作を停止させたのちに行ってください。
- 備考1. fx:メイン・システム・クロック発振周波数
  - 2. ( ) 内は, fx =12 MHz動作時。

## (2) アナログ入力チャネル指定レジスタ 0 (ADS0)

A/D変換するアナログ電圧の入力ポートを指定するレジスタです。

ADSOは、8ビット・メモリ操作命令で設定します。

RESET 入力により、00Hになります。

## 図11-3 アナログ入力チャネル指定レジスタ 0 (ADSO) のフォーマット

アドレス:FF81H リセット時:00H R/W

| 略号   | 7 | 6 | 5 | 4 | 3 | 2              | 1     | 0     |
|------|---|---|---|---|---|----------------|-------|-------|
| ADS0 | 0 | 0 | 0 | 0 | 0 | 0 <sup>注</sup> | ADS01 | ADS00 |

| ADS01 | ADS00 | アナログ入力チャネルの指定 |
|-------|-------|---------------|
| 0     | 0     | ANI0          |
| 0     | 1     | ANI1          |
| 1     | 0     | ANI2          |
| 1     | 1     | ANI3          |

注 ビット2には必ず0を設定してください。

# 11.4 A/Dコンバータの動作

## 11.4.1 A/Dコンバータの基本動作

- ① A/D変換するチャネルをアナログ入力チャネル指定レジスタ 0 (ADSO) で 1 チャネル選択してください。
- ② 選択されたアナログ入力チャネルに入力されている電圧を、サンプル&ホールド回路がサンプリングします。
- ③ 一定時間サンプリングを行うとサンプル&ホールド回路はホールド状態となり、入力されたアナログ電圧をA/D変換が終了するまで保持します。
- ④ 逐次変換レジスタ(SAR)のビット7がセットされます。タップ・セレクタにより直列抵抗ストリング の電圧タップが(1/2)AVREFにされます。
- ⑤ 直列抵抗ストリングの電圧タップとアナログ入力との電圧差が電圧コンパレータで比較されます。もし、アナログ入力が(1/2)AVREFよりも大きければ、SARのMSBがセットされたままです。また、(1/2)AVREFよりも小さければMSBをリセットします。
- ⑥ 次にSARのビット 6 が自動的にセットされ、次の比較に移ります。ここではすでに結果がセットされているビット 7 の値によって、次に示すように直列抵抗ストリングの電圧タップが選択されます。
  - ・ビット7 = 1: (3/4) AVREF
  - ・ビット7 = 0: (1/4) AVREF

この電圧タップとアナログ入力電圧を比較し、その結果でSARのビット6が次のように操作されます。

- ・アナログ入力電圧≥電圧タップ:ビット6=1
- ・アナログ入力電圧<電圧タップ:ビット6=0
- ⑦ このような比較をSARのビットOまで続けます。
- ⑧ 8ビットの比較が終了したとき、SARには有効なディジタルの結果が残り、その値がA/D変換結果レジスタ 0 (ADCRO) に転送され、ラッチされます。

同時に、A/D変換終了割り込み要求(INTADO)を発生させることができます。

- 注意 1. A/D変換動作をスタートした直後のA/D変換値は定格を満たさないことがあります。A/D変換終 了割り込み要求(INTADO)をポーリングし、最初の変換結果を廃棄するなどの対策を行ってく ださい。
  - 2. スタンバイ・モード時, A/Dコンバータは動作停止となります。



図11-4 8ビットA/Dコンバータの基本動作

A/D変換動作は、ソフトウエアによりA/Dコンバータ・モード・レジスタ 0 (ADM0)のビット 7 (ADCS0)をリセット( 0 )するまで連続的に行われます。

A/D変換結果レジスタ 0 (ADCRO)は、 $\overline{RESET}$  により00Hとなります。

A/D変換終了は、A/D変換終了割り込み要求フラグ(ADIFO)で確認してください。

A/Dコンバータのサンプリング時間は、A/Dコンバータ・モード・レジスタ 0 (ADMO) の設定値によって異なります。また、A/Dコンバータを動作許可してから実際にサンプリングが行われるまで遅延時間が存在します。 A/D変換時間を厳密に必要とするセットの場合は、表11-2に示す内容にご注意ください。

変換時間<sup>注</sup> FR02 サンプリング時間 A/D変換開始遅延時間 FR01 FR00 MIN. MAX. 0.5/fcpu+6/fx 0.5/fcpu+8/fx 0 0 0 144/fx 20/fx 120/fx 16/fx 0 0 1 0 1 0 96/fx 12/fx 0 0 72/fx 10/fx  $0.5/f_{CPU} + 3/f_X$ 0.5/fCPU $\pm 4/f$ X 1 1 0 1 60/fx 8/fx 1 1 0 48/fx 6/fx 上記以外 設定禁止

表11-2 A/Dコンバータのサンプリング時間とA/D変換開始遅延時間

注 A/D変換時間が、 $12 \mu$  S以上になるように設定してください(fx = 12 MHz動作時)。

備考 fx :メイン・システム・クロック発振周波数

fcpu : CPUクロック周波数

## 11.4.2 入力電圧と変換結果

アナログ入力端子(ANIO-ANI3)に入力されたアナログ入力電圧と理論上のA/D変換結果(A/D変換結果レジスタ 0(ADCR0))には次式に示す関係があります。

ADCR0 = INT 
$$\left(\frac{V_{AIN}}{AV_{REF}}\right) \times 256 + 0.5$$

または,

$$(ADCR0-0.5) \times \frac{AV_{REF}}{256} \le V_{AIN} < (ADCR0+0.5) \times \frac{AV_{REF}}{256}$$

INT( ):( )内の値の整数部を返す関数

VAIN: アナログ入力電圧AVREF: AVREF端子電圧

ADCRO : A/D変換結果レジスタ 0 (ADCRO) の値

図11-5にアナログ入力電圧とA/D変換結果の関係を示します。

図11-5 アナログ入力電圧とA/D変換結果の関係



入力電圧/AV<sub>REF</sub>

## 11.4.3 A/Dコンバータの動作モード

アナログ入力チャネル指定レジスタ 0 (ADS0)によってANIO-ANI3からアナログ入力を 1 チャネル選択し、A/D変換を開始させてください。

A/D変換動作の起動方法には、次の2種類があります。

- ・ハードウエア・スタート:トリガ入力(立ち上がり,立ち下がり,立ち上がりと立ち下がりの両エッジ指定 可能)
- ・ソフトウエア・スタート:A/Dコンバータ・モード・レジスタ 0 (ADM0) を設定することにより開始

また、A/D変換が終了したら、割り込み要求信号(INTADO)を発生します。

#### (1) ハードウエア・スタートによるA/D変換動作

A/Dコンバータ・モード・レジスタ 0 (ADM0) のビット 6 (TRG0) に 1, ビット 7 (ADCS0) に 1 を設定することによってA/D変換動作の待機状態になります。外部トリガ信号 (ADTRG) が入力されると、アナログ入力チャネル指定レジスタ 0 (ADS0) で指定したアナログ入力端子に印加されている電圧のA/D変換動作を開始します。

A/D変換動作が終了すると、変換結果をA/D変換結果レジスタ 0 (ADCRO)に格納し、割り込み要求信号 (INTADO) を発生します。次のA/D変換動作が一度起動し、1回のA/D変換が終了すると、新たに外部トリガ 信号が入力されないかぎり、A/D変換動作は開始しません。

A/D変換動作中に、ADSOを書き換えると、そのとき行っていたA/D変換動作を中断し、新たに外部トリガ信号が入力されるまで待機します。外部トリガ入力信号が再度入力されると、A/D変換動作を最初から行います。A/D変換待機中にADSOを書き換えた場合、次に外部トリガ入力信号が入力された時点で、新たにA/D変換動作を開始します。

A/D変換動作中に、ADCS0に再度1を書き込むと、そのとき行っていたA/D変換動作を中断し、次に外部トリガ入力信号が入力された時点で、新たにA/D変換動作を開始します。

また、A/D変換動作中に、ADCS0に0を書き込むと、ただちにA/D変換動作を停止します。

注意 P03/INTP3/ADTRGを外部トリガ入力(ADTRG)として使用する場合は、A/Dコンバータ・モード・レジスタ 0 (ADM0) のビット 1 、2 (EGA00, EGA01) で有効エッジを指定し、割り込みマスク・フラグ (PMK3) を 1 に設定してください。

## ◆ 図11-6 ハードウエア・スタートによるA/D変換動作(立ち下がりエッジ指定時)



備考1. n = 0, 1, ······, 3

2.  $m = 0, 1, \dots, 3$ 

#### (2) ソフトウエア・スタートによるA/D変換動作

A/Dコンバータ・モード・レジスタ 0 (ADM0) のビット 6 (TRG0) に 0 、ビット 7 (ADCS0) に 1 を設定することにより、アナログ入力チャネル指定レジスタ 0 (ADS0) で指定したアナログ入力端子に印加されている電圧のA/D変換動作を開始します。

A/D変換動作が終了すると、変換結果をA/D変換結果レジスタ 0 (ADCRO)に格納し、割り込み要求信号 (INTADO) が発生します。A/D変換動作が一度起動し、1回のA/D変換が終了すると、ただちに次のA/D変換動作を開始します。新たなデータをADSOに書き込むまで繰り返しA/D変換動作を行います。

A/D変換動作中にADSOを書き換えると、そのとき行っていたA/D変換動作を中断し、新たに選択したアナログ入力チャネルのA/D変換動作を開始します。

A/D変換動作中に、ADCS0に再度 1 を書き込むと、そのとき行っていたA/D変換動作を中断し、新たにA/D変換動作を開始します。

また、A/D変換動作中に、ADCS0に0を書き込むと、ただちにA/D変換動作を停止します。

#### 図11-7 ソフトウエア・スタートによるA/D変換動作



備考1. n = 0, 1, ······, 3

2.  $m = 0, 1, \dots, 3$ 

# 11.5 A/Dコンバータ特性表の読み方

A/Dコンバータに特有な用語について説明します。

#### (1)分解能

識別可能な最小アナログ入力電圧、つまり、ディジタル出力 1 ビットあたりのアナログ入力電圧の比率を 1LSB(Least Significant Bit)といいます。1LSBのフルスケールに対する比率を%FSR(Full Scale Range)で表します。

分解能8ビットのとき

$$1LSB = 1/2^8 = 1/256$$
  
= 0.4%FSR

精度は分解能とは関係なく、総合誤差によって決まります。

#### (2)総合誤差

実測値と理論値との差の最大値を指しています。

ゼロスケール誤差、フルスケール誤差、積分直線性誤差、微分直線性誤差およびそれらの組み合わせから 生じる誤差を総合した誤差を表しています。

なお、特性表の総合誤差には量子化誤差は含まれていません。

#### (3)量子化誤差

アナログ値をディジタル値に変換するとき、必然的に生じる $\pm 1/2$ LSBの誤差です。A/Dコンバータでは、 $\pm 1/2$ LSBの範囲にあるアナログ入力電圧は、同じディジタル・コードに変換されるため、量子化誤差を避けることはできません。

なお、特性表の総合誤差、ゼロスケール誤差、フルスケール誤差、積分直線性誤差、微分直線性誤差には 含まれていません。

図11-8 総合誤差



図11-9 量子化誤差



## (4) ゼロスケール誤差

ディジタル出力が0……000から0……001に変化するときの、アナログ入力電圧の実測値と理論値(1/2LSB)との差を表します。実測値が理論値よりも大きい場合は、ディジタル出力が0……011から0……010に変化するときの、アナログ入力電圧の実測値と理論値(3/2LSB)との差を表します。

#### (5) フルスケール誤差

ディジタル出力が1……110から1……111に変化するときの、アナログ入力電圧の実測値と理論値(フルスケール-3/2LSB)との差を表します。

## (6) 積分直線性誤差

変換特性が、理想的な直線関係から外れている程度を表します。ゼロスケール誤差、フルスケール誤差を 0 としたときの、実測値と理想直線との差の最大値を表します。

#### (7) 微分直線性誤差

理想的にはあるコードを出力する幅は1LSBですが、あるコードを出力する幅の実測値と理想値との差を表します。

図11-10 ゼロスケール誤差

図11-11 フルスケール誤差





図11-12 積分直線性誤差



アナログ入力

図11-13 微分直線性誤差



## (8)変換時間

サンプリングを開始してから、ディジタル出力が得られるまでの時間を表します。 特性表の変換時間にはサンプリング時間が含まれています。

AVREF

## (9) サンプリング時間

アナログ電圧をサンプル&ホールド回路に取り込むため、アナログ・スイッチがオンしている時間です。



# 11.6 A/Dコンバータの注意事項

#### (1) スタンバイ・モード時の消費電力について

A/Dコンバータは、スタンバイ・モード時には動作が停止します。このときA/Dコンバータ・モード・レジスタ0(ADM0)のビット7(ADCS0) = 0にすることにより、消費電力を低減させることができます。 直列抵抗ストリングの回路構成を図11-14に示します。

図11-14 直列抵抗ストリングの回路構成



#### (2) ANIO-ANI3入力範囲について

ANIO-ANI3入力電圧は規格の範囲内でご使用ください。特にAVREF以上、AVSS以下(絶対最大定格の範囲内でも)の電圧が入力されると、そのチャネルの変換値が不定となります。また、ほかのチャネルの変換値にも影響を与えることがあります。

## (3) 競合動作について

- ① 変換終了時のA/D変換結果レジスタ 0 (ADCR0) ライトと命令によるADCR0リードとの競合 ADCR0リードが優先されます。リードしたあと、新しい変換結果がADCR0にライトされます。
- ② 変換終了時のADCR0ライトと外部トリガ信号入力の競合 A/D変換中の外部トリガ信号は受け付けません。したがってADCR0ライト中の外部トリガ信号も受け 付けません。
- ③ 変換終了時のADCR0ライトとA/Dコンバータ・モード・レジスタ 0 (ADM0) ライト、またはアナログ 入力チャネル指定レジスタ 0 (ADS0) ライトの競合

ADMOまたはADSOへのライトが優先されます。ADCROへのライトはされません。また、変換終了割り込み要求信号(INTADO)も発生しません。

#### (4) ANIO/P10-ANI3/P13

- ① アナログ入力(ANIO-ANI3)端子は入力ポート(P10-P13)端子と兼用になっています。
  ANIO-ANI3のいずれかを選択してA/D変換をする場合、変換中にポート1に対してアクセスしないでください。変換分解能が低下することがあります。
- ② A/D変換中の端子に隣接する端子へディジタル・パルスを印加すると、カップリング・ノイズによって A/D変換値が期待どおりに得られないこともあります。したがって、A/D変換中の端子に隣接する端子へ のパルス印加はしないようにしてください。

#### (5) AVREF端子の入力インピーダンスについて

AVREF端子とAVss端子の間には数十kΩの直列抵抗ストリングが接続されています。

したがって、基準電圧源の出力インピーダンスが高い場合、AVREF端子とAVss端子の間の直列抵抗ストリングと直列接続することになり、基準電圧の誤差が大きくなります。

## (6)割り込み要求フラグ(ADIFO)について

アナログ入力チャネル指定レジスタ 0 (ADS0)を変更しても割り込み要求フラグ(ADIF0)はクリアされません。

したがって、A/D変換中にアナログ入力端子の変更を行った場合、ADSO書き換え直前に変更前のアナログ入力に対するA/D変換結果および変換終了割り込み要求フラグがセットされる場合があります。このときADSO書き換え直後にADIFOを読み出すと、変更後のアナログ入力に対するA/D変換が終了していないにもかかわらずADIFOがセットされていることになりますので注意してください。

また、A/D変換を一度停止させて再開する場合は、再開する前にADIFOをクリアしてください。

#### 図11-15 A/D変換終了割り込み要求発生タイミング



備考1. n = 0, 1, ······, 3

2.  $m = 0, 1, \dots, 3$ 

#### (7) A/D変換スタート直後の変換結果について

A/D変換動作をスタートした直後のA/D変換値は定格を満たさないことがあります。A/D変換終了割り込み要求(INTADO)をポーリングし、最初の変換結果を廃棄するなどの対策を行ってください。

## (8) A/D変換結果レジスタ 0 (ADCRO) の読み出しについて

A/Dコンバータ・モード・レジスタ 0 (ADM0) , アナログ入力チャネル指定レジスタ 0 (ADS0) に対して書き込み動作を行ったとき、ADCROの内容は不定となることがあります。変換結果は、変換動作終了後、ADM0, ADS0に対して書き込み動作を行う前に読み出してください。上記以外のタイミングでは、正しい変換結果が読み出されないことがあります。

#### ★ (9) A/D変換結果が不定になるタイミング

A/D変換終了のタイミングとA/D変換動作を停止するタイミングが競合するとA/D変換値は不定になることがあります。そのため、A/D変換結果を読み出す場合は、A/D変換動作中に行ってください。

変換結果を読み出すタイミングを図11-16に示します。

図11-16 変換結果を読み出すタイミング(変換結果が不定値の場合)



#### (10) ボード設計上の注意

ボード上でのディジタル回路ノイズの影響を避けるために、アナログ回路はディジタル回路とできるだけ離して配置してください。特にアナログ信号線とディジタル信号線を交差させたり近接させたりすることは極力避けてください。ノイズの誘導などによってA/D変換特性が悪化する恐れがあります。

AVssoとVssoはボード上で安定しているところで1箇所、接続してください。

## (11) AVDD端子について

AVDD端子はアナログ回路の電源端子であり、ANIO-ANI3の入力回路にも電源を供給しています。 したがって、バックアップ電源に切り替えるようなアプリケーションにおいても、必ずVDDD端子と同レベルの電位を印加してください。

AVREF

VDD0

AVDD

バックアップ用
コンデンサ

Vsso

**AV**ss

7/7

図11-17 AVDD端子の処理

#### (12) AVREF端子

ノイズによる変換誤差を小さく抑えるため、AVREF端子にコンデンサを接続してください。またA/D変換動作を停止した状態から動作開始した直後は、AVREF端子にかかる電圧が不安定になり、A/D変換精度の悪化が生じる場合があります。このような場合にもAVREF端子にコンデンサを接続してください。コンデンサの接続例を図11-18に示します。

図11-18 AVREF端子とコンデンサの接続例



備考  $C1:4.7 \mu F\sim 10 \mu F$  (参考値)

C2:0.01 μF~0.1 μF (参考値)

C2は端子のできるだけ近くに接続してください。

#### (13) ANIO-ANI3端子内部等価回路と許容信号源インピーダンス

サンプリング時間内にサンプリングを完了し、十分なA/D変換精度を得るにはセンサなどの信号源のインピーダンスが十分に低い必要があります。図11-19にANIO-ANI3端子のマイコン内部の等価回路を示します。信号源のインピーダンスが高い場合には、ANIO-ANI3端子に大きな容量を接続することで見かけ上インピーダンスを低くすることができます。図11-20に回路例を示します。この場合にはロウ・パス・フィルタを構成しますので、微分係数の大きなアナログ信号には追従できなくなります。

高速なアナログ信号を変換する場合やスキャン・モードで変換する場合にはロウ・インピーダンスのバッファを挿入してください。

図11-19 ANIO-ANI3端子内部等価回路



備考 n = 0-3

表11-3 等価回路の各抵抗と容量値(参考値)

| AVREF | R1    | R2     | C1   | C2     | C3   |
|-------|-------|--------|------|--------|------|
| 2.7 V | 12 kΩ | 8 kΩ   | 8 pF | 3 pF   | 2 pF |
| 4.5 V | 4 kΩ  | 2.7 kΩ | 8 pF | 1.4 pF | 2 pF |

注意 表11-3の各抵抗と容量値は保証値ではありません。

図11-20 信号源インピーダンスが高い場合の回路例



備考 n = 0-3

## (14) ANIO-ANI3端子の入力インピーダンスについて

このA/Dコンバータでは、変換時間の約1/10程度の間、内部のサンプリング・コンデンサに充電して、サンプリングを行っています。

したがって、サンプリング中以外はリーク電流だけであり、サンプリング中にはコンデンサに充電するための電流も流れるので、入力インピーダンスは変動して意味がありません。

ただし、十分にサンプリングするためには、アナログ入力源の出力インピーダンスを10 k $\Omega$ 以下にするか、ANIO-ANI3端子に100 pF程度のコンデンサを付けることを推奨します(図11ー20参照)。

# 第12章 10ビットA/Dコンバータ (μPD780034ASサブシリーズ)

# 12.1 A/Dコンバータの機能

A/Dコンバータは、アナログ入力をディジタル値に変換する10ビット分解能コンバータで、最大4チャネル(ANIO-ANI3)のアナログ入力を制御できる構成になっています。

#### (1) ハードウエア・スタート

トリガ入力(ADTRG:立ち上がり、立ち下がり、立ち上がりと立ち下がりの両エッジの指定が可能)により変換開始。

## (2) ソフトウエア・スタート

A/Dコンバータ・モード・レジスタ 0 (ADMO) を設定することにより変換開始。

アナログ入力をANIO-ANI3から1チャネル選択し、A/D変換を行ってください。A/D変換の動作は、ハードウエア・スタート時ではA/D変換動作終了後停止し、割り込み要求(INTADO)を発生します。ソフトウエア・スタート時では、A/D変換動作を繰り返し行います。A/D変換を1回終了するたびに、INTADOを発生します。

注意  $\mu$  PD78F0034BSは10ビットA/Dコンバータを内蔵していますが、デバイス・ファイル DF780024を使用 することにより、8 ビットA/Dコンバータとして動作可能になります。



図12-1 10ビットA/Dコンバータのブロック図

注 EGP, EGNレジスタのビット 3 で外部割り込みの有効エッジ指定(図15-5 外部割り込み立ち上がりエッジ許可レジスタ(EGP),外部割り込み立ち下がりエッジ許可レジスタ(EGN)のフォーマット参照)。

# 12.2 A/Dコンバータの構成

A/Dコンバータは、次のハードウエアで構成しています。

 項目
 構成

 アナログ入力
 4 チャネル (ANIO-ANI3)

 ハードトリガ入力
 1本 (ADTRG)

 レジスタ
 逐次変換レジスタ (SAR)

 A/D変換結果レジスタ 0 (ADCR0)

 制御レジスタ
 A/Dコンバータ・モード・レジスタ 0 (ADM0)

 アナログ入力チャネル指定レジスタ 0 (ADS0)

表12-1 A/Dコンバータの構成

## (1)逐次変換レジスタ (SAR)

アナログ入力の電圧値と直列抵抗ストリングからの電圧タップ(比較電圧)の値を比較し、その結果を最上位ビット(MSB)から保持するレジスタです。

最下位ビット(LSB)まで保持すると(A/D変換終了), SARの内容はA/D変換結果レジスタ 0(ADCR0)に転送されます。

#### (2) A/D変換結果レジスタ 0 (ADCRO)

A/D変換結果を格納する16ビットのレジスタです。下位 6 ビットは "0" 固定です。A/D変換が終了するたびに、逐次変換レジスタから変換結果がロードされます。ADCR0には最上位ビット(MSB)から順に格納されます。FF17Hには変換結果の上位 8 ビットが入ります。FF16Hには変換結果の下位 2 ビットが入ります。

ADCR0は16ビット・メモリ操作命令で読み出します。

RESET 入力により、0000Hになります。

図12-2 A/D変換結果レジスタ 0 (ADCR0) のフォーマット

アドレス:FF16H, FF17H リセット値:0000H R



注意 A/Dコンバータ・モード・レジスタ 0 (ADM0), アナログ入力チャネル指定レジスタ 0 (ADS0) に対して書き込み動作を行ったとき, ADCR0の内容は不定となることがあります。変換結果は,変換動作終了後, ADM0, ADS0に対して書き込み動作を行う前に読み出してください。上記以外のタイミングでは,正しい変換結果が読み出されないことがあります。

#### (3) サンプル&ホールド回路

サンプル&ホールド回路は、セレクタで選択されたアナログ入力端子の入力信号をA/D変換開始時にサンプリングし、そのサンプリングしたアナログ入力電圧値をA/D変換中は保持します。

#### (4) 電圧コンパレータ

電圧コンパレータは、サンプリングしたアナログ入力電圧と直列抵抗ストリングの出力電圧を比較します。

#### (5) 直列抵抗ストリング

直列抵抗ストリングはAVREF-AVss間に接続されており、アナログ入力と比較する電圧を発生します。

#### (6) ANIO-ANI3端子

A/Dコンバータへの4チャネルのアナログ入力端子です。A/D変換するアナログ信号を入力します。ANIO-ANI3は、ディジタル入力兼用のアナログ入力端子です。

- 注意 1. ANIO-ANI3入力電圧は規格の範囲内でご使用ください。特にAVREF以上、AVSS以下(絶対最大定格の範囲内でも)の電圧が入力されると、そのチャネルの変換値が不定となり、またほかのチャネルの変換値にも影響を与えることがあります。
  - 2. アナログ入力(ANIO-ANI3)端子は入力ポート(P10-P13)端子と兼用になっています。ANIO-ANI3のいずれかを選択してA/D変換をする場合,変換中にポート1に対してアクセスしないでください。変換分解能が低下することがあります。
  - 3. A/D変換中の端子に隣接する端子へディジタル・パルスを印加すると、カップリング・ノイズによってA/D変換値が期待どおりに得られないことがあります。したがって、A/D変換中の端子に 隣接する端子へのパルス印加はしないようにしてください。

#### (7) AVREF端子

A/Dコンバータの基準電圧を入力する端子です。

AVREF、AVss間にかかる電圧に基づいて、ANIO-ANI3に入力される信号をディジタル信号に変換します。

注意 AVREF端子とAVss端子の間には数十kΩの直列抵抗ストリングが接続されています。したがって、 基準電圧源の出力インピーダンスが高い場合、AVREF端子とAVss端子の間の直列抵抗ストリングと 直列接続することになり、基準電圧の誤差が大きくなります。

#### (8) AVss端子

A/Dコンバータのグランド電位端子です。A/Dコンバータを使用しないときでも、常にVssoまたはVssi端子と同電位で使用してください。

## (9) AVDD端子

A/Dコンバータのアナログ電源端子です。A/Dコンバータを使用しないときでも、常にV<sub>DD0</sub>またはV<sub>DD1</sub>端子と同電位で使用してください。

## (10) ADTRG端子

A/Dコンバータをハードウエア・スタートするために使用する端子です。

# 12.3 A/Dコンバータを制御するレジスタ

A/Dコンバータは、次の2種類のレジスタで制御します。

- ・A/Dコンバータ・モード・レジスタ 0 (ADMO)
- ・アナログ入力チャネル指定レジスタ 0 (ADS0)
- (1) A/Dコンバータ・モード・レジスタ 0 (ADM0)

A/D変換するアナログ入力の変換時間、変換動作の開始/停止、外部トリガを設定するレジスタです。 ADMOは、1ビット・メモリ操作命令または8ビット・メモリ操作命令で設定します。 RESET 入力により、00Hになります。

## 図12-3 A/Dコンバータ・モード・レジスタ 0 (ADM0) のフォーマット

アドレス:FF80H リセット時:00H R/W

| 略号   | 7     | 6    | 5    | 4    | 3    | 2     | 1     | 0 |
|------|-------|------|------|------|------|-------|-------|---|
| ADM0 | ADCS0 | TRG0 | FR02 | FR01 | FR00 | EGA01 | EGA00 | 0 |

| ADCS0 | A/D変換動作の制御 |
|-------|------------|
| 0     | 変換動作停止     |
| 1     | 変換動作許可     |

| TRG0 | ソフトウエア・スタート/ハードウエア・スタートの選択 |
|------|----------------------------|
| 0    | ソフトウエア・スタート                |
| 1    | ハードウエア・スタート                |

| FR02 | FR01 | FR00 | 変換時間の選択 <sup>注 1</sup>       |  |
|------|------|------|------------------------------|--|
| 0    | 0    | 0    | 144/fx (12.0 μs)             |  |
| 0    | 0    | 1    | 120/fx(設定禁止 <sup>注 2</sup> ) |  |
| 0    | 1    | 0    | 96/fx(設定禁止 <sup>注 2</sup> )  |  |
| 1    | 0    | 0    | 72/fx(設定禁止 <sup>注 2</sup> )  |  |
| 1    | 0    | 1    | 60/fx(設定禁止 <sup>注 2</sup> )  |  |
| 1    | 1    | 0    | 48/fx(設定禁止 <sup>注 2</sup> )  |  |
| 上記以外 |      |      | 設定禁止                         |  |

| EGA01 | EGA00 | 外部トリガ信号、エッジ指定      |  |  |  |  |
|-------|-------|--------------------|--|--|--|--|
| 0     | 0     | エッジ検出なし            |  |  |  |  |
| 0     | 1     | 立ち下がりエッジ検出         |  |  |  |  |
| 1     | 0     | 立ち上がりエッジ検出         |  |  |  |  |
| 1     | 1     | 立ち下がり、立ち上がりの両エッジ検出 |  |  |  |  |

- 注1. A/D変換時間が、 $12 \mu$ s以上になるように設定してください。
  - 2. A/D変換時間が $12 \mu s$ 未満となりますので、設定禁止です。
- 注意 FR00-FR02を同一データ以外に書き換える場合は、いったんA/D変換動作を停止させたのちに行ってください。
- 備考1. fx:メイン・システム・クロック発振周波数
  - 2. ( ) 内は, fx = 12 MHz動作時。

## (2) アナログ入力チャネル指定レジスタ 0 (ADS0)

A/D変換するアナログ電圧の入力ポートを指定するレジスタです。

ADSOは、8ビット・メモリ操作命令で設定します。

RESET 入力により、00Hになります。

図12-4 アナログ入力チャネル指定レジスタ 0 (ADS0) のフォーマット

アドレス:FF81H リセット時:00H R/W

| 略号   | 7 | 6 | 5 | 4 | 3 | 2              | 1     | 0     |
|------|---|---|---|---|---|----------------|-------|-------|
| ADS0 | 0 | 0 | 0 | 0 | 0 | 0 <sup>注</sup> | ADS01 | ADS00 |

| ADS01 | ADS00 | アナログ入力チャネルの指定 |
|-------|-------|---------------|
| 0     | 0     | ANI0          |
| 0     | 1     | ANI1          |
| 1     | 0     | ANI2          |
| 1     | 1     | ANI3          |

注 ビット2には必ず0を設定してください。

# 12.4 A/Dコンバータの動作

## 12.4.1 A/Dコンバータの基本動作

- ① A/D変換するチャネルをアナログ入力チャネル指定レジスタ 0 (ADSO) で 1 チャネル選択してください。
- ② 選択されたアナログ入力チャネルに入力されている電圧を、サンプル&ホールド回路がサンプリングします。
- ③ 一定時間サンプリングを行うとサンプル&ホールド回路はホールド状態となり、入力されたアナログ電圧をA/D変換が終了するまで保持します。
- ④ 逐次変換レジスタ(SAR)のビット9がセットされます。タップ・セレクタにより直列抵抗ストリング の電圧タップが(1/2)AVREFにされます。
- ⑤ 直列抵抗ストリングの電圧タップとアナログ入力との電圧差が電圧コンパレータで比較されます。もし、アナログ入力が(1/2)AVREFよりも大きければ、SARのMSBがセットされたままです。また、(1/2)AVREFよりも小さければMSBをリセットします。
- ⑥ 次にSARのビット 8 が自動的にセットされ、次の比較に移ります。ここではすでに結果がセットされているビット 9 の値によって、次に示すように直列抵抗ストリングの電圧タップが選択されます。
  - ・ビット9 = 1: (3/4) AVREF
  - ・ビット9 = 0: (1/4) AVREF
  - この電圧タップとアナログ入力電圧を比較し、その結果でSARのビット8が次のように操作されます。
    - ・アナログ入力電圧≥電圧タップ:ビット8=1
    - ・アナログ入力電圧く電圧タップ:ビット8=0
- ⑦ このような比較をSARのビット0まで続けます。
- ⑧ 10ビットの比較が終了したとき、SARには有効なディジタルの結果が残り、その値がA/D変換結果レジスタ 0 (ADCR0) に転送され、ラッチされます。

同時に、A/D変換終了割り込み要求(INTADO)を発生させることができます。

- 注意 1. A/D変換動作をスタートした直後のA/D変換値は定格を満たさないことがあります。A/D変換終 了割り込み要求(INTADO)をポーリングし、最初の変換結果を廃棄するなどの対策を行ってく ださい。
  - 2. スタンバイ・モード時, A/Dコンバータは動作停止となります。

図12-5 10ビットA/Dコンバータの基本動作



A/D変換動作は、ソフトウエアによりA/Dコンバータ・モード・レジスタ 0 (ADMO)のビット 7 (ADCS0)をリセット( 0 )するまで連続的に行われます。

A/D変換結果レジスタ 0 (ADCRO) は、RESET により0000Hとなります。

A/D変換終了は、A/D変換終了割り込み要求フラグ(ADIFO)で確認してください。

A/Dコンバータのサンプリング時間は、A/Dコンバータ・モード・レジスタ 0 (ADMO) の設定値によって異なります。また、A/Dコンバータを動作許可してから実際にサンプリングが行われるまで遅延時間が存在します。 A/D変換時間を厳密に必要とするセットの場合は、表12-2に示す内容にご注意ください。

表12-2 A/Dコンバータのサンプリング時間とA/D変換開始遅延時間

| FR02 | FR01 | FR00 | 変換時間 <sup>注</sup> | サンプリング時間 | A/D変換開始遅延時間   |               |
|------|------|------|-------------------|----------|---------------|---------------|
|      |      |      |                   |          | MIN.          | MAX.          |
| 0    | 0    | 0    | 144/fx            | 20/fx    | 0.5/fcpu+6/fx | 0.5/fcpu+8/fx |
| 0    | 0    | 1    | 120/fx            | 16/fx    |               |               |
| 0    | 1    | 0    | 96/fx             | 12/fx    |               |               |
| 1    | 0    | 0    | 72/fx             | 10/fx    | 0.5/fcpu+3/fx | 0.5/fcpu+4/fx |
| 1    | 0    | 1    | 60/fx             | 8/fx     |               |               |
| 1    | 1    | 0    | 48/fx             | 6/fx     |               |               |
| 上記以外 |      |      | 設定禁止              | _        | _             | _             |

注 A/D変換時間が、 $12 \mu s$ 以上になるように設定してください(fx = 12 MHz動作時)。

備考 fx :メイン・システム・クロック発振周波数

fcpu : CPUクロック周波数

## 12.4.2 入力電圧と変換結果

アナログ入力端子(ANIO-ANI7)に入力されたアナログ入力電圧と理論上のA/D変換結果(A/D変換結果レジスタ 0 (ADCR0))には次式に示す関係があります。

ADCR0 = INT 
$$\left(\frac{V_{AIN}}{AV_{REF}} \times 1024 + 0.5\right)$$

または,

$$(ADCR0-0.5) \times \frac{AV_{REF}}{1024} \le V_{AIN} < (ADCR0+0.5) \times \frac{AV_{REF}}{1024}$$

INT( ):( )内の値の整数部を返す関数

VAIN: アナログ入力電圧AVREF: AVREF端子電圧

ADCRO : A/D変換結果レジスタ 0 (ADCRO) の値

図12-6にアナログ入力電圧とA/D変換結果の関係を示します。

図12-6 アナログ入力電圧とA/D変換結果の関係



## 12.4.3 A/Dコンバータの動作モード

アナログ入力チャネル指定レジスタ 0 (ADS0)によってANIO-ANI3からアナログ入力を 1 チャネル選択し、A/D変換を開始させてください。

A/D変換動作の起動方法には、次の2種類があります。

- ・ハードウエア・スタート: トリガ入力(立ち上がり,立ち下がり,立ち上がりと立ち下がりの両エッジ指 定可能)
- ・ソフトウエア・スタート:A/Dコンバータ・モード・レジスタ 0 (ADMO) を設定することにより開始

また、A/D変換が終了したら、割り込み要求信号(INTADO)を発生します。

#### (1) ハードウエア・スタートによるA/D変換動作

A/Dコンバータ・モード・レジスタ 0 (ADM0) のビット 6 (TRG0) に 1, ビット 7 (ADCS0) に 1 を設定することによってA/D変換動作の待機状態になります。外部トリガ信号 (ADTRG) が入力されると、アナログ入力チャネル指定レジスタ 0 (ADS0) で指定したアナログ入力端子に印加されている電圧のA/D変換動作を開始します。

A/D変換動作が終了すると、変換結果をA/D変換結果レジスタ 0 (ADCRO)に格納し、割り込み要求信号 (INTADO) を発生します。次のA/D変換動作が一度起動し、1回のA/D変換が終了すると、新たに外部トリガ信号が入力されないかぎり、A/D変換動作は開始しません。

A/D変換動作中に、ADSOを書き換えると、そのとき行っていたA/D変換動作を中断し、新たに外部トリガ信号が入力されるまで待機します。外部トリガ入力信号が再度入力されると、A/D変換動作を最初から行います。A/D変換待機中にADSOを書き換えた場合、次に外部トリガ入力信号が入力された時点で、新たにA/D変換動作を開始します。

A/D変換動作中に、ADCS0に再度1を書き込むと、そのとき行っていたA/D変換動作を中断し、次に外部トリガ入力信号が入力された時点で、新たにA/D変換動作を開始します。

また、A/D変換動作中に、ADCSOに 0 を書き込むと、ただちにA/D変換動作を停止します。

注意 P03/INTP3/ADTRGを外部トリガ入力(ADTRG)として使用する場合は、A/Dコンバータ・モード・レジスタ 0 (ADM0) のビット 1 、2 (EGA00, EGA01) で有効エッジを指定し、割り込みマスク・フラグ (PMK3) を 1 に設定してください。

## ◆ 図12-7 ハードウエア・スタートによるA/D変換動作(立ち下がりエッジ指定時)



**備考1.** n = 0, 1, ······, 3

2.  $m = 0, 1, \dots, 3$ 

#### (2) ソフトウエア・スタートによるA/D変換動作

A/Dコンバータ・モード・レジスタ 0 (ADM0) のビット 6 (TRG0) に 0 、ビット 7 (ADCS0) に 1 を設定することにより、アナログ入力チャネル指定レジスタ 0 (ADS0) で指定したアナログ入力端子に印加されている電圧のA/D変換動作を開始します。

A/D変換動作が終了すると、変換結果をA/D変換結果レジスタ 0 (ADCRO)に格納し、割り込み要求信号 (INTADO) が発生します。A/D変換動作が一度起動し、1回のA/D変換が終了すると、ただちに次のA/D変換動作を開始します。新たなデータをADSOに書き込むまで繰り返しA/D変換動作を行います。

A/D変換動作中にADSOを書き換えると、そのとき行っていたA/D変換動作を中断し、新たに選択したアナログ入力チャネルのA/D変換動作を開始します。

A/D変換動作中に、ADCS0に再度 1 を書き込むと、そのとき行っていたA/D変換動作を中断し、新たにA/D変換動作を開始します。

また、A/D変換動作中に、ADCSOに0を書き込むと、ただちにA/D変換動作を停止します。

#### 図12-8 ソフトウエア・スタートによるA/D変換動作



備考1. n = 0, 1, ······, 3

2.  $m = 0, 1, \dots, 3$ 

# 12.5 A/Dコンバータ特性表の読み方

A/Dコンバータに特有な用語について説明します。

#### (1)分解能

識別可能な最小アナログ入力電圧、つまり、ディジタル出力 1 ビットあたりのアナログ入力電圧の比率を 1LSB(Least Significant Bit)といいます。1LSBのフルスケールに対する比率を%FSR(Full Scale Range)で表します。

分解能10ビットのとき

 $1LSB = 1/2^{10} = 1/1024$ = 0.098%FSR

精度は分解能とは関係なく、総合誤差によって決まります。

#### (2)総合誤差

実測値と理論値との差の最大値を指しています。

ゼロスケール誤差、フルスケール誤差、積分直線性誤差、微分直線性誤差およびそれらの組み合わせから 生じる誤差を総合した誤差を表しています。

なお、特性表の総合誤差には量子化誤差は含まれていません。

#### (3)量子化誤差

アナログ値をディジタル値に変換するとき、必然的に生じる $\pm 1/2$ LSBの誤差です。A/Dコンバータでは、 $\pm 1/2$ LSBの範囲にあるアナログ入力電圧は、同じディジタル・コードに変換されるため、量子化誤差を避けることはできません。

なお、特性表の総合誤差、ゼロスケール誤差、フルスケール誤差、積分直線性誤差、微分直線性誤差には 含まれていません。

図12-9 総合誤差



図12-10 量子化誤差



#### (4) ゼロスケール誤差

ディジタル出力が0……000から0……001に変化するときの、アナログ入力電圧の実測値と理論値(1/2LSB)との差を表します。実測値が理論値よりも大きい場合は、ディジタル出力が0……011から0……010に変化するときの、アナログ入力電圧の実測値と理論値(3/2LSB)との差を表します。

#### (5) フルスケール誤差

ディジタル出力が1……110から1……111に変化するときの、アナログ入力電圧の実測値と理論値(フルスケール-3/2LSB)との差を表します。

## (6) 積分直線性誤差

変換特性が、理想的な直線関係から外れている程度を表します。ゼロスケール誤差、フルスケール誤差を 0 としたときの、実測値と理想直線との差の最大値を表します。

#### (7) 微分直線性誤差

理想的にはあるコードを出力する幅は1LSBですが、あるコードを出力する幅の実測値と理想値との差を表します。

図12-11 ゼロスケール誤差

図12-12 フルスケール誤差





図12-13 積分直線性誤差



図12-14 微分直線性誤差



## アナログ入力

積分直線性誤差

# (8)変換時間

サンプリングを開始してから、ディジタル出力が得られるまでの時間を表します。 特性表の変換時間にはサンプリング時間が含まれています。

AVREF

# (9) サンプリング時間

アナログ電圧をサンプル&ホールド回路に取り込むため、アナログ・スイッチがオンしている時間です。



# 12.6 A/Dコンバータの注意事項

#### (1) スタンバイ・モード時の消費電力について

A/Dコンバータは、スタンバイ・モード時には動作が停止します。このときA/Dコンバータ・モード・レジスタ 0 (ADM0)のビット 7 (ADCS0) = 0にすることにより、消費電力を低減させることができます。 直列抵抗ストリングの回路構成を図12-15に示します。

図12-15 直列抵抗ストリングの回路構成



#### (2) ANIO-ANI3入力範囲について

ANIO-ANI3入力電圧は規格の範囲内でご使用ください。特にAVREF以上、AVSS以下(絶対最大定格の範囲内でも)の電圧が入力されると、そのチャネルの変換値が不定となります。また、ほかのチャネルの変換値にも影響を与えることがあります。

## (3) 競合動作について

- ① 変換終了時のA/D変換結果レジスタ 0 (ADCR0)ライトと命令によるADCR0リードとの競合 ADCR0リードが優先されます。リードしたあと、新しい変換結果がADCR0にライトされます。
- ② 変換終了時のADCR0ライトと外部トリガ信号入力の競合 A/D変換中の外部トリガ信号は受け付けません。したがってADCR0ライト中の外部トリガ信号も受け付けません。
- ③ 変換終了時のADCR0ライトとA/Dコンバータ・モード・レジスタ 0 (ADM0) ライト、またはアナログ入力チャネル指定レジスタ 0 (ADS0) ライトの競合

ADM0またはADS0へのライトが優先されます。ADCR0へのライトはされません。また、変換終了割り込み要求信号(INTAD0)も発生しません。

#### (4) ANIO/P10-ANI3/P13

- ① アナログ入力(ANIO-ANI3)端子は入力ポート(P10-P13)端子と兼用になっています。 ANIO-ANI3のいずれかを選択してA/D変換をする場合、変換中にポート1に対してアクセスしないでください。変換分解能が低下することがあります。
- ② A/D変換中の端子に隣接する端子へディジタル・パルスを印加すると、カップリング・ノイズによってA/D変換値が期待どおりに得られないこともあります。したがって、A/D変換中の端子に隣接する端子へのパルス印加はしないようにしてください。

#### (5) AVREF端子の入力インピーダンスについて

AVREF端子とAVss端子の間には数十kΩの直列抵抗ストリングが接続されています。

したがって、基準電圧源の出力インピーダンスが高い場合、AVREF端子とAVss端子の間の直列抵抗ストリングと直列接続することになり、基準電圧の誤差が大きくなります。

## (6)割り込み要求フラグ(ADIFO)について

アナログ入力チャネル指定レジスタ 0 (ADS0)を変更しても割り込み要求フラグ(ADIF0)はクリアされません。

したがって、A/D変換中にアナログ入力端子の変更を行った場合、ADSO書き換え直前に変更前のアナログ入力に対するA/D変換結果および変換終了割り込み要求フラグがセットされる場合があります。このときADSO書き換え直後にADIFOを読み出すと、変更後のアナログ入力に対するA/D変換が終了していないにもかかわらずADIFOがセットされていることになりますので注意してください。

また、A/D変換を一度停止させて再開する場合は、再開する前にADIFOをクリアしてください。

#### 図12-16 A/D変換終了割り込み要求発生タイミング



備考1. n = 0, 1, ······, 3

2.  $m = 0, 1, \dots, 3$ 

#### (7) A/D変換スタート直後の変換結果について

A/D変換動作をスタートした直後のA/D変換値は定格を満たさないことがあります。A/D変換終了割り込み要求(INTADO)をポーリングし、最初の変換結果を廃棄するなどの対策を行ってください。

# (8) A/D変換結果レジスタ 0 (ADCRO) の読み出しについて

A/Dコンバータ・モード・レジスタ 0 (ADM0) , アナログ入力チャネル指定レジスタ 0 (ADS0) に対して書き込み動作を行ったとき、ADCROの内容は不定となることがあります。変換結果は、変換動作終了後、ADM0, ADS0に対して書き込み動作を行う前に読み出してください。上記以外のタイミングでは、正しい変換結果が読み出されないことがあります。

#### ★ (9) A/D変換結果が不定になるタイミング

A/D変換終了のタイミングとA/D変換動作を停止するタイミングが競合するとA/D変換値は不定になることがあります。そのため、A/D変換結果を読み出す場合は、A/D変換動作中に行ってください。

変換結果を読み出すタイミングを図12-17に示します。

図12-17 変換結果を読み出すタイミング(変換結果が不定値の場合)



#### (10) ボード設計上の注意

ボード上でのディジタル回路ノイズの影響を避けるために、アナログ回路はディジタル回路とできるだけ離して配置してください。特にアナログ信号線とディジタル信号線を交差させたり近接させたりすることは極力避けてください。ノイズの誘導などによってA/D変換特性が悪化する恐れがあります。

AVssoとVssoはボード上で安定しているところで1箇所、接続してください。

# (11) AVDD端子について

AVDD端子はアナログ回路の電源端子であり、ANIO-ANI3の入力回路にも電源を供給しています。 したがって、バックアップ電源に切り替えるようなアプリケーションにおいても、必ずVDDD端子と同レベルの電位を印加してください。

図12-18 AVDD端子の処理



#### (12) AVREF端子

ノイズによる変換誤差を小さく抑えるため、AVREF端子にコンデンサを接続してください。またA/D変換動作を停止した状態から動作開始した直後は、AVREF端子にかかる電圧が不安定になり、A/D変換精度の悪化が生じる場合があります。このような場合にもAVREF端子にコンデンサを接続してください。コンデンサの接続例を図12-19に示します。

図12-19 AVREF端子とコンデンサの接続例



備考  $C1:4.7 \mu F\sim 10 \mu F$  (参考値)

C2:0.01 μF~0.1 μF (参考値)

C2は端子のできるだけ近くに接続してください。

#### (13) ANIO-ANI3端子内部等価回路と許容信号源インピーダンス

サンプリング時間内にサンプリングを完了し、十分なA/D変換精度を得るにはセンサなどの信号源のインピーダンスが十分に低い必要があります。図12-20にANIO-ANI3端子のマイコン内部の等価回路を示します。信号源のインピーダンスが高い場合には、ANIO-ANI3端子に大きな容量を接続することで見かけ上インピーダンスを低くすることができます。図12-21に回路例を示します。この場合にはロウ・パス・フィルタを構成しますので、微分係数の大きなアナログ信号には追従できなくなります。

高速なアナログ信号を変換する場合やスキャン・モードで変換する場合にはロウ・インピーダンスのバッファを挿入してください。

図12-20 ANIO-ANI3端子内部等価回路



備考 n = 0-3

表12-3 等価回路の各抵抗と容量値(参考値)

| AVREF | R1    | R2     | C1   | C2     | C3   |
|-------|-------|--------|------|--------|------|
| 2.7 V | 12 kΩ | 8 kΩ   | 8 pF | 3 pF   | 2 pF |
| 4.5 V | 4 k Ω | 2.7 kΩ | 8 pF | 1.4 pF | 2 pF |

注意 表12-3の各抵抗と容量値は保証値ではありません。

図12-21 信号源インピーダンスが高い場合の回路例



備考 n = 0-3

# (14) ANIO-ANI3端子の入力インピーダンスについて

このA/Dコンバータでは、変換時間の約1/10程度の間、内部のサンプリング・コンデンサに充電して、サンプリングを行っています。

したがって、サンプリング中以外はリーク電流だけであり、サンプリング中にはコンデンサに充電するための電流も流れるので、入力インピーダンスは変動して意味がありません。

ただし、十分にサンプリングするためには、アナログ入力源の出力インピーダンスを10 k $\Omega$ 以下にするか、ANIO-ANI3端子に100 pF程度のコンデンサを付けることを推奨します(図12ー21参照)。

# 第13章 シリアル・インタフェースUARTO

# 13.1 シリアル・インタフェースUARTOの機能

シリアル・インタフェースUARTOには、次の3種類のモードがあります。

## (1)動作停止モード

シリアル転送を行わないときに使用するモードです。消費電力を低減できます。 詳細については**13.4.1 動作停止モード**を参照してください。

## (2) アシンクロナス・シリアル・インタフェース(UART) モード(LSB先頭固定)

スタート・ビットに続く1バイトのデータを送受信するモードで、全二重動作が可能です。

UART専用ボー・レート・ジェネレータを内蔵しており、広範囲な任意のボー・レートで通信できます。通信範囲は1.2 kbps~131 kbps(fx = 8.38 MHz動作時)です。また、ASCKO端子への入力クロックを分周してボー・レート(Max. 39 kbps(fx = 1.25 MHz動作時))を定義することもできます。

UART専用ボー・レート・ジェネレータを利用してMIDI規格のボー・レート(31.25 kbps)を使用することもできます。

詳細については13.4.2 アシンクロナス・シリアル・インタフェース (UART) モードを参照してください。

#### (3) 赤外線データ転送モード

詳細については13.4.3 赤外線データ転送モードを参照してください。

図13-1に、シリアル・インタフェースUARTOのブロック図を示します。

図13-1 シリアル・インタフェースUARTOのブロック図



注 ボー・レート・ジェネレータの構成は、図13-2を参照してください。

図13-2 ボー・レート・ジェネレータのブロック図



備考 TXEO: アシンクロナス・シリアル・インタフェース・モード・レジスタ 0 (ASIMO) のビット7

RXEO: のビット6

# 13.2 シリアル・インタフェースUART0の構成

シリアル・インタフェースUARTOは、次のハードウエアで構成されています。

表13-1 シリアル・インタフェースUARTOの構成

| 項目     | 構 成                                       |
|--------|-------------------------------------------|
| レジスタ   | 送信シフト・レジスタ 0 (TXS0)                       |
|        | 受信シフト・レジスタ 0 (RX0)                        |
|        | 受信バッファ・レジスタ 0 (RXB0)                      |
|        | アシンクロナス・シリアル・インタフェース・ステータス・レジスタ 0 (ASIS0) |
| 制御レジスタ | アシンクロナス・シリアル・インタフェース・モード・レジスタ 0 (ASIMO)   |
|        | ボー・レート・ジェネレータ・コントロール・レジスタ 0 (BRGC0)       |
|        | ポート・モード・レジスタ2(PM2)                        |
|        | ポート2 (P2)                                 |

## (1) 送信シフト・レジスタ 0 (TXSO)

送信データを設定するレジスタです。TXSOに書き込まれたデータをシリアル・データとして送信します。 データ長を7ビットに指定した場合、TXSOに書き込んだデータのビット0-6が送信データとして転送され ます。TXSOにデータを書き込むことにより、送信動作を開始します。

TXSOは、8ビット・メモリ操作命令で書き込みます。読み出しはできません。

RESET 入力により、FFHになります。

## 注意 送信動作中は、TXSOへの書き込みを行わないでください。

TXS0と受信バッファ・レジスタ 0 (RXB0) は同一アドレスに割り当てられており、読み出しを 行った場合にはRXB0の値が読み出されます。

#### (2) 受信シフト・レジスタ 0 (RXO)

RxD0端子に入力されたシリアル・データをパラレル・データに変換するレジスタです。1 バイト分のデータを受信すると、受信データを受信バッファ・レジスタ 0 (RXB0) へ転送します。

RX0はプログラムで直接操作できません。

(3) 受信バッファ・レジスタ 0 (RXBO)

受信データを保持するレジスタです。データを1バイト受信するごとに受信シフト・レジスタ(RXO)から新たな受信データが転送されます。

データ長を 7 ビットに指定した場合,受信データはRXB0のビット 0 - 6 に転送され,RXB0のMSBは必ず 0 になります。

RXBOは、8ビット・メモリ操作命令で読み出せます。書き込みはできません。

RESET 入力により、FFHになります。

- 注意 RXB0と送信シフト・レジスタ 0 (TXS0) は同一アドレスに割り当てられており、書き込みを行った場合にはTXS0に値が書き込まれます。
- (4) アシンクロナス・シリアル・インタフェース・ステータス・レジスタ 0 (ASISO)

UARTモードで受信エラー発生時、エラーの種類を表示するレジスタです。

ASISOは、8ビット・メモリ操作命令で読み出します。

RESET 入力により、00Hになります。

図13-3 アシンクロナス・シリアル・インタフェース・ステータス・レジスタ 0 (ASISO) のフォーマット

アドレス:FFA1H リセット時:00H R

| 略号    | 7 | 6 | 5 | 4 | 3 | 2   | 1   | 0    |
|-------|---|---|---|---|---|-----|-----|------|
| ASIS0 | 0 | 0 | 0 | 0 | 0 | PE0 | FE0 | OVE0 |

| PE0 | パリティ・エラー・フラグ         |
|-----|----------------------|
| 0   | パリティ・エラーなし           |
| 1   | パリティ・エラー発生           |
|     | (送信データのパリティが一致しないとき) |

| FE0 | フレーミング・エラー・フラグ              |
|-----|-----------------------------|
| 0   | フレーミング・エラーなし                |
| 1   | フレーミング・エラー発生 <sup>注 1</sup> |
|     | (ストップ・ビットが検出されないとき)         |

| OVE0 | オーバラン・エラー・フラグ                     |
|------|-----------------------------------|
| 0    | オーバラン・エラーなし                       |
| 1    | オーバラン・エラー発生 <sup>注 2</sup>        |
|      | (受信バッファ・レジスタ 0 (RXB0)からデータを読み出す前に |
|      | 次の受信動作が完了したとき)                    |

- **注1.** アシンクロナス・シリアル・インタフェース・モード・レジスタ 0 (ASIMO) のビット 2 (SLO) でストップ・ビット長を 2 ビットに設定した場合も、受信時のストップ・ビット検出は 1 ビット のみです。
  - 2. オーバラン・エラーが発生したとき、受信バッファ・レジスタ 0 (RXB0) を読み出すまで、オーバラン・エラーが発生し続けます。

#### (5) 送信制御回路

アシンクロナス・シリアル・インタフェース・モード・レジスタ 0 (ASIMO) に設定された内容に従って、送信シフト・レジスタ 0 (TXSO) に書き込まれたデータにスタート・ビット、パリティ・ビット、ストップ・ビットの付加などの送信動作の制御を行います。

#### (6)受信制御回路

アシンクロナス・シリアル・インタフェース・モード・レジスタ 0 (ASIMO) に設定された内容に従って、受信動作を制御します。また、受信動作中にパリティ・エラーなどのエラー・チェックも行い、エラーを検出したときにはエラー内容に応じた値をアシンクロナス・シリアル・インタフェース・ステータス・レジスタ 0 (ASISO) にセットします。

# 13.3 シリアル・インタフェースUARTOを制御するレジスタ

シリアル・インタフェースUARTOは、次の4種類のレジスタで制御します。

- ・アシンクロナス・シリアル・インタフェース・モード・レジスタ 0 (ASIMO)
- ・ボー・レート・ジェネレータ・コントロール・レジスタ 0 (BRGC0)
- ・ポート・モード・レジスタ2 (PM2)
- ・ポート2 (P2)
- (1) アシンクロナス・シリアル・インタフェース・モード・レジスタ 0 (ASIMO) シリアル・インタフェースUARTOのシリアル転送動作を制御する 8 ビットのレジスタです。 ASIMOは、1 ビット・メモリ操作命令または 8 ビット・メモリ操作命令で設定します。 RESET 入力により、00Hになります。

図13-4にASIMOのフォーマットを示します。

#### 図13-4 アシンクロナス・シリアル・インタフェース・モード・レジスタ 0 (ASIMO) のフォーマット

アドレス:FFA0H リセット時:00H R/W

 略号
 7
 6
 5
 4
 3
 2
 1
 0

 ASIM0
 TXE0
 RXE0
 PS01
 PS00
 CL0
 SL0
 ISRM0
 IRDAM0

| TXE0 | RXE0 | 動作モード         | RxD0/P23端子の機能 | TxD0/P24端子の機能 |
|------|------|---------------|---------------|---------------|
| 0    | 0    | 動作停止          | ポート機能(P23)    | ポート機能(P24)    |
| 0    | 1    | UARTモード(受信のみ) | シリアル機能(RxD0)  |               |
| 1    | 0    | UARTモード(送信のみ) | ポート機能(P23)    | シリアル機能(TxD0)  |
| 1    | 1    | UARTモード(送受信)  | シリアル機能(RxD0)  |               |

| PS01 | PS00 | パリティ・ビットの指定                     |
|------|------|---------------------------------|
| 0    | 0    | パリティなし                          |
| 0    | 1    | 送信時、常に0パリティ付加                   |
|      |      | 受信時、パリティの検査をしない(パリティ・エラーを発生しない) |
| 1    | 0    | 奇数パリティ                          |
| 1    | 1    | 偶数パリティ                          |

| CL0 | キャラクタ長の指定 |
|-----|-----------|
| 0   | 7ビット      |
| 1   | 8ビット      |

| SL0 | 送信データのストップ・ビット長の指定 |
|-----|--------------------|
| 0   | 1ビット               |
| 1   | 2 ビット              |

| ISRM0 | エラー発生時の受信完了割り込み制御       |
|-------|-------------------------|
| 0     | エラー発生時、受信完了割り込み要求を発生する  |
| 1     | エラー発生時,受信完了割り込み要求を発生しない |

| IRDAN | の 赤外線データ転送モードの動作の指定 <sup>注1</sup> |
|-------|-----------------------------------|
| 0     | UART(送受信)モード                      |
| 1     | 赤外線データ転送(送受信)モード <sup>注 2</sup>   |

- 注1. UART/赤外線データ転送モードの指定は、TXE0,RXE0により制御されます。
  - 2. 赤外線データ転送モード使用時は、ボー・レート・ジェネレータ・コントロール・レジスタ 0 (BRGC0) を必ず10Hに設定してください。

注意 ASIMOを同一データ以外に書き換える場合には、いったん動作停止してから書き換えてください。

(2) ボー・レート・ジェネレータ・コントロール・レジスタ 0 (BRGC0)

シリアル・インタフェースのシリアル・クロックを設定するレジスタです。

BRGC0は、8ビット・メモリ操作命令で設定します。

RESET 入力により、00Hになります。

図13-5にBRGC0のフォーマットを示します。

図13-5 ボー・レート・ジェネレータ・コントロール・レジスタ 0 (BRGC0) のフォーマット

アドレス:FFA2H リセット時:00H R/W

 略号
 7
 6
 5
 4
 3
 2
 1
 0

 BRGC0
 0
 TPS02
 TPS01
 TPS00
 MDL03
 MDL02
 MDL01
 MDL00

| TPS02 | TPS01 | TPS00 | 5 ビット・カウンタのソース・クロック選択 | n |
|-------|-------|-------|-----------------------|---|
| 0     | 0     | 0     | ASCK0への外部クロック入力       | 0 |
| 0     | 0     | 1     | fx/2                  | 1 |
| 0     | 1     | 0     | fx/2 <sup>2</sup>     | 2 |
| 0     | 1     | 1     | fx/2 <sup>3</sup>     | 3 |
| 1     | 0     | 0     | fx/2 <sup>4</sup>     | 4 |
| 1     | 0     | 1     | fx/2 <sup>5</sup>     | 5 |
| 1     | 1     | 0     | fx/2 <sup>6</sup>     | 6 |
| 1     | 1     | 1     | fx/2 <sup>7</sup>     | 7 |

| MDL03 | MDL02 | MDL01 | MDL00 | ボー・レート・ジェネレー | k  |
|-------|-------|-------|-------|--------------|----|
|       |       |       |       | タの出力クロックの選択  |    |
| 0     | 0     | 0     | 0     | fscко/16     | 0  |
| 0     | 0     | 0     | 1     | fscко/17     | 1  |
| 0     | 0     | 1     | 0     | fscко/18     | 2  |
| 0     | 0     | 1     | 1     | fscко/19     | 3  |
| 0     | 1     | 0     | 0     | fscко/20     | 4  |
| 0     | 1     | 0     | 1     | fscко/21     | 5  |
| 0     | 1     | 1     | 0     | fscко/22     | 6  |
| 0     | 1     | 1     | 1     | fscко/23     | 7  |
| 1     | 0     | 0     | 0     | fscко/24     | 8  |
| 1     | 0     | 0     | 1     | fscко/25     | 9  |
| 1     | 0     | 1     | 0     | fscко/26     | 10 |
| 1     | 0     | 1     | 1     | fscко/27     | 11 |
| 1     | 1     | 0     | 0     | fscко/28     | 12 |
| 1     | 1     | 0     | 1     | fscко/29     | 13 |
| 1     | 1     | 1     | 0     | fscко/30     | 14 |
| 1     | 1     | 1     | 1     | 設定禁止         | _  |

- 注意 1. 通信動作中にBRGC0への書き込みを行うと、ボー・レート・ジェネレータの出力が乱れ正常に 通信ができなくなります。したがって、通信動作中にはBRGC0への書き込みを行わないでくだ さい。
  - 2. 赤外線データ転送モードで使用するときは、BRGC0に10Hを設定してください。

備考1. fx :メイン・システム・クロック発振周波数

**2.** fscко : 5 ビット・カウンタのソース・クロック

**3.** n : TPS00-TPS02で設定した値(0≦n≦7)

4. k : MDL00-MDL03で設定した値(0≤k≤14)

5. ボー・レートの計算式は次のとおりです。

$$(\ddot{\pi} - \cdot \nu - F) = \frac{fx}{2^{n+1} (k+16)}$$
 (Hz)

## (3) ポート・モード・レジスタ2 (PM2)

ポート2の入力/出力を1ビット単位で設定するレジスタです。

P24/TxD0端子をシリアル・データ出力として使用するとき、PM24およびP24の出力ラッチに 0 を設定してください。

P23/RxD0端子をシリアル・データ入力として、P25/ASCK0端子をクロック入力として使用するとき、PM23、PM25に1を設定してください。このときP23、P25の出力ラッチは0または1のどちらでもかまいません。

PM2は、1 ビット・メモリ操作命令または8 ビット・メモリ操作命令で設定します。 RESET入力により、FFHになります。

図13-6 ポート・モード・レジスタ2 (PM2) のフォーマット

アドレス:FF22H リセット時:FFH R/W

 略号
 7
 6
 5
 4
 3
 2
 1
 0

 PM2
 1
 1
 PM25
 PM24
 PM23
 PM22
 PM21
 PM20

| PM2n | P2n端子の入出力モードの選択(n = 0-5) |
|------|--------------------------|
| 0    | 出力モード(出力バッファ・オン)         |
| 1    | 入力モード(出力バッファ・オフ)         |

# 13.4 シリアル・インタフェースUART0の動作

シリアル・インタフェースUARTOの持つ3種類のモードについて説明します。

# 13.4.1 動作停止モード

動作停止モードでは、シリアル転送を行いませんので、消費電力を低減できます。 また、動作停止モードでは、端子を通常のポートとして使用できます。

## (1) 使用するレジスタ

動作停止モードの設定は、アシンクロナス・シリアル・インタフェース・モード・レジスタ 0 (ASIMO) で行います。

ASIMOは、1 ビット・メモリ操作命令または8 ビット・メモリ操作命令で設定します。 RESET 入力により、00Hになります。

アドレス:FFA0H リセット時:00H R/W

 略号
 7
 6
 5
 4
 3
 2
 1
 0

 ASIM0
 TXE0
 RXE0
 PS01
 PS00
 CL0
 SL0
 ISRM0
 IRDAM0

| TXE0 | RXE0 | 動作モード | RxD0/P23端子の機能 | TxD0/P24端子の機能 |
|------|------|-------|---------------|---------------|
| 0    | 0    | 動作停止  | ポート機能(P23)    | ポート機能(P24)    |

# 13.4.2 アシンクロナス・シリアル・インタフェース(UART) モード

スタート・ビットに続く1バイトのデータを送受信するモードで、全二重動作が可能です。

UART専用ボー・レート・ジェネレータを内蔵しており、広範囲な任意のボー・レートで通信できます。通信範囲は1.2 kbps~131 kbps(fx = 8.38 MHz動作時)です。また、ASCKO端子への入力クロックを分周してボー・レート(Max. 39 kbps(fx = 1.25 MHz動作時))を定義することができます。

UART専用ボー・レート・ジェネレータを利用してMIDI規格のボー・レート(31.25 kbps)を使用することもできます。

## (1) 使用するレジスタ

- ・アシンクロナス・シリアル・インタフェース・モード・レジスタ 0 (ASIMO)
- ・アシンクロナス・シリアル・インタフェース・ステータス・レジスタ 0 (ASISO)
- ・ボー・レート・ジェネレータ・コントロール・レジスタ 0 (BRGC0)
- ・ポート・モード・レジスタ 2 (PM2)
- ・ポート2 (P2)
- (a) アシンクロナス・シリアル・インタフェース・モード・レジスタ 0 (ASIMO) ASIMOは、1 ビット・メモリ操作命令または8 ビット・メモリ操作命令で設定します。 RESET 入力により、00Hになります。

アドレス:FFA0H リセット時:00H R/W

略号 7 6 5 3 1 0 2

ASIMO TXEO RXEO PS01 PS00 ISRM0 IRDAM0 CL0 SL0

| TXE0 | RXE0 | 動作モード         | RxD0/P23端子の機能 | TxD0/P24端子の機能 |
|------|------|---------------|---------------|---------------|
| 0    | 0    | 動作停止          | ポート機能(P23)    | ポート機能(P24)    |
| 0    | 1    | UARTモード(受信のみ) | シリアル機能(RxD0)  |               |
| 1    | 0    | UARTモード(送信のみ) | ポート機能(P23)    | シリアル機能(TxD0)  |
| 1    | 1    | UARTモード(送受信)  | シリアル機能(RxD0)  |               |

| PS01 | PS00 | パリティ・ビットの指定                     |
|------|------|---------------------------------|
| 0    | 0    | パリティなし                          |
| 0    | 1    | 送信時、常に0パリティ付加                   |
|      |      | 受信時、パリティの検査をしない(パリティ・エラーを発生しない) |
| 1    | 0    | 奇数パリティ                          |
| 1    | 1    | 偶数パリティ                          |

| CL0 | キャラクタ長の指定 |
|-----|-----------|
| 0   | 7ビット      |
| 1   | 8ビット      |

| SL0 | 送信データのストップ・ビット長の指定 |
|-----|--------------------|
| 0   | 1ビット               |
| 1   | 2ビット               |

| ISRM0 | エラー発生時の受信完了割り込み制御       |
|-------|-------------------------|
| 0     | エラー発生時、受信完了割り込み要求を発生する  |
| 1     | エラー発生時,受信完了割り込み要求を発生しない |

| IRDAM0 | 赤外線データ転送モードの動作の指定 <sup>注 1</sup> |
|--------|----------------------------------|
| 0      | UART(送受信)モード                     |
| 1      | 赤外線データ転送(送受信)モード <sup>注2</sup>   |

- 注1. UART/赤外線データ転送モードの指定は、TXEO, RXEOにより制御されます。
  - 2. 赤外線データ転送モード使用時は、ボー・レート・ジェネレータ・コントロール・レジスタ 0 (BRGCO) を必ず10Hに設定してください。

注意 ASIMOを同一データ以外に書き換える場合には、いったん動作停止してから書き換えてください。

(b) アシンクロナス・シリアル・インタフェース・ステータス・レジスタ 0 (ASISO) ASISOは、8 ビット・メモリ操作命令で読み出します。 RESET 入力により、00Hになります。

アドレス:FFA1H リセット時:00H R

| 略号    | 7 | 6 | 5 | 4 | 3 | 2   | 1   | 0    |
|-------|---|---|---|---|---|-----|-----|------|
| ASIS0 | 0 | 0 | 0 | 0 | 0 | PE0 | FE0 | OVE0 |

| PE0 | パリティ・エラー・フラグ         |
|-----|----------------------|
| 0   | パリティ・エラーなし           |
| 1   | パリティ・エラー発生           |
|     | (送信データのパリティが一致しないとき) |

| FE0 | フレーミング・エラー・フラグ              |
|-----|-----------------------------|
| 0   | フレーミング・エラーなし                |
| 1   | フレーミング・エラー発生 <sup>注 1</sup> |
|     | (ストップ・ビットが検出されないとき)         |

| OVE0 | オーバラン・エラー・フラグ                     |
|------|-----------------------------------|
| 0    | オーバラン・エラーなし                       |
| 1    | オーバラン・エラー発生 <sup>注 2</sup>        |
|      | (受信バッファ・レジスタ 0 (RXB0)からデータを読み出す前に |
|      | 次の受信動作が完了したとき)                    |

- 注1. アシンクロナス・シリアル・インタフェース・モード・レジスタ 0 (ASIMO) のビット 2 (SLO) でストップ・ビット長を 2 ビットに設定した場合も、受信時のストップ・ビット検出は 1 ビットのみです。
  - 2. オーバラン・エラーが発生したとき、受信バッファ・レジスタ 0 (RXBO) を読み出すまで、オーバラン・エラーが発生し続けます。

(c) ボー・レート・ジェネレータ・コントロール・レジスタ 0 (BRGC0)

BRGC0は、8ビット・メモリ操作命令で設定します。

RESET 入力により、00Hになります。

アドレス:FFA2H リセット時:00H R/W

略号 7 6 5 4 3 2 1 0 BRGC0 0 TPS02 TPS01 TPS00 MDL03 MDL02 MDL01 MDL00

| TPS02 | TPS01 | TPS00 | 5 ビット・カウンタのソース・クロック選択 | n |
|-------|-------|-------|-----------------------|---|
| 0     | 0     | 0     | ASCK0への外部クロック入力       | 0 |
| 0     | 0     | 1     | fx/2                  | 1 |
| 0     | 1     | 0     | fx/2 <sup>2</sup>     | 2 |
| 0     | 1     | 1     | fx/2 <sup>3</sup>     | 3 |
| 1     | 0     | 0     | fx/2 <sup>4</sup>     | 4 |
| 1     | 0     | 1     | fx/2 <sup>5</sup>     | 5 |
| 1     | 1     | 0     | fx/2 <sup>6</sup>     | 6 |
| 1     | 1     | 1     | fx/2 <sup>7</sup>     | 7 |

| MDL03 | MDL02 | MDL01 | MDL00 | ボー・レート・ジェネレー | k  |
|-------|-------|-------|-------|--------------|----|
|       |       |       |       | タの出力クロックの選択  |    |
| 0     | 0     | 0     | 0     | fscко/16     | 0  |
| 0     | 0     | 0     | 1     | fscко/17     | 1  |
| 0     | 0     | 1     | 0     | fscко/18     | 2  |
| 0     | 0     | 1     | 1     | fscко/19     | 3  |
| 0     | 1     | 0     | 0     | fscко/20     | 4  |
| 0     | 1     | 0     | 1     | fscко/21     | 5  |
| 0     | 1     | 1     | 0     | fscко/22     | 6  |
| 0     | 1     | 1     | 1     | fscко/23     | 7  |
| 1     | 0     | 0     | 0     | fscко/24     | 8  |
| 1     | 0     | 0     | 1     | fscко/25     | 9  |
| 1     | 0     | 1     | 0     | fscко/26     | 10 |
| 1     | 0     | 1     | 1     | fscко/27     | 11 |
| 1     | 1     | 0     | 0     | fscко/28     | 12 |
| 1     | 1     | 0     | 1     | fscко/29     | 13 |
| 1     | 1     | 1     | 0     | fscко/30     | 14 |
| 1     | 1     | 1     | 1     | 設定禁止         | _  |

注意 通信動作中にBRGC0への書き込みを行うと、ボー・レート・ジェネレータの出力が乱れ正常に通信ができなくなります。したがって、通信動作中にはBRGC0への書き込みを行わないでください。

備考1. fx :メイン・システム・クロック発振周波数

fscko : 5 ビット・カウンタのソース・クロック
 n :TPS00-TPS02で設定した値(0≦n≦7)

4. k : MDL00-MDL03で設定した値(0≤k≤14)

生成するボー・レート用の送受信クロックは、メイン・システム・クロックを分周した信号になります。

・メイン・システム・クロックによるボー・レート用の送受信クロックの生成 メイン・システム・クロックを分周して送受信クロックを生成します。メイン・システム・クロックから 生成するボー・レートは次の式によって求められます。

$$[\# - \cdot \nu - \Vdash] = \frac{fx}{2^{n+1} (k+16)} [Hz]$$

fx :メイン・システム・クロック発振周波数

5 ビット・カウンタのソース・クロックにASCK0を選択したときは、上式のfxにASCK0端子への入力クロック周波数を代入してください。

n : TPS00-TPS02で設定した値(0≦n≦7) k : MDL00-MDL03で設定した値(0≦k≦14)

表13-2 メイン・システム・クロックとボー・レートの誤差との関係

| ボー・レート | fx = 8.38 | 386 MHz | fx = 8.0 | 00 MHz | fx = 7.37 | 728 MHz | fx = 5.0 | 00 MHz | fx = 4.19 | 943 MHz |
|--------|-----------|---------|----------|--------|-----------|---------|----------|--------|-----------|---------|
| [bps]  | BRGC0     | 誤差(%)   | BRGC0    | 誤差(%)  | BRGC0     | 誤差(%)   | BRGC0    | 誤差(%)  | BRGC0     | 誤差(%)   |
| 600    | _         | _       | _        | _      | _         | _       | _        | _      | 7BH       | 1.14    |
| 1200   | 7BH       | 1.10    | 7AH      | 0.16   | 78H       | 0       | 70H      | 1.73   | 6BH       | 1.14    |
| 2400   | 6BH       | 1.10    | 6AH      | 0.16   | 68H       | 0       | 60H      | 1.73   | 5BH       | 1.14    |
| 4800   | 5BH       | 1.10    | 5AH      | 0.16   | 58H       | 0       | 50H      | 1.73   | 4BH       | 1.14    |
| 9600   | 4BH       | 1.10    | 4AH      | 0.16   | 48H       | 0       | 40H      | 1.73   | звн       | 1.14    |
| 19200  | звн       | 1.10    | ЗАН      | 0.16   | 38H       | 0       | 30H      | 1.73   | 2BH       | 1.14    |
| 31250  | 31H       | -1.3    | 30H      | 0      | 2DH       | 1.70    | 24H      | 0      | 21H       | -1.3    |
| 38400  | 2BH       | 1.10    | 2AH      | 0.16   | 28H       | 0       | 20H      | 1.73   | 1BH       | 1.14    |
| 76800  | 1BH       | 1.10    | 1AH      | 0.16   | 18H       | 0       | 10H      | 1.73   | _         | _       |
| 115200 | 12H       | 1.10    | 11H      | 2.12   | 10H       | 0       | _        | _      | _         | _       |

備考 fx :メイン・システム・クロック発振周波数

#### ・ボー・レートの許容誤差範囲

ボー・レートの誤差は、1フレームのビット数、および5ビット・カウンタの分周比[1/(16+k)]に依存します。

図13-7にボー・レートの許容誤差の例を示します。

#### 図13-7 サンプリング誤差を考慮したボー・レートの許容誤差(k=0の場合)



ボー・レート許容誤差(
$$k = 0$$
の場合) =  $\frac{\pm 15.5}{320}$  ×100 = 4.8438(%)

注意 上記の許容誤差値は、理想サンプル点からの計算値です。実際の設計においては、スタート・ビット検出タイミングの誤差なども考慮して、マージンを取ってください。

備考 T:5ビット・カウンタのソース・クロック周期

## (d) ポート・モード・レジスタ2 (PM2)

ポート2の入力/出力を1ビット単位で設定するレジスタです。

P24/TxD0端子をシリアル・データ出力として使用するとき、PM24およびP24の出力ラッチに 0 を設定してください。

P23/RxD0端子をシリアル・データ入力として、P25/ASCK0端子をクロック入力として使用するとき、PM23、PM25に1を設定してください。このときP23、P25の出力ラッチは0または1のどちらでもかまいません。

PM2は、1 ビット・メモリ操作命令または8 ビット・メモリ操作命令で設定します。 RESET入力により、FFHになります。

アドレス:FF22H リセット時:FFH R/W 略号 0 5 3 2 PM2 PM25 PM24 PM23 PM22 PM21 PM20 1

| PM2n | P2n端子の入出力モードの選択(n = 0-5) |
|------|--------------------------|
| 0    | 出力モード(出力バッファ・オン)         |
| 1    | 入力モード(出力バッファ・オフ)         |

#### (2) 通信動作

#### (a) データ・フォーマット

送受信データのフォーマットを図13-8に示します。

図13-8 アシンクロナス・シリアル・インタフェースの送受信データのフォーマット



1データ・フレームは、次に示す各ビットで構成されます。

- ・スタート・ビット……1ビット
- ・キャラクタ・ビット…7ビット/8ビット(先頭LSB)
- ・パリティ・ビット……偶数パリティ/奇数パリティ/0パリティ/パリティなし
- ・ストップ・ビット……1ビット/2ビット

1 データ・フレーム内のキャラクタ・ビット長の指定、パリティ選択、ストップ・ビット長の指定は、アシンクロナス・シリアル・インタフェース・モード・レジスタ 0 (ASIMO) によって行います。

キャラクタ・ビットとして7ビットを選択した場合、下位7ビット(ビット0-6)のみが有効となり、送信の場合は最上位ビット(ビット7)は無視され、受信の場合は必ず最上位ビット(ビット7)は"0"になります。

シリアルの転送レートの設定は、ボー・レート・ジェネレータ・コントロール・レジスタ 0 (BRGCO) によって行います。

また、シリアル・データの受信エラーが発生した場合、アシンクロナス・シリアル・インタフェース・ステータス・レジスタ 0 (ASISO) の状態を読むことによって受信エラーの内容を判定できます。

## (b) パリティの種類と動作

パリティ・ビットは通信データのビット誤りを検出するためのビットです。通常は、送信側と受信側のパリティ・ビットは同一の種類のものを使用します。偶数パリティと奇数パリティでは、1ビット(奇数個)の誤りを検出できます。0パリティとパリティなしとでは、誤りを検出できません。

#### (i) 偶数パリティ

#### • 送信時

パリティ・ビットを含めた送信データ中の, 値が"1"のキャラクタ・ビットの数を偶数個にするように制御します。パリティ・ビットの値は次のようになります。

送信データ中で値が"1"のキャラクタ・ビットの数が奇数個:1 送信データ中で値が"1"のキャラクタ・ビットの数が偶数個:0

#### • 受信時

パリティ・ビットを含めた受信データ中の、値が"1"のキャラクタ・ビットの数をカウントし、 奇数個であった場合にパリティ・エラーを発生します。

#### (ii) 奇数パリティ

#### ・送信時

偶数パリティとは逆に、パリティ・ビットを含めた送信データ中の、値が"1"のキャラクタ・ビットの数を奇数個にするように制御します。パリティ・ビットの値は次のようになります。

送信データ中で値が"1"のキャラクタ・ビットの数が奇数個:0 送信データ中で値が"1"のキャラクタ・ビットの数が偶数個:1

#### ・受信時

パリティ・ビットを含めた受信データ中の、値が"1"のキャラクタ・ビットの数をカウントし、偶数個であった場合にパリティ・エラーを発生します。

# (iii) 0パリティ

送信時には、送信データによらずパリティ・ビットを"0"にします。 受信時には、パリティ・ビットの検査を行いません。したがって、パリティ・ビットが"0"でも "1"でもパリティ・エラーを発生しません。

# (iv) パリティなし

送信データにパリティ・ビットを付加しません。

受信時にもパリティ・ビットがないものとして受信を行います。パリティ・ビットがないため、パリティ・エラーを発生しません。

## (c)送 信

送信動作は、アシンクロナス・シリアル・インタフェース・モード 0 (ASIMO) のビット7 (TXEO) がセット (1) されると許可状態になり、送信シフト・レジスタ0 (TXSO) に送信データを書き込むことによって送信動作は起動します。スタート・ビット、パリティ・ビット、ストップ・ビットは自動的に付加されます。

送信動作の開始により、TXS0内のデータがシフト・アウトされTXS0が空になると、送信完了割り込み要求(INTSTO)が発生します。

送信完了割り込みのタイミングを図13-9に示します。

## 図13-9 アシンクロナス・シリアル・インタフェース送信完了割り込み要求タイミング

# (i) ストップ・ビット長:1



## (ii) ストップ・ビット長:2



注意 送信動作中にはアシンクロナス・シリアル・インタフェース・モード・レジスタ 0 (ASIMO) を 書き換えないでください。送信中にASIMOレジスタを書き換えると、それ以降の送信動作ができ なくなる場合があります (RESET 入力により、正常になります)。

#### (d)受 信

受信動作はレベル検出を行っています。

受信動作はアシンクロナス・シリアル・インタフェース・モード・レジスタ 0 (ASIMO) のビット 6 (RXEO) がセット (1) されると許可状態となり、RxD0端子入力のサンプリングを行います。

RxD0端子入力のサンプリングは、ボー・レート・ジェネレータ・コントロール・レジスタ 0 (BRGC0) で指定したシリアル・クロックで行います。

RxD0端子入力がロウ・レベルになると、ボー・レート・ジェネレータの5ビット・カウンタがカウントを開始し、設定したボー・レートの半分の時間が経過したところでデータ・サンプリングのスタート・タイミング信号を出力します。このスタート・タイミング信号で再度RxD0端子入力をサンプリングした結果、ロウ・レベルであれば、スタート・ビットとして認識し、5ビット・カウンタを初期化してカウントを開始し、データのサンプリングを行います。スタート・ビットに続いて、キャラクタ・データ、パリティ・ビットおよび1ビットのストップ・ビットが検出されると、1フレームのデータ受信が終了します。

1フレームのデータ受信が終了すると、シフト・レジスタ内の受信データを受信バッファ・レジスタ 0 (RXB0) に転送し、INTSR0 (受信完了割り込み要求)を発生します。

なお、受信動作中にRXE0ビットをリセット(0)すると、ただちに受信動作を停止します。このとき、RXB0およびASIS0の内容は変化せず、また、INTSR0、INTSER0(受信エラー割り込み要求)も発生しません。

図13-10にアシンクロナス・シリアル・インタフェース受信完了割り込み要求タイミングを示します。

図13-10 アシンクロナス・シリアル・インタフェース受信完了割り込み要求タイミング



注意 RxD0端子入力がロウ・レベルの状態で受信動作を許可すると、ただちに受信動作を開始してしまいますので、必ずハイ・レベルにしてから受信動作を許可してください。

#### (e) 受信エラー

受信動作時のエラーには、パリティ・エラー、フレーミング・エラー、オーバラン・エラーの3種類があります。データ受信の結果、エラー・フラグがアシンクロナス・シリアル・インタフェース・ステータス・レジスタ0(ASISO)内に立つと、受信エラー割り込み要求(INTSERO)を発生します。受信エラー割り込みは、受信完了割り込み要求(INTSRO)より先に発生します。受信エラー要因を表13-3に示します。

受信エラー割り込み処理(INTSERO)内でASISOの内容を読み出すことによって、いずれのエラーが 受信時に発生したかを検出できます(表13-3、図13-11参照)。

ASISOの内容は、受信バッファ・レジスタ 0(RXBO)を読み出すか、次のデータを受信することでリセット(0)されます(次のデータにエラーがあれば、そのエラー・フラグがセットされます)。

| 受信エラー      | 要因                                    | ASIS0の値 |
|------------|---------------------------------------|---------|
| パリティ・エラー   | パリティ指定と受信データのパリティが一致しない               | 04H     |
| フレーミング・エラー | ストップ・ビットが検出されない                       | 02H     |
| オーバラン・エラー  | 受信バッファ・レジスタ 0 (RXBO)からデータを読み出す前に,次のデー | 01H     |
|            | タ受信完了                                 |         |

表13-3 受信エラーの要因





注 ISRM0ビットがセット(1)されている場合に受信エラーが発生しても、INTSR0は発生しません。

- 注意 1. アシンクロナス・シリアル・インタフェース・ステータス・レジスタ 0 (ASISO) の内容は、受信バッファ・レジスタ 0 (RXBO) を読み出すか、次のデータを受信することにより、リセット (0) されます。エラーの内容が知りたい場合には、必ずRXBOを読み出す前にASISOを読み出してください。
  - 2. 受信エラー発生時にも、受信完了割り込み要求発生後に受信バッファ・レジスタ 0 (RXB0) を 必ず読み出してください。受信完了割り込み要求発生後にRXB0を読み出さないと、次のデータ 受信時にオーバラン・エラーが発生し、いつまでも受信エラーの状態が続いてしまいます。

# 13.4.3 赤外線データ転送モード

赤外線データ転送モードでは、(2)に示すデータ・フォーマットでのパルス出力およびパルス受信が可能です。

## (1) 使用するレジスタ

- ・アシンクロナス・シリアル・インタフェース・モード・レジスタ 0 (ASIMO)
- ・アシンクロナス・シリアル・インタフェース・ステータス・レジスタ 0 (ASISO)
- ・ボー・レート・ジェネレータ・コントロール・レジスタ 0 (BRGC0)
- ・ポート・モード・レジスタ2 (PM2)
- ・ポート2 (P2)
- (a) アシンクロナス・シリアル・インタフェース・モード・レジスタ 0 (ASIMO) ASIMOは、1 ビット・メモリ操作命令または8 ビット・メモリ操作命令で設定します。 RESET 入力により、00Hになります。

アドレス:FFA0H リセット時:00H R/W

 略号
 7
 6
 5
 4
 3
 2
 1
 0

 ASIM0
 TXE0
 RXE0
 PS01
 PS00
 CL0
 SL0
 ISRM0
 IRDAM0

| TXE0 | RXE0 | 動作モード         | RxD0/P23端子の機能 | TxD0/P24端子の機能 |
|------|------|---------------|---------------|---------------|
| 0    | 0    | 動作停止          | ポート機能(P23)    | ポート機能(P24)    |
| 0    | 1    | UARTモード(受信のみ) | シリアル機能(RxD0)  |               |
| 1    | 0    | UARTモード(送信のみ) | ポート機能(P23)    | シリアル機能(TxD0)  |
| 1    | 1    | UARTモード(送受信)  | シリアル機能(RxD0)  |               |

| PS01 | PS00 | パリティ・ビットの指定                     |
|------|------|---------------------------------|
| 0    | 0    | パリティなし                          |
| 0    | 1    | 送信時、常に0パリティ付加                   |
|      |      | 受信時、パリティの検査をしない(パリティ・エラーを発生しない) |
| 1    | 0    | 奇数パリティ                          |
| 1    | 1    | 偶数パリティ                          |

| CL0 | キャラクタ長の指定 |
|-----|-----------|
| 0   | 7ビット      |
| 1   | 8ビット      |

| SL0 | 送信データのストップ・ビット長の指定 |
|-----|--------------------|
| 0   | 1ビット               |
| 1   | 2ビット               |

| ISRM0 | エラー発生時の受信完了割り込み制御       |
|-------|-------------------------|
| 0     | エラー発生時、受信完了割り込み要求を発生する  |
| 1     | エラー発生時,受信完了割り込み要求を発生しない |

| IRDAM0 | 赤外線データ転送モードの動作の指定 <sup>注 1</sup> |
|--------|----------------------------------|
| 0      | UART(送受信)モード                     |
| 1      | 赤外線データ転送(送受信)モード <sup>注2</sup>   |

- 注1. UART/赤外線データ転送モードの指定は、TXEO, RXEOにより制御されます。
  - 2. 赤外線データ転送モード使用時は、ボー・レート・ジェネレータ・コントロール・レジスタ 0 (BRGC0) を必ず10Hに設定してください。

注意 ASIMOを同一データ以外に書き換える場合は、いったん動作停止してから書き換えてください。

(b) アシンクロナス・シリアル・インタフェース・ステータス・レジスタ 0 (ASISO) ASISOは、8 ビット・メモリ操作命令で読み出します。 RESET 入力により、00Hになります。

アドレス:FFA1H リセット時:00H R

| 略号    | 7 | 6 | 5 | 4 | 3 | 2   | 1   | 0    |
|-------|---|---|---|---|---|-----|-----|------|
| ASIS0 | 0 | 0 | 0 | 0 | 0 | PE0 | FE0 | OVE0 |

| PE0 | パリティ・エラー・フラグ         |
|-----|----------------------|
| 0   | パリティ・エラーなし           |
| 1   | パリティ・エラー発生           |
|     | (送信データのパリティが一致しないとき) |

| FE0 | フレーミング・エラー・フラグ              |
|-----|-----------------------------|
| 0   | フレーミング・エラーなし                |
| 1   | フレーミング・エラー発生 <sup>注 1</sup> |
|     | (ストップ・ビットが検出されないとき)         |

| OVE0 | オーバラン・エラー・フラグ                     |  |  |  |
|------|-----------------------------------|--|--|--|
| 0    | オーバラン・エラーなし                       |  |  |  |
| 1    | オーバラン・エラー発生 <sup>注 2</sup>        |  |  |  |
|      | (受信バッファ・レジスタ 0 (RXB0)からデータを読み出す前に |  |  |  |
|      | 次の受信動作が完了したとき)                    |  |  |  |

- 注1. アシンクロナス・シリアル・インタフェース・モード・レジスタ 0 (ASIMO) のビット 2 (SLO) でストップ・ビット長を 2 ビットに設定した場合も、受信時のストップ・ビット検出は 1 ビットのみです。
  - 2. オーバラン・エラーが発生したとき、受信バッファ・レジスタ 0 (RXB0) を読み出すまで、オーバラン・エラーが発生し続けます。

(c) ボー・レート・ジェネレータ・コントロール・レジスタ 0 (BRGC0)

BRGC0は、8ビット・メモリ操作命令で設定します。

RESET 入力により、00Hになります。

アドレス:FFA2H リセット時:00H R/W

 略号
 7
 6
 5
 4
 3
 2
 1
 0

 BRGC0
 0
 TPS02
 TPS01
 TPS00
 MDL03
 MDL02
 MDL01
 MDL00

| TPS02 | TPS01 | TPS00 | 5 ビット・カウンタのソース・クロック選択 | n |
|-------|-------|-------|-----------------------|---|
| 0     | 0     | 0     | ASCK0への外部クロック入力       | 0 |
| 0     | 0     | 1     | fx/2                  | 1 |
| 0     | 1     | 0     | fx/2 <sup>2</sup>     | 2 |
| 0     | 1     | 1     | fx/2 <sup>3</sup>     | 3 |
| 1     | 0     | 0     | fx/2 <sup>4</sup>     | 4 |
| 1     | 0     | 1     | fx/2 <sup>5</sup>     | 5 |
| 1     | 1     | 0     | fx/2 <sup>6</sup>     | 6 |
| 1     | 1     | 1     | fx/2 <sup>7</sup>     | 7 |

| MDL03 | MDL02 | MDL01 | MDL00 | ボー・レート・ジェネレー | k  |
|-------|-------|-------|-------|--------------|----|
|       |       |       |       | タの出力クロックの選択  |    |
| 0     | 0     | 0     | 0     | fscко/16     | 0  |
| 0     | 0     | 0     | 1     | fscко/17     | 1  |
| 0     | 0     | 1     | 0     | fscко/18     | 2  |
| 0     | 0     | 1     | 1     | fscко/19     | 3  |
| 0     | 1     | 0     | 0     | fscко/20     | 4  |
| 0     | 1     | 0     | 1     | fscко/21     | 5  |
| 0     | 1     | 1     | 0     | fscко/22     | 6  |
| 0     | 1     | 1     | 1     | fscко/23     | 7  |
| 1     | 0     | 0     | 0     | fscко/24     | 8  |
| 1     | 0     | 0     | 1     | fscко/25     | 9  |
| 1     | 0     | 1     | 0     | fscко/26     | 10 |
| 1     | 0     | 1     | 1     | fscко/27     | 11 |
| 1     | 1     | 0     | 0     | fscко/28     | 12 |
| 1     | 1     | 0     | 1     | fscко/29     | 13 |
| 1     | 1     | 1     | 0     | fscко/30     | 14 |
| 1     | 1     | 1     | 1     | 設定禁止         | _  |

- 注意 1. 通信動作中にBRGC0への書き込みを行うと、ボー・レート・ジェネレータの出力が乱れ正常に 通信ができなくなります。したがって、通信動作中にはBRGC0への書き込みを行わないでくだ さい。
  - 2. 赤外線データ転送モードで使用するときは、BRGC0に10Hを設定してください。

備考1.fx :メイン・システム・クロック発振周波数

2. fscкo : 5 ビット・カウンタのソース・クロック

**3.** n : TPS00-TPS02で設定した値 (0≦n≦7)

4. k : MDL00-MDL03で設定した値(0≤k≤14)

#### (d) ポート・モード・レジスタ2 (PM2)

ポート2の入力/出力を1ビット単位で設定するレジスタです。

P24/TxD0端子をシリアル・データ出力として使用するとき、PM24およびP24の出力ラッチに 0 を設定してください。

P23/RxD0端子をシリアル・データ入力として、P25/ASCK0端子をクロック入力として使用するとき、PM23、PM25に1を設定してください。このときP23、P25の出力ラッチは0または1のどちらでもかまいません。

PM2は、1ビット・メモリ操作命令または8ビット・メモリ操作命令で設定します。

RESET入力により、FFHになります。

 アドレス:FF22H
 リセット時:FFH
 R/W

 略号
 7
 6
 5
 4
 3
 2
 1
 0

 PM2
 1
 1
 PM25
 PM24
 PM23
 PM22
 PM21
 PM20

| PM2n | P2n端子の入出力モードの選択(n = 0-5) |
|------|--------------------------|
| 0    | 出力モード(出力バッファ・オン)         |
| 1    | 入力モード(出力バッファ・オフ)         |

#### (2) データ・フォーマット

UARTモードのデータ・フォーマットと比較した赤外線データ転送モードのデータ・フォーマットを図13ー12に示します。

IRフレームは、スタート・ビット、8個のデータ・ビット、1ビットのストップ・ビットで終わるパルスからなるUARTフレームのビット列に対応します。

また、そのIRフレームで送受信される電気的パルスの長さは、1 ビットの周期の3/16になります。1 ビット周期の3/16のパルスは、ビット周期の真ん中から立ち上がります(下図参照)。



#### 図13-12 赤外線データ転送モードとUARTモードのデータ・フォーマットの比較



(3)メイン・システム・クロックとボー・レートの関係 メイン・システム・クロックとボー・レートの関係を表13-4に示します。

表13-4 メイン・システム・クロックとボー・レートの関係

|        | fx = 8.3886 MHz | fx = 8.000 MHz | fx = 7.3728 MHz | fx = 5.000 MHz | fx = 4.1943 MHz |
|--------|-----------------|----------------|-----------------|----------------|-----------------|
| ボー・レート | 131031 bps      | 125000 bps     | 115200 bps      | 78125 bps      | 65536 bps       |

#### (4) ビット・レートとパルス幅

ビット・レート、ビット・レート許容誤差、パルス幅の値を表13-5に示します。

表13-5 ビット・レートとパルス幅の値

| ビット・レート              | ビット・レート許容誤差     | パルス幅最小値            | パルス幅3/16公称値 | パルス幅最大値 |
|----------------------|-----------------|--------------------|-------------|---------|
| (kbits/s)            | (% of bit rate) | (μs) <sup>注2</sup> | (μs)        | (μs)    |
| 115.2 <sup>注 1</sup> | +/-0.87         | 1.41               | 1.63        | 2.71    |

## 注1. fx = 7.3728 MHz動作時

2. ディジタル・ノイズ除去回路を1.41 MHz以上の周波数でマイコンに使用した場合。

注意 赤外線データ転送モードで使用するときは、ボー・レート・ジェネレータ・コントロール・レジスタ 0 (BRGC0) に10Hを設定してください。

備考 fx:メイン・システム・クロック発振周波数

### (5) 入力データと内部信号

### ・送信動作タイミング



### ・受信動作タイミング

設定ボー・レートの半分、データの受信が遅れます。



### 表13-6 レジスタの設定一覧

### (1)動作停止モード

|      | ASIM0 |      |      |     |     | BRGC0 |        |       |       |       | PM23  | P23   | PM24  | P24   | 端子 | 機能 | 動作 |   |          |          |     |
|------|-------|------|------|-----|-----|-------|--------|-------|-------|-------|-------|-------|-------|-------|----|----|----|---|----------|----------|-----|
| TXE0 | RXE0  | PS01 | PS00 | CL0 | SL0 | ISRM0 | IRDAM0 | TPS02 | TPS01 | TPS00 | MDL03 | MDL02 | MDL01 | MDL00 |    |    |    |   | P23/RxD0 | P24/TxD0 | モード |
| 0    | 0     | ×    | ×    | ×   | ×   | ×     | ×      | ×     | ×     | ×     | ×     | ×     | ×     | ×     | ×  | ×  | ×  | × | P23      | P24      | 停止  |
|      |       |      |      |     |     | •     |        |       | 上記以外  |       |       |       |       |       |    |    |    |   |          | 設定禁止     |     |

#### (2) アシンクロナス・シリアル・インタフェース(UART) モード

|      | ASIM0 |      |      |     |     | BRGC0 |        |       |       |       | PM23  | P23   | PM24  | P24   | 端子 | 機能 | 動作 |   |          |          |     |
|------|-------|------|------|-----|-----|-------|--------|-------|-------|-------|-------|-------|-------|-------|----|----|----|---|----------|----------|-----|
| TXE0 | RXE0  | PS01 | PS00 | CL0 | SL0 | ISRM0 | IRDAM0 | TPS02 | TPS01 | TPS00 | MDL03 | MDL02 | MDL01 | MDL00 |    |    |    |   | P23/RxD0 | P24/TxD0 | モード |
| 0    | 1     | 0/1  | 0/1  | 0/1 | ×   | 0/1   | 0      | 0/1   | 0/1   | 0/1   | 0/1   | 0/1   | 0/1   | 0/1   | 1  | ×  | ×  | × | RxD0     | P24      | 受信  |
| 1    | 0     | 0/1  | 0/1  | 0/1 | 0/1 | ×     | 0      | 0/1   | 0/1   | 0/1   | 0/1   | 0/1   | 0/1   | 0/1   | ×  | ×  | 0  | 0 | P23      | TxD0     | 送信  |
| 1    | 1     | 0/1  | 0/1  | 0/1 | 0/1 | 0/1   | 0      | 0/1   | 0/1   | 0/1   | 0/1   | 0/1   | 0/1   | 0/1   | 1  | ×  | 0  | 0 | RxD0     | TxD0     | 送受信 |
|      | 上記以外  |      |      |     |     |       |        |       | 設定禁止  |       |       |       |       |       |    |    |    |   |          |          |     |

### (3) 赤外線データ転送モード

|      | ASIM0 |      |      |     |     |       | BRGC0  |       |       |       |       | PM23  | P23   | PM24  | P24 | 端子 | 機能 | 動作 |          |          |     |
|------|-------|------|------|-----|-----|-------|--------|-------|-------|-------|-------|-------|-------|-------|-----|----|----|----|----------|----------|-----|
| TXE0 | RXE0  | PS01 | PS00 | CL0 | SL0 | ISRM0 | IRDAM0 | TPS02 | TPS01 | TPS00 | MDL03 | MDL02 | MDL01 | MDL00 |     |    |    |    | P23/RxD0 | P24/TxD0 | モード |
| 0    | 1     | 0/1  | 0/1  | 0/1 | ×   | 0/1   | 1      | 0     | 0     | 1     | 0     | 0     | 0     | 0     | 1   | ×  | ×  | ×  | RxD0     | P24      | 受信  |
| 1    | 0     | 0/1  | 0/1  | 0/1 | 0/1 | ×     | 1      | 0     | 0     | 1     | 0     | 0     | 0     | 0     | ×   | ×  | 0  | 0  | P23      | TxD0     | 送信  |
| 1    | 1     | 0/1  | 0/1  | 0/1 | 0/1 | 0/1   | 1      | 0     | 0     | 1     | 0     | 0     | 0     | 0     | 1   | ×  | 0  | 0  | RxD0     | TxD0     | 送受信 |
|      | 上記以外  |      |      |     |     |       |        | 設定禁止  |       |       |       |       |       |       |     |    |    |    |          |          |     |

注意 赤外線データ転送モードを使用する場合, BRGCOレジスタに10Hを設定してください。

備考 X:don't care, ASIMO: アシンクロナス・シリアル・インタフェース・モード・レジスタ 0

BRGCO:ボー・レート・ジェネレータ・コントロール・レジスタ O, PMXX:ポート・モード・レジスタ, PXX:ポートの出力ラッチ

# 第14章 シリアル・インタフェースSIO30, SIO31

# 14.1 シリアル・インタフェースSIO30, SIO31の機能

シリアル・インタフェースSIO3nには、次の2種類のモードがあります。

### (1)動作停止モード

シリアル転送を行わないときに使用するモードです。詳細については**14.4.1 動作停止モード**を参照してください。

### (2) 3線式シリアルI/Oモード(MSB先頭固定)

シリアル・クロック( $\overline{SCK3n}$ )、シリアル出力(SO3n)、シリアル入力(SI3n)の 3 本のラインにより、 8 ビット・データ転送を行うモードです。

3線式シリアルI/Oモードは、同時送受信動作が可能なので、データ転送の処理時間が短くなります。 シリアル転送する8ビット・データの先頭ビットは、MSB固定です。

3線式シリアルI/Oモードは、クロック同期式シリアル・インタフェースを内蔵するICや表示コントローラなどを接続するときに有効です。詳細については**14.4.2 3線式シリアルI/Oモード**を参照してください。 図14-1 に、シリアル・インタフェースSIO3nのブロック図を示します。

内部バス ₹8 🗦 シリアルI/Oシフト・ Sl3n<sup>注</sup> ○ レジスタ3n(SIO3n) SOn<sup>注</sup> ○ 出カラッチ シリアル・クロック・ 割り込み要求 SCK3n<sup>注</sup> ○ ► INTCSI3n カウンタ 信号発生回路 シリアル・ クロック セレクタ 制御回路

図14-1 シリアル・インタフェースSIO3nのブロック図

注 SI30, SO30, SCK30端子はP20, P21, P22端子と, SI31, SO31, SCK31端子はP34, P35, P36端子と 兼用しています。

備考 n = 0, 1

# 14.2 シリアル・インタフェースSIO30, SIO31の構成

シリアル・インタフェースSIO3nは、次のハードウエアで構成されています。

表14-1 シリアル・インタフェースSIO3nの構成

| 項目     | 構成                         |
|--------|----------------------------|
| レジスタ   | シリアルI/Oシフト・レジスタ3(SIO3n)    |
| 制御レジスタ | シリアル動作モード・レジスタ3(CSIM3n)    |
|        | ポート・モード・レジスタ2, 3(PM2, PM3) |
|        | ポート2,3 (P2, P3)            |

### (1) シリアルI/O シフト・レジスタ3n (SIO3n)

パラレル-シリアルの変換を行い、シリアル・クロックに同期してシリアル送受信(シフト動作)を行う 8 ビット・レジスタです。

シリアル動作モード・レジスタ3n(CSIM3n)のビット7(CSIE3n)が1のとき、SIO3nにデータを書き込むか、または読み出すことによりシリアル動作が開始されます。

送信時は、SIO3nに書き込まれたデータが、シリアル出力(SO3n)に出力されます。

受信時は、データがシリアル入力(SI3n)からSIO3nに読み込まれます。

SIO3nは、8ビット・メモリ操作命令で設定します。

RESET 入力により、不定になります。

注意 転送動作中のSIO3nアクセスは、転送起動トリガとなるアクセス以外は実行しないでください (MODEn = 0のときリード動作が、MODEn = 1のときはライト動作が禁止となります)。

備考 n = 0, 1

# 14.3 シリアル・インタフェースSIO30, SIO31を制御するレジスタ

シリアル・インタフェースSIO3nは、次の3種類のレジスタで制御します。

- ・シリアル動作モード・レジスタ3n(CSIM3n)
- ・ポート・モード・レジスタ2, 3 (PM2, PM3)
- ・ポート2,3 (P2, P3)

### (1) シリアル動作モード・レジスタ3n(CSIM3n)

シリアル動作モード・レジスタ3n(CSIM3n)は、SIO3nのシリアル・クロック、動作モード、動作の許可 /停止を設定するレジスタです。

CSIM3nは、1ビット・メモリ操作命令または8ビット・メモリ操作命令で設定します。

RESET 入力により、00Hになります。

備考 n = 0, 1

### 図14-2 シリアル動作モード・レジスタ30 (CSIM30) のフォーマット

アドレス:FFB0H リセット時:00H R/W

| 略号     | 7      | 6 | 5 | 4 | 3 | 2     | 1      | 0      |
|--------|--------|---|---|---|---|-------|--------|--------|
| CSIM30 | CSIE30 | 0 | 0 | 0 | 0 | MODE0 | SCL301 | SCL300 |

| CSIE30 | SIO        | SIO30の動作許可/禁止の指定 |                      |  |  |  |  |  |
|--------|------------|------------------|----------------------|--|--|--|--|--|
|        | シフト・レジスタ動作 | シリアル・カウンタ        | ポート                  |  |  |  |  |  |
| 0      | 動作禁止       | クリア              | ポート機能 <sup>注 1</sup> |  |  |  |  |  |
| 1      | 動作許可       | カウント動作許可         | シリアル機能十              |  |  |  |  |  |
|        |            |                  | ポート機能 <sup>注 2</sup> |  |  |  |  |  |

| MODE0 | 車         | 転送動作モード・フラグ |                    |  |  |  |  |  |
|-------|-----------|-------------|--------------------|--|--|--|--|--|
|       | 動作モード     | 転送起動トリガ     | SO30/P21端子の機能      |  |  |  |  |  |
| 0     | 送信/送受信モード | SIO30ライト    | SO30               |  |  |  |  |  |
| 1     | 受信専用モード   | SIO30リード    | P21 <sup>注 3</sup> |  |  |  |  |  |

| SCL301 | SCL300 | クロックの選択                      |
|--------|--------|------------------------------|
| 0      | 0      | SCK30への外部クロック入力              |
| 0      | 1      | fx/2 <sup>3</sup> (1.50 MHz) |
| 1      | 0      | fx/2 <sup>4</sup> (750 kHz)  |
| 1      | 1      | fx/2 <sup>5</sup> (375 kHz)  |

- 注1. CSIE30 = 0(SIO30動作停止状態)のときは、SI30、SO30、 $\overline{SCK30}$ 端子を、ポート機能として使用できます。
  - 2. CSIE30 = 1 (SIO30動作許可状態) のときは、送信機能のみ使用する場合はSI30端子、受信専用モード時はSO30端子をそれぞれポート機能として使用できます。
  - 3. MODE0 = 1 (受信専用モード) のときは、SO30端子をポート機能として使用できます。
- 注意 転送動作中にCSIM30の値を書き換えないでください。ただし、1 ビット・メモリ操作命令により、CSIE30を書き換えることはできます。
- 備考1. fx:メイン・システム・クロック発振周波数
  - 2. ( )内は, fx = 12 MHz動作時。

### 図14-3 シリアル動作モード・レジスタ31 (CSIM31) のフォーマット

アドレス:FFB8H リセット時:00H R/W

| 略号     | 7      | 6 | 5 | 4 | 3 | 2     | 1      | 0      |
|--------|--------|---|---|---|---|-------|--------|--------|
| CSIM31 | CSIE31 | 0 | 0 | 0 | 0 | MODE1 | SCL311 | SCL310 |

| CSIE31 | SIO31の動作許可/禁止の指定 |           |                      |  |  |  |  |
|--------|------------------|-----------|----------------------|--|--|--|--|
|        | シフト・レジスタ動作       | シリアル・カウンタ | ポート                  |  |  |  |  |
| 0      | 動作禁止             | クリア       | ポート機能 <sup>注 1</sup> |  |  |  |  |
| 1      | 動作許可             | カウント動作許可  | シリアル機能十              |  |  |  |  |
|        |                  |           | ポート機能 <sup>注 2</sup> |  |  |  |  |

| MODE1 | 車         | 転送動作モード・フラグ |                    |  |  |  |  |  |
|-------|-----------|-------------|--------------------|--|--|--|--|--|
|       | 動作モード     | 転送起動トリガ     | SO31/P35端子の機能      |  |  |  |  |  |
| 0     | 送信/送受信モード | SIO31ライト    | SO31               |  |  |  |  |  |
| 1     | 受信専用モード   | SIO31リード    | P35 <sup>注 3</sup> |  |  |  |  |  |

| SCL311 | SCL310 | クロックの選択                     |
|--------|--------|-----------------------------|
| 0      | 0      | SCK31への外部クロック入力             |
| 0      | 1      | fx/2³ (1.50 MHz)            |
| 1      | 0      | fx/2 <sup>4</sup> (750 kHz) |
| 1      | 1      | fx/2 <sup>5</sup> (375 kHz) |

- **注1.** CSIE31 = 0(SIO31動作停止状態)のときは、SI31, SO31, SCK31端子を、ポート機能として使用できます。
  - 2. CSIE31 = 1(SIO31動作許可状態)のときは、送信機能のみ使用する場合はSI31端子、受信専用モード時はSO31端子をそれぞれポート機能として使用できます。
  - 3. MODE1 = 1 (受信専用モード) のときは、SO31端子をポート機能として使用できます。
- 注意 転送動作中にCSIM31の値を書き換えないでください。ただし、1 ビット・メモリ操作命令により、CSIE31を書き換えることはできます。
- 備考1. fx:メイン・システム・クロック発振周波数
  - 2. ( )内は, fx = 12 MHz動作時。

### (2) ポート・モード・レジスタ2,3 (PM2, PM3)

ポート2.3の入力/出力を1ビット単位で設定するレジスタです。

P21/SO30, P35/SO31端子をシリアル・データ出力として、P22/SCK30, P36/SCK31端子をクロック出力として使用するとき、PM21,PM35, PM22, PM36およびP21, P35, P22, P36の出力ラッチに0を設定してください。

P20/SI30, P34/SI31端子をシリアル・データ入力として、P22/SCK30, P36/SCK31端子をクロック入力として使用するとき、PM20, PM34, P22, PM36に1を設定してください。

このときP20, P34, P22, P36の出力ラッチは0または1のどちらでもかまいません。

PM2, PM3は、1 ビット・メモリ操作命令または8 ビット・メモリ操作命令で設定します。 RESET入力により、FFHになります。

図14-4 ポート・モード・レジスタ2 (PM2) のフォーマット

 アドレス: FF22H
 リセット時: FFH
 R/W

 略号
 7
 6
 5
 4
 3
 2
 1
 0

 PM2
 1
 1
 PM25
 PM24
 PM23
 PM22
 PM21
 PM20

| PM2n | P2n端子の入出力モードの選択(n = 0-5) |
|------|--------------------------|
| 0    | 出力モード(出力バッファ・オン)         |
| 1    | 入力モード(出力バッファ・オフ)         |

図14-5 ポート・モード・レジスタ3 (PM3) のフォーマット

アドレス:FF23H リセット時:FFH R/W 略号 5 4 0 7 6 3 2 1 1<sup>注</sup> 1<sup>注</sup> 1注 1<sup>注</sup> PM36 PM35 PM34 РМ3 1

| PM3n | P3n端子の入出力モードの選択(n = 4-6) |
|------|--------------------------|
| 0    | 出力モード(出力バッファ・オン)         |
| 1    | 入力モード(出力バッファ・オフ)         |

注 PM3の下位 4 ビット (PM33-PM30) は 1 に固定されていないので、8 ビット・メモリ操作命令で値を設定する場合。下位 4 ビットには必ず 1 を設定してください。

# 14.4 シリアル・インタフェースSIO30, SIO31の動作

シリアル・インタフェースSIO30, SIO31の持つ2種類のモードについて説明します。

### 14.4.1 動作停止モード

動作停止モードではシリアル転送を行いませんので、消費電力を低減できます。 また、動作停止モードでは、端子を通常の入出力ポートとして使用できます。

### (1) 使用するレジスタ

動作停止モードの設定は、シリアル動作モード・レジスタ3n(CSIM3n)で行います。 CSIM3nは、1ビット・メモリ操作命令または8ビット・メモリ操作命令で設定します。 RESET 入力により、00Hになります。

アドレス:FFB0H(SIO30), FFB8H(SIO31) リセット時:00H R/W 略号 7 6 5 4 3 2 1 0 CSIM3n CSIE3n 0 0 0 MODEn SCL3n1 SCL3n0

| CSIE3n | SIO3nの動作許可/禁止の指定 |           |                    |  |  |  |  |  |  |  |
|--------|------------------|-----------|--------------------|--|--|--|--|--|--|--|
|        | シフト・レジスタ動作       | シリアル・カウンタ | ポート                |  |  |  |  |  |  |  |
| 0      | 動作禁止             | クリア       | ポート機能 <sup>注</sup> |  |  |  |  |  |  |  |

注 CSIE3n = 0 (SIO3n動作停止状態) のときは、SI3n, SO3n, SCK3n 端子を、ポート機能として使用できます。

備考 n = 0, 1

### 14.4.2 3 線式シリアルI/Oモード

3線式シリアルI/Oモードは、クロック同期式シリアル・インタフェースを内蔵する周辺ICや表示コントローラなどを接続するときに使用できます。

シリアル・クロック( $\overline{SCK3n}$ )、シリアル出力(SO3n)、シリアル入力(SI3n)の 3 本のラインで通信を行います。

### (1) 使用するレジスタ

- ・シリアル動作モード・レジスタ3n(CSIM3n)
- ・ポート・モード・レジスタ 2, 3 (PM2, PM3)
- ・ポート2,3 (P2,3)

### (a) シリアル動作モード・レジスタ3 (CSIM3n)

CSIM3nは、1 ビット・メモリ操作命令または8 ビット・メモリ操作命令で設定します。 RESET 入力により、00Hになります。

アドレス:FFB0H(SIO30), FFB8H(SIO31) リセット時:00H R/W 略号 7 6 5 4 3 2 1 0 CSIM3n CSIE3n 0 0 0 MODEn SCL3n1 SCL3n0

| CSIE3n | SIO3nの動作許可/禁止の指定 |           |                      |  |  |  |  |  |  |  |  |
|--------|------------------|-----------|----------------------|--|--|--|--|--|--|--|--|
|        | シフト・レジスタ動作       | シリアル・カウンタ | ポート                  |  |  |  |  |  |  |  |  |
| 0      | 動作禁止             | クリア       | ポート機能 <sup>注 1</sup> |  |  |  |  |  |  |  |  |
| 1      | 動作許可             | カウント動作許可  | シリアル機能十              |  |  |  |  |  |  |  |  |
|        |                  |           | ポート機能 <sup>注 2</sup> |  |  |  |  |  |  |  |  |

| MODEn | 転送動作モード・フラグ |          |                      |  |  |  |  |  |  |  |
|-------|-------------|----------|----------------------|--|--|--|--|--|--|--|
|       | 動作モード       | 転送起動トリガ  | SO3n端子の機能            |  |  |  |  |  |  |  |
| 0     | 送信/送受信モード   | SIO3nライト | SO3n                 |  |  |  |  |  |  |  |
| 1     | 受信専用モード     | SIO3nリード | ポート機能 <sup>注 3</sup> |  |  |  |  |  |  |  |

| SCL3n1 | SCL3n0 | クロックの選択                      |  |  |  |  |  |  |  |
|--------|--------|------------------------------|--|--|--|--|--|--|--|
| 0      | 0      | SCK3nへの外部クロック入力              |  |  |  |  |  |  |  |
| 0      | 1      | fx/2 <sup>3</sup> (1.50 MHz) |  |  |  |  |  |  |  |
| 1      | 0      | fx/2 <sup>4</sup> (750 kHz)  |  |  |  |  |  |  |  |
| 1      | 1      | fx/2 <sup>5</sup> (375 kHz)  |  |  |  |  |  |  |  |

- 注1. CSIE3n = 0 (SIO3n動作停止状態) のときは、SI3n, SO3n, SCK3n端子を、ポート機能として使用できます。
  - 2. CSIE3n = 1 (SIO3n動作許可状態) のときは、送信機能のみ使用する場合はSI3n端子、受信専用モード時はSO3n端子をそれぞれポート機能として使用できます。
  - 3. MODEn = 1 (受信専用モード) のときは、SO3n端子をポート機能として使用できます。

注意 転送動作中にCSIM3nの値を書き換えないでください。ただし、1 ビット・メモリ操作命令により、CSIE3nを書き換えることはできます。

備考1. fx:メイン・システム・クロック発振周波数

- 2. ( ) 内は, fx = 12 MHz動作時。
- 3. n = 0.1

### (b) ポート・モード・レジスタ2,3 (PM2, PM3)

ポート2,3の入力/出力を1ビット単位で設定するレジスタです。

P21/SO30, P35/SO31端子をシリアル・データ出力として、P22/SCK30, P36/SCK31端子をクロック出力として使用するとき、PM21, PM35, PM22, PM36およびP21, P35, P22, P36の出力ラッチに0を設定してください。

P20/Sl30, P34/Sl31端子をシリアル・データ入力として、P22/SCK30, P36/SCK31端子をクロック入力として使用するとき、PM20, PM34, PM22, PM36に1を設定してください。

このときP20, P34, P22, P36の出力ラッチは0または1のどちらでもかまいません。

PM2, PM3は、1ビット・メモリ操作命令または8ビット・メモリ操作命令で設定します。

RESET入力により、FFHになります。

アドレス:FF22H リセット時:FFH R/W

| 略号  | 7 | 6 | 5    | 4    | 3    | 2    | 1    | 0    |
|-----|---|---|------|------|------|------|------|------|
| PM2 | 1 | 1 | PM25 | PM24 | PM23 | PM22 | PM21 | PM20 |

| PM2n | P2n端子の入出力モードの選択(n = 0-5) |
|------|--------------------------|
| 0    | 出力モード(出力バッファ・オン)         |
| 1    | 入力モード(出力バッファ・オフ)         |

アドレス:FF23H リセット時:FFH R/W

| 略号  | 7 | 6    | 5    | 4    | 3              | 2              | 1              | 0              |
|-----|---|------|------|------|----------------|----------------|----------------|----------------|
| PM3 | 1 | PM36 | PM35 | PM34 | 1 <sup>注</sup> | 1 <sup>注</sup> | 1 <sup>注</sup> | 1 <sup>注</sup> |

| PM3n | P3n端子の入出力モードの選択(n = 4-6) |
|------|--------------------------|
| 0    | 出力モード(出力バッファ・オン)         |
| 1    | 入力モード(出力バッファ・オフ)         |

注 PM3の下位 4 ビット (PM33-PM30) は 1 に固定されていないので、8 ビット・メモリ操作命令で値を設定する場合、下位 4 ビットには必ず 1 を設定してください。

#### (2) 転送スタート

シリアル転送は、次の2つの条件を満たしたとき、シリアルI/Oシフト・レジスタ3n(SIO3n)に転送データをセットする(またはリードする)ことで開始します。

#### 〈転送スタート条件〉

- ・SIO3nの動作制御ビット(CSIE3n) = 1
- ・8 ビット・シリアル転送後、内部のシリアル・クロックが停止した状態か、またはSCK3nがハイ・レベルの状態

### 〈転送スタート・タイミング〉

- ・送信/送受信モード (MODEn = 0)SIO3nのライトで転送スタート
- ・受信専用モード (MODEn = 1)SIO3nのリードで転送スタート

注意 SIO3nにデータを書き込んだあと、CSIE3nを"1"にしても転送はスタートしません。

#### (3) 通信動作

3線式シリアルI/Oモードは、8ビット単位でデータの送受信を行います。データは、シリアル・クロックに同期して1ビットごとに送受信されます。

シリアルI/Oシフト・レジスタ3n(SIO3n)のシフト動作は、シリアル・クロックの立ち下がりに同期して行われます。そして、送信データがSO3nラッチに保持され、SO3n端子から出力されます。また、シリアル・クロックの立ち上がりで、SI3n端子に入力された受信データがSIO3nにラッチされます。

図14-6 3線式シリアルI/Oモードのタイミング

### (4) 転送終了

8 ビット転送終了により、シリアル転送は自動的に停止し、割り込み要求フラグ(CSIIF3n)がセットされます。

### 備考 n=0,1

ザーズ・マニュアル U16035JJ4V1UD

### (1)動作停止モード

### ・シリアル・インタフェースSIO30

|        | CSIM30 |        |        | PM20 | P20 | PM21 | P21 | PM22 | P22 |          | 端子機能     |           | 動作モード |
|--------|--------|--------|--------|------|-----|------|-----|------|-----|----------|----------|-----------|-------|
| CSIE30 | MODE0  | SCL301 | SCL300 |      |     |      |     |      |     | P20/SI30 | P21/SO30 | P22/SCK30 |       |
| 0      | ×      | ×      | ×      | ×    | ×   | ×    | ×   | ×    | ×   | P20      | P21      | P22       | 停止    |
|        |        |        |        | 上記以外 |     |      |     |      |     |          |          | 設定禁止      |       |

### ・シリアル・インタフェースSIO31

| CSIM31 |       |        | PM34   | P34 | PM35 | P35 | PM36 | P36 |   | 端子機能     |          | 動作モード     |    |
|--------|-------|--------|--------|-----|------|-----|------|-----|---|----------|----------|-----------|----|
| CSIE31 | MODE1 | SCL311 | SCL310 |     |      |     |      |     |   | P34/SI31 | P35/SO31 | P36/SCK31 |    |
| 0      | ×     | ×      | ×      | ×   | ×    | ×   | ×    | ×   | × | P34      | P35      | P36       | 停止 |
|        |       |        |        |     |      |     |      |     |   |          |          | 設定禁止      |    |

**備考** X:don't care, CSIM30, CSIM31:シリアル動作モード・レジスタ30, 31, PM×X:ポート・モード・レジスタ, P×X:ポートの出力ラッチ

### 表14-2 レジスタの設定一覧 (2/2)

### (2) 3線式シリアルI/Oモード

### ・シリアル・インタフェースSIO30

|        | CSII  | M30    |        | PM20 | P20 | PM21 | P21 | PM22 | P22 | 端子機能              |          |           | 動作モード      |
|--------|-------|--------|--------|------|-----|------|-----|------|-----|-------------------|----------|-----------|------------|
| CSIE30 | MODE0 | SCL301 | SCL300 |      |     |      |     |      |     | P20/SI30          | P21/SO30 | P22/SCK30 |            |
| 1      | 1     | 0      | 0      | 1    | ×   | ×    | ×   | 1    | ×   | SI30              | P21      | SCK30入力   | スレーブ受信     |
| 1      | 0     | 0      | 0      | 1    | ×   | 0    | 0   | 1    | ×   | SI30 <sup>注</sup> | SO30     | SCK30入力   | スレーブ送信/送受信 |
| 1      | 1     | 上記     | 以外     | 1    | ×   | ×    | ×   | 0    | 0   | SI30              | P21      | SCK30出力   | マスタ受信      |
| 1      | 0     |        |        | 1    | ×   | 0    | 0   | 0    | 0   | SI30 <sup>注</sup> | SO30     | SCK30出力   | マスタ送信/送受信  |
|        | 上記以外  |        |        |      |     |      |     |      |     |                   |          | 設定禁止      |            |

### ・シリアル・インタフェースSIO31

|        | CSIM31 |        |        | PM34 | P34 | PM35 | P35 | PM36 | P36 | 端子機能              |          |           | 動作モード      |
|--------|--------|--------|--------|------|-----|------|-----|------|-----|-------------------|----------|-----------|------------|
| CSIE31 | MODE1  | SCL311 | SCL310 |      |     |      |     |      |     | P34/SI31          | P35/SO31 | P36/SCK31 |            |
| 1      | 1      | 0      | 0      | 1    | ×   | ×    | ×   | 1    | ×   | SI31              | P35      | SCK31入力   | スレーブ受信     |
| 1      | 0      | 0      | 0      | 1    | ×   | 0    | 0   | 1    | ×   | Sl31 <sup>注</sup> | SO31     | SCK31入力   | スレーブ送信/送受信 |
| 1      | 1      | 上記     | 以外     | 1    | ×   | ×    | ×   | 0    | 0   | SI31              | P35      | SCK31出力   | マスタ受信      |
| 1      | 0      |        |        | 1    | ×   | 0    | 0   | 0    | 0   | Sl31 <sup>注</sup> | SO31     | SCK31出力   | マスタ送信/送受信  |
|        | 上記以外   |        |        |      |     |      |     |      |     |                   |          | 設定禁止      |            |

注 送信のみ使用する場合は、P20、P34として使用できます。

備考 X:don't care, CSIM30, CSIM31:シリアル動作モード・レジスタ30, 31, PM×X:ポート・モード・レジスタ, P×X:ポートの出力ラッチ

ズ・マニュアル U16035JJ4V1UD

# 第15章 割り込み機能

### 15.1 割り込み機能の種類

割り込み機能には、次の3種類があります。

### (1) ノンマスカブル割り込み

割り込み禁止状態でも受け付けられる割り込みです。また、割り込み優先順位制御の対象にならず、すべての割り込み要求に対して最優先されます。ただしノンマスカブル割り込み中の場合、割り込み要求は保留されます。

スタンバイ・リリース信号を発生します。メイン・システム・クロック動作中のHALTモードを解除しま す。

ノンマスカブル割り込みは、ウォッチドッグ・タイマからの割り込み要求だけです。

#### (2) マスカブル割り込み

マスク制御を受ける割り込みです。優先順位指定フラグ・レジスタ(PROL, PROH, PR1L)の設定により、割り込み優先順位を高い優先順位のグループと低い優先順位のグループに分けることができます。高い優先順位の割り込みは、低い優先順位の割り込みに対して、多重割り込みをすることができます。また、同一優先順位を持つ複数の割り込み要求が同時に発生しているときの優先順位が決められています(表15-1参照)。

スタンバイ・リリース信号を発生し、STOPモード、HALTモードを解除します。マスカブル割り込みには、外部割り込み要求が5要因、内部割り込み要求が13要因あります。

### (3) ソフトウエア割り込み

BRK命令の実行によって発生するベクタ割り込みです。割り込み禁止状態でも受け付けられます。また、割り込み優先順位制御の対象になりません。

### 15.2 割り込み要因と構成

割り込み要因には、ノンマスカブル割り込み、マスカブル割り込み、ソフトウェア割り込みをあわせて、合計20要因あります(表15-1参照)。

備考 ウォッチドッグ・タイマの割り込み(INTWDT)は、ノンマスカブル割り込みかマスカブル割り込み(内部)のどちらかを選択できます。

表15-1 割り込み要因一覧

| 割り込み ディフォールト・注1 割り込み要因 |         |          | 割り込み要因                      | 内部/ | ベクタ・  | 基本構成 <sup>注 2</sup> |
|------------------------|---------|----------|-----------------------------|-----|-------|---------------------|
| の種類                    | プライオリティ | 名 称      | トリガ                         | 外部  | テーブル・ | タイプ                 |
|                        |         | L 13     | 1 7 72                      |     | アドレス  |                     |
| ノンマスカブル                | _       | INTWDT   | ウォッチドッグ・タイマのオーバフロー          | 内部  | 0004H | (A)                 |
|                        |         |          | (ウォッチドッグ・タイマ・モード1選択時)       |     |       |                     |
| マスカブル                  | 0       | INTWDT   | ウォッチドッグ・タイマのオーバフロー          |     |       | (B)                 |
|                        |         |          | (インターバル・タイマ・モード選択時)         |     |       |                     |
|                        | 1       | INTP0    | 端子入力エッジ検出                   | 外部  | 0006H | (C)                 |
|                        | 2       | INTP1    |                             |     | 0008H | ]                   |
|                        | 3       | INTP2    |                             |     | 000AH |                     |
|                        | 4       | INTP3    |                             |     | 000CH |                     |
|                        | 5       | INTSER0  | シリアル・インタフェースUART0の受信エラー発生   | 内部  | 000EH | (B)                 |
|                        | 6       | INTSR0   | シリアル・インタフェースUART0の受信終了      |     | 0010H |                     |
|                        | 7       | INTST0   | シリアル・インタフェースUART0の送信終了      |     | 0012H |                     |
|                        | 8       | INTCSI30 | シリアル・インタフェースSIO30の転送終了      |     | 0014H | ]                   |
|                        | 9       | INTCSI31 | シリアル・インタフェースSIO31の転送終了      |     | 0016H |                     |
|                        | 10      | INTWTI   | 時計用タイマからの基準時間間隔信号           |     | 001AH |                     |
|                        | 11      | INTTM00  | TM0とCR00の一致(CR00をコンペア・レジスタに |     | 001CH |                     |
|                        |         |          | 指定したとき)                     |     |       |                     |
|                        |         |          | TI00またはTI01端子の有効エッジ検出(CR00を |     |       |                     |
|                        |         |          | キャプチャ・レジスタに指定したとき)          |     |       |                     |
|                        | 12      | INTTM01  | TM0とCR01の一致(CR01をコンペア・レジスタに |     | 001EH |                     |
|                        |         |          | 指定したとき)                     |     |       |                     |
|                        |         |          | TI00端子の有効エッジ検出(CR01をキャプチャ・  |     |       |                     |
|                        |         |          | レジスタに指定したとき)                |     |       |                     |
|                        | 13      | INTTM50  | TM50とCR50の一致                |     | 0020H | 1                   |
|                        | 14      | INTTM51  | TM51とCR51の一致                |     | 0022H | ]                   |
|                        | 15      | INTAD0   | A/Dコンバータの変換終了               |     | 0024H | ]                   |
|                        | 16      | INTWT    | 時計用タイマのオーバフロー               |     | 0026H |                     |
|                        | 17      | INTKR    | ポート4の立ち下がりエッジ検出             | 外部  | 0028H | (D)                 |
| ソフトウエア                 | _       | BRK      | BRK命令の実行                    | _   | 003EH | (E)                 |

注1. ディフォールト・プライオリティは、複数のマスカブル割り込みが同時に発生している場合に、優先する順位です。 0 が最高順位、17が最低順位です。

2. 基本構成タイプの(A)-(E)は、それぞれ図15-1の(A)-(E)に対応しています。

図15-1 割り込み機能の基本構成(1/2)

### (A)内部ノンマスカブル割り込み



### (B) 内部マスカブル割り込み



### (C) 外部マスカブル割り込み(INTP0-INTP3)



### 図15-1 割り込み機能の基本構成(2/2)

### (D) 外部マスカブル割り込み(INTKR)



### (E) ソフトウエア割り込み



IF :割り込み要求フラグIE :割り込み許可フラグ

ISP :インサービス・プライオリティ・フラグ

MK :割り込みマスク・フラグPR :優先順位指定フラグ

MEM:メモリ拡張モード・レジスタ

# 15.3 割り込み機能を制御するレジスタ

割り込み機能は、次の7種類のレジスタで制御します。

- ・割り込み要求フラグ・レジスタ(IF0L,IF0H,IF1L)
- ・割り込みマスク・フラグ・レジスタ(MK0L,MK0H,MK1L)
- ・優先順位指定フラグ・レジスタ(PROL,PROH,PR1L)
- ・外部割り込み立ち上がりエッジ許可レジスタ(EGP)
- ・外部割り込み立ち下がりエッジ許可レジスタ(EGN)
- ・メモリ拡張モード・レジスタ(MEM)
- ・プログラム・ステータス・ワード (PSW)

各割り込み要求ソースに対応する割り込み要求フラグ、割り込みマスク・フラグ、優先順位指定フラグ名称を表 15-2に示します。

表15-2 割り込み要求ソースに対応する各種フラグ 割り込み要求フラグ 割り込みマスク・フラグ

| 割り込み要因   | 割り込み要                | 求フラグ | 割り込みマスク | フ・フラグ | 優先順位指:  | 定フラグ |
|----------|----------------------|------|---------|-------|---------|------|
|          |                      | レジスタ |         | レジスタ  |         | レジスタ |
| INTWDT   | WDTIF <sup>注 1</sup> | IF0L | WDTMK   | MK0L  | WDTPR   | PR0L |
| INTP0    | PIF0                 |      | PMK0    |       | PPR0    |      |
| INTP1    | PIF1                 |      | PMK1    |       | PPR1    |      |
| INTP2    | PIF2                 |      | PMK2    |       | PPR2    |      |
| INTP3    | PIF3                 |      | PMK3    |       | PPR3    |      |
| INTSER0  | SERIF0               |      | SERMK0  |       | SERPR0  |      |
| INTSR0   | SRIF0                |      | SRMK0   |       | SRPR0   |      |
| INTST0   | STIF0                |      | STMK0   |       | STPR0   |      |
| INTCSI30 | CSIIF30              | IF0H | CSIMK30 | MK0H  | CSIPR30 | PR0H |
| INTCSI31 | CSIIF31              |      | CSIMK31 |       | CSIPR31 |      |
| INTWTI   | WTIIF                |      | WTIMK   |       | WTIPR   |      |
| INTTM00  | TMIF00               |      | TMMK00  |       | TMPR00  |      |
| INTTM01  | TMIF01               |      | TMMK01  |       | TMPR01  |      |
| INTTM50  | TMIF50               |      | TMMK50  |       | TMPR50  |      |
| INTTM51  | TMIF51               |      | TMMK51  |       | TMPR51  |      |
| INTAD0   | ADIF0                | IF1L | ADMK0   | MK1L  | ADPR0   | PR1L |
| INTWT    | WTIF                 |      | WTMK    |       | WTPR    |      |
| INTKR    | KRIF                 |      | KRMK    |       | KRPR    |      |

注 ウォッチドッグ・タイマをインターバル・タイマとして使用しているときの割り込み制御フラグ

### (1) 割り込み要求フラグ・レジスタ (IFOL, IFOH, IF1L)

割り込み要求フラグは、対応する割り込み要求の発生または命令の実行によりセット(1)され、割り込み要求受け付け時、 $\overline{\text{RESET}}$  入力時、命令の実行によりクリア(0)されるフラグです。

IF0L, IF0H, IF1Lは、1 ビット・メモリ操作命令または8 ビット・メモリ操作命令で設定します。また、IF0L とIF0Hをあわせて16ビット・レジスタIF0として使用するときは、16ビット・メモリ操作命令で設定します。 RESET 入力により、00Hになります。

図15-2 割り込み要求フラグ・レジスタ (IFOL, IFOH, IF1L) のフォーマット

アドレス:FFE0H リセット時:00H R/W 0 略号 7 6 5 3 2 1 IF0L STIF0 SRIF0 SERIF0 PIF3 PIF2 PIF1 PIF0 **WDTIF** アドレス:FFE1H リセット時:00H R/W 略号 3 1 IFOH TMIF51 TMIF50 TMIF01 TMIF00 WTIIF CSIIF31 CSIIF30 アドレス:FFE2H リセット時:00H R/W 略号 5 0 7 6 3 2 1 **KRIF** WTIF ADIF0 IF1L 0 0 0 0

| XXIFX | 割り込み要求フラグ             |
|-------|-----------------------|
| 0     | 割り込み要求信号が発生していない      |
| 1     | 割り込み要求信号が発生し、割り込み要求状態 |

- 注意 1. WDTIFフラグはウォッチドッグ・タイマをインターバル・タイマとして使用しているときのみ, R/W可能です。ウォッチドッグ・タイマ・モード 1 で使用する場合は,WDTIFフラグに 0 を設 定してください。
  - 2. 1F0Hのビット 2, IF1Lのビット 3-7 には、必ず 0 を設定してください。
  - 3. タイマ、シリアル・インタフェース、A/Dコンバータなどをスタンバイ解除後に動作させる場合、いったん割り込み要求フラグをクリアしてから動作させてください。ノイズなどにより割り込み要求フラグがセットされる場合があります。
  - 4. 割り込みが受け付けられた場合、まず割り込み要求フラグが自動的にクリアされてから割り込みルーチンに入ります。

★ 注意 5. 割り込み要求フラグ・レジスタのフラグ操作には、1ビット・メモリ操作命令(CLR1)を使用してください。C言語での記述の場合は、コンパイルされたアセンブラが1ビット・メモリ操作命令(CLR1)になっている必要があるため、「IFOL.0 = 0;」や「\_asm("clr1 IFOL, 0");」のようなビット操作命令を使用してください。

なお、C言語で「IFOL & = 0xfe;」のように8ビット・メモリ操作命令で記述した場合、コンパイルすると3命令のアセンブラになります。

mov a, IF0L and a, #0FEH mov IF0L, a

この場合,「mov a, IFOL」後から「mov IFOL, a」の間のタイミングで,同一の割り込み要求フラグ・レジスタ(IFOL)の他ビットの要求フラグがセット(1)されても,「mov IFOL, a」でクリア(0)されます。したがって,C言語で8ビット・メモリ操作命令を使用する場合は注意が必要です。

### (2) 割り込みマスク・フラグ・レジスタ (MK0L, MK0H, MK1L)

割り込みマスク・フラグは、対応するマスカブル割り込み処理の許可/禁止を設定するフラグです。 MKOL, MKOH, MK1Lは、1ビット・メモリ操作命令または8ビット・メモリ操作命令で設定します。また、 MKOLとMK0Hをあわせて16ビット・レジスタMK0として使用するときは、16ビット・メモリ操作命令で設定します。

RESET 入力により、FFHになります。

図15-3 割り込みマスク・フラグ・レジスタ(MKOL, MKOH, MK1L)のフォーマット

| アドレス | :FFE4H | l リセッ  | ト時:FFI | H R/W  |            |      |         |         |
|------|--------|--------|--------|--------|------------|------|---------|---------|
| 略号   | 7      | 6      | 5      | 4      | 3          | 2    | 1       | 0       |
| MK0L | STMK0  | SRMK0  | SERMK0 | РМК3   | PMK2       | PMK1 | PMK0    | WDTMK   |
|      |        |        |        |        |            |      |         |         |
| アドレス | :FFE5H | I リセッ  | ト時:FFI | H R/W  |            |      |         |         |
| 略号   | 7      | 6      | 5      | 4      | 3          | 2    | 1       | 0       |
|      |        |        |        |        |            |      |         |         |
| MK0H | TMMK51 | TMMK50 | TMMK01 | TMMK00 | WTIMK      | 1    | CSIMK31 | CSIMK30 |
| MK0H | TMMK51 | TMMK50 | TMMK01 | TMMK00 | WTIMK      | 1    | CSIMK31 | CSIMK30 |
| -    |        |        | TMMK01 |        | WTIMK      | 1    | CSIMK31 | CSIMK30 |
| -    |        |        |        |        | WTIMK<br>3 | 1    | CSIMK31 | CSIMK30 |

| XXMKX | 割り込み処理の制御 |
|-------|-----------|
| 0     | 割り込み処理許可  |
| 1     | 割り込み処理禁止  |

- 注意 1. ウォッチドッグ・タイマをウォッチドッグ・タイマ・モード 1 で使用する場合は、WDTMKフラグを読み出すと不定になっています。
  - 2. ポート 0 は、外部割り込み要求入力と兼用になっているため、ポート機能の出力モードを指定 し、出力レベルを変化させたとき、割り込み要求フラグがセットされてしまいます。したがっ て、出力モードを使用するときは、あらかじめ割り込みマスク・フラグに 1 を設定してくださ い。
  - 3. MK0Hのビット2, MK1Lのビット3-7には,必ず1を設定してください。

### (3)優先順位指定フラグ・レジスタ (PR0L, PR0H, PR1L)

優先順位指定フラグは、対応するマスカブル割り込みの優先順位を設定するフラグです。

PROL, PROH, PR1Lは、1 ビット・メモリ操作命令または8 ビット・メモリ操作命令で設定します。また、PROLとPROHをあわせて16ビット・レジスタPROとして使用するときは、16ビット・メモリ操作命令で設定します。

RESET 入力により、FFHになります。

図15-4 優先順位指定フラグ・レジスタ(PR0L, PR0H, PR1L)のフォーマット

| アドレス | :FFE8H  | 1 リセッ  | 卜時:FFI | H R/W  |       |      |         |         |
|------|---------|--------|--------|--------|-------|------|---------|---------|
| 略号   | 7       | 6      | 5      | 4      | 3     | 2    | 1       | 0       |
| PR0L | STPR0   | SRPR0  | SERPR0 | PPR3   | PPR2  | PPR1 | PPR0    | WDTPR   |
|      |         |        |        |        |       |      |         |         |
| アドレス | :FFE9H  | 1 リセッ  | 卜時:FFI | H R/W  |       |      |         |         |
| 略号   | 7       | 6      | 5      | 4      | 3     | 2    | 1       | 0       |
| PR0H | TMPR51  | TMPR50 | TMPR01 | TMPR00 | WTIPR | 1    | CSIPR31 | CSIPR30 |
|      |         |        |        |        |       |      |         |         |
| アドレス | : FFEAH | Η リセッ  | 卜時:FF  | H R/W  |       |      |         |         |
| 略号   | 7       | 6      | 5      | 4      | 3     | 2    | 1       | 0       |
| PR1L | 1       | 1      | 1      | 1      | 1     | KRPR | WTPR    | ADPR0   |

| XXPRX | 優先順位レベルの選択 |
|-------|------------|
| 0     | 高優先順位レベル   |
| 1     | 低優先順位レベル   |

- 注意 1. ウォッチドッグ・タイマをウォッチドッグ・タイマ・モード 1 で使用する場合は、WDTPRフラグに 1 を設定してください。
  - 2. PR0Hのビット 2, PR1Lのビット 3-7 には,必ず 1を設定してください。

(4) 外部割り込み立ち上がりエッジ許可レジスタ (EGP), 外部割り込み立ち下がりエッジ許可レジスタ (EGN) INTPO-INTP3の有効エッジを設定するレジスタです。

EGP, EGNは、それぞれ 1 ビット・メモリ操作命令または 8 ビット・メモリ操作命令で設定します。  $\overline{\text{RESET}}$  入力により、 $\overline{\text{00H}}$ になります。

図15-5 外部割り込み立ち上がりエッジ許可レジスタ(EGP),外部割り込み立ち下がりエッジ許可レジスタ(EGN)のフォーマット

アドレス:FF48H リセット時:00H R/W

| 略号  | 7 | 6 | 5 | 4 | 3    | 2    | 1    | 0    |
|-----|---|---|---|---|------|------|------|------|
| EGP | 0 | 0 | 0 | 0 | EGP3 | EGP2 | EGP1 | EGP0 |

アドレス:FF49H リセット時:00H R/W

| 略号  | 7 | 6 | 5 | 4 | 3    | 2    | 1    | 0    |
|-----|---|---|---|---|------|------|------|------|
| EGN | 0 | 0 | 0 | 0 | EGN3 | EGN2 | EGN1 | EGN0 |

| EGPn | EGNn | INTPn端子の有効エッジの選択(n = 0-3) |
|------|------|---------------------------|
| 0    | 0    | 割り込み禁止                    |
| 0    | 1    | 立ち下がりエッジ                  |
| 1    | 0    | 立ち上がりエッジ                  |
| 1    | 1    | 立ち上がり、立ち下がりの両エッジ          |

注意 外部割り込み要求機能からポート機能に切り替える場合に、エッジ検出を行う可能性があるため、 EGPnとEGNnを 0 に設定してからポート・モードに切り替えてください。

(5) メモリ拡張モード・レジスタ (MEM)

MEMは、ポート4の立ち上がりエッジ検出機能を設定するレジスタです。 MEMは、1ビット・メモリ操作命令または8ビット・メモリ操作命令で設定します。

RESET入力により、00Hになります。

図15-6 メモリ拡張モード・レジスタ (MEM) のフォーマット

アドレス:FF47H リセット時:00H R/W

| 略号  | 7 | 6 | 5 | 4 | 3 | 2   | 1   | 0   |
|-----|---|---|---|---|---|-----|-----|-----|
| MEM | 0 | 0 | 0 | 0 | 0 | MM2 | MM1 | MM0 |

| MM2  | MM1 | MM0 | シングルチップ/メモリ拡張モードの選択 |
|------|-----|-----|---------------------|
| 0    | 0   | 0   | シングルチップ・モード         |
| 0    | 0   | 1   | ポート4の立ち下がりエッジ検出モード  |
| 上記以外 |     |     | 設定禁止                |

注意 ポート4の立ち下がりエッジ検出機能を使用する場合は、必ずMEM = 01Hに設定してください。

#### (6) プログラム・ステータス・ワード(PSW)

プログラム・ステータス・ワードは、命令の実行結果や割り込み要求に対する現在の状態を保持するレジスタです。マスカブル割り込みの許可/禁止を設定するIEフラグと多重割り込み処理の制御を行うISPフラグがマッピングされています。

8 ビット単位で読み出し/書き込み操作ができるほか、ビット操作命令や専用命令(EI, DI)により操作ができます。また、ベクタ割り込み要求受け付け時および、BRK命令実行時には、PSWの内容は自動的にスタックに退避され、IEフラグはリセット(0)されます。また、マスカブル割り込み要求受け付け時には、受け付けた割り込みの優先順位指定フラグの内容がISPフラグに転送されます。PUSH PSW命令によってもPSWの内容はスタックに退避されます。RETI、RETB、POP PSW命令により、スタックから復帰します。

RESET入力により、PSWは02Hとなります。

図15-7 プログラム・ステータス・ワードの構成



### 15.4 割り込み処理動作

### 15.4.1 ノンマスカブル割り込み要求の受け付け動作

ノンマスカブル割り込み要求は、割り込み要求受け付け禁止状態であっても無条件に受け付けられます。また、 割り込み優先順位制御の対象にならず、すべての割り込みに対して最優先の割り込み要求です。

ノンマスカブル割り込みサービス・プログラム実行中に発生した新たなノンマスカブル割り込み要求は、現在処理中のノンマスカブル割り込みサービス・プログラムの実行が終了(RETI命令実行後)し、メイン・ルーチンを1命令実行したあと、受け付けられます。ただし、ノンマスカブル割り込みサービス・プログラム実行中に新たなノンマスカブル割り込み要求が2回以上発生しても、そのノンマスカブル割り込みサービス・プログラム実行終了後に受け付けられるノンマスカブル割り込み要求は1回分だけになります。

ノンマスカブル割り込み要求発生から受け付けまでのフロー・チャートを図15-8に、ノンマスカブル割り込み要求の受け付けタイミングを図15-9に、ノンマスカブル割り込み要求が多重に発生した場合の受け付け動作を図15-10に示します。

★ 注意 ノンマスカブル割り込みから復帰するときは、必ずRETI命令を使用してください。

図15-8 ノンマスカブル割り込み要求発生から受け付けまでのフロー・チャート



WDTM: ウォッチドッグ・タイマ・モード・レジスタ

WDT :ウォッチドッグ・タイマ

図15-9 ノンマスカブル割り込み要求の受け付けタイミング



この間に発生した割り込みは↑のタイミングで受け付けられます。

WDTIF:ウォッチドッグ・タイマ割り込み要求フラグ

### 図15-10 ノンマスカブル割り込み要求の受け付け動作

(a) ノンマスカブル割り込みサービス・プログラム実行中に 新たなノンマスカブル割り込み要求が発生した場合



(b) ノンマスカブル割り込みサービス・プログラム実行中に 新たに2回のノンマスカブル割り込み要求が発生した場合



### 15.4.2 マスカブル割り込み要求の受け付け動作

マスカブル割り込み要求は、割り込み要求フラグがセット(1)され、その割り込み要求のマスク(MK)フラグがクリア(0)されていると受け付けが可能な状態になります。ベクタ割り込み要求は、割り込み許可状態(IE フラグがセット(1)されているとき)であれば受け付けます。ただし、優先順位の高い割り込みを処理中(ISP フラグがリセット(0)されているとき)に低い優先順位に指定されている割り込み要求は受け付けられません。

★ また、ノンマスカブル割り込みサービス・プログラム実行中にEI命令を実行しても、ノンマスカブル割り込み要求は受け付けられません。

マスカブル割り込み要求が発生してから割り込み処理が行われるまでの時間は表15-3のようになります。割り込み要求の受け付けタイミングについては、図15-12、15-13を参照してください。

表15-3 マスカブル割り込み要求発生から処理までの時間

|           | 最小時間   | 最大時間 <sup>注</sup> |
|-----------|--------|-------------------|
| XXPR=0のとき | 7 クロック | 32クロック            |
| XXPR=1のとき | 8 クロック | 33クロック            |

注 除算命令の直前に割り込み要求が発生したとき、ウェイトする時間が最大となります。

備考 1 クロック:1/fcpu(fcpu:CPUクロック)

マスカブル割り込み要求が同時に発生したときは、優先順位指定フラグで高優先順位に指定されているものから受け付けられます。また、優先順位指定フラグで同一優先順位に指定されているときは、ディフォールト優先順位の高い割り込みから受け付けられます。

保留された割り込み要求は受け付け可能な状態になると受け付けられます。

割り込み要求受け付けのアルゴリズムを図15-11に示します。

マスカブル割り込み要求が受け付けられると、プログラム・ステータス・ワード(PSW)、プログラム・カウンタ(PC)の順に内容をスタックに退避し、IEフラグをリセット(0)し、受け付けた割り込みの優先順位指定フラグの内容をISPフラグへ転送します。さらに、割り込み要求ごとに決められたベクタ・テーブル中のデータをPCへロードし、分岐します。

RETI命令によって、割り込みから復帰できます。

開 始 No  $\times \times IF = 1$ ? Yes(割り込み要求発生) No  $\times$ XMK = 0? Yes 割り込み要求保留 Yes(高優先順位)  $\times$  ×PR = 0 ? **ク**同時に発生している Yes XXPR = 0の割り込み 同時に発生してい 要求で優先順位の高い Yes XXPR = 0の割り込 み要求はあるか? ものはあるか? 割り込み要求保留 No 割り込み要求保留 No No IE = 1 ? 同時に発生している 優先順位の高い割り Yes Yes 込み要求はあるか 割り込み要求保留 割り込み要求保留 ベクタ割り込み処理 No No IE = 1? Yes 割り込み要求保留

図15-11 割り込み要求受け付け処理アルゴリズム

××IF :割り込み要求フラグ××MK:割り込みマスク・フラグ××PR:優先順位指定フラグ

IE :マスカブル割り込み要求の受け付けを制御するフラグ(1=許可,0=禁止)

ISP : 現在処理中の割り込みの優先順位を示すフラグ(0=高優先順位の割り込み処理中、1=割り込み

No

割り込み要求保留

ISP = 1 ?

ベクタ割り込み処理

Yes

要求を受け付けていない、または低優先順位の割り込み処理中)

図15-12 割り込み要求の受け付けタイミング (最小時間)



**備考** 1 クロック:1/fcpu(fcpu:CPUクロック)

図15-13 割り込み要求の受け付けタイミング (最大時間)



備考 1 クロック:1/fcpu(fcpu:CPUクロック)

### 15.4.3 ソフトウエア割り込み要求の受け付け動作

ソフトウエア割り込み要求はBRK命令の実行により受け付けられます。ソフトウエア割り込みは禁止することはできません。

ソフトウエア割り込み要求が受け付けられると、プログラム・ステータス・ワード(PSW)、プログラム・カウンタ(PC)の順に内容をスタックに退避し、IEフラグをリセット(0)し、ベクタ・テーブル(003EH、003FH)の内容をPCにロードして分岐します。

RETB命令によって、ソフトウエア割り込みから復帰できます。

注意 ソフトウエア割り込みからの復帰にRETI命令を使用しないでください。

### 15.4.4 多重割り込み処理

割り込み処理中に、さらに別の割り込み要求を受け付けることを多重割り込みといいます。

多重割り込みは、割り込み要求受け付け許可状態(IE = 1)になっていなければ発生しません(ノンマスカブル割り込みを除く)。また、割り込み要求が受け付けられた時点で、割り込み要求は受け付け禁止状態(IE = 0)になります。したがって、多重割り込みを許可するには、割り込み処理中にEI命令によってIEフラグをセット(1)して、割り込み許可状態にする必要があります。

また、割り込み許可状態であっても、多重割り込みが許可されない場合がありますが、これは割り込みの優先順位によって制御されます。割り込みの優先順位には、ディフォールト優先順位とプログラマブル優先順位の2つがありますが、多重割り込みの制御はプログラマブル優先順位制御により行われます。

割り込み許可状態で、現在処理中の割り込みと同レベルか、それよりも高い優先順位の割り込み要求が発生した場合には、多重割り込みとして受け付けられます。現在処理中の割り込みより低い優先順位の割り込み要求が発生した場合には、多重割り込みとして受け付けられません。

割り込み禁止、または低優先順位のために多重割り込みが許可されなかった割り込み要求は保留されます。そして、現在の割り込み処理終了後、メイン処理の命令を少なくとも1命令実行後に受け付けられます。

なお、ノンマスカブル割り込み処理中には、多重割り込みは許可されません。

表15-4に多重割り込み可能な割り込み要求を、図15-14に多重割り込みの例を示します。

表15-4 割り込み処理中に多重割り込み可能な割り込み要求

| 多重割り込み要求    |         | ノンマスカブル | マスカブル割り込み要求 |        |        | ソフトウエア |   |
|-------------|---------|---------|-------------|--------|--------|--------|---|
|             | 割り込み要求  | PR = 0  |             | PR = 1 |        | 割り込み要求 |   |
| 処理中の割り込み    |         |         | IE = 1      | IE = 0 | IE = 1 | IE = 0 |   |
| ノンマスカブル割り込み | ×       | ×       | ×           | ×      | ×      | 0      |   |
| マスカブル割り込み   | ISP = 0 | 0       | 0           | ×      | ×      | ×      | 0 |
|             | ISP = 1 | 0       | 0           | ×      | 0      | ×      | 0 |
| ソフトウエア割り込み  |         | 0       | 0           | ×      | 0      | ×      | 0 |

備考1. ○:多重割り込み可能。

2. X:多重割り込み不可能。

3. ISP, IEはPSWに含まれるフラグです。

ISP = 0: 高優先順位の割り込み処理中

ISP = 1:割り込み要求を受け付けていないか、低優先順位の割り込み処理中

 IE = 0
 :割り込み要求受け付け禁止

 IE = 1
 :割り込み要求受け付け許可

4. PRはPROL, PROH, PR1Lに含まれるフラグです。

PR = 0: 高優先順位レベル PR = 1: 低優先順位レベル

#### 図15-14 多重割り込みの例(1/2)

### 例1. 多重割り込みが2回発生する例



割り込みINTxx処理中に、2つの割り込み要求INTyy、INTzzが受け付けられ、多重割り込みが発生する。各割り込み要求受け付けの前には、必ずEI命令が発行され、割り込み要求受け付け許可状態になっている。

### 例2. 優先順位制御により, 多重割り込みが発生しない例



割り込みINTxx処理中に発生した割り込み要求INTyyは、割り込みの優先順位がINTxxより低いため受け付けられず、多重割り込みは発生しない。INTyy要求は保留され、メイン処理1命令実行後に受け付けられる。

PR = 0: 高優先順位レベル PR = 1: 低優先順位レベル

IE=0 :割り込み要求受け付け禁止

### 図15-14 多重割り込みの例(2/2)

### 例3. 割り込みが許可されてないため、多重割り込みが発生しない例



割り込みINTxx処理では割り込みが許可されていない(EI命令が発行されていない)ので、割り込み要求INTyyは受け付けられず、多重割り込みは発生しない。INTyy要求は保留され、メイン処理1命令実行後に受け付けられる。

PR = 0: 高優先順位レベル

IE=0 :割り込み要求受け付け禁止

### 15.4.5 割り込み要求の保留

命令の中には、実行中に割り込み要求が発生しても、次の命令の実行終了までその要求の受け付けを保留する ものがあります。このような命令(割り込み要求の保留命令)を以下に示します。

- · MOV PSW, # byte
- · MOV A, PSW
- · MOV PSW, A
- · MOV1 PSW. bit, CY
- · MOV1 CY, PSW. bit
- · AND1 CY, PSW. bit
- · OR1 CY, PSW. bit
- · XOR1 CY, PSW. bit
- · SET1 PSW. bit
- · CLR1 PSW. bit
- RETB
- · RETI
- PUSH PSW
- POP PSW
- · BT PSW. bit, \$addr16
- · BF PSW. bit, \$addr16
- · BTCLR PSW. bit, \$addr16
- ٠EI
- · DI
- ・IFOL, IFOH, IF1L, MKOL, MKOH, MK1L, PROL, PROH, PR1Lの各レジスタに対する操作命令

注意 BRK命令は、上述の割り込み要求の保留命令ではありません。しかしBRK命令の実行により起動する ソフトウエア割り込みでは、IEフラグが 0 にクリアされます。したがって、BRK命令実行中にマスカ ブル割り込み要求が発生しても、割り込み要求を受け付けません。ただし、ノンマスカブル割り込み 要求は受け付けます。

割り込み要求が保留されるタイミングを図15-15に示します。

図15-15 割り込み要求の保留

| CPU処理 | 命令N | 命令M | PSW, PCの退避,<br>割り込み処理へジャンプ | 割り込み処理プログラム |
|-------|-----|-----|----------------------------|-------------|
| ××IF  |     |     |                            |             |

備考1. 命令N:割り込み要求の保留命令

- 2. 命令M:割り込み要求の保留命令以外の命令
- 3. ××IF(割り込み要求)の動作は、××PR(優先順位レベル)の値の影響を受けません。

# 第16章 スタンバイ機能

### 16.1 スタンバイ機能と構成

### 16.1.1 スタンバイ機能

スタンバイ機能は、システムの消費電力をより低減するための機能で、次の2種類のモードがあります。

### (1) HALTモード

HALT命令の実行により、HALTモードとなります。HALTモードは、CPUの動作クロックを停止させるモードです。システム・クロック発振回路の発振は継続します。このモードでは、STOPモードほどの消費電力の低減はできませんが、割り込み要求により、すぐに処理を再開したい場合や、間欠動作をさせたい場合に有効です。

### (2) STOPモード

STOP命令の実行により、STOPモードとなります。STOPモードは、メイン・システム・クロック発振回路を停止させ、システム全体が停止するモードです。CPUの消費電力を、かなり低減できます。

また、データ・メモリの低電圧 (VDD = 1.6 Vまで) 保持が可能です。したがって、超低消費電力でデータ・メモリの内容を保持する場合に有効です。

さらに、割り込み要求によって解除できるため、間欠動作も可能です。ただし、STOPモード解除時に発振 安定時間確保のためのウエイト時間がとられるため、割り込み要求によって、すぐに処理を開始しなければ ならない場合にはHALTモードを選択してください。

いずれのモードでも、スタンバイ・モードに設定される直前のレジスタ、フラグ、データ・メモリの内容はすべて保持されます。また、入出力ポートの出力ラッチ、出力バッファの状態も保持されます。

- 注意 1. STOPモードは、メイン・システム・クロックで動作しているときだけ使用できます(サブシステム・クロックの発振を停止させることができません)。HALTモードは、メイン・システム・クロック、サブシステム・クロックのどちらの動作状態でも使用できます。
  - 2. STOPモードに移行するとき、メイン・システム・クロックで動作する周辺ハードウエアの動作を必ず 停止させたのち、STOP命令を実行してください。
  - 3. A/Dコンバータ部の消費電力を低減させるためには、A/Dコンバータ・モード・レジスタ 0 (ADM0) のビット 7 (ADCS0)を 0 にクリアし、A/D変換動作を停止させてから、HALT命令またはSTOP命令 を実行してください。

## 16.1.2 スタンバイ機能を制御するレジスタ

割り込み要求でSTOPモードを解除してから発振が安定するまでのウエイト時間は、発振安定時間選択レジスタ (OSTS) で制御します。

OSTSは、8ビット・メモリ操作命令で設定します。

RESET入力により、04Hになります。したがって、 $\overline{RESET}$ 入力でSTOPモードを解除するとき、解除までの時間は $2^{17}$ /fxです。

図16-1 発振安定時間選択レジスタ (OSTS) のフォーマット

 アドレス: FFFAH
 リセット時: 04H
 R/W

 略号
 7
 6
 5
 4
 3
 2
 1
 0

 OSTS
 0
 0
 0
 0
 OSTS2
 OSTS1
 OSTS0

| OSTS2 | OSTS1 | OSTS0 | 発振安定時間の選択                     |
|-------|-------|-------|-------------------------------|
| 0     | 0     | 0     | 2 <sup>12</sup> /fx (341 μs)  |
| 0     | 0     | 1     | 2 <sup>14</sup> /fx (1.36 ms) |
| 0     | 1     | 0     | 2 <sup>15</sup> /fx (2.73 ms) |
| 0     | 1     | 1     | 2 <sup>16</sup> /fx (5.46 ms) |
| 1     | 0     | 0     | 2 <sup>17</sup> /fx (10.9 ms) |
| 上記以外  |       |       | 設定禁止                          |

注意 STOPモード解除時のウエイト時間には、STOPモード解除後にクロックが発振を開始するまでの時間 (下図 a) は含みません。これは、RESET入力による場合も、割り込み要求発生による場合も同様です。



備考1. fx:メイン・システム・クロック発振周波数

2. ( )内は、fx = 12 MHz動作時。

## 16.2 スタンバイ機能の動作

## 16.2.1 HALTモード

### (1) HALTモードの設定および動作状態

HALTモードは、HALT命令の実行により設定されます。設定時のシステム・クロックは、メイン・システム・クロック、サブシステム・クロックのいずれの場合でも設定可能です。

次にHALTモード時の動作状態を示します。

表16-1 HALTモード時の動作状態

| HALTモードの設定       | メイン・システム・クロック動作中のHALT命令実行時  |                      | サブシステム・クロック   | 動作中のHALT命令実行時   |  |  |
|------------------|-----------------------------|----------------------|---------------|-----------------|--|--|
|                  | サブシステム・クロック                 | サブシステム・クロック          | メイン・システム・クロック | メイン・システム・クロック   |  |  |
| 項目               | がない場合 <sup>注 1</sup>        | がある場合 <sup>注 2</sup> | 発振継続時         | 発振停止時           |  |  |
| クロック発生回路         | メイン・システム・ク                  | ロック,サブシステム・          | クロックとも発振可能    |                 |  |  |
|                  | CPUへのクロック供給                 | CPUへのクロック供給は停止       |               |                 |  |  |
| CPU              | 動作停止                        |                      |               |                 |  |  |
| ポート(出力ラッチ)       | HALTモード設定前のお                | 忧態を保持                |               |                 |  |  |
| 16ビット・タイマ/イベント・カ | 動作可能                        |                      |               | 動作停止            |  |  |
| ウンタ 0            |                             |                      |               |                 |  |  |
| 8 ビット・タイマ/イベント・  | 動作可能                        |                      |               | カウント・クロックにTI50, |  |  |
| カウンタ50, 51       |                             |                      |               | TI51選択時,動作可能    |  |  |
| 時計用タイマ           | カウント・クロックに                  | 動作可能                 |               | カウント・クロックに      |  |  |
|                  | fx/2 <sup>7</sup> 選択時,動作可能  |                      |               | fxт選択時,動作可能     |  |  |
| ウォッチドッグ・タイマ      | 動作可能                        |                      | 動作停止          |                 |  |  |
| クロック出力           | 出力クロックにfx-fx/2 <sup>7</sup> | 動作可能                 |               | 出力クロックにfхт選択    |  |  |
|                  | 選択時,動作可能                    |                      |               | 時,動作可能          |  |  |
| ブザー出力            | 動作可能                        |                      |               | BUZはロウ・レベル      |  |  |
| A/Dコンバータ         | 動作停止                        |                      |               |                 |  |  |
| シリアル・インタフェース     | 動作可能                        |                      |               | 外部からのクロック入      |  |  |
|                  |                             |                      |               | 力時は,動作可能        |  |  |
| 外部割り込み           | 動作可能                        |                      |               |                 |  |  |

- 注1. 外部クロックを供給しない場合を含む。
  - 2. 外部クロックを供給する場合を含む。

#### (2) HALTモードの解除

HALTモードは、次の3種類のソースによって解除できます。

#### (a) マスクされていない割り込み要求による解除

マスクされていない割り込み要求が発生すると、HALTモードは解除されます。そして、割り込み受け付け許可状態であれば、ベクタ割り込み処理が行われます。割り込み受け付け禁止状態であれば、次のアドレスの命令が実行されます。

図16-2 HALTモードの割り込み要求発生による解除



備考1. 破線は、スタンバイを解除した割り込み要求が受け付けられた場合です。

2. ウエイト時間は次のようになります。

・ベクタ割り込み処理を行う場合 :  $8 \sim 9 \ D = 0$ ・ベクタ割り込み処理を行わない場合 :  $2 \sim 3 \ D = 0$ 

### (b) ノンマスカブル割り込み要求による解除

ノンマスカブル割り込み要求が発生すると、割り込み受け付け許可、禁止の状態に関係なく、HALTモードは解除され、ベクタ割り込み処理が行われます。

ただしサブシステム・クロック動作時は、ノンマスカブル割り込み要求を発生しません。

#### (c) RESET入力による解除

RESET信号の入力があると、HALTモードは解除されます。そして、通常のリセット動作と同様にリセット・ベクタ・アドレスに分岐したあと、プログラムが実行されます。

図16-3 HALTモードのRESET入力による解除



備考1. fx:メイン・システム・クロック発振周波数

2. ( )内はfx = 12 MHz動作時

表16-2 HALTモードの解除後の動作

| 解除ソース   | $MK \times \times$ | PRXX | IE | ISP | 動 作       |
|---------|--------------------|------|----|-----|-----------|
| マスカブル   | 0                  | 0    | 0  | ×   | 次アドレス命令実行 |
| 割り込み要求  | 0                  | 0    | 1  | ×   | 割り込み処理実行  |
|         | 0                  | 1    | 0  | 1   | 次アドレス命令実行 |
|         | 0                  | 1    | ×  | 0   |           |
|         | 0                  | 1    | 1  | 1   | 割り込み処理実行  |
|         | 1                  | ×    | ×  | ×   | HALTモード保持 |
| ノンマスカブル | _                  | _    | ×  | ×   | 割り込み処理実行  |
| 割り込み要求  |                    |      |    |     |           |
| RESET入力 | _                  | _    | ×  | ×   | リセット処理    |

X: don't care

## 16.2.2 STOPモード

#### (1) STOPモードの設定および動作状態

STOPモードは、STOP命令の実行により設定されます。設定時のシステム・クロックは、メイン・システム・クロックの場合のみ設定可能です。

- 注意 1. STOPモードに設定すると、水晶発振回路部のリークを抑えるためにX2端子が内部でVDDIにプルアップされます。したがって、メイン・システム・クロックに外部クロックを使用するシステムでは、STOPモードは使用しないでください。
  - 2. スタンバイ・モードの解除に割り込み要求信号が用いられるため、割り込み要求フラグがセット、割り込みマスク・フラグがリセットされている割り込みソースがある場合には、スタンバイ・モードに入ってもただちに解除されます。したがって、STOPモードの場合はSTOP命令実行後すぐにHALTモードに入り発振安定時間選択レジスタ(OSTS)による設定時間だけウエイトしたあと動作モードに戻ります。

次にSTOPモード時の動作状態を示します。

表16-3 STOPモード時の動作状態

| STO                     | OPモードの設定  | サブシステム・クロックがある場合                                 | サブシステム・クロックがない場合 |  |  |  |  |
|-------------------------|-----------|--------------------------------------------------|------------------|--|--|--|--|
| 項目                      |           |                                                  |                  |  |  |  |  |
| クロック発生回路                |           | メイン・システム・クロックのみ発振停止                              |                  |  |  |  |  |
| CPU                     |           | 動作停止                                             |                  |  |  |  |  |
| ポート(出力ラッ                | チ)        | STOPモード設定前の状態を保持                                 |                  |  |  |  |  |
| 16ビット・タイマ/イ             | ベント・カウンタ0 | 動作停止                                             |                  |  |  |  |  |
| 8ビット・タイマ/イベント・カウンタ50,51 |           | カウント・クロックにTI50,TI51選択時のみ動作可能                     |                  |  |  |  |  |
| 時計用タイマ                  |           | カウント・クロックにfxт選択時のみ,動作可能                          | 動作停止             |  |  |  |  |
| ウォッチドッグ・                | タイマ       | 動作停止                                             |                  |  |  |  |  |
| クロック出力                  |           | 出力クロックにfxT選択時,動作可能                               | PCLはロウ・レベル       |  |  |  |  |
| ブザー出力                   |           | BUZはロウ・レベル                                       |                  |  |  |  |  |
| A/Dコンバータ                |           | 動作停止                                             |                  |  |  |  |  |
| シリアル・インタフェース            | UART以外    | シリアル・クロックに外部からの入力クロック選択時のみ、動作可能                  |                  |  |  |  |  |
| UART                    |           | 動作停止(送信シフト・レジスタ 0 (TXS0),受信シフト・レジスタ 0 (RX0),受信バッ |                  |  |  |  |  |
|                         |           | ファ・レジスタ 0 (RXB0)はクロック停止直前の値を保持)                  |                  |  |  |  |  |
| 外部割り込み                  |           | 動作可能                                             |                  |  |  |  |  |

#### (2) STOPモードの解除

STOPモードは、次の2種類のソースによって解除できます。

#### (a) マスクされていない割り込み要求による解除

マスクされていない割り込み要求が発生すると、STOPモードは解除されます。発振安定時間経過後、割り込み受け付け許可状態であれば、ベクタ割り込み処理が行われます。割り込み受け付け禁止状態であれば、次のアドレスの命令が実行されます。

図16-4 STOPモードの割り込み要求発生による解除



備考 破線は、スタンバイを解除した割り込み要求が受け付けられた場合です。

#### (b) RESET入力による解除

RESET信号の入力があると、STOPモードは解除されます。そして、発振安定時間経過後リセット動作が行われます。

図16-5 STOPモードのRESET入力による解除



備考1. fx:メイン・システム・クロック発振周波数

2. ( )内はfx = 12 MHz動作時

表16-4 STOPモードの解除後の動作

| 解除ソース   | $MK \times \times$ | PRXX | IE | ISP | 動 作       |
|---------|--------------------|------|----|-----|-----------|
| マスカブル   | 0                  | 0    | 0  | ×   | 次アドレス命令実行 |
| 割り込み要求  | 0                  | 0    | 1  | ×   | 割り込み処理実行  |
|         | 0                  | 1    | 0  | 1   | 次アドレス命令実行 |
|         | 0                  | 1    | ×  | 0   |           |
|         | 0                  | 1    | 1  | 1   | 割り込み処理実行  |
|         | 1                  | ×    | ×  | ×   | STOPモード保持 |
| RESET入力 | _                  | _    | ×  | ×   | リセット処理    |

X: don't care

## 第17章 リセット機能

リセット信号を発生させる方法には、次の2種類があります。

- (1) RESET端子による外部リセット入力
- (2) ウォッチドッグ・タイマの暴走時間検出による内部リセット

外部リセットと内部リセットは機能面での差はなく、RESET入力により、ともに0000H, 0001H番地に書かれてあるアドレスからプログラムの実行を開始します。

RESET端子にロウ・レベルが入力されるか、またはウォッチドッグ・タイマのオーバフローが発生することによってリセットがかかり、各ハードウエアは表17-1に示すような状態になります。また、リセット入力中およびリセット解除直後の発振安定時間中の各端子の状態は、ハイ・インピーダンスとなっています。

RESET端子にハイ・レベルが入力されると、リセットが解除され、発振安定時間経過後( $2^{17}/fx$ )プログラムの実行を開始します。また、ウォッチドッグ・タイマのオーバフロー発生によるリセットは、リセット後、自動的にリセットが解除され、発振安定時間経過後( $2^{17}/fx$ )プログラムの実行を開始します(図17-2 から図17-4 参照)。

注意1. 外部リセットを行う場合、RESET端子に10 µ s以上のロウ・レベルを入力してください。

- 2. リセット入力中は、メイン・システム・クロックの発振が停止しますが、サブシステム・クロックの発振は停止せず、発振状態になっています。
- 3. リセットでSTOPモードを解除するとき、リセット入力中はSTOPモード時の内容を保持します。ただし、ポート端子は、ハイ・インピーダンスとなります。

RESET ◎ リセット制御回路 リセット信号
カウント・クロック ウォッチドッグ・タイマ オーバフロー 割り込み機能

図17-1 リセット機能のブロック図

図17-2 RESET入力によるリセット・タイミング



図17-3 ウォッチドッグ・タイマのオーバフローによるリセット・タイミング



図17-4 STOPモード中のRESET入力によるリセット・タイミング



表17-1 各ハードウエアのリセット後の状態(1/2)

|                 | ハードウエア                              | リセット後の状態             |
|-----------------|-------------------------------------|----------------------|
| プログラム・カウンタ(PC)  | 注1                                  | リセット・ベクタ・テーブル        |
|                 |                                     | (0000H, 0001H)の内容がセッ |
|                 |                                     | トされる                 |
| スタック・ポインタ(SP)   |                                     | 不 定                  |
| プログラム・ステータス・ワ   | 7-ド (PSW)                           | 02H                  |
| RAM             | データ・メモリ                             | 不 定 <sup>注 2</sup>   |
|                 | 汎用レジスタ                              | 不 定 <sup>注 2</sup>   |
| ポート(出力ラッチ)      |                                     | 00H                  |
| ポート・モード・レジスタ () | , 2-5, 7 (PM0, PM2-PM5, PM7)        | FFH                  |
| プルアップ抵抗オプション・   | レジスタ 0 , 2-5, 7 (PU0, PU2-PU5, PU7) | 00H                  |
| プロセッサ・クロック・コン   | トロール・レジスタ(PCC)                      | 04H                  |
| メモリ・サイズ切り替えレシ   | ジスタ(IMS)                            | CFH <sup>注 3</sup>   |
| メモリ拡張モード・レジスタ   | (MEM)                               | 00H                  |
| 発振安定時間選択レジスタ    | (OSTS)                              | 04H                  |
| 16ビット・タイマ/      | タイマ・カウンタ 0 (TM0)                    | 0000H                |
| イベント・カウンタ       | キャプチャ/コンペア・レジスタ00, 01 (CR00, CR01)  | 不 定                  |
|                 | プリスケーラ・モード・レジスタ 0 (PRMO)            | 00H                  |
|                 | キャプチャ/コンペア・コントロール・レジスタ 0 (CRC0)     | 00H                  |
|                 | モード・コントロール・レジスタ 0 (TMC0)            | 00H                  |
|                 | 出力コントロール・レジスタ 0 (TOC0)              | 00H                  |
| 8ビット・タイマ/       | タイマ・カウンタ50,51 (TM50, TM51)          | 00H                  |
| イベント・カウンタ       | コンペア・レジスタ50,51 (CR50, CR51)         | 不 定                  |
|                 | クロック選択レジスタ50, 51(TCL50, TCL51)      | 00H                  |
|                 | モード・コントロール・レジスタ50,51 (TMC50, TMC51) | 00H                  |
| 時計用タイマ          | 動作モード・レジスタ(WTM)                     | 00H                  |
| ウォッチドッグ・タイマ     | クロック選択レジスタ(WDCS)                    | 00H                  |
|                 | モード・レジスタ(WDTM)                      | 00H                  |
|                 |                                     |                      |

- 注1. リセット入力中および発振安定時間ウエイト中の各ハードウエアの状態は、PCの内容のみ不定となります。その他は、リセット後の状態と変わりありません。
  - 2. スタンバイ・モード時にリセットがかかった場合には、リセット前の状態がリセット後も保持されます。
  - 3. 初期値はCFHですが、初期設定で各製品ごとに次に示す値を設定して使用してください。

 $\mu$  PD780021AS, 780031AS : 42H  $\mu$  PD780022AS, 780032AS : 44H  $\mu$  PD780023AS, 780033AS : C6H  $\mu$  PD780024AS, 780034AS : C8H

μPD78F0034BS :マスクROM製品に対応した値

表17-1 各ハードウエアのリセット後の状態 (2/2)

|              | ハードウエア                                    | リセット後の状態 |
|--------------|-------------------------------------------|----------|
| クロック出力/      | クロック出力選択レジスタ(CKS)                         | 00H      |
| ブザー出力制御回路    |                                           |          |
| A/Dコンバータ     | 変換結果レジスタ 0 (ADCRO)                        | 00H      |
|              | モード・レジスタ 0 (ADMO)                         | 00H      |
|              | アナログ入力チャネル指定レジスタ 0 (ADS0)                 | 00H      |
| シリアル・インタフェース | アシンクロナス・シリアル・インタフェース・モード・レジスタ 0 (ASIMO)   | 00H      |
| UART0        | アシンクロナス・シリアル・インタフェース・ステータス・レジスタ 0 (ASISO) | 00H      |
|              | ボー・レート・ジェネレータ・コントロール・レジスタ 0(BRGC0)        | 00H      |
|              | 送信シフト・レジスタ 0 (TXS0)                       | FFH      |
|              | 受信バッファ・レジスタ 0 (RXB0)                      |          |
| シリアル・インタフェース | シフト・レジスタ30, 31 (SIO30, SIO31)             | 不 定      |
| SIO30, SIO31 | 動作モード・レジスタ30, 31(CSIM30, CSIM31)          | 00H      |
| 割り込み         | 要求フラグ・レジスタ(IFOL, IF0H, IF1L)              | 00H      |
|              | マスク・フラグ・レジスタ(MKOL, MKOH, MK1L)            | FFH      |
|              | 優先順位指定フラグ・レジスタ(PROL, PROH, PR1L)          | FFH      |
|              | 外部割り込み立ち上がりエッジ許可レジスタ(EGP)                 | 00H      |
|              | 外部割り込み立ち下がりエッジ許可レジスタ(EGN)                 | 00H      |

# 第18章 μPD78F0034BS

 $\mu$ PD780024AS, 780034ASサブシリーズのフラッシュ・メモリ製品には、 $\mu$ PD78F0034BSがあります。

 $\mu$ PD78F0034BSは、基板に実装した状態でプログラムの書き込み、消去、再書き込み可能なフラッシュ・メモリを内蔵した製品です。

フラッシュ・メモリへの書き込みは、ターゲット・システムに実装した状態(オンボード)で行えます。専用フラッシュ・ライタをターゲット・システムに接続して書き込みます。

フラッシュ・メモリを使用した開発環境および用途として次のようなことが考えられます。

- $\bigcirc$ ターゲット・システムに  $\mu$ PD78F0034BSを半田実装後、ソフトウェアの変更可能
- ○ソフトウエアを区別することで少量多品種生産が容易
- ○量産立ち上げ時のデータ調整が容易

μPD78F0034BSとマスクROM製品の違いを表18-1に示します。

表18-1 μ PD78F0034BSとマスクROM製品の違い

| 項目             | μPD78F0034BS         | マスクR                   | OM製品                 |  |
|----------------|----------------------|------------------------|----------------------|--|
|                |                      | μPD780034ASサブシリーズ      | μPD780024ASサブシリーズ    |  |
| 内部ROM構造        | フラッシュ・メモリ            | マスクROM                 |                      |  |
| 内部ROM容量        | 32 Kバイト <sup>注</sup> | μPD780031AS:8 Kバイト     | μPD780021AS:8 Kバイト   |  |
|                |                      | μPD780032AS:16 Kバイト    | μPD780022AS:16 Kバイト  |  |
|                |                      | μPD780033AS:24 Kバイト    | μPD780023AS:24 Kバイト  |  |
|                |                      | μPD780034AS:32 Kバイト    | μPD780024AS:32 Kバイト  |  |
| 内部高速RAM容量      | 1024バイト <sup>注</sup> | μPD780031AS:512 バイト    | μPD780021AS:512 バイト  |  |
|                |                      | μPD780032AS:512 バイト    | μPD780022AS:512 バイト  |  |
|                |                      | μPD780033AS:1024バイト    | μPD780023AS:1024バイト  |  |
|                |                      | μPD780034AS:1024バイト    | μPD780024AS:1024 バイト |  |
| A/Dコンバータの分解能   | 10ビット                |                        | 8ビット                 |  |
| IC端子           | なし                   | あり                     |                      |  |
| Vpp端子          | あり                   | なし                     |                      |  |
| 電気的特性、半田付け推奨条件 | 第20章 電気的特性,第22章      | <b>半田付け推奨条件</b> を参照してく | ださい。                 |  |

注 メモリ・サイズ切り替えレジスタ (IMS) により、マスクROM製品と同一の容量に設定できます。

注意 フラッシュ・メモリ製品とマスクROM製品では、ノイズ耐量やノイズ輻射が異なります。試作から量産の過程でフラッシュ・メモリ製品からマスクROM製品への置き換えを検討される場合は、マスクROM製品のCS製品 (ES製品でなく)で十分に評価してください。

## 18.1 メモリ・サイズ切り替えレジスタ

 $\mu$ PD78F0034BSは、メモリ・サイズ切り替えレジスタ(IMS)により、内部メモリ容量を選択できます。IMS を設定することにより、内部メモリ容量の異なる  $\mu$ PD780021AS, 780022AS, 780023AS, 780024ASおよび  $\mu$ PD780031AS, 780032AS, 780033AS, 780034ASのメモリ・マップと同一のメモリ・マップにできます。

IMSは、8ビット・メモリ操作命令で設定します。

RESET入力により、CFHになります。

注意 プログラムの初期設定として、IMSには必ず対象のマスクROM製品の値を設定してください。なお、リセットによりIMSはCFHになりますので、リセット後は必ず対象のマスクROM製品の値を設定してください。

図18-1 メモリ・サイズ切り替えレジスタ (IMS) のフォーマット

 アドレス: FFF0H
 リセット時: CFH
 R/W

 略号
 7
 6
 5
 4
 3
 2
 1
 0

 IMS
 RAM2
 RAM1
 RAM0
 0
 ROM3
 ROM2
 ROM1
 ROM0

| RAM2 | RAM1 | RAM0 | 内部高速RAM容量の選択 |
|------|------|------|--------------|
| 0    | 1    | 0    | 512バイト       |
| 1    | 1    | 0    | 1024バイト      |
| 上記以外 | 上記以外 |      | 設定禁止         |

| ROM3 | ROM2 | ROM1 | ROM0 | 内部ROM容量の選択    |
|------|------|------|------|---------------|
| 0    | 0    | 1    | 0    | 8 Kバイト        |
| 0    | 1    | 0    | 0    | 16 Kバイト       |
| 0    | 1    | 1    | 0    | 24 Kバイト       |
| 1    | 0    | 0    | 0    | 32 Kバイト       |
| 1    | 1    | 1    | 1    | 60 Kバイト(設定禁止) |
| 上記以外 |      |      |      | 設定禁止          |

マスクROM製品と同一のメモリ・マップにするIMSの設定値を表18-2に示します。

表18-2 メモリ・サイズ切り替えレジスタの設定値

| 対象のマスクROM製品           | IMSの設定値 |
|-----------------------|---------|
| μPD780021AS, 780031AS | 42H     |
| μPD780022AS, 780032AS | 44H     |
| μPD780023AS, 780033AS | C6H     |
| μPD780024AS, 780034AS | C8H     |

注意 マスクROM製品を使用する場合,IMSには表18-2に示す値を必ず設定してください。

## 18.2 フラッシュ・メモリの特徴

フラッシュ・メモリへのプログラミングは、ターゲット・システムに実装した状態(オンボード)で、専用のフラッシュ・ライタ(Flashpro III(型番 FL-PR3、PG-FP3)/Flashpro IV(型番 FL-PR4、PG-FP4))をターゲット・システムに接続して行います。またプログラミング専用のターゲット・ボードであるフラッシュ書き込み用アダプタ(プログラム・アダプタ)を用意しています。

**備考** FL-PR3, FL-PR4, プログラム・アダプタは, 株式会社内藤電誠町田製作所(TEL(045)475-4191)の製品です。

フラッシュ・メモリによるプログラミングには、次のような利点があります。

- ○ターゲット・システムにマイコンを半田実装後、ソフトウエアの変更可能
- ○ソフトウェアを区別することで少量多品種生産が容易
- ○量産立ち上げ時のデータ調整が容易

## 18.2.1 プログラミング環境

μPD78F0034BSのフラッシュ・メモリ・プログラミングに必要な環境を示します。

専用フラッシュ・ライタとしてFlashpro III/Flashpro IV を使用した場合、専用フラッシュ・ライタには、これを制御するホスト・マシンが必要です。ホスト・マシンとフラッシュ・ライタ間の通信は、RS-232C/USB (Rev1.1) で行います。

詳細はFlashpro III/Flashpro IVのマニュアルを参照してください。

#### 備考 USBはFlashproIVのみ対応

図18-2 フラッシュ・メモリにプログラムを書き込むための環境



## 18.2.2 通信方式

専用フラッシュ・ライタと  $\mu$  PD78F0034BSとの通信は、表18-3 に示す通信方式から選択して行います。

|   | 通信方式        | Standard(TYPE)設定 <sup>注 1</sup> |                                   |             |                         |                 |               | $V_{PP}$ |
|---|-------------|---------------------------------|-----------------------------------|-------------|-------------------------|-----------------|---------------|----------|
|   |             | Port                            | Speed                             | On Target   | Frequency               | Multiply rate   |               | パルス数     |
|   |             | (COMM PORT)                     | (SIO CLOCK)                       | (CPU CLOCK) | (Flashpro Clock)        | (Multiple Rate) |               |          |
|   | 3 線式シリアルI/O | SIO-ch0                         | 2.4 kHz-625 kHz <sup>注 2</sup>    | 任意          | 1-10 MHz <sup>注 2</sup> | 1.0             | SI30/P20      | 0        |
|   | (SIO30)     | (SIO ch-0)                      | (100 Hz-1.25 MHz) <sup>注 2</sup>  |             |                         |                 | SO30/P21      |          |
|   |             |                                 |                                   |             |                         |                 | SCK30/P22     |          |
|   | 3 線式シリアルI/O | SIO-ch1                         |                                   |             |                         |                 | SI31/P34      | 1        |
|   | (SIO31)     | (SIO ch-1)                      |                                   |             |                         |                 | SO31/P35      |          |
|   |             |                                 |                                   |             |                         |                 | SCK31/P36     |          |
|   | 3 線式シリアルI/O | SIO-H/S                         |                                   |             |                         |                 | SI30/P20      | 3        |
| * | (SIO30)     | (SIO ch-0+                      |                                   |             |                         |                 | SO30/P21      |          |
|   | ハンドシェークあり   | handshake)                      |                                   |             |                         |                 | SCK30/P22     |          |
|   | UART        | UART-ch0                        | 4800-76800 Baud <sup>注 2, 3</sup> |             |                         |                 | HS/P25        |          |
|   | (UART0)     | (UART ch-0)                     | (4800-76800 bps) <sup>注2,3</sup>  |             |                         |                 | RxD0/P23      | 8        |
|   | 疑似 3 線式シリアル | Port-ch0                        | 100-1500 Hz <sup>注 2</sup>        |             |                         |                 | TxD0/P24      |          |
|   | I/O         | (Port A)                        | (100 Hz-1.25 MHz) <sup>注2</sup>   |             |                         |                 | P70/TI00/TO0  | 12       |
|   |             |                                 |                                   |             |                         |                 | (シリアル・        |          |
|   |             |                                 |                                   |             |                         |                 | データ入力)        |          |
|   |             |                                 |                                   |             |                         |                 | P71/TI01      |          |
|   |             |                                 |                                   |             |                         |                 | (シリアル・        |          |
|   |             |                                 |                                   |             |                         |                 | データ出力)        |          |
|   |             |                                 |                                   |             |                         |                 | P72/TI50/TO50 |          |
|   |             |                                 |                                   |             |                         |                 | (シリアル・        |          |
|   |             |                                 |                                   |             |                         |                 | クロック入力)       |          |

表18-3 通信方式一覧

- 注1.Flashpro IV上のStandard設定(Flashpro III上ではTYPE設定)における設定項目です。
  - 2. 電圧により設定可能な範囲が異なります。詳細は第20章 電気的特性を参照してください。
  - 3. UART通信にはボー・レート誤差のほかに、信号波形の鈍りなどが影響するため、評価のうえ使用してください。

備考 設定項目の( )内はFlashproⅣと異なる場合のFlashproⅢの設定値および設定項目です。



図18-3 通信方式選択フォーマット

図18-4 専用フラッシュ・ライタとの接続例(1/2)

#### (a) 3線式シリアルI/O (SIO3n)



備考 n = 0, 1

#### (b) 3線式シリアルI/O (SIO30) ハンドシェークあり



### (c) UART (UARTO)



- ★ 注1. VDDD, VDD1端子はオンボード上で電源が供給されている場合でも、専用フラッシュ・ライタのVDDと必ず接続してください。また、プログラミング開始前にVDD電圧を供給してください。
  - 2. X1端子はオンボード上での供給が可能です。この場合、専用フラッシュ・ライタと接続する必要はありません。

#### 図18-4 専用フラッシュ・ライタとの接続例(2/2)

#### (d) 疑似 3 線式シリアルI/O



- ★ 注1. VDDD, VDD1端子はオンボード上で電源が供給されている場合でも、専用フラッシュ・ライタのVDDと必ず接続してください。また、プログラミング開始前にVDD電圧を供給してください。
  - 2. X1端子はオンボード上での供給が可能です。この場合、専用フラッシュ・ライタと接続する必要はありません。

専用フラッシュ・ライタとしてFlashpro III/Flashpro IV を使用した場合、μPD78F0034BSに対して次の信号を生成します。詳細はFlashpro III/Flashpro IV のマニュアルを参照してください。

信号名 入出力 端子機能 端子名 SIO30 SIO31 SIO30 UART0 疑似3線 (HS)  $V_{PP}$ 出力 書き込み電圧  $V_{PP}$ 0 0  $\bigcirc$ 0  $\bigcirc$ ◎注 ◎註 ◎注 ◎註 ◎注  $V_{\text{DD}}$ 入出力 VDD電圧生成/電圧監視 VDD0, VDD1, AVDD GND グランド Vsso, Vss1, AVss, 0 0 0  $\bigcirc$ AVREF CLK 出力 クロック出力 X1  $\bigcirc$  $\bigcirc$  $\bigcirc$  $\bigcirc$  $\bigcirc$ /RESET 出力 リセット信号 RESET 0 0 0 0 0 入力 SI/RxD 受信信号 SO30/SO31/ 0 0 0 0 0 TxD0/P71 SO/TxD 出力 送信信号 SI30/SI31/RxD0/ 0  $\bigcirc$  $\bigcirc$  $\bigcirc$  $\bigcirc$ P70 SCK 出力 転送クロック SCK30/SCK31/ 0  $\bigcirc$ X P72 H/S 入力 ハンドシェーク信号 P25 (HS) × X 0 X X

表18-4 端子接続一覧

注 VDD電圧はプログラミング開始前に供給する必要があります。

備考 ◎:必ず接続してください。

○:ターゲット・ボード上で供給されていれば、接続の必要はありません。

×:接続の必要はありません。

## 18.2.3 オンボード上の端子処理

ターゲット・システム上でプログラミングを行う場合は、ターゲット・システム上に専用フラッシュ・ライタと接続するためのコネクタを設けます。

また、オンボード上に通常動作モードからフラッシュ・メモリ・プログラミング・モードへの切り替え機能が 必要になる場合があります。

#### <VPP端子>

通常動作モード時は、VPP端子に0 Vを入力します。またフラッシュ・メモリ・プログラミング・モード時は、VPP端子に10.0 V (TYP.) の書き込み電圧を供給しますので、次の端子処理を行ってください。

- (1)  $V_{PP}$ 端子にプルダウン抵抗 $RV_{PP} = 10 k\Omega$  を接続してください
- (2) ボード上のジャンパで、VPP端子の入力をライタ側または直接GNDのどちらかに切り替えてください

VPP端子の接続例を次に示します。

図18-5 VPP端子の接続例



### <シリアル・インタフェース端子>

各シリアル・インタフェースが使用する端子を次に示します。

| シリアル・インタフェース       | 使用端子                                  |
|--------------------|---------------------------------------|
| 3 線式シリアルI/O(SIO30) | SI30/P20, SO30/P21, SCK30/P22         |
| 3 線式シリアルI/O(SIO31) | SI31/P34, SO31/P35, SCK31/P36         |
| 3 線式シリアルI/O(SIO30) | SI30/P20, SO30/P21, SCK30/P22, HS/P25 |
| ハンドシェークあり          |                                       |
| UART (UARTO)       | RxD0/P23, TxD0/P24                    |
| 疑似 3 線式シリアルI/O     | P70/TI00/TO0(シリアル・データ入力),             |
|                    | P71/Tl01(シリアル・データ出力),                 |
|                    | P72/TI50/TO50(シリアル・クロック入力)            |

オンボード上でほかのデバイスと接続しているシリアル・インタフェース用の端子に、専用フラッシュ・ライタを接続する場合、信号の衝突、ほかのデバイスの異常動作などに注意してください。

#### (1) 信号の衝突

ほかのデバイス(出力)と接続しているシリアル・インタフェース用の端子(入力)に、専用フラッシュ・ライタ(出力)を接続すると、信号の衝突が発生します。この信号の衝突を避けるため、ほかのデバイスとの接続をアイソレートするか、またはほかのデバイスを出力ハイ・インピーダンス状態にしてください。

図18-6 信号の衝突(シリアル・インタフェースの入力端子)



フラッシュ・メモリ・プログラミング・モードでは、ほかのデバイスが出力する信号と専用フラッシュ・ライタから送り出される信号が衝突するため、ほかのデバイス側の信号をアイソレートしてください。

#### (2) ほかのデバイスの異常動作

ほかのデバイス (入力) と接続しているシリアル・インタフェース用の端子 (入力または出力) に、専用フラッシュ・ライタ (出力または入力) を接続する場合、ほかのデバイスに信号が出力され、異常動作を起こす可能性があります。この異常動作を避けるため、ほかのデバイスとの接続をアイソレートするか、またはほかのデバイスへの入力信号を無視するように設定してください。

図18-7 ほかのデバイスの異常動作



フラッシュ・メモリ・プログラミング・モードでは、 $\mu$ PD78F0034BSが出力する信号が、ほかのデバイスに影響を与える場合、ほかのデバイス側の信号をアイソレートしてください。



フラッシュ・メモリ・プログラミング・モードでは、専用フラッシュ・ライタが出力する信号が、ほかのデバイスに影響を与える場合、ほかのデバイス側の信号をアイソレートしてください。

#### <RESET端子>

オンボード上で、リセット信号生成回路と接続しているRESET端子に、専用フラッシュ・ライタのリセット信号を接続する場合、信号の衝突が発生します。この信号の衝突を避けるため、リセット信号生成回路との接続をアイソレートしてください。

また、フラッシュ・メモリ・プログラミング・モード期間中に、ユーザ・システムからリセット信号を入力した場合、正常なプログラミング動作が行われなくなるので、専用フラッシュ・ライタからのリセット信号以外は入力しないでください。

図18-8 信号の衝突(RESET端子)



フラッシュ・メモリ・プログラミング・モードでは、リセット信号生成回路が出力する信号と専用フラッシュ・ライタから出力される信号が衝突するため、リセット信号生成回路側の信号をアイソレートしてください。

#### <ポート端子>

フラッシュ・メモリ・プログラミング・モードに遷移すると、フラッシュ・メモリ・プログラミングと通信する端子を除くすべての端子は、すべてリセット直後と同じ状態になります。

したがって、外部デバイスが出力ハイ・インピーダンス状態などの初期状態を認めない場合は、抵抗を介してVppoに接続する、または抵抗を介してVssoに接続するなどの処置をしてください。

#### <発振端子>

オンボード上のクロックを使用する場合、X1, X2, XT1, XT2は、通常動作モード時に準拠した接続をしてください。

フラッシュ・ライタのクロック出力を使用する場合は、オンボード上のメイン発振子を切り離し、X1端子に直接接続し、X2端子はオープンにしてください。サブクロックに関しては通常動作モードに準拠します。

#### <電源>

フラッシュ・ライタの電源出力を使用する場合は、VDDO, VDDI端子はフラッシュ・ライタのVDDに、VSSO, VSSI端子はフラッシュ・ライタのGNDに、それぞれ接続してください。

オンボード上の電源を使用する場合は、通常動作モード時に準拠した接続にしてください。ただし、フラッシュ・ライタで電圧監視をするので、フラッシュ・ライタのVopは必ず接続してください。

ただし、フラッシュ・ライタで電圧監視をするため、VDDO, VDD1, VSSO, VSS1端子はフラッシュ・ライタのVDD, GNDと必ず接続してください。

その他の電源(AVDD, AVREF, AVSS)は、通常動作モード時と同じ電源を供給してください。

## 18.2.4 フラッシュ書き込み用アダプタ上の接続

フラッシュ書き込み用アダプタ使用時の推奨接続例を示します。

#### 図18-9 3線式シリアルI/O方式でのフラッシュ書き込み用アダプタ配線例(1/2)

### (a) SIO30の場合



#### 図18-9 3線式シリアルI/O方式でのフラッシュ書き込み用アダプタ配線例(2/2)

### (b) SIO31の場合



図18-10 3線式シリアルI/O方式でのフラッシュ書き込み用アダプタ配線例(ハンドシェーク使用時)



図18-11 UART方式でのフラッシュ書き込み用アダプタ配線例



図18-12 疑似 3 線式シリアルI/O方式でのフラッシュ書き込み用アダプタ配線例



# 第19章 命令セットの概要

 $\mu$ PD780024AS, 780034ASサブシリーズの命令セットを一覧表にして示します。なお、各命令の詳細な動作および機械語(命令コード)については、78K/0シリーズ ユーザーズ・マニュアル 命令編(U12326J)を参照してください。

## 19.1 凡 例

## 19.1.1 オペランドの表現形式と記述方法

各命令のオペランド欄には、その命令のオペランド表現形式に対する記述方法に従ってオペランドを記述しています(詳細は、アセンブラ仕様による)。記述方法の中で複数個あるものは、それらの要素の1つを選択します。大文字で書かれた英字および#、!、\$、[]の記号はキー・ワードであり、そのまま記述します。記号の説明は、次のとおりです。

・# :イミーディエト・データ指定

・! :絶対アドレス指定・\$ :相対アドレス指定・[ ]:間接アドレス指定

イミーディエト・データのときは、適当な数値またはレーベルを記述します。レーベルで記述する際も#,!, \$,[]記号は必ず記述してください。

| 表現形式   | 記 述 方 法                                                        |
|--------|----------------------------------------------------------------|
| r      | X (R0), A (R1), C (R2), B (R3), E (R4), D (R5), L (R6), H (R7) |
| rp     | AX (RP0), BC (RP1), DE (RP2), HL (RP3)                         |
| sfr    | 特殊機能レジスタ略号 <sup>注</sup>                                        |
| sfrp   | 特殊機能レジスタ略号(16ビット操作可能なレジスタの偶数アドレスのみ) <sup>注</sup>               |
| saddr  | FE20H-FF1FH イミーディエト・データまたはレーベル                                 |
| saddrp | FE20H-FF1FH イミーディエト・データまたはレーベル(偶数アドレスのみ)                       |
| addr16 | 0000H-FFFFH イミーディエト・データまたはレーベル                                 |
|        | (16ビット・データ転送命令時は偶数アドレスのみ)                                      |
| addr11 | 0800H-0FFFH イミーディエト・データまたはレーベル                                 |
| addr5  | 0040H-007FH イミーディエト・データまたはレーベル(偶数アドレスのみ)                       |
| word   | 16ビット・イミーディエト・データまたはレーベル                                       |
| byte   | 8 ビット・イミーディエト・データまたはレーベル                                       |
| bit    | 3 ビット・イミーディエト・データまたはレーベル                                       |
| RBn    | RB0-RB3                                                        |

表19-1 オペランドの表現形式と記述方法

注 FFD0H-FFDFHは、アドレスできません。

**備考** 特殊機能レジスタの略号は表3-5 特殊機能レジスタ一覧を参照してください。

## 19.1.2 オペレーション欄の説明

 X
 : X レジスタ

 B
 : B レジスタ

 C
 : C レジスタ

 D
 : D レジスタ

 E
 : E レジスタ

H : HレジスタL : Lレジスタ

AX : AXレジスタ・ペア;16ビット・アキュームレータ

 BC
 : BCレジスタ・ペア

 DE
 : DEレジスタ・ペア

 HL
 : HLレジスタ・ペア

 PC
 : プログラム・カウンタ

 SP
 : スタック・ポインタ

PSW :プログラム・ステータス・ワード

CY :キャリー・フラグ

AC :補助キャリー・フラグ

Z :ゼロ・フラグ

RBS : レジスタ・バンク選択フラグIE :割り込み要求許可フラグ

( ) : ( )内のアドレスまたはレジスタの内容で示されるメモリの内容

XH, XL : 16ビット・レジスタの上位8ビット, 下位8ビット

↑ : 論理積 (AND)∨ : 論理和 (OR)

∀ :排他的論理和(exclusive OR)

\_\_\_\_\_ : 反転データ

addr16 : 16ビット・イミーディエト・データまたはレーベル jdisp8 : 符号付き 8 ビット・データ(ディスプレースメント値)

## 19.1.3 フラグ動作欄の説明

(ブランク):変化なし

0 : 0 にクリアされる1 : 1 にセットされる

:結果に従ってセット/クリアされる以前に退避した値がストアされる

## 19.2 オペレーション一覧

| 命令群    | ニモニック | オペランド               | バイト | クロ | ック     | オペレーション       |   | フラク | ブ  |
|--------|-------|---------------------|-----|----|--------|---------------|---|-----|----|
| 群      |       |                     |     | 注1 | 注 2    |               | Z | AC  | CY |
| 8<br>Ľ | MOV   | r, #byte            | 2   | 4  | _      | r←byte        |   |     |    |
| ビッ     |       | saddr, #byte        | 3   | 6  | 7      | (saddr) ←byte |   |     |    |
| ット・    |       | sfr, #byte          | 3   | _  | 7      | sfr←byte      |   |     |    |
| デー     |       | A, r 注 3            | 1   | 2  | _      | A←r           |   |     |    |
| - タ転送  |       | r, A 注 3            | 1   | 2  | _      | r←A           |   |     |    |
| 送送     |       | A, saddr            | 2   | 4  | 5      | A←(saddr)     |   |     |    |
|        |       | saddr, A            | 2   | 4  | 5      | (saddr) ←A    |   |     |    |
|        |       | A, sfr              | 2   | _  | 5      | A←sfr         |   |     |    |
|        |       | sfr, A              | 2   | _  | 5      | sfr←A         |   |     |    |
|        |       | A, !addr16          | 3   | 8  | 9 + n  | A←(addr16)    |   |     |    |
|        |       | !addr16, A          | 3   | 8  | 9 + m  | (addr16)←A    |   |     |    |
|        |       | PSW, #byte          | 3   | _  | 7      | PSW←byte      | × | ×   | ×  |
|        |       | A, PSW              | 2   | _  | 5      | A←PSW         |   |     |    |
|        |       | PSW, A              | 2   | _  | 5      | PSW←A         | × | ×   | ×  |
|        |       | A, [DE]             | 1   | 4  | 5 + n  | A←(DE)        |   |     |    |
|        |       | [DE], A             | 1   | 4  | 5 + m  | (DE)←A        |   |     |    |
|        |       | A, [HL]             | 1   | 4  | 5 + n  | A←(HL)        |   |     |    |
|        |       | [HL], A             | 1   | 4  | 5 + m  | (HL)←A        |   |     |    |
|        |       | A, [HL+byte]        | 2   | 8  | 9 + n  | A←(HL+byte)   |   |     |    |
|        |       | [HL+byte], A        | 2   | 8  | 9 + m  | (HL+byte)←A   |   |     |    |
|        |       | A, [HL+B]           | 1   | 6  | 7 + n  | A←(HL+B)      |   |     |    |
|        |       | [HL+B], A           | 1   | 6  | 7 + m  | (HL+B)←A      |   |     |    |
|        |       | A, [HL+C]           | 1   | 6  | 7 + n  | A←(HL+C)      |   |     |    |
|        |       | [HL+C], A           | 1   | 6  | 7 + m  | (HL+C)←A      |   |     |    |
|        | XCH   | A, r <sup>注 3</sup> | 1   | 2  | _      | A↔r           |   |     |    |
|        |       | A, saddr            | 2   | 4  | 6      | A←→(saddr)    |   |     |    |
|        |       | A, sfr              | 2   | _  | 6      | A↔sfr         |   |     |    |
|        |       | A, !addr16          | 3   | 8  | 10+n+m | A←→ (addr16)  |   |     |    |
|        |       | A, [DE]             | 1   | 4  | 6+n+m  | A↔(DE)        |   |     |    |
|        |       | A, [HL]             | 1   | 4  | 6+n+m  | A↔(HL)        |   |     |    |
|        |       | A, [HL+byte]        | 2   | 8  | 10+n+m | A ← (HL+byte) |   |     |    |
|        |       | A, [HL+B]           | 2   | 8  | 10+n+m | A ←→ (HL+B)   |   |     |    |
|        |       | A, [HL+C]           | 2   | 8  | 10+n+m | A↔(HL+C)      |   |     |    |
|        |       |                     |     |    |        |               | _ |     |    |

- 注1. 内部高速RAM領域をアクセスしたときまたはデータ・アクセスしない命令のとき。
  - 2. 内部高速RAM以外の領域をアクセスしたとき。
  - 3. r = Aを除く。
- **備考1.** 命令の1クロックはプロセッサ・クロック・コントロール・レジスタ(PCC)で選択したCPUクロック (fcpu) の1クロック分です。
  - 2. クロック数は内部ROM領域にプログラムがある場合です。
  - 3. n は外部メモリ拡張領域をリードしたときのウエイト数です。
  - 4. mは外部メモリ拡張領域をライトしたときのウエイト数です。

| 命      | ニモニック | オペランド                | バイト | クロ | ック    | オペレーション                     |   | フラ | グ  |
|--------|-------|----------------------|-----|----|-------|-----------------------------|---|----|----|
| 命令群    |       |                      |     | 注1 | 注 2   |                             | Z | AC | CY |
| 16     | MOVW  | rp, #word            | 3   | 6  | _     | rp←word                     |   |    |    |
| ビット    |       | saddrp, #word        | 4   | 8  | 10    | (saddrp)←word               |   |    |    |
|        |       | sfrp, #word          | 4   | _  | 10    | sfrp←word                   |   |    |    |
| デー     |       | AX, saddrp           | 2   | 6  | 8     | AX←(saddrp)                 |   |    |    |
| タ転送    |       | saddrp, AX           | 2   | 6  | 8     | (saddrp)←AX                 |   |    |    |
| 送      |       | AX, sfrp             | 2   | _  | 8     | AX←sfrp                     |   |    |    |
|        |       | sfrp, AX             | 2   | _  | 8     | sfrp←AX                     |   |    |    |
|        |       | AX, rp <sup>注3</sup> | 1   | 4  | _     | AX←rp                       |   |    |    |
|        |       | rp, AX <sup>注3</sup> | 1   | 4  | _     | rp←AX                       |   |    |    |
|        |       | AX, !addr16          | 3   | 10 | 12+2n | AX←(addr16)                 |   |    |    |
|        |       | !addr16, AX          | 3   | 10 | 12+2m | (addr16)←AX                 |   |    |    |
|        | XCHW  | AX, rp <sup>注3</sup> | 1   | 4  | _     | AX←→rp                      |   |    |    |
| 8      | ADD   | A, #byte             | 2   | 4  | _     | A, CY←A+byte                | × | ×  | ×  |
| ツ      |       | saddr, #byte         | 3   | 6  | 8     | (saddr), CY←(saddr)+byte    | × | ×  | ×  |
| 8ビット演算 |       | A, r <sup>注 4</sup>  | 2   | 4  | _     | A, CY←A+r                   | × | ×  | ×  |
| 昇      |       | r, A                 | 2   | 4  | _     | r, CY←r+A                   | × | ×  | X  |
|        |       | A, saddr             | 2   | 4  | 5     | A, CY←A+(saddr)             | × | ×  | X  |
|        |       | A, !addr16           | 3   | 8  | 9 + n | A, CY←A+(addr16)            | × | ×  | X  |
|        |       | A, [HL]              | 1   | 4  | 5 + n | A, CY←A+(HL)                | × | ×  | X  |
|        |       | A, [HL+byte]         | 2   | 8  | 9+n   | A, CY←A+(HL+byte)           | X | ×  | X  |
|        |       | A, [HL+B]            | 2   | 8  | 9 + n | A, CY←A+(HL+B)              | × | ×  | X  |
|        |       | A, [HL+C]            | 2   | 8  | 9 + n | A, CY←A+(HL+C)              | × | ×  | X  |
|        | ADDC  | A, #byte             | 2   | 4  | _     | A, CY←A+byte+CY             | X | ×  | X  |
|        |       | saddr, #byte         | 3   | 6  | 8     | (saddr), CY←(saddr)+byte+CY | × | ×  | X  |
|        |       | A, r <sup>注 4</sup>  | 2   | 4  | _     | A, CY←A+r+CY                | × | ×  | X  |
|        |       | r, A                 | 2   | 4  | _     | r, CY←r+A+CY                | × | ×  | X  |
|        |       | A, saddr             | 2   | 4  | 5     | A, CY←A+(saddr)+CY          | × | ×  | X  |
|        |       | A, !addr16           | 3   | 8  | 9 + n | A, CY←A+(addr16)+CY         | × | ×  | X  |
|        |       | A, [HL]              | 1   | 4  | 5 + n | A, CY←A+(HL)+CY             | × | ×  | ×  |
|        |       | A, [HL+byte]         | 2   | 8  | 9 + n | A, CY←A+(HL+byte)+CY        | × | ×  | ×  |
|        |       | A, [HL+B]            | 2   | 8  | 9 + n | A, CY←A+(HL+B)+CY           | × | ×  | ×  |
|        |       | A, [HL+C]            | 2   | 8  | 9 + n | A, CY←A+(HL+C)+CY           | × | ×  | ×  |

- 注1. 内部高速RAM領域をアクセスしたときまたはデータ・アクセスしない命令のとき。
  - 2. 内部高速RAM以外の領域をアクセスしたとき。
  - 3. rp = BC, DE, HLのときの $A_{\circ}$
  - 4. r = Aを除く。
- **備考1.** 命令の1クロックはプロセッサ・クロック・コントロール・レジスタ(PCC)で選択したCPUクロック (fcpu) の1クロック分です。
  - 2. クロック数は内部ROM領域にプログラムがある場合です。
  - 3. nは外部メモリ拡張領域をリードしたときのウエイト数です。
  - 4. mは外部メモリ拡張領域をライトしたときのウエイト数です。

| 命     | ニモニック | オペランド              | バイト | クロ  | ック    | オペレーション                      |   | フラク | グ  |
|-------|-------|--------------------|-----|-----|-------|------------------------------|---|-----|----|
| 命令群   |       |                    |     | 注 1 | 注 2   |                              | Z | AC  | CY |
| 8     | SUB   | A, #byte           | 2   | 4   | _     | A, CY←A-byte                 | × | ×   | ×  |
| ビッ    |       | saddr, #byte       | 3   | 6   | 8     | (saddr), CY←(saddr) —byte    | × | ×   | ×  |
| ビット演算 |       | A, r <sup>注3</sup> | 2   | 4   | _     | A, CY←A−r                    | × | ×   | ×  |
| 算     |       | r, A               | 2   | 4   | _     | r, CY←r—A                    | × | ×   | ×  |
|       | ,     | A, saddr           | 2   | 4   | 5     | A, CY←A−(saddr)              | × | ×   | ×  |
|       |       | A, !addr16         | 3   | 8   | 9 + n | A, CY←A−(addr16)             | × | ×   | ×  |
|       |       | A, [HL]            | 1   | 4   | 5 + n | A, CY←A−(HL)                 | × | ×   | ×  |
|       |       | A, [HL+byte]       | 2   | 8   | 9 + n | A, CY←A−(HL+byte)            | × | ×   | ×  |
|       |       | A, [HL+B]          | 2   | 8   | 9 + n | A, CY←A−(HL+B)               | × | ×   | ×  |
|       |       | A, [HL+C]          | 2   | 8   | 9 + n | A, CY←A−(HL+C)               | × | ×   | ×  |
|       | SUBC  | A, #byte           | 2   | 4   | _     | A, CY←A−byte−CY              | × | ×   | ×  |
|       |       | saddr, #byte       | 3   | 6   | 8     | (saddr), CY←(saddr) -byte-CY | × | ×   | X  |
|       |       | A, r <sup>注3</sup> | 2   | 4   | _     | A, CY←A−r−CY                 | × | ×   | X  |
|       |       | r, A               | 2   | 4   | _     | r, CY←r—A—CY                 | × | ×   | ×  |
|       |       | A, saddr           | 2   | 4   | 5     | A, CY-A-(saddr)-CY           | × | ×   | ×  |
|       |       | A, !addr16         | 3   | 8   | 9 + n | A, CY←A−(addr16)−CY          | × | ×   | ×  |
|       |       | A, [HL]            | 1   | 4   | 5 + n | A, CY←A−(HL)−CY              | × | ×   | ×  |
|       |       | A, [HL+byte]       | 2   | 8   | 9 + n | A, CY←A−(HL+byte)−CY         | × | ×   | ×  |
|       |       | A, [HL+B]          | 2   | 8   | 9 + n | A, CY-A-(HL+B)-CY            | × | ×   | ×  |
|       |       | A, [HL+C]          | 2   | 8   | 9 + n | A, CY-A-(HL+C)-CY            | × | ×   | ×  |
|       | AND   | A, #byte           | 2   | 4   | _     | A←A ∧ byte                   | × |     |    |
|       |       | saddr, #byte       | 3   | 6   | 8     | (saddr) ← (saddr) ∧ byte     | × |     |    |
|       |       | A, r <sup>注3</sup> | 2   | 4   | _     | A←A ∧ r                      | × |     |    |
|       |       | r, A               | 2   | 4   | _     | r←r ∧ A                      | × |     |    |
|       |       | A, saddr           | 2   | 4   | 5     | A←A ∧ (saddr)                | × |     |    |
|       |       | A, !addr16         | 3   | 8   | 9 + n | A←A ∧ (addr16)               | × |     |    |
|       |       | A, [HL]            | 1   | 4   | 5 + n | A←A ∧ (HL)                   | × |     |    |
|       |       | A, [HL+byte]       | 2   | 8   | 9 + n | A←A ∧ (HL+byte)              | × |     |    |
|       |       | A, [HL+B]          | 2   | 8   | 9 + n | A←A ∧ (HL+B)                 | × |     |    |
|       |       | A, [HL+C]          | 2   | 8   | 9 + n | A←A ∧ (HL+C)                 | × |     |    |

- 注1. 内部高速RAM領域をアクセスしたときまたはデータ・アクセスしない命令のとき。
  - 2. 内部高速RAM以外の領域をアクセスしたとき。
  - 3. r = Aを除く。
- **備考1.** 命令の1クロックはプロセッサ・クロック・コントロール・レジスタ(PCC)で選択したCPUクロック (fcpu) の1クロック分です。
  - 2. クロック数は内部ROM領域にプログラムがある場合です。
  - 3. nは外部メモリ拡張領域をリードしたときのウエイト数です。

| 命           | ニモニック | オペランド              | バイト | クロ  | ック    | オペレーション                  | - | フラク | ブ  |
|-------------|-------|--------------------|-----|-----|-------|--------------------------|---|-----|----|
| 命令群         |       |                    |     | 注 1 | 注 2   |                          | Z | AC  | CY |
| 8           | OR    | A, #byte           | 2   | 4   | _     | A←A ∨ byte               | × |     |    |
| 8ビット        |       | saddr, #byte       | 3   | 6   | 8     | (saddr) ← (saddr) ∨ byte | × |     |    |
| ト油          |       | A, r <sup>注3</sup> | 2   | 4   | _     | A←A∨r                    | × |     |    |
| ·<br>演<br>算 |       | r, A               | 2   | 4   | _     | r←r ∨ A                  | × |     |    |
|             |       | A, saddr           | 2   | 4   | 5     | A←A ∨ (saddr)            | × |     |    |
|             |       | A, !addr16         | 3   | 8   | 9 + n | A←A ∨ (addr16)           | × |     |    |
|             |       | A, [HL]            | 1   | 4   | 5 + n | A←A ∨ (HL)               | × |     |    |
|             |       | A, [HL+byte]       | 2   | 8   | 9 + n | A←A ∨ (HL+byte)          | × |     |    |
|             |       | A, [HL+B]          | 2   | 8   | 9 + n | A←A ∨ (HL+B)             | × |     |    |
|             |       | A, [HL+C]          | 2   | 8   | 9 + n | A←A ∨ (HL+C)             | × |     |    |
|             | XOR   | A, #byte           | 2   | 4   | _     | A←A ∀ byte               | × |     |    |
|             |       | saddr, #byte       | 3   | 6   | 8     | (saddr) ← (saddr) ∀ byte | × |     |    |
|             |       | A, r <sup>注3</sup> | 2   | 4   | _     | A←A <del>∀</del> r       | × |     |    |
|             |       | r, A               | 2   | 4   | _     | r←r <del>V</del> A       | × |     |    |
|             |       | A, saddr           | 2   | 4   | 5     | A←A ∀ (saddr)            | × |     |    |
|             |       | A, !addr16         | 3   | 8   | 9 + n | A←A ∀ (addr16)           | × |     |    |
|             |       | A, [HL]            | 1   | 4   | 5 + n | A←A ∀ (HL)               | × |     |    |
|             |       | A, [HL+byte]       | 2   | 8   | 9 + n | A←A ∀ (HL+byte)          | × |     |    |
|             |       | A, [HL+B]          | 2   | 8   | 9 + n | A←A ∀ (HL+B)             | × |     |    |
|             |       | A, [HL+C]          | 2   | 8   | 9 + n | A←A ★ (HL+C)             | × |     |    |
|             | CMP   | A, #byte           | 2   | 4   | _     | A-byte                   | × | ×   | ×  |
|             |       | saddr, #byte       | 3   | 6   | 8     | (saddr) - byte           | × | ×   | ×  |
|             |       | A, r <sup>注3</sup> | 2   | 4   | _     | A—r                      | × | ×   | ×  |
|             |       | r, A               | 2   | 4   | _     | r—A                      | × | ×   | ×  |
|             |       | A, saddr           | 2   | 4   | 5     | A—(saddr)                | × | ×   | ×  |
|             |       | A, !addr16         | 3   | 8   | 9 + n | A—(addr16)               | × | ×   | ×  |
|             |       | A, [HL]            | 1   | 4   | 5 + n | A—(HL)                   | × | ×   | ×  |
|             |       | A, [HL+byte]       | 2   | 8   | 9 + n | A—(HL+byte)              | × | ×   | ×  |
|             |       | A, [HL+B]          | 2   | 8   | 9 + n | A—(HL+B)                 | × | ×   | ×  |
|             |       | A, [HL+C]          | 2   | 8   | 9 + n | A-(HL+C)                 | × | ×   | ×  |
| 16<br>ビ     | ADDW  | AX, #word          | 3   | 6   | _     | AX, CY←AX+word           | × | ×   | ×  |
| ット          | SUBW  | AX, #word          | 3   | 6   | _     | AX, CY←AX—word           | × | ×   | ×  |
| 16ビット演算     | CMPW  | AX, #word          | 3   | 6   | _     | AX—word                  | × | ×   | ×  |
| 乗除算         | MULU  | Х                  | 2   | 16  | _     | AX←A×X                   |   |     |    |
| 际<br>算      | DIVUW | С                  | 2   | 25  | _     | AX(商), C(余り)←AX÷C        |   |     |    |

- 注1. 内部高速RAM領域をアクセスしたときまたはデータ・アクセスしない命令のとき。
  - 2. 内部高速RAM以外の領域をアクセスしたとき。
  - 3. r = Aを除く。
- **備考1.** 命令の1 クロックはプロセッサ・クロック・コントロール・レジスタ(PCC)で選択したCPUクロック (fcpu) の1 クロック分です。
  - 2. クロック数は内部ROM領域にプログラムがある場合です。
  - 3. nは外部メモリ拡張領域をリードしたときのウエイト数です。

| 命       | ニモニック | オペランド         | バイト | クロ | ック     | オペレーション                                                                                                                  |   | フラク | Ï  |
|---------|-------|---------------|-----|----|--------|--------------------------------------------------------------------------------------------------------------------------|---|-----|----|
| 命令群     |       |               |     | 注1 | 注 2    |                                                                                                                          | Z | AC  | CY |
| 増減      | INC   | r             | 1   | 2  | _      | r←r+1                                                                                                                    | × | X   |    |
| 減       |       | saddr         | 2   | 4  | 6      | (saddr) ← (saddr) +1                                                                                                     | × | X   |    |
|         | DEC   | r             | 1   | 2  | _      | r←r—1                                                                                                                    | × | X   |    |
|         |       | saddr         | 2   | 4  | 6      | (saddr) ← (saddr) −1                                                                                                     | × | X   |    |
|         | INCW  | rp            | 1   | 4  | _      | rp←rp+1                                                                                                                  |   |     |    |
|         | DECW  | rp            | 1   | 4  | _      | rp←rp—1                                                                                                                  |   |     |    |
| П-      | ROR   | A, 1          | 1   | 2  | _      | $(CY, A_7$ ← $A_0, A_{m-1}$ ← $A_m$ $) × 1 □$                                                                            |   |     | ×  |
| <br>  デ | ROL   | A, 1          | 1   | 2  | _      | $(CY, A_0$ ← $A_7, A_{m+1}$ ← $A_m$ $) × 1 □$                                                                            |   |     | ×  |
|         | RORC  | A, 1          | 1   | 2  | _      | $(CY \leftarrow A_0, A_7 \leftarrow CY, A_{m-1} \leftarrow A_m) \times 1$ □                                              |   |     | ×  |
|         | ROLC  | A, 1          | 1   | 2  | _      | $(CY \leftarrow A_7, A_0 \leftarrow CY, A_{m+1} \leftarrow A_m) \times 1$ □                                              |   |     | ×  |
|         | ROR4  | [HL]          | 2   | 10 | 12+n+m | A <sub>3-0</sub> ←(HL) <sub>3-0</sub> , (HL) <sub>7-4</sub> ←A <sub>3-0</sub> , (HL) <sub>3-0</sub> ←(HL) <sub>7-4</sub> |   |     |    |
|         | ROL4  | [HL]          | 2   | 10 | 12+n+m | A <sub>3-0</sub> ←(HL) <sub>7-4</sub> , (HL) <sub>3-0</sub> ←A <sub>3-0</sub> , (HL) <sub>7-4</sub> ←(HL) <sub>3-0</sub> |   |     |    |
| всы     | ADJBA |               | 2   | 4  | _      | Decimal Adjust Accumulator after Addition                                                                                | × | X   | ×  |
| 補正      | ADJBS |               | 2   | 4  | _      | Decimal Adjust Accumulator after Subtract                                                                                | × | X   | ×  |
| ビ       | MOV1  | CY, saddr.bit | 3   | 6  | 7      | CY←(saddr.bit)                                                                                                           |   |     | ×  |
| ット操作    |       | CY, sfr.bit   | 3   | _  | 7      | CY←sfr.bit                                                                                                               |   |     | ×  |
| 操作      |       | CY, A.bit     | 2   | 4  | _      | CY←A.bit                                                                                                                 |   |     | ×  |
|         |       | CY, PSW.bit   | 3   | _  | 7      | CY←PSW.bit                                                                                                               |   |     | ×  |
|         |       | CY, [HL].bit  | 2   | 6  | 7 + n  | CY←(HL).bit                                                                                                              |   |     | ×  |
|         |       | saddr.bit, CY | 3   | 6  | 8      | (saddr.bit) ←CY                                                                                                          |   |     |    |
|         |       | sfr.bit, CY   | 3   | _  | 8      | sfr.bit←CY                                                                                                               |   |     |    |
|         |       | A.bit, CY     | 2   | 4  | _      | A.bit←CY                                                                                                                 |   |     |    |
|         |       | PSW.bit, CY   | 3   | _  | 8      | PSW.bit←CY                                                                                                               | × | X   |    |
|         |       | [HL].bit, CY  | 2   | 6  | 8+n+m  | (HL).bit←CY                                                                                                              |   |     |    |
|         | AND1  | CY, saddr.bit | 3   | 6  | 7      | CY←CY ∧ (saddr.bit)                                                                                                      |   |     | ×  |
|         |       | CY, sfr.bit   | 3   | _  | 7      | CY←CY ∧ sfr.bit                                                                                                          |   |     | ×  |
|         |       | CY, A.bit     | 2   | 4  | _      | CY←CY ∧ A.bit                                                                                                            |   |     | ×  |
|         |       | CY, PSW.bit   | 3   | _  | 7      | CY←CY ∧ PSW.bit                                                                                                          |   |     | ×  |
|         |       | CY, [HL].bit  | 2   | 6  | 7 + n  | CY←CY ∧ (HL).bit                                                                                                         |   |     | ×  |
|         | OR1   | CY, saddr.bit | 3   | 6  | 7      | CY←CY ∨ (saddr.bit)                                                                                                      |   |     | ×  |
|         |       | CY, sfr.bit   | 3   | _  | 7      | CY←CY ∨ sfr.bit                                                                                                          |   |     | ×  |
|         |       | CY, A.bit     | 2   | 4  | _      | CY←CY ∨ A.bit                                                                                                            |   |     | ×  |
|         |       | CY, PSW.bit   | 3   | _  | 7      | CY←CY ∨ PSW.bit                                                                                                          |   |     | ×  |
|         |       | CY, [HL].bit  | 2   | 6  | 7 + n  | CY←CY ∨ (HL).bit                                                                                                         |   |     | ×  |

- 注1. 内部高速RAM領域をアクセスしたときまたはデータ・アクセスしない命令のとき。
  - 2. 内部高速RAM以外の領域をアクセスしたとき。
- **備考1.** 命令の1クロックはプロセッサ・クロック・コントロール・レジスタ(PCC)で選択したCPUクロック (fcpu) の1クロック分です。
  - 2. クロック数は内部ROM領域にプログラムがある場合です。
  - 3. nは外部メモリ拡張領域をリードしたときのウエイト数です。
  - 4. mは外部メモリ拡張領域をライトしたときのウエイト数です。

| 命        | ニモニック | オペランド         | バイト | クロ | ック    | オペレーション                                                              |   | フラク | <br>ブ |
|----------|-------|---------------|-----|----|-------|----------------------------------------------------------------------|---|-----|-------|
| 命令群      |       |               |     | 注1 | 注 2   |                                                                      | Z | AC  | CY    |
| ビ        | XOR1  | CY, saddr.bit | 3   | 6  | 7     | CY←CY ∀ (saddr.bit)                                                  |   |     | ×     |
|          |       | CY, sfr.bit   | 3   | _  | 7     | CY←CY ∀ sfr.bit                                                      |   |     | ×     |
| ット<br>操作 |       | CY, A.bit     | 2   | 4  | _     | CY←CY ∀ A.bit                                                        |   |     | ×     |
| '        |       | CY, PSW.bit   | 3   | _  | 7     | CY←CY ∀ PSW.bit                                                      |   |     | ×     |
|          |       | CY, [HL].bit  | 2   | 6  | 7 + n | CY←CY ∀ (HL).bit                                                     |   |     | ×     |
|          | SET1  | saddr.bit     | 2   | 4  | 6     | (saddr.bit) ← 1                                                      |   |     |       |
|          |       | sfr.bit       | 3   | _  | 8     | sfr.bit← 1                                                           |   |     |       |
|          |       | A.bit         | 2   | 4  | _     | A.bit← 1                                                             |   |     |       |
|          |       | PSW.bit       | 2   | _  | 6     | PSW.bit← 1                                                           | × | ×   | ×     |
|          |       | [HL].bit      | 2   | 6  | 8+n+m | (HL).bit← 1                                                          |   |     |       |
|          | CLR1  | saddr.bit     | 2   | 4  | 6     | (saddr.bit) ← 0                                                      |   |     |       |
|          |       | sfr.bit       | 3   | _  | 8     | sfr.bit← 0                                                           |   |     |       |
|          |       | A.bit         | 2   | 4  | _     | A.bit← 0                                                             |   |     |       |
|          |       | PSW.bit       | 2   | _  | 6     | PSW.bit← 0                                                           | × | ×   | ×     |
|          |       | [HL].bit      | 2   | 6  | 8+n+m | (HL).bit← 0                                                          |   |     |       |
|          | SET1  | CY            | 1   | 2  | _     | CY← 1                                                                |   |     | 1     |
|          | CLR1  | CY            | 1   | 2  | _     | CY← 0                                                                |   |     | 0     |
|          | NOT1  | CY            | 1   | 2  | _     | CY←CY                                                                |   |     | ×     |
|          | CALL  | !addr16       | 3   | 7  | _     | (SP-1)←(PC+3) <sub>H</sub> , (SP-2)←(PC+3) <sub>L</sub> ,            |   |     |       |
| ル        |       |               |     |    |       | PC←addr16, SP←SP-2                                                   |   |     |       |
| ļ        | CALLF | !addr11       | 2   | 5  | _     | $(SP-1) \leftarrow (PC+2)_H, (SP-2) \leftarrow (PC+2)_L,$            |   |     |       |
| ター       |       |               |     |    |       | PC <sub>15-11</sub> ←00001, PC <sub>10-0</sub> ←addr11, SP←SP−2      |   |     |       |
| レ        | CALLT | [addr5]       | 1   | 6  | _     | $(SP-1) \leftarrow (PC+1)_H, (SP-2) \leftarrow (PC+1)_L,$            |   |     |       |
|          |       |               |     |    |       | PC <sub>H</sub> ←(00000000, addr5+1),                                |   |     |       |
|          |       |               |     |    |       | PC <sub>L</sub> ←(00000000, addr5), SP←SP−2                          |   |     |       |
|          | BRK   |               | 1   | 6  | _     | (SP-1)←PSW, (SP-2)←(PC+1) <sub>H</sub> ,                             |   |     |       |
|          |       |               |     |    |       | $(SP-3)\leftarrow (PC+1)_L, PC_H\leftarrow (003FH),$                 |   |     |       |
|          |       |               |     |    |       | PC <sub>L</sub> ←(003EH), SP←SP−3, IE←0                              |   |     |       |
|          | RET   |               | 1   | 6  | _     | $PCH\leftarrow (SP+1), PCL\leftarrow (SP), SP\leftarrow SP+2$        |   |     |       |
|          | RETI  |               | 1   | 6  | _     | $PCH \leftarrow (SP+1), PCL \leftarrow (SP), PSW \leftarrow (SP+2),$ | R | R   | R     |
|          |       |               |     |    |       | SP←SP+3                                                              |   |     |       |
|          | RETB  |               | 1   | 6  | _     | $PCH\leftarrow (SP+1), PCL\leftarrow (SP), PSW\leftarrow (SP+2),$    | R | R   | R     |
|          |       |               |     |    |       | SP←SP+3                                                              |   |     |       |
|          | i .   |               |     |    |       |                                                                      | 1 |     |       |

- 注1.内部高速RAM領域をアクセスしたときまたはデータ・アクセスしない命令のとき。
  - 2. 内部高速RAM以外の領域をアクセスしたとき。
- **備考1.** 命令の1クロックはプロセッサ・クロック・コントロール・レジスタ(PCC)で選択したCPUクロック (fcpu) の1クロック分です。
  - 2. クロック数は内部ROM領域にプログラムがある場合です。
  - 3. n は外部メモリ拡張領域をリードしたときのウエイト数です。
  - 4. mは外部メモリ拡張領域をライトしたときのウエイト数です。

320

| 命       | ニモニック | オペランド               | バイト | クロ | ック     | オペレーション                                                 |   | フラ | グ  |
|---------|-------|---------------------|-----|----|--------|---------------------------------------------------------|---|----|----|
| 命令群     |       |                     |     | 注1 | 注 2    |                                                         | Z | AC | CY |
| スク      | PUSH  | PSW                 | 1   | 2  | _      | (SP-1)←PSW, SP←SP-1                                     |   |    |    |
| ツ       |       | rp                  | 1   | 4  | _      | (SP-1)←rpH, (SP-2)←rpL, SP←SP-2                         |   |    |    |
| タック操作   | POP   | PSW                 | 1   | 2  | _      | PSW←(SP), SP←SP+1                                       | R | R  | R  |
| 17F<br> |       | rp                  | 1   | 4  | _      | rp <sub>H</sub> ←(SP+1), rp <sub>L</sub> ←(SP), SP←SP+2 |   |    |    |
|         | MOVW  | SP, #word           | 4   | _  | 10     | SP←word                                                 |   |    |    |
|         |       | SP, AX              | 2   | _  | 8      | SP←AX                                                   |   |    |    |
|         |       | AX, SP              | 2   | _  | 8      | AX←SP                                                   |   |    |    |
| 無       | BR    | !addr16             | 3   | 6  | _      | PC←addr16                                               |   |    |    |
| 無条件分岐   |       | \$addr16            | 2   | 6  | _      | PC←PC+2+jdisp8                                          |   |    |    |
| 対       |       | AX                  | 2   | 8  | _      | PC <sub>H</sub> ←A, PC <sub>L</sub> ←X                  |   |    |    |
| 条件      | вс    | \$addr16            | 2   | 6  | _      | PC←PC+2+jdisp8 if CY = 1                                |   |    |    |
| 行       | BNC   | \$addr16            | 2   | 6  | _      | PC←PC+2+jdisp8 if CY = 0                                |   |    |    |
| 条件付き分岐  | BZ    | \$addr16            | 2   | 6  | _      | PC←PC+2+jdisp8 if Z = 1                                 |   |    |    |
| 岐       | BNZ   | \$addr16            | 2   | 6  | _      | $PC\leftarrow PC+2+jdisp8 \text{ if } Z=0$              |   |    |    |
|         | ВТ    | saddr.bit, \$addr16 | 3   | 8  | 9      | PC←PC+3+jdisp8 if (saddr.bit) = 1                       |   |    |    |
|         |       | sfr.bit, \$addr16   | 4   | _  | 11     | PC←PC+4+jdisp8 if sfr.bit = 1                           |   |    |    |
|         |       | A.bit, \$addr16     | 3   | 8  | _      | PC←PC+3+jdisp8 if A.bit = 1                             |   |    |    |
|         |       | PSW.bit, \$addr16   | 3   | _  | 9      | PC←PC+3+jdisp8 if PSW.bit = 1                           |   |    |    |
|         |       | [HL].bit, \$addr16  | 3   | 10 | 11+ n  | PC←PC+3+jdisp8 if (HL).bit = 1                          |   |    |    |
|         | BF    | saddr.bit, \$addr16 | 4   | 10 | 11     | PC←PC+4+jdisp8 if (saddr.bit) = 0                       |   |    |    |
|         |       | sfr.bit, \$addr16   | 4   | _  | 11     | PC←PC+4+jdisp8 if sfr.bit = 0                           |   |    |    |
|         |       | A.bit, \$addr16     | 3   | 8  | _      | PC←PC+3+jdisp8 if A.bit = 0                             |   |    |    |
|         |       | PSW.bit, \$addr16   | 4   | _  | 11     | PC←PC+4+jdisp8 if PSW.bit = 0                           |   |    |    |
|         |       | [HL].bit, \$addr16  | 3   | 10 | 11+ n  | PC←PC+3+jdisp8 if (HL).bit = 0                          |   |    |    |
|         | BTCLR | saddr.bit, \$addr16 | 4   | 10 | 12     | PC←PC+4+jdisp8 if (saddr.bit) = 1                       |   |    |    |
|         |       |                     |     |    |        | then reset (saddr.bit)                                  |   |    |    |
|         |       | sfr.bit, \$addr16   | 4   | _  | 12     | PC←PC+4+jdisp8 if sfr.bit = 1                           |   |    |    |
|         |       |                     |     |    |        | then reset sfr.bit                                      |   |    |    |
|         |       | A.bit, \$addr16     | 3   | 8  | _      | PC←PC+3+jdisp8 if A.bit = 1                             |   |    |    |
|         |       |                     |     |    |        | then reset A.bit                                        |   |    |    |
|         |       | PSW.bit, \$addr16   | 4   | _  | 12     | PC←PC+4+jdisp8 if PSW.bit = 1                           | × | ×  | ×  |
|         |       |                     |     |    |        | then reset PSW.bit                                      |   |    |    |
|         |       | [HL].bit, \$addr16  | 3   | 10 | 12+n+m | PC←PC+3+jdisp8 if (HL).bit = 1                          |   |    |    |
| L       |       |                     |     |    |        | then reset (HL).bit                                     |   |    |    |

- 注1. 内部高速RAM領域をアクセスしたときまたはデータ・アクセスしない命令のとき。
  - 2. 内部高速RAM以外の領域をアクセスしたとき。
- **備考1.** 命令の1クロックはプロセッサ・クロック・コントロール・レジスタ(PCC)で選択したCPUクロック (fcpu) の1クロック分です。
  - 2. クロック数は内部ROM領域にプログラムがある場合です。
  - 3. n は外部メモリ拡張領域をリードしたときのウエイト数です。
  - 4. mは外部メモリ拡張領域をライトしたときのウエイト数です。

| 命令群    | ニモニック | オペランド           | バイト | クロ | ック  | オペレーション                       | フラグ     |
|--------|-------|-----------------|-----|----|-----|-------------------------------|---------|
| 群      |       |                 |     | 注1 | 注 2 |                               | Z AC CY |
| 条      | DBNZ  | B, \$addr16     | 2   | 6  | _   | B←B-1, then                   |         |
| 条件付き分岐 |       |                 |     |    |     | PC←PC+2+jdisp8 if B ≠ 0       |         |
| き分     |       | C, \$addr16     | 2   | 6  | _   | C←C-1, then                   |         |
| 6      |       |                 |     |    |     | PC←PC+2+jdisp8 if C ≠ 0       |         |
|        |       | saddr, \$addr16 | 3   | 8  | 10  | (saddr) ← (saddr) —1, then    |         |
|        |       |                 |     |    |     | PC←PC+3+jdisp8 if (saddr) ≠ 0 |         |
| C<br>P | SEL   | RBn             | 2   | 4  | _   | RBS1, 0←n                     |         |
| lυ     | NOP   |                 | 1   | 2  | _   | No Operation                  |         |
| 制御     | El    |                 | 2   | _  | 6   | IE←1 (Enable Interrupt)       |         |
|        | DI    |                 | 2   | _  | 6   | IE←0 (Disable Interrupt)      |         |
|        | HALT  |                 | 2   | 6  | _   | Set HALT Mode                 |         |
|        | STOP  |                 | 2   | 6  | _   | Set STOP Mode                 |         |

- 注1. 内部高速RAM領域をアクセスしたときまたはデータ・アクセスしない命令のとき。
  - 2. 内部高速RAM以外の領域をアクセスしたとき。
- **備考1.** 命令の1 クロックはプロセッサ・クロック・コントロール・レジスタ(PCC)で選択したCPUクロック (fcpu) の1 クロック分です。
  - 2. クロック数は内部ROM領域にプログラムがある場合です。

# 19.3 アドレシング別命令一覧

# (1) 8ビット命令

MOV, XCH, ADD, ADDC, SUB, SUBC, AND, OR, XOR, CMP, MULU, DIVUW, INC, DEC, ROR, ROL, RORC, ROLC, ROR4, ROL4, PUSH, POP, DBNZ

| 第2オペランド         | #byte | Α    | r <sup>注</sup> | sfr | saddr | !addr16 | PSW | [DE] | [HL] | [HL+byte] | \$addr16 | 1    | なし          |
|-----------------|-------|------|----------------|-----|-------|---------|-----|------|------|-----------|----------|------|-------------|
|                 |       |      |                |     |       |         |     |      |      | [HL+B]    |          |      |             |
| 第1オペランド         |       |      |                |     |       |         |     |      |      | [HL+C]    |          |      |             |
| А               | ADD   |      | MOV            | MOV | MOV   | MOV     | MOV | MOV  | MOV  | MOV       |          | ROR  |             |
|                 | ADDC  |      | XCH            | XCH | XCH   | XCH     |     | XCH  | XCH  | XCH       |          | ROL  |             |
|                 | SUB   |      | ADD            |     | ADD   | ADD     |     |      | ADD  | ADD       |          | RORC |             |
|                 | SUBC  |      | ADDC           |     | ADDC  | ADDC    |     |      | ADDC | ADDC      |          | ROLC |             |
|                 | AND   |      | SUB            |     | SUB   | SUB     |     |      | SUB  | SUB       |          |      |             |
|                 | OR    |      | SUBC           |     | SUBC  | SUBC    |     |      | SUBC | SUBC      |          |      |             |
|                 | XOR   |      | AND            |     | AND   | AND     |     |      | AND  | AND       |          |      |             |
|                 | CMP   |      | OR             |     | OR    | OR      |     |      | OR   | OR        |          |      |             |
|                 |       |      | XOR            |     | XOR   | XOR     |     |      | XOR  | XOR       |          |      |             |
|                 |       |      | CMP            |     | CMP   | CMP     |     |      | CMP  | CMP       |          |      |             |
| r               | MOV   | MOV  |                |     |       |         |     |      |      |           |          |      | INC         |
|                 |       | ADD  |                |     |       |         |     |      |      |           |          |      | DEC         |
|                 |       | ADDC |                |     |       |         |     |      |      |           |          |      |             |
|                 |       | SUB  |                |     |       |         |     |      |      |           |          |      |             |
|                 |       | SUBC |                |     |       |         |     |      |      |           |          |      |             |
|                 |       | AND  |                |     |       |         |     |      |      |           |          |      |             |
|                 |       | OR   |                |     |       |         |     |      |      |           |          |      |             |
|                 |       | XOR  |                |     |       |         |     |      |      |           |          |      |             |
|                 |       | CMP  |                |     |       |         |     |      |      |           |          |      |             |
| B, C            |       |      |                |     |       |         |     |      |      |           | DBNZ     |      |             |
| sfr             | MOV   | MOV  |                |     |       |         |     |      |      |           |          |      |             |
| saddr           | MOV   | MOV  |                |     |       |         |     |      |      |           | DBNZ     |      | INC         |
|                 | ADD   |      |                |     |       |         |     |      |      |           |          |      | DEC         |
|                 | ADDC  |      |                |     |       |         |     |      |      |           |          |      |             |
|                 | SUB   |      |                |     |       |         |     |      |      |           |          |      |             |
|                 | SUBC  |      |                |     |       |         |     |      |      |           |          |      |             |
|                 | AND   |      |                |     |       |         |     |      |      |           |          |      |             |
|                 | OR    |      |                |     |       |         |     |      |      |           |          |      |             |
|                 | XOR   |      |                |     |       |         |     |      |      |           |          |      |             |
|                 | CMP   |      |                |     |       |         |     |      |      |           |          |      |             |
| !addr16         |       | MOV  |                |     |       |         |     |      |      |           |          |      |             |
| PSW             | MOV   | MOV  |                |     |       |         |     |      |      |           |          |      | PUSH<br>POP |
| [DE]            |       | MOV  |                |     |       |         |     |      |      |           |          |      |             |
| [HL]            |       | MOV  |                |     |       |         |     |      |      |           |          |      | ROR4        |
| [HL+byte]       |       | MOV  |                |     |       |         |     |      |      |           |          |      | ROL4        |
| [HL+B]          |       |      |                |     |       |         |     |      |      |           |          |      |             |
| [HL+C]          |       |      |                |     |       |         |     |      |      |           |          |      |             |
| X               |       |      |                |     |       |         |     |      |      |           |          |      | MULU        |
| С               |       |      |                |     |       |         |     |      |      |           |          |      | DIVUW       |
| <br>注 r = Aは除く。 | 1     | 1    | 1              |     | 1     | 1       |     | 1    |      | 1         |          |      |             |

注 r = Aは除く。

# (2) 16ビット命令

MOVW, XCHW, ADDW, SUBW, CMPW, PUSH, POP, INCW, DECW

| 第2オペランド | #word | AX                | rp <sup>注</sup> | sfrp | saddrp | !addr16 | SP   | なし   |
|---------|-------|-------------------|-----------------|------|--------|---------|------|------|
| 第1オペランド |       |                   |                 |      |        |         |      |      |
| AX      | ADDW  |                   | MOVW            | MOVW | MOVW   | MOVW    | MOVW |      |
|         | SUBW  |                   | XCHW            |      |        |         |      |      |
|         | CMPW  |                   |                 |      |        |         |      |      |
| rp      | MOVW  | MOVW <sup>注</sup> |                 |      |        |         |      | INCW |
|         |       |                   |                 |      |        |         |      | DECW |
|         |       |                   |                 |      |        |         |      | PUSH |
|         |       |                   |                 |      |        |         |      | POP  |
| sfrp    | MOVW  | MOVW              |                 |      |        |         |      |      |
| saddrp  | MOVW  | MOVW              |                 |      |        |         |      |      |
| !addr16 |       | MOVW              |                 |      |        |         |      |      |
| SP      | MOVW  | MOVW              |                 |      |        |         |      |      |

注 rp = BC, DE, HLのときのみ。

# (3)ビット操作命令

MOV1, AND1, OR1, XOR1, SET1, CLR1, NOT1, BT, BF, BTCLR

| 第2オペランド   | A.bit | sfr.bit | saddr.bit | PSW.bit | [HL].bit | CY   | \$addr16 | なし   |
|-----------|-------|---------|-----------|---------|----------|------|----------|------|
| 第1オペランド   |       |         |           |         |          |      |          |      |
| A.bit     |       |         |           |         |          | MOV1 | ВТ       | SET1 |
|           |       |         |           |         |          |      | BF       | CLR1 |
|           |       |         |           |         |          |      | BTCLR    |      |
| sfr.bit   |       |         |           |         |          | MOV1 | ВТ       | SET1 |
|           |       |         |           |         |          |      | BF       | CLR1 |
|           |       |         |           |         |          |      | BTCLR    |      |
| saddr.bit |       |         |           |         |          | MOV1 | ВТ       | SET1 |
|           |       |         |           |         |          |      | BF       | CLR1 |
|           |       |         |           |         |          |      | BTCLR    |      |
| PSW.bit   |       |         |           |         |          | MOV1 | ВТ       | SET1 |
|           |       |         |           |         |          |      | BF       | CLR1 |
|           |       |         |           |         |          |      | BTCLR    |      |
| [HL].bit  |       |         |           |         |          | MOV1 | ВТ       | SET1 |
|           |       |         |           |         |          |      | BF       | CLR1 |
|           |       |         |           |         |          |      | BTCLR    |      |
| CY        | MOV1  | MOV1    | MOV1      | MOV1    | MOV1     |      |          | SET1 |
|           | AND1  | AND1    | AND1      | AND1    | AND1     |      |          | CLR1 |
|           | OR1   | OR1     | OR1       | OR1     | OR1      |      |          | NOT1 |
|           | XOR1  | XOR1    | XOR1      | XOR1    | XOR1     |      |          |      |

# (4) コール命令/分岐命令

CALL, CALLF, CALLT, BR, BC, BNC, BZ, BNZ, BT, BF, BTCLR, DBNZ

|       | 第2オペランド | AX | !addr16 | !addr11 | [addr5] | \$addr16 |
|-------|---------|----|---------|---------|---------|----------|
| 第1オペラ | ランド     |    |         |         |         |          |
| 基本命令  |         | BR | CALL    | CALLF   | CALLT   | BR       |
|       |         |    | BR      |         |         | ВС       |
|       |         |    |         |         |         | BNC      |
|       |         |    |         |         |         | BZ       |
|       |         |    |         |         |         | BNZ      |
| 複合命令  |         |    |         |         |         | ВТ       |
|       |         |    |         |         |         | BF       |
|       |         |    |         |         |         | BTCLR    |
|       |         |    |         |         |         | DBNZ     |

# (5) その他の命令

ADJBA, ADJBS, BRK, RET, RETI, RETB, SEL, NOP, EI, DI, HALT, STOP

# 第20章 電気的特性

# 絶対最大定格(TA = 25℃)

| 項目       | 略号               | 条                      | 件                       | 定                    | 格                       | 単位         |
|----------|------------------|------------------------|-------------------------|----------------------|-------------------------|------------|
| 電源電圧     | V <sub>DD</sub>  |                        |                         | -0.3~                | +6.5                    | V          |
|          | AVDD             |                        |                         | -0.3∼V <sub>DD</sub> | ·十0.3 <sup>注 1</sup>    | V          |
|          | AVREF            |                        |                         | -0.3∼V <sub>DD</sub> | ·十0.3 <sup>注 1</sup>    | V          |
|          | AVss             |                        |                         | -0.3~                | +0.3                    | V          |
|          | V <sub>PP</sub>  | μPD78F0034BSのみ         | 注 2                     | -0.3~                | +10.5                   | V          |
| 入力電圧     | Vıı              | P00-P03, P10-P13, P20- | -P25, P34-P36,          | -0.3∼V <sub>DD</sub> | +0.3 <sup>注 1</sup>     | V          |
|          |                  | P40-P47, P50-P57, P70  | -P75, X1, X2, XT1, XT2, |                      |                         |            |
|          |                  | RESET                  |                         |                      |                         |            |
| 出力電圧     | Vo               |                        |                         | -0.3~V <sub>DD</sub> | +0.3 <sup>注 1</sup>     | V          |
| アナログ入力電圧 | Van              | P10-P13                | アナログ入力端子                | AVss-0.3~A           | Vref十0.3 <sup>注 1</sup> | V          |
|          |                  |                        |                         | かつー0.3~\             | /pp十0.3 <sup>注 1</sup>  |            |
| ハイ・レベル   | Іон              | 1 端子                   | 端子                      |                      | 0                       | mA         |
| 出力電流     |                  | P00-P03, P40-P47, P50- | -P57, P70-P75 合計        | -1                   | 5                       | mA         |
|          |                  | P20-P25, P34-P36 合語    | <del>'</del> †          | -1                   | 5                       | mA         |
| ロウ・レベル   | loL              | P00-P03, P20-P25, P34- | P36, P40-P47,           | 20                   | )                       | mA         |
| 出力電流     |                  | P70-P75 1 端子           |                         |                      |                         |            |
|          |                  | P50-P57 1 端子           |                         | 30                   | )                       | mA         |
|          |                  | P00-P03, P40-P47, P70- | -P75 合計                 | 50                   | )                       | mA         |
|          |                  | P20-P25 合計             |                         | 20                   | )                       | mA         |
|          |                  | P34-P36 合計             |                         | 60                   | )                       | mA         |
|          |                  | P50-P57 合計             |                         | 10                   | 0                       | mA         |
| 動作周囲温度   | Та               | 通常動作時                  | 1. 电常動作時                |                      | · <del>+</del> 85       | c          |
|          |                  | フラッシュ・メモリ・プログラミング時     |                         | +10~                 | +80                     | °C         |
| 保存温度     | T <sub>stg</sub> | マスクROM製品               |                         | <b>−65</b> ~         | +150                    | °C         |
|          |                  | μPD78F0034BS           |                         | -40~·                | +125                    | $^{\circ}$ |

注1. 6.5 V以下であること。

(注2の説明は次頁に示します)

注意 各項目のうち1項目でも、また一瞬でも絶対最大定格を越えると、製品の品質を損なう恐れがあります。つまり絶対最大定格とは、製品に物理的な損傷を与えかねない定格値です。必ずこの定格値を越えない状態で、製品をご使用ください。

**備考** 特に指定のないかぎり、兼用端子の特性はポート端子の特性と同じです。

注2. フラッシュ・メモリ書き込み時、Vppの電圧印加タイミングについては、必ず次の条件を満たしてください。

・電源電圧立ち上がり時

VDDが動作電圧範囲の下限電圧(1.8 V)に達してから10  $\mu$  S以上経過後、VPPがVDDを越えること(下図のa)。

・電源電圧立ち下がり時

VPPがVDDの動作電圧範囲の下限電圧(1.8 V)を下回ってから 10  $\mu$  S以上経過後、VDDを立ち下げること(下図のb)。



容量 (Ta = 25 ℃, VDD = Vss = 0 V)

| 項目    | 略号  | 条                    | 件                          | MIN. | TYP. | MAX. | 単位 |
|-------|-----|----------------------|----------------------------|------|------|------|----|
| 入力容量  | CIN | f = 1 MHz 被測定端子以外は 0 | V                          |      |      | 15   | рF |
| 入出力容量 | Сю  | f = 1 MHz            | P00-P03, P20-P25, P34-P36, |      |      | 15   | pF |
|       |     | 被測定端子以外は0V           | P40-P47, P50-P57,P70-P75   |      |      |      |    |

**備考** 特に指定のないかぎり、兼用端子の特性はポート端子の特性と同じです。

メイン・システム・クロック発振回路特性(T<sub>A</sub> = −40~+85 °C, V<sub>DD</sub> = 1.8~5.5 V)

| 発振子          | 推奨回路               | 項目                        | 条件                           | MIN. | TYP. | MAX. | 単位  |
|--------------|--------------------|---------------------------|------------------------------|------|------|------|-----|
| セラミック        | I (VPP)I           | 発振周波数(fx) <sup>注1</sup>   | 4.5 V≦VDD≦5.5 V              | 1.0  |      | 12.0 | MHz |
| 発振子          | X1 X2 IC           |                           | 3.0 V≦VDD<4.5 V              | 1.0  |      | 8.38 |     |
|              | R1                 |                           | 1.8 V≦V <sub>DD</sub> <3.0 V | 1.0  |      | 5.0  |     |
|              | <b>→ I</b>         | 発振安定時間 <sup>注 2</sup>     | VDDが発振電圧範囲のMIN.              |      |      | 4    | ms  |
|              |                    |                           | に達したあと                       |      |      |      |     |
| J. B. 15.1.7 | <i>m</i>           |                           | 451/21/2551                  | 1.0  |      | 40.0 |     |
| 水晶振動子        | (V <sub>PP</sub> ) | 発振周波数(fx) <sup>注 1</sup>  | 4.5 V≦VDD≦5.5 V              | 1.0  |      | 12.0 | MHz |
|              | X1 X2 IC           |                           | 3.0 V≦V <sub>DD</sub> <4.5 V | 1.0  |      | 8.38 |     |
|              |                    |                           | 1.8 V≦V <sub>DD</sub> <3.0 V | 1.0  |      | 5.0  |     |
|              | +         +        | 発振安定時間 <sup>注2</sup>      | 4.0 V≦V <sub>DD</sub> ≦5.5 V |      |      | 10   | ms  |
|              | <u> </u>           |                           | 1.8 V≦V <sub>DD</sub> <4.0 V |      |      | 30   |     |
| 外部クロッ        |                    | X1入力周波数(fx) <sup>注1</sup> | 4.5 V≦VDD≦5.5 V              | 1.0  |      | 12.0 | MHz |
| ク            | X1 X2              |                           | 3.0 V≦V <sub>DD</sub> <4.5 V | 1.0  |      | 8.38 |     |
|              | XI X               |                           | 1.8 V≦V <sub>DD</sub> <3.0 V | 1.0  |      | 5.0  |     |
|              |                    | X1入力ハイ, ロウ・レ              | 4.5 V≦VDD≦5.5 V              | 38   |      | 500  | ns  |
|              | Å                  | ベル幅(txH, txL)             | 3.0 V≦V <sub>DD</sub> <4.5 V | 50   |      | 500  |     |
|              | I                  |                           | 1.8 V≦V <sub>DD</sub> <3.0 V | 85   |      | 500  |     |

- 注1. 発振回路の特性だけを示すものです。命令実行時間は、AC特性を参照してください。
  - 2. リセットまたはSTOPモード解除後、発振が安定するのに必要な時間です。
- 注意 1. メイン・システム・クロック発振回路を使用する場合は、配線容量などの影響を避けるために、図中の破線 の部分を次のように配線してください。
  - ●配線は極力短くする。
  - ●他の信号線と交差させない。
  - ●変化する大電流が流れる線に接近させない。
  - ●発振回路のコンデンサの接地点は、常にVss1と同電位になるようにする。
  - ●大電流が流れるグランド・パターンに接地しない。
  - ●発振回路から信号を取り出さない。
  - 2. メイン・システム・クロックを停止させてサブシステム・クロックで動作させているときに、再度メイン・システム・クロックに切り替えるには、プログラムで発振安定時間を確保したあとに切り替えてください。

備考 図中の( )内は μ PD78F0034BSの場合

サブシステム・クロック発振回路特性  $(T_A = -40 \sim +85 \, ^{\circ})$ ,  $V_{DD} = 1.8 \sim 5.5 \, V$ 

| 発振子    | 推奨回路                                  | 項                | 目                      | 条                        | 件     | MIN. | TYP.   | MAX. | 単位  |
|--------|---------------------------------------|------------------|------------------------|--------------------------|-------|------|--------|------|-----|
| 水晶振動子  | XT2 XT1 IC                            | 発振周波数            | (f <sub>XT</sub> ) 注 1 |                          |       | 32   | 32.768 | 35   | kHz |
|        | +C4 +C3                               | 発振安定時間           | <b>間注2</b>             | 4.0 V≦V <sub>DD</sub> ≦5 | 5.5 V |      | 1.2    | 2    | s   |
|        | , , , , , , , , , , , , , , , , , , , |                  |                        | 1.8 V≦V <sub>DD</sub> <4 | I.0 V |      |        | 10   |     |
| 外部クロック | XT2 XT1                               | XT1入力周波          | 数(fxt) <sup>注1</sup>   |                          |       | 32   |        | 38.5 | kHz |
|        | \hf\(\frac{\dagger}{\dagger}\)        | XT1入力ハ<br>レベル幅(t |                        |                          |       | 12   |        | 15   | μS  |

- 注1. 発振回路の特性だけを示すものです。命令実行時間は、AC特性を参照してください。
  - 2. VDDが発振電圧範囲のMIN.に達したあと、発振が安定するのに必要な時間です。
- 注意 1. サブシステム・クロック発振回路を使用する場合は、配線容量などの影響を避けるために、図中の破線の部分を次のように配線してください。
  - ●配線は極力短くする。
  - ●他の信号線と交差させない。
  - ●変化する大電流が流れる線に接近させない。
  - ●発振回路のコンデンサの接地点は、常にVss1と同電位になるようにする。
  - ●大電流が流れるグランド・パターンに接地しない。
  - ●発振回路から信号を取り出さない。
  - 2. サブシステム・クロック発振回路は、低消費電流にするために増幅度の低い回路になっており、ノイズによる誤動作がメイン・システム・クロックよりも起こりやすくなっています。したがって、サブシステム・クロックを使用する場合は、配線方法について特にご注意ください。
- **備考1.** 図中の( )内は μ PD78F0034BSの場合
  - 2. サブシステム・クロックの発振子の選択および発振回路定数についてはお客様において発振評価していただくか、発振子メーカに評価を依頼してください。

# 推奨発振回路定数

(a)  $\mu$  PD780021AS, 780022AS, 780023AS, 780024AS, 780031AS, 780032AS, 780033AS, 780034AS

メイン・システム・クロック:セラミック発振子(T<sub>A</sub> = −40~+85 °C)

| メーカ   | 品 名          | 周波数   |         | 推奨回路定数  |         | 発振電      | 圧範囲      |
|-------|--------------|-------|---------|---------|---------|----------|----------|
|       |              | (MHz) | C1 (pF) | C2 (pF) | R1 (kΩ) | MIN. (V) | MAX. (V) |
| 村田製作所 | CSBFB1M00J58 | 1.00  | 100     | 100     | 2.2     | 1.8      | 5.5      |
|       | CSBLA1M00J58 | 1.00  | 100     | 100     | 2.2     | 1.8      | 5.5      |
|       | CSTCC2M00G56 | 2.00  | 内蔵      | 内蔵      | 0       | 1.8      | 5.5      |
|       | CSTLS2M00G56 | 2.00  | 内蔵      | 内蔵      | 0       | 1.8      | 5.5      |
|       | CSTCC3M58G53 | 3.58  | 内蔵      | 内蔵      | 0       | 1.8      | 5.5      |
|       | CSTLS3M58G53 | 3.58  | 内蔵      | 内蔵      | 0       | 1.8      | 5.5      |
|       | CSTCR4M00G53 | 4.00  | 内蔵      | 内蔵      | 0       | 1.8      | 5.5      |
|       | CSTLS4M00G53 | 4.00  | 内蔵      | 内蔵      | 0       | 1.8      | 5.5      |
|       | CSTCR4M19G53 | 4.19  | 内蔵      | 内蔵      | 0       | 1.8      | 5.5      |
|       | CSTLS4M19G53 | 4.19  | 内蔵      | 内蔵      | 0       | 1.8      | 5.5      |
|       | CSTCR4M91G53 | 4.91  | 内蔵      | 内蔵      | 0       | 1.8      | 5.5      |
|       | CSTLS4M91G53 | 4.91  | 内蔵      | 内蔵      | 0       | 1.8      | 5.5      |
|       | CSTCR5M00G53 | 5.00  | 内蔵      | 内蔵      | 0       | 2.7      | 5.5      |
|       | CSTLS5M00G53 | 5.00  | 内蔵      | 内蔵      | 0       | 2.7      | 5.5      |
|       | CSTCE8M00G52 | 8.00  | 内蔵      | 内蔵      | 0       | 2.7      | 5.5      |
|       | CSTLS8M00G53 | 8.00  | 内蔵      | 内蔵      | 0       | 2.7      | 5.5      |
|       | CSTCE8M38G52 | 8.38  | 内蔵      | 内蔵      | 0       | 3.0      | 5.5      |
|       | CSTLS8M38G53 | 8.38  | 内蔵      | 内蔵      | 0       | 3.0      | 5.5      |
|       | CSTCE10M0G52 | 10.00 | 内蔵      | 内蔵      | 0       | 4.5      | 5.5      |
|       | CSTLS10M0G53 | 10.00 | 内蔵      | 内蔵      | 0       | 4.5      | 5.5      |
|       | CSTCE12M0G52 | 12.00 | 内蔵      | 内蔵      | 0       | 4.5      | 5.5      |
|       | CSTLA12M0T55 | 12.00 | 内蔵      | 内蔵      | 0       | 4.5      | 5.5      |
| TDK   | CCR3.58MC3   | 3.58  | 内蔵      | 内蔵      | 0       | 1.8      | 5.5      |
|       | CCR4.19MC3   | 4.19  | 内蔵      | 内蔵      | 0       | 1.8      | 5.5      |
|       | CCR5.0MC3    | 5.00  | 内蔵      | 内蔵      | 0       | 1.8      | 5.5      |
|       | CCR8.0MC5    | 8.00  | 内蔵      | 内蔵      | 0       | 2.0      | 5.5      |
|       | CCR8.38MC5   | 8.38  | 内蔵      | 内蔵      | 0       | 2.0      | 5.5      |

注意 この発振回路定数は発振子メーカによる特定の環境下での評価に基づく参考値です。実アプリケーションにおいて発振回路特性の最適化が必要な場合は、実装回路上での評価を発振子メーカに依頼してください。

また、発振電圧、発振周波数はあくまで発振回路特性を示すものであり、  $\mu$  PD780024AS, 780034ASサブシリーズの内部動作条件についてはDC, AC特性の規格内で使用してください。

## (b) $\mu$ PD78F0034BS

メイン・システム・クロック:セラミック発振子(T<sub>A</sub> = −40~+85 ℃)

| メーカ      | 品 名             | 周波数   |         | 推奨回路定数  |             | 発振電      | 圧範囲      |
|----------|-----------------|-------|---------|---------|-------------|----------|----------|
|          |                 | (MHz) | C1 (pF) | C2 (pF) | R1 (kΩ)     | MIN. (V) | MAX. (V) |
| 村田製作所    | CSBFB1M00J58    | 1.00  | 100     | 100     | 2.2         | 1.9      | 5.5      |
|          | CSBLA1M00J58    | 1.00  | 100     | 100     | 2.2         | 1.9      | 5.5      |
|          | CSTCC2M00G56    | 2.00  | 内蔵      | 内蔵      | 0           | 1.8      | 5.5      |
|          | CSTLS2M00G56    | 2.00  | 内蔵      | 内蔵      | 0           | 1.8      | 5.5      |
|          | CSTCC3M58G53    | 3.58  | 内蔵      | 内蔵      | 0           | 1.8      | 5.5      |
|          | CSTLS3M58G53    | 3.58  | 内蔵      | 内蔵      | 0           | 1.8      | 5.5      |
|          | CSTCR4M00G53    | 4.00  | 内蔵      | 内蔵      | 0           | 1.8      | 5.5      |
|          | CSTLS4M00G53    | 4.00  | 内蔵      | 内蔵      | 0           | 1.8      | 5.5      |
|          | CSTCR4M19G53    | 4.19  | 内蔵      | 内蔵      | 0           | 1.8      | 5.5      |
|          | CSTLS4M19G53    | 4.19  | 内蔵      | 内蔵      | 0           | 1.8      | 5.5      |
|          | CSTCR4M91G53    | 4.91  | 内蔵      | 内蔵      | 0           | 1.8      | 5.5      |
|          | CSTLS4M91G53    | 4.91  | 内蔵      | 内蔵      | 0           | 1.8      | 5.5      |
|          | CSTCR5M00G53    | 5.00  | 内蔵      | 内蔵      | 0           | 2.7      | 5.5      |
|          | CSTLS5M00G53    | 5.00  | 内蔵      | 内蔵      | 0           | 2.7      | 5.5      |
|          | CSTCE8M00G52    | 8.00  | 内蔵      | 内蔵      | 0           | 2.7      | 5.5      |
|          | CSTLS8M00G53    | 8.00  | 内蔵      | 内蔵      | 0           | 2.7      | 5.5      |
|          | CSTLS8M00G53093 | 8.00  | 内蔵      | 内蔵      | 0           | 2.7      | 5.5      |
|          | CSTCE8M38G52    | 8.38  | 内蔵      | 内蔵      | 0           | 3.0      | 5.5      |
|          | CSTLS8M38G53    | 8.38  | 内蔵      | 内蔵      | 0           | 3.0      | 5.5      |
|          | CSTLS8M38G53093 | 8.38  | 内蔵      | 内蔵      | 0           | 3.0      | 5.5      |
|          | CSTCE10M0G52    | 10.00 | 内蔵      | 内蔵      | 0           | 4.5      | 5.5      |
|          | CSTLS10M0G53    | 10.00 | 内蔵      | 内蔵      | 0           | 4.5      | 5.5      |
|          | CSTLS10M0G53093 | 10.00 | 内蔵      | 内蔵      | 0           | 4.5      | 5.5      |
|          | CSTCE12M0G52    | 12.00 | 内蔵      | 内蔵      | 0           | 4.5      | 5.5      |
|          | CSTLA12M0T55    | 12.00 | 内蔵      | 内蔵      | 0           | 4.5      | 5.5      |
|          | CSTLA12M0T55093 | 12.00 | 内蔵      | 内蔵      | 0           | 4.5      | 5.5      |
| ・辛 この発生に | 可数字粉は発揮スメー・     |       |         |         | <del></del> | 生マプリケ.   | <u> </u> |

注意 この発振回路定数は発振子メーカによる特定の環境下での評価に基づく参考値です。実アプリケーションにおいて発振回路特性の最適化が必要な場合は、実装回路上での評価を発振子メーカに依頼してください。

また、発振電圧、発振周波数はあくまで発振回路特性を示すものであり、  $\mu$  PD780024AS, 780034ASサブシリーズの内部動作条件についてはDC, AC特性の規格内で使用してください。

# DC特性 $(T_A = -40 \sim +85 \,^{\circ}\text{C}, V_{DD} = 1.8 \sim 5.5 \,^{\circ}\text{V})$ (1/4)

| 項目       | 略号               | 条                      | 件                             | MIN.                 | TYP. | MAX.                                  | 単位 |
|----------|------------------|------------------------|-------------------------------|----------------------|------|---------------------------------------|----|
| ハイ・レベル   | Іон              | 1 端子                   |                               |                      |      | <b>-</b> 1                            | mA |
| 出力電流     |                  | 全端子                    |                               |                      |      | -15                                   | mA |
| ロウ・レベル出力 | loL              | P00-P03, P20-P25, P34  | -P36, P40-P47, P70-P75 1 端子   |                      |      | 10                                    | mA |
| 電流       |                  | P50-P57 1 端子           |                               |                      |      | 15                                    | mA |
|          |                  | P00-P03, P40-P47, P70- | -P75 合計                       |                      |      | 20                                    | mA |
|          |                  | P20-P25 合計             |                               |                      |      | 10                                    | mA |
|          |                  | P34-P36 合計             |                               |                      |      | 30                                    | mA |
|          |                  | P50-P57 合計             |                               |                      |      | 70                                    | mA |
| ハイ・レベル   | V <sub>IH1</sub> | P10-P13, P21, P24,     | 2.7 V≦VDD≦5.5 V               | 0.7 V <sub>DD</sub>  |      | V <sub>DD</sub>                       | V  |
| 入力電圧     |                  | P35, P40-P47,          | 101//1 /071/                  | 0.0.1/               |      | \ \ \ \ \ \ \ \ \ \ \ \ \ \ \ \ \ \ \ | V  |
|          |                  | P50-P57, P74, P75      | 1.8 V≦V <sub>DD</sub> <2.7 V  | 0.8 V <sub>DD</sub>  |      | V <sub>DD</sub>                       | V  |
|          | V <sub>IH2</sub> | P00-P03, P20, P22,     | 2.7 V≦VDD≦5.5 V               | 0.8 V <sub>DD</sub>  |      | V <sub>DD</sub>                       | V  |
|          |                  | P23, P25, P34, P36,    | 1.8 V≦V <sub>DD</sub> <2.7 V  | 0.05.1/              |      | \/                                    | V  |
|          |                  | P70-P73, RESET         | 1.8 V ≥ V DD < 2.7 V          | 0.85 V <sub>DD</sub> |      | V <sub>DD</sub>                       | V  |
|          | VIH3             | X1, X2                 | 2.7 V≦VDD≦5.5 V               | V <sub>DD</sub> -0.5 |      | V <sub>DD</sub>                       | V  |
|          |                  |                        | 1.8 V≦V <sub>DD</sub> <2.7 V  | V <sub>DD</sub> -0.2 |      | V <sub>DD</sub>                       | V  |
|          | V <sub>IH4</sub> | XT1, XT2               | 4.0 V≦VDD≦5.5 V               | 0.8 V <sub>DD</sub>  |      | V <sub>DD</sub>                       | V  |
|          |                  |                        | 1.8 V≦V <sub>DD</sub> <4.0 V  | 0.9 V <sub>DD</sub>  |      | V <sub>DD</sub>                       | V  |
| ロウ・レベル   | V <sub>IL1</sub> | P10-P13, P21, P24,     | 2.7 V≦VDD≦5.5 V               | 0                    |      | 0.3 V <sub>DD</sub>                   | V  |
| 入力電圧     |                  | P35, P40-P47,          | 1.8 V≦V <sub>DD</sub> <2.7 V  | 0                    |      | 0.2 V <sub>DD</sub>                   | V  |
|          |                  | P50-P57, P74, P75      | 1.6 V ≦ V DD \ 2./ V          |                      |      | U.Z VDD                               | V  |
|          | V <sub>IL2</sub> | P00-P03, P20, P22,     | 2.7 V≦VDD≦5.5 V               | 0                    |      | 0.2 V <sub>DD</sub>                   | V  |
|          |                  | P23, P25, P34, P36,    | 1.8 V≦V <sub>DD</sub> <5.5 V  | 0                    |      | 0.15.\/                               | V  |
|          |                  | P70-P73, RESET         | 1.6 V ≦ V DD \ 5.5 V          |                      |      | 0.15 V <sub>DD</sub>                  | V  |
|          | VIL3             | X1, X2                 | 2.7 V≦VDD≦5.5 V               | 0                    |      | 0.4                                   | V  |
|          |                  |                        | 1.8 V≦V <sub>DD</sub> <2.7 V  | 0                    |      | 0.2                                   | V  |
|          | VIL4             | XT1, XT2               | 4.0 V≦VDD≦5.5 V               | 0                    |      | 0.2 V <sub>DD</sub>                   | V  |
|          |                  |                        | 1.8 V≦V <sub>DD</sub> <4.0 V  | 0                    |      | 0.1 V <sub>DD</sub>                   | V  |
| ハイ・レベル   | V <sub>OH1</sub> | Iон = —1 mA            | 4.0 V≦VDD≦5.5 V               | V <sub>DD</sub> -1.0 |      | V <sub>DD</sub>                       | V  |
| 出力電圧     |                  | Ioн = -100 μ A         | 1.8 V≦V <sub>DD</sub> <4.0 V  | V <sub>DD</sub> -0.5 |      | V <sub>DD</sub>                       | V  |
| ロウ・レベル   | V <sub>OL1</sub> | P50-P57                | 4.0 V≦VDD≦5.5 V, loL = 15 mA  |                      | 0.4  | 2.0                                   | ٧  |
| 出力電圧     | V <sub>OL2</sub> | P00-P03, P20-P25,      | 4.0 V≦VDD≦5.5 V, IoL = 1.6 mA |                      |      | 0.4                                   | V  |
|          |                  | P34-P36, P40-P47,      |                               |                      |      |                                       |    |
|          |                  | P70-P75                |                               |                      |      |                                       |    |
|          | V <sub>OL3</sub> | IoL = 400 μ A          |                               |                      |      | 0.5                                   | V  |

**備考** 特に指定のないかぎり、兼用端子の特性はポート端子の特性と同じです。

# DC特性 $(T_A = -40 \sim +85 \,^{\circ}\text{C}, V_{DD} = 1.8 \sim 5.5 \,^{\circ}\text{V})$ (2/4)

| 項目       | 略号             | 条                       | 件                              | MIN. | TYP. | MAX.        | 単位 |
|----------|----------------|-------------------------|--------------------------------|------|------|-------------|----|
| ハイ・レベル   | Ішн1           | VIN = VDD               | P00-P03, P10-P13, P20-P25,     |      |      | 3           | μΑ |
| 入カリーク電流  |                |                         | P34-P36, P40-P47, P50-P57,     |      |      |             |    |
|          |                |                         | P70-P75, RESET                 |      |      |             |    |
|          | ILIH2          |                         | X1, X2, XT1, XT2               |      |      | 20          | μΑ |
| ロウ・レベル   | ILIL1          | VIN = 0 V               | P00-P03, P10-P13, P20-P25,     |      |      | <b>—</b> 3  | μΑ |
| 入力リーク電流  |                |                         | P34-P36, P40-P47, P50-P57,     |      |      |             |    |
|          |                |                         | P70-P75, RESET                 |      |      |             |    |
|          | ILIL2          |                         | X1, X2, XT1, XT2               |      |      | <b>- 20</b> | μΑ |
| ハイ・レベル   | Ісон           | Vout = Vdd              |                                |      |      | 3           | μΑ |
| 出カリーク電流  |                |                         |                                |      |      |             |    |
| ロウ・レベル   | ILOL           | Vout = 0 V              |                                |      |      | <b>—</b> 3  | μΑ |
| 出カリーク電流  |                |                         |                                |      |      |             |    |
| ソフトウエア・プ | R <sub>2</sub> | VIN = 0 V,              |                                | 15   | 30   | 90          | kΩ |
| ルアップ抵抗   |                | P00-P03, P20-P25, P34-F | P36, P40-P47, P50-P57, P70-P75 |      |      |             |    |

備考 特に指定のないかぎり、兼用端子の特性はポート端子の特性と同じです。

DC特性  $(T_A = -40 \sim +85 \,^{\circ}\text{C}, V_{DD} = 1.8 \sim 5.5 \,^{\circ}\text{V})$  (3/4)

## (a) $\mu$ PD780021AS, 780022AS, 780023AS, 780024AS, 780031AS, 780032AS, 780033AS, 780034AS

| 項目                  | 略号                  | 条                |                                               | 件                            | MIN. | TYP. | MAX. | 単位 |
|---------------------|---------------------|------------------|-----------------------------------------------|------------------------------|------|------|------|----|
| 電源電流 <sup>注 1</sup> | I <sub>DD1</sub> 注2 | 12.0 MHz水晶発振     | V <sub>DD</sub> = 5.0 V±10 % <sup>注3</sup>    | A/Dコンバータ停止時                  |      | 8.5  | 17   | mA |
|                     |                     | 動作モード            |                                               | A/Dコンバータ動作時 <sup>注 7</sup>   |      | 9.5  | 19   | mA |
|                     |                     | 8.38 MHz水晶発振     | V <sub>DD</sub> = 5.0 V±10 % <sup>注3</sup>    | A/Dコンバータ停止時                  |      | 5.5  | 11   | mA |
|                     |                     | 動作モード            |                                               | A/Dコンバータ動作時 <sup>注 7</sup>   |      | 6.5  | 13   | mA |
|                     |                     |                  | V <sub>DD</sub> = 3.0 V+10 % <sup>注 3,6</sup> | A/Dコンバータ停止時                  |      | 3    | 6    | mA |
|                     |                     |                  |                                               | A/Dコンバータ動作時 <sup>注 7</sup>   |      | 4    | 8    | mA |
|                     |                     | 5.0 MHz水晶発振      | V <sub>DD</sub> = 3.0 V±10 % <sup>注3</sup>    | A/Dコンバータ停止時                  |      | 2    | 4    | mA |
|                     |                     | 動作モード            |                                               | A/Dコンバータ動作時 <sup>注 7</sup>   |      | 3    | 6    | mA |
|                     |                     |                  | V <sub>DD</sub> = 2.0 V±10 % <sup>注 4</sup>   | A/Dコンバータ停止時                  |      | 0.4  | 1.5  | mA |
|                     |                     |                  |                                               | A/Dコンバータ動作時 <sup>注 7</sup>   |      | 1.4  | 4.2  | mA |
|                     | I <sub>DD2</sub>    | 12.0 MHz水晶発振     | V <sub>DD</sub> = 5.0 V±10 % <sup>注3</sup>    | 周辺機能停止時                      |      | 2    | 4    | mA |
|                     |                     | HALTモード          |                                               | 周辺機能動作時                      |      |      | 10   | mA |
|                     |                     | 8.38 MHz水晶発振     | V <sub>DD</sub> = 5.0 V±10 % <sup>注3</sup>    | 周辺機能停止時                      |      | 1.1  | 2.2  | mA |
|                     |                     | HALTモード          |                                               | 周辺機能動作時                      |      |      | 4.7  | mA |
|                     |                     |                  | V <sub>DD</sub> = 3.0 V+10 % <sup>注 3,6</sup> | 周辺機能停止時                      |      | 0.5  | 1    | mA |
|                     |                     |                  |                                               | 周辺機能動作時                      |      |      | 4    | mA |
|                     |                     | 5.0 MHz水晶発振      | V <sub>DD</sub> = 3.0 V±10 % <sup>注3</sup>    | 周辺機能停止時                      |      | 0.35 | 0.7  | mA |
|                     |                     | HALTモード          |                                               | 周辺機能動作時                      |      |      | 1.7  | mA |
|                     |                     |                  | V <sub>DD</sub> = 2.0 V±10 % <sup>注 4</sup>   | 周辺機能停止時                      |      | 0.15 | 0.4  | mA |
|                     |                     |                  |                                               | 周辺機能動作時                      |      |      | 1.1  | mA |
|                     | IDD3                | 32.768 kHz水晶発振   | 動作モード <sup>注 5</sup>                          | V <sub>DD</sub> = 5.0 V±10 % |      | 40   | 80   | μΑ |
|                     |                     |                  |                                               | V <sub>DD</sub> = 3.0 V±10 % |      | 20   | 40   | μΑ |
|                     |                     |                  |                                               | V <sub>DD</sub> = 2.0 V±10 % |      | 10   | 20   | μΑ |
|                     | I <sub>DD4</sub>    | 32.768 kHz水晶発振   | HALTモード <sup>注 5</sup>                        | V <sub>DD</sub> = 5.0 V±10 % |      | 30   | 60   | μΑ |
|                     |                     |                  |                                               | V <sub>DD</sub> = 3.0 V±10 % |      | 6    | 18   | μΑ |
|                     |                     |                  |                                               | V <sub>DD</sub> = 2.0 V±10 % |      | 2    | 10   | μΑ |
|                     | I <sub>DD5</sub>    | XT1 = VDD, STOP₹ | - ř                                           | V <sub>DD</sub> = 5.0 V±10 % |      | 0.1  | 30   | μΑ |
|                     |                     | フィードバック抵抗        | 非使用時                                          | V <sub>DD</sub> = 3.0 V±10 % |      | 0.05 | 10   | μΑ |
|                     |                     |                  |                                               | V <sub>DD</sub> = 2.0 V±10 % |      | 0.05 | 10   | μΑ |

- 注1. 内部電源( $V_{DD0}, V_{DD1}$ )に流れるトータル電流です。ただし、ポートのプルアップ抵抗に流れる電流は含みません。
  - 2. IDD1は周辺動作電流を含みます。
  - 3. プロセッサ・クロック・コントロール・レジスタ (PCC) を00Hに設定したとき
  - 4. PCCを02Hに設定したとき
  - 5. メイン・システム・クロックを停止させたとき
  - 6.  $V_{DD} = 3.0 \sim 3.3 V$ 時のスペックです。TYP.は $V_{DD} = 3.0 V$ 時のスペックです。
  - 7. AVDD端子に流れる電流を含みます。

335

DC特性  $(T_A = -40 \sim +85 \,^{\circ}\text{C}, V_{DD} = 1.8 \sim 5.5 \,\text{V})$  (4/4)

## (b) $\mu$ PD78F0034BS

| 項目                  | 略号                 | 条                |                                                   | 件                            | MIN. | TYP. | MAX. | 単位 |
|---------------------|--------------------|------------------|---------------------------------------------------|------------------------------|------|------|------|----|
| 電源電流 <sup>注 1</sup> | IDD1 <sup>注2</sup> | 12.0 MHz水晶発振     | $V_{DD} = 5.0 \text{ V} \pm 10 \%^{\frac{1}{2}3}$ | A/Dコンバータ停止時                  |      | 16   | 32   | mA |
|                     |                    | 動作モード            |                                                   | A/Dコンバータ動作時 <sup>注 7</sup>   |      | 17   | 34   | mA |
|                     |                    | 8.38 MHz水晶発振     | $V_{DD} = 5.0 \text{ V} \pm 10 \%^{\frac{1}{2}3}$ | A/Dコンバータ停止時                  |      | 10.5 | 21   | mA |
|                     |                    | 動作モード            |                                                   | A/Dコンバータ動作時 <sup>注 7</sup>   |      | 11.5 | 23   | mA |
|                     |                    |                  | $V_{DD} = 3.0 \text{ V} + 10 \%^{\frac{1}{2}3,6}$ | A/Dコンバータ停止時                  |      | 7    | 14   | mA |
|                     |                    |                  |                                                   | A/Dコンバータ動作時 <sup>注 7</sup>   |      | 8    | 16   | mA |
|                     |                    | 5.0 MHz水晶発振      | $V_{DD} = 3.0 \text{ V} \pm 10 \%^{\frac{1}{2}3}$ | A/Dコンバータ停止時                  |      | 4.5  | 9    | mA |
|                     |                    | 動作モード            |                                                   | A/Dコンバータ動作時 <sup>注 7</sup>   |      | 5.5  | 11   | mA |
|                     |                    |                  | V <sub>DD</sub> = 2.0 V±10 % <sup>注 4</sup>       | A/Dコンバータ停止時                  |      | 1    | 2    | mA |
|                     |                    |                  |                                                   | A/Dコンバータ動作時 <sup>注 7</sup>   |      | 2    | 6    | mA |
|                     | I <sub>DD2</sub>   | 12.0 MHz水晶発振     | $V_{DD} = 5.0 \text{ V} \pm 10 \%^{\frac{1}{2}3}$ | 周辺機能停止時                      |      | 2.0  | 4.0  | mA |
|                     |                    | HALTモード          |                                                   | 周辺機能動作時                      |      |      | 8.0  | mA |
|                     |                    | 8.38 MHz水晶発振     | $V_{DD} = 5.0 \text{ V} \pm 10 \%^{\frac{1}{2}3}$ | 周辺機能停止時                      |      | 1.2  | 2.4  | mA |
|                     |                    | HALTモード          |                                                   | 周辺機能動作時                      |      |      | 5    | mA |
|                     |                    |                  | $V_{DD} = 3.0 \text{ V} + 10 \%^{\frac{1}{2}3,6}$ | 周辺機能停止時                      |      | 0.6  | 1.2  | mA |
|                     |                    |                  |                                                   | 周辺機能動作時                      |      |      | 2.4  | mA |
|                     |                    | 5.0 MHz水晶発振      | $V_{DD} = 3.0 \text{ V} \pm 10 \%^{\frac{1}{2}3}$ | 周辺機能停止時                      |      | 0.4  | 0.8  | mA |
|                     |                    | HALTモード          |                                                   | 周辺機能動作時                      |      |      | 1.7  | mA |
|                     |                    |                  | V <sub>DD</sub> = 2.0 V±10 % <sup>注 4</sup>       | 周辺機能停止時                      |      | 0.2  | 0.4  | mA |
|                     |                    |                  |                                                   | 周辺機能動作時                      |      |      | 1.1  | mA |
|                     | IDD3               | 32.768 kHz水晶発振   | 動作モード <sup>注 5</sup>                              | V <sub>DD</sub> = 5.0 V±10 % |      | 115  | 230  | μΑ |
|                     |                    |                  |                                                   | V <sub>DD</sub> = 3.0 V±10 % |      | 95   | 190  | μΑ |
|                     |                    |                  |                                                   | V <sub>DD</sub> = 2.0 V±10 % |      | 75   | 150  | μΑ |
|                     | I <sub>DD4</sub>   | 32.768 kHz水晶発振   | HALTモード <sup>注 5</sup>                            | V <sub>DD</sub> = 5.0 V±10 % |      | 30   | 60   | μΑ |
|                     |                    |                  |                                                   | V <sub>DD</sub> = 3.0 V±10 % |      | 6    | 18   | μΑ |
|                     |                    |                  |                                                   | V <sub>DD</sub> = 2.0 V±10 % |      | 2    | 10   | μΑ |
|                     | I <sub>DD5</sub>   | XT1 = VDD, STOP€ | - Ķ                                               | V <sub>DD</sub> = 5.0 V±10 % |      | 0.1  | 30   | μΑ |
|                     |                    | フィードバック抵抗        | V <sub>DD</sub> = 3.0 V±10 %                      |                              | 0.05 | 10   | μΑ   |    |
|                     |                    |                  |                                                   | V <sub>DD</sub> = 2.0 V±10 % |      | 0.05 | 10   | μΑ |

- 注1. 内部電源( $V_{DD0}$ ,  $V_{DD1}$ )に流れるトータル電流です。ただし、ポートのプルアップ抵抗に流れる電流は含みません。
  - 2. IDD1は周辺動作電流を含みます。
  - 3. プロセッサ・クロック・コントロール・レジスタ (PCC) を00Hに設定したとき
  - 4. PCCを02Hに設定したとき
  - 5. メイン・システム・クロックを停止させたとき
  - 6.  $V_{DD} = 3.0 \sim 3.3 V$ 時のスペックです。TYP.は $V_{DD} = 3.0 V$ 時のスペックです。
  - 7. AVDD端子に流れる電流を含みます。

\*

# AC特性

# (1) 基本動作(T<sub>A</sub> = -40~+85℃, V<sub>DD</sub> = 1.8~5.5 V)

| 項目            | 略             | 号 | 条                            | 件                            | MIN.                 | TYP. | MAX. | 単位  |
|---------------|---------------|---|------------------------------|------------------------------|----------------------|------|------|-----|
| サイクル・タイム      | Тсч           |   | メイン・システム・クロックで               | 4.5 V≦VDD≦5.5 V              | 0.166                |      | 16   | μS  |
| (最小命令実行時間)    |               |   | 動作                           | 3.0 V≦V <sub>DD</sub> <4.5 V | 0.238                |      | 16   | μS  |
|               |               |   |                              | 2.7 V≦V <sub>DD</sub> <3.0 V | 0.4                  |      | 16   | μS  |
|               |               |   |                              | 1.8 V≦V <sub>DD</sub> <2.7 V | 1.6                  |      | 16   | μS  |
|               |               |   | サブシステム・クロックで動作               |                              | 103.9 <sup>注 1</sup> | 122  | 125  | μS  |
| TI00, TI01入カハ | <b>t</b> тіно |   | 3.0 V≦VDD≦5.5 V              |                              | 2/f <sub>sam</sub> + |      |      | μS  |
| イ,ロウ・レベル幅     | <b>t</b> TIL0 |   |                              |                              | 0.1 <sup>注 2</sup>   |      |      |     |
|               |               |   | 2.7 V≦V <sub>DD</sub> <3.0 V |                              | 2/f <sub>sam</sub> + |      |      | μS  |
|               |               |   |                              |                              | 0.2 <sup>注 2</sup>   |      |      |     |
|               |               |   | 1.8 V≦V <sub>DD</sub> <2.7 V |                              | 2/f <sub>sam</sub> + |      |      | μS  |
|               |               |   |                              |                              | 0.5 <sup>注 2</sup>   |      |      |     |
| TI50, TI51入力周 | <b>f</b> TI5  |   | 2.7 V≦VDD≦5.5 V              |                              | 0                    |      | 4    | MHz |
| 波数            |               |   | 1.8 V≦V <sub>DD</sub> <2.7 V |                              | 0                    |      | 275  | kHz |
| TI50, TI51入力ハ | <b>t</b> тін5 |   | 2.7 V≦VDD≦5.5 V              |                              | 100                  |      |      | ns  |
| イ,ロウ・レベル幅     | <b>t</b> TIL5 |   | 1.8 V≦V <sub>DD</sub> <2.7 V |                              | 1.8                  |      |      | μS  |
| 割り込み要求入力ハ     | tınth         |   | INTP0-INTP3,                 | 2.7 V≦VDD≦5.5 V              | 1                    |      |      | μS  |
| イ,ロウ・レベル幅     | tintl         |   | P40-P47                      | 1.8 V≦V <sub>DD</sub> <2.7 V | 2                    |      |      | μS  |
| RESETロウ・レベ    | trsL          |   | 2.7 V≦VDD≦5.5 V              |                              | 10                   |      |      | μS  |
| ル幅            |               |   | 1.8 V≦V <sub>DD</sub> <2.7 V |                              | 20                   |      |      | μS  |

- 注1. 外部クロック使用時の値です。水晶振動子使用時は114 $\mu$ s(MIN.)です。
  - 2. プリスケーラ・モード・レジスタ 0 (PRM0) のビット 0 、1 (PRM00, PRM01) により、 $f_{sam} = f_{x}$ ,  $f_{x}/4$ ,  $f_{x}/64$  の選択が可能です。ただし、カウント・クロックとしてTI00有効エッジを選択した場合は、 $f_{sam} = f_{x}/8$ となります。

# Tcy vs Vdd (メイン・システム・クロック動作時)



## (2) シリアル・インタフェース $(T_A = -40 \sim +85 \, ^{\circ} \, ^{\circ}$

# (a) 3 線式シリアルI/Oモード(SCK3n···内部クロック出力)

| 項目                      | 1           | 略                | 号 | 条                            | 件                            | MIN.        | TYP. | MAX. | 単位 |
|-------------------------|-------------|------------------|---|------------------------------|------------------------------|-------------|------|------|----|
| SCK3nサイクル               | <b>ノ・</b> タ | tkcy1            |   | 4.5 V≦VDD≦5.5 V              |                              | 666         |      |      | ns |
| 14                      |             |                  |   | 3.0 V≦V <sub>DD</sub> <4.5 V |                              | 954         |      |      | ns |
|                         |             |                  |   | 2.7 V≦V <sub>DD</sub> <3.0 V |                              | 1600        |      |      | ns |
|                         |             |                  |   | 1.8 V≦V <sub>DD</sub> <2.7 V |                              | 3200        |      |      | ns |
| SCK3nハイ,                |             | <b>t</b> KH1     |   | 3.0 V≦VDD≦5.5 V              |                              | tkcy1/2-50  |      |      | ns |
| ロウ・レベル幅                 |             | t <sub>KL1</sub> |   | 1.8 V≦V <sub>DD</sub> <3.0 V |                              | tkcy1/2-100 |      |      | ns |
| SI3nセットアッ               | プ時          | tsik1            |   | 3.0 V≦VDD≦5.5 V              |                              | 100         |      |      | ns |
| 間(対 <del>SCK3n</del> ↑) |             |                  |   | 2.7 V≦V <sub>DD</sub> <3.0 V |                              | 150         |      |      | ns |
|                         |             |                  |   | 1.8 V≦V <sub>DD</sub> <2.7 V |                              | 300         |      |      | ns |
| SI3nホールド時間              | 間           | <b>t</b> KSI1    |   | 4.5 V≦VDD≦5.5 V              |                              | 300         |      |      | ns |
| (対 <del>SCK3n</del> ↑)  |             |                  |   | 1.8 V≦V <sub>DD</sub> <4.5 V |                              | 400         |      |      | ns |
| SCK3n ↓ →               |             | tkso1            |   | C = 100 pF <sup>注</sup>      | 4.5 V≦VDD≦5.5 V              |             |      | 200  | ns |
| SO3n出力遅延時               | 間           |                  |   |                              | 1.8 V≦V <sub>DD</sub> <4.5 V |             |      | 300  | ns |

注 Cは、SCK3n, SO3n出力ラインの負荷容量です。

# (b) 3線式シリアルI/Oモード(SCK3n···外部クロック入力)

| 項目                       | 略                 | 号 | 条                            | 件                            | MIN. | TYP. | MAX. | 単位 |
|--------------------------|-------------------|---|------------------------------|------------------------------|------|------|------|----|
| SCK3nサイクル・:              | タ tkcy2           |   | 4.5 V≦VDD≦5.5 V              |                              | 666  |      |      | ns |
| イム                       |                   |   | 3.0 V≦V <sub>DD</sub> <4.5 V |                              | 800  |      |      | ns |
|                          |                   |   | 2.7 V≦V <sub>DD</sub> <3.0 V |                              | 1600 |      |      | ns |
|                          |                   |   | 1.8 V≦V <sub>DD</sub> <2.7 V |                              | 3200 |      |      | ns |
| SCK3nハイ,                 | <b>t</b> KH2      |   | 4.5 V≦VDD≦5.5 V              |                              | 333  |      |      | ns |
| ロウ・レベル幅                  | t <sub>KL2</sub>  |   | 3.0 V≦V <sub>DD</sub> <4.5 V |                              | 400  |      |      | ns |
|                          |                   |   | 2.7 V≦V <sub>DD</sub> <3.0 V |                              | 800  |      |      | ns |
|                          |                   |   | 1.8 V≦V <sub>DD</sub> <2.7 V |                              | 1600 |      |      | ns |
| Sl3nセットアップ時              | 間 tsik2           |   |                              |                              | 100  |      |      | ns |
| (対 <mark>SCK3n</mark> ↑) |                   |   |                              |                              |      |      |      |    |
| SI3nホールド時間               | t <sub>KSI2</sub> |   | 4.5 V≦VDD≦5.5 V              |                              | 300  |      |      | ns |
| (対 <del>SCK3n</del> † )  |                   |   | 1.8 V≦V <sub>DD</sub> <4.5 V |                              | 400  |      |      | ns |
| SCK3n ↓ →                | tks02             | ! | C = 100 pF <sup>注</sup>      | 4.5 V≦VDD≦5.5 V              |      |      | 200  | ns |
| SO3n出力遅延時間               |                   |   |                              | 1.8 V≦V <sub>DD</sub> <4.5 V |      |      | 300  | ns |

注 Cは、SO3n出力ラインの負荷容量です。

# 備考 n = 0, 1

# (2) $9 \text{ JPW} \cdot \text{APP} - \text{APP} \cdot \text{APP} = -40 - +85 \,^{\circ}\text{C}$ , $\text{VDD} = 1.8 - 5.5 \,^{\circ}\text{V}$ ) (2/2)

# (c) UARTモード(専用ボー・レート・ジェネレータ出力)

| 項     | 目 | 略 | 号 | 条                            | 件 | MIN. | TYP. | MAX.   | 単位  |
|-------|---|---|---|------------------------------|---|------|------|--------|-----|
| 転送レート |   |   |   | 4.5 V≦VDD≦5.5 V              |   |      |      | 187500 | bps |
|       |   |   |   | 3.0 V≦V <sub>DD</sub> <4.5 V |   |      |      | 131031 | bps |
|       |   |   |   | 2.7 V≦V <sub>DD</sub> <3.0 V |   |      |      | 78125  | bps |
|       |   |   |   | 1.8 V≦V <sub>DD</sub> <2.7 V |   |      |      | 39063  | bps |

## (d) UARTモード(外部クロック入力)

| 項       | 目     | 略             | 号 | 条                            | 件 | MIN. | TYP. | MAX.  | 単位  |
|---------|-------|---------------|---|------------------------------|---|------|------|-------|-----|
| ASCK0サ1 | ′クル・  | <b>t</b> KCY3 |   | 4.0 V≦VDD≦5.5 V              |   | 800  |      |       | ns  |
| タイム     |       |               |   | 2.7 V≦V <sub>DD</sub> <4.0 V |   | 1600 |      |       | ns  |
|         |       |               |   | 1.8 V≦V <sub>DD</sub> <2.7 V |   | 3200 |      |       | ns  |
| ASCK0   |       | <b>t</b> кнз, |   | 4.0 V≦VDD≦5.5 V              |   | 400  |      |       | ns  |
| ハイ,ロウ   | ・レベル幅 | tкьз          |   | 2.7 V≦V <sub>DD</sub> <4.0 V |   | 800  |      |       | ns  |
|         |       |               |   | 1.8 V≦V <sub>DD</sub> <2.7 V |   | 1600 |      |       | ns  |
| 転送レート   |       |               |   | 4.0 V≦VDD≦5.5 V              |   |      |      | 39063 | bps |
|         |       |               |   | 2.7 V≦V <sub>DD</sub> <4.0 V |   |      |      | 19531 | bps |
|         |       |               |   | 1.8 V≦V <sub>DD</sub> <2.7 V |   |      |      | 9766  | bps |

# (e) UARTモード(赤外線データ転送モード)

| 項      | 目                                     | 略 | 号 | 条               | 件 | MIN. | TYP. | MAX.                  | 単位  |
|--------|---------------------------------------|---|---|-----------------|---|------|------|-----------------------|-----|
| 転送レート  |                                       |   |   | 4.0 V≦VDD≦5.5 V |   |      |      | 131031                | bps |
| ビット・レー | ト許容誤差                                 |   |   | 4.0 V≦VDD≦5.5 V |   |      |      | ±0.87                 | %   |
| 出力パルス「 | ····································· |   |   | 4.0 V≦VDD≦5.5 V |   | 1.2  |      | 0.24/fbr <sup>注</sup> | μS  |
| 入力パルス「 | 福                                     |   |   | 4.0 V≦VDD≦5.5 V |   | 4/fx |      |                       | μS  |

注 fbr:設定ボー・レート

# ACタイミング測定点(X1, XT1入力を除く)



## クロック・タイミング



# TIタイミング





# 割り込み要求入力タイミング



# RESET入力タイミング



# シリアル転送タイミング

## 3 線式シリアルI/Oモード:



**備考1.** m = 1, 2

2. n = 0, 1

# UARTモード (外部クロック入力):



## A/Dコンバータ特性

## (a) 8ビットA/Dコンバータ (μPD780024ASサブシリーズ)

 $(T_A = -40 \sim +85 \,^{\circ}\text{C}, V_{DD} = AV_{DD} = 1.8 \sim 5.5 \,^{\circ}\text{V}, AV_{SS} = V_{SS} = 0 \,^{\circ}\text{V})$ 

| 項                   | 目  | 略     | 号 | 条                              | 件 | MIN. | TYP. | MAX.             | 単位   |
|---------------------|----|-------|---|--------------------------------|---|------|------|------------------|------|
| 分解能                 |    |       |   |                                |   | 8    | 8    | 8                | bit  |
| 総合誤差 <sup>注1,</sup> | 2  |       |   | 4.0 V≦AV <sub>REF</sub> ≦5.5 V |   |      |      | ±0.4             | %FSR |
|                     |    |       |   | 2.7 V≦AV <sub>REF</sub> <4.0 V |   |      |      | ±0.6             | %FSR |
|                     |    |       |   | 1.8 V≦AV <sub>REF</sub> <2.7 V |   |      |      | ±1.2             | %FSR |
| 変換時間                |    | tconv |   | 4.5 V≦AVDD≦5.5 V               |   | 12   |      | 96               | μS   |
|                     |    |       |   | 4.0 V≦AV <sub>DD</sub> <4.5 V  |   | 14   |      | 96               | μS   |
|                     |    |       |   | 2.7 V≦AV <sub>DD</sub> <4.0 V  |   | 17   |      | 96               | μS   |
|                     |    |       |   | 1.8 V≦AV <sub>DD</sub> <2.7 V  |   | 28   |      | 96               | μS   |
| アナログ入力              | 電圧 | VAIN  |   |                                |   | 0    |      | AVREF            | V    |
| 基準電圧                |    | AVRE  |   |                                |   | 1.8  |      | AV <sub>DD</sub> | V    |
| AVREF-AVss間         | 抵抗 | RREF  |   | A/D変換動作時                       |   | 20   | 40   |                  | kΩ   |

- 注1. 量子化誤差 (土 1/2 LSB) を含みません。
  - 2. フルスケール値に対する比率(%FSR)で表します。

## (b) 10ビットA/Dコンバータ (μPD780034ASサブシリーズ)

 $(T_A = -40 \sim +85 \,^{\circ}\text{C}, V_{DD} = AV_{DD} = 1.8 \sim 5.5 \,^{\circ}\text{V}, AV_{SS} = V_{SS} = 0 \,^{\circ}\text{V})$ 

| 項目                        | 略号    | 条                              | 件 | MIN. | TYP. | MAX.  | 単位   |
|---------------------------|-------|--------------------------------|---|------|------|-------|------|
| 分解能                       |       |                                |   | 10   | 10   | 10    | bit  |
| 総合誤差 <sup>注1,2</sup>      |       | 4.0 V≦AV <sub>REF</sub> ≦5.5 V |   |      | ±0.2 | ±0.4  | %FSR |
|                           |       | 2.7 V≦AV <sub>REF</sub> <4.0 V |   |      | ±0.3 | ±0.6  | %FSR |
|                           |       | 1.8 V≦AV <sub>REF</sub> <2.7 V |   |      | ±0.6 | ±1.2  | %FSR |
| 変換時間                      | tconv | 4.5 V≦AVDD≦5.5 V               |   | 12   |      | 96    | μS   |
|                           |       | 4.0 V≦AV <sub>DD</sub> <4.5 V  |   | 14   |      | 96    | μS   |
|                           |       | 2.7 V≦AV <sub>DD</sub> <4.0 V  |   | 17   |      | 96    | μS   |
|                           |       | 1.8 V≦AV <sub>DD</sub> <2.7 V  |   | 28   |      | 96    | μS   |
| ゼロスケール誤差 <sup>注 1,2</sup> | 2     | 4.0 V≦AV <sub>REF</sub> ≦5.5 V |   |      |      | ±0.4  | %FSR |
|                           |       | 2.7 V≦AV <sub>REF</sub> <4.0 V |   |      |      | ±0.6  | %FSR |
|                           |       | 1.8 V≦AV <sub>REF</sub> <2.7 V |   |      |      | ±1.2  | %FSR |
| フルスケール誤差 <sup>注 1,2</sup> | 2     | 4.0 V≦AV <sub>REF</sub> ≦5.5 V |   |      |      | ±0.4  | %FSR |
|                           |       | 2.7 V≦AV <sub>REF</sub> <4.0 V |   |      |      | ±0.6  | %FSR |
|                           |       | 1.8 V≦AV <sub>REF</sub> <2.7 V |   |      |      | ±1.2  | %FSR |
| 積分直線性誤差 <sup>注 1</sup>    |       | 4.0 V≦AV <sub>REF</sub> ≦5.5 V |   |      |      | ±2.5  | LSB  |
|                           |       | 2.7 V≦AV <sub>REF</sub> <4.0 V |   |      |      | ±4.5  | LSB  |
|                           |       | 1.8 V≦AV <sub>REF</sub> <2.7 V |   |      |      | ±8.5  | LSB  |
| 微分直線性誤差 <sup>注 1</sup>    |       | 4.0 V≦AV <sub>REF</sub> ≦5.5 V |   |      |      | ±1.5  | LSB  |
|                           |       | 2.7 V≦AV <sub>REF</sub> <4.0 V |   |      |      | ±2.0  | LSB  |
|                           |       | 1.8 V≦AV <sub>REF</sub> <2.7 V |   |      |      | ±3.5  | LSB  |
| アナログ入力電圧                  | Vain  |                                |   | 0    |      | AVREF | V    |
| 基準電圧                      | AVREF |                                |   | 1.8  |      | AVDD  | V    |
| AVREF-AVss間抵抗             | RREF  | A/D変換動作時                       |   | 20   | 40   |       | kΩ   |

注1. 量子化誤差 (土 1/2 LSB) を含みません。

2. フルスケール値に対する比率(%FSR)で表します。

(備考は次頁に示します)

## **備考** アナログ入力端子のインピーダンスを次に示します。

## 〔等価回路〕



# ★ 〔パラメータ値〕

(TYP.)

| AV <sub>DD</sub> | R1    | R2     | C1     | C2     | C3     |
|------------------|-------|--------|--------|--------|--------|
| 2.7 V            | 12 kΩ | 8.0 kΩ | 8.0 pF | 3.0 pF | 2.0 pF |
| 4.5 V            | 4 kΩ  | 2.7 kΩ | 8.0 pF | 1.4 pF | 2.0 pF |

データ・メモリSTOPモード低電源電圧データ保持特性(TA =  $-40 \sim +85 \, ^{\circ}$ C)

| 項目          | 略     | 号 | 条             | 件          | MIN. | TYP.   | MAX. | 単位 |
|-------------|-------|---|---------------|------------|------|--------|------|----|
| データ保持電源電圧   | VDDDR |   |               |            | 1.6  |        | 5.5  | V  |
| データ保持電源電流   | IDDDR |   | VDDDR = 1.6 V |            |      | 0.1    | 30   | μΑ |
|             |       |   | (サブシステム・クロッ   | ク停止,フィードバッ |      |        |      |    |
|             |       |   | ク抵抗切断時)       |            |      |        |      |    |
| リリース信号セット時間 | tsrel |   |               |            | 0    |        |      | μS |
| 発振安定ウエイト時間  | twait |   | RESETによる解除    |            |      | 217/fx |      | S  |
|             |       |   | 割り込み要求による解    | 除          |      | 注      |      | S  |

注 発振安定時間選択レジスタ(OSTS)のビット0-2(OSTS0-OSTS2)により、2<sup>12</sup>/fx、2<sup>14</sup>/fx、2<sup>15</sup>/fx、2<sup>15</sup>/fx、2<sup>17</sup>/fxの 選択が可能です。

## データ保持タイミング(RESETによるSTOPモード解除)



#### データ保持タイミング(スタンバイ・リリース信号:割り込み要求信号によるSTOPモード解除)



# フラッシュ・メモリ・プログラミング特性: μ PD78F0034BS (Ta = +10~+40 °C, VDD = AVDD = 1.8~5.5 V, Vss = AVss = 0 V)

#### (1)書き込み消去特性

| 項目                                 | 略号               |            | 条           | 件                            | MIN.  | TYP. | MAX.  | 単 位   |
|------------------------------------|------------------|------------|-------------|------------------------------|-------|------|-------|-------|
| 動作周波数                              | fx               | 4.5 V≦VD   | )≦5.5 V     |                              | 1.0   |      | 10.0  | MHz   |
|                                    |                  | 3.0 V≦VD   | <4.5 V      |                              | 1.0   |      | 8.38  | MHz   |
|                                    |                  | 2.7 V≦VDE  | ><3.0 V     |                              | 1.0   |      | 5.00  | MHz   |
|                                    |                  | 1.8 V≦Vɒɒ  | <2.7 V      |                              | 1.0   |      | 1.25  | MHz   |
| Vpp電源電圧                            | V <sub>PP2</sub> | フラッシュ      | ・メモリ・プロク    | ラミング時                        | 9.7   | 10.0 | 10.3  | V     |
| V <sub>DD</sub> 電源電流 <sup>注1</sup> | IDD              | VPP = VPP2 | 10 MHz      | VDD = 5.0 V±10 %             |       |      | 30    | mA    |
|                                    |                  |            | 水晶発振動作モード   |                              |       |      |       |       |
|                                    |                  |            | 8.38 MHz    | V <sub>DD</sub> = 5.0 V±10 % |       |      | 24    | mA    |
|                                    |                  |            | 水晶発振動作モード   | V <sub>DD</sub> = 3.0 V±10 % |       |      | 17    | mA    |
| Vpp電源電流                            | <b>I</b> PP      | VPP = VPP2 |             |                              |       |      | 100   | mA    |
| ステップ消去時間 <sup>注 2</sup>            | Ter              |            |             |                              | 0.199 | 0.2  | 0.201 | s     |
| 総消去時間 <sup>注 3</sup>               | Tera             | ステップ消      | 去時間 = 0.2 s |                              |       |      | 20    | s/チップ |
| ライトバック時間 <sup>注 4</sup>            | Twb              |            |             |                              | 49.4  | 50   | 50.6  | ms    |
| 1 ライトバック・コマンドあたり                   | Cwb              | ライトバッ      | ク時間 = 50 ms |                              |       |      | 60    | 回     |
| のライトバック回数 <sup>注 5</sup>           |                  |            |             |                              |       |      |       |       |
| 消去ーライトバック回数                        | Cerwb            |            |             |                              |       |      | 16    | 回     |
| ステップ書き込み時間 <sup>注 6</sup>          | Twr              |            |             |                              | 48    | 50   | 52    | μs    |
| 1ワードあたりの総書き込み時間 <sup>注7</sup>      | Twrw             | ステップ書      | き込み時間 = 50  | ) <i>μ</i> s設定               | 48    |      | 520   | μs    |
|                                    |                  | (1ワード      | = 1バイト)     |                              |       |      |       |       |
| 1チップあたりの書き換え回数 <sup>注 8</sup>      | Cerwr            | 消去1回十      | 消去後の書き込     | ふ1回                          |       |      | 20    | 回/エリア |
|                                    |                  | = 書き換え     | に回数1回とする    |                              |       |      |       |       |

- 注1. AVDD電流およびポート電流(内蔵プルアップ抵抗に流れる電流)は含まれません。
  - 2. ステップ消去時間の推奨設定値 = 0.2 sです。
  - 3. 消去前のプリライトおよび消去ベリファイ時間(ライトバック時間)は、含まれません。
  - 4. ライトバック時間の推奨設定値 = 50 msです。
  - 5. ライトバック・コマンドの発行により、ライトバックは1回実行されます。したがってリトライ回数設定値は、本値よりコマンド発行回数をマイナスした値としてください。
  - 6. ステップ書き込み時間の推奨設定値 =  $50 \mu s$ です。
  - 7. 実際の1ワードあたりの書き込み時間は、100 $\mu$ sが加算されます。書き込み中および書き込み後の内部ベリファイ時間は含まれません。
  - 8. 出荷品に対する初回書き込み時では、「消去→書き込み」の場合も、「書き込みのみ」の場合も書き換え1回となります。

例 P:書き込み E:消去

出荷品  $\rightarrow P \rightarrow E \rightarrow P \rightarrow E \rightarrow P$ :書き換え回数3回 出荷品 $\rightarrow E \rightarrow P \rightarrow E \rightarrow P \rightarrow E \rightarrow P$ :書き換え回数3回

# (2) シリアル書き込みオペレーション特性

| 項目                                       | 略号               | 条件 | MIN.               | TYP.            | MAX.               | 単位 |
|------------------------------------------|------------------|----|--------------------|-----------------|--------------------|----|
| V <sub>DD</sub> ↑→V <sub>PP</sub> ↑セット時間 | <b>t</b> DP      |    | 10                 |                 |                    | μS |
| V <sub>PP</sub> ↑→RESET↑解除時間             | <b>t</b> PR      |    | 1.0                |                 |                    | μS |
| RESET↑→Vppパルス入力開始時間                      | <b>t</b> RP      |    | 1.0                |                 |                    | μS |
| Vppパルス・ハイ, ロウ・レベル幅                       | tpw              |    | 8.0                |                 |                    | μS |
| RESET↑→Vppパルス入力終了時間                      | <b>t</b> rpe     |    |                    |                 | 20                 | ms |
| Vppパルス・ロウ・レベル入力電圧                        | V <sub>PPL</sub> |    | 0.8V <sub>DD</sub> | V <sub>DD</sub> | 1.2V <sub>DD</sub> | V  |
| Vppパルス・ハイ・レベル入力電圧                        | V <sub>PPH</sub> |    | 9.7                | 10.0            | 10.3               | V  |

# フラッシュ書き込みモード設定タイミング



# 第21章 外形図

# 52ピン・プラスチック LQFP(10x10)外形図(単位:mm)



S52GB-65-8ET-2

# 第22章 半田付け推奨条件

この製品の半田付け実装は、次の推奨条件で実施してください。 なお、推奨条件以外の半田付け方式および半田付け条件については、当社販売員にご相談ください。 半田付け推奨条件の技術的内容については、下記を参照してください。

「半導体デバイス実装マニュアル」(http://www.necel.com/pkg/ja/jissou/index.html)

#### 表22-1 表面実装タイプの半田付け条件(1/2)

(1)  $\mu$ PD780021ASGB- $\times\times$ -8ET :52ピン・プラスチックLQFP(10x10)  $\mu$  PD780022ASGB- $\times\times$  $\mu$  PD780023ASGB- $\times\times$  $\mu$  PD780024ASGB- $\times\times$ -8ET  $\mu$  PD780031ASGB- $\times\times$  $\mu$  PD780032ASGB- $\times\times$ -8ET  $\mu$  PD780033ASGB- $\times$  $\times$ -8ET  $\mu$  PD780034ASGB- $\times\times$  $\mu$  PD780021ASGB(A)- $\times$  $\times$ -8ET  $\mu$  PD780022ASGB(A)- $\times$  $\times$ -8ET  $\mu$  PD780023ASGB(A)- $\times$  $\times$ -8ET  $\mu$  PD780024ASGB(A)- $\times$  $\times$ -8ET  $\mu$  PD780031ASGB(A)- $\times$  $\times$ -8ET  $\mu$  PD780032ASGB(A)- $\times$  $\times$ -8ET  $\mu$  PD780033ASGB(A)- $\times$  $\times$ -8ET  $\mu$  PD780034ASGB(A)- $\times$  $\times$ -8ET

| 半田付け方式      | 半 田 付 け 条 件                               | 推奨条件記号    |
|-------------|-------------------------------------------|-----------|
| 赤外線リフロ      | パッケージ・ピーク温度:235℃,時間:30秒以内(210℃以上),回数:2回以内 | IR35-00-2 |
| VPS         | パッケージ・ピーク温度:215℃,時間:40秒以内(200℃以上),回数:2回以内 | VP15-00-2 |
| ウエーブ・ソルダリング | 半田槽温度:260 ℃以下,時間:10秒以内,回数:1回              | WS60-00-1 |
|             | 予備加熱温度:120 ℃ MAX.(パッケージ表面温度)              |           |
| 端子部分加熱      | 端子温度:300℃以下,時間:3秒以内(デバイスの一辺当たり)           | _         |

注意 半田付け方式の併用はお避けください(ただし、端子部分加熱方式は除く)。

## 表22-1 表面実装タイプの半田付け条件(2/2)

(2) μPD78F0034BSGB-8ET :52ピン・プラスチックLQFP (10x10)

 $\mu$  PD78F0034BSGB(A)-8ET : "

| 半田付け方式      | 半 田 付 け 条 件                                 | 推奨条件記号     |
|-------------|---------------------------------------------|------------|
| 赤外線リフロ      | パッケージ・ピーク温度:235℃,時間:30秒以内(210℃以上),回数:2回以内,  | IR35-107-2 |
|             | 制限日数:7日間 <sup>注</sup> (以降は125℃プリベーク10時間必要)  |            |
|             | 〈留意事項〉                                      |            |
|             | 耐熱トレイ以外(マガジン,テーピング,非耐熱トレイ)は,包装状態でのベーキン      |            |
|             | グができません。                                    |            |
| VPS         | パッケージ・ピーク温度:215℃,時間:40秒以内(200℃以上),回数:2回以内,  | VP15-107-2 |
|             | 制限日数:7日間 <sup>注</sup> (以降は125℃プリベーク10時間必要)  |            |
|             | 〈留意事項〉                                      |            |
|             | 耐熱トレイ以外(マガジン,テーピング,非耐熱トレイ)は,包装状態でのベーキン      |            |
|             | グができません。                                    |            |
| ウエーブ・ソルダリング | 半田槽温度:260℃以下,時間:10秒以内,回数:1回,                | WS60-107-1 |
|             | 予備加熱温度:120 ℃ MAX.(パッケージ表面温度)                |            |
|             | 制限日数:7日間 <sup>注</sup> (以降は125℃プリベーク 10時間必要) |            |
|             | <留意事項>                                      |            |
|             | 耐熱トレイ以外(マガジン,テーピング,非耐熱トレイ)は,包装でのベーキングが      |            |
|             | できません。                                      |            |
| 端子部分加熱      | 端子温度:300℃以下,時間:3秒以内(デバイスの一辺当たり)             | _          |

注 ドライパック開封後の保管日数で、保管条件は25℃,65%RH以下。

注意 半田付け方式の併用はお避けください(ただし,端子部分加熱方式は除く)。

# 付録 A μ PD780024A, 780024AS, 780034A, 780034AS サブシリーズ間の違い

 $\mu$ PD780024A, 780024AS, 780034A, 780034ASサブシリーズ間の主な違いを表A-1に示します。

表 A - 1 μ PD780024A, 780024AS, 780034A, 780034ASサブシリーズ間の主な違い (1/2)

|                       | 製品名                    | μPD780024A                                           | μPD780034A                     | μPD780024AS     | $\mu$ PD780034AS |  |  |
|-----------------------|------------------------|------------------------------------------------------|--------------------------------|-----------------|------------------|--|--|
| 項目                    |                        | サブシリーズ                                               | サブシリーズ                         | サブシリーズ          | サブシリーズ           |  |  |
| ROM容量                 |                        |                                                      | 8 Kバイト/16 Kバイト/24 Kバイト/32 Kバイト |                 |                  |  |  |
| 内部高速R                 | AM容量                   |                                                      | 512バイト/1024バイト                 |                 |                  |  |  |
| フラッシュ                 | ・メモリ製品                 | μPD78                                                | F0034B                         | μPD78F          | F0034BS          |  |  |
| I <sup>2</sup> Cバス内ii | <b>戴製品</b>             | μPD780024AY                                          | μPD780034AY                    | なし              |                  |  |  |
|                       |                        | サブシリーズ                                               | サブシリーズ                         |                 |                  |  |  |
| 最少命令実                 | 2行時間                   | $0.166 \mu\text{s}$ : V <sub>DD</sub> = $4.5\sim5$ . | 5 V                            |                 |                  |  |  |
|                       |                        | $0.238 \mu\text{s}$ : V <sub>DD</sub> = $3.0\sim5$ . | 5 V                            |                 |                  |  |  |
|                       |                        | $0.400 \mu\text{s}$ : V <sub>DD</sub> = $2.7\sim5$ . | 5 V                            |                 |                  |  |  |
|                       |                        | $1.60 \mu\text{s}$ : V <sub>DD</sub> = $1.8\sim5.5$  | V                              |                 |                  |  |  |
| 動作電圧範                 | 5囲                     | 1.8∼5.5 V                                            |                                |                 |                  |  |  |
| I/Oポート数               | <br>数                  | 合計 51本                                               |                                | 合計 39本          |                  |  |  |
|                       |                        | 入力 :8本                                               |                                | 入力 :4本          |                  |  |  |
|                       |                        | 入出力:43本                                              |                                | 入出力:35本         |                  |  |  |
|                       |                        | (5 V耐圧N-chオープ)                                       | レ・ドレーン:4本)                     | √:4本)           |                  |  |  |
| タイマ/カ                 | 1ウンタ                   | 16ビット×1ch                                            |                                |                 |                  |  |  |
|                       |                        | 8 ビット×2ch                                            |                                |                 |                  |  |  |
|                       |                        | 時計用タイマ×1ch                                           |                                |                 |                  |  |  |
|                       |                        | ウォッチドッグタイマX                                          | 1ch                            |                 |                  |  |  |
| シリアル・                 | インタフェース                | 3 線式シリアルI/Oモード×2ch                                   |                                |                 |                  |  |  |
|                       |                        | UARTモード×1ch                                          |                                |                 |                  |  |  |
| A/Dコンバ                | ータ                     | 8ビット×8ch                                             | 10ビット×8ch                      | 8ビットX4ch        | 10ビット×4ch        |  |  |
| 割り込み                  | マスカブル                  | 内部:13本 外部:5本                                         |                                |                 |                  |  |  |
|                       | ノンマスカブル                | 1本                                                   |                                |                 |                  |  |  |
|                       | ソフトウエア                 | 1本                                                   |                                |                 |                  |  |  |
| 外部デバイ                 | ス拡張機能                  | 時分割方式                                                |                                | なし              |                  |  |  |
|                       |                        | F7FFHまで拡張可能                                          |                                |                 |                  |  |  |
| マスク・オ                 | <sup>-</sup> プション      | P30-P33プルアップ抵抗                                       | 指定可能                           | なし              |                  |  |  |
| パッケージ                 | パッケージ ・64ピン・プラスチックSDIP |                                                      | SDIP                           | 52ピン・プラスチックLQFP |                  |  |  |
|                       |                        | ・64ピン・プラスチック                                         | QFP                            |                 |                  |  |  |
|                       |                        | ・64ピン・プラスチック                                         | TQFP                           |                 |                  |  |  |
|                       |                        | ・64ピン・プラスチック                                         | LQFP                           |                 |                  |  |  |
|                       |                        | ・72ピン・プラスチックFBGA                                     |                                |                 |                  |  |  |
| エミュレー                 | -ション・ボード               | IE-780034-NS-EM1                                     |                                |                 |                  |  |  |
|                       |                        |                                                      |                                |                 |                  |  |  |

表 A -1  $\mu$  PD780024A, 780024AS, 780034A, 780034ASサブシリーズ間の主な違い(2/2)

| 製品名           | μPD780024A                            | μPD780034A          | μPD780024AS        | μPD780034AS |
|---------------|---------------------------------------|---------------------|--------------------|-------------|
| 項目            | サブシリーズ                                | サブシリーズ              | サブシリーズ             | サブシリーズ      |
| エミュレーション・プローブ | • NP-64CW                             |                     | NP-H52GB-TQ(TGB-05 | 52SBP)      |
| (変換アダプタ)      | • NP-64GC (EV-9200G                   | iC-64)              | ※エミュレーション・ボ        | ードとプローブを接続す |
|               | NP-64GC-TQ, NP-H64                    | 4GC-TQ (TGC-064SAP) | るために変換ボードが         | 必要になります。    |
|               | • NP-64GK, NP-H64GK                   | -TQ (TGK-064SBW)    |                    |             |
|               | • NP-H64GB-TQ(TGB                     | -064SDP)            |                    |             |
|               | • NP-73F1-CN3 (CSICE73A0909N01,       |                     |                    |             |
|               | LSPACK73A0909N01, CSSOCKET73A0909N01) |                     |                    |             |
| デバイス・ファイル     | DF780024                              | DF780034            | DF780024           | DF780034    |
| フラッシュ・メモリ     | • FA-64CW                             |                     | FA-52GB-8ET        |             |
| 書き込み用アダプタ     | • FA-64GC-8BS-A                       |                     |                    |             |
|               | • FA-64GC                             |                     |                    |             |
|               | • FA-64GK-9ET                         |                     |                    |             |
|               | • FA-64GB-8EU-A                       |                     |                    |             |
|               | • FA-73F1-CN3-A                       |                     |                    |             |

# 付録B 開発ツール

 $\mu$ PD780024AS, 780034ASサブシリーズを使用するシステム開発のために次のような開発ツールを用意しています。 図B-1 に開発ツール構成を示します。

## ●PC98-NXシリーズへの対応について

特に断りのないかぎり、IBM PC/AT™互換機でサポートされている製品については、PC98-NXシリーズでも使用できます。PC98-NXシリーズを使用する場合は、IBM PC/AT互換機の説明を参照してください。

#### ●Windows®について

特に断りのないかぎり、「Windows」は次のOSを示しています。

- Windows 3.1
- · Windows 95
- · Windows 98
- · Windows 2000
- ★ Windows XP
  - · WindowsNT® Ver. 4.0

図B-1 開発ツール構成



- 注1. Cライブラリ・ソース・ファイルは、ソフトウエア・パッケージには含まれていません。
  - 2. プロジェクト・マネージャは、アセンブラ・パッケージに入っています。 また、Windows以外ではプロジェクト・マネージャは使用しません。

# B.1 ソフトウエア・パッケージ

| SP78K0       | 78K/0シリーズ開発用の各種ソフトウエア・ツールを 1 つにパッケージングしたものです。  |
|--------------|------------------------------------------------|
| ソフトウエア・パッケージ | 以下のツールが入っています。                                 |
|              | RA78K0, CC78K0, ID78K0-NS, SM78K0, デバイス・ファイル各種 |
|              | オーダ名称:μS××××SP78K0                             |

備考 オーダ名称のXXXXは、使用するOSにより異なります。



# B.2 言語処理用ソフトウエア

| RA78K0                  | ニモニックで書かれたプログラムをマイコンの実行可能なオブジェクト・コードに変換するプ                   |
|-------------------------|--------------------------------------------------------------|
| アセンブラ・パッケージ             | ログラムです。                                                      |
|                         | このほかに、シンボル・テーブルの生成、分岐命令の最適化処理などを自動的に行う機能を備                   |
|                         | えています。                                                       |
|                         | 別売のデバイス・ファイル(DF780024またはDF780034)と組み合わせて使用します。               |
|                         | <pc環境で使用する場合の注意></pc環境で使用する場合の注意>                            |
|                         | アセンブラ・パッケージはDOSベースのアプリケーションですが、Windows上でプロジェク                |
|                         | ト・マネージャ(アセンブラ・パッケージに含まれています)を使用することにより、Win-                  |
|                         | dows環境でも使用できます。                                              |
|                         | オーダ名称: μS××××RA78K0                                          |
| CC78K0                  | C言語で書かれたプログラムをマイコンの実行可能なオブジェクト・コードに変換するプログ                   |
| Cコンパイラ・パッケージ            | ラムです。                                                        |
|                         | 別売のアセンブラ・パッケージおよびデバイス・ファイルと組み合わせて使用します。                      |
|                         | <pc環境で使用する場合の注意></pc環境で使用する場合の注意>                            |
|                         | Cコンパイラ・パッケージはDOSベースのアプリケーションですが、Windows上でプロジェク               |
|                         | ト・マネージャ(アセンブラ・パッケージに含まれています)を使用することにより、Win-                  |
|                         | dows環境でも使用できます。                                              |
|                         | オーダ名称:μS××××CC78K0                                           |
| DF780024 <sup>注1</sup>  | デバイス固有の情報が入ったファイルです。                                         |
| DF780034 <sup>注1</sup>  | 別売の各ツール(RA78K0, CC78K0, SM78K0, ID78K0-NS, RX78K0)と組み合わせて使用し |
| デバイス・ファイル               | ます。                                                          |
|                         | 対応OS、ホスト・マシンは組み合わされる各ツールに依存します。                              |
|                         | ・DF780024: $\mu$ PD780024, 780024AY, 780024ASサブシリーズ用         |
|                         | ・DF780034: $\mu$ PD780034A, 780034AY, 780034ASサブシリーズ用        |
|                         | オーダ名称:μS××××DF780024, μS××××DF780034                         |
| CC78K0-L <sup>注 2</sup> | Cコンパイラ・パッケージに含まれているオブジェクト・ライブラリを構成する関数のソース・                  |
| Cライブラリ・ソース・             | ファイルです。                                                      |
| ファイル                    | Cコンパイラ・パッケージに含まれているオブジェクト・ライブラリをお客様の仕様にあわせ                   |
|                         | て変更する場合に必要です。                                                |
|                         | ソース・ファイルのため、動作環境はOSに依存しません。                                  |
|                         | オーダ名称:μS××××CC78K0-L                                         |

- 注1. DF780024, DF780034は、RA78K0, CC78K0, SM78K0, ID78K0-NS, RX78K0のすべての製品に共通に使用できます。
  - 2. CC78KO-Lは、ソフトウエア・パッケージ(SP78KO)には含まれていません。

備考 オーダ名称の××××は、使用するホスト・マシン、OSにより異なります。

 $\mu$ SXXXXRA78K0  $\mu$ SXXXXCC78K0

| ×××× | ホスト・マシン        | OS                         | 供給媒体         |
|------|----------------|----------------------------|--------------|
| AB13 | PC-9800シリーズ,   | 日本語Windows                 | 3.5インチ2HD FD |
| BB13 | IBM PC/AT互換機   | 英語Windows                  |              |
| AB17 |                | 日本語Windows                 | CD-ROM       |
| BB17 |                | 英語Windows                  |              |
| 3P17 | HP9000シリーズ700™ | HP-UX™ (Rel.10.10)         |              |
| 3K17 | SPARCstation™  | SunOS™ (Rel. 4 . 1 . 4 ) , |              |
|      |                | Solaris™ (Rel. 2 . 5 . 1 ) |              |

| ×××× | ホスト・マシン       | OS                        | 供給媒体         |
|------|---------------|---------------------------|--------------|
| AB13 | PC-9800シリーズ,  | 日本語Windows                | 3.5インチ2HD FD |
| BB13 | IBM PC/AT互換機  | 英語Windows                 |              |
| 3P16 | HP9000シリーズ700 | HP-UX (Rel.10.10)         | DAT          |
| 3K13 | SPARCstation  | SunOS (Rel. 4 . 1 . 4 ) , | 3.5インチ2HD FD |
| 3K15 |               | Solaris (Rel. 2.5.1)      | 1/4インチCGMT   |

# B.3 制御ソフトウエア

| プロジェクト・マネージャ | Windows環境で効率よくユーザ・プログラム開発できるように作られた制御ソフトウエア |
|--------------|---------------------------------------------|
|              | です。プロジェクト・マネージャ上から,エディタの起動,ビルド,ディバッガの起動な    |
|              | ど、ユーザ・プログラム開発の一連の作業を行うことができます。              |
|              | <注意>                                        |
|              | プロジェクト・マネージャはアセンブラ・パッケージ(RA78KO)の中に入っています。  |
|              | Windows以外の環境では使用できません。                      |

# B.4 フラッシュ・メモリ書き込み用ツール

| Flashpro III (型番 FL-PR3, PG-FP3) | フラッシュ・メモリ内蔵マイコン専用のフラッシュ・ライタです。                              |
|----------------------------------|-------------------------------------------------------------|
| Flashpro IV (型番 FL-PR4, PG-FP4)  |                                                             |
| フラッシュ・ライタ                        |                                                             |
| FA-52GB-8ET                      | フラッシュ・メモリ書き込み用アダプタです。Flashpro III , Flashpro IV に接続して使用します。 |
| フラッシュ・メモリ書き込み用アダプタ               | ・FA-52GB-8ET :52ピン・プラスチックLQFP(GB-8ETタイプ)用                   |

備考 FL-PR3, FL-PR4, FA-52GB-8ETは, 株式会社内藤電誠町田製作所の製品です。

問い合わせ先:株式会社内藤電誠町田製作所(TEL(045)475-4191)

# B.5 ディバグ用ツール (ハードウエア)

| IE-78K0-NS        |            | 78K/0シリーズを使用する応用システムを開発する際に、ハードウエア、ソフトウエアを         |
|-------------------|------------|----------------------------------------------------|
| インサーキット・エミュレータ    |            | ディバグするためのインサーキット・エミュレータです。統合ディバッガ(ID78K0-NS)       |
|                   |            | に対応しています。電源ユニット、エミュレーション・プローブおよび、ホスト・マシンと          |
|                   |            | 接続するためのインタフェース・アダプタと組み合わせて使用します。                   |
| IE-78K0-NS-PA     |            | IE-78K0-NSの機能を拡張するためのボードです。IE-78K0-NSに接続して使用します。この |
| パフォーマンス・ボード       |            | ボードを追加することにより、カバレッジ機能が追加され、トレーサ機能、タイマ機能が強          |
|                   |            | 化されるなど、ディバグ機能がより強化されます。                            |
| IE-78K0-NS-A      |            | IE-78K0-NSとIE-78K0-NS-PAを組み合わせたもの                  |
| インサーキット・エミュレータ    |            |                                                    |
| IE-70000-MC-PS-B  |            | AC100~240 Vのコンセントから電源を供給するためのアダプタです。               |
| 電源ユニット            |            |                                                    |
| IE-70000-98-IF-C  |            | ホスト・マシンとしてPC-9800シリーズ(ノート型パソコンを除く)を使用するときに必要       |
| インタフェース・アダプタ      |            | なアダプタです(Cバス対応)。                                    |
| IE-70000-CD-IF-A  |            | ホスト・マシンとしてのノート型パソコンを使用するときに必要なPCカードとインタ            |
| PCカード・インタフェース     |            | フェース・ケーブルです(PCMCIAソケット対応)。                         |
| IE-70000-PC-IF-C  |            | ホスト・マシンとしてIBM PC/AT互換機を使用するときに必要なアダプタです(ISAバス対     |
| インタフェース・アダプタ      |            | 応)。                                                |
| IE-70000-PCI-IF-A |            | ホスト・マシンとしてPCIバスを内蔵したパソコンを使用するときに必要なアダプタです。         |
| インタフェース・アダプタ      |            |                                                    |
| IE-780034-NS-EM1  |            | デバイスに固有な周辺ハードウエアをエミュレーションするためのボードです。インサー           |
| エミュレーション・ボ-       | - <b>ド</b> | キット・エミュレータと組み合わせて使用します。                            |
| 780034AS 52F      | in Board   | エミュレーション・ボードとエミュレーション・プローブを接続するための変換ボードで           |
| 変換ボード             |            | す。                                                 |
| NP-H52GB-TQ       |            | インサーキット・エミュレータとターゲット・システムを接続するためのプローブです。           |
| エミュレーション・プローブ     |            | 52ピン・プラスチックLQFP(GB-8ETタイプ)用です。                     |
| TGB-052SBP        |            | 52ピン・プラスチックLQFP(GB-8ETタイプ)を実装できるように作られたターゲット・      |
| 変換アダプタ            |            | システムの基板と、NP-H52GB-TQを接続するための変換アダプタです。              |
| ALL de            |            |                                                    |

備考1. NP-H52GB-TQは、株式会社内藤電誠町田製作所の製品です。

問い合わせ先:株式会社内藤電誠町田製作所(TEL(045)475-4191)

2. TGB-052SBPは、東京エレテック株式会社の製品です。

問い合わせ先:大丸興業株式会社 東京電子部 (TEL (03) 3820-7112)

大阪電子部(TEL(06)6244-6672)

**3.** TGB-052SBPは、1個単位で販売しています。

# B.6 ディバグ用ツール (ソフトウエア)

| SM78K0                   | 78K/0シリーズ用のシステム・シミュレータです。SM78K0は、Windowsベースのソフトウ |
|--------------------------|--------------------------------------------------|
| システム・シミュレータ              | エアです。                                            |
|                          | ホスト・マシン上でターゲット・システムの動作をシミュレーションしながら,Cソース・        |
|                          | レベルまたはアセンブラ・レベルでのディバグが可能です。                      |
|                          | SM78K0を使用することにより,アプリケーションの論理検証,性能検証をハードウエア開      |
|                          | 発から独立して行えます。したがって、開発効率やソフトウエア品質の向上が図れます。         |
|                          | 別売のデバイス・ファイル(DF780024またはDF780034)と組み合わせて使用します。   |
|                          | オーダ名称:μS××××SM78K0                               |
| ID78K0-NS                | 78K/0シリーズ用のインサーキット・エミュレータに対応したディバッガです。ID78K0-NS  |
| 統合ディバッガ                  | は、Windowsベースのソフトウエアです。                           |
| (インサーキット・エミュレータIE-       | C言語対応のディバグ機能を強化しており、ソース・プログラムや逆アセンブル表示、メモ        |
| 78K0-NS, IE-78K0-NS-A対応) | リ表示をトレース結果に連動させるウインドウ統合機能を使用することにより,トレース結        |
|                          | 果をソース・プログラムと対応させて表示することもできます。                    |
|                          | 別売のデバイス・ファイルと組み合わせて使用します。                        |
|                          |                                                  |
|                          | オーダ名称:μS××××ID78K0-NS                            |

備考 オーダ名称の××××は、使用するホスト・マシン、OSにより異なります。

 $\begin{array}{l} \mu\,\mathrm{S} \times \times \times \times \mathrm{SM78K0} \\ \mu\,\mathrm{S} \underline{\times \times \times} \mathrm{ID78K0\text{-}NS} \end{array}$ 

| ×××× | ホスト・マシン      | OS         | 供給媒体         |
|------|--------------|------------|--------------|
| AB13 | PC-9800シリーズ, | 日本語Windows | 3.5インチ2HD FD |
| BB13 | IBM PC/AT互換機 | 英語Windows  |              |
| AB17 |              | 日本語Windows | CD-ROM       |
| BB17 |              | 英語Windows  |              |

## B.7 組み込み用ソフトウエア

| RX78K0   | μITRON仕様に準拠したリアルタイムOSです。                          |
|----------|---------------------------------------------------|
| リアルタイムOS | RX78K0のニュークリアスと複数の情報テーブルを作成するためのツール(コンフィギュレータ)    |
|          | を添付しています。                                         |
|          | 別売のアセンブラ・パッケージ(RA78K0)およびデバイス・ファイル(DF780024または    |
|          | DF780034)と組み合わせて使用します。                            |
|          | <pc環境で使用する場合の注意></pc環境で使用する場合の注意>                 |
|          | リアルタイムOSはDOSベースのアプリケーションです。Windows上ではDOSプロンプトで使用し |
|          | てください。                                            |
|          | オーダ名称:μS××××RX78013-△△△                           |

注意 RX78K0を購入する際,事前に購入申込書にご記入のうえ,使用許諾契約書を締結してください。

備考 オーダ名称の××××および△△△は、使用するホスト・マシン、OSなどにより異なります。

| $\mu$ S $\times \times$ | XXRX78013- <u>△</u> ∠ |      |              |           |                     |              |  |
|-------------------------|-----------------------|------|--------------|-----------|---------------------|--------------|--|
|                         |                       |      |              | 製品概要      | 量産時使用数量の上限          |              |  |
|                         |                       |      | 001          | 評価用オブジェクト | 量産品には使用しないでください。    |              |  |
|                         |                       |      | 100K         | 量産用オブジェクト | 10万個                |              |  |
|                         |                       |      | 001M         |           | 100万個               |              |  |
|                         |                       |      | 010M         |           | 1000万個              |              |  |
|                         |                       |      | S01          | ソース・プログラム | 量産用オブジェクトのソース・プログラム |              |  |
|                         |                       |      |              |           |                     |              |  |
|                         |                       | ×××× | ホスト・マシン      |           | OS                  | 供給媒体         |  |
|                         |                       | AA13 | PC-9800シリーズ  |           | 日本語Windows          | 3.5インチ2HD FD |  |
|                         |                       | AB13 | IBM PC/AT互換機 |           | 日本語Windows          |              |  |
|                         |                       | BB13 |              |           | 英語Windows           |              |  |

## 付録C ターゲット・システム設計上の注意

エミュレーション・プローブと変換アダプタとの接続条件図を次に示します。ターゲット・システム上に実装する 部品の形状などを考慮したうえで、この構成によってシステム設計を行ってください。

なお、この付録に記載されているエミュレーション・プローブはすべて株式会社内藤電誠町田製作所の製品です。 また、この付録に記載されている変換アダプタはすべて東京エレテック株式会社の製品です。

表C-1 IEシステムから変換アダプタまでの距離

| エミュレーション・プローブ | 変換アダプタ     | IEシステムから    |  |
|---------------|------------|-------------|--|
|               |            | 変換アダプタまでの距離 |  |
| NP-H52GB-TQ   | TGB-052SBP | 370 mm      |  |

#### 図C-1 インサーキット・エミュレータから変換アダプタまでの距離(NP-H52GB-TQの場合)

Tミュレーション・ボード
IE-780034-NS-EM1

CN2

Tミュレーション・プローブ
NP-H52GB-TQ

TGB-052SBP

図C-2 ターゲット・システムの接続条件 (NP-H52GB-TQの場合)

780034AS 52pin Board



## 付録D レジスタ索引

### D.1 レジスタ索引(50音順)

#### [あ行]

アシンクロナス・シリアル・インタフェース・ステータス・レジスタ 0 (ASISO) … 228 アシンクロナス・シリアル・インタフェース・モード・レジスタ 0 (ASIMO) … 229 アナログ入力チャネル指定レジスタ 0 (ADSO) … 187, 209 ウォッチドッグ・タイマ・クロック選択レジスタ (WDCS) … 172 ウォッチドッグ・タイマ・モード・レジスタ (WDTM) … 173 A/Dコンバータ・モード・レジスタ 0 (ADMO) … 185, 207 A/D変換結果レジスタ 0 (ADCRO) … 183, 205

#### [か行]

外部割り込み立ち上がりエッジ許可レジスタ (EGP) … 273 外部割り込み立ち下がりエッジ許可レジスタ (EGN) … 273 キャプチャ/コンペア・コントロール・レジスタ0 (CRC0) … 112 クロック出力選択レジスタ (CKS) … 177

#### [さ行]

16ビット・タイマ・カウンタ 0 (TMO) … 108
16ビット・タイマ・キャプチャ/コンペア・レジスタ00 (CR00) … 108
16ビット・タイマ・キャプチャ/コンペア・レジスタ01 (CR01) … 109
16ビット・タイマ出力コントロール・レジスタ 0 (TOC0) … 113
16ビット・タイマ・モード・コントロール・レジスタ 0 (TMC0) … 110
受信シフト・レジスタ 0 (RX0) … 227
受信バッファ・レジスタ 0 (RXB0) … 228
シリアルI/Oシフト・レジスタ30 (SIO30) … 254
シリアルI/Oシフト・レジスタ31 (SIO31) … 254
シリアル動作モード・レジスタ31 (CSIM30) … 254
シリアル動作モード・レジスタ31 (CSIM31) … 254
送信シフト・レジスタ 0 (TXS0) … 227

#### [た行]

タイマ・クロック選択レジスタ50(TCL50) ··· 146 タイマ・クロック選択レジスタ51(TCL51) ··· 146 時計用タイマ動作モード・レジスタ(WTM) ··· 168

#### [は行]

8 ビット・タイマ・カウンタ50 (TM50) … 144 8 ビット・タイマ・カウンタ51 (TM51) … 144

```
8ビット・タイマ・コンペア・レジスタ50 (CR50) ··· 145
8ビット・タイマ・コンペア・レジスタ51 (CR51) … 145
8ビット・タイマ・モード・コントロール・レジスタ50 (TMC50) … 147
8ビット・タイマ・モード・コントロール・レジスタ51 (TMC51) ··· 147
発振安定時間選択レジスタ (OSTS) … 95,287
プリスケーラ・モード・レジスタ 0 (PRM0) … 114
プルアップ抵抗オプション・レジスタ 0 (PU0) ··· 89
プルアップ抵抗オプション・レジスタ 2 (PU2) ··· 89
プルアップ抵抗オプション・レジスタ3 (PU3) ··· 89
プルアップ抵抗オプション・レジスタ 4 (PU4) … 89
プルアップ抵抗オプション・レジスタ5 (PU5) ··· 89
プルアップ抵抗オプション・レジスタ7 (PU7) ··· 89
プログラム・ステータス・ワード (PSW) ··· 50, 274
プロセッサ・クロック・コントロール・レジスタ (PCC) ··· 93
ポート0 (P0) … 72
ポート1 (P1) … 74
ポート2 (P2) … 75
ポート3 (P3) · · · 78
ポート4 (P4) ··· 81
ポート5 (P5) … 82
ポート7 (P7) … 83
ポート・モード・レジスタ 0 (PM0) … 86
ポート・モード・レジスタ 2 (PM2) ··· 86, 232, 257
ポート・モード・レジスタ3 (PM3) … 86,257
ポート・モード・レジスタ4 (PM4) … 86
ポート・モード・レジスタ5 (PM5) … 86
ポート・モード・レジスタ7 (PM7) … 86, 115, 150, 179
ボー・レート・ジェネレータ・コントロール・レジスタ 0 (BRGC0) … 230
```

#### [ま行]

メモリ拡張モード・レジスタ(MEM) ··· 273 メモリ・サイズ切り替えレジスタ(IMS) ··· 299

#### [や行]

優先順位指定フラグ・レジスタ0H (PR0H) … 272優先順位指定フラグ・レジスタ0L (PR0L) … 272優先順位指定フラグ・レジスタ1L (PR1L) … 272

#### [わ行]

割り込みマスク・フラグ・レジスタ0H (MK0H) … 271 割り込みマスク・フラグ・レジスタ0L (MK0L) … 271 割り込みマスク・フラグ・レジスタ1L (MK1L) … 271 割り込み要求フラグ・レジスタ0H (IF0H) … 269 割り込み要求フラグ・レジスタOL (IFOL) … 269

割り込み要求フラグ・レジスタ1L (IF1L) … 269

### D.2 レジスタ索引 (アルファベット順)

[ A ]

ADCRO : A/D変換結果レジスタ0 … 183, 205

ADMO : A/Dコンバータ・モード・レジスタ 0 … 185, 207 ADSO : アナログ入力チャネル指定レジスタ 0 … 187, 209

ASIMO : アシンクロナス・シリアル・インタフェース・モード・レジスタ 0 … 229

ASISO : アシンクロナス・シリアル・インタフェース・ステータス・レジスタ 0 … 228

[B]

BRGC0 :ボー・レート・ジェネレータ・コントロール・レジスタ 0 … 230

[C]

CKS : クロック出力選択レジスタ … 177

CR00 : 16ビット・タイマ・キャプチャ/コンペア・レジスタ00 … 108 CR01 : 16ビット・タイマ・キャプチャ/コンペア・レジスタ01 … 109

CR50 : 8 ビット・タイマ・コンペア・レジスタ50 … 145CR51 : 8 ビット・タイマ・コンペア・レジスタ51 … 145

CRC0 : キャプチャ/コンペア・コントロール・レジスタ 0 … 112

CSIM30 : シリアル動作モード・レジスタ30 … 254 CSIM31 : シリアル動作モード・レジスタ31 … 254

[E]

EGN : 外部割り込み立ち下がりエッジ許可レジスタ … 273EGP : 外部割り込み立ち上がりエッジ許可レジスタ … 273

[1]

IFOH:割り込み要求フラグ・レジスタ0H… 269IFOL:割り込み要求フラグ・レジスタ0L… 269IF1L:割り込み要求フラグ・レジスタ1L… 269IMS:メモリ・サイズ切り替えレジスタ… 299

[M]

MEM :メモリ拡張モード・レジスタ … 273

MK0H :割り込みマスク・フラグ・レジスタ0H … 271MK0L :割り込みマスク・フラグ・レジスタ0L … 271MK1L :割り込みマスク・フラグ・レジスタ1L … 271

[0]

OSTS : 発振安定時間選択レジスタ ··· 95, 287

[P]

P0 :ポート0 … 72

P1

:ポート1 … 74

```
P2
       :ポート2 … 75
P3
       :ポート3 … 78
P4
       :ポート4 … 81
P5
       :ポート5 … 82
P7
       :ポート7 … 83
PCC
       :プロセッサ・クロック・コントロール・レジスタ … 93
PM<sub>0</sub>
       :ポート・モード・レジスタ 0 … 86
PM2
       :ポート・モード・レジスタ2 … 86,232,257
PM3
       :ポート・モード・レジスタ3 … 86,257
       :ポート・モード・レジスタ4 … 86
PM4
       :ポート・モード・レジスタ5 … 86
PM5
       :ポート・モード・レジスタ7 … 86, 115, 150, 179
PM7
PR0H
       :優先順位指定フラグ・レジスタ0H … 272
PR<sub>0</sub>L
       :優先順位指定フラグ・レジスタOL … 272
PR1L
       :優先順位指定フラグ・レジスタ1L … 272
PRM<sub>0</sub>
       :プリスケーラ・モード・レジスタ0 … 114
PSW
       :プログラム・ステータス・ワード … 50,274
PU0
       :プルアップ抵抗オプション・レジスタ0 … 89
       :プルアップ抵抗オプション・レジスタ2
PU<sub>2</sub>
                                ... 89
       :プルアップ抵抗オプション・レジスタ3 … 89
PU3
PU4
       :プルアップ抵抗オプション・レジスタ4
                                ... 89
PU5
       :プルアップ抵抗オプション・レジスタ5 … 89
PU7
       :プルアップ抵抗オプション・レジスタ7 … 89
[R]
RXB0
       :受信バッファ・レジスタ 0 … 228
RX0
       :受信シフト・レジスタ 0 … 227
[S]
       :シリアルI/Oシフト・レジスタ30 ··· 254
SIO<sub>30</sub>
SIO31
       :シリアルI/Oシフト・レジスタ31 ··· 254
[T]
TCL50
       :タイマ・クロック選択レジスタ50 … 146
TCL51
       :タイマ・クロック選択レジスタ51 … 146
       :16ビット・タイマ・カウンタ 0 … 108
TM0
       :8ビット・タイマ・カウンタ50 … 144
TM50
TM51
       :8ビット・タイマ・カウンタ51 … 144
TMC0
       :16ビット・タイマ・モード・コントロール・レジスタ 0 … 110
TMC50
       :8ビット・タイマ・モード・コントロール・レジスタ50 … 147
TMC51
       :8ビット・タイマ・モード・コントロール・レジスタ51 … 147
TOC0
       :16ビット・タイマ出力コントロール・レジスタ 0 … 113
```

TXSO :送信シフト・レジスタ 0 … 227

[W]

WDCS : ウォッチドッグ・タイマ・クロック選択レジスタ … 172

WDTM : ウォッチドッグ・タイマ・モード・レジスタ … 173

WTM :時計用タイマ動作モード・レジスタ … 168

# 付録E 改版履歴

# E.1 本版で改訂された主な箇所

| 箇 所                       | 内容                                                                                                 |
|---------------------------|----------------------------------------------------------------------------------------------------|
|                           |                                                                                                    |
| p.104                     | 表 5 - 3 CPU クロックの切り替えに要する最大時間を修正                                                                   |
| pp.302, 303               | 図18-4 専用フラッシュ・ライタとの接続例の旧版の注を注1と注2に分け、内容を変更                                                         |
| p.306                     | 18.2.3 オンボード上の端子処理の<電源>に専用フラッシュ・ライタの電圧監視の説明を追加                                                     |
| •                         | 16.2.3                                                                                             |
| p.17                      | 第1章 概 説                                                                                            |
| μ. 17                     | ・1.2 応用分野の記述を変更                                                                                    |
| p.28                      | 第2章 端子機能                                                                                           |
| μ.20                      | ・2.1 端子機能一覧(2)ポート以外の端子のAVREFのリセット時を変更                                                              |
| p.55                      | 第3章 CPUアーキテクチャ                                                                                     |
| p.55                      | ・3.2.3 特殊機能レジスタ(SFR:Special Function Register)の記述を変更                                               |
| n 06                      | 第4章 ポート機能                                                                                          |
| p.86                      | ・4.3 ポート機能を制御するレジスタの注意2の記述を変更                                                                      |
| n 170                     |                                                                                                    |
| p.170                     | 第8章 時計用タイマ<br>・図8-3 時計用タイマ/インターバル・タイマの動作タイミングの注意の記述を変更                                             |
| nn 100 100                |                                                                                                    |
| pp.192, 193,              | 第11章 8ビットA/Dコンバータ(μPD780024ASサブシリーズ)                                                               |
| 198, 199,                 | ・図11ー 6 ハードウエア・スタートによるA/D変換動作(立ち下がりエッジ指定時)を修正<br>・図11ー 7 ソフトウエア・スタートによるA/D変換動作を修正                  |
| 202                       |                                                                                                    |
|                           | ・図11-15 A/D変換終了割り込み要求発生タイミングを修正<br> <br> ・11.6 A/Dコンバータの注意事項(9)A/D変換結果が不定になるタイミングの記述を変更、旧版の図11-17を |
|                           | ・II.0 A/Dコンハータの注息争項(9)A/D変換結果が小定になるタイミングの記述を変更、旧版の図IIーI7を<br>削除                                    |
|                           | ・表 <b>11</b> -3 等価回路の各抵抗と容量値(参考値)のC1の値を変更                                                          |
| nn 014 015                |                                                                                                    |
| pp.214, 215,<br>220, 221, | 第12章 10ビットA/Dコンバータ( μ PD780034ASサブシリーズ)<br> <br> ・図12-7 ハードウエア・スタートによるA/D変換動作(立ち下がりエッジ指定時)を修正      |
| 220, 221,                 | ・図12-8 ソフトウエア・スタートによるA/D変換動作を修正                                                                    |
| 224                       | ・図12-16 A/D変換終了割り込み要求発生タイミングを修正                                                                    |
|                           | ・12.6 A/Dコンバータの注意事項(9)A/D変換結果が不定になるタイミングの記述を変更、旧版の図12-18を                                          |
|                           | 削除                                                                                                 |
|                           | ・表12-3 等価回路の各抵抗と容量値(参考値)のC1の値を変更                                                                   |
| nn 265, 270               | 第15章 割り込み機能                                                                                        |
| pp.265, 270,<br>275, 278  |                                                                                                    |
| 2/5, 2/6                  | ・表15-1 割り込み要因一覧の記述を修正                                                                              |
|                           | ・図15-2 割り込み要求フラグ・レジスタ(IFOL, IFOH, IF1L)のフォーマットの注意 5 を変更                                            |
|                           | ・15.4.1 ノンマスカブル割り込み要求の受け付け動作の記述を変更                                                                 |
| - 001                     | ・15.4.2 マスカブル割り込み要求の受け付け動作の記述を変更                                                                   |
| p.301                     | 第18章 μPD78F0034BS                                                                                  |
| nn 014 000                | ・表18-3 通信方式一覧の記述を修正                                                                                |
| pp.314, 320               | 第19章 命令セットの概要                                                                                      |
|                           | ・19.1.2 オペレーション欄の説明のNMISの説明を削除                                                                     |
| 005 000                   | ・19.2 オペレーション一覧のコール・リターンのRETIのオペレーション欄を変更                                                          |
| pp.335, 336,              | 第20章 電気的特性                                                                                         |
| 345                       | ・DC特性(T <sub>A</sub> = −40~+85 °C, V <sub>DD</sub> = 1.8~5.5 V)の電源電流のlopsの記述を修正                    |
| 05/                       | ・アナログ入力端子の入力インピーダンスの〔パラメータ値〕のC1の値を変更                                                               |
| p.354                     | 付録B  開発ツール                                                                                         |
|                           | ・WindowsについてにWindows XPを追加                                                                         |

# E.2 前版までの改版履歴

前版までの改版履歴を次に示します。なお、適用箇所は各版での章を示します。

(1/3)

| 版数    | 前版からの改版内容                                                           |      | 適用箇所          |
|-------|---------------------------------------------------------------------|------|---------------|
| 第2版   | ・次の製品を対象製品に追加                                                       | 全般   |               |
|       | μPD780021AS(A), 780022AS(A), 780023AS(A), 780024AS(A), 780031AS(A), |      |               |
|       | 780032AS(A), 780033AS(A), 780034AS(A), 78F0034BS(A)                 |      |               |
|       | ・すべての対象製品が開発中→開発済み                                                  |      |               |
|       | ・1.4 品質水準 追加                                                        | 第1章  | 概 説           |
|       | ・1.6 78K/0シリーズの展開 更新                                                |      |               |
|       | ・1.9 標準水準品と特別水準品との違いについて 追加                                         |      |               |
| ,     | 18.2 フラッシュ・メモリ・プログラミング 記述追加                                         | 第18章 | μ PD78F0034BS |
| ,     | 章を追加                                                                | 第20章 | 電気的特性         |
| ,     | 章を追加                                                                | 第21章 | 外形図           |
| ,     | 章を追加                                                                | 第22章 | 半田付け推奨条件      |
|       | B.2 フラッシュ・メモリ書き込み用ツール 記述追加                                          | 付録B  | 開発ツール         |
|       | 章を追加                                                                | 付録E  | 改版履歴          |
| 第 3 版 | 拡張規格(12 MHz)に関する記述を追加                                               | 全般   |               |
|       | 1.6 78K/0シリーズの展開を更新                                                 | 第1章  | 概 説           |
|       | 2.2.16 VPP(フラッシュ・メモリ製品のみ)に端子処理についての記述を追加                            | 第2章  | 端子機能          |
|       | 表2-1 各端子の入出力回路タイプの記述を変更                                             |      |               |
|       | 3.1.2 内部データ・メモリ空間にプログラム領域についての説明文を追加                                | 第3章  | CPUアーキテクチャ    |
|       | 図3-14 スタック・メモリへ退避されるデータ、図3-15 スタック・メモリか                             |      |               |
|       | ら復帰されるデータを変更                                                        |      |               |
|       | 3.4.4 ショート・ダイレクト・アドレシングの【記述例】を変更                                    |      |               |
|       | 3.4.7 ベースト・アドレシング、3.4.8 ベースト・インデクスト・アドレシ                            |      |               |
|       | ング, 3.4.9 スタック・アドレシングに【図解】を追加                                       |      |               |
|       | ポートのブロック図(図 4 - 2 ~ 図 4 - 12)を修正                                    | 第4章  | ポート機能         |
|       | 表4-3 兼用機能使用時のポート・モード・レジスタ,出力ラッチの設定を追加                               |      |               |
|       | 5.3 クロック発生回路を制御するレジスタに内蔵フィードバック抵抗の説明と発                              | 第5章  | クロック発生回路      |
|       | 振安定時間選択レジスタ(OSTS)を追加                                                |      |               |
|       | 図 6 - 1 16ビット・タイマ/イベント・カウンタ 0 のブロック図を変更                             | 第6章  | 16ビット・タイマ/    |
|       | 旧版の表 6 - 2 TI00/TO0/P70端子の有効エッジとCR00, CR01のキャプチャ・                   | イベンI | ・カウンタ 0       |
|       | トリガ、表 6 一 3 TI01/P71端子の有効エッジとCR00のキャプチャ・トリガを、                       |      |               |
|       | 表 6 - 2 CR00のキャプチャ・トリガとTI00端子とTI01端子の有効エッジ,表 6                      |      |               |
|       | - 3 CR01のキャプチャ・トリガとTI00端子の有効エッジ(CRC02 = 1)に変更                       |      |               |
|       | 6.4 16ビット・タイマ/イベント・カウンタ 0 の動作の各機能の説明の順番を変                           |      |               |
|       | 更                                                                   |      |               |
|       | 図 6 - 26 PPG出力の構成図、図 6 - 27 PPG出力動作のタイミングを追加                        |      |               |
|       | 6.5 プログラム・リストを追加                                                    |      |               |
|       | 6.6 (3) キャプチャ・レジスタのデータ保持タイミングを変更, (11) STOP                         |      |               |
|       | モードまたはメイン・システム・クロック停止モードの設定についてを追加                                  |      |               |
|       | 図7-1 8ビット・タイマ/イベント・カウンタ50のブロック図、図7-2 8                              | 第7章  | 8ビット・タイマ/     |
|       | ビット・タイマ/イベント・カウンタ51のブロック図を変更                                        | イベンI | ト・カウンタ50, 51  |

(2/3)

| 版 数  | 前版からの改版内容                                               | 適用箇所                             |
|------|---------------------------------------------------------|----------------------------------|
| 第3版  | III版の図7-5 8ビット・タイマ・モード・コントロール・レジスタ5n                    |                                  |
| ≥ NX | (TMC5n) のフォーマットの注意を削除                                   | 第7章 8 ピット・メイマン<br>イベント・カウンタ50,51 |
|      | 7.4.2 外部イベント・カウンタとしての動作にレジスタの設定方法を追加                    | 1 12 1 27 250,01                 |
|      | 7.4.2 <b>今日                                   </b>      |                                  |
|      | 7.4.3                                                   |                                  |
|      | 7.4.4 8ビットPWM出力としての動作の【設定方法】に周期とデューティ比に                 |                                  |
|      | 7.4.4 0 こうドー・マング 10 10 10 10 10 10 10 10 10 10 10 10 10 |                                  |
|      | 7.5 プログラム・リストを追加                                        |                                  |
|      | 旧版の 7.5 (2) タイマ・カウント動作中のコンペア・レジスタの変更後の動作を               |                                  |
|      | 削除                                                      |                                  |
|      | 旧版の 9.3 ウォッチドッグ・タイマを制御するレジスタから、発振安定時間選択                 | 第9章 ウォッチドッグ・4                    |
|      | レジスタ(OSTS)を削除                                           | イマ                               |
|      | 図10-1 クロック出力/ブザー出力制御回路のブロック図を変更                         | 第10章 クロック出力/ご                    |
|      |                                                         | ザー出力制御回路                         |
|      | 11.2 (3) サンプル&ホールド回路, 11.2 (4) 電圧コンパレータの説明文を修           |                                  |
|      | 正, 11.2 (10) ADTRG端子を追加                                 | バータ(μPD780024ASサフ                |
|      | 表11-2 A/Dコンバータのサンプリング時間とA/D変換開始遅延時間を追加                  | シリーズ)                            |
|      | 旧版の11.6 (4) ノイズ対策についてを削除(削除内容については、図11-19               |                                  |
|      | AVREF端子とコンデンサの接続例と図11-21 信号源インピーダンスが高い場合の               |                                  |
|      | 回路例に追加)                                                 |                                  |
|      | 図12-2 A/D変換結果レジスタ 0 (ADCRO) のフォーマットを追加                  | 第12章 10ビットA/Dコン                  |
|      | 12.2 (3) サンプル&ホールド回路, 12.2 (4) 電圧コンパレータの説明文を修           | ・<br>バータ(μPD780034ASサ:           |
|      | 正、12.2(10)ADTRG端子を追加                                    | シリーズ)                            |
|      | 表12-2 A/Dコンバータのサンプリング時間とA/D変換開始遅延時間を追加                  |                                  |
|      | 旧版の12.6 (4) ノイズ対策についてを削除(削除内容については, 図12-20              |                                  |
|      | AVREF端子とコンデンサの接続例と図12-22 信号源インピーダンスが高い場合の               |                                  |
|      | 回路例に追加)                                                 |                                  |
|      | 図13-1 シリアル・インタフェースUART0のブロック図を追加                        | 第13章 シリアル・イン:                    |
|      | アシンクロナス・シリアル・インタフェース・ステータス・レジスタ 0 (ASISO                | フェースUART0                        |
|      | の説明を13.3 シリアル・インタフェースUARTOを制御するレジスタから13.2               |                                  |
|      | シリアル・インタフェースUARTOの構成に移動                                 |                                  |
|      | 図13-7 サンプリング誤差を考慮したボー・レートの許容誤差(k = 0の場合)                |                                  |
|      | に注意を追加                                                  |                                  |
|      | 図13-10 アシンクロナス・シリアル・インタフェース受信完了割り込み要求タイ                 |                                  |
|      | ミングの注意を変更                                               |                                  |
|      | 13.4.3 赤外線データ転送モードに(1)使用するレジスタと(3)メイン・シ                 |                                  |
|      | ステム・クロックとボー・レートの関係を追加                                   |                                  |
|      | 表13-6 レジスタの設定一覧を追加                                      |                                  |
|      | 図14-1 シリアル・インタフェースSIO3nのブロック図を変更                        | 第14章 シリアル・イング                    |
|      | 図14-2 シリアル動作モード・レジスタ30 (CSIM30) のフォーマット、図14-            | フェースSIO30, SIO31                 |
|      | 3 シリアル動作モード・レジスタ31 (CSIM31) のフォーマットに注 1,3 と注意           |                                  |
|      | を追加                                                     |                                  |
|      | 表14-2 レジスタの設定一覧を追加                                      |                                  |
|      | 図15-1 割り込み機能の基本構成の(E)ソフトウエア割り込みを修正                      | 第15章 割り込み機能                      |
|      | 図15-2 割り込み要求フラグ・レジスタ(IFOL, IFOH, IF1L)のフォーマットに          |                                  |
|      | 注意 5 を追加                                                |                                  |

(3/3)

| 版   | 数 | 前版からの改版内容                               |      | 適用箇所          |
|-----|---|-----------------------------------------|------|---------------|
| 第3版 |   | 図15-5 外部割り込み立ち上がりエッジ許可レジスタ(EGP),外部割り込み立 | 第15章 | 割り込み機能        |
|     |   | ち下がりエッジ許可レジスタ(EGN)のフォーマットに注意を追加         |      |               |
|     |   | 15.4.1 ノンマスカブル割り込み要求の受け付け動作に説明文と備考を追加   |      |               |
|     |   | 15.4.2 マスカブル割り込み要求の受け付け動作に説明文を追加        |      |               |
|     |   | 表15-4 割り込み処理中に多重割り込み可能な割り込み要求に項目追加      |      |               |
|     |   | 表16-1 HALTモード時の動作状態にクロック出力とブザー出力を追加     | 第16章 | スタンバイ機能       |
|     |   | 表16-3 STOPモード時の動作状態のクロック出力を修正           |      |               |
|     |   | 章を改訂                                    | 第18章 | μ PD78F0034BS |
|     |   |                                         | 第20章 | 電気的特性         |
|     |   |                                         | 付録B  | 開発ツール         |
|     |   | 章を追加                                    | 付録C  | ターゲット・システ     |
|     |   |                                         | ム設計」 | 上の注意          |

(メ モ)

## 【発行】

### NECエレクトロニクス株式会社

〒211-8668 神奈川県川崎市中原区下沼部1753

電話(代表): 044(435)5111

-----お問い合わせ先-

### 【ホームページ】

NECエレクトロニクスの情報がインターネットでご覧になれます。

URL(アドレス) http://www.necel.co.jp/

### 【営業関係、技術関係お問い合わせ先】

半導体ホットライン電話: 044-435-9494(電話:午前9:00~12:00, 午後1:00~5:00)E-mail: info@necel.com

#### 【資料請求先】

NECエレクトロニクスのホームページよりダウンロードいただくか、NECエレクトロニクスの販売特約店へお申し付けください。