# 特徴

- 高性能、低消費AVR® 8ビット マイクロ コントローラ
- 進化したRISC構造
  - ・強力な123命令(多くは1周期で実行)
  - ・32個の1バイト長汎用レジスタ
  - ・完全なスタティック動作
  - ・20MHz時、20MIPSに達する高速動作

## ■ 高耐久不揮発性メモリ部

- ・実装自己書き換え可能な1Kバイト(512語)フラッシュ メモリ内蔵
- ・64バイトのEEPROM
- ・64バイトの内蔵SRAM
- ・書き換え回数: 10,000/フラッシュ, 100,000/EEPROM
- ・ データ保持力: 20年/85℃, 100年/25℃ (4頁をご覧ください。)
- ・自己プログラミング、フラッシュとEEPROMデータ保護用の設定可能な施錠機能

#### ■ 内蔵周辺機能

- ・前置分周器と2つのPWM出力付き1つの8ビット タイマ/カウンタ
- ・4チャネルの内部基準電圧付き10ビット A/D変換器
- ・設定可能な専用発振器付きウォッチドッグ、タイマ
- ・アナログ比較器

#### ■ 特殊マイクロ コントローラ機能

- ・デバッグWIRE内蔵デバッグ機能
- ・SPIポート経由の実装書き込み
- ・外部及び内部の割り込み
- ・アイドハ、A/D変換雑音低減、パワーダウンの3つの低消費動作
- ・強化した電源ONJセット回路
- ・設定可能な低電圧検出器(BOD)回路
- ・校正付き内蔵RC発振器

#### ■ I/Oと外囲器

- ・6ビットの設定可能なI/O
- ・8ピンPDIP、8リートSOIC、10パットQFN/MLF、20パットQFN/MLF

# ■ 動作電圧

- 1.8~5.5V (ATtiny13V)
- 2.7~5.5V (ATtiny13)

#### ■ 動作速度

- $0\sim4\text{MHz}/1.8\sim5.5\text{V},0\sim10\text{MHz}/2.7\sim5.5\text{V}$  (ATtiny13V)
- $0 \sim 10 \text{MHz} / 2.7 \sim 5.5 \text{V}, 0 \sim 20 \text{MHz} / 4.5 \sim 5.5 \text{V}$  (ATtiny13)

## ■ 工業用温度範囲

## ■ 低消費電力

- · 240µA (1MHz,1.8V,活動動作)
- 0.1µA (1.8V,パワータ ウン動作)





8ビット **AVA**® マイクロ コントローラ 実装書き換え可能な 1 K バイト フラッシュ メモリ内蔵

ATtiny13 ATtiny13V

Rev. 2535J-08/10, 2535JJ5-01/22





# 1. ピン配置



## 1.1. ピン概要

## 1.1.1. VCC

電源ピン。

#### 1.1.2. GND

接地ピン。

## 1.1.3. PB5~PB0 (ポートB)

ポートBは(ビット単位で選択される)内蔵プルアップ抵抗付きの6ビット双方向入出力ポートです。ポートB出力緩衝部は共に高い吐き出し/吸い込み能力の対称駆動特性です。入力の時にプルアップ抵抗が有効の場合、外部的にLowへ引き込まれたポートBピンには吐き出し電流が流れます。リセット条件が有効になると、クロックが走行していなくても、ポートBピンはHi-Zにされます。

ポートBは36頁で示されるATtinv13の様々な特殊機能も扱います。

# 1.1.4. RESET

リセット入力。例えクロックが走行していなくても、最小パルス幅より長いこのピンのLowレベルはリセットを生成します。最小パルス幅は79頁の表 18-4.で与えられます。より短いパルスはリセットの生成が保証されません。

リセット ピンは(弱い駆動の)入出力ピンとしても使えます。

# 2. 概要

ATtiny13はAVR強化RISC構造を基にした低消費CMOS 8ビットマイクロコントローラです。1周期での強力な命令の実行により、ATtiny13はMHzあたり1MIPSに達する単位処理量を成し遂げ、処理速度対消費電力の最適化を設計者に許します。

# 2.1. 構成図



AVRコアは32個の汎用作業レジスタと豊富な命令群の組み合わせです。32個の全レジスタはALU(Arithmetic Logic Unit)に直結され、レジスタ間命令は1クロック周期で実行されます。AVR構造は現状のCISC型マイクロコントローラに対して最大10倍の単位処理量向上効果があります。

ATtiny13は1Kバイトの実装書き込み可能なフラッシュメモリ、64バイトのEEPROM、64バイトのRAM、6本の汎用入出力線、32個の汎用作業レジスタ、比較動作付きの1つの8ビット タイマ/カウンタ、内部及び外部割り込み、4チャネルの10ビット A/D変換器、内蔵発振器付きの設定変更可能なウォッチドッグタイマ、ソフトウュアで選択できる3つの低消費動作を提供します。アイドル動作はCPUを停止し、一方SRAM、タイマ/カウンタ、A/D変換器、アナログ比較器、割り込み機構に機能の継続を許します。パワーダウン動作はレジスタの内容を保護し、発振器が停止するため、以降のハードウュア リセットか外部割り込みまで、他の全機能を禁止します。A/D変換雑音低減動作はA/D変換中の切り替え雑音を最小とするためにA/D変換器を除く全I/O部とCPUを停止します。

本デバイスはAtmelの高密度不揮発性メモリ技術を使って製造されます。チップ上のISPフラッシュメモリは通常の不揮発性メモリ書き込み器によるSPI直列インターフェースを通して、またはAVRコア上で走行するチップ。上のブートコートによる実装書き換えをプログラム用メモリに許します。 ATtiny13 AVRはCコンパイラ、マクロアセンブラ、プログラムデバッカ/シミュレータ、評価キットを含む完全なプログラム及びシステム開発ツールで支援されます。





# 3. 一般情報

## 3.1. 資料

包括的なデータシート、応用記述、トライハ、群と開発ツールの記述はhttp://www.atmel.com/avrでのダウンロードで利用可能です。

# 3.2. コート 例

この資料はデバイスの様々な部分の使用法を手短に示す簡単なコート・例を含みます。これらのコート・例はアセンブルまたはコンパイルに先立って、デバイス定義へッタ・ファイルがインクルートされると仮定します。全てのCコンパイラ製造業者がヘッタ・ファイル内にビット定義を含めるとは限らず、またCでの割り込みの扱いがコンパイラに依存することに注意してください。より多くの詳細についてはCコンパイラの資料で確認してください。

# 3.3. データ保持力

信頼性証明結果はデータ保持誤り率の反映を示し、20年以上/85℃または100年以上/25℃で1PPMよりずっと小さな値です。

## 4. CPU コア

本項はAVRコア構造を一般的に説明します。このCPUコアの主な機能は正しいプログラム実行を保証することです。従ってCPUはメモリアクセス、計算実行、周辺制御、割り込み操作ができなければなりません。

## 4.1. 構造概要

最大効率と平行処理のため、AVRはプログラムとデータに対してメモリとハ、スを分離するハーハート、構造を使います。プログラムメモリ内の命令は単一段のハーイプラインで実行されます。1命令の実行中に次の命令がプログラムメモリから事前取得されます。この概念は全部のクロック周期で命令実行を可能にします。プログラムメモリは実装書き換え可能なフラッシュメモリです。

高速レジスタファイルは1クロック周期アクセスの32個の8ビット長汎用レジタを含みます。これは1クロック周期ALU(Arithmetic Logic Unit)操作を許します。代表的なALU操作では2つのオペランドがレジスタファイルからの出力で、1クロック周期内でその操作が実行され、その結果がレジスタファイルに書き戻されます。

32個中の6つのレシ、スタは効率的なアトンス計算ができるデータ空間アトンス指定用に3つの16ビット長間接アトンスポーインタ用レシ、スタとして使われます。これらアトンスポーインタの1つはプログラム用フラッシュメモリ内の定数表参照用アトンスポーインタとしても使えます。これら16ビット長付加機能レシ、スタはX,Y,Zレシ、スタで、本項内で後述されます。

ALUはレシ、スタ間またはレシ、スタと定数間の算術及び論理操作を支援します。単一レシ、スタ操作もALUで実行できます。算術演算操作後、操作結果についての情報を反映するために、ステータスレジ、スタ (SREG)が更新されます。

プログラムの流れは条件/無条件分岐や呼び出し命令によって提供され、全アドレス空間を直接アドレス指定できます。AVR命令の多くは

16ビット語(ワード)形式です。全てのプログラム メモリのアドレスは(訳注:定数のみを除き)16または32ビット長命令を含みます。

割り込みやサブルーチン呼び出し中、戻りアドレスを示すプログラム カウンタ(PC)はスタックに保存されます。スタックは一般的なデータ用SRAM上に実際には割り当てられ、従ってスタック容量は全SRAM容量とSRAM使用量でのみ制限されます。全ての使用者プログラムはリセット処理ルーチンで(サブルーチン呼び出しや割り込みが実行される前に)、スタック ポインタ(SP)を初期化しなければなりません。SPはI/O空間で読み書きアクセスが可能です。データ用SRAMはAVR構造で支援される5つの異なるアドレス指定種別を通して容易にアクセスできます。

AVR構造に於けるメモリ空間は全て直線的な普通のメモリ配置です。

柔軟な割り込み部にはI/O空間の各制御レシ、スタとステータスレシ、スタ(SREG)の特別な全割り込み許可(I)ビットがあります。全ての割り込みは割り込みへ、クタ表に個別の割り込みへ、クタを持ちます。割り込みには割り込みへ、クタ表の位置に従う優先順があります。下位側割り込みへ、クタアドレスが高い優先順位です。

I/Oメモリ空間は制御レジスタや他のI/O機能としてCPU周辺機能用の64アドレスを含みます。I/Oメモリは直接またはレジスタ ファイルの次のデータ空間位置\$20~\$5Fとしてアクセスできます。

## **4.2. ALU** (Arithmetic Logic Unit)

高性能なAVRのALUは32個全ての汎用レジスタに直接接続され動作します。汎用レジスタ間または汎用レジスタと即値間の演算操作は単一クロック周期内で実行されます。ALU操作は算術演算、論理演算、ビット操作の3つの主な種類に大別されます。符号付きと符号なし両方の乗算と固定小数点形式を支援する乗算器(乗算命令)も提供する構造の実装(製品)もあります。詳細記述については「命令要約」章をご覧ください。







# 4.3. ステータス レジスタ

ステータスレジスタは最も直前に実行した演算命令の結果についての情報を含みます。この情報は条件処理を行うためのプログラムの流れ変更に使えます。ステータスレジスタは「命令一式参考書」で詳述したように、全てのALU操作後、更新されることに注目してください。これは多くの場合でそれ用の比較命令使用の必要をなくし、高速でより少ないコードに帰着します。

ステータス レジスタは割り込み処理ルーチン移行時の保存と割り込みからの復帰時の回復(復帰)が自動的に行われません。これはソフトウェアによって扱われなければなりません。

## 4.3.1. ステータス レシ スタ (Status Register) SREG

| ピット         | 7   | 6   | 5   | 4   | 3   | 2   | 1   | 0   |      |
|-------------|-----|-----|-----|-----|-----|-----|-----|-----|------|
| \$3F (\$5F) | I   | T   | Н   | S   | V   | N   | Z   | С   | SREG |
| Read/Write  | R/W |      |
| 初期値         | 0   | 0   | 0   | 0   | 0   | 0   | 0   | 0   |      |

#### ■ ビット7 - I: 全割り込み許可 (Global Interrupt Enable)

全割り込み許可ビットは割り込みが許可されるために設定(1)されなければなりません。その時の個別割り込み許可制御は独立した制御レジスタで行われます。全割り込み許可ビットが解除(0)されると、個別割り込み許可設定に拘らず、どの割り込みも許可されません。I ビットは割り込みが起こった後にハードウェアによって解除(0)され、後続の割り込みを許可するために、RETI命令によって設定(1)されます。Iビットは「命令一式参考書」で記述されるようにSEIやCLI命令で応用(プログラム)によって設定(1)や解除(0)もできます。

#### ■ L'yh6 - T: L'yh変数 (Bit Copy Storage)

ビット複写命令、BLD(Bit LoaD)とBST(Bit STore)は操作したビットの転送元または転送先として、このTビットを使います。レジスタ ファイルのレジスタからのビットはBST命令によってTに複写でき、TのビットはBLD命令によってレジスタ ファイルのレジスタ内のビットに複写できます。

#### **■ ビット5 - H**: **ハーフキャリー フラク** (Half Carry Flag)

ハーフキャリー(H)フラグはいくつかの算術操作でのハーフキャリーを示します。ハーフキャリーはBCD演算に有用です。詳細情報については「命令要約」記述をご覧ください。

## ■ ビット4 - S: 符号 (Sign Bit, S= N Ex-OR V)

Sフラグは常に負(N)フラグと2の補数溢れ(V)フラグの排他的論理和です。詳細情報については「命令要約」記述をご覧ください。

#### ■ ビット3 - V: 2の補数溢れフラグ(2's Complement Overflow Flag)

2の補数溢れ(V)フラグは2の補数算術演算を支援します。詳細情報については「命令要約」記述をご覧ください。

## **■ Ľット2 - N**: **負フラク** (Negative Flag)

負(N)フラグは算術及び論理操作での負の結果(MSB=1)を示します。詳細情報については「命令要約」記述をご覧ください。

## **■ L**"**yh1 - Z** : **t**"**D 750**" (Zero Flag)

ゼロ(Z)フラグは算術及び論理操作でのゼロ(0)の結果を示します。詳細情報については「命令要約」記述をご覧ください。

## **■** じット0 - C: キャリー フラク (Carry Flag)

キャリー(C)フラグは算術及び論理操作でのキャリー(またはボロー)を示します。詳細情報については「**命令要約**」記述をご覧ください。

## 4.4. 汎用レジスタファイル

このレシ、スタファイルはAVRの増強したRISC命令群用に最適化されています。必要な効率と柔軟性を達成するために、次の入出力機構がレシ、スタファイルによって支援されます。

- ・1つの8ビット出力オペラントと1つの8ビットの結果入力
- ・2つの8ビット出力オペラントと1つの8ビットの結果入力
- ・2つの8ビット出力オペランドと1つの16ビットの結果入力
- ・1つの16ビット出力オペランドと1つの16ビットの結果入力

**図4-2**.はCPU内の32個の汎用作業レジスタの構造を示します。 レジスタファイルを操作する殆どの命令は全てのレジスタに直接アクセスし、それらの殆どは単一周期命令です。

図4-2.で示されるように各レジスタは使用者データ空間の最初の32位置へ直接的に配置することで、それらはデータメモリアドレスも割り当てられます。例え物理的にSRAM位置として実装されていなくてもX,Y,Zレジスタ(ポインタ)がレジスタファイル内のどのレジスタの指示にも設定できるように、このメモリ構成は非常に柔軟なレジスタのアクセスを提供します。

| 図4-2. AVR CPU 汎用レジスタ構成図 |     |      |                                             |  |  |  |  |
|-------------------------|-----|------|---------------------------------------------|--|--|--|--|
|                         | 7 0 | アドレス |                                             |  |  |  |  |
|                         | R0  | \$00 |                                             |  |  |  |  |
|                         | R1  | \$01 |                                             |  |  |  |  |
|                         | R2  | \$02 |                                             |  |  |  |  |
|                         | }   |      |                                             |  |  |  |  |
|                         | R13 | \$0D |                                             |  |  |  |  |
|                         | R14 | \$0E |                                             |  |  |  |  |
| on EE                   | R15 | \$0F |                                             |  |  |  |  |
| 汎用<br>レシ゛スタ             | R16 | \$10 |                                             |  |  |  |  |
| ファイル                    | R17 | \$11 |                                             |  |  |  |  |
| 2 7 (0)                 | }   |      |                                             |  |  |  |  |
|                         | R26 | \$1A | Xレジスタ       下位バイト         上位バイト       上位バイト |  |  |  |  |
|                         | R27 | \$1B | <u> </u>                                    |  |  |  |  |
|                         | R28 | \$1C | VIC/フタ 下位バイト                                |  |  |  |  |
|                         | R29 | \$1D | 上ルハイト                                       |  |  |  |  |
|                         | R30 | \$1E | Zレジスタ 下位バイト                                 |  |  |  |  |
|                         | R31 | \$1F | 上位が小                                        |  |  |  |  |

## 4.4.1. Xレシ、スタ、Yレシ、スタ、Zレシ、スタ

R26~R31レジスタには通常用途の使用にいくつかの追加機能があります。これらのレジスタはデータ空間の間接アドス指定用の16 ビットアドレス ポインタです。3つのX,Y,Z間接アドレス レジスタは図4-3.で記載したように定義されます。

種々のアドレス指定種別で、これらのアドレス レジスタは固定変位、 自動増加、自動減少としての機能を持ちます(詳細については 「命令一式参考書」をご覧ください)。

| 図4-3. X,Y,ZI         | 図4-3. X,Y,Zレジスタ構成図 |            |     |            |   |  |  |
|----------------------|--------------------|------------|-----|------------|---|--|--|
|                      | 15                 | XH (上位)    |     | XL (下位)    | 0 |  |  |
| X レジスタ               | 7                  | R27 (\$1B) | 0 7 | R26 (\$1A) | 0 |  |  |
|                      | 15                 | YH (上位)    |     | YL (下位)    | 0 |  |  |
| Y レシ <sup>・</sup> スタ | 7                  | R29 (\$1D) | 0 7 | R28 (\$1C) | 0 |  |  |
|                      | 15                 | ZH (上位)    |     | ZL (下位)    | 0 |  |  |
| Ζ レジスタ               | 7                  | R31 (\$1F) | 0 7 | R30 (\$1E) | 0 |  |  |
|                      |                    |            |     |            |   |  |  |

# 4.5. スタック ホ°インタ

スタックは主に一時データの保存、局所変数の保存、割り込みとサブルーチン呼び出し後の戻りアドレスの保存に使われます。スタック ポインタ レジスタは常にこのスタックの先頭(<mark>訳注</mark>:次に使われるべき位置)を指し示します。スタックが高位メモリから低位メモリへ伸長するように実行されることに注意してください。これはスタックへのPUSH命令はスタック ポインタを減少するという意味です。

スタック ポインタはサブルーチンや割り込みのスタックが配置されるデータSRAMのスタック領域を指し示します。データSRAM内のスタック空間は電源 ONリセット中にSRAMの最終アドレスが自動的に定義されます。スタック ポインタは \$60以上を指示するように設定されなければなりません。スタック ポインタは PUSH命令でデータがスタックに格納されると-1され、サブルーチン呼び出しや割り込みで戻りアドレスがスタックに格納されると-2されます。スタック ポインタは POP命令でデータがスタックから引き出されると+1され、サブルーチンからの復帰(RET)命令や割り込みからの復帰(RET)命令でアドレスがスタックから引き出されると+2されます。

AVRのスタック ポインタはI/O空間内の2つの8ビット レジ、スタとして実装されます。実際に使われるビット数は(そのデ`バイス)実装に依存します。SPLだけが必要とされる程に小さいAVR構造の実装(デバイス)のデータ空間もあることに注意してください。その場合、SPHレシ、スタは存在しません。

## 4.5.1. スタック ホーインタ (Stack Pointer) SPL (SP)

|             | . , |     |     |     |     |     |     |     |     |
|-------------|-----|-----|-----|-----|-----|-----|-----|-----|-----|
| ピット         | 7   | 6   | 5   | 4   | 3   | 2   | 1   | 0   | _   |
| \$3D (\$5D) | SP7 | SP6 | SP5 | SP4 | SP3 | SP2 | SP1 | SP0 | SPL |
| Read/Write  | R/W |     |
| 初期値         | 1   | 0   | 0   | 1   | 1   | 1   | 1   | 1   |     |





## 4.6. 命令実行タイミング

本項は命令実行の一般的なアクセス タイミング の概念を記述します。AVR CPUはチップ(デバイス)用に選択したクロック元から直接的に生成したCPUクロック(clkcPU)によって駆動されます。内部クロック分周は使われません。

図4-4.はハーハート、構造と高速アクセスレジスタファイルの概念によって可能とされる並列の命令取得と命令実行を示します。これは機能対費用、機能対クロック、機能対電源部に関する好結果と対応するMHzあたり1MIPSを達成するための基本的なパイプラインの概念です。

図4-5.はレシ、スタファイルに対する内部タイミングの概念を示します。単一クロック周期で2つのレシ、スタオペラント、を使うALU操作が実行され、その結果が転送先レジ、スタへ書き戻されます。





## 4.7. リセットと割り込みの扱い

AVRは多くの異なる割り込み元を提供します。これらの割り込みと独立したリセット ベクタ各々はプログラム メモリ空間内に独立したプログラム ベクタを持ちます。全ての割り込みは割り込みを許可するために、ステータス レジスタ(SREG)の全割り込み許可(I)ビットと共に論理1が書かれなければならない個別の許可ビットを割り当てられます。

既定でのプログラムメモリ空間の最下位アトレスはリセットと割り込みのベクタとして定義されます。ベクタの完全な一覧は29頁の「割り込み」で示されます。この一覧は各種割り込みの優先順位も決めます。下位側アトレスがより高い優先順位です。リセットが最高優先順位で、次が外部割り込み要求の(INTO)です。

割り込みが起こると全割り込み許可(I)ビットが解除(0)され、全ての割り込みは禁止されます。使用者ソフトウェアは多重割り込みを許可するため、全割り込み許可(I)ビットへ論理1を書けます。その後全ての許可した割り込みが現在の割り込みルーチンで割り込めます。全割り込み許可(I)ビットは割り込みからの復帰(RETI)命令が実行されると、自動的に設定(1)されます。

根本的に2つの割り込み形式があります。1つ目の形式は割り込み要求フラグを設定(I)する事象によって起動されます。これらの割り込みでは割り込み処理ルーチンを実行するために、プログラム カウンタは対応する現実の割り込みへ、クタを指示し、ハートウェアが対応する割り込み要求フラグを解除(0)します。割り込み要求フラグは解除(0)されるべきフラグのビット位置へ論理1を書くことによっても解除(0)できます。対応する割り込み許可ビットが解除(0)されている間に割り込み条件が起こると、割り込み要求フラグが設定(1)され、割り込みが許可されるか、またはこのフラグがソフトウェアによって解除(0)されるまで記憶(保持)されます。同様に、全割り込み許可(I)ビットが解除(0)されている間に1つまたはより多くの割り込み条件が起こると、対応する割り込み要求フラグが設定(1)されて全割り込み許可(I)ビットが設定(1)されるまで記憶され、その(I=1)後で優先順に従って実行されます。

2つ目の割り込み形式は割り込み条件が存在する限り起動し(続け)ます。これらの割り込みは必ずしも割り込み要求フラグを持っているとは限りません。割り込みが許可される前に割り込み条件が消滅すると、この割り込みは起動されません。

AVRが割り込みから抜け出すと常に主プログラムへ戻り、何れかの保留割り込みが扱われる前に1つ以上の命令を実行します。

ステータス レジスタ(SREG)は割り込みルーチンへ移行時の保存も、復帰時の再設定も自動的に行われないことに注意してください。これはソフトウェアによって扱われなければなりません。

割り込みを禁止するためにCLI命令を使うと、割り込みは直ちに禁止されます。CLI命令と同時に割り込みが起こっても、CLI命令後に割り込みは実行されません。次例は時間制限EEPROM書き込み手順中に割り込みを無効とするために、これがどう使えるかを示します。

| アセンブリ言語プログラム例                  |                                                                                                                      |                                                                                                                                    |
|--------------------------------|----------------------------------------------------------------------------------------------------------------------|------------------------------------------------------------------------------------------------------------------------------------|
| IN<br>CLI<br>SBI<br>SBI<br>OUT | R16, SREG  EECR, EEMPE EECR, EEPE SREG, R16                                                                          | ;ステータスレジスタを保存<br>;EEPROM書き込み手順中割り込み禁止<br>;EEPROM主書き込み許可<br>;EEPROM書き込み開始<br>;ステータスレジスタを復帰                                          |
| C言語プログラム例                      |                                                                                                                      |                                                                                                                                    |
| cSREG<br>dis<br>EECR<br>EECR   | <pre>cSREG; = SREG; able_interrupt();  = (1&lt;<eempe); =="" csreg:<="" pre=""  ="(1&lt;&lt;EEPE);"></eempe);></pre> | /* ステータス レジ スタ保存変数定義 */ /* ステータス レジ スタを保存 */ /* EEPROM書き込み手順中割り込み禁止 */ /* EEPROM主書き込み許可 */ /* EEPROM書き込み開始 */ /* ステータス レジ スタを復帰 */ |

割り込みを許可するためにSEI命令を使うと、次例で示されるようにどの保留割り込みにも先立ってSEI命令の次の命令が実行されます。

| アセンブリ言語プログラム例       |                       |
|---------------------|-----------------------|
| SEI                 | ;全割り込み許可              |
| SLEEP               | ;休止形態移行(割り込み待ち)       |
| C言語プログラム例           |                       |
| enable_interrupt(); | /* 全割り込み許可 */         |
| sleep();            | /* 休止形態移行 (割り込み待ち) */ |

## 4.7.1. 割り込み応答時間

許可した全てのAVR割り込みに対する割り込み実行応答は最小4クロック周期です。4クロック周期後、実際の割り込み処理ルーチンに対するプログラム ベクタ アドレスが実行されます。この4クロック周期時間中にプログラム カウンタ(PC)がスタック上に保存(プッシュ)されます。このベクタは標準的に割り込み処理ルーチンへの無条件分岐で、この分岐は2クロック周期(<mark>訳注</mark>:原文は3(JMP命令=3を想定、実際はRJMP命令=2))要します。複数周期命令実行中に割り込みが起こると、その割り込みが扱われる前に、この命令が完了されます。MCUが休止形態の時に割り込みが起こると、割り込み実行応答時間は4クロック周期増やされます。この増加は選択した休止形態からの起動時間に加えてです。

割り込み処理ルーチンからの復帰は4クロック周期要します。これらの4クロック周期中、プログラム カウンタ(PC:2バイト)がスタックから取り戻され(ポップ)、スタック ポプンタは増加され(+2)、ステータス レシ、スタ(SREG)の全割り込み許可(I)ビットが設定(1)されます。





# 5. メモリ

この項はATtiny13の各種メモリを記述します。AVR構造にはプログラム メモリ空間とデータ メモリ空間の2つの主なメモリ空間があります。加えてATtiny13はデータ保存用EEPROMメモリが特徴です。3つのメモリ空間全ては一般的な直線的アドレスです。

## 5.1. 実装書き換え可能なプログラム用フラッシュ メモリ

ATtiny13はプログラム保存用に実装書き換え可能な1Kバイトのフラッシュ メモリをチップ上に含みます。全てのAVR命令が16または32ビット幅のため、このフラッシュ メモリは512×16ビットとして構成されます。

フラッシュ メモリは最低10,000回の消去/書き込み回数の耐久性があります。ATtiny13のプログラム カウンタ(PC)は9ビット幅、従って512プログラム メモリ位置のアトレス指定です。68頁の「メモリプログラミング」はSPIピンを使うフラッシュ メモリの直列プログラミング、の詳細な記述を含みます。

定数表は全てのプログラム メモリ アドレス空間に配置できます。(LPM命令記述参照) 命令の取得と実行のタイミング図は8頁の「命令実行タイミング」で示されます。

# 図5-1. プログラム メモリ配置図 プログラム用 フラッシュ メモリ 512×16 \$01FF

## **5.2.** データ用SRAM メモリ

図5-2.はATtiny13のSRAMメモリ構成方法を示します。

下位160データメモリ位置はレジスタファイル、I/Oメモリ、内蔵データSRAMに充てます。最初の32位置はレジスタファイル、次の64位置は標準I/Oメモリに充て、最後の64位置は内蔵データSRAMに充てます。

直接、間接、変位付き間接、事前減少付き間接、事後増加付き間接の5つの異なるアトレス指定種別でデータ メモリ(空間)を網羅します。レジスタファイル内のレジスタR26~R31は間接アトレス指定ポインタ用レジスタが特徴です。

直接アドレス指定はデータ空間全体に届きます。

変位付き間接動作はYまたはZレシ、スタで与えられる基準アト、レスからの63アト、レス位置に届きます。

自動の事前減少付きと事後増加付きのレシ、スタ間接アドレス指定動作を使う時に(使われる)X, Y,Zアドレスレジ、スタは減少(-1)または増加(+1)されます。

ATtiny13の32個の汎用レジスタ、64個のI/Oレジスタ、64バイトのデータ用内蔵SRAMは、これら全てのアドレス指定種別を通して全部アクセスできます。レジスタファイルは7頁の「汎用レジスタファイル」で記述されます。



## 5.2.1. データ メモリ アクセス タイミング

この項は内部メモリ アクセスに対する一般的なアクセス タイミングの概念を記述します。 データ用内蔵SRAMアクセスは図5-3.で記載されるように2clkcpu周期で実行されます。

(訳注) 内蔵SRAMのアクセスを含む代表的な命令はT1,T2の 2周期で実行され、T1で対象アトレスを取得/(算出)/ 確定し、T2で実際のアクセスが行われます。後続する (T1)は次の命令のT1です。



# 5.3. データ用EEPROMメモリ

ATtiny13は64小、イトのデータ用EEPROMを含みます。それは単一ハ、イトが読み書きできる分離したデータ空間として構成されます。EEPROMは最低100,000回の消去/書き込み回数の耐久性があります。CPUとEEPROM間のアクセスは以降のEEPROMアドレスレジスタ、EEPROMデータレジスタ、EEPROM制御レジスタで詳細に記述されます。EEPROMの直列プログラミングの詳細な記述については71頁をご覧ください。

## **5.3.1.** EEPROMアクセス

EEPROMアクセスレジスタはI/O空間でアクセス可能です。

EEPROMの書き込み(<mark>訳注</mark>:原文はアクセス)時間は表5-1.で与えられます。(書き込みは)自己タイシンが機能ですが、使用者ソフトウェアは次ハイトが書ける時を検知してください。使用者コートがEEPROMに書く命令を含む場合、いくつかの予防処置が取られなければなりません。厳重に濾波した電源では電源投入/切断でVCCが緩やかに上昇または下降しそうです。これはデバイスが何周期かの時間、使われるクロック周波数に於いて最小として示されるより低い電圧で走行する原因になります。これらの状態で問題を避ける方法の詳細については12頁の「EEPROMデータ化けの防止」をご覧ください。

予期せぬEEPROM書き込みを防止するため特別な書き込み手順に従わなければなりません。この詳細については「非分離バー書き込み」と「分離バー書き込み」を参照してください。

EEPROMが読まれると、CPUは次の命令が実行される前に4クロック周期停止されます。EEPROMが書かれると、CPUは次の命令が実行される前に2クロック周期停止されます。

#### 5.3.2. 非分離バイト プログラミング

非分離バイト プログラミングの使用は最も簡単な動作です。EEPROMにバイトを書くとき、使用者はEEARLにアドレス、EEDRにデータを書かなければなりません。EEPMnビットが'00'ならば、(EEMPEが1を書かれる後の4周期内の)EEPEの1書き込みは消去/書き込み動作を起動します。消去と書き込みの両周期は1操作で行われ、総プログラミング時間は表5-1.で与えられます。EEPEビットは消去と書き込み動作が完了されるまで設定(1)に留まります。デバイスがプログラミング動作中、他のどのEEPROM操作の実行も不可能です。

## 5.3.3. 分離バイト プログラミング

2つの異なる操作として消去と書き込み周期を分離することが可能です。これは或る時間制限(代表的には電源電圧不足)に対してシステムが短いアクセス時間を必要とする場合に有用かもしれません。この方法の優位性を得るため、書かれるべき位置が書き込み操作前に消去されてしまっていることが必要とされます。しかし、消去と書き込みが分離されるため、時間が重大な操作の実行をシステムが許す時(代表的には電源投入後)に消去操作を行うことが可能です。

## 5.3.4. 消去

ハ'イトを消去するにはアドレスがEEARLに書かれなければなりません。EEPMnビットが'01'なら、(EEMPEが1を書かれた後の4周期内の) EEPEの1書き込みは消去動作だけを起動します(プログラミング時間は表5-1.で与えられます)。EEPEビットは消去動作が完了されるまで設定(1)に留まります。デバイスがプログラミング動作中、他のどのEEPROM操作の実行も不可能です。

## 5.3.5. 書き込み

(特定)位置を書くため、使用者はEEARLにアドレス、EEDRにデータを書かなければなりません。EEPMnt゙ットが'10'なら、(EEMPEが1を書かれる後の4周期内の)EEPEの1書き込みは書き込み動作だけを起動します(プログラミング時間は表5-1.で与えられます)。EEPEt゙ットは書き込み動作が完了されるまで設定(1)に留まります。書かれるべき位置が書き込み前に消去されてしまっていなければ、元の格納データは失ったとみなされなければなりません。デバイスがプログラミング動作中、他のどのEEPROM操作の実行も不可能です。

EEPROMアクセスの時間に校正済み内蔵RC発振器が使われます。発振器周波数が18頁の「**発振校正レジスタ**(OSCCAL)」で記述した必要条件内であることを確かめてください。





次のコート・例はアセンブリ言語とC言語でのEEPROM消去、書き込み、または非分離書き込み関数を示します。本例は(例えば全割り込み禁止によって)割り込みが制御され、これらの関数実行中に割り込みが起きない前提です。

```
アセンブリ言語プログラム例
EEPROM_WR:
                                                     ;EEPROMプログラミング完了ならばスキップ
           SBIC
                  EECR, EEPE
           RJMP
                  EEPROM WR
                                                     ;以前のEEPROMプログラミング完了まで待機
                  R18, (0<<EEPM1) | (0<<EEPM0)
           LDI
                                                     ;プログラミング種別値取得(本例は非分離)
                                                     ;対応プログラミング種別設定
           OUT
                  EECR, R18
           OUT
                  EEARL, R17
                                                     ;EEPROMアドレス設定
                  EEDR, R16
                                                     ;EEPROM書き込み値を設定
           OUT
                                                     ;EEPROM主プログラム許可ビット設定
           SBI
                  EECR, EEMPE
                                                     ;EEPROMプログラミング開始(プログラム許可ビット設定)
           SBI
                  EECR, EEPE
                                                     ;呼び出し元へ復帰
           RET
C言語プログラム例
void EEPROM_write(unsigned char ucAddress, unsigned char ucData)
   while (EECR & (1<<EPE));
                                                    /* 以前のEEPROMプログラミング完了まで待機 */
   EECR = (0 << EEPM1) \mid (0 << EEPM0);
                                                    /* 対応プログラミング種別設定 */
                                                    /* EEPROMアトレス設定*/
   EEARL = ucAddress;
   EEDR = ucData;
                                                    /* EEPROM書き込み値を設定 */
   EECR = (1 < EEMPE);
                                                    /* EEPROM主プログラム許可*/
                                                    /* EEPROMプログラミング開始*/
   EECR \mid = (1 << EEPE);
```

次のコート・例はアセンブリ言語とC言語でのEEPROM読み込み関数を示します。本例は割り込みが制御され、これらの関数実行中に割り込みが起きない前提です。

```
アセンブリ言語プログラム例
                                                   ;EEPROMプログラミング完了ならばスキップ
EEPROM RD:
           SBIC
                 EECR, EEPE
                 EEPROM RD
                                                   ;以前のEEPROMプログラミング完了まで待機
           R.JMP
           OUT
                 EEARL, R17
                                                   ;EEPROMアトレス設定
                                                   ;EEPROM読み出し開始(読み込み許可ビット設定)
           SBI
                 EECR, EERE
                                                   ;EEPROM読み出し値を取得
           ΙN
                 R16, EEDR
           RET
                                                   ;呼び出し元へ復帰
C言語プログラム例
unsigned char EEPROM read(unsigned char ucAddress)
   while (EECR & (1<<EPE));
                                                   /* 以前のEEPROMプログラミング完了まで待機 */
   EEARL = ucAddress;
                                                  /* EEPROMアドレス設定*/
   EECR = (1 \le EERE);
                                                   /* EEPROM読み出し開始 */
                                                   /* EEPROM読み出し値を取得,復帰 */
   return EEDR;
}
```

## 5.3.6. EEPROMデータ化けの防止

低VCCの期間中、正しく動作するための供給電圧がCPUとEEPROMに対して低すぎるためにEEPROMデータが化け得ます。これらの問題はEEPROMを使う基板段階の装置と同じで、同じ設計上の解決策が適用されるべきです。

EEPROMデータ化けは電圧が低すぎる時の2つの状態によって起こされ得ます。1つ目として、EEPROMへの通常の書き込み手順は正しく動作するための最低電圧が必要です。2つ目として、供給電圧が低すぎると、CPU自身が命令を間違って実行し得ます。

EEPROMデータ化けは次の推奨設計によって容易に避けられます。

不充分な供給電源電圧の期間中、AVRのRESETを活性(Low)に保ってください。これは内蔵低電圧検出器(BOD)を許可することによって行えます。内蔵BODの検出電圧が必要とした検出電圧と一致しない場合、外部低VCCリセット保護回路が使えます。書き込み動作実行中にリセットが起こると、この書き込み操作は供給電源電圧が充分ならば(継続)完了されます。

## 5.4. I/O メモリ (レシ スタ)

ATtiny13のI/O空間定義は104頁の「レジスタ要約」で示されます。

ATtiny13の全てのI/Oと周辺機能はI/O空間に配置されます。全てのI/O位置はI/O空間と32個の汎用作業レジスタ間のデータ転送を行うLD/LDS/LDD命令とST/STS/STD命令によってアクセスされます。アドレス範囲\$00~\$1F内のI/OレジスタはSBI命令とCBI命令の使用で直接的にビット アクセス可能です。これらのレジスタではSBISとSBIC命令の使用によって単一ビット値が検査できます。より多くの詳細については「命令要約」章を参照してください。I/O指定命令INとOUTを使う時はI/Oアドレス\$00~\$3Fが使われなければなりません。LD命令とST命令を使い、データ空間としてI/Oレジスタをアクセスする時はこれらのアドレスに\$20が加算されなければなりません。

将来のデバイスとの共通性を保つため、アクセスされる場合、予約ビットはOが書かれるべきです。予約済みI/Oメモリ アドレスは決して書かれるべきではありません。

状態フラグのいくつかはそれらへ論理1を書くことによって解除(0)されます。CBIとSBI命令は他の多くのAVRの様ではなく、指定ビットだけを操作し、従って状態フラグのようなものを含むレジスタに使えることに注意してください。CBIとSBI命令は(I/Oアドレス)\$00~\$1Fのレジスタでのみ動作します。

I/Oと周辺制御レジスタは以降の項で説明されます。

## 5.5. メモリ関係レジスタ

## 5.5.1. EEPROMアドレス レシ スタ (EEPROM Address Register) EEARL

| ピット         | 7 | 6 | 5     | 4     | 3     | 2     | 1     | 0     |       |
|-------------|---|---|-------|-------|-------|-------|-------|-------|-------|
| \$1E (\$3E) | _ | - | EEAR5 | EEAR4 | EEAR3 | EEAR2 | EEAR1 | EEAR0 | EEARL |
| Read/Write  | R | R | R/W   | R/W   | R/W   | R/W   | R/W   | R/W   |       |
| 初期値         | 0 | 0 | 不定    | 不定    | 不定    | 不定    | 不定    | 不定    |       |

#### ■ ビット7.6 - Res: 予約 (Reserved)

これらのビットは予約されており、常に0として読まれます。

## ■ ビット5~0 - EEAR5~0: EEPROM7ドレス (EEPROM Address)

EEPROMアドレス レジスタ(EEARL)は64バイトEEPROM空間のEEPROMアドレスを指定します。EEPROMデータ バイトは0~63間で直線的に配されます。EEARLの初期値は不定です。EEPROMがアクセスされるであろう前に適切な値が書かれなければなりません。

## 5.5.2. EEPROMデータレジスタ (EEPROM Data Register) EEDR

| ピット         | 7     | 6   | 5   | 4   | 3   | 2   | 1   | 0     |      |
|-------------|-------|-----|-----|-----|-----|-----|-----|-------|------|
| \$1D (\$3D) | (MSB) |     |     |     |     |     |     | (LSB) | EEDR |
| Read/Write  | R/W   | R/W | R/W | R/W | R/W | R/W | R/W | R/W   |      |
| 初期値         | 不定    | 不定  | 不定  | 不定  | 不定  | 不定  | 不定  | 不定    |      |

#### ■ ビット7~0 - EEDR7~0: EEPROMデータ (EEPROM Data)

EEPROM書き込み操作に対して、EEDRはEEPROMアドレス レジスタ(EEARL)で与えたアドレスのEEPROMへ書かれるべきデータを含みます。EEPROM読み込み操作に対して、EEDRはEEARLで与えたアドレスのEEPROMから読み出したデータを含みます。

## 5.5.3. EEPROM制御レジスタ (EEPROM Control Register) EECR

| ピット         | 7 | 6 | 5     | 4     | 3     | 2     | 1    | 0    |      |
|-------------|---|---|-------|-------|-------|-------|------|------|------|
| \$1C (\$3C) | _ | - | EEPM1 | EEPM0 | EERIE | EEMPE | EEPE | EERE | EECR |
| Read/Write  | R | R | R/W   | R/W   | R/W   | R/W   | R/W  | R/W  |      |
| 初期値         | 0 | 0 | 不定    | 不定    | 0     | 0     | 不定   | 0    |      |

#### ■ ビット7 - Res: 予約 (Reserved)

このビットは将来の使用用に予約されており、常に0として読まれます。将来のAVRデバイスとの共通性のため、常に本ビットに0を書いてください。読み込み後、このビットを遮蔽(マスク)してください。

#### ■ ビット6 - Res: 予約 (Reserved)

このビットは予約されており、常に0として読まれます。





#### ■ ビット5.4 - EEPM1.0: EEPROMプログラミング種別(EEPROM Programing Mode Bits)

EEPROMプログラミング種別ピット設定はEEPROMプログラミング種別ピット設定はEEPROMプログラミング種別グラミング種別グラミングではできる。1つの非分離操作(旧値消去と新値書き込み)、または2つの異なる操作として消去と書き込み操作を分離してデータをプログラムする(書く)ことが可能です。各動作に対するプログラミング時間は表5-1.で示されます。EEPEが設定(1)されている間はEEPMnへのどの書き込

| 表5-1. EEPROMプログラミング 種別 |       |           |                     |  |  |  |
|------------------------|-------|-----------|---------------------|--|--|--|
| EEPM1                  | EEPM0 | プログラミング時間 | 動作                  |  |  |  |
| 0                      | 0     | 3.4ms     | 1操作での消去と書き込み(非分離操作) |  |  |  |
| 0                      | 1     | 1.8ms     | 消去のみ                |  |  |  |
| 1                      | 0     | 1.8ms     | 書き込みのみ              |  |  |  |
| 1                      | 1     | -         | 将来使用に予約             |  |  |  |

みも無視されます。 リセット中、EEPMnt'ットはEEPROMがプログラミング作業中を除いて'00'にリセットされます。

# ■ ビット3 - EERIE: EEPROM操作可割り込み許可 (EEPROM Ready Interrupt Enable)

EERIEの1書き込みはステータスレジスタ(SREG)の全割り込み許可(I)ビットが設定(1)されているなら、EEPROM操作可割り込みを許可します。EERIEの0書き込みは、この割り込みを禁止します。EEPROM操作可割り込みは不揮発性メモリ(フラッシュ メモリとEEPROM)がプログラミングの準備可ならば継続する割り込みを発生します。

#### ■ ビット2 - EEMPE: EEPROM主プログラム許可 (EEPROM Master Program Enable)

EEMPEビットはEEPROMプログラム許可(EEPE)ビットの1書き込みが有効か無効かどちらかを決めます。

EEMPEが設定(1)されると、4クロック周期内のEEPE設定(1)は選択したアドレスのEEPROMをプログラムします。EEMPEが0なら、EEPE設定(1)は無効です。EEMPEがソフトウェアによって設定(1)されてしまうと、4クロック周期後にハードウェアがこのビットを0に解除します。

## ■ ビット1 - EEPE: EEPROMプログラム許可(EEPROM Program Enable)

EEPROMプログラム許可信号(EEPE)はEEPROMへのプログラミング許可信号です。EEPEが(1を)書かれると、EEPROMはEEPMnビット設定に従ってプログラムされます。論理1がEEPEへ書かれる前にEEPROM主プログラム許可(EEMPE)ビットは1を書かれねばならず、さもなければEEPROM書き込み(消去)は行われません。書き込み(プログラミング)アクセス時間が経過されると、EEPROMプログラム許可(EEPE)ビットはハードウェアによって解除(0)されます。EEPEが設定(1)されてしまうと、次の命令が実行される前にCPUは2周期停止されます。

### ■ ビット0 - EERE: EEPROM読み込み許可 (EEPROM Read Enable)

EEPROM読み込み許可信号(EERE)はEEPROMへの読み込みストローブです。EEARLに正しいアドレスが設定されると、EEPROM読み出しを起動するためにEEREビットは1を書かれなければなりません。EEPROM読み出しアクセスは(その)1命令で行われ、要求したデータは直ちに利用できます。EEPROMが読まれるとき、次の命令が実行される前にCPUは4周期停止されます。使用者は読み込み操作を始める前にEEPEビットをポーリングすべきです。書き込み(プログラム)操作実行中の場合、EEPROMアドレス レジスタ(EEARL)の変更もEEP ROM読み込みもできません。

# 6. システム クロックとクロック選択

## 6.1. クロック系統とその配給

図6-1.はAVR内の主要なクロック系統とその配給を示します。全てのクロックが与えられた時間有効である必要はありません。消費電力低減のため、20頁の「電力管理と休止形態」で記述される各種休止形態の使用によって、使われていない部分のクロックが停止できます。クロック系統は以下で詳述されます。



## 6.1.1. CPU クロック - clk<sub>CPU</sub>

CPUクロックはAVRコアの動作と関係する系統の部分に配給されます。このような部分の例は汎用レジスタ ファイル、ステータス レジスタ、スタック ポインタを保持するデータ メモリです。CPUクロックの停止はコアが一般的な操作や計算を実行することを禁止します。

# 6.1.2. I/O クロック - clk<sub>I/O</sub>

I/Oクロックは、タイマ/カウンタのようなI/O部の大部分で使われます。I/Oクロックは外部割り込み部でも使われますが、いくつかの外部割り込みは例えI/Oクロックが停止されても検出されることをこのような割り込みに許す非同期論理回路によって検出されることに注意してください。

## 6.1.3. フラッシュ クロック - clk<sub>FLASH</sub>

フラッシュ クロックはフラッシュ メモリ インターフェースの動作を制御します。このフラッシュ クロックは常にCPUクロックと同時に活動します。

## 6.1.4. A/D変換クロック - clk<sub>ADC</sub>

A/D変換器には専用のクロック範囲が提供されます。これはデジタル回路によって生成される雑音を低減するためにCPUとI/Oクロックの停止を許します。これはより正確なA/D変換結果を与えます。

#### 6.2. クロック元

このデバイスには右で示されるようにフラッシュ ヒュース ビットによって選択可能な後続のクロック元選択があります。選択したクロック元からのクロックはAVRクロック発生器への入力で、適切な単位部へ配給されます。

各クロック選択に対する様々な選択は次項で得られます。CPUがパワータ・ウンから起動するとき、選択したクロック元は命令実行開始前に安定な発振器動作を保証する起動時間に使われます。CPUがリセットから始まるとき、これらは通常動作開始前に安定電圧へ達するのを電源に許す付加遅延です。ウォッチト、ック・発振器はこの起動時間の実時間部のタインングに使われます。各計時完了に使われるウォッチト、ックが(WDT)発振器の各周期数は表6-2.で示されます。

| 3 | 表6-1. クロック種別選択 |          |
|---|----------------|----------|
|   | クロック種別         | CKSEL1,0 |
| ı | 128kHz内部発振器    | 11       |

| 128kHz内部発振器 | 11    |
|-------------|-------|
| 校正付き内蔵RC発振器 | 01,10 |
| 外部クロック信号    | 00    |
|             |       |

注: 1=非プログラム、0=プログラム

| 表6-2. WDT発振器代表計時完 | 表6-2. WDT発振器代表計時完了值、周期数 |  |  |  |  |  |  |  |  |
|-------------------|-------------------------|--|--|--|--|--|--|--|--|
| 代表的な計時完了時間        | 周期数                     |  |  |  |  |  |  |  |  |
| 4ms               | 512                     |  |  |  |  |  |  |  |  |
| 64ms              | 8K (8192)               |  |  |  |  |  |  |  |  |





## 6.2.1. 外部クロック信号

外部クロック元からデバイスを駆動するにはCLKIが**図6-2**.で示されるように駆動されるべきです。外部クロックでデバイスを走行するためにCKSELヒューズは'00'にプログラム(設定)されなければなりません。

このクロック元が選択されると、起動時間は表6-3.で示されるようにSUTヒューズによって決定されます。



表6-3. 外部クロック信号駆動用起動遅延時間選択表

| SUT1,0 | パワーダウンからの<br>起動遅延時間 | リセットからの<br>付加遅延時間 | 推奨使用法            |  |  |  |  |  |
|--------|---------------------|-------------------|------------------|--|--|--|--|--|
| 0 0    | 6×CK                | 14×CK             | 低電圧検出(BOD)リセット許可 |  |  |  |  |  |
| 0 1    | 6×CK                | 14×CK+4ms         | 高速上昇電源           |  |  |  |  |  |
| 1 0    | 6×CK                | 14×CK+64ms        | 低速上昇電源           |  |  |  |  |  |
| 1 1    | (予約)                |                   |                  |  |  |  |  |  |

外部クロックを供給するとき、MCUの安定な動作を保証するために供給したクロック周波数の急な変化を避けることが必要とされます。或るクロック周期から次への2%より大きな周波数変化は予測されない事態を引き起こします。このようなクロック周波数での変化中、MCUはリセットに保たれるのを保証することが必要とされます。

システム クロック前置分周器が安定な動作を保証しながら、内部クロック周波数の実行時変更の実現に使えることに注意してください。詳細については17頁の「システム クロック前置分周器」を参照してください。

## 6.2.2. 校正付き内蔵4.8/9.6MHz発振器

校正された内蔵RC発振器は9.6MHzまたは4.8MHzクロックを供給します。この周波数は3V,25℃での公称値です。この周波数がデバイス仕様(VCCに依存)を越える場合、起動中に内部周波数を8分周するために、CKDIV8ヒューズがプログラム(0)されなければなりません。より多くの詳細については17頁の「システム クロック前置分周器」をご覧ください。このクロックは表6-4.で示されるようにCKSELヒューズのプログラミングによってシステムクロックとして選択できます。選択したなら、外部部品なしで動作します。

表6-4. 校正付き内蔵RC発振器動作

| CKSEL1,0 | 公称周波数 (MHz) |
|----------|-------------|
| 10 (注1)  | 9.6         |
| 0 1      | 4.8         |

注1: デバイスはこの選択で出荷されます。

リセット中、ハート・ウェアが発振校正レシ、スタ(OSCCAL)に校正値バイトを設定し、これによってこの発振器を自動的に校正します。4.8MHzと9.6MHzに対して独立した校正バイトがありますが、リセット中に1つだけが自動的に設定されます(70頁の「校正値バイト」項をご覧ください)。これは4.8MHzと9.6MHz間の違いが内部クロック分周器だけだからです。

ソフトウェアからOSCCALレシブスタを変更することによって(18頁の「**発振校正レジスタ** (OSCCAL)」参照)、工場校正を使うよりも高い精度を得ることができます。78頁の「校正付き内蔵RC発振器精度」をご覧ください。

この発振器がチップ(システム)クロックとして使われるとき、ウォッチドッグ発振器は未だウォッチドッグタイマとリセット付加遅延タイマに使われます。予め設定された校正値のより多くの情報については70頁の「校正バイト」項をご覧ください。

この発振器が選択されると、起動時間は表6-5.で示されるようにSUTヒューズによって決定されます。

#### 表6-5. 校正付き内蔵RC発振器用起動遅延時間選択表

| SUT1,0  | パワーダウンからの<br>起動遅延時間 | リセットからの<br>付加遅延時間          | 推奨使用法            |  |  |  |  |  |  |
|---------|---------------------|----------------------------|------------------|--|--|--|--|--|--|
| 0 0     | 6×CK                | 14×CK                      | 低電圧検出(BOD)リセット許可 |  |  |  |  |  |  |
| 0 1     | 6×CK                | 14×CK+4ms                  | 高速上昇電源           |  |  |  |  |  |  |
| 10 (注1) | 6×CK                | $14 \times \text{CK+64ms}$ | 低速上昇電源           |  |  |  |  |  |  |
| 11      |                     | (予約)                       |                  |  |  |  |  |  |  |

注1: デバイスはこの選択で出荷されます。

#### 6.2.3. 128kHz内部発振器

128kHz内部発振器は128kHzのクロックを供給する低電力発振器です。この周波数は供給電圧、温度、1群の変量に依存します。この クロックはCKSELヒューズを'11'にプログラミング(設定)することによってシステム クロックとして選択できます。

このクロック元が選択されると、起動時間は表6-6.で示されるようにSUTヒューズによって決定されます。

| 表6-6. 128kHz内    | 邻癸排   | 長器用:   | 記動遅 | 延時間 | 選択表 |
|------------------|-------|--------|-----|-----|-----|
| 120 U. 12UM12[7] | コレフレル | 以カロノリノ | 巴利吐 | ᄣᄞᄓ |     |

| SUT1,0 | パワーダウンからの<br>起動遅延時間 | リセットからの<br>付加遅延時間 推奨使用法    |                  |  |  |  |  |  |  |  |
|--------|---------------------|----------------------------|------------------|--|--|--|--|--|--|--|
| 0 0    | 6×CK                | 14×CK                      | 低電圧検出(BOD)リセット許可 |  |  |  |  |  |  |  |
| 0 1    | 6×CK                | $14 \times \text{CK+4ms}$  | 高速上昇電源           |  |  |  |  |  |  |  |
| 1 0    | 6×CK                | $14 \times \text{CK+64ms}$ | 低速上昇電源           |  |  |  |  |  |  |  |
| 1 1    |                     | (予約)                       |                  |  |  |  |  |  |  |  |

## 6.2.4. 既定のクロック元

このデバイスはCKSEL=10, SUT=10, CKDIV8=プログラム(0)で出荷されます。従って既定クロック元設定は最長起動時間の9.6MHzで走行する内蔵RC発振器、8で前置分周する初期システム クロックです。この既定設定は全ての使用者が実装または並列書き込み器を使って、それらを希望したクロック元設定にできることを保証します。

## 6.3. システム クロック前置分周器

ATtiny13のシステム クロックは18頁の「**クロック前置分周レシ、スタ(CLKPR)**」の設定によって分周できます。この特徴(機能)は必要とされる処理能力が低い時の消費電力削減に使えます。これは全クロック種別で使え、CPUと全ての同期周辺機能のクロック周波数に影響を及ぼします。clk<sub>CPU</sub>、clk<sub>FLASH</sub>、clk<sub>I/O</sub>、clk<sub>ADC</sub>は19頁の表6-8.で示された値によって分周されます。

## 6.3.1. 切り替え時間

前置分周設定間を切り替えるとき、システム クロック前置分周器は中間(経過途中)の周波数が直前の設定に対応するクロック周波数または 新規設定に対応するクロック周波数のどちらよりも高くなく、クロック シクテムで不具合が起きないことを保証します。

前置分周器として実行するリプル カウンタは分周されないクロック周波数で走行し、CPUのクロック周波数より速いかもしれません。従って例え(カウンタ値が)読めるとしても、前置分周器の状態を決めることはできず、1から他へのクロック分周値切り替えを行う正確な時間は必ずしも予測できません。

CLKPS値が書かれる時から新規クロック周波数が活性(有効)になる前にT1+T2~T1+2×T2間かかります。この間で2つの有効なクロック端が生成されます。ここでのT1は直前のクロック周期、T2は新規前置分周器設定に対応する周期です。





## 6.4. クロック関係レジスタ

## 6.4.1. 発振校正レジスタ (Oscillator Calibration Register) OSCCAL

| ピット         | 7            | 6    | 5    | 4    | 3    | 2    | 1    | 0    |        |  |  |  |
|-------------|--------------|------|------|------|------|------|------|------|--------|--|--|--|
| \$31 (\$51) | -            | CAL6 | CAL5 | CAL4 | CAL3 | CAL2 | CAL1 | CAL0 | OSCCAL |  |  |  |
| Read/Write  | R            | R/W  |        |  |  |  |
| 初期値         | 0 デバイス固有の校正値 |      |      |      |      |      |      |      |        |  |  |  |

#### ■ ビット7 - Res: 予約 (Reserved)

このビットは予約されており、常に0として読まれます。

#### ■ ビット6~0 - CAL6~0:発振校正値 (Oscillator Calibration Value)

このアドレスへの校正ハ・小書き込みは発振器周波数の偏差処理を省くために内蔵発振器を調整します。これはチップ・リセット中、自動的に行われます。OSCCALが0の時に最低利用可能周波数が選択されます。このレシ・スタへの以外の値を書くことは内蔵発振器の周波数を増加します。このレシ・スタへの\$7F書き込みは最高使用可能周波数にします。校正付き発振器はフラッシュメモリとEEPROMのアクセス時間に使われます。フラッシュメモリまたはEEPROMが書かれる場合、公称周波数より上へ10%を越えて校正してはいけません。そうでなければ、フラッシュメモリまたはEEPROM書き込みは失敗するかもしれません。この発振器は9.6MHzまたは4.8 MHzへの校正を意

| 表6-7. 内蔵RC発振器周波数範囲 |             |      |  |  |  |  |  |  |  |
|--------------------|-------------|------|--|--|--|--|--|--|--|
| OSCCAL値            | 公称周波数に対する割合 |      |  |  |  |  |  |  |  |
|                    | 最小          | 最大   |  |  |  |  |  |  |  |
| \$00               | 50%         | 100% |  |  |  |  |  |  |  |
| \$3F               | 75%         | 150% |  |  |  |  |  |  |  |
| \$7F               | 100%        | 200% |  |  |  |  |  |  |  |

図したものであることに注意してください。表6-7.で示されるような他の値への調整は保証されません。

校正付き内蔵RC発振器を校正するとき、MCUの安定な動作を保証するために大きな段階での校正値変更を避けてください。或るクロック周期から次への2%より大きな周波数変化は予測されない事態を引き起こします。OSCCAL変更は各校正について\$20を越えるべきではありません。

## 6.4.2. クロック前置分周レジスタ (Clock Prescale Register) CLKPR

| ピット         | 7      | 6 | 5 | 4 | 3      | 2      | 1      | 0      | _     |
|-------------|--------|---|---|---|--------|--------|--------|--------|-------|
| \$26 (\$46) | CLKPCE | - | - | - | CLKPS3 | CLKPS2 | CLKPS1 | CLKPS0 | CLKPR |
| Read/Write  | R/W    | R | R | R | R/W    | R/W    | R/W    | R/W    |       |
| 初期値         | 0      | 0 | 0 | 0 | 内容参照   | 内容参照   | 内容参照   | 内容参照   |       |

## ■ ビット7 - CLKPCE: クロック分周値変更許可 (Clock Prescaler Change Enable)

CLKPSビットの変更を許可するためにCLKPCEビットは論理1を書かれなければなりません。CLKPCEビットは同時にCLKPRの他の全ビットが0を書かれる時だけ更新されます。CLKPCEは書き込み後4クロック周期またはCLKPSビット書き込み時、ハードウェアによって解除(0)されます。この制限時間(4クロック周期)内のCLKPCEビット再書き込みは制限時間の延長もCLKPCEビットの解除(0)も行いません。

## ■ L\*ット6~4 - Res: 予約 (Reserved)

これらのビットは予約されており、常に0として読まれます。

# ■ ビット3~0 - CLKPS3~0: クロック分周値選択 (Clock Prescaler Select Bits 3~0)

これらのビットは選択したクロック元と内部システム クロック間の分周値を定義します。これらのビットは応用の必要条件に合わせた各種クロック周波数を実行時に書けます。分周値が使われると、分周器はMCUへの主クロックを分周し、全ての同期周辺機能の速度が減じられます。分周値は次頁の表6-8.で与えられます。

予期せぬクロック周波数の変更を防ぐため、CLKPSビットの変更は次の特別な書き込み手順に従わなければなりません。

- 1. クロック分周値変更許可(CLKPCE)ビットに1、CLKPR内の他の全ビットに0を書きます。
- 2. (次からの)4周期以内にCLKPCEビットをOとする欲したCLKPS値を書きます。

前置分周器設定変更時、書き込み手続きが割り込まれないことを保証するため、割り込みは禁止されなければなりません。

CKDIV8ビュース、がCLKPSビットの初期値を決めます。CKDIV8が非プログラム(1)にされると、CLKPSビットは、0000、にリセットされます。 CKDIV8がプログラム(0)されると、CLKPSビットは起動時に8分周を与える、0011、にリセットされます。現在の動作条件でデバイスの最高周波数より高い周波数のクロック元を選択した場合、この機能が使われるべきです。CKDIV8ビュース、設定に拘らず、どの値もCLKPSビットへ書けることに注意してください。応用ソフトウェアは現在の動作条件でデバイスの最高周波数より高い周波数のクロック元を選択した場合、充分な分周値が選択されることを保証しなければなりません。このデバイスはCKDIV8ビュースがプログラム(0)で出荷されます。

| 表6-8. クロック前置分 | 表6-8. クロック前置分周選択 |   |   |   |    |    |    |     |     |      |   |   |   |   |   |   |  |
|---------------|------------------|---|---|---|----|----|----|-----|-----|------|---|---|---|---|---|---|--|
| CLKPS3        |                  | 0 |   |   |    |    |    |     |     |      | 1 |   |   |   |   |   |  |
| CLKPS2        |                  | ( | ) |   | 1  |    |    |     |     | 0    |   |   |   | 1 |   |   |  |
| CLKPS1        | (                | ) | 1 |   | 0  |    | 1  |     | (   | 0 1  |   | L | 0 |   | 1 |   |  |
| CLKPS0        | 0                | 1 | 0 | 1 | 0  | 1  | 0  | 1   | 0   | 1    | 0 | 1 | 0 | 1 | 0 | 1 |  |
| 分周値(数)        | 1                | 2 | 4 | 8 | 16 | 32 | 64 | 128 | 256 | (予約) |   |   |   |   |   |   |  |





# 7. 電力管理と休止形態

高機能と産業的に先行するコート、効率は低電力の応用に対してAVRマイクロコントローラを理想的に選択させます。加えて、休止形態は応用でMCU内の未使用部を一時停止することを可能にし、それによって節電します。AVRは応用で必要な消費電力に仕立てることを使用者に許す様々な休止形態を提供します。

## 7.1. 休止形態種別

15頁の図6-1.はATtiny13の各種クロック系統とその配給を示します。この図は適切な休止形態を選択する助けになります。表7-1.は異なる休止形態とそれらの起動元を示します。

表7-1. 各休止形態に於ける動作クロック範囲と復帰起動要因

| Γ |                                    |            | 動作クロッ        | ク範囲       |            | 発振器動作        | <b>復帰起動要因</b> (割り込み) |                   |         |            |           |  |  |
|---|------------------------------------|------------|--------------|-----------|------------|--------------|----------------------|-------------------|---------|------------|-----------|--|--|
|   | 休止種別                               | clk<br>CPU | clk<br>FLASH | clk<br>10 | clk<br>ADC | 主クロック<br>供給元 | INTO<br>ピン変化         | SPM/EEPROM<br>操作可 | A/D変換完了 | その他<br>I/O | ウォッチト゛ック゛ |  |  |
|   | アイドル                               |            |              | 0         | 0          | 0            | 0                    | 0                 | 0       | 0          | 0         |  |  |
| 1 | A/D変換雑音低減                          |            |              |           | 0          | 0            | 1                    | 0                 | 0       |            | 0         |  |  |
|   | ハ <sup>°</sup> ワータ <sup>*</sup> ウン |            |              |           |            |              | 1                    |                   |         |            | $\circ$   |  |  |

① INT0についてはレベル割り込みだけです。

3つの休止形態の何れかへ移行するにはMCU制御レシ、スタ(MCUCR)の休止許可(SE)ビットが論理1を書かれ、SLEEP命令が実行されなければなりません。MCUCRの休止種別選択(SM1,0)ビットはSLEEP命令によって活性(有効)にされる休止形態(アイドル、A/D変換雑音低減、ハプワーダウン)のどれかを選びます。一覧については22頁の表7-2.をご覧ください。

MCUが休止形態中に許可した割り込みが起こると、MCUは起動します。その時にMCUは起動時間に加えて4周期停止され、割り込みルーチンを実行し、そしてSLEEP命令の次の命令から実行を再開します。デバイスが休止から起動するとき、レジスタファイルとSRAMの内容は変えられません。休止形態中にリセットが起こると、MCUは起動し、リセット ベクタから実行します。

レヘールで起動した割り込みが起動復帰に使われる場合、MCUを起動(とMCUがその割り込み処理ルーチンへ移行)するには、変更したレベルが一定時間保持されなければならないことに注意してください。詳細については30頁の「外部割り込み」を参照してください。

#### 7.1.1. アイドル動作

休止種別選択(SM1,0)ビットが、'00'を書かれるとき、SLEEP命令はMCUをアイドル動作へ移行させて、CPUを停止しますが、アナロケド較器、A/D変換器、タイマ/カウンタ、ウォッチドッケ、割り込み機構の継続動作を許します。この休止形態は基本的にclkCPUとclkFLASHを停止する一方、他のクロックに走行を許します。

アイドル動作はMCUにタイマ溢れなどの内部割り込みだけでなく、外部で起動された割り込みからの起動も可能にします。アナロゲ比較器割り込みからの起動が必要とされないなら、アナロゲ比較器制御/状態レジスタ(ACSR)のアナロゲ比較器禁止(ACD)ビットを設定(1)することによってアナロゲ比較器を電源断にできます。これはアイドル動作での消費電力を削減します。A/D変換が許可されるなら、この動作に移行すると変換が自動的に始まります。

#### 7.1.2. A/D変換雑音低減動作

SM1,0ビットが'01'を書かれるとき、SLEEP命令はMCUをA/D変換雑音低減動作へ移行させ、CPUを停止しますが、A/D変換器、外部割り込み、ウォッチドッグの(許可されていれば)継続動作を許します。この休止形態は基本的にclk<sub>I/O</sub>, clk<sub>CPU</sub>, clk<sub>FLASH</sub>を停止する一方、他のクロックに走行を許します。

これはA/D変換に対する雑音環境を改善し、より高い分解能の測定を可能にします。A/D変換器が許可されている場合、この動作に移行すると、変換が自動的に始まります。A/D変換完了割り込みからの他、外部リセット、ウォッチドッグ リセット、低電圧検出(BOD)リセット、SPM/EEPROM操作可割り込み、INTOの外部レヘル割り込み、ピン変化割り込みだけが、A/D変換雑音低減動作からMCUを起動できます。

# 7.1.3. パワーダウン動作

SM1,0ビットが、10'を書かれると、SLEEP命令はMCUをパワーダウン動作へ移行させます。この動作では発振器が停止される一方、外部割り込み、ウォッチドッグ機能は(許可されていれば)継続して動作します。外部リセット、ウォッチドッグ機能は(許可されていれば)継続して動作します。外部リセット、ウォッチドッグリセット、低電圧検出(BOD)リセット、INTOの外部レヘル割り込み、ピン変化割り込みだけがMCUを起動できます。この休止形態は生成した全てのクロックを停止し、非同期部の動作だけを許します。

# 7.2. 消費電力の最小化

これらはAVRが制御するシステムで消費電力の最小化を試みる時に考慮するためのそれぞれの検討点です。一般的に休止形態は可能な限り多く使われるべきで、休止種別は動作するデバイスの機能が可能な限り少なくなるために選択されるべきです。必要とされない全ての機能は禁止されるべきです。特に次の機能部は最低可能消費電力の達成を試みるとき、特別な考慮を必要とするでしょう。

## 7.2.1. A/D変換器 (ADC)

許可したなら、A/D変換器は全休止形態で許可されます。節電のため、休止形態の何れかへ移行する前にA/D変換器は禁止されるべきです。A/D変換器がOFFそして再びONに切り替えられると、次の(最初の)変換は延長された(初回)変換になります。A/D変換器操作の詳細については54頁の「A/D変換器」を参照してください。

## 7.2.2. アナログ比較器

アイドル動作へ移行するとき、アナロゲ比較器は使われないなら、禁止されるべきです。A/D変換雑音削減動作へ移行するとき、アナロゲ比較器は禁止されるべきです。その他の休止形態でのアナロゲ比較器は自動的に禁止されます。しかしアナロゲ比較器が入力として内部基準電圧を使う設定の場合、全休止形態でアナロゲ比較器は禁止されるべきです。さもなければ内部基準電圧は休止形態と無関係に許可されます。アナロゲ比較器設定法の詳細については52頁の「アナロゲ比較器」を参照してください。

## 7.2.3. 低電圧検出器 (BOD)

低電圧検出器(BOD)が応用で必要とされないなら、この単位部はOFFにされるべきです。低電圧検出器がBODLEVELヒューズによって許可されていると全休止形態で許可され、故に常時電力を消費します。これはより深い休止形態での総消費電流にとって重要な一因になります。低電圧検出器(BOD)設定法の詳細については24頁の「低電圧検出(BOD)」を参照してください。

## 7.2.4. 内部基準電圧

内部基準電圧は低電圧検出器(BOD)、アナログ比較器、A/D変換器によって必要とされる時に許可されます。これら単位部が上の項で記述されたように禁止されると、内部基準電圧は禁止され、電力を消費しません。再び許可する場合、この出力が使われる前に使用者は基準電圧へ起動(安定時間)を与えなければなりません。基準電圧が休止形態でON保持される場合、この出力は直ちに使えます。起動時間の詳細については25頁の「内部基準電圧」を参照してください。

## 7.2.5. ウォッチト・ック・タイマ

ウォッチト、ック、タイマが応用で必要とされないなら、この単位部はOFFにされるべきです。ウォッチト、ック、タイマが許可されていると全休止形態で許可され、故に常時電力を消費します。これはより深い休止形態での総消費電流にとって重要な一因になります。ウォッチト、ック、タイマ 設定法の詳細については25頁の「ウォッチト、ック、タイマ」を参照してください(訳注:原書に対して参照先修正)。

## 7.2.6. ホート ピン

休止形態へ移行するとき、全てのポート ピンは最小電力使用に設定されるべきです。最も重要なことはその時にピンが抵抗性負荷を駆動しないのを保証することです。I/Oクロック(clkɪ/O)とA/D変換クロック(clkADC)の両方が停止される休止形態ではデバイスの入力緩衝部が禁止されます。これは必要とされない時に入力論理回路によって電力が消費されないことを保証します。いくつかの場合で入力論理回路は起動条件を検出するために必要とされ、その時は許可されます。どのピンが許可されるかの詳細については34頁の「デジタル入力許可と休止形態」を参照してください。入力緩衝部が許可され、入力信号が浮いている状態のままか、またはアナログ信号電圧がVCC/2付近の場合、入力緩衝部は過大な電力を消費するでしょう。

アナログ・入力ピンに対するデジタル入力緩衝部は常に禁止されるべきです。入力ピンでのVCC/2付近のアナログ信号入力は活動動作でも 重要な電流を引き起こし得ます。デジタル入力緩衝部はデジタル入力禁止レジスタの(DIDRO)の書き込みによって禁止できます。詳細に ついては53頁と62頁の「デジタル入力禁止レジスタの(DIDRO)」を参照してください。





# 7.3. 電力管理用レジスタ

# 7.3.1. MCU制御レジスタ (MCU Control Register) MCUCR

このMCU制御レシブスタは電力管理用の制御ビットを含みます。

| ピット         | 7 | 6   | 5   | 4   | 3   | 2 | 1     | 0     |       |
|-------------|---|-----|-----|-----|-----|---|-------|-------|-------|
| \$35 (\$55) | - | PUD | SE  | SM1 | SM0 | - | ISC01 | ISC00 | MCUCR |
| Read/Write  | R | R/W | R/W | R/W | R/W | R | R/W   | R/W   |       |
| 初期値         | 0 | 0   | 0   | 0   | 0   | 0 | 0     | 0     |       |

## ■ ビット5 - SE: 休止許可 (Sleep Enable)

SLEEP命令が実行される時にMCUを休止形態へ移行させるには、休止許可(SE)ビットが論理1を書かれなければなりません。MCUの目的外休止形態移行を避けるため、SLEEP命令実行直前に休止許可(SE)ビットを設定(1)し、起動後直ちに解除(0)することが推奨されます。

## ■ ビット4,3 - SM1,0: 休止種別選択 (Sleep Mode Select Bits 1 and 0)

これらのビットは表7-2.で示される利用可能な3つの休止形態の1つを選択します。

| 表7-2. 亿 | 表7-2. 休止形態種別選択                          |             |  |  |  |  |  |  |  |  |  |
|---------|-----------------------------------------|-------------|--|--|--|--|--|--|--|--|--|
| SM1     | 11 二 // / / / / / / / / / / / / / / / / |             |  |  |  |  |  |  |  |  |  |
| 0       | 0                                       | アイドル動作      |  |  |  |  |  |  |  |  |  |
| 0       | 1                                       | A/D変換雑音低減動作 |  |  |  |  |  |  |  |  |  |
| 1       | 0                                       | パプーダウン動作    |  |  |  |  |  |  |  |  |  |
| 1       | 1                                       | (予約)        |  |  |  |  |  |  |  |  |  |

## ■ ビット2 - Res: 予約 (Reserved)

このビットは予約されており、常に0として読まれます。

# 8. システム制御とリセット

## 8.1. AVRのリセット

リセット中、全てのI/Oレシ、スタはそれらの初期値に設定され、プログラムはリセット、グクタから実行を開始します。 リセット、グクタに配置される命令は、きっとリセット処理ルーチンへの無条件相対分岐(RJMP)命令でしょう。 プログラムが決して割り込み元を許可しないなら、割り込み、グタは使われず、これらの位置に通常のプログラムコードが配置できます。 図8-1.の回路構成図はリセット論理回路を示します。 79頁の「システムとリセットの特性」はリセット回路の電気的特性を定義します。



AVRのI/Oポートはリセット元が有効になると直ちにそれらの初期状態にリセットされます。これはどのクロック元の走行も必要ありません。全てのリセット元が無効にされてしまった後、遅延計数器(タイマ)が始動され、内部リセットを引き伸ばします。これは通常動作開始前に安定電圧へ達することを電源に許します。遅延タイマの遅延時間はSUTヒューズとCKSELヒューズを通して使用者によって定義されます。この遅延時間についての各種選択は15頁の「クロック元」で示されます。

#### 8.2. リセット元

ATtiny13には次の4つのリセット元があります。

- ・電源ONリセット・・・・・ 供給電圧が電源ONリセット閾値電圧(VPOT)以下でMCUがリセットされます。
- ・**外部リセット・・・・・・・**RESETビンが最小パルス幅以上Lowレベルに保たれると、MCUがリセットされます。
- ・ウォッチドッグリセット・・・ウォッチドッグシステム リセット動作が許可され、ウォッチドッグタイマが終了すると、MCUがリセットされます。
- ・低電圧リセット・・・・・ 低電圧検出器(BOD)が許可され、供給電圧(VCC)が低電圧検出電圧(VBOT)以下でMCUがリセットされます。





## 8.2.1. 電源ONリセット

電源ONJセット(POR)パルスはチップ上の検出回路によって生成されます。検出電圧は79頁の「システムとリセットの特性」で定義されます。POR信号はVCCが検出電圧以下の時は必ず活性(有効)にされます。POR回路は供給電圧異常検出は勿論、始動リセットの起動にも使えます。

電源ONJセット回路はデバイスが電源投入でJセットされることを保証します。電源ONJセット閾値電圧への到達はVCCの上昇後にデバイスがどのくらいJセットを保つかを決める遅延計数器(タイマ)を起動します。VCCがこの検出電圧以下に低下すると、Jセット信号はどんな遅延もなく再び有効にされます。





#### 8.2.2. 外部リセット

内部リセット

許可したなら、外部リセットはRESETピンのLowレヘールによって生成されます。例えクロックが走行してなくても最小ハールス幅(79頁の「システムとリセットの特性」参照)以上のリセットハールスはリセットを生成します。短すぎるハールスはリセットの生成が保証されません。印加された信号の上昇がリセット関値電圧(VRST)に達すると(遅延タイマが起動され)、遅延タイマは遅延時間(trout)経過後にMCUを始動します。



## 8.2.3. 低電圧(ブラウンアウト)検出リセット

ATtiny13には固定化された起動(検出)電圧と比較することによって動作中のVCCを監視するチップ。上の低電圧検出(BOD)回路があります。BODの起動電圧はBODLEVELtュース。によって選択できます。この起動電圧はスパイク対策BODを保証するためにヒステリシスを持ちます。検出電圧のヒステリシスはVBOT+=VBOT+VHYST/2、VBOT-=VBOT-VHYST/2と解釈されるべきです。

BODが許可され、VCCが起動電圧以下の値に下降すると(図8-5.のVBOT-)、低電圧リセットが直ちに有効とされます。VCCが起動電圧以上に上昇すると(図8-5.のVBOT+)、(遅延タイマが起動されて)遅延タイマは遅延時間(tTOUT)経過後にMCUを始動します。



BOD回路は電圧が79頁の「システムとリセットの特性」で与えられるtBOD時間より長く起動電圧以下に留まる場合のみ、VCCでの低下を検出します。

## 8.2.4. ウォッチト・ック・リセット

ウォッチト、ック・時間経過時、(内部的に)1CK周期幅の短いリセット ハ・ルスを生成します。このハ・ルスの下降端で遅延タイマは遅延時間(trout)の計時を始めます。ウォッチト、ック・タイマ操作の詳細については25頁を参照してください。



## 8.3. 内部基準電圧

ATtiny13は内部基準電圧が特徴です。この基準電圧は低電圧検出(BOD)に使われ、A/D変換やアナログ比較器の入力としても使えます。

# 8.3.1. 基準電圧許可信号と起動時間

この基準電圧には使われるべき方法に影響を及ぼすかもしれない起動時間があります。この起動時間は79頁の「システムとリセットの特性」で与えられます。節電のために、この基準電圧は常にONではありません。この基準電圧は次の状態中ONです。

- 1. 低電圧検出リセット許可時 (BODLEVEL1,0ヒュース、のプログラム(0)により)
- 2. アナログ比較器基準電圧接続時 (アナログ比較器制御/状態レジスタ(ACSR)の基準電圧入力選択(ACBG)=1)
- 3. A/D変換部動作許可時 (A/D変換制御/状態レジスタA(ADCSRA)のA/D動作許可(ADEN)=1)

従って低電圧検出(BOD)が許可されていないと、ACBGの設定(=1)またはA/D変換部許可(ADEN=1)後、使用者はアナログ比較器またはA/D変換器出力が使われる前に基準電圧へ起動時間を与えなければなりません。パワーダウン動作での消費電力を減らすため、使用者はパワーダウン動作へ移行する前に基準電圧がOFFされるのを保証することで上の3つの状態を避けられます。

## 8.4. ウォッチトック タイマ

ATtiny13は強化されたウォッチト、ッグ。タイマ(WDT)を持ちます。ウォッチト、ッグ。タイマ(WDT)はチップ。上の独立した128kHz発振器の間隔で計時するタイマです。WDTは計数器が与えられた計時完了値に達した時に割り込みまたはシステムリセットを生じます。通常動作では計時完了値へ達する前に計数器を再始動するために、システムはウォッチト、ッグ・リセット(WDR)命令を使うる必要があります。システムが計数器を再始動しなければ、割り込みまたはシステムリセットが起こるでしょう。

割り込み動作種別では、タイマ計時完了時にWDTが割り込みを生じます。この割り込みは休止形態からデバイスを起動するためや、一般的なシステムタイマとしても使えます。1つの例は或る動作に対して許された最大時間を制限することで、その動作が予測されたより長く走行する時に割り込みを生じます。システムリセット動作種別ではタイマ計時完了時にWDTがリセットを生じます。これは一般的にコード外走行の場合の中断を防止するのに使われます。3つ目の動作種別は先に割り込みを生じ、その後にシステムリセット動作種別に切り替えることで、他の2つの動作種別の組み合わせとなる、割り込み及びシステムリセット動作種別です。この動作種別は例えばシステムリセットに先立って重要なパラメータを保存することによって安全な停止を許します。



ウォッチト、ック、常時ON(WDTON)ヒュース、のフ。ロク・ラム(0)はウォッチト、ック、タイマをシステムリセット動作種別に強制します。このヒュース、のフ。ロク・ラム(0)でシステムリセット動作(WDE)ヒ、ットと割り込み動作(WDTIE)ヒ、ットは各々、、1と、0、に固定されます。更にフ。ログ・ラム保護を保証するためにウォッチト、ック、設定の変更は時間制限手順に従わなければなりません。システムリセット許可(WDE)の解除と計時完了時間設定の変更についての手順は次のとおりです。

- 1. 同じ操作(命令)でウォッチドッグ変更許可(WDCE)とWDEに論理1を書きます。WDEビットの直前の値に拘らず、論理1がWDEに書かれなければなりません。
- 2. 次からの4クロック周期内に同じ操作(命令)で欲したWDEとウォッチドッグタイマ前置分周選択(WDP3~0)ビットを書きますが、WDCEビットは解除(0)されてです。これは1操作(命令)で行わなければなりません。





次のコート・例はウォッチト・ッグ、タイマをOFFに切り替えるアセンフ・リ言語とC言語の関数を示します。本例は(例えば全割り込み禁止によって)割り込みが制御され、それ故これらの関数実行中に割り込みが起きない前提です。

```
アセンブリ言語プログラム例
WDT OFF:
                                                       ;全割り込み禁止
            CLI
            WDR
                                                       ;ウォッチト`ック` タイマ リセット
                   R16, MCUSR
                                                       ;MCUSR値を取得
            ΤN
            ANDI
                   R16, ~ (1<<WDRF)
                                                       ;WDRF論理0値を取得
                                                       ;ウォッチト、ック、リセット フラク (WDRF)解除
            OUT
                   MCUSR, R16
                   R16, WDTCR
                                                       ;現WDTCR値を取得(他ビット保護用)
            IN
                   R16, (1<<WDCE) | (1<<WDE)
                                                       ;WDCEとWDE論理1値を設定
            ORI
            OUT
                   WDTCR, R16
                                                       ;WDCEとWDEに論理1書き込み
            LDI
                   R16, (0<<WDE)
                                                       ;WDE論理0値を取得
            OUT
                   WDTCR, R16
                                                       ;ウォッチト・ック・禁止
            SEI
                                                       ;全割り込み許可
            RET
                                                       ;呼び出し元へ復帰
C言語プログラム例
void WDT_off(void)
            __disable_interrupt();
                                                       /* 全割り込み禁止 */
                                                       /* ウォッチト゛ック゛ タイマ リセット */
            __watchdog_reset();
            MCUSR &= ^{\sim} (1<<WDRF);
                                                       /* ウォッチト、ック、リセット フラク(WDRF)解除 */
            WDTCR = (1 << WDCE) | (1 << WDE);
                                                       /* WDCEとWDEに論理1書き込み */
            WDTCR = 0x00;
                                                       /* ウォッチト・ック 禁止 */
            __enable_interrupt();
                                                       /* 全割り込み許可 */
```

注: このコート 例はデバイス定義ファイルがインクルート されることが前提です。

注: ウォッチト、ック、が偶然に許可されると(例えばポインタの逸脱や低電圧(ブラウンアウト)状態)、デバイスはリセットし、ウォッチト、ック、は許可に留まります。コート、がウォッチト、ック、操作の初期設定をしなければ、これは計時完了の無限繰り返しを引き起こすかもしれません。この状態を避けるため、応用ソフトウェアは例えウォッチト、ック、が使われなくても、初期化ルーチンでWDRFフラグとWDE制御ビットを常に解除(0)すべきです。

次のコード例はウォッチドッグタイマの計時完了値変更用のアセンブリ言語とC言語の関数を示します。

```
アセンブリ言語プログラム例
WDT_PRS:
           CLT
                                                     ;全割り込み禁止
                                                     ;ウォッチトック タイマ リセット
           WDR
           IN
                  R16, WDTCR
                                                     ;現WDTCR値を取得(他ビット保護用)
           ORT
                  R16, (1<<WDCE) | (1<<WDE)
                                                     ;WDCEとWDE論理1値を設定
                                                     ;WDCEとWDEに論理1書き込み
           OUT
                  WDTCR, R16
                  R16, (1<<WDE) | (1<<WDP2) | (1<<WDP0)
           LDI
                                                     ;WDE=1,計時間隔=0.5s値を取得
                                                     ;0.5s監視間隔リセット動作開始
           OUT
                  WDTCR, R16
           SEI
                                                     ;全割り込み許可
                                                     ;呼び出し元へ復帰
           RET
C言語プログラム例
void WDT_off(void)
           __disable_interrupt();
                                                     /* 全割り込み禁止 */
                                                     /* ウォッチト・ック・タイマ リセット */
             _watchdog_reset();
           WDTCR = (1 << WDCE) | (1 << WDE);
                                                     /* WDCEとWDEに論理1書き込み */
           WDTCR = (1 << WDE) | (1 << WDP2) | (1 << WDP0);
                                                     /* 0.5s 監視間隔リセット動作開始 */
                                                     /* 全割り込み許可 */
           __enable_interrupt();
}
注: このコード例はデバイス定義ファイルがインクルードされることが前提です。
```

注: ウォッチドッグタイマ前置分周選択(WDP3~0)ビットの変更がより短い計時完了周期に変わってしまう結果になり得るため、ウォッチドッグ タイマはWDPビットのどんな変更にも先立ってリセット(WDR命令)されるべきです。

# 8.5. リセット関係レジスタ

## 8.5.1. MCU状態レシ、スタ (MCU Status Register) MCUSR

MCU状態レジスタはどのリセット元がMCUリセットを起こしたかの情報を提供します。

| ピット         | 7 | 6 | 5 | 4 | 3    | 2    | 1     | 0    |       |
|-------------|---|---|---|---|------|------|-------|------|-------|
| \$34 (\$54) | _ | - | - | - | WDRF | BORF | EXTRF | PORF | MCUSR |
| Read/Write  | R | R | R | R | R/W  | R/W  | R/W   | R/W  |       |
| 初期値         | 0 | 0 | 0 | 0 | 内容参照 | 内容参照 | 内容参照  | 内容参照 |       |

## ■ L\*ット7~4 - Res: 予約 (Reserved)

これらのビットは予約されており、常に0として読まれます。

#### ■ ビット3 - WDRF: ウォッチドック゛リセット フラク゛(Watchdog Reset Flag)

このビットはウォッチドッグ リセットが起こると設定(1)されます。このビットは電源ONリセットまたは、このフラグへの論理0書き込みによってリセット(0)されます。

#### ■ ビット2 - BORF: 低電圧リセット フラク (Brown-Out Reset Flag)

このビットは低電圧リセットが起こると設定(1)されます。このビットは電源ONリセットまたは、このフラグへの論理0書き込みによってリセット(0)されます。

## ■ ビット1 - EXTRF:外部リセット フラク (External Reset Flag)

このビットは外部リセットが起こると設定(1)されます。このビットは電源ONリセットまたは、このフラグへの論理0書き込みによってリセット(0)されます。

## ■ ビット0 - PORF: 電源ONリセット フラク (Power-on Reset Flag)

このビットは電源ONリセットが起こると設定(1)されます。このビットはこのフラグへの論理0書き込みによってのみリセット(0)されます。

リセット条件の確認にリセット フラグを使うために使用者はプログラム内で可能な限り早くMCUSRを読み、それから解除(0)すべきです。別の リセットが起こる前にこのレジスタが解除(0)されると、リセット元はリセット フラグを調べることによって得られます。





## 8.5.2. ウォッチトック タイマ制御レシ スタ (Watchdog Timer Control Register) WDTCR

| ピット         | 7     | 6     | 5    | 4    | 3   | 2    | 1    | 0    | _     |
|-------------|-------|-------|------|------|-----|------|------|------|-------|
| \$21 (\$41) | WDTIF | WDTIE | WDP3 | WDCE | WDE | WDP2 | WDP1 | WDP0 | WDTCR |
| Read/Write  | R/W   | R/W   | R/W  | R/W  | R/W | R/W  | R/W  | R/W  |       |
| 初期値         | 0     | 0     | 0    | 0    | 不定  | 0    | 0    | 0    |       |

## ■ ビット7 - WDTIF: ウォッチドッグ割り込み要求フラグ (Watchdog Timer Interrupt Flag)

ウォッチト、ック、タイマが割り込みに設定され、ウォッチト、ック、タイマで計時完了が起こると、このヒ、ットが設定(1)されます。対応する割り込み処理 へ、クタを実行すると、WDTIFはハート・ウェアによって解除(0)されます。代わりにWDTIFはこのフラク、への論理1書き込みによっても解除(0)されます。ステータスレシ、スタ(SREG)の全割り込み許可(I)ヒ、ットとウォッチト、ック・割り込み許可(WDTIE)が設定(1)されていれば、ウォッチト、ック・計時完了割り込みが実行されます。

## ■ ビット6 - WDTIE: ウォッチドッグ割り込み許可 (Watchdog Timer Interrupt Enable)

このビットが1を書かれ、ステータス レジスタ(SREG)の全割り込み許可(I)ビットが設定(1)されると、ウォッチドッグ割り込みが許可されます。この設定(=1)との組み合わせでウォッチドッグ リセット許可(WDE)ビットが解除(0)されると、割り込み動作種別になり、ウォッチドッグ タイマで計時完了が起こると、対応する割り込みが実行されます。

WDEが設定(1)されると、ウォッチドッグ タイマは割り込み及びシステム リセット動作種別になります。ウォッチドッグタイマでの最初の計時完了がウォッチドッグ割り込み要求(WDTIF)フラクを設定(1)します。対応する割り込みへ、クタの実行はハート・ウェアによってWDTIEとWDTIFを自動的に解除(0)します。これは割り込みを使う間のウォッチドッグ リセット保護を維持するために有用です。割り込み及びシステム リセット動作種別に留まるには、各割り込み後にWDTIEが設定(1)されなければなりません。然しながら、ウォッチドッグ・システム リセット動作種別の安全機能に危険を及ぼすかもしれないため、これは割り込み処理ルーチン自身内で行われるべきではありません。次の計時完了に先立って割り込みが実行されない場合、システム リセットが適用(実行)されます。

| 表8-1 | -<br>ս+ | ッチト | " <sub>11</sub> /1" | 41 | ク訳 | 完 |
|------|---------|-----|---------------------|----|----|---|
|      |         |     |                     |    |    |   |

| WDTON | WDE | WDTIE | 動作種別           | 計時完了での動作             |
|-------|-----|-------|----------------|----------------------|
| 1     | 0   | 0     | 停止             | なし                   |
| 1     | 0   | 1     | 割り込み           | 割り込み                 |
| 1     | 1   | 0     | システム リセット      | リセット                 |
| 1     | 1   | 1     | 割り込み及びシステムリセット | 割り込み、その後システムリセット動作種別 |
| 0     | X   | X     | システム リセット      | リセット                 |

注: WDTONヒュース、は0=プログラム、1=非プログラムです。

## ■ ビット4 - WDCE: ウォッチドッグ変更許可 (Watchdog Change Enable)

このビットはウォッチドッグ リセット許可(WDE)と前置分周選択ビットの変更用の時間制限手順で使われます。WDEビットの解除(0)や前置分周選択ビット変更のため、WDCEは設定(1)されなければなりません。

一旦1を書かれると、4クロック周期後にハードウェアがWDCEを解除(0)します。

#### ■ ビット3 - WDE: ウオッチドッグ リセット許可 (Watchdog System Reset Enable)

WDEはMCU状態レジスタ(MCUSR)のウォッチト、ック、リセット フラク(WDRF)によって無効にされます。これはWDRFが設定(1)されると、WDEが常に設定(1)されることを意味します。WDEを解除(0)するにはWDRFが先に解除(0)されなければなりません。この特徴は失敗を引き起こす状態中の複数リセットと失敗後の安全な起動を保証します。

## ■ ビット5,2~0 - WDP3~0: ウォッチドッグ タイマ前置分周選択 (Watchdog Timer Prescaler 3,2,1 and 0)

このWDP3~0ビットはウォッチドッグ タイマが走行する時のウォッチドッグ タイマの前置分周を決めます。各種前置分周値と対応する計時完了周期は表8-2.で示されます。

表8-2. ウォッチト、ック、前置分周選択

| WDP3                  |      | 0    |      |        |       |      |      |      |      |       |      | 1 |   |   |   |   |
|-----------------------|------|------|------|--------|-------|------|------|------|------|-------|------|---|---|---|---|---|
| WDP2                  |      | 0    |      |        |       | 1    |      |      |      | 0     |      |   |   | 1 |   |   |
| WDP1                  | 0    |      | 1    |        | (     | )    |      | [    | (    | )     | ]    | L | 0 |   | 1 |   |
| WDP0                  | 0    | 1    | 0    | 1      | 0     | 1    | 0    | 1    | 0    | 1     | 0    | 1 | 0 | 1 | 0 | 1 |
| WDT発振周期数              | 2k   | 4k   | 8k   | 16k    | 32k   | 64k  | 128k | 256k | 512k | 1024k | (予約) |   |   |   |   |   |
| 代表的計時完了<br>周期(VCC=5V) | 16ms | 32ms | 64ms | 0.125s | 0.25s | 0.5s | 1.0s | 2.0s | 4.0s | 8.0s  |      |   |   |   |   |   |

# 9. 割り込み

本項はATtiny13によって実行される割り込み操作の詳細を記述します。AVR割り込み操作の一般説明については8頁の「リセットと割り込みの扱い」を参照してください。

# 9.1. 割り込みべかり

ATtiny13の割り込みベクタは下の表9-1.で記述されます。

表9-1. リセットと割り込みのベクタ

| ベクタ番号 | プログラム アト゛レス | 発生元              | 備考                     |
|-------|-------------|------------------|------------------------|
| 1     | \$0000      | リセット             | 電源ON, WDT, BOD等の各種リセット |
| 2     | \$0001      | INT0             | 外部割り込み要求0              |
| 3     | \$0002      | PCINTO (PCI)     | ピン変化割り込み要求             |
| 4     | \$0003      | タイマ/カウンタ OVF     | タイマ/カウンタ溢れ             |
| 5     | \$0004      | EEPROM EE_RDY    | EEPROM 操作可             |
| 6     | \$0005      | アナログ比較器 ANA_COMP | アナログ比較器出力遷移            |
| 7     | \$0006      | タイマ/カウンタ COMPA   | タイマ/カウンタ比較A一致          |
| 8     | \$0007      | タイマ/カウンタ COMPB   | タイマ/カウンタ比較B一致          |
| 9     | \$0008      | ウォッチドック゛ WDT     | ウォッチドッグ計時完了            |
| 10    | \$0009      | A/D変換器 ADC       | A/D変換完了                |

プログラムが決して割り込み元を許可しないなら、割り込みへ、クタは使われず、これらの位置に通常のプログラムコート、が配置できます。 ATtiny13での最も代表的且つ一般的なリセットと割り込みのへ、クタアトレス用設定を次に示します。

| アト・レス  | ラヘ゛ル   | 命令   |                   | 注釈                 |
|--------|--------|------|-------------------|--------------------|
| \$0000 |        | RJMP | RESET             | ;各種リセット            |
| \$0001 |        | RJMP | EXT_INTO          | ;外部割り込み要求0         |
| \$0002 |        | RJMP | PCINTO            | ;ピン変化0群割り込み要求      |
| \$0003 |        | RJMP | TIMO_OVF          | ;タイマ/カウンタ溢れ        |
| \$0004 |        | RJMP | EE_RDY            | ;EEPROM操作可         |
| \$0005 |        | RJMP | ANA_COMP          | ;アナログ比較器出力遷移       |
| \$0006 |        | RJMP | TIMO_COMPA        | ;タイマ/カウンタ比較A一致     |
| \$0007 |        | RJMP | TIMO_COMPB        | ;タイマ/カウンタ比較B一致     |
| \$0008 |        | RJMP | WATCHDOG          | ;ウォッチドッグ計時完了       |
| \$0009 |        | RJMP | ADC               | ;A/D変換完了           |
| ;      |        |      |                   |                    |
| \$000A | RESET: | LDI  | R16, LOW (RAMEND) | ;RAM最終アドレス下位を取得    |
| \$000B |        | OUT  | SPL, R16          | ;スタック ポインタ(下位)を初期化 |
|        |        | }    |                   | ;以下、I/O初期化など       |





# 9.2. 外部割り込み

外部割り込みはINT0ピンまたはPCINT0~5ピンの何れかによって起動されます。許可したなら、例えINT0またはPCINT0~5ピンが出力として設定されても、割り込みが起動することに注目してください。この特徴はソフトウェア割り込みを生成する方法を提供します。ピン変化割り込みPCIは許可したPCINT0~5の何れかが切り替わると起動します。ピン変化割り込み許可レジスタ(PCMSK)は、どのピンがピン変化割り込み要因となるかを制御します。PCINT0~5でのピン変化割り込みは非同期に検知されます。これはそれらの割り込みがアイドル動作以外の休止形態からもデバイスを起動するのに使えることを意味します。

INT0割り込みは上昇端または下降端(含む両端)、またはLowレヘルによって起動できます。これはMCU制御レシ、スタ(MCUCR)の詳述で示される設定です。INT0割り込みがレヘル起動として設定、且つ許可されると、そのピンがLowに保持される限り、割り込みは(継続的に)起動します。INT0の上昇端または下降端割り込みの認知は15頁の「クロック系統とその配給」で記述されるI/Oクロックの存在を必要とすることに注意してください。

# 9.2.1. Lowレベル割り込み

INT0のLowレヘル割り込みは非同期に検知されます。これはそれらの割り込みがアイル動作以外の休止形態からもデバイスを起動するのに使えることを意味します。I/Oクロックはアイドル動作を除く全休止形態で停止されます。

レヘ・ル起動割り込みがハ。ワーダウン動作からの起動に使われる場合、この必要としたレヘ・ルはレヘ・ル割り込みを起動する完全な起動復帰のために、MCUに対して充分長く保たれなければならないことに注意してください。このレヘ・ルが起動時間の最後に先立って消滅すると、MCUは今までどおり起動しますが、割り込みが生成されません。起動時間は15頁の「システム クロックとクロック選択」で示されるようにSUTヒューズとCKSELヒューズで定義されます。

デバイスが起動復帰する前に割り込みピン上のLowレヘールが取り去られると、プログラム実行は割り込み処理ルーチンへ転換されませんが、 SLEEP命令に続く命令から継続します。

## 9.2.2. ピン変化割り込みタイミング

ピン変化割り込みの例は図9-1.で示されます。





## 9.3. 割り込み用レジスタ

## 9.3.1. MCU制御レジスタ (MCU Control Register) MCUCR

MCU制御レジスタは割り込み条件制御ビットを含みます。

| ピット         | 7 | 6   | 5   | 4   | 3   | 2 | 1     | 0     |       |
|-------------|---|-----|-----|-----|-----|---|-------|-------|-------|
| \$35 (\$55) | - | PUD | SE  | SM1 | SM0 | - | ISC01 | ISC00 | MCUCR |
| Read/Write  | R | R/W | R/W | R/W | R/W | R | R/W   | R/W   |       |
| 初期値         | 0 | 0   | 0   | 0   | 0   | 0 | 0     | 0     |       |

## ■ ビット1,0 - ISC01,0:外部割り込み0条件制御 (Interrupt Sense Control 0 bit1 and 0)

外部割り込み0はステータスレジスタ(SREG)の全割り込み許可(I)ビットと一般割り込み許可レジスタ(GIMSK)の外部割り込み0許可(INTO)ビットが設定(1)される場合のINTO外部ピットによって活性(有効)にされます。割り込みを活性にする外部INTOピッのエッジとレヘルは表9-2.で定義されます。INTOピッの値はエッジ検知前に採取されています。エッジまたは論理変化割り込みが選択される場合、1クロック周期より長く留まるパルスは割り込みを生成します。より短いパルスは割り込みの発生が保証されません。Lowレヘル割り込みが選択される場合、Lowレヘルは割り込みを生成するために現在実行している命令の完了まで保たれなければなりません。

| 表9-2. 外部割り込み0(INTO)割り込み条件  |   |          |  |  |  |  |  |  |  |
|----------------------------|---|----------|--|--|--|--|--|--|--|
| ISC01 ISC00 INTOピン割り込み発生条件 |   |          |  |  |  |  |  |  |  |
| 0                          | 0 | Lowレヘンル。 |  |  |  |  |  |  |  |
| 0                          | 1 | 論理変化(両端) |  |  |  |  |  |  |  |
| 1                          | 0 | 下降端      |  |  |  |  |  |  |  |
| 1                          | 1 | 上昇端      |  |  |  |  |  |  |  |

# 9.3.2. 一般割り込み許可レジスタ (General Interrupt Mask Register) GIMSK

| ピット         | 7 | 6    | 5    | 4 | 3 | 2 | 1 | 0 |       |
|-------------|---|------|------|---|---|---|---|---|-------|
| \$3B (\$5B) | _ | INT0 | PCIE | _ | - | - | - | - | GIMSK |
| Read/Write  | R | R/W  | R/W  | R | R | R | R | R |       |
| 初期値         | 0 | 0    | 0    | 0 | 0 | 0 | 0 | 0 |       |

#### ■ ビット7.4~0 - Res: 予約 (Reserved)

これらのビットは予約されており、常に0として読まれます。

#### ■ ビット6 - INTO:外部割り込み0許可(External Interrupt Request 0 Enable)

ステータスレジスタ(SREG)の全割り込み許可(I)ビットが設定(1)され、INT0ビットが設定(1)されると、INT0外部ピン割り込みが許可されます。 MCU制御レジスタ(MCUCR)の割り込み条件制御0のビット1と0(ISC01,0)はこの外部割り込みがINT0ピンの上昇端、下降端、両端、またはLowレベルのどれで活性(有効)にされるかを定義します。例えINT0ピンが出力として設定されても、このピンの動きは割り込み要求を引き起こします。外部割り込み要求のに対応する割り込みはINT0割り込みへブタから実行されます。

## ■ ビット5 - PCIE: ピン変化割り込み許可 (Pin Change Interrupt Enable)

ステータスレジ、スタ(SREG)の全割り込み許可(I)ビットが設定(1)され、このPCIEビットが設定(1)されると、ピン変化割り込みが許可されます。 許可したPCINT0~5ピンの何れかの変化が割り込みを起こします。このピン変化割り込み要求に対応する割り込みはPCI割り込みへ、クタから実行されます。PCINT0~5ピンはピン変化割り込み許可レジ、スタ(PCMSK)によって個別に許可されます。

## 9.3.3. 一般割り込み要求フラグレジスタ (General Interrupt Flag Register) GIFR

| ピット         | 7 | 6     | 5    | 4 | 3 | 2 | 1 | 0 |      |
|-------------|---|-------|------|---|---|---|---|---|------|
| \$3A (\$5A) | _ | INTF0 | PCIF | - | - | - | - | - | GIFR |
| Read/Write  | R | R/W   | R/W  | R | R | R | R | R |      |
| 初期値         | 0 | 0     | 0    | 0 | 0 | 0 | 0 | 0 |      |

## ■ ビット7,4~0 - Res: 予約 (Reserved)

これらのビットは予約されており、常に0として読まれます。

## ■ ビット6 - INTFO:外部割り込み0要求フラグ(External Interrupt Flag0)

 $INT0t^{\circ}$ ン上のエッシ または論理変化が割り込み要求を起動すると、INTF0が設定(1)になります。ステータスレシ スタ(SREG)の全割り込み許可(I) t ットと一般割り込み許可レシ スタ(GIMSK)の外部割り込み0許可(INT0) t ットが設定(1) なら、MCUは対応する割り込みへ かりなった。このフラク は割り込みルーチンが実行されると解除(0)されます。代わりにこのフラク は論理1を書くことによっても解除(0)できます。INT0がレヘル割り込みとして設定されると、このフラク は常に解除(0)されます。

## ■ ビット5 - PCIF: ピン変化割り込み要求フラグ (Pin Change Interrupt Flag)

PCINT0~5ピンの何れかの論理変化が割り込み要求を起動すると、PCIFが設定(1)になります。ステータスレジスタ(SREG)の全割り込み許可(I)ビットと一般割り込み許可レジスタ(GIMSK)のピン変化割り込み許可(PCIE)ビットが設定(1)なら、MCUは対応する割り込みベクタへ飛びます。このフラグは割り込みハーチンが実行されると解除(0)されます。代わりに本フラグは論理1を書くことによっても解除(0)できます。

## 9.3.4. ピン変化割り込み許可レジスタ (Pin Change Mask) PCMSK

| ピット         | 7 | 6 | 5      | 4      | 3      | 2      | 1      | 0      |       |
|-------------|---|---|--------|--------|--------|--------|--------|--------|-------|
| \$15 (\$35) | _ | _ | PCINT5 | PCINT4 | PCINT3 | PCINT2 | PCINT1 | PCINT0 | PCMSK |
| Read/Write  | R | R | R/W    | R/W    | R/W    | R/W    | R/W    | R/W    |       |
| 初期値         | 0 | 0 | 0      | 0      | 0      | 0      | 0      | 0      |       |

#### ■ ビット7,6 - Res: 予約 (Reserved)

これらのビットは予約されており、常に0として読まれます。

#### ■ ビット5~0 - PCINT5~PCINT0: ピン変化割り込み5~0許可(Pin Change Enable Mask 5~0)

各PCINT0~5ビットは対応するI/Oピンでピン変化割り込みが許可されるかどうかを選びます。PCINT0~5と一般割り込み許可レジスタ (GIMSK)のPCIEが設定(1)なら、対応するI/Oピンのピン変化割り込みが許可されます。PCINT0~5が解除(0)されると、対応するI/Oピンのピン変化割り込みは禁止されます。





# 10. 入出力ポート

## 10.1. 概要

全てのAVRのポートは標準デジタルI/Oポートとして使われる時に真の読み-変更-書き(リート、モディファイライト)を機能的に持ちます。これはSBIとCBI命令で他のどのピンの方向をも無意識に変更することなく、1つのポートピンの方向を変更できることを意味します。(出力として設定されていれば)駆動値を変更、または(入力として設定されていれば)アルアップ抵抗を許可/禁止する時にも同じく適用されます。各出力緩衝部は高い吐き出し(ソース)と吸い込み(シンケ)の両能力で対称的な駆動特性を持ちます。このピン駆動部はLED(表示器)を直接駆動するのに充分な強さです。全てのポートピンは個別に選択可能な、供給電圧で抵抗値が変化しないプルアップ抵抗を持っています。全てのI/Oピンは図10-1.で示されるようにVCCとGNDの両方に保護ダイオート、を持っています。各値の完全な一覧については77頁の「電気的特性」を参照してください。



本項内の全てのレジスタとビットの参照は一般形で記されます。小文字の'x'はポート番号文字、小文字の'n'はビット番号を表します。けれどもプログラム内でレジスタやビット定義に使うとき、正確な形式(例えば、ここで一般に記されたPORTxnがポートBのビット3に対してはPORTB3)が使われなければなりません。物理的なI/Oレジスタとビット位置は37頁の「I/Oポート用レジスタ」で一覧されます。

各々1つの出力レシ、スタ(PORTx)、方向レシ、スタ(DDRx)、入力レシ、スタ(PINx)の各ポートに対して、3つI/Oメモリアト・レス位置が割り当てられます。入力レシ、スタのI/O位置は読むだけで、一方出力レシ、スタと方向レシ、スタは読み書き(両方)です。けれどもPINxレシ、スタのビットへの論理1書き込みは、出力レシ、スタの対応ビット値を(1/0)反転する結果になります。加えてMCU制御レシ、スタ(MCUCR)のプルアップ、禁止(PUD)ビットが設定(1)されると、全ポートで全ビットに対してプルアップ、機能を禁止します。

標準デジタルI/OとしてのI/Oポートの使用は次の「標準デジタル入出力としてのポート」で記述されます。多くのポート ピンはデバイスの周辺機能用の交換機能と多重化されます。ポート ピンとの各交換機能のインターフェース法は35頁の「交換ポート機能」で記述されます。交換機能の完全な記述については個別機能部項を参照してください。

ポート ピンのいくつかの交換機能の許可は、そのポート内の他のピンの標準デジタル入出力としての使用に影響しないことに注意してください。

## 10.2. 標準デジタル入出力としてのポート

このポートは任意の内部プルアップ付き双方向I/Oポートです。図10-2.はここで属にPxnと呼ばれるI/Oポートピンの1つの機能説明を示します。



## 10.2.1. ピンの設定

各ポート ピンは3つのレシ、スタ ビット、DDxn、PORTxn、PINxnから成ります。37頁の「I/Oポート用レシ、スタ」で示されるように、DDxnビットはDDRx I/Oアドレス、PORTxnビットはPORTx I/Oアドレス、PINxビットはPINx I/Oアドレスでアクセスされます。

DDRxレジスタ内のDDxnビットはそのピンの方向を選択します。DDxnが論理1を書かれるとPxnは出力ピンとして設定されます。DDxnが論理0を書かれるとPxnは入力ピンとして設定されます。

そのピンが入力ピンとして設定される時にPORTxnが論理1を書かれると、プルアップ抵抗が活性(有効)にされます。プルアップ抵抗をOFF に切り替えるにはPORTxnが論理0を書かれるか、またはそのピンが出力ピンとして設定されなければなりません。ポートピンは例えクロックが動いていなくても、リセット条件が活性(有効)になるとHi-Zにされます。

そのピンが出力ピンとして設定される時にPORTxnが論理1を書かれると、そのポート ピンはHigh(1)に駆動されます。そのピンが出力ピンとして設定される時にPORTxnが論理0を書かれると、そのポート ピンはLow(0)に駆動されます。

## 10.2.2. ピンの出力交互切り替え

PINxnへの論理1書き込みはDDRxnの値に拘らず、PORTxnの値を反転切り替えします。SBI命令がポート内の1ビットの反転切り替えに使えることに注目してください。

# 10.2.3. 入出力間の切り替え

Hi-Z入力(DDxn=0, PORTxn=0)とHigh出力(DDxn=1, PORTxn=1)間の切り替え時、プルアップ許可入力(DDxn=0, PORTxn=1)または Low出力(DDxn=1, PORTxn=0)のどちらかの中間状態が生じるに違いありません。通常、高インピーダンス環境は強力なHigh(吐き出し) 駆動部とプルアップ間の違いに気付かないので、プルアップが許可された状態は十分受け入れられます。この事例でないなら、全ポートの全プルアップを禁止するために、MCU制御レジスタ(MCUCR)のプルアップ禁止(PUD)ピットが設定(1)できます。

プルアップ、入力とLow出力間の切り替えは同じ問題を発生します。使用者は中間状態としてHi-Z入力(DDxn=0, PORTxn=0)またはHigh 出力(DDxn=1, PORTxn=1)のどちらかを使わなければなりません。

表10-1.はピン値に対する制御信号の一覧を示します。

| 表10-1 | 1. ホート | ヒンの | 設定 |
|-------|--------|-----|----|
|       |        |     |    |

| DDxn | PORTxn | PUD (MCUCR) | 入出力 | プルアップ抵抗 | 備考                            |
|------|--------|-------------|-----|---------|-------------------------------|
| 0    | 0      | X           | 入力  | なし      | 高インヒ゜ーダンス (Hi-Z)              |
| 0    | 1      | 0           | 入力  | あり      | Pxnに外部からLowを入力すると吐き出し電流が流れます。 |
| 0    | 1      | 1           | 入力  | なし      | 高インピーダンス (Hi-Z)               |
| 1    | 0      | X           | 出力  | なし      | Low (吸い込み)出力                  |
| 1    | 1      | X           | 出力  | なし      | High (吐き出し)出力                 |

## 10.2.4. ピン値の読み込み

DDxn方向ビットの設定に関係なく、ポート ピンはPINxnレジスタ ビットを通して読めます。図10-2.で示されるようにPINxnレジスタ ビットと先行するラッチは同期化回路を構成します。これは物理ピンが内部クロックのエッジ付近で値を変える場合の未定義状態(メタ ステーブル)を避けるために必要とされますが、それは遅延も持ち込みます。図10-3.は外部的に加えられたピン値を読む時の同期化タイミング図を示します。伝播遅延の最小と最大は各々tpd,minとtpd,maxで示されます。

(図10-3.で)システム クロックの最初の下降端直後から始まるクロック周期を考察してください。このラッチはクロックがLowの時に閉じ、クロックがHighの時に同期ラッチ信号の斜線部分で示されるように通過(トランスペプレント)となります。この信号値はシステム クロックがLowになる時に保持(ラッチ)されます。それが続くクロックの上昇端でPINxnレジスタに取り込まれます。2つの矢印tpd,minとtpd,maxによって示されるように、ピン上の単一信号遷移は出現時点に依存して0.5~1.5システムクロック周期遅らされます。

ソフトウェアが指定したピン値を読み戻す時は、図10-4.で示されるようにNOP命令が挿入されなければなりません。OUT命令はシステムクロックの上昇端で同期ラッチを設定します。この場合、同期化回路を通過する遅延時間(tpd)は1システムクロック周期です。









次のコート・例はポートBピンの0と1をHigh出力、2と3をLow出力、4をプルアップ指定として4と5を入力に設定する方法を示します。結果のピン値が再び読み戻されますが、前記で検討されたように、いくつかのピンへ直前に指定された値を読み戻すことができるようにNOP命令が挿入されます。

```
アセンブリ言語プログラム例
            LDI
                   R16, (1<<PB4) | (1<<PB1) | (1<<PB0)
                                                               ;プルアップとHigh値を取得
                   R17, (1<<DDB3) | (1<<DDB2) | (1<<DDB1) | (1<<DDB0) ;出力ビット値を取得
            LDI
                   PORTB, R16
                                                               ;プルアップとHigh値を設定
            OUT
            OUT
                   DDRB, R17
                                                               ;入出力方向を設定
            NOP
                                                               ;同期化遅延対処
                                                               ;ピン値読み戻し
            IN
                   R16, PINB
C言語プログラム例
unsigned char i;
                                                               /* */
    PORTB = (1 << PB4) | (1 << PB1) | (1 << PB0);
                                                               /* プルアップとHigh値を設定 */
    DDRB = (1<<DDB3) | (1<<DDB2) | (1<<DDB1) | (1<<DDB0);
                                                               /* 入出力方向を設定 */
                                                               /* 同期化遅延対処 */
    __no_opration();
                                                               /* ピン値読み戻し*/
    i = PINB;
```

注: アセンブリ言語プログラムについてはプルアップがピン0,1,4に設定されてから、ビット0と1の強力なHigh駆動部としての再定義、ビット2と3のLow駆動部としての定義、方向ビットが正しく設定されるまでの時間を最小とするために2つの一時レジスタが使われます。

## 10.2.5. デジタル入力許可と休止形態

図10-2.で示されるようにデジタル入力信号はシュミットトリガの入力をGNDにクランプできます。この図でSLEEPと印された信号は入力信号のいくつかが開放のまま、またはVCC/2付近のアナログ信号電圧を持つ場合の高消費電力を避けるため、パワーダウン動作でMCU休止制御器によって設定(1)されます。

SLEEPは外部割り込みピンとして許可されたポート ピンに対しては無視されます。外部割り込み要求が許可されないなら、SLEEPは他のピンについてと同様に有効です。SLEEPは35頁の「**交換ポート機能**」で記載されるように様々な他の交換機能によっても無視されます。

外部割り込みが許可されていない"上昇端、下降端または論理変化(両端)割り込み"として設定された非同期外部割り込みピンに論理1が存在すると、上で言及した休止形態から(復帰)再開する時に、これらの休止形態に於けるクランプが要求された論理変化を生ずるので、対応する外部割り込み要求フラグが設定(=1)されます。

## 10.2.6. 未接続ピン

いくつかのピンが未使用にされる場合、それらのピンが定義されたレベルを持つのを保証することが推奨されます。例え上記のような深い休止形態で多くのデジタル入力が禁止されるとしても、デジタル入力が許可される他の全ての動作(リセット、活動動作、アイドル動作)で消費電流削減のため、浮き状態入力は避けられるべきです。

未使用ピンの定義されたレベルを保証する最も簡単な方法は内部プルアップを許可することです。この場合、リセット中のプルアップは禁止されます。リセット中の低消費電力が重要なら、外部プルアップまたはプルダウンを使うことが推奨されます。未使用ピンを直接GNDまたはVCCに接続することは、ピンが偶然に出力として設定されると過電流を引き起こす可能性があるため推奨されません。

# 10.3. 交換ポート機能

多くのポート ピンには標準デジタル入出力に加え交換機能があります。図10-5.は単純化された図10-2.でのポート ピン制御信号が交換機能によってどう重複できるかを示します。この重複信号は全てのポート ピンに存在する訳ではありませんが、この図はAVRマイクロコントローラ系統の全ポート ピンに適用できる一般的な記述として取り扱います。



表10-2.は重複(交換)信号の機能一覧を示します。図10-5.で示すピンとポートは次表で示されません。重複(交換)信号は交換機能を持つ機能部で内部的に生成されます。

| 表10-2. 交換機能用交換信号の一般定義 |                                                                           |                                                                                                      |  |  |  |
|-----------------------|---------------------------------------------------------------------------|------------------------------------------------------------------------------------------------------|--|--|--|
| 信号略名                  | 信号名                                                                       | 意味                                                                                                   |  |  |  |
| PUOE                  | プルアップ値交換許可                                                                | 1で、プルアップ許可はPUOV信号で制御され、0の場合、DDxn=0, PORTxn=1, PUD=0でプルアップが許可されます。                                    |  |  |  |
| PUOV                  | プルアップ値交換値                                                                 | PUOE=1時、DDxn, PORTxn, PUDの値に関係なく、プルアップの有(1)/無(0)を指定します。                                              |  |  |  |
| DDOE                  | 方向値交換許可                                                                   | 1で、出力駆動部はDDOV信号で制御され、0の場合、DDxnレジスタ値で制御されます。                                                          |  |  |  |
| DDOV                  | 方向値交換値                                                                    | DDOE=1時、DDxnレシ、スタ値に関係なく、出力駆動部のON(1)/OFF(0)を制御します。                                                    |  |  |  |
| PVOE                  | 出力値交換許可 1で出力駆動部がONなら、ポート値はPVOV信号で制御されます。出力駆動部が場合、ポート値はPORTxnレジスタ値で制御されます。 |                                                                                                      |  |  |  |
| PVOV                  | 出力値交換値                                                                    | PVOE=1時、PORTxnレジスタ値に関係なく、ポート値を制御(1/0)します。                                                            |  |  |  |
| PTOE                  | 出力切替許可                                                                    | PTOE=1時、PORTxnレジスタ値が反転します。                                                                           |  |  |  |
| DIEOE                 | デジタル入力許可交換許可                                                              | 1で、デジタル入力許可はDIEOV信号で制御され、0の場合、MCUの状態(活動動作、休止<br>形態)によって決定されます。                                       |  |  |  |
| OIEOV                 | デジタル入力許可交換値                                                               | DIEOE=1時、MCUの状態(活動動作、休止形態)に関係なく、デジタル入力を許可(1)/禁止(0)します。                                               |  |  |  |
| DI                    | デジタル入力                                                                    | 交換機能用デジタル入力です。この信号は図上でシュミット トリカ 出力に接続されていますが、<br>これは同期化前となります。この信号はクロックとしての使用を除き、各交換機能自身が同<br>期化します。 |  |  |  |
| AIO                   | アナログ入出力                                                                   | 交換機能用アナログ入出力です。この信号はピンに直接接続され、双方向使用ができます。                                                            |  |  |  |

次節は交換機能に関連する重複(交換)信号と各ポートの交換機能を簡単に記述します。更に先の詳細については交換機能の記述を参照してください。





# 10.3.1. ポートBの交換機能

ポートBピンの交換機能は表10-3.で示されます。

# 表10-3. ポートBピンの交換機能

| ホ <sup>°</sup> ート ヒ <sup>°</sup> ン | 交換機能                                                                       | ポート ピン | 交換機能                                                                                                               |
|------------------------------------|----------------------------------------------------------------------------|--------|--------------------------------------------------------------------------------------------------------------------|
| PB5                                | RESET (外部リセット入力) dW (デバッグWIRE入出力) ADC0 (A/D変換チャネル0入力) PCINT5 (ピン変化割り込み5入力) | PB2    | SCK (SPI 直列プログラミング クロック入力)<br>ADC1 (A/D変換チャネル1入力)<br>T0 (タイマ/カウンタ 外部クロック入力)<br>PCINT2 (ピン変化割り込み2入力)                |
| PB4                                | ADC2 (A/D変換チャネル2入力)<br>PCINT4 (ピン変化割り込み4入力)                                | PB1    | MISO (SPI 直列プログラミング データ入力) AIN1 (アナログ 比較器反転入力) OC0B (タイマ/カウンタ 比較B一致/PWM-B出力) INT0 (外部割り込み0入力) PCINT1 (ピン変化割り込み1入力) |
| PB3                                | ADC3 (A/D変換チャネル3入力)<br>CLKI (外部クロック信号入力)<br>PCINT3 (ピン変化割り込み3入力)           | PB0    | MOSI (SPI 直列プログラミング データ出力)<br>AIN0 (アナログ 比較器非反転入力)<br>OCOA (タイマ/カウンタ 比較A一致/PWM-A出力)<br>PCINTO (ピン変化割り込み0入力)        |

表10-4.と表10-5.はポートBの交換機能を35頁の図10-5.で示される交換信号に関連付けます。

# 表10-4 ポートB5~3の交換機能用交換信号

| 信号名   | PB5/RESET/ADC0/PCINT5          | PB4/ADC2/PCINT4     | PB3/ADC3/CLKI/PCINT3 |
|-------|--------------------------------|---------------------|----------------------|
| PUOE  | RSTDISBL • DWEN                | 0                   | 0                    |
| PUOV  | 1                              | 0                   | 0                    |
| DDOE  | RSTDISBL•DWEN                  | 0                   | 0                    |
| DDOV  | ァブバックWIRE送信                    | 0                   | 0                    |
| PVOE  | 0                              | 0                   | 0                    |
| PVOV  | 0                              | 0                   | 0                    |
| PTOE  | 0                              | 0                   | 0                    |
| DIEOE | RSTDISBL+(PCINT5 • PCIE+ADC0D) | PCINT4 • PCIE+ADC2D | PCINT3 • PCIE+ADC3D  |
| DIEOV | ADC0D                          | ADC2D               | ADC3D                |
| DI    | PCINT5入力                       | PCINT4入力            | PCINT3入力             |
| AIO   | リセット入力/ADC0入力                  | ADC2入力              | ADC3入力               |

注: RSTDISBLとDWENはプログラム(0)時が1です。

# 表10-5. ポートB2~0の交換機能用交換信号

| 信号名   | PB2/SCK/ADC1/T0/PCINT2 | PB1/MISO/AIN1/<br>OC0B/INT0/PCINT1 | PB0/MOSI/AIN0/OC0A/PCINT0 |  |
|-------|------------------------|------------------------------------|---------------------------|--|
| PUOE  | 0                      | 0                                  | 0                         |  |
| PUOV  | 0                      | 0                                  | 0                         |  |
| DDOE  | 0                      | 0                                  | 0                         |  |
| DDOV  | 0                      | 0                                  | 0                         |  |
| PVOE  | 0                      | OC0B許可                             | OC0A許可                    |  |
| PVOV  | 0                      | OC0B                               | OC0A                      |  |
| PTOE  | 0                      | 0                                  | 0                         |  |
| DIEOE | PCINT2 • PCIE+ADC1D    | PCINT1 • PCIE+ADC1D                | PCINT0 • PCIE+ADC0D       |  |
| DIEOV | ADC1D                  | AIN1D                              | AIN0D                     |  |
| DI    | T0入力/PCINT2入力          | INT0入力/PCINT1入力                    | PCINT0入力                  |  |
| AIO   | ADC1入力                 | アナログ比較器反転入力                        | アナログ比較器非反転入力              |  |

# 10.4. I/Oホ°ート用レシ、スタ

# 10.4.1. MCU制御レジスタ (MCU Control Register) MCUCR

| ピット         | 7 | 6   | 5   | 4   | 3   | 2 | 1     | 0     |       |
|-------------|---|-----|-----|-----|-----|---|-------|-------|-------|
| \$35 (\$55) | _ | PUD | SE  | SM1 | SM0 | - | ISC01 | ISC00 | MCUCR |
| Read/Write  | R | R/W | R/W | R/W | R/W | R | R/W   | R/W   |       |
| 初期値         | 0 | 0   | 0   | 0   | 0   | 0 | 0     | 0     |       |

### ■ ビット7,2 - Res: 予約 (Reserved)

これらのビットは予約されており、常に0として読まれます。

### ■ ビット4 - PUD: プルアップ、禁止 (Pull-up Disable)

このビットが1を書かれると、例えDDxnとPORTxnレジスタがプルアップを許可(DDxn=0, PORTxn=1)に設定されていても、I/Oポートのプルアップは禁止されます。この特徴についてより多くの詳細に関しては33頁の「ピンの設定」をご覧ください。

### 10.4.2. ホートB出力レジスタ (Port B Data Register) PORTB

| ピット         | 7 | 6 | 5      | 4      | 3      | 2      | 1      | 0      |       |
|-------------|---|---|--------|--------|--------|--------|--------|--------|-------|
| \$18 (\$38) | - | - | PORTB5 | PORTB4 | PORTB3 | PORTB2 | PORTB1 | PORTB0 | PORTB |
| Read/Write  | R | R | R/W    | R/W    | R/W    | R/W    | R/W    | R/W    |       |
| 初期値         | 0 | 0 | 0      | 0      | 0      | 0      | 0      | 0      |       |

### 10.4.3. ポートB方向レジスタ (Port B Data Direction Register) DDRB

| ピット         | 7 | 6 | 5    | 4    | 3    | 2    | 1    | 0    |      |
|-------------|---|---|------|------|------|------|------|------|------|
| \$17 (\$37) | _ | - | DDB5 | DDB4 | DDB3 | DDB2 | DDB1 | DDB0 | DDRB |
| Read/Write  | R | R | R/W  | R/W  | R/W  | R/W  | R/W  | R/W  |      |
| 初期値         | 0 | 0 | 0    | 0    | 0    | 0    | 0    | 0    |      |

# 10.4.4. ホートB入力レシ、スタ (Port B Input Address) PINB

| ピット         | 7 | 6 | 5     | 4     | 3     | 2     | 1     | 0     | _    |
|-------------|---|---|-------|-------|-------|-------|-------|-------|------|
| \$16 (\$36) | _ | - | PINB5 | PINB4 | PINB3 | PINB2 | PINB1 | PINB0 | PINB |
| Read/Write  | R | R | R/W   | R/W   | R/W   | R/W   | R/W   | R/W   |      |
| 初期値         | 0 | 0 | 不定    | 不定    | 不定    | 不定    | 不定    | 不定    |      |





# 11. 8ビット タイマ/カウンタ0 (PWM付き)

### 11.1. 特徴

- ・2つの独立した比較出力部
- ・2重緩衝の比較レジスタ
- ・比較一致でのタイマ/カウンタ解除(自動再設定)
- ・不具合なしで正しい位相のパルス幅変調器 (PWM)
- ・可変PWM周期
- ・周波数発生器
- ・3つの独立した割り込み (TOV0,OCF0A,OCF0B)

### 11.2. 概要

タイマ/カウンタのは2つの独立した比較出力部とPWM支援付きの汎用8ビット タイマ/カウンタ部です。それは正確なプログラム実行タイミング(事象管理)、波形生成を許します。

この8ビット タイマ/カウンタの簡単化した構成図は**図11-1**.で示されます。I/Oピンの実際の配置については2頁の「ピン配置」を参照してください。CPUがアクセス可能な(I/OビットとI/Oピンを含む)I/Oレジスタは赤文字(訳注:原文は太字)で示されます。デバイス仕様のI/Oレジスタとビット位置は46頁の「8ビット タイマ/カウンタ0用レジスタ」で一覧されます。



#### 11.2.1. 関係レジスタ

タイマ/カウンタ(TCNT0)と比較レシ、スタ(OCR0AとOCR0B)は8ビットのレシ、スタです。割り込み要求信号はタイマ/カウンタ割り込み要求レシ、スタ(TIF R0)で全て見えます。全ての割り込みはタイマ/カウンタ割り込み許可レシ、スタ(TIMSK0)で個別に遮蔽(禁止)されます。TIFR0とTIMSK0はこの図で示されません。

このタイマ/カウンタは内部的、前置分周器経由、またはTOピンの外部クロック元によってクロック駆動されます。クロック選択論理部はタイマ/カウンタが値を増加(または減少)するのに使うクロック元を制御します。クロック元が選択されないとき、タイマ/カウンタは動きません。クロック選択論理部からの出力はタイマ/カウンタ クロック(clkTo)として参照されます。

2重緩衝化した比較レシ、スタ(OCR0AとOCR0B)はタイマ/カウンタ値と常に比較されます。この比較結果は比較出力(OC0AとOC0B) ピンで PWMまたは可変周波数出力を作成するための波形生成器によって使えます。詳細については40 頁の「比較出力部」をご覧ください。この比較一致発生は比較一致割り込み要求の発生に使える比較一致割り込み要求フラグ (OCF0AとOCF0B) も設定(1)します。

#### 11.2.2. 定義

本項でのレシ、スタとヒット参照の多くは一般形で書かれます。小文字の'n'は タイマ/カウンタ番号、この場合は0で置き換えます。小文字のxは比較出力部のチャネル名を表し、この場合はAまたはBです。然しながらプログラムでレシ、スタまたはヒット定義に使う時は正確な形式が使われなければなりません(例えばタイマ/カウンタののカウンタ値のアクセスに対してのTCNT0のように)。

表11-1.の定義は本資料を通して広範囲に渡って使われます。

| 表11-1. 用語 | 表11-1. 用語定義                                                           |  |  |  |  |  |
|-----------|-----------------------------------------------------------------------|--|--|--|--|--|
| 用語        | 意味                                                                    |  |  |  |  |  |
| BOTTOM    | タイマ/カウンタが\$00に到達した時。                                                  |  |  |  |  |  |
| MAX       | タイマ/カウンタが\$FF(255)に到達した時。                                             |  |  |  |  |  |
| TOP       | タイマ/カウンタが指定された固定値(\$FF)<br>またはOCROA値に到達した時。この指<br>定(TOP)値は動作種別に依存します。 |  |  |  |  |  |

### 11.3. タイマ/カウンタのクロック

このタイマ/カウンタは内部または外部のクロック元によってクロック駆動できます。このクロック元はタイマ/カウンタ制御レシ、スタB(TCCR0B)に配置されたクロック選択(CS02~0)ビットによって制御されるクロック選択論理回路で選択されます。クロック元と前置分周器の詳細については50頁の「タイマ/カウンタの前置分周器」をご覧ください。

# 11.4. 計数器部

8ビット タイマ/カウンタの主な部分は設定可能な双方向カウンタ部です。図11-2.はこのカウンタとその周辺環境の構成図を示します。



使った動作種別に依存して、カウンタは各タイマ/カウンタ クロック(clkT0)で解除(\$00)、増加(+1)、または減少(-1)されます。clkT0はクロック選択 (CS02~0)ビットによって選択された内部または外部のクロック元から生成できます。クロック元が選択されない(CS02~0=000)とき、タイマ/カウンタは停止されます。けれどもTCNT0値はタイマ/カウンタ クロック(clkT0)が存在するしないに拘らず、CPUによってアクセスできます。CPU書き込みは全てのカウンタ解除や計数動作を無視します(上位優先順位を持ちます)。

計数順序(方法)はタイマ/カウンタ制御レシ、スタA(TCCR0A)に配置された波形生成種別(WGM01,0)ビットとタイマ/カウンタ制御レシ、スタB(TCCR0B)に配置された波形生成種別(WGM02)ビットの設定によって決定されます。これらはカウンタ動作(計数)方法とOC0A/OC0B比較出力に生成される方法間の接続に近いものです。進化した計数順序と波形生成についてより多くの詳細に関しては42頁の「動作種別」をご覧ください。

タイマ/カウンタ溢れ(TOV0)フラグはWGM02~0ビットによって選択された動作種別に従って設定(1)されます。TOV0はCPU割り込み発生に使えます。





### 11.5. 比較出力部

この8ビット比較器はTCNT0と比較レシ、スタ(OCR0AとOCR0B)を継続的に比較します。TCNT0がOCR0AまたはOCR0Bと等しければ比較器は一致を指示します。この一致は次のタイマ/カウンタ クロック周期で比較割り込み要求フラグ(OCF0AまたはOCF0B)を設定(1)します。対応する割り込みが許可(I=1, OCIE0AまたはOCIE0B=1)されているならば、その比較割り込み要求フラグは比較割り込みを発生します。比較割り込み要求フラグは割り込みが実行されると自動的に解除(0)されます。代わりにこのフラグはこのI/Oビット位置に論理1を書

くことによってソフトウェアでも解除(0)できます。波形生成器は波形生成種別(WGM02~0)ビットと比較出力選択(COM0x1,0)ビットによって設定された動作種別に従った出力を生成するのにこの一致信号を使います。MAXとBOTTOM信号は動作種別(42頁の「動作種別」参照)のいくつかで両端値の特別な場合を扱うため、波形生成器によって使われます。

#### 図11-3.は比較出力部の構成図を示します。

OCR0xはパルス幅変調(PWM)のどれかを使う時に2重緩衝化されます。標準動作と比較一致タイマ/カウンタ解除(CTC)動作については2重緩衝動作が禁止されます。2重緩衝動作は計数の流れのTOPまたはBOTTOMのどちらかに対してOCR0xレジスタの更新を同期化します。この同期化は奇数長、非対称PWMパルスの発生を防ぎ、それによって不具合なしの出力を作成します。

OCR0xのアクセスは複雑なように思えますが決してそんなことはありません。2重緩衝動作が許可されるとCPUはOCR0x緩衝部をアクセスし、禁止されるとOCR0xレジスタを直接アクセスします。



(<mark>訳注</mark>) ここでは比較nxレジスタ全体をOCR0x、OCR0xを構成する緩衝部分をOCR0x緩衝部、実際の比較に使われるレジスタ本体部分をOCR0xレジスタとして記述しています。他の部分での記述でも特に必要がある場合はこの記述方法を適用します。

### 11.5.1. 強制比較出力

非PWM波形生成動作での比較器の一致出力は強制変更(FOC0x)ビットに1を書くことによって強制(変更)できます。比較一致の強制は比較割り込み要求フラグ(OCF0x)の設定(1)やタイマ/カウンタの再設定/解除を行いませんが、OC0xピンは実際の比較一致が起きた場合と同様に更新されます(COM0x1,0ビット設定がOC0xピンの設定(1)、解除(0)、1/0交互のどれかを定義)。

### 11.5.2. TCNT0書き込みによる比較一致妨害

TCNT0への全てのCPU書き込みは例えタイマ/カウンタが停止されていても、次のタイマ/カウンタ クロック周期で起こるどんな比較一致をも妨げます。この特性はタイマ/カウンタ クロックが許可されている時に割り込みを起動することなく、TCNT0と同じ値に初期化されることをOCR0xに許します。

#### 11.5.3. 比較一致部の使用

どの動作種別でのTCNT0書き込みでも1タイマ/カウンタ クロック周期間、全ての比較一致を妨げるため、タイマ/カウンタが走行中であるかないかに拘らず、比較出力部を使う場合、TCNT0を変更する時に危険を伴います。TCNT0に書かれた値がOCR0x値と同じ場合に比較一致は失われ(一致が発生せず)、不正な波形生成に終わります。同様にタイマ/カウンタが下降計数のとき、BOTTOMに等しいTCNT 0値を書いてはいけません。

OC0xの初期設定はポート ピンに対するポート方向レジスタを出力に設定する前に行われるべきです。OC0x値を設定する一番簡単な方法は標準動作で強制変更(FOC0x)ストローブ ビットを使うことです。波形生成動作種別間を変更する時でも、OC0x(内部)レジスタはその値を保ちます。

比較出力選択(COM0x1,0)ビットが比較値(OCR0x)と共に2重緩衝されないことに気付いてください。COM0x1,0ビットの変更は直ちに有効となります。

### 11.6. 比較一致出力部

比較出力選択(COM0x1,0)ビットは2つの機能を持ちます。波形生成器は次の比較一致での比較出力(OC0x)状態の定義にCOM0x1,0ビットを使います。またCOM0x1,0ビットはOC0xピン出力元を制御します。図11-4.はCOM0x1,0ビット設定によって影響を及ぼされる論理回路の簡単化した図を示します。図のI/Oレジスタ、I/Oビット、I/Oピンは赤文字(訳注:原文は太字)で示されます。COM0x1,0ビットによって影響を及ぼされる標準I/Oポート制御レジスタ(PORTとDDR)の部分だけが示されます。OC0xの状態を参照するとき、その参照はOC0xピンでなく内部OC0xレジスタに対してです。システム リセットが起こると、OC0xレジスタは'0'にリセットされます。



COM0x1,0ビットのどちらかが設定(1)されると、標準I/Oポート機能は波形生成器からの比較出力(OC0x)によって無効にされます。けれどもOC0xピンの方向(入出力)はポート ピンに対するポート方向レジスタ(DDR)によって未だ制御されます。OC0xピンに対するポート方向レジスタのビット(DDR\_OC0x)はOC0x値がピンで見えるのに先立って出力として設定されなければなりません。このポートの交換機能は波形生成種別と無関係です。

比較出力ピン論理回路の設計は出力が許可される前のOC0x状態の初期化を許します。いくつかのCOM0x1,0ビット設定が或る種の動作種別に対して予約されることに注意してください。46頁の「8ビット タイマ/カウンタ0用レジスタ」をご覧ください。

### 11.6.1. 比較一致出力選択と波形生成

波形生成器は標準、CTC、PWM動作でCOM0x1,0ビットを違うふうに使います。全ての動作種別に対してCOM0x1,0=00設定は次の比較一致で実行すべきOC0xレジスタの動きがないことを波形生成器へ告げます。非PWM動作での比較出力動作については46頁の表11-2.と表11-5.を参照してください。高速PWM動作については46頁の表11-3.と表11-6.、位相基準PWMについては46頁の表11-4.と表11-7.を参照してください。

COM0x1,0ビットの状態変更はこのビットが書かれた後の最初の比較一致で有効になります。非PWM動作についてはこの動作が強制変更(FOC0x)ストロープピットを使うことによって直ちに効果を得ることを強制できます。





## 11.7. 動作種別

動作種別、換言するとタイマ/カウンタと比較出力ピンの動作は波形生成種別(WGM02~0)ピットと比較出力選択(COM0x1,0)ピットの組み合わせによって定義されます。比較出力選択ピットは計数順序(動作)に影響を及ぼしませんが、一方波形生成種別ピットは影響を及ぼします。COM0x1,0ピットは生成されるPWM出力が反転されるべきか、されないべきか(反転または非反転PWM)どちらかを制御します。非PWM動作に対するCOM0x1,0ピットは比較一致で出力が解除(0)、設定(1)、1/0交互のどれにされるべきかを制御します(41頁の「比較一致出力部」をご覧ください)。

タイミング情報の詳細については45頁の「**タイマ/カウンタ0のタイミング**」を参照してください(<mark>訳注</mark>:原文中の図番号省略)。

### 11.7.1. 標準動作

最も単純な動作種別が標準動作(WGM02~0=000)です。この動作種別での計数方向は常に上昇(+)で、カウンタ解除は実行されません。カウンタは8ピット最大値(TOP=\$FF)を通過すると単に範囲を超え、そして\$00(BOTTOM)から再び始めます。通常動作でのタイマ/カウンタ溢れ(TOV0)フラケはTCNT0が\$00になる時と同じタイマ/カウンタクロック周期で設定(1)されます。この場合のTOV0フラケは設定(1)のみで解除(0)されないことを除いて第9ピットのようになります。けれどもTOV0フラケを自動的に解除(0)するタイマ/カウンタの溢れ割り込みと組み合わせたタイマ/カウンタの分解能はソフトウェアによって増やせます。標準動作での考慮に特別な場合はなく、新しいカウンタ値は何時でも書けます。

比較出力部は与えられた或る時間に割り込みを生成するのに使えます。標準動作で波形を生成するのに比較出力を使うのは、それが大変多くのCPU時間を占有するため推奨されません。

### 11.7.2. 比較一致タイマ/カウンタ解除(CTC)動作

比較一致タイマ/カウンタ解除(CTC)動作(WGM02~0=010)ではOCR0Aがカウンタの分解能を操作するのに使われます。CTC動作ではカウンタ(TCNT0)値がOCR0Aと一致すると、カウンタは\$00に解除されます。OCR0Aはカウンタに対するTOP値、従って分解能も定義します。この動作種別はより大きい比較一致出力周波数の制御を許します。それは外部の出来事の計数操作も簡単にします。

CTC動作についてのタイミング図は図11-5.で示されます。カウンタ(TCNT0)値はTCNT0とOCR0A間で比較一致が起こるまで増加し、そしてその後にカウンタ(TCNT0)は解除(\$00)されます。



OCF0Aフラグを使うことにより、タイマ/カウンタ値がTOP値に達する時毎に割り込みが生成できます。割り込みが許可されるなら、割り込み処理ルーチンはTOP値を更新するのに使えます。けれども前置分周なしまたは低い前置分周値でカウンタが走行している時にBOTTOMと近い値にTOPを変更することは、CTC動作が2重緩衝機能を持たないために注意して行わなければなりません。OCR0Aに書かれた新しい値がTCNT0の現在値よりも低い(小さい)場合、タイマ/カウンタは(その回の)比較一致を失います。その後のカウンタは比較一致が起こるのに先立って最大値(\$FF)へ、そして次に\$00から始める計数をしなければならないでしょう。

CTC動作で波形出力を生成するため、OC0A出力は比較出力選択(COM0A1,0)ビットを交互動作(=01)に設定することによって各比較一致での論理レベル交互切り替えに設定できます。OC0A値はそのピンに対するデータ方向が出力(DDR\_OC0A=1)に設定されない限り ポート ピンで見えないでしょう。生成された波形はOCR0Aが0(\$00)に設定される時に $f_{OC0A}=f_{clk_LI/O}/2$ の最大周波数を得ます。生成波形周波数は次式によって定義されます。

$$f_{\text{OCnx}} = \frac{f_{\text{clk\_I/O}}}{2 \times \text{N} \times (1 + \text{OCRnx})}$$

変数Nは前置分周数(1,8,64,256,1024)を表します。

標準動作と同じようにタイマ/カウンタ溢れ(TOV0)フラグ はカウンタがMAXから\$00へ計数するのと同じタイマ/カウンタ クロック周期で設定(1)されます。

### 11.7.3. 高速PWM動作

高速 $\uppha$ <sup>ルス幅変調(PWM)動作(WGM02 $\uppha$ 0=011または111)は高周波数PWM波形生成選択を提供します。高速PWMはそれが単一傾斜(鋸波)動作であることによって他のPWM動作と異なります。 $\uppha$ 0はBOTTOMからTOPまで計数し、その後BOTTOMから再び始めます。 $\uppha$ 00に以近て $\uppha$ 00に1時に $\uppha$ 5下、 $\uppha$ 0の $\uppha$ 0のとして定義されます。非反転比較出力動作(COM0 $\uppha$ 1,0=10)での比較出力(OC0 $\uppha$ 0)はTCNT0とOCR0 $\uppha$ 間の比較一致で解除(0)され、BOTTOMで設定(1)されます。反転出力動作(COM0 $\uppha$ 1,0=11)の出力は比較一致で設定(1)され、BOTTOMで解除(0)されます。 $\uppha$ 0の当中傾斜動作のため、高速PWM動作の動作周波数は両傾斜(三角波)動作を使う位相基準PWM動作よりも2倍高くできます。この高い周波数は電力調節、整流、 $\uppha$ 0人変換に対して高速PWM動作を都合よく適合させます。高い周波数は物理的に小さな外部部品( $\uppha$ 1, $\uppha$ 2, $\uppha$ 2, $\uppha$ 3, $\uppha$ 3, $\uppha$ 3, $\uppha$ 3, $\uppha$ 3, $\uppha$ 4, $\uppha$ 5, $\uppha$ 6, $\uppha$ 6, $\uppha$ 6, $\uppha$ 7, $\uppha$ 7, $\uppha$ 8, $\uppha$ 9, $\upp</sup>$ 

高速PWM動作でのタイマ/カウンタはタイマ/カウンタ値がTOP値と一致するまで増加されます。そしてタイマ/カウンタは(一致の)次のタイマ/カウンタクロック周期で解除(\$00)されます。高速PWM動作のタイミング図は図11-6.で示されます。TCNT0値はタイミング図で単一傾斜動作(鋸波)を表す折れ線グラフとして示されます。この図は非反転と反転のPWM出力を含みます。赤細線はOCR0x値を示し、TCNT0値との交点(接点)がTCNT0とOCR0x間の比較一致を示します(訳注:図補正に伴い本行若干変更)。比較割り込み要求フラグ(OCF0x)はOCR0x=TOPを除いて比較一致が起こると設定(1)されます(訳注:共通性のため本行追加)。



タイマ/カウンタ溢れ(TOV0)フラグはカウンタがTOPに到達する時毎に設定(1)されます。割り込みが許可されるなら、その割り込み処理ルーチンは比較値を更新するのに使えます。

高速PWM動作での比較部はOC0xピンでのPWM波形の生成を許します。COM0x1,0ビットを'10'に設定することは非反転PWM出力を作成し、反転PWM出力はCOM0x1,0を'11'に設定することで生成できます。WGM02ビットが設定(1)なら、COM0A1,0ビットの'01'設定は比較一致での交互反転をOC0Aピンに許します。この任意選択はOC0Bピンに対して利用できません(46頁の表11-3.と表11-6.をご覧ください)。実際のOC0x値はポート ピンに対するデータ方向(DDR\_OC0x)が出力として設定される場合だけ見えるでしょう。PWM波形はTCNT0とOCR0x間の比較一致で、OC0x(内部)レジスタを設定(1)(または解除(0))と、カウンタが解除(\$00、TOPからBOTTOMへ変更)されるタイマ/カウンタ クロック周期でOC0xレジスタを解除(0)または設定(1)することによって生成されます。

PWM出力周波数は次式によって計算できます。

$$f_{\text{OCnxPWM}} = \frac{f_{\text{clk\_I/O}}}{N \times (1 + \text{TOP})}$$

変数Nは前置分周数(1,8,64,256,1024)を表します。

OCR0xの両端値は高速PWM動作でPWM波形出力を生成する時の特別な場合にあたります。OCR0xがBOTTOM(\$00)と等しく設定されると、出力はTOP+1 タイマ/カケンタ クロック周期毎の狭いスパーク(パルス)になるでしょう。OCR0xがTOPに等しく設定されると、(COM0x 1,0ビットによって設定される出力極性に依存して)定常的なLowまたはHigh出力に終わるでしょう。

(<mark>訳補</mark>:WGM02~0=111の場合については、)高速PWM動作での(デューティ比50%)周波数の波形出力は比較一致毎に論理反転する OC0A設定(COM0A1,0=01)によって達成できます。生成された波形はOCR0Aが0(\$00)に設定される時にfOC0x=fclk\_I/O/2の最大 周波数でしょう。この特性は高速PWM動作で比較出力部の2重緩衝機能が許可されることを除いて、CTC動作でのOC0A交互出力 (COM0A1,0=01)と同じです。





### 11.7.4. 位相基準PWM動作

位相基準 $^\circ$ ル $^\circ$ ル $^\circ$ 相変調(PWM)動作(WGM02 $^\circ$ 0=001または101)は高分解能で正しい位相のPWM波形生成選択を提供します。位相基準PWM動作は両傾斜(三角波)動作を基にします。カウンタはBOTTOMからTOPへそして次にTOPからBOTTOMへを繰り返し計数します。TOPはWGM02 $^\circ$ 0=001時に $^\circ$ 5FF、WGM02 $^\circ$ 0=101時にOCR0Aとして定義されます。非反転比較出力動作(COM0x1,0=10)での比較出力(OC0x)は上昇計数中のTCNT0とOCR0xの比較一致で解除(0)され、下降計数中の比較一致で設定(1)されます。反転出力動作(COM0x1,0=11)での動作は逆にされます。両傾斜(三角波)動作は単一傾斜(鋸波)動作よりも低い最大動作周波数になります。けれども両傾斜(三角波)動作の対称特性のため、これらの動作種別は電動機制御の応用に好まれます。

位相基準PWM動作でのカウンタはカウンタ値がTOPと一致するまで増加されます。カウンタはTOPに達すると計数方向を変更します。この TCNT0値は1タイマ/カウンタ クロック周期間TOPと等しくなります。位相基準PWM動作のタイミング図は図11-7.で示されます。TCNT0値はタイミング図で両傾斜動作(三角波)を表す折れ線グラフとして示されます。この図は非反転と反転のPWM出力を含みます。細い赤線はOCR0x値を示し、TCNT0値との交点(接点)がTCNT0とOCR0x間の比較一致を示します(訳注:図補正に伴い本行若干変更)。



タイマ/カウンタ溢れ(TOV0)フラグはタイマ/カウンタがBOTTOMに到達する時毎に設定(1)されます。この割り込み要求フラグはカウンタがBOTT OM値に到達する毎に割り込みを発生するのに使えます。

位相基準PWM動作での比較部はOC0xピンでのPWM波形の生成を許します。COM0x1,0ビットを'10'に設定することは非反転PWM出力を作成し、反転PWM出力はCOM0x1,0ビットを'11'に設定することで生成できます。WGM02ビットが設定(1)なら、COM0A1,0ビットの'01'設定は比較一致での交互反転をOC0Aピンに許します。この任意選択はOC0Bピンに対して利用できません(46頁の表11-4と表11-7.をご覧ください)。実際のOC0x値はそのポート ピンに対するデータ方向(DDR\_OC0x)が出力として設定される場合だけ見えるでしょう。PWM波形はカウンタが増加する時のTCNT0とOCR0x間の比較一致でOC0x(内部)レジ、スタを設定(1)(または解除(0))と、カウンタが減少する時のTCNT0とOCR0x間の比較一致でOC0xレジ、スタを解除(0)(または設定(1))によって生成されます。位相基準PWMを使う時の出力に対するPWM周波数は次式によって計算できます。

$$f_{\text{OCnxPCPWM}} = \frac{f_{\text{clk\_I/O}}}{2 \times N \times \text{TOP}}$$

変数Nは前置分周数(1,8,64,256,1024)を表します。

OCR0xの両端値は位相基準PWM動作でPWM波形出力を生成する時の特別な場合にあたります。非反転PWM動作ではOCR0xがBOTTOM(\$00)に等しく設定されると出力は定常的なLow、TOPに等しく設定されると定常的なHighになるでしょう。反転PWMに対する出力は逆の論理値になります。

図11-7.の第2周期のその出発点に於いて、例え比較一致がないとしても、OCnxにはHighからLowへの遷移があります。この遷移点はBOTTOMを挟む対称を保証するためです。比較一致なしに遷移を生ずるのは2つの場合です。

- ・図11-7.でのようにOCR0xはTOPからその値を変更します。OCR0x値がTOPのとき、OCnxピン値は下降計数での比較一致の結果と同じです(訳補: L→H、直前がHのため、常にH)。BOTTOMを挟む対称を保証するため、(変更直後の)TOP(位置)でのOCnx値は上昇計数での比較一致の結果(H→L)と一致しなければなりません。
- ・タイマ/カウンタがOCR0x値よりも高い値から数え始め、そしてその理屈のために比較一致、それ故上昇途中で起こされるであろうOCnxの変更を逃します。(<mark>訳補</mark>: 従って上記同様、TOP位置で(直前がHならば)H→L遷移が生じます。)

## 11.8. タイマ/カウンタのタイミング

このタイマ/カウンタは同期設計で、従って以下の図でタイマ/カウンタ クロック(clkT0)がクロック許可信号として示されます。この図は割り込みフラケが設定(1)される時の情報を含みます。図11-8.は基本的なタイマ/カウンタ動作についてのタイミング・データを含みます。この図は位相基準PWM動作以外の全ての動作種別でのMAX値近辺の計数の流れを示します。



図11-9.は同じタイミングデータを示しますが、前置分周器が許可されています。



図11-10.はCTC動作とOCR0AがTOPのPWM動作を除く全動作種別でのOCF0Aと全動作種別でのOCF0Bの設定を示します。



図11-11.はOCR0AがTOPの高速PWM動作と、CTC動作でのTCNT0の解除とOCF0Aの設定を示します。





### 11.9. 8ビット タイマ/カウンタ用レジスタ

### 11.9.1. タイマ/カウンタ制御レシ、スタA (Timer/Counter Control Register A) TCCROA

| ピット         | 7      | 6      | 5      | 4      | 3 | 2 | 1     | 0     |        |
|-------------|--------|--------|--------|--------|---|---|-------|-------|--------|
| \$2F (\$4F) | COM0A1 | COM0A0 | COM0B1 | COM0B0 | - | - | WGM01 | WGM00 | TCCR0A |
| Read/Write  | R/W    | R/W    | R/W    | R/W    | R | R | R/W   | R/W   |        |
| 初期値         | 0      | 0      | 0      | 0      | 0 | 0 | 0     | 0     |        |

### ■ ビット7,6 - COMOA1,0:比較A出力選択 (Compare Match A Output Mode bit 1 and 0)

これらのビットはOC0A比較出力ピンの動作を制御します。COM0A1,0ビットの1つまたは両方が1を書かれると、OC0A出力はそのI/Oピンの通常ポート機能を無効にし、そのI/Oピンに接続されます。けれども出力駆動部を許可するため、OC0Aピンに対応するポート方向レジスタ(DDR)のビットが設定(1)されなければならないことに注意してください。

OCOAがピンに接続されるとき、COMOA1,0ビットの機能はWGM02~0ビット設定に依存します。

表11-2.はWGM02~0ビットが標準動作またはCTC動作(つまりPW M以外)に設定される時のCOM0A1,0ビット機能を示します。 表11-2. 非PWM動作比較A出力選択 COM0A1 COM0A1

**表11-3**.はWGM02~0ビットが高速PWM動作に設定される時のCO M0A1,0ビットの機能を示します。

**表11-4**.はWGM02~0ビットが位相基準PWM動作に設定される時のCOM0A1,0ビットの機能を示します。

| COMO | )A1 | COM0A0 | 意味                     |
|------|-----|--------|------------------------|
| 0    |     | 0      | 標準ポート動作(OC0A切断)        |
| 0    |     | 1      | 比較一致でOC0Aピン トグル(交互)出力  |
| 1    |     | 0      | 比較一致でOC0At°ン Lowレヘブル出力 |
| 1    |     | 1      | 比較一致でOC0At°ン Highレヘル出力 |

表11-3. 高速PWM動作比較A出力選択(共通注意参照)

| COM0A1 | COM0A0 | 意味                                                           |
|--------|--------|--------------------------------------------------------------|
| 0      | 0      | 標準ポート動作 (OC0A切断)                                             |
| 0      | 1      | WGM02=0:標準ポート動作(OC0A切断)<br>WGM02=1:比較一致でOC0Aピン トグル<br>(交互)出力 |
| 1      | 0      | 比較一致でLow、BOTTOMでHighを<br>OCOAピンへ出力(非反転動作)                    |
| 1      | 1      | 比較一致でHigh、BOTTOMでLowを<br>OCOAピン〜出力(反転動作)                     |

表11-4. 位相基準PWM動作比較A出力選択(共通注意参照)

| COM0A1 | COM0A0 | 意味                                                           |
|--------|--------|--------------------------------------------------------------|
| 0      | 0      | 標準ポート動作 (OC0A切断)                                             |
| 0      |        | WGM02=0:標準ポート動作(OC0A切断)<br>WGM02=1:比較一致でOC0Aピン トグル<br>(交互)出力 |
| 1      | 0      | 上昇計数時の比較一致でLow、下降計数<br>時の比較一致でHighをOCOAピンへ出力                 |
| 1      | 1      | 上昇計数時の比較一致でHigh、下降計数<br>時の比較一致でLowをOCOAピンへ出力                 |

#### ■ ビット5,4 - COM0B1,0:比較B出力選択 (Compare Match B Output Mode bit 1 and 0)

これらのビットはOC0B比較出力ピンの動作を制御します。COM0B1,0ビットの1つまたは両方が1を書かれると、OC0B出力はそのI/Oピンの通常ポート機能を無効にし、そのI/Oピンに接続されます。けれども出力駆動部を許可するため、OC0Bピンに対応するポート方向レジスタ(DDR)のビットが設定(1)されなければならないことに注意してください。

OCOBがピンに接続されるとき、COMOB1,0ビットの機能はWGM02~0ビット設定に依存します。

**表11-5**.はWGM02~0ビットが標準動作またはCTC動作(つまりPW M以外)に設定される時のCOM0B1,0ビット機能を示します。

**表11-6**.はWGM02~0ビットが高速PWM動作に設定される時のCO M0B1,0ビットの機能を示します。

**表11-7**.はWGM02~0ビットが位相基準PWM動作に設定される時のCOM0B1,0ビットの機能を示します。

表11-5. 非PWM動作比較B出力選択

| COM0B1 | СОМ0В0 | 意味                    |
|--------|--------|-----------------------|
| 0      | 0      | 標準ポート動作 (OC0B切断)      |
| 0      | 1      | 比較一致でOC0Bピン トグル(交互)出力 |
| 1      | 0      | 比較一致でOC0Bピン Lowレベル出力  |
| 1      | 1      | 比較一致でOC0Bピン Highレベル出力 |

表11-6. 高速PWM動作比較B出力選択(共通注意参照)

| COM0B1 | СОМ0В0 | 意味                                        |
|--------|--------|-------------------------------------------|
| 0      | 0      | 標準ポート動作(OC0B切断)                           |
| 0      | 1      | (予約)                                      |
| 1      | 0      | 比較一致でLow、BOTTOMでHighを<br>OC0Bピンへ出力(非反転動作) |
| 1      | 1      | 比較一致でHigh、BOTTOMでLowを<br>OC0Bピンへ出力(反転動作)  |

表11-7. 位相基準PWM動作比較B出力選択(共通注意参照)

| COM0B1 | СОМ0В0 | 意味                                           |
|--------|--------|----------------------------------------------|
| 0      | 0      | 標準ポート動作(OC0B切断)                              |
| 0      | 1      | (予約)                                         |
| 1      | 0      | 上昇計数時の比較一致でLow、下降計数<br>時の比較一致でHighをOC0Bピンへ出力 |
| 1      | 1      | 上昇計数時の比較一致でHigh、下降計数<br>時の比較一致でLowをOCOBピンへ出力 |

共通注意: COM0x1が設定(1)され、対応するOCR0xがTOPと等しい時に特別な状態が起きます。この状態での比較一致は無視されますが、 BOTTOMまたはTOPでの設定(1)または解除(0)は行われます。より多くの詳細については43頁の「高速PWM動作」または44頁の「位相 基準PWM動作」をご覧ください。(表11-3,4,6,7.各々での注:を纏めました。)

#### ■ ビット3.2 - Res: 予約 (Reserved)

これらのビットは予約されており、常に0として読まれます。

### ■ ビット1,0 - WGM01,0: 波形生成種別 (Waveform Generation Mode bit 1 and 0)

タイマ/カウンタ制御レジスタB(TCCR0B)で得られるWGM02ビットと組み合わせたこれらのビットはカウンタの計数順序(方向)、最大カウンタ(TOP)値の供給元、使われるべき波形生成のどの形式かを制御します(表11-8.参照)。タイマ/カウンタ部によって支援される動作種別は標準動作(カウンタ)、比較一致タイマ/カウンタ解除(CTC)動作と2形式のパルス幅変調(PWM)動作です。42頁の「動作種別」をご覧ください。

表11-8. 波形生成種別選択

| 番号 | WGM02 | WGM01 | WGM00 | タイマ/カウンタ動作種別          | TOP値  | OCR0x更新時 | TOV0設定時 |
|----|-------|-------|-------|-----------------------|-------|----------|---------|
| 0  | 0     | 0     | 0     | 標準動作                  | \$FF  | 即時       | MAX     |
| 1  | 0     | 0     | 1     | 8ビット位相基準PWM動作         | \$FF  | TOP      | BOTTOM  |
| 2  | 0     | 1     | 0     | 比較一致タイマ/カウンタ解除(CTC)動作 | OCR0A | 即時       | MAX     |
| 3  | 0     | 1     | 1     | 8ビット高速PWM動作           | \$FF  | BOTTOM   | MAX     |
| 4  | 1     | 0     | 0     | (予約)                  | -     | -        | -       |
| 5  | 1     | 0     | 1     | 位相基準PWM動作             | OCR0A | TOP      | BOTTOM  |
| 6  | 1     | 1     | 0     | (予約)                  | -     | _        | _       |
| 7  | 1     | 1     | 1     | 高速PWM動作               | OCR0A | BOTTOM   | TOP     |

注: MAX=\$FF、BOTTOM=\$00です。

### 11.9.2. タイマ/カウンタ制御レジスタB (Timer/Counter Control Register B) TCCROB

| ピット         | 7     | 6     | 5 | 4 | 3     | 2    | 1    | 0    |        |
|-------------|-------|-------|---|---|-------|------|------|------|--------|
| \$33 (\$53) | FOC0A | FOC0B | - | - | WGM02 | CS02 | CS01 | CS00 | TCCR0B |
| Read/Write  | W     | W     | R | R | R/W   | R/W  | R/W  | R/W  |        |
| 初期値         | 0     | 0     | 0 | 0 | 0     | 0    | 0    | 0    |        |

### ■ ビット7 - FOC0A: OC0A強制変更 (Force Output Compare A)

FOC0AビットはWGM02~0ビットが非PWM動作を指示する時だけ有効です。

けれども将来のデバイスとの共通性を保証するため、PWM動作で扱う時にTCCR0Bが書かれる場合、このビットは0に設定されなければなりません。FOC0Aビットに論理1を書くと、波形生成部で直ちに比較一致が強制されます。OC0A出力はCOM0A1,0ビット設定に従って変更されます。FOC0Aビットがストローブとして実行されることに注意してください。従って強制した比較の効果を決めるのはCOM0A1,0ビットに存在する値です。

FOC0Aストローブは何れの割り込みの生成もTOPとしてOCR0Aを使う比較一致タイマ解除(CTC)動作でのタイマ/カウンタの解除(\$00)も行いません。

FOC0At'ットは常に0として読まれます。

### ■ ビット6 - FOC0B: OC0B強制変更 (Force Output Compare B)

FOC0BビットはWGM02~0ビットが非PWM動作を指示する時だけ有効です。

けれども将来のデバイスとの共通性を保証するため、PWM動作で扱う時にTCCR0Bが書かれる場合、このビットは0に設定されなければなりません。FOC0Bビットに論理1を書くと、波形生成部で直ちに比較一致が強制されます。OC0B出力はCOM0B1,0ビット設定に従って変更されます。FOC0Bビットがストローブとして実行されることに注意してください。従って強制した比較の効果を決めるのはCOM0B1,0ビットに存在する値です。

FOC0Bストローブは何れの割り込みの生成も行いません。

FOC0Bビットは常に0として読まれます。

## ■ ビット5,4 - **Res** : 予約 (Reserved)

これらのビットは予約されており、常に0として読まれます。

■ ビット3 - WGM02:波形生成種別 (Waveform Generation Mode bit 2)

46頁の「タイマ/カウンタ制御レジスタA (TCCROA)」のWGM01,0ビット記述をご覧ください。





### ■ ビット2~0 - CS02~0: クロック選択0 (Clock Select0, bit 2,1 and 0)

この3つのクロック選択ビットはタイマ/カウンタ(TCNT0)によって使われるクロック元を選択します。

### 表11-9. タイマ/カウンタ0入力クロック選択

| CS02 | CS01 | CS00 | 意味                                |
|------|------|------|-----------------------------------|
| 0    | 0    | 0    | 停止(タイマ/カウンタ0動作停止)                 |
| 0    | 0    | 1    | clk <sub>I/O</sub> (前置分周なし)       |
| 0    | 1    | 0    | clk <sub>I/O</sub> /8 (8分周)       |
| 0    | 1    | 1    | clk <sub>I/O</sub> /64 (64分周)     |
| 1    | 0    | 0    | clk <sub>I/O</sub> /256 (256分周)   |
| 1    | 0    | 1    | clk <sub>I/O</sub> /1024 (1024分周) |
| 1    | 1    | 0    | T0ピンの下降端 (外部クロック)                 |
| 1    | 1    | 1    | T0ピンの上昇端 (外部クロック)                 |

外部ピン(クロック)動作がタイマ/カウンタ0に対して使われる場合、例えT0ピンが出力として設定されても、T0ピンの遷移はカウンタをクロック駆動します。この特徴がソフトウェアに計数制御を許します。

### 11.9.3. タイマ/カウンタ (Timer/Counter) TCNTO

| ピット         | 7     | 6   | 5   | 4   | 3   | 2   | 1   | 0     |       |
|-------------|-------|-----|-----|-----|-----|-----|-----|-------|-------|
| \$32 (\$52) | (MSB) |     |     |     |     |     |     | (LSB) | TCNT0 |
| Read/Write  | R/W   | R/W | R/W | R/W | R/W | R/W | R/W | R/W   |       |
| 初期値         | 0     | 0   | 0   | 0   | 0   | 0   | 0   | 0     |       |

このタイマ/カウンタ レシ スタは読み書き両方の操作についてタイマ/カウンタ部の8ビット カウンタに直接アクセスします。TCNT0への書き込みは次のタイマ/カウンタ クロックでの比較一致を妨害(除去)します。カウンタが走行中にカウンタ(TCNT0)を変更することはTCNT0とOCR0x間の比較一致消失の危険を誘発します。

# 11.9.4. タイマ/カウンタ 比較Aレジスタ (Timer/Counter Output Compare A Register) OCR0A

| ピット         | 7     | 6   | 5   | 4   | 3   | 2   | 1   | 0     |      |
|-------------|-------|-----|-----|-----|-----|-----|-----|-------|------|
| \$36 (\$56) | (MSB) |     |     |     |     |     |     | (LSB) | OCR0 |
| Read/Write  | R/W   | R/W | R/W | R/W | R/W | R/W | R/W | R/W   |      |
| 初期値         | 0     | 0   | 0   | 0   | 0   | 0   | 0   | 0     |      |

この比較レシ、スタは継続的にカウンタ(TCNT0)値と比較される8ビットの値を含みます。一致は比較一致割り込みやOC0Aピンでの波形出力を生成するのに使えます。

### 11.9.5. タイマ/カウンタ 比較Bレシ、スタ (Timer/Counter Output Compare B Register) OCROB

| ピット         | 7     | 6   | 5   | 4   | 3   | 2   | 1   | 0     |       |
|-------------|-------|-----|-----|-----|-----|-----|-----|-------|-------|
| \$29 (\$49) | (MSB) |     |     |     |     |     |     | (LSB) | OCR0B |
| Read/Write  | R/W   | R/W | R/W | R/W | R/W | R/W | R/W | R/W   |       |
| 初期値         | 0     | 0   | 0   | 0   | 0   | 0   | 0   | 0     |       |

この比較レジスタは継続的にカウンタ(TCNT0)値と比較される8ビットの値を含みます。一致は比較一致割り込みやOC0Bピンでの波形出力を生成するのに使えます。

### 11.9.6. タイマ/カウンタ割り込み許可レジスタ (Timer/Counter Interrupt Mask Register) TIMSKO

| ピット         | 7 | 6 | 5 | 4 | 3      | 2      | 1     | 0 |        |
|-------------|---|---|---|---|--------|--------|-------|---|--------|
| \$39 (\$59) | _ | - | - | - | OCIE0B | OCIE0A | TOIE0 | - | TIMSK0 |
| Read/Write  | R | R | R | R | R/W    | R/W    | R/W   | R |        |
| 初期値         | 0 | 0 | 0 | 0 | 0      | 0      | 0     | 0 |        |

#### ■ ビット7~4.0 - Res: 予約 (Reserved)

これらのビットは予約されており、常に0として読まれます。

### ■ ビット3 - OCIEOB: タイマ/カウンタ比較B割り込み許可 (Timer/Counter Output Compare Match B Interrupt Enable)

OCIE0Bビットが1を書かれ、ステータス レジスタ(SREG)の全割り込み許可(I)ビットが設定(1)されると、タイマ/カウンタ比較B一致割り込みが許可されます。タイマ/カウンタ(TCNT0)で比較一致が起こる、換言するとタイマ/カウンク割り込み要求フラグレジスタ(TIFR0)で比較B割り込み要求フラグ(OCF0B)が設定(1)されると、対応する割り込みが実行されます。

### ■ ビット2 - OCIEOA: タイマ/カウンタ比較A割り込み許可 (Timer/Counter Output Compare Match A Interrupt Enable)

OCIEOAビットが1を書かれ、ステータス レジスタ(SREG)の全割り込み許可(I)ビットが設定(1)されると、タイマ/カウンタ比較A一致割り込みが許可されます。タイマ/カウンタ(TCNTO)で比較一致が起こる、換言するとタイマ/カウンタ割り込み要求フラク゛レジスタ(TIFRO)で比較A割り込み要求フラク゛(OCFOA)が設定(1)されると、対応する割り込みが実行されます。

#### ■ ビット1 - TOIE0: タイマ/カウンタ溢れ割り込み許可 (Timer/Counter Overflow Interrupt Enable)

TOIE0ビットが1を書かれて、ステータスレジスタ(SREG)の全割り込み許可(I)ビットが設定(1)されるとタイマ/カウンタ溢れ割り込みが許可されます。タイマ/カウンタ(TCNT0)溢れが起こる、換言するとタイマ/カウンタ割り込み要求フラケ゛レジ、スタ(TIFR0)でタイマ/カウンタ溢れ割り込み要求 (TOV0)フラケ゛が設定(1)されると、対応する割り込みが実行されます。

### 11.9.7. タイマ/カウンタ割り込み要求フラク゛レジスタ (Timer/Counter Interrupt Flag Register) TIFRO

| ピット         | 7 | 6 | 5 | 4 | 3     | 2     | 1    | 0 |       |
|-------------|---|---|---|---|-------|-------|------|---|-------|
| \$38 (\$58) | - | - | - | - | OCF0B | OCF0A | TOV0 | - | TIFR0 |
| Read/Write  | R | R | R | R | R/W   | R/W   | R/W  | R |       |
| 初期値         | 0 | 0 | 0 | 0 | 0     | 0     | 0    | 0 |       |

#### ■ ビット7~4.0 - Res: 予約 (Reserved)

これらのビットは予約されており、常に0として読まれます。

### ■ ビット3 - OCF0B: タイマ/カウンタ比較B割り込み要求フラグ(Timer/Conter, Output Compare B Match Flag)

OCF0Bビットは比較一致がタイマ/カウンタ(TCNT0)と比較レシ、スタ(OCR0B)間で起こる時に設定(1)されます。対応する割り込み処理へ、クタを実行すると、OCF0Bはハードウェアによって解除( $\frac{0}{0}$ )されます。代わりにこのフラケ、へ論理1を書くことによってもOCF0Bは解除( $\frac{0}{0}$ )されます。ステータス レシ、スタ(SREG)の全割り込み許可( $\frac{1}{0}$ )されると、タイマ/カウンタ比較B一致割り込み許可(OCIE0B)ビット、OCF0Bが設定( $\frac{1}{0}$ )されると、タイマ/カウンタ比較B一致割り込みが実行されます。

### ■ ビット2 - OCF0A: タイマ/カウンタ比較A割り込み要求フラグ(Timer/Conter, Output Compare A Match Flag)

OCF0Aビットは比較一致がタイマ/カウンタ(TCNT0)と比較レシ、スタ(OCR0A)間で起こる時に設定(1)されます。対応する割り込み処理へクタを実行すると、OCF0Aはハート・ウェアによって解除( $\frac{0}{0}$ )されます。代わりにこのフラグへ論理1を書くことによってもOCF0Aは解除( $\frac{0}{0}$ )されます。ステータスレシ、スタ(SREG)の全割り込み許可( $\frac{1}{0}$ )されると、タイマ/カウンタ比較A一致割り込み許可( $\frac{1}{0}$ )されると、タイマ/カウンタ比較A一致割り込みが実行されます。

### ■ ビット1 - TOVO: タイマ/カウンタ溢れ割り込み要求フラグ(Timer/Counter Overflow Flag)

TOV0ビットはタイマ/カウンタ(TCNT0)溢れが起こる時に設定(1)されます。対応する割り込み処理ベクタを実行すると、TOV0はハードウェアによって解除(0)されます。代わりにこのフラグへ論理1を書くことによってもTOV0は解除(0)されます。ステータス レジスタ(SREG)の全割り込み許可(I)ビット、タイマ/カウンタ割り込み許可レジスタ(TIMSKO)のタイマ/カウンタ溢れ割り込み許可(TOIE0)ビット、TOV0が設定(1)されると、タイマ/カウンタ溢れ割り込みが実行されます。

このフラグの(1)設定はWGM02~0設定に依存します。47頁の**表11-8.「波形生成種別選択**」を参照してください。





# 12. タイマ/カウンタの前置分周器

#### 12.1. 概要

タイマ/カウンタはシステム クロック(CSn2~0=001設定)により直接的にクロック駆動できます。これはシステム クロック周波数(fclk\_I/O)と等しいタイマ/カウンタ最大クロック周波数での最高速動作を提供します。選択で前置分周器からの4つのタップの1つがクロック元として使えます。この前置分周したクロックはfclk I/O/8, fclk I/O/64, fclk I/O/256, fclk I/O/1024の何れかの周波数です。

### 12.2. 前置分周器リセット

この前置分周器は自由走行です(換言するとタイマ/カウンタのクロック選択論理回路と無関係に動作します)。前置分周器はタイマ/カウンタのクロック選択によって影響されないため、前置分周器の状態は前置分周したクロックが使われる状況に対して密接に関係します。タイマ/カウンタが許可され、前置分周器によってクロック駆動される(CSn2~0=5~2)とき、前置分周加工の一例が生じます。タイマ/カウンタが許可される時から最初の計数が起きるまでのシステムクロック周期数はNが前置分周値(8,64,256,1024)とすると、1~N+1 システムクロック周期になり得ます。

プログラム実行にタイマ/カウンタを同期することに対して前置分周器リセットを使うことが可能です。

### 12.3. 外部クロック元

TOピンに印加した外部クロック元はタイマ/カウンタ クロック(fclk\_To)として使えます。このTOピンはピン同期化論理回路によって全システム クロック周期に1回採取されます。この同期化(採取)された信号はその後にエッジ検出器を通して通過されます。図12-1.はT0同期化とエッジ検出器論理回路の機能等価構成図を示します。レジスタは内部システム クロック(fclk\_I/O)の上昇端でクロック駆動されます。ラッチは内部システム ク ロックのHigh区間で通過(Low区間で保持)です。

エッジ検出器は上昇端(CSn2~0=111)または下降端(CSn2~0=110)の検出毎に1つのclkToパルスを生成します。



同期化とエッジ・検出器論理回路はTOピンへ印加したエッジから計数器が更新されるまでに2.5~3.5システム クロック周期の遅延をもたらします。

クロック入力の許可と禁止はT0が最低1システム クロック周期に対して安定してしまっている時に行われなければならず、さもなければ不正なタイマ/カウンタ クロック パルスが生成される危険があります。

印加された外部クロックの各半周期は正しい採取を保証するために1システム クロック周期より長くなければなりません。この外部クロックは50%/50%デューティ比で与えられるものとして、システム クロック周波数の半分未満(fextelk/felk\_I/O/2)であることが保証されなければなりません。エッジ検出器が採取を使うため、検出できる外部クロックの最大周波数は採取周波数の半分です(ナイキストの標本化定理)。然しながら、発振元(クリスタル発振子、セラミック振動子、コンデンサ)公差によって引き起こされたシステム クロック周波数やデューティ比の変動のため、外部クロック元の最大周波数はfelk\_I/O/2.5未満が推奨されます。



# 12.4. タイマ/カウンタ前置分周器制御用レジスタ

# 12.4.1. 一般タイマ/カウンタ制御レシ、スタ (General Timer/Counter Control Register) GTCCR

| ピット         | 7   | 6 | 5 | 4 | 3 | 2 | 1 | 0     |       |
|-------------|-----|---|---|---|---|---|---|-------|-------|
| \$28 (\$48) | TSM | - | - | - | - | - | - | PSR10 | GTCCR |
| Read/Write  | R/W | R | R | R | R | R | R | R/W   |       |
| 初期値         | 0   | 0 | 0 | 0 | 0 | 0 | 0 | 0     |       |

### ■ ビット7 - TSM: タイマ/カウンタ同時動作 (Timer/Counter Synchronization Mode)

TSMビットに1を書くことはタイマ/カウンタ同期化動作を活性(有効)にします。この動作でPSR10へ書かれる値は保持され、従って対応する前置分周器リセット信号の有効を保持します。これは対応するタイマ/カウンタを停止し、設定中に進行する危険なしに設定できることを保証します。TSMビットが0を書かれると、PSR10ビットはハードウェアによって解除(0)され、同時にタイマ/カウンタが計数を始めます。

### ■ ビット0 - PSR10: タイマ/カウンタ0前置分周器リセット (Prescaler Reset Timer/Counter 0)

このビットが1のとき、タイマ/カウンタ0の前置分周器はリセットします。TSMビットが設定(1)されている場合を除き、通常、このビットはハードウェアによって直ちに解除(0)されます。





# 13. アナログ比較器

アナログ・比較器は非反転入力AIN0(PB0)ピンと反転入力AIN 1(PB1)ピンの入力値を比較します。非反転AIN0(PB0)ピンの電圧が反転AIN1(PB1)ピンの電圧よりも高い時にACSRのアナログ・比較器出力(ACO)ピットが設定(1)されます。この比較器はアナログ・比較器専用の独立した割り込みを起動できます。使用者は比較器出力の上昇端、下降端、またはその両方で割り込み起動を選べます。この比較器とその周辺論理回路の構成図は図13-1.で示されます。

アナログ比較器のピン配置に関しては2頁の「ピン配置」、36頁の表10-5.、表13-1.をご覧ください。



## 13.1. アナログ比較器入力選択

アナログ比較器への反転入力を取り替えるのにADC3~0のどれかを選択することができます。A/D変換の多重器がこの入力選択に使われ、従ってこの機能を利用するためにA/D変換部がOFF(動作禁止)にされなければなりません。ADCSRBのアナログ比較器多重器許可(ACME)とットが設定(1)され、A/D変換部がOFF(ADCSRAのADENとットが0)にされているなら、表13-1.で示されるようにADMUXのチャネル選択(MUX1,0)とットがアナログ比較器への反転入力を取り替えるための入力と、シを選びます。ACMEが解除(0)、またはADENが設定(1)されると、AIN1がアナログ比較器への反転入力に印加されます。

| 表13-1. | アナログ出 | 2較器反射   | <b>公力選択</b> |  |  |  |  |
|--------|-------|---------|-------------|--|--|--|--|
| ACME   | ADEN  | MUX1,0  | アナログ比較器反転入力 |  |  |  |  |
| 0      | X     | хх      | AIN1        |  |  |  |  |
|        | 1     | хх      | AINI        |  |  |  |  |
|        |       | 00 ADC0 |             |  |  |  |  |
| 1      | 0     | 0 1     | ADC1        |  |  |  |  |
|        | U     | 1 0     | ADC2        |  |  |  |  |
|        |       | 1 1     | ADC3        |  |  |  |  |

### 13.2. アナログ比較器用レジスタ

### 13.2.1. A/D変換制御/状態レジスタB (ADC Control and Status Register B) ADCSRB

| ピット         | 7 | 6    | 5 | 4 | 3 | 2     | 1     | 0     |        |
|-------------|---|------|---|---|---|-------|-------|-------|--------|
| \$03 (\$23) | - | ACME | - | - | - | ADTS2 | ADTS1 | ADTS0 | ADCSRB |
| Read/Write  | R | R/W  | R | R | R | R/W   | R/W   | R/W   |        |
| 初期値         | 0 | 0    | 0 | 0 | 0 | 0     | 0     | 0     |        |

### ■ ビット6 - ACME: アナログ比較器多重器許可 (Analog Comparator Multiplexer Enable)

このビットが論理1を書かれ、A/D変換部がOFF(ADCSRAのADENビットが0)にされると、A/D変換の多重器がアナログ比較器への反転入力を選択します。このビットが論理0を書かれると、AIN1がアナログ比較器の反転入力に印加されます。このビットの詳細な記述については上の「アナログ比較器入力選択」をご覧ください。

### 13.2.2. アナログ比較器 制御/状態レジスタ (Analog Comparator Control and Status Register) ACSR

| ピット         | 7   | 6    | 5   | 4   | 3    | 2 | 1     | 0     | _    |
|-------------|-----|------|-----|-----|------|---|-------|-------|------|
| \$08 (\$28) | ACD | ACBG | ACO | ACI | ACIE | - | ACIS1 | ACIS0 | ACSR |
| Read/Write  | R/W | R/W  | R   | R/W | R/W  | R | R/W   | R/W   |      |
| 初期値         | 0   | 0    | 不定  | 0   | 0    | 0 | 0     | 0     |      |

### ■ ビット7 - ACD: アナログ比較器禁止 (Analog Comparator Disable)

このビットが論理1を書かれると、アナログ比較器への電力がOFFにされます。このビットはアナログ比較器をOFFにするために何時でも設定(1)できます。これは活動動作やアイドル動作で電力消費を削減します。ACDビットを変更する時にACSRのアナログ比較器割り込み許可(ACIE)ビットを解除(0)することによってアナログ比較器割り込みが禁止されなければなりません。さもなければ、このビットが変更される時に割り込みが起こり得ます。

### ■ ビット6 - ACBG: 基準電圧選択 (Analog Comparator Bandgap Select)

このビットが設定(1)されると、内部基準電圧(公称1.1V)がアナログ比較器への非反転入力に置き換わります。本ビットが解除(0)されると、AIN0がアナログ比較器の非反転入力に印加されます。内部基準電圧がアナログ比較器への入力として使われるとき、電圧の安定に一定時間を必要とします。安定(待機を)しない場合、不正な比較になるかもしれません。25頁の「内部基準電圧」をご覧ください。

#### ■ ビット5 - ACO: アナログ比較器出力 (Analog Comparator Output)

アナログ比較器の出力は同期化され、その後に直接ACOへ接続されます。この同期化は1~2クロック周期の遅延をもたらします。

### ■ ビット4 - ACI: アナログ比較器割り込み要求フラグ (Analog Comparator Interrupt Flag)

このビットは比較器出力での出来事がACSRのアナログ比較器割り込み条件(ACIS1,0)ビットによって定義した割り込み方法で起動する時に設定(1)されます。ACSRのアナログ比較器割り込み許可(ACIE)ビットが設定(1)され、ステータス レジスタ(SREG)の全割り込み許可(I)ビットが設定(1)されていると、アナログ比較器割り込みルーチンが実行されます。対応する割り込み処理ベクタを実行すると、ACIはハードウェアによって解除(0)されます。代わりにこのフラグへ論理1を書くことによってもACIは解除(0)されます。

#### ■ ビット3 - ACIE: アナログ比較器割り込み許可 (Analog Comparator Interrupt Enable)

ACIEL、ットが論理1を書かれ、ステータスレシ、スタ(SREG)の全割り込み許可(I)ヒ、ットが設定(1)されていると、アナログ、比較器割り込みが活性(有効)にされます。論理0を書かれると、この割り込みは禁止されます。

### ■ ビット2 - Res: 予約 (Reserved)

このビットは予約されており、常に0として読まれます。

#### ■ ビット1,0 - ACIS1,0: アナロゲ比較器割り込み条件 (Analog Comparator Interrupt Mode Select)

これらのビットは比較器のどの事象がアナログ比較器割り込みを起動するのかを決めます。各種設定は表13-2.で示されます。

ACIS1,ACIS0ビットを変更する時にACSRのアナログ比較器割り込み許可(ACIE)ピットを解除(0)することによってアナログ比較器割り込みが禁止されなければなりません。さもなければ、これらのビットが変更される時に割り込みが起き得ます。

| 表13-2. アナ | ログ比較器割り: | 込み条件選択 |
|-----------|----------|--------|
|           |          |        |

| ACIS1 | ACIS0 | 割り込み発生条件      |
|-------|-------|---------------|
| 0     | 0     | 比較器出力の変移(トグル) |
| 0     | 1     | (予約)          |
| 1     | 0     | 比較器出力の下降端     |
| 1     | 1     | 比較器出力の上昇端     |

### 13.2.3. デンタル入力禁止レジスタ0 (Digital Input Disable Register 0) DIDRO

| \$14 (\$34)                      | ピット         | 7 | 6 | 5     | 4     | 3     | 2     | 1     | 0     |       |
|----------------------------------|-------------|---|---|-------|-------|-------|-------|-------|-------|-------|
| Read/Write R R/W R/W R/W R/W R/W | \$14 (\$34) | - | - | ADC0D | ADC2D | ADC3D | ADC1D | AIN1D | AIN0D | DIDR0 |
|                                  | Read/Write  | R | R | R/W   | R/W   | R/W   | R/W   | R/W   | R/W   |       |
| 初期値 0 0 0 0 0 0 0 0              | 初期値         | 0 | 0 | 0     | 0     | 0     | 0     | 0     | 0     |       |

### ■ ビット1,0 - AIN1D,AIN0D: AIN1,AIN0 デジタル入力禁止 (AIN1,AIN0 Digital Input Disable)

このビットが論理1を書かれると、AIN1/0ピンのデジタル入力緩衝部が禁止されます。このビットが設定(1)されると、対応するポート入力レジスタのビット(PINx)は常に0として読みます。AIN1/0ピンにアナログ信号が印加され、そのピンからのデジタル入力が必要とされない時にデジタル入力緩衝部での消費電力を削減するため、このビットは論理1を書かれるべきです。





# 14. A/D変換器

### 14.1. 特徴

- ・10ビット分解能
- ・積分非直線性誤差0.5LSB
- ・絶対精度±2LSB
- ・変換時間13~260µs (50kHz~1MHz変換クロック)
- ・最大分解能で15kSPS(採取/s)まで(200kHz変換クロック)
- ・4チャネルのシングルエント、入力多重器内蔵
- ・A/D変換結果読み出しに対する任意の左揃え
- ・0~VCC A/D変換入力電圧範囲
- ・選択可能な1.1V A/D変換基準電圧
- ・連続と単独の変換動作
- ・割り込み元の自動起動によるA/D変換開始
- ・A/D変換完了割り込み
- ·休止形態雑音低減機能

#### 14.2. 概要

ATtiny13は10ビット逐次比較A/D変換器が特徴です。A/D変換部の構成図は図14-1.で示されます。



A/D変換器はポートBのピンから構成された4つのシングルエント・電圧入力を許す4チャネルアナログ多重器に接続されます。このシングルエント・電圧入力は0V(GND)が基準です。

このA/D変換器はA/D変換器への入力電圧が変換中に一定の値で保持されることを保証する採取&保持(S/H)回路を含みます。公称1.1Vの内蔵基準電圧またはVCCがチップ上で提供されます。

## 14.3. 操作

A/D変換部は逐次比較を通してアナログ入力電圧を10ビットのデジタル値に変換します。最小値はGNDを表し、最大値はAREFビンの電圧-1LSBを表します。A/D多重器選択レジスタ(ADMUX)の基準電圧選択(REFS0)ビットの設定により、基準電圧としてVCCまたは内部 1.1V基準電圧を選択できます(<mark>訳注</mark>:共通性のため本行追加)。

アナログ入力チャネルはADMUXのチャネル選択(MUX1,0)ビットへの書き込みによって選択されます。どのADC入力ピン(ADC3~0)もがA/D変換器のシングルエンド入力として選択できます。

A/D変換部はA/D変換制御/状態レジスタA(ADCSRA)のA/D許可(ADEN)ビットの設定(1)によって(動作が)許可されます。基準電圧と入力チャネルの選択はADENが設定(1)されるまで実施しません。ADENが解除(0)されているとA/D変換部は電力を消費しないので、節電をする休止形態へ移行する前にA/D変換部をOFFに切り替えることが推奨されます。

A/D変換部はA/Dデータレジスタ(ADCH,ADCL)で示される10ビットの結果を生成します。既定ではこの結果は右揃え(16ビットのビット0側 10ビット)で表されますが、ADMUXで左揃え選択(ADLAR)ビットを設定(1)することにより、任意で左揃え(16ビットのビット15側10ビット)で表せます。

この結果が左揃え補正され、8ビットを越える精度が必要とされない場合はADCHを読むことで足ります。さもなければデータレシ、スタの内容が同じ変換に属すこと(からの結果)を保証するため、ADCLが初めに、次にADCHが読まれなければなりません。一度ADCLが読まれると、A/D変換器からのA/Dデータレジスタ(ADCH,ADCL)アクセスが阻止されます。これはADCLが読まれてしまい、ADCHが読まれる前に変換が完了すると、どちらのレジスタ(ADCH,ADCL)も更新されず、その変換からの結果が失われることを意味します。ADCHが読まれると、ADCH,ADCLへのA/D変換器アクセスが再び許可されます。

A/D変換部には変換完了時に起動できる自身の割り込みがあります。A/DデータレジスタへのA/D変換器アクセスがADCLとADCHの読み込み間で禁止されている場合、例えその変換結果が失われても割り込みは起動します。

### 14.4. 変換の開始

単独変換はADCSRAに於いて変換開始(ADSC)ビットに論理1を書くことによって開始されます。このビットは変換が進行中である限り1に留まり、変換が完了されるとハードウェアによって解除(0)されます。変換が進行中に違う入力チャネルが選択されると、A/D変換部はそのチャネル変更を実行する前に現在の変換を済ませます。

代わりに変換は様々な起動元によって自動的に起動できます。自動起動はA/D変換制御/状態レジスタA(ADCSRA)のA/D変換自動起動許可(ADATE)ビットの設定(1)によって許可されます。起動元はA/D変換制御/状態レジスタB(ADCSRB)のA/D変換起動元選択(ADTS2~0)ビットの設定によって選択されます(起動元の一覧についてはADTSビットの記述をご覧ください)。選択した起動信号上に上昇端が起きると、A/D変換用前置分周器がリセットして変換が開始されます。これは一定間隔での変換開始の方法を提供します。変換完了時、起動信号が未だ設定(1)されている場合、新規の変換は開始されません。変換中にこの起動信号上で別の上昇端が起きると、そのエッジは無視されます。指定した割り込みが禁止またはステータスレジスタ(SREG)の全割り込み許可(1)ビットが解除(0)でも、割り込み要求フラグが設定(1)されることに注意してください。従って割り込みを起こさずに変換が起動できます。けれども次の割り込み要因で新規変換を起動するために、割り込み要求フラグは解除(0)されなければなりません。



起動元としてA/D変換完了割り込み要求フラグ(ADIF)を使うことは、A/D変換器に実行中の変換が完了されると直ぐに新規変換を開始させます。そのためA/D変換器は連続動作で動き、継続的な採取(変換)とA/Dデータレジスタを更新します。最初の変換はADCSRAでADSCビットに論理1を書くことによって始めなければなりません。この動作でのA/D変換器はA/D変換完了割り込み要求フラグ(ADIF)が解除(0)されるかどうかに拘らず、連続的な変換を実行します。

自動起動が許可されている場合、ADCSRAのADSCビットに論理1を書くことによって単独変換を開始できます。ADSCは変換が進行中かを決めるためにも使えます。ADSCビットは変換がどう開始されたかに拘らず、変換中は1として読めます。

変換はA/D変換雑音低減機能の使用によっても開始され得ます。この機能はアイドル休止動作とA/D変換雑音低減休止動作中に変換を許可します。詳細については58頁の「雑音低減機能」をご覧ください。(<mark>訳注</mark>:共通性から2行追加)





### 14.5. 前置分周と変換タイミング

既定での逐次比較回路は最大分解能を得るのに50~200kHzの入力クロック周波数を必要とします。10ビットよりも低い分解能が必要とされるなら、A/D変換器への入力クロック周波数はより高い採取速度を得るために200kHzよりも高くできます。

A/D変換部は100kHz以上のどんなCPUクロックからも受け入れ可能なA/D変換クロック周波数を生成する前置分周器を含みます。この前置分周はA/D変換制御/状態レジスタA(ADCSRA)のA/Dクロック選択(ADPS2~0)ビットによって設定されます。前置分周器はADCSRAでA/D許可(ADEN)ビットの設定(1)によってA/D変換部がONにされた瞬間から計数を開始します。前置分周器はADENビットが設定(1)される限り走行を維持し、ADENが0の時は継続的にリセットします。

ADCSRAのA/D変換開始(ADSC)ビットの設定(1)によってシングルェンド入力の変換を起動すると、その変換は直後の変換クロックの上昇端で始まります。

通常の変換は13変換クロック周期で行われます。A/D変換部がONされる(ADCSRAの ADEN=1)後の最初の変換はアナログ回路を初期化するために、下の図14-4.で示されるように25変換クロック周期で行われます。





内部基準電圧がA/D変換器への入力として使われるとき、電圧の安定に一定時間を必要とします。安定(待機を)しない場合は初回変換後の最初の読み込み値は不正になるかもしれません。

実際の採取&保持(保持開始点)は通常変換の開始後1.5変換クロック周期、初回変換の開始後13.5変換クロック周期で行われます。変換が完了すると、結果がA/Dデータ レジスタ(ADCH,ADCL)に書かれ、ADCSRAのA/D変換完了割り込み要求フラグ(ADIF)が設定(1)されます。単独変換動作(ADATE=0)では同時にADCSRAのA/D変換開始(ADSC)ビットが解除(0)されます。その後にソフトウェアは再びADSCを設定(1)でき、新規変換は変換クロックの最初の上昇端で開始されます。



自動起動が使われると、前置分周器は起動要因発生時にリセットされます。これは起動要因から変換開始までの一定の遅延を保証します。この動作での採取&保持は起動要因となる信号の上昇後、2変換クロック周期で採取が行われます。同期化論理回路(エッシ・検出器)に対して追加の3CPUクロック周期が費やされます。



連続変換動作(ADATE=1)では変換完了後直ちに新規変換が開始され、一方ADSCは1に留まります。変換時間の要約については表14-1.をご覧ください。



| 表14-1. A/D変換時間  |          |           |
|-----------------|----------|-----------|
| 変換種別            | 保持点      | 変換時間      |
| 初回変換            | 13.5     | 25        |
| シングルエント、入力通常変換  | 1.5      | 13        |
| 自動起動変換          | 1.5 (2)  | 13.5      |
| 注: 変換時間を除く各値は変担 | 奥開始からの変換 | 換クロック数です。 |

### 14.6. チャネル変更と基準電圧選択

A/D多重器選択レジスタ(ADMUX)のチャネル選択(MUX1,0)ビットと基準電圧選択(REFS0)ビットはCPUが欄順にアクセスするための一時レジスタを通して単独緩衝されます。これはチャネルと基準電圧の選択が変換中の安全なところでだけ行うのを保証します。チャネルと基準電圧の選択は変換が開始されるまで継続的に更新されます。一旦変換が始まると、A/D変換器に対して充分な採取/変換時間を保証するためにチャネルと基準電圧の選択は固定されます。継続的な更新は変換完了(ADCSRAのADIF=1)前の最後の変換クロック周期で再開します。ADCSRAの変換開始(ADSC)ビットが書かれた後の次の変換クロックの上昇端で変換が始まることに注意してください。従って使用者はADSC書き込み後、1変換クロック周期(経過)まで新しいチャネルまたは基準電圧選択値をADMUXに書かないことが推奨されます。

自動起動が使われる場合、起動要因の正確な時間は確定できません。変換が新規設定によって影響されるように制御するには ADMUXの更新時に特別な注意が祓われなければなりません。

ADCSRAのA/D許可(ADEN)とA/D変換自動起動許可(ADATE)の両方が1を書かれると、何時でも割り込みが起き得ます。この期間でADMUXが変更されると、使用者は次の変換が旧設定または新設定どちらを基準にされるかを知ることができません。ADMUXは次の方法で安全に更新できます。

- ・ADENまたはADATEが解除(0)されているとき。
- ・変換開始後、最低1変換クロック周期経過後の変換中。
- ・変換後から、変換起動元として使った割り込みフラグが解除(0)される直前まで。

これら条件の1つでADMUXを更新すると、新設定は次のA/D変換に影響を及ぼします。

#### 14.6.1. A/D入力チャネル

チャネル選択を変更する時に使用者は正しルチャネルが選択されることを保証するために次の指針を守るべきです。

単独変換動作では常に変換を始める前にチャネルを選択してください。チャネル選択はADSCへの1書き込み後、1変換クロック周期で変更されるかもしれません。とは言え、最も簡単な方法はチャネル選択を変更する前に変換が完了するまで待つことです。

連続変換動作では常に最初の変換を始める前にチャネルを選択してください。チャネル選択はADSCへの1書き込み後、1変換クロック周期で変更されるかもしれません。とは言え、最も簡単な方法は最初の変換が完了するまで待ち、その後にチャネル選択を変更することです。既に次の変換が自動的に開始されているので、次の結果は直前のチャネル選択を反映します。それに続く変換は新しいチャネル選択を反映します。





## 14.6.2. A/D変換基準電圧

このA/D変換用の基準電圧(VREF)はA/D変換に対する変換範囲を示します。VREFを越えるシングルエンド入力チャネルは\$3FFで打ち切るコードに帰着します。VREFはVCC、内部1.1V基準電圧のどちらかとして選択できます。基準電圧源切り替え後の最初のA/D変換結果は不正確かもしれず、使用者はこの結果を破棄することが推奨されます。

### 14.7. 雜音低減機能

このA/D変換部はCPUコアと他の周辺I/Oが誘導した雑音を削減するために休止形態中の変換を可能にする雑音低減機能が特徴です。この機能はA/D変換雑音低減動作とアイル動作で使えます。この機能を使うには次の手順が使われるべきです。

- 1. A/D変換部が許可(ADEN=1)され、変換中でない(ADSC=0)ことを確認してください。単独変換動作が選択(ADATE=0)され、且つ A/D変換完了割り込みが許可(ADIE=1)されていなければなりません。
- 2. A/D変換雑音低減(またはアイドル)動作に移行してください。一旦CPUが停止されてしまうと、A/D変換部は変換を始めます。
- 3. A/D変換完了前に他の割り込みが起こらなければ、A/D変換完了割り込みはCPUを起動してA/D変換完了割り込みルーチンを実行します。A/D変換完了前に他の割り込みがCPUを起動すると、その割り込みが実行され、A/D変換完了割り込み要求はA/D変換完了時に生成されます。CPUは新規SLEEP命令が実行されるまで活動動作に留まります。

アイドル動作とA/D変換雑音低減動作を除く他の休止形態へ移行する時にA/D変換部が自動的にOFFへ切り替えられないことに注意してください。使用者は余分な消費電力を避けるため、このような休止形態へ移行する前にADENへ0を書くことが推奨されます。

### 14.8. アナログ入力回路

シングル エント・入力チャネルのアナログ回路は**図14-8**.で図示されます。ADCnに印加したアナログ(信号)源はそのチャネルがADC入力として選択されているかどうかに拘らず、ピン容量とそのピンの漏れ電流に左右されます。そのチャネルが選択されると、(アナログ信号)源は直列抵抗(入力経路の合成抵抗)を通してS/Hコンテンサを駆動しなければなりません。

A/D変換部は概ね10kΩ若しくはそれ以下の出力インピーダンスのアナログ信号用に最適化されています。このような(アナログ信号)源が使われるなら、採取時間は無視してもよいでしょう。より高いインピーダンスの(アナログ信号)源が使われる場合、採取時間は広範囲に変化し得るS/Hコンデンサを充電するために(アナログ信号)源がどれくらいの時間を必要とするかに依存します。必要とされるS/Hコンデンサへの充放電を最小とするため、使用者は緩やかに変化する低インピーダンス(アナログ信号)源だけを使うことが推奨されます。

特定できない信号の渦からの歪を避けるために、どのチャネルに対してもナイキスト周波数 (fADC/2)よりも高い信号成分が存在すべきではありません。使用者はADC入力として信号を印加する前に低域通過濾波器(ローパスフィルタ)で高い周波数成分を取り除くことが推奨されます。



注: 図内のコンデンサ容量はS/Hコンデンサとデバイス内の何れかの浮遊容量または寄生容量を含む合計容量を叙述します。 与えられた 値は最悪(最大)値です。

### 14.9. アナログ雑音低減技術

デバイス内外のデジタル回路がアナログ測定の精度に影響を及ぼすかもしれないEMIを発生します。変換精度が重要などき、次の技法を適用することによって雑音レベルを低減できます。

- ・アナログ信号経路を可能な限り最短にしてください。
- ・アナログ信号経路がアナログGND面上を走ることを確認してください。
- アナログ信号経路を高速切り替えデジタル信号線から充分離すことを守ってください。
- ・何れかのADCポートピンがデジタル出力として使われる場合、これらを変換進行中に決して切り替えてはなりません。
- ・可能な限りVCCとGNDピンの近くにパスコンを配置してください。

高いA/D変換精度が必要とされるとき、「**雑音低減機能**」で記述されるようにA/D変換雑音低減動作の使用が推奨されます。これは特にシステム クロック周波数が1MHz以上の場合です。正しい外部パペコン配置での良いシステム設計はA/D変換雑音低減動作の必要性を低減します。

## 14.10. A/D変換の精度定義

シングル エント、入力電圧のnビットA/D変換はGNDとVREF間を2<sup>n</sup>で直線的に変換します。最低値コート、は0として読み、最高値コート、は2<sup>n</sup>-1として読みます。以下の各種パラメータは理想状態からの偏差を表します。

#### ● オフセット誤差 - 図14-9.

最初の遷移点(\$000から\$001)に於いて理想遷移点(差0.5 LSB)と比較した偏差です。理想値は0LSBです。

#### ● 利得誤差 - 図14-10.

オフセット誤差補正後の最後の遷移点(\$3FEから\$3FF)に於いて理想遷移点(最大差1.5LSB以下)と比較した偏差です。理想値は0LSBです。

#### ● 積分非直線性誤差 (INL) - 図14-11.

オフセット誤差と利得誤差補正後の全ての遷移点に於いて理想遷移点と比較した最大偏差です。理想値は0LSBです。

#### ● 微分非直線性誤差 (DNL) - 図14-12.

実際のコードの幅(隣接する2つの遷移点間)に於いて理想コード幅(1LSB)と比較した最大偏差です。理想値は0LSBです。

#### ● 量子化誤差

有限数のコートで入力電圧を量子化するため、1LSB幅となる 入力電圧範囲は同じ値のコートになります。この値は常に ±0.5LSBです。

#### ● 絶対精度

補正しない全ての遷移点に於いて理想遷移点と比較した最大偏差です。これは、オフセット誤差、利得誤差、差動誤差、非直線誤差の影響の合成です。理想値は±0.5LSBです。









# 14.11. A/D変換の結果

変換完了(ADIF=1)後、変換結果はA/Dデータレジスタ(ADCH, ADCL)で得られます。 シングルエンド入力変換での結果は次式で示されます。

$$ADC = \frac{V_{IN} \times 1024}{V_{REF}}$$

 $V_{IN}$ は選択した入力ピンの電圧で、 $V_{REF}$ は選択した基準電圧です(60頁の表14-2.と表14-3.をご覧ください)。\$000はアナロゲGNDを表し、\$3FFは選択した基準電圧-1LSBを表します。





# 14.12. A/D変換用レジスタ

### 14.12.1. A/D多重器選択レジスタ (ADC Multiplexer Select Register) ADMUX

| ピット         | 7 | 6     | 5     | 4 | 3 | 2 | 1    | 0    |       |
|-------------|---|-------|-------|---|---|---|------|------|-------|
| \$07 (\$27) | _ | REFS0 | ADLAR | - | - | - | MUX1 | MUX0 | ADMUX |
| Read/Write  | R | R/W   | R/W   | R | R | R | R/W  | R/W  |       |
| 初期値         | 0 | 0     | 0     | 0 | 0 | 0 | 0    | 0    |       |

■ ビット7 - Res: 予約 (Reserved)

このビットは予約されており、常に0として読まれます。

■ ビット6 - REFS0: 基準電圧選択 (Reference Select Bit)

このビットは表14-2.で示されるようにA/D変換器の基準電圧を選びます。このビットが変換中に変更されると、その変更は変換が完了する(ADCSRAのADIF=1)まで実施しません。

| 表14-2.     | A/D変換部の基準電圧選択 |  |  |  |  |  |  |
|------------|---------------|--|--|--|--|--|--|
| REFS0 基準電圧 |               |  |  |  |  |  |  |
| 0          | 基準電圧としてVCCを使用 |  |  |  |  |  |  |
| 1          | 内部1.1V基準電圧    |  |  |  |  |  |  |

#### ■ ビット5 - ADLAR: 左揃え選択 (ADC Left Adjust Result)

ADLARビットはA/Dデータ レジスタ内の変換結果の配置に影響を及ぼします。結果を左揃えにするにはADLARに1を書いてください。さもなければ結果は右揃えです。ADLARビットの変更はどんな進行中の変換にも拘らず、直ちにA/Dデータ レジスタの内容に影響を及ぼします。このビットの完全な記述については62頁の「A/Dデータ レジスタ」をご覧ください。

■ ビット4~2 - Res: 予約 (Reserved)

これらのビットは予約されており、常に0として読まれます。

■ ビット1,0 - MUX1,0: A/Dチャネル選択 (Analog Channel Select Bits)

これらのビットの値はA/D変換器にどのアナログ入力が接続されるかを選びます。詳細については**表14-3**.をご覧ください。これらのビットが変換中に変更される場合、その変更は変換が完了する(ADCSRAのADIF=1)まで実施しません。

| 表14-3. アナ | 表14-3. アナログ入力チャネル選択 |  |  |  |  |  |  |  |  |  |
|-----------|---------------------|--|--|--|--|--|--|--|--|--|
| MUX1,0    | シングル エント 入力         |  |  |  |  |  |  |  |  |  |
| 0 0       | ADC0 (PB5)          |  |  |  |  |  |  |  |  |  |
| 0 1       | ADC1 (PB2)          |  |  |  |  |  |  |  |  |  |
| 1 0       | ADC2 (PB4)          |  |  |  |  |  |  |  |  |  |
| 11        | ADC3 (PB3)          |  |  |  |  |  |  |  |  |  |

### 14.12.2. A/D変換 制御/状態レジスタA (ADC Control and Status Register A) ADCSRA

| ピット         | 7    | 6    | 5     | 4    | 3    | 2     | 1     | 0     |        |
|-------------|------|------|-------|------|------|-------|-------|-------|--------|
| \$06 (\$26) | ADEN | ADSC | ADATE | ADIF | ADIE | ADPS2 | ADPS1 | ADPS0 | ADCSRA |
| Read/Write  | R/W  | R/W  | R/W   | R/W  | R/W  | R/W   | R/W   | R/W   |        |
| 初期値         | 0    | 0    | 0     | 0    | 0    | 0     | 0     | 0     |        |

### ■ ビット7 - ADEN: A/D許可 (ADC Enable)

このビットに1を書くことがA/D変換部(動作)を許可します。0を書くことによってA/D変換部は(電源が)OFFされます。変換が進行中に A/D変換部をOFFにすることはその変換を(途中)終了します。

■ ビット6 - ADSC: A/D変換開始 (ADC Start Conversion)

単独変換動作で各変換を始めるにはこのビットへ1を書いてください。連続変換動作で最初の変換を始めるにはこのビットへ1を書いてください。A/D変換部が許可される(ADEN=1)と同時にADSCが書かれるか、またはA/D変換部が許可されてしまった後にADSCが書かれた後の初回変換は、通常の13に代わって25変換クロック周期で行います。この初回変換はA/D変換部の初期化を実行します。ADSCは変換が進行中である限り1として読めます。変換が完了すると0に戻ります。このビットへの0書き込みは無効です。

■ ビット5 - ADATE: A/D変換自動起動許可 (ADC Auto Trigger Enable)

このビットが1を書かれると、A/D変換の自動起動が許可されます。A/D変換器は選択した起動信号の上昇端で変換を開始します。この起動元はA/D変換制御/状態レジスタB(ADCSRB)のA/D変換起動要因選択(ADTS2~0)ビット設定によって選択されます。

### ■ ビット4 - ADIF: A/D変換完了割り込み要求フラグ(ADC Interrupt Flag)

A/D変換が完了し、A/Dデータレジスタが更新されると、このフラケが設定(1)されます。ステータスレジスタ(SREG)の全割り込み許可(I)ビットと A/D変換完了割り込み許可(ADIE)ビットが設定(1)されていればA/D変換完了割り込みが実行されます。対応する割り込み処理へクタを実行する時にADIFはハートウェアによって解除(0)されます。代わりにこのフラケに論理1を書くことによってもADIFは解除(0)されます。 ADCSRAで読み-変更-書き(リート・モディファイライト)を行うと、保留中の割り込みが禁止され得ることに注意してください。これはSBI,CBI 命令が使われる場合にも適用されます。

#### ■ ビット3 - ADIE: A/D変換完了割り込み許可 (ADC Interrupt Enable)

このビットが1を書かれ、SREGの全割り込み許可(I)ビットが設定(1)されていると、A/D変換完了割り込みが活性に(許可)されます。この ビットが解除(0)されると、この割り込みは禁止されます(訳注:共通性のため本行追加)。

### ■ ビット2~0 - ADPS2~0: A/D変換クロック選択 (ADC Prescaler Select Bits)

これらのビットはシステム クロック周波数とA/D変換部への入力クロック間の分周値を決めます。

| 表14-4. A/D変換ク | 表14-4. A/D変換クロック選択 (CK=システム クロック) |      |      |      |       |       |       |        |  |  |  |  |
|---------------|-----------------------------------|------|------|------|-------|-------|-------|--------|--|--|--|--|
| ADPS2         | 0                                 | 0    | 0    | 0    | 1     | 1     | 1     | 1      |  |  |  |  |
| ADPS1         | 0                                 | 0    | 1    | 1    | 0     | 0     | 1     | 1      |  |  |  |  |
| ADPS0         | 0                                 | 1    | 0    | 1    | 0     | 1     | 0     | 1      |  |  |  |  |
| A/D変換クロック     | CK/2                              | CK/2 | CK/4 | CK/8 | CK/16 | CK/32 | CK/64 | CK/128 |  |  |  |  |

### 14.12.3. A/D変換 制御/状態レジスタB (ADC Control and Status Register B) ADCSRB

| ピット         | 7 | 6    | 5 | 4 | 3 | 2     | 1     | 0     |        |
|-------------|---|------|---|---|---|-------|-------|-------|--------|
| \$03 (\$23) | _ | ACME | - | - | - | ADTS2 | ADTS1 | ADTS0 | ADCSRB |
| Read/Write  | R | R/W  | R | R | R | R/W   | R/W   | R/W   |        |
| 初期値         | 0 | 0    | 0 | 0 | 0 | 0     | 0     | 0     |        |

### ■ ビット7,5~3 - Res: 予約 (Reserved Bit)

これらのビットは予約されており、常に0として読まれます。

#### ■ ビット2~0 - ADTS2~0: A/D変換自動起動要因選択 (ADC Auto Trigger Source)

A/D変換制御/状態レシ、スタA(ADCSRA)のA/D変換自動起動許可(ADATE) に、外が1を書かれると、これらのじ、外の値はどの起動元がA/D変換を起動するのかを選択します。ADATEが解除(0)されると、ADTS2~0設定は無効です。変換は選択した割り込みフラグの上昇端によって起動されます。解除(0)されている起動元から設定(1)されている起動元への切り替えが起動信号上に上昇端を生成することに注意してください。ADCSRAのA/D許可(ADEN) に、外が設定(1)されているなら、これが変換を開始させます。連続変換動作(ADTS2~0=0)への切り替えは、例えA/D変換完了割り込み要求フラグが設定(1)されていても、起動事象を引き起こしません。

ADTS2 ADTS1 ADTS0 起動元 連続変換動作 0 0 0 0 0 アナログ比較器 0 外部割り込み要求0 0 1 1 タイマ/カウンタ比較A一致 0 0 タイマ/カウンタ溢れ 1 0 1 タイマ/カウンタ比較B一致 1 0 ピン変化割り込み要求

(予約)

表14-5. A/D変換自動起動元選択





### 14.12.4. A/Dデータレジスタ (ADC Data Register) ADCH,ADCL

|             | ADLAR=0 | 時    |      |      |      |      |      |      |      |
|-------------|---------|------|------|------|------|------|------|------|------|
| ピット         | 15      | 14   | 13   | 12   | 11   | 10   | 9    | 8    |      |
| \$05 (\$25) | _       | -    | -    | -    | -    | -    | ADC9 | ADC8 | ADCH |
| Read/Write  | R       | R    | R    | R    | R    | R    | R    | R    |      |
| 初期値         | 0       | 0    | 0    | 0    | 0    | 0    | 0    | 0    |      |
| ピット         | 7       | 6    | 5    | 4    | 3    | 2    | 1    | 0    |      |
| \$04 (\$24) | ADC7    | ADC6 | ADC5 | ADC4 | ADC3 | ADC2 | ADC1 | ADC0 | ADCL |
| Read/Write  | R       | R    | R    | R    | R    | R    | R    | R    |      |
| 初期値         | 0       | 0    | 0    | 0    | 0    | 0    | 0    | 0    |      |
|             | ADLAR=1 | 時    |      |      |      |      |      |      |      |
|             | 15      | 14   | 13   | 12   | 11   | 10   | 9    | 8    | _    |
|             | ADC9    | ADC8 | ADC7 | ADC6 | ADC5 | ADC4 | ADC3 | ADC2 | ADCH |
|             | 7       | 6    | 5    | 4    | 3    | 2    | 1    | 0    |      |
|             |         |      |      |      |      |      |      |      | 4001 |
|             | ADC1    | ADC0 | _    | _    | _    | _    | _    | _    | ADCL |

A/D変換が完了すると、その結果がこれら2つのレジスタで得られます。

ADCLが読まれると、A/DデータレジスタはADCHが読まれるまで更新されません。従ってこの結果が左揃えで且つ8ビットを越える精度が必要とされないなら、ADCHを読むことで用が足ります。さもなければADCLが先に、その後にADCHが読まれなければなりません。A/D多重器選択レジスタ(ADMUX)の左揃え選択(ADLAR)ビットとA/Dチャネル選択(MUX1,0)ビットは、このレジスタから結果を読む方法に影響を及ぼします。ADLARが設定(1)されると、結果は左揃えにされます。ADLARが解除(0)されていると(既定)、結果は右揃えにされます。

### ■ ADC9~0: A/D変換結果 (ADC Conversion result)

これらのビットは59頁の「A/D変換の結果」で詳述されるように変換での結果を表します。

## 14.12.5. デジタル入力禁止レジスタ0 (Digital Input Disable Register 0) DIDRO

| ピット         | 7 | 6 | 5     | 4     | 3     | 2     | 1     | 0     |       |
|-------------|---|---|-------|-------|-------|-------|-------|-------|-------|
| \$14 (\$34) | _ | - | ADC0D | ADC2D | ADC3D | ADC1D | AIN1D | AIN0D | DIDR0 |
| Read/Write  | R | R | R/W   | R/W   | R/W   | R/W   | R/W   | R/W   |       |
| 初期値         | 0 | 0 | 0     | 0     | 0     | 0     | 0     | 0     |       |

### ■ ビット5~2 - ADC3D~ADC0D: ADC3~0 デジタル入力禁止 (ADC3~0 Digital Input Disable)

このビットが論理1を書かれると、対応するADCnt゚ンのデジタル入力緩衝部が禁止されます。このビットが設定(1)されると、対応するポート入力レジスタのビット(PINx)は常に0として読みます。アナログ信号がADC3~0ピンに印加され、そのピンからのデジタル入力が必要とされない時にデジタル入力緩衝部での消費電力を削減するため、そのビットは論理1を書かれるべきです。

# 15. デバッグWIRE 内蔵デバッグ システム

# 15.1. 特徴

- ・完全なプログラムの流れ制御
- ・RESETピンを除くデジタルとアナログ両方でのチップ全機能のエミュレート
- ・実時間(リアル タイム)動作
- ・シンホリック デバッグ支援 (アセンフリ及びC言語または他の高位言語)
- ・無制限数のプログラム中断点(ブレーク ポイント: ソフトウェア中断点使用)
- ・邪魔しない動作
- ・実デバイスと同じ電気的特性
- 自動設定システム
- ・高速動作
- ・不揮発性メモリのプログラミング

**15.2. 概要** デバッグWIRE内蔵デバッグ システムはCPUでのAVR命令実行、プログラムの流れ制御、各種不揮発性メモリのプログラミングのための1本線の双方向インターフェースを使います。

### 15.3. 物理インターフェース

デバック'WIRE許可(DWEN)ヒュース'がプログラム(0)され、施錠ビットが非プログラム(1)にされると、対象デバイス内のデバック'WIREシステムが活性(有効)にされます。RESETポート ピンはプルアップ。許可のANDタイ(オープントレイン)双方向I/Oピンとして設定され、対象デバイスとエミュレータ間の通信路になります。

図15-1.はエミュレータと許可したデバックWIREでの対象MCUとの接続の図を示します。システムクロックはデバックWIREによって影響を及ぼされず、常にCKSELヒュースで選択したクロック元です。



- ・dW/(RESET)線のプルアップ。抵抗は $10k\sim20k\Omega$ の範囲でなければなりません。けれどもこのプルアップ。抵抗は任意です。
- ・RESETピンのVCCへの直接的な接続では動作しません。
- ・RESETt°ンに挿入したコンテンサはデハックWIRE使用時、切断されなければなりません。
- 全ての外部リセット元は切断されなければなりません。

### 15.4. ソフトウェア中断点(ブレーク ポペイント)

デバック・WIREはAVRのBREAK命令によってプログラム メモリの中断点を支援します。AVR Studio®での中断点設定はプログラム メモリに BREAK命令を挿入します。BREAK命令で置換した(元の)命令は保存されます。プログラム実行が継続されるとき、プログラム メモリから継続される前に保存した命令が実行されます。一時停止(ブレーク)はプログラムにBREAK命令を置くことによって手動で挿入できます。

フラッシュ メモリは中断点が変更される度毎に再書き換えされなければなりません。これはデバッグWIREインターフェースを通してAVR Studioによって自動的に操作されます。従って中断点の使用はフラッシュ メモリのデータ保持力を低下させます。デバッグ目的に使ったデバイスは最終顧客へ出荷すべきではありません。

## 15.5. デバッグWIREの制限

ディック、WIRE通信(dW)ピンは物理的に外部リセット(RESET)と同じピンに配置されます。従ってディック、WIREが許可されると、外部リセット元が支援されません。

デバック、WIREシステムは全速度、換言するとCPUのプログラムが走行する時に全I/O機能を正確エミュレートします。CPUが停止される時にデバッカ、(AVR Studio)経由でいくつかのI/Oレジスタをアクセスする間、注意が祓われなければなりません。この制限の詳細説明についてはデバック、WIRE資料をご覧ください。

デバック・WIREインターフェースはデバッカがシステム クロックに同期する必要を意味する、非同期です。システム クロックがソフトウェア(例えばCLKPS ビット書き込み)によって変更されると、デバック・WIRE経由通信は失敗するかもしれません。また、100kHz未満のクロック周波数は通信問題を引き起こすかもしれません。

プログラム(0)にしたDWENヒュース、は全休止形態でクロック系のいくつかの部分の走行を許可します。これは休止間中の消費電力を増加します。従ってDWENヒュース、はデバック、WIREが使われない場合、禁止されるべきです。

## 15.6. デバックWIRE用レジスタ

次項はデバッグWIREで使うレジスタを記述します。

### 15.6.1. デバック WIRE データレジスタ (debugWIRE Data Register) DWDR



DWDRはMCU内で走行するプログラムからディッカーへの通信チャネルを提供します。このレジスタはディックWIREでだけアクセス可能で、従って通常動作で一般目的レジスタとして使えません。





# 16. フラッシュ メモリの 自己プログラミング

本デバイスはMCU自身によるプログラムコート、のダウンロート、とアップロート、用の自己プログラミング、機構を提供します。自己プログラミングはフラッシュメモリ内にコート、を書き(プログラム)、コート、を読み、またはプログラムメモリからコート、を読むのに、利用可能なデータインターフェースと関連する規約のどれもが使えます。SPM命令は既定で禁止ですが、SELFPRGENヒュース、を(のに)プログラミングすることで許可にできます。

プログラム メモリはヘージ単位形式で更新されます。ヘージー時緩衝部へ格納したデータでヘージを書く前にそのヘージは消去されなければなりません。ヘージー時緩衝部はSPM命令使用時毎の1語(ワート)で満たされ、この緩衝部はヘージ消去命令前、またはヘージ消去とヘージ書き込み操作間のどちらかで満たすことができます。

### **手段1**. (ページ消去前の一時緩衝部格納)

- ページー時緩衝部を満たしてください。
- ペーシ消去を実行してください。
- ページ書き込みを実行してください。

#### 手段2.(ペーシ)消去後の一時緩衝部格納)

- ・ページ消去を実行してください。
- ・ページー時緩衝部を満たしてください。
- ページ書き込みを実行してください。

へ°ーシ'の一部の変更だけが必要な場合、消去前にへ°ーシ'の残す部分は(例えばヘ°ーシ'一時緩衝部に)保存されなければならず、その後に改めて書かれます。**手段1.**を使う場合、初めにヘ°ーシ'を読んで必要な変更を行い、その後に変更したデータを書き戻すことを使用者ソフトウェアに許す効率的な読みー修正ー書き(リート' モデファイライト)機能をデバイスが提供します。**手段2.**が使われる場合、ヘ°ーシ'が既に消去されているため、格納中の旧データを読むことができません。ヘ°ーシ'一時緩衝部は乱順でアクセスできます。ヘ°ーシ'消去とヘ°ーシ'書き込み操作の両方で使われるヘ°ーシ、アト・レスは同じヘ°ーシをアト・レス指定することが非常に重要です。

### 16.1. SPM命令によるページ消去の実行

へ°ーシ´消去を実行するにはZポインタにアドレスを設定してSPM命令制御/状態レジスタ(SPMCSR)に'00000011'を書き、SPMCSR書き込み後4クロック周期内にSPM命令を実行してください。R1とR0のデータは無視されます。 ぺージ アドレスはZポインタのPCPAGEに書かれなければなりません。この操作中、Zポインタの他のビットは無視されます。

注: ページ消去中、CPUは停止されます。

### 16.2. ページー 時緩衝部の設定 (ページ設定)

命令語(ワート)を(ページ一時緩衝部に)書くにはZポインタにアドレス、R1:R0にデータを設定してSPMCSRに'00000001'を書き、SPMCSR書き込み後4クロック周期内にSPM命令を実行してください。ZポインタのPCWORDの内容は一時緩衝部のデータのアドレスに使われます。一時緩衝部はページ書き込み操作後、またはSPMCSRのページ一時緩衝部消去(CTPB)ビット書き込みによって自動的に消去されます。システムリセット後も消去されています。一時緩衝部を消去せずに各アドレスへ複数回書くことができないことに注意してください。

SPMページ設定操作の途中でEEPROMが書かれると、設定した全データが失われます。

#### 16.3. ページ書き込みの実行

へージ書き込みを行うにはZポインタにアドレスを設定し、SPMCSRに'00000101'を書き、SPMCSR書き込み後4クロック周期内にSPM命令を実行してください。R1とR0のデータは無視されます。ヘージ アドレスは(Zポインタの)PCPAGEに書かれなければなりません。この操作の間中、Zポインタの他のビットは0を書かれなければなりません。

注: ページ書き込み中、CPUは停止されます。

# 16.4. 自己プログラミング中のフラッシュ メモリのアドレス指定

Zポインタ(レジスタ)はSPM命令でのアドレス指定に使われます。

| ピット      | 15  | 14  | 13  | 12  | 11  | 10  | 9  | 8  |
|----------|-----|-----|-----|-----|-----|-----|----|----|
| ZH (R31) | Z15 | Z14 | Z13 | Z12 | Z11 | Z10 | Z9 | Z8 |
| ピット      | 7   | 6   | 5   | 4   | 3   | 2   | 1  | 0  |
| ZL (R30) | 77  | Z6  | 75  | Z4  | Z3  | Z2  | 71 | Z0 |

フラッシュ メモリがヘージ で構成されるため(70頁の表17-5.参照)、プログラム カウンタ(アドレス ポインタ)は2つの違う領域を持つように取り扱われます。1つの領域は下位側ビットから成り、ヘージ内の語(ワード)をアドレス指定し、一方上位側ビットはそのヘージをアドレス指定します。これは図16-1.で示されます。ヘージ消去とヘージ書き込み操作が個別にアドレス指定されることに注意してください。従ってソフトウェアがヘージ消去とヘージ書き込み操作の両方で同じヘージをアドレス指定することが最も重要です。



**注**: 図内で使った各変数は70頁の**表17-5**.で一覧されます。

LPM命令はアドレスを格納するのにZポインタを使います。この命令はフラッシュメモリのバイト単位をアドレス指定するので、Zポインタの最下位ビット(Z0)も使われます。

### 16.5. SPM命令での書き込み時のEEPROM書き込みによる妨害

EEPROM書き込み動作がフラッシュ メモリへの全ソフトウェア プログラミングを妨げることに注意してください。ソフトウェアからのヒューズと施錠ビット読み出しもEEPROM書き込み動作中に妨げられます。使用者はEEPROM制御レジスタ(EECR)のEEPROMプログラム許可(EEPE)ビットを検査し、SPM命令制御/状態レジスタ(SPMCSR)へ書く前にこのビットが解除(0)されているのを確認することが推奨されます。





### 16.6. ファームウェアからの施錠ビットとヒュースでの読み出し

ファームウェアからヒュース、と施錠ビットを読むことが可能です。

#### 16.6.1. ファームウェアからの施錠ビット読み出し

SPMCSRでフラッシュ/施錠ビット読み込み(RFLB)と自己プロケブラミンケ、許可(SELFPRGEN)ビットを設定(1)した後の3CPU周期内のLPM命令実行は転送先レシ、スタ内に施錠ビット値を返します。RFLBとSELFPRGENビットは施錠ビット読み出しの完了で、または3CPU周期内にLPM命令が実行されないか、または4CPU周期内にSPM命令が実行されない場合、自動的に解除(0)されます。通常、RFLBとSELFPRGENビットが解除(0)されるのはLPMの作用です。

施錠ビットを読むには以下の手順に従ってください。

- 1. Zポインタに\$0001を格納してください。
- 2. SPMCSRでRFLBとSELFPRGENt ットを設定(1)してください。
- 3. 3クロック周期内のLPM命令実行が転送先レジスタに施錠ビット値を返します。

成功なら、転送先レジスタの内容は次のとおりです。

| ピット | 7 | 6 | 5 | 4 | 3 | 2 | 1   | 0   |
|-----|---|---|---|---|---|---|-----|-----|
| Rd  | - | - | - | - | - | - | LB2 | LB1 |

より多くの情報については68頁の「プログラム メモリとデータ メモリ用施錠ビット」をご覧ください。

#### 16.6.2. ファームウェアからのヒュース ビット読み出し

ヒューズバイトを読む方法はアドレスが異なるだけで上記の施錠ビット読み出しと同様です。

ヒューズ下位バイト(FLB)を読むには以下の手順に従ってください。

- 1. Zポインタに\$0000を格納してください。
- 2. SPMCSRでRFLBとSELFPRGENt ットを設定(1)してください。
- 3. 3クロック周期内のLPM命令実行が転送先レジスタにFLB値返します。

成功なら、転送先レジスタの内容は次のとおりです。

| ピット | 7    | 6    | 5    | 4    | 3    | 2    | 1    | 0    |
|-----|------|------|------|------|------|------|------|------|
| Rd  | FLB7 | FLB6 | FLB5 | FLB4 | FLB3 | FLB2 | FLB1 | FLB0 |

ヒューズ上位バイト(FHB)を読むには単にZポインタ内のアトレスを\$0003に置き換え、前の手順を繰り返してください。 成功なら、転送先レジスタの内容は次のとおりです。

| ピット | 7 | 6 | 5 | 4    | 3    | 2    | 1    | 0    |
|-----|---|---|---|------|------|------|------|------|
| Rd  | _ | - | 1 | FHB4 | FHB3 | FHB2 | FHB1 | FHB0 |

ヒューズと施錠ビットのより多くの情報については68頁の「プログラム メモリとデータ メモリ用施錠ビット」と69頁の「ヒュース´ビット」をご覧ください。

# 16.7. フラッシュ メモリ データ化けの防止

低VCCの期間中、CPUとフラッシュメモリの正しい動作に対して供給電圧が低すぎるためにフラッシュメモリのプログラムが不正にされ得ます。これらの問題はフラッシュメモリを使う基板段階の装置と同じで、同じ設計上の解決策が適用されるべきです。

フラッシュ メモリのプログラム化けは電圧が低すぎる時の2つの状態によって起こされます。1つ目としてフラッシュ メモリへの通常の書き込み手順は正しく動作するための最低電圧が必要です。2つ目として供給電圧が低すぎると、CPU自身が命令を間違って実行し得ます。フラッシュ メモリ化けは次の推奨設計によって容易に避けられます(1つは必須)。

- ・不十分な供給電源電圧の期間中、AVR RESETを活性(Low)に保ってください。これは動作電圧が検出電圧と一致するなら、内部 低電圧検出器(BOD)を許可することによって行えます。そうでなければ外部低VCCリセット保護回路が使えます。書き込み操作進 行中にリセットが起こると、その書き込み動作は供給電源電圧が充分であれば完了されます。
- ・低VCCの期間中、AVRコアをパワーダウン休止動作に保ってください。これはCPUが命令の復号と実行を試みることを防ぎ、SPMCS R、従ってフラッシュ メモリを予期せぬ書き込みから効果的に保護します。

### 16.8. SPM命令使用時のフラッシュ メモリ用プログラミング(書き込み)時間

校正された内蔵RC発振器がフラッシュ メモリ アクセス時間に使われます。表16-1.はCPUからのフラッシュ メモリ アクセスに対する代表的なプログラミング時間を示します。

| 表16-1. SPM命令によるフラッシュ フ | メモリのプログラミン・ | グ時間 |
|------------------------|-------------|-----|
|------------------------|-------------|-----|

| 項目                                         | 最小    | 最大    |
|--------------------------------------------|-------|-------|
| SPM命令によるフラッシュ書き込み(ページ消去、ページ書き込み、施錠ビット書き込み) | 3.7ms | 4.5ms |

注: 最小と最大の時間は(項目の)個別操作毎に対してです。

## 16.9. 自己プログラミング用レジスタ

16.9.1. SPM命令制御/状態レジスタ (Store Program Memory Control and Status Register) SPMCSR

このレジスタはプログラムメモリ操作を制御するために必要とする制御ビットを含みます。

| ピット         | 7 | 6 | 5 | 4    | 3    | 2     | 1     | 0         |        |
|-------------|---|---|---|------|------|-------|-------|-----------|--------|
| \$37 (\$57) | - | - | - | СТРВ | RFLB | PGWRT | PGERS | SELFPRGEN | SPMCSR |
| Read/Write  | R | R | R | R/W  | R/W  | R/W   | R/W   | R/W       |        |
| 初期値         | 0 | 0 | 0 | 0    | 0    | 0     | 0     | 0         |        |

#### ■ L\*ット7~5 - Res: 予約 (Reserved)

これらのビットは予約されており、常に0として読まれます。

■ ビット4 - CTPB : ペ-ジー時緩衝部消去 (Clear Temporary Page Buffer)

へージー時緩衝部を満たしている間にCTPBビットが1を書かれると、ヘージー時緩衝部は消去され、データが失われます。

■ ビット3 - RFLB: ヒューズ/施錠ビット読み込み (Read Fuse and Lock Bits)

SPMCSRでRFLBとSELFPRGENが設定(1)された後3クロック周期内のLPM命令は(ZポインタのZ0によって)ヒューズビットまたは施錠ビットのどちらかを転送先レジスタに読みます。詳細については66頁の「ファームウェアからのヒューズビットと施錠ビットの読み出し」をご覧ください。

■ ビット2 - PGWRT : ページ書き込み (Page Write)

このビットがSELFPRGENと同時に1を書かれると、次の4クロック周期内のSPM命令は一時緩衝部に格納したデータでページ書き込みを実行します。ページアドレスはZポインタの上位部から取得されます。R1とR0のデータは無視されます。PGWRTビットはページ書き込みの完了で、または4クロック周期内にSPM命令が実行されない場合、自動的に解除(0)されます。ペーシ´全体の書き込み動作中、CPUは停止されます。

■ ビット1 - PGERS : ページ消去 (Page Erase)

このビットがSELFPRGENと同時に1を書かれると、次の4クロック周期内のSPM命令はページ消去を実行します。 ページアドレスはZポインタの上位部から取得されます。R1とR0のデータは無視されます。PGERSビットはページ消去の完了で、または4クロック周期内にSPM命令が実行されない場合、自動的に解除(0)されます。 ページ全体の消去中、CPUは停止されます。

■ ビット0 - SELFPRGEN: 自己プログラミング許可 (Self Programming Enable)

このビットは次の4クロック周期間SPM命令を許可します。このビットがCTPB,RFLB,PGWRT,PGERSのどれかと共に1を書かれると、続くSPM命令は特別な意味を持ちます(上の記述をご覧ください)。SELFPRGENだけが書かれると、続くSPM命令はZポインタでアドレス指定したページ一時緩衝部へR1:R0の値を格納します。Zレジスタの最下位ビットは無視されます。SELFPRGENビットはSPM命令の完了で、または4クロック周期内にSPM命令が実行されないと自動的に解除(0)されます。 ページ消去とページ書き込み中、SELFPRGENビットはその動作が完了されるまで1に留まります。

下位5ビットに10001, 01001, 00101, 00011, 00001以外のどんな組み合わせを書いても無効です。

(<mark>訳注</mark>) ビット0の名称SELFPRGENはヒューズ ビットに同一名が存在します。状況によっては不都合かもしれません。従ってソフトウェアに於ける本ビットの参照は他の多くのAVRと同様にSPMENの使用が推奨されます。AVR Studioでのデバイス定義インクルード ファイルでは既に本ビットに対してシンボルSPMENが定義されており、SELFPRGENはヒューズ ビット定義になっています。





# 17. メモリ プログラミング

本項はATtiny13のメモリ プログラミングについての各種方法を記述します。

## 17.1. プログラム メモリとデータ メモリ用施錠ビット

ATtiny13は非プログラム(1)のままか、表17-2.で一覧される付加機能を得るためにプログラム(0)できる2つの施錠ビットを提供します。この施錠ビットはチップ消去指令でのみ1に消去できます。

プログラム メモリは例え施錠ビットが設定されていても、DWENヒューズがプログラム(0)されると、デ`ハ`ック`WIREインターフェース経由で読み出せます。従って施錠ビット保護が必要とされる場合、DWENヒューズを消去(1)することによって常にデ`ハ`ック`WIREが禁止されるべきです。

### 表17-1. 施錠ビット バイトの内容

| 名称  | ピット番号 | 意味                                | 既定値 ( <mark>注</mark> ) |
|-----|-------|-----------------------------------|------------------------|
| _   | 7     |                                   | 1 (非プログラム)             |
| _   | 6     |                                   | 1 (非プログラム)             |
| _   | 5     |                                   | 1 (非プログラム)             |
| _   | 4     |                                   | 1 (非プログラム)             |
| _   | 3     |                                   | 1 (非プログラム)             |
| _   | 2     |                                   | 1 (非プログラム)             |
| LB2 | 1     | フラッシュとEEPROMメモリに対する一般保護用施錠ビット     | 1 (非プログラム)             |
| LB1 | 0     | //ツンユCEEFNU!VI/モリ(CX) りる一阪床護用施錠しり | 1 (非プログラム)             |

注: 0はプログラム、1は非プログラムを意味します。

### 表17-2. 施錠ビットの保護種別

|               | メモリ施錠ビット |     | 保護種別                                                                                 |
|---------------|----------|-----|--------------------------------------------------------------------------------------|
| LB 種別 LB2 LB1 |          | LB1 | 直列、並列、またはデバッグWIRE経由プログラミングに対する保護                                                     |
| 1             | 1        | 1   | メモリ施錠機能は機能しません。                                                                      |
| 2             | 1        | 0   | フラッシュ、EEPROMの更なるプログラミング(書き込み)が禁止されます。ヒュース゛ビットが固定されます。 ( <mark>注1</mark> )            |
| 3             | 0        | 0   | フラッシュ、EEPROMの更なるプログラミング(書き込み)と照合(読み出し)が禁止されます。ヒュース<br>ビットが固定されます。( <mark>注1</mark> ) |

**注1**: 施錠ビットを書く前にヒューズビットを書いてください。次頁の「ヒューズビット」をご覧ください。

注2: 0はプログラム、1は非プログラムを意味します。

## 17.2. ヒュース<sup>\*</sup> ヒ<sup>\*</sup>ット

ATtiny13には2つのヒュース、ハ・仆があります。**表17-3**.と**表17-4**.は全てのヒュース・の概略機能とヒュース、ハ・仆内でどのように配置されるかを示します。ヒュース・はプログラムされると、論理0として読まれることに注意してください。

表17-3. ヒューズ上位バイト一覧

| 名称        | ピット | 意味                                | 既定值                     |
|-----------|-----|-----------------------------------|-------------------------|
| -         | 7   |                                   | 1 (非プログラム)              |
| -         | 6   |                                   | 1 (非プログラム)              |
| _         | 5   |                                   | 1 (非プログラム)              |
| SELFPRGEN | 4   | 自己プログラミング機能許可。 (注1)               | 1 (非プログラム) 自己プログラミング不許可 |
| DWEN      | 3   | デバックWIRE機能許可。 ( <mark>注2</mark> ) | 1 (非プログラム) ディックWIRE不許可  |
| BODLEVEL1 | 2   | 低電圧検出(BOD)リセットの制御と検出電圧選択。 (注3)    | 1 (非プログラム)              |
| BODLEVEL0 | 1   | 低電圧検出(BOD)リセットの制御と検出電圧選択。 (注3)    | 1 (非プログラム)              |
| RSTDISBL  | 0   | PB5がI/OピンかまたはRESETピンかを選択します。 (注4) | 1 (非プログラム) PB5はRESETピン  |

注1: SPM命令許可。64頁の「フラッシュの自己プログラミング」をご覧ください。

注2: 施錠ビット保護が必要とされる場合、DWENは非プログラム(1)にされなければなりません。68頁の「プ<mark>ログラムとデータ メモリ用施錠ビッ</mark>ト」をご覧ください。

注3: BODLEVELヒューズの復号については79頁の表18-5.をご覧ください。

**注4**: RSTDISBLとDWENヒュース、の記述については36頁の「ポートBの交換機能」をご覧ください。RSTDISBLヒュース、をプログラム(0)すると、ヒュース、変更または更なるプログラミングを実行するのに高電圧直列プログラミングが使われなければなりません。

表17-4. ヒューズ下位バイト一覧

| 双17 元 [2] 八 [1] | 27.11 | <del>52</del>          |                                                    |
|-----------------|-------|------------------------|----------------------------------------------------|
| 名称              | ビット   | 意味                     | 既定値                                                |
| SPIEN           | 7     | 低電圧直列プログラミング許可。 (注1)   | 0 (プログラム) 低電圧直列プログラミング許可                           |
| EESAVE          | 6     | fップ消去からEEPROM内容を保護。    | 1 (非プログラム) EEPROMは未保護                              |
| WDTON           | 5     | ウォッチト、ック、タイマ常時有効。 (注2) | 1 (非プログラム) WDTはWDTCRで許可                            |
| CKDIV8          | 4     | システム クロック 8分周選択。 (注3)  | 0 (プログラム) 8分周                                      |
| SUT1            | 3     | 起動時間選択。 (注4)           | 1 (非プログラム)                                         |
| SUT0            | 2     | 起動時間選択。 (注4)           | <mark>0</mark> (プ <sup>°</sup> ロク <sup>*</sup> ラム) |
| CKSEL1          | 1     | クロック種別選択。 (注5)         | 1 (非プログラム)                                         |
| CKSEL0          | 0     | (注3)<br>               | 0 (プ <sup>°</sup> ロク <sup>*</sup> ラム)              |

注1: SPIENヒューズはSPI(低電圧)直列プログラミングでアクセスできません。

**注2**: このヒュース、のプログラム(0)はウォッチト、ッグ、タイマ割り込みを禁止します。詳細については25頁の「ウォッチト、ッグ、タイマ」をご覧ください。

**注3**: 詳細については17頁の「システム クロック前置分周器」をご覧ください。

注4: SUT1,0の既定値は既定クロック元に対して最大起動時間になります。詳細については16頁の表6-5.をご覧ください。

注5: 既定のCKSEL1,0設定は9.8MHz校正付き内蔵RC発振器になります。詳細については16頁の表6-4.をご覧ください。

施錠ビット1(LB1)がプログラム(0)されると、ヒュース゛ビットが固定されることに注意してください。施錠ビットをプログラム(0)する前にヒュース゛ビットをプログラミング(書き込み)してください。ヒュース゛ビットの状態はチップ消去によって影響されません。

ヒュース ビットはデバイス ファームウェアによって読むこともできます。66頁の「ファームウェアからの施錠,ヒュース と識票のデータ読み出し」項をご覧ください。

# 17.2.1. ヒュース のラッチ

ヒュース<sup>\*</sup>値はデバイスがプログラミング動作へ移行する時にラッチされ、ヒュース<sup>\*</sup>値の変更はデバイスがプログラミング動作を去るまで無効です。これは一旦プログラム(0)されると直ぐに効果があるEESAVEヒュース<sup>\*</sup>には適用されません。ヒュース<sup>\*</sup>は通常動作での電源投入でもラッチされます。





# 17.3. 校正バ か

ATtiny13の識票領域は内蔵RC発振器用に2バイトの校正値を持っています。アドレス\$000の上位バイトの校正値は9.6MHz設定発振器での使用のためのものです。リセット中、校正付き内蔵RC発振器の正しい周波数を保証するために、このバイトがOSCCALレジスタへ自動的に書かれます。

4.8MHz動作での内蔵発振器動作用に独立した校正バイがありますが、このデータは自動的に設定されません。ハードウェアはリセット中、常に9.6MHz校正データを設定します。4.8MHz動作発振器用の独立した校正データを使うにはOSCCALレジスタがファームウェアによって更新されなければなりません。4.8MHz動作用の校正データは識票領域内のアドレス\$0001の上位バイトに配置されています。

### 17.4. 識票バイ

全てのAtmelマイクロコントローラはデバイスを識別する3バイトの識票符号を持ちます。この符号は直列と高電圧プログラミング動作の両方で、またデバイスが施錠されていても読めます。この3バイトは分離された空間に存在します。ATtiny13の識票バイトを右に示します。

① \$000: \$1E 製造業者Atmelを示します。

② \$001: \$90 フラッシュ メモリ容量1Kバイトを示します。

③ \$002:\$07 ②値\$90と合せ、ATtiny13を示します。

# 17.5. ページ容量

### 表17-5. フラッシュ メモリのヘーン 数とヘーン の語数

| 全容量           | ページ容量 | PCWORD | ページ数 | PCPAGE | PCMSB |
|---------------|-------|--------|------|--------|-------|
| 512ワード(1Kバイト) | 16ワート | PC3∼0  | 32   | PC8∼4  | 8     |

### 表17-6. EEPROMメモリのページ数とページの語数

| 全容量   | ページ容量 | PCWORD | ページ数 | PCPAGE | EEAMSB |
|-------|-------|--------|------|--------|--------|
| 64バイト | 4バイト  | EEA1∼0 | 16   | EEA5∼2 | 5      |

## 17.6. 低電圧直列プログラミング

フラッシュメモリとEEPROMの両方はRESETがGNDに引かれている間に直列SPI、「スを使ってプログラミング」できます。この直列インターフェースはSCK入力、MOSI入力、MISO出力から成ります。図17-1.をご覧ください。

RESETがLowに設定された後、書き込み/消去操作が実行され得るのに先立ってプログラミング許可命令が初めに実行されるのを必要とします。

表17-7. 低電圧直列プログラミング用ピン配置

| 信号名  | ピン名 | 入出力 | 機能      |
|------|-----|-----|---------|
| MOSI | PB0 | 入力  | 直列データ入力 |
| MISO | PB1 | 出力  | 直列データ出力 |
| SCK  | PB2 | 入力  | 直列クロック  |

注: 上の表17-7.でSPIプログラミング用のピン配置が一覧されます。全てのデバイスが内部SPIインターフェース専用SPIピンを使うとは限りません。

EEPROMをプログラミングする時に自動消去周期が自動書き込み動作内に組み入れられ(低電圧直列プログラミングのみ)、チップ消去命令を先に実行する必要がありません。チップ消去操作はプログラム(フラッシュメモリ)とEEPROM両方の全メモリ位置の内容を\$FFにします。

CKSELヒューズによる有効なクロックが与えられなければなりません。直列クロック (SCK)入力のLowとHighの区間の最小値は次のように定義されます。

図17-1. 低電圧直列プログラミング構成図

(GND) PB5/RESET VCC

クロック元 (注1) PB3/(CLKI) PB2 SCK PB1 MISO MOSI

注1: 内部発振器クロック駆動の場合、クロック元をCLKI ピンに接続する必要はありません。

 $f_{\rm CK} < 12$ MHz: Low区間>2CPUクロック周期  $f_{\rm CK} < 12$ MHz: High区間>2CPUクロック周期  $f_{\rm CK} \ge 12$ MHz: High区間>3CPUクロック周期

### 17.6.1. 低電圧直列プログラミング手順

ATtiny13に直列データを書く時にデータはSCKの上昇端で行われ、ATtiny13から読む時にデータはSCKの下降端で行われます。タイシングの詳細については80頁の図18-4と図18-5.をご覧ください。

低電圧直列プログラミング動作でのATtiny13のプログラミングと照合は次の手順が推奨されます(4小小命令形式は表17-9.を参照)。

- 1. 電源投入手順: RESETとSCKがLow(0)に設定されている間にVCCとGND間へ電源を印加します。いくつかのシステムで電源投入中にSCKがLowに保持されることを書き込み器が保証できません。この場合、SCKがLow(0)に設定されてしまった後にRESETは正パルスを与えられなければなりません。パルス幅は少なくてもtRST(RESET ピンの最小パルス幅、79頁表18-4.参照)+2CPUクロック周期でなければなりません。
- 2. 最低20ms待ち、MOSIピンにプログラミング許可命令を送ることによって直列プログラミングを許可してください。
- 3. 通信が同期を外していると、直列プログラミング命令は動作しません。同期していると、プログラミング許可命令の第3小小送出時に第2 ハイト(\$53)が戻ります。この戻りが正しいかどうかによらず命令の4小小全てが送信されなければなりません。\$53が戻らない場合、 RESETに正パルスを与え、新規プログラミング許可命令を行ってください。
- 4. フラッシュ メモリは1ペーシ 単位で書かれます(70頁の表17-5.)。このメモリ ペーシ はペーシ 設定命令と共にアトレスの下位4+1ビットとデータを供給することによって1パイトづつ設定されます。ペーシ が正しく設定されるのを保証するため、与えられたアトレスにデータ上位パイトが適用される前にデータ下位パイトが設定されなければなりません。プログラム メモリのペーシ はアトレスの上位5ビットを含むペーン 書き込み命令の設定によって(フラッシュ メモリに)格納されます。ポーリング(BSY/RDY)が使われない場合、使用者は次のペーシ を行う前に最低twp Flash(表17-8.参照)待たなければなりません。
  - 注: 何れの(フラッシュ、EEPROM、施錠ピット、ヒューズ)書き込み操作が完了される前にポーリング(読み)以外の命令が加えられると、不正な書き込みに終わるかもしれません(訳注:共通性のため原書の該当行に代わり本行追加)。
- 5. EEPROMはペーシー単位かハート単位のどちらかでプログラミングできます。

**バイト単位**: EEPROMは適切なEEPROM書き込み命令と共にアトンスとデータを供給することによって1バイト単位で書かれます。EEP ROMのメモリ位置は新規データが書かれるのに先立って始めで自動的に消去されます。ポーリング(BSY/ $\overline{RDY}$ )が使われない場合、次のバイトを行う前に最低twp\_eeprom(表17-8.参照)待たなければなりません。

**ページ単位**: EEPROMの1ページはEEPROMページ設定命令と共にアドレスの下位2ビットとデータを供給することによって1バイトづつ設定されます。EEPROMページはアドレスの上位4ビットを含むEEPROMページ書き込み命令によって(EEPROMに)格納されます。EEPROMページ アクセス使用時、EEPROMページ 設定命令で設定したバイト位置だけが変更されます。残りの位置は無変化で留まります。ポーリング(BSY/RDY)が使われない場合、次のページを行う前に最低twp\_eeprom(表17-8.参照)待たなければなりません。チップ消去されたデバイスでの\$FFデータは書かれる必要がありません。

- 6. どのメモリ位置も選択したアドレスの内容を直列出力MISOに読み戻す読み出し命令を使うことによって照合できます。
- 7. プログラミング作業終了時、RESETは通常動作を開始するため、High(1)に設定できます。
- 8. 電源OFF手順(必要とされるなら)
  - ・RESETをHigh(1)に設定します。
  - ・VCC電源をOFFにします。





表17-8. ヒューズ, フラッシュ, EEPROM次位置書き込み前の待機時間

| シンホ゛ル      | 最低待機時間 | 備考            |  |
|------------|--------|---------------|--|
| two_fuse   | 4.5ms  | ヒュース゛書き込み     |  |
| two_flash  | 4.5ms  | フラッシュ メモリ書き込み |  |
| twd_eeprom | 4.0ms  | EEPROM書き込み    |  |
| two_erase  | 9.0ms  | チップ消去         |  |

# 17.6.2. 低電圧直列プログラミング命令一式

命令一式は表17-9.で記述されます。

表17-9. 低電圧直列プログラミング命令一式

| ۵۵                                                         | 命令形式      |           |           | ₹h //r    |                               |  |
|------------------------------------------------------------|-----------|-----------|-----------|-----------|-------------------------------|--|
| 命令                                                         | 第1バイト     | 第2バイト     | 第3バイト     | 第4バイト     | 動作                            |  |
| プログラミング許可                                                  | 1010 1100 | 0101 0011 | XXXX XXXX | XXXX XXXX | RESET=Low後のプログラミングを許可します。     |  |
| チップ消去                                                      | 1010 1100 | 100x xxxx | XXXX XXXX | XXXX XXXX | フラッシュ メモリ,EEPROM,施錠ビットを消去します。 |  |
| フラッシュメモリ読み出し                                               | 0010 P000 | 0000 000H | LLLL LLLL | RRRR RRRR | アドレスH:LのP(H/L)バイトを読み出します。     |  |
| フラッシュ ヘ゜ーシ゛設定                                              | 0100 P000 | 000x xxxx | xxxx LLLL | wwww wwww | 緩衝部アドレスLのP(H/L)バイトに書き込みます。    |  |
| フラッシュヘ゜ージ書き込み                                              | 0100 1100 | 0000 000H | LLLL xxxx | XXXX XXXX | アト・レスH:Lのヘ゜ーシ゛に書き込みます。        |  |
| EEPROM読み出し                                                 | 1010 0000 | 000x xxxx | xxLL LLLL | RRRR RRRR | アドレスLのバイトを読み出します。             |  |
| EEPROMバイト書き込み                                              | 1100 0000 | 000x xxxx | xxLL LLLL | wwww wwww | アドレスLのバイトに書き込みます。             |  |
| EEPROMページ設定                                                | 1100 0001 | 0000 0000 | 0000 00LL | wwww wwww | 緩衝部アドレスLのバイトに書き込みます。          |  |
| EEPROMページ書き込み                                              | 1100 0010 | 00xx xxxx | xxLL LL00 | xxxx xxxx | アドレスLのページに書き込みます。             |  |
| 施錠ビット読み出し                                                  | 0101 1000 | 0000 0000 | XXXX XXXX | xxxx xxRR | 7 - 7 ·                       |  |
| 施錠ビット書き込み                                                  | 1010 1100 | 111x xxxx | XXXX XXXX | 1111 11WW | (68頁の表17-1.参照) に書き込みます。       |  |
| ヒューズバ小読み出し                                                 | 0101 P000 | 0000 P000 | xxxx xxxx | RRRR RRRR | ヒュース、バイトを読み出します。              |  |
| ヒューズバー書き込み                                                 | 1010 1100 | 1010 P000 | XXXX XXXX | WWWW WWWW | (69頁の「ヒューズビット」参照) に書き込みます。    |  |
| 識票バ小読み出し                                                   | 0011 0000 | 000x xxxx | xxxx xxLL | RRRR RRRR | アドレスLの識票バイトを読み出します。           |  |
| 校正バ小読み出し                                                   | 0011 1000 | 000x xxxx | 0000 000L | RRRR RRRR | 校正バイトを読み出します。                 |  |
| 多忙/準備可検査                                                   | 1111 0000 | 0000 0000 | XXXX XXXX | xxxx xxxR | R=1で多忙、他の操作前に0まで待機します。        |  |
| H =    アト                                                  |           |           |           |           |                               |  |
| R = 読み出しデータ (MCU出力) W = 書き込みデータ (MCU入力) x = 0または1 (無意味/不定) |           |           |           |           |                               |  |

#### **17.7**. 高電圧直列プログラミング

本項はATtiny13でのプログラム用フラッシュメモリ、データ用EEPROM、施錠ビット、ヒュース、ビットのプログラミングと照合の方法を記述します。

| 表17-10. 高電圧直列プログラミング用ピン配置 |     |     |                      |  |  |  |  |
|---------------------------|-----|-----|----------------------|--|--|--|--|
| 信号名                       | ピン名 | 入出力 | 機能                   |  |  |  |  |
| SDI                       | PB0 | 入力  | 直列データ入力              |  |  |  |  |
| SII                       | PB1 | 入力  | 直列命令入力               |  |  |  |  |
| SDO                       | PB2 | 出力  | 直列データ出力              |  |  |  |  |
| SCI                       | PB3 | 入力  | 直列クロック入力(最小周期=220ns) |  |  |  |  |



高電圧直列プログラミング間中の直列クロック入力(SCI)に対する最小周期は220nsです。

#### 表17-11. プログラミング動作移行に使うピン値

| ピン(信号)名 | シンホ゛ル          | 値 |
|---------|----------------|---|
| SDI     | Prog_enable[0] | 0 |
| SII     | Prog_enable[1] | 0 |
| SDO     | Prog_enable[2] | 0 |

#### 17.7.1. 高電圧直列プログラミング手順

高電圧直列プログラミング動作でのATtiny13Aのプログラミングと照合は次の手順が推奨されます(命令形式は**表17-13**.参照)。 次に示す方法がデバイスを高電圧直列プログラミング動作にします。

- 1. 表17-11.で一覧されるProg\_enablet°ンを全てLow(0)、RESETt°ンをLow(0)、VCCを0Vに設定してください。
- 2. VCCとGND間に4.5~5.5Vを印加してください。それから20μs以内にVCCが少なくても1.8Vに達することを保証してください。
- 3. 20~60µs待機し、RESETに11.5~12.5Vを印加してください。
- 4. プログラミング許可(Prog\_enable)識別がラッチされてしまうのを保証するために、高電圧印加後、最低10µs間Prog\_enablet°ンを無変化に保ってください。
- 5. Prog\_enable[2]/SDOピンでの駆動衝突を避けるために、Prog\_enable[2]ピンを開放してください。
- 6. SDI/SIIで何か直列命令を与える前に少なくとも300µs間待ってください。
- 7. デバイス電源断またはRESETピンをLow(0)に持ってくることによってプログラミング動作を抜けてください。

VCCの上昇時間が上で記された必要条件を完全に満たすことが不可能な場合、次の代替手順が使えます。

- 1. 表17-11.で一覧されるProg\_enablet°ンを全てLow(0)、RESETt°ンをLow(0)、VCCを0Vに設定してください。
- 2. VCCとGND間に4.5~5.5Vを印加してください。
- 3. VCCを監視し、VCCが0.9~1.1Vに達すると直ぐにRESET~11.5~12.5Vを印加してください。
- 4. プログラミング許可(Prog\_enable)識別がラッチされてしまうのを保証するために、高電圧印加後、最低10µs間Prog\_enablet°ンを無変化に保ってください。
- 5. Prog\_enable[2]/SDOピンでの駆動衝突を避けるために、Prog\_enable[2]ピンを開放してください。
- 6. SDI/SIIで何か直列命令を与える前に、VCCが4.5~5.5Vに達するまで待ってください。
- 7. デバイス電源断またはRESETピンをLow(0)に持ってくることによってプログラミング動作を抜けてください。

| 表17-12               | 古命団」 | よって生き    |
|----------------------|------|----------|
| <del>20</del>   /- 2 | 一曲十二 | ノカットキチルチ |

| 供給電 | 圧(VCC) | RESETピン高電圧閾値 (VHVRST) | プログラミング許可識別ラッチに対する最小高電圧時間(t <sub>HVRST</sub> ) |
|-----|--------|-----------------------|------------------------------------------------|
| 4.  | .5V    | 12V                   | 100ns                                          |
| 5.  | .5V    | 12V                   | 100ns                                          |





| 表17-13. 福 | <b>高電圧直列プ</b> | ログラミング | 命令一式 |
|-----------|---------------|--------|------|
|-----------|---------------|--------|------|

| 命令                                      |     |                              |                     |                 | 形式                 |                                         |                                         | 備:         |
|-----------------------------------------|-----|------------------------------|---------------------|-----------------|--------------------|-----------------------------------------|-----------------------------------------|------------|
| נך נוְּע                                |     | 第1バイト                        | 第2バイト               | 第3バイト           | 第4バイト              | 第5バイト                                   | 第6バイト                                   | NH.        |
|                                         | SDI | 0 1000 0000 00               | 0 0000 0000 00      | 0 0000 0000 00  |                    |                                         |                                         |            |
| チップ消去                                   | SII | 0 0100 1100 00               | $0\ 0110\ 0100\ 00$ | 0 0110 1100 00  |                    | 第3バイト後SDO                               | =Highまで待機。                              |            |
|                                         | SDO | x xxxx xxxx xx               | x xxxx xxxx xx      | x xxxx xxxx xx  |                    |                                         |                                         |            |
| 75 V 171                                | SDI | 0 0001 0000 00               |                     |                 |                    |                                         |                                         |            |
| フラッシュ メモリ                               | SII | 0 0100 1100 00               |                     |                 |                    | フラッシュ メモリ書き                             | 込み処理移行。                                 |            |
| 書き込み移行                                  |     | x xxxx xxxx xx               |                     |                 |                    | ,, , , , ,                              | ,, = _,, ,,,                            |            |
| 0 - 8                                   |     |                              | 0 LLLL LLLL 00      | 0 нини нини 00  | 0 0000 0000 00     | 0 0000 0000 00                          | N 亚华 八 // //                            | »          |
| フラッシュ ペーシ゛                              |     |                              |                     |                 | 0 0111 1101 00     |                                         | 必要数分第1~5                                | 5/1        |
| 緩衝部設定                                   |     |                              |                     |                 | X XXXX XXXX XX     |                                         | 繰り返し。                                   |            |
| フラッシュ メモリ                               |     | 0 0000 000 <mark>U</mark> 00 |                     |                 |                    |                                         | A=下位アト・レス(注                             | <u>(1)</u> |
| こ位アドレス設定                                |     | 0 0001 1100 00               |                     |                 | 第3ハ 1N俊SDO         | =Highまで待機。                              | H=上位データ                                 |            |
| ページ書き込み                                 |     |                              |                     |                 | U=上位アドレス           |                                         | L=下位データ                                 |            |
|                                         |     | 0 0000 0010 00               | X XXXX XXXX XX      | X XXXX XXXX XX  |                    |                                         |                                         |            |
| フラッシュ メモリ                               |     |                              |                     |                 | コニン・フェルギフ          | 、山口和田坂仁                                 |                                         |            |
| 読み出し移行                                  |     | 0 0100 1100 00               |                     |                 | フラッシュ メモリ読み        | 出し処理移行。                                 |                                         |            |
|                                         |     | X XXXX XXXX XX               |                     |                 |                    | I                                       |                                         |            |
| フラッシュ メモリ                               |     |                              |                     |                 | 0 0000 0000 00     |                                         |                                         |            |
| 上下バル                                    |     |                              |                     |                 | 0 0110 1100 00     |                                         |                                         |            |
| 読み出し                                    |     | x xxxx xxxx xx               | x xxxx xxxx xx      | x xxxx xxxx xx  | L LLLL LLLx xx     |                                         |                                         |            |
| EEPROM                                  | SDI | 0 0001 0001 00               |                     | EEPROM書き        |                    |                                         | 56バイトページ・時に                             | は          |
|                                         | SII | 0 0100 1100 00               |                     |                 | 第2バイトも繰り返          | えし。                                     |                                         |            |
| 書き込み移行                                  | SDO | x xxxx xxxx xx               |                     | 込み処理移行          | A=下位アドレス( <u>注</u> | <b>E1</b> ), H=上位データ                    | , L=下位データ                               |            |
| SEDDOM: ° ×                             | SDI | 0 00AA AAAA 00               | 0 LLLL LLLL 00      | 0 0000 0000 00  | 0 0000 0000 00     | 以再类八烷1                                  | 4* /1 (星)() (二)                         |            |
| EEPROMへ。ーシ                              | SII | 0 0000 1100 00               | 0 0010 1100 00      | 0 0110 1101 00  | 0 0110 1100 00     | 必要数分第1~                                 |                                         |            |
| 緩衝部設定                                   |     | x xxxx xxxx xx               |                     |                 | 1                  | A=下位アトレス( <u>注</u>                      | <b>2</b> ), L=アータ                       |            |
|                                         |     | 0 0000 0000 00               |                     | A AAAA AAAA AA  | A AAAA AAAA AA     |                                         |                                         |            |
| EEPROM                                  |     | 0 0110 0100 00               |                     |                 |                    | 第2バイト後SDO                               | =Highまで待機                               |            |
| ページ書き込み                                 |     |                              |                     |                 |                    |                                         | -1 11g11 よく小小戏。                         |            |
|                                         |     | X XXXX XXXX XX               |                     | 0 0000 0000 00  | 0 0000 0000 00     | 0.0000.0000.00                          |                                         |            |
| EEPROM                                  |     |                              |                     |                 | 0 0000 0000 00     |                                         | 第5バイト後SDO=                              | =Hi        |
| バイ書き込み                                  |     |                              |                     |                 | 0 0110 0100 00     |                                         | まで待機。必要                                 | 数分         |
| 11                                      |     |                              | X XXXX XXXX XX      | X XXXX XXXX XX  | X XXXX XXXX XX     | X XXXX XXXX XX                          | 第1~5小小繰り                                |            |
| EEPROM                                  |     | 0 0000 0011 00               |                     |                 |                    | EEPROM読み                                | A=下位アドレス                                | ~          |
| 読み出し移行                                  | SII | 0 0100 1100 00               |                     |                 |                    | 出し処理移行。                                 | L=データ                                   |            |
| 即でと田で4多41                               | SDO | X XXXX XXXX XX               |                     |                 |                    | 田した生物11。                                | L-/ -/                                  |            |
| EEPROM                                  | SDI | 0 00AA AAAA 00               | 0 0000 0000 00      | 0 0000 0000 00  | 0 0000 0000 00     |                                         |                                         |            |
|                                         | SII | 0 0000 1100 00               | 0 0001 1100 00      | 0 0110 1000 00  | 0 0110 1100 00     | 必要数分第1~                                 | 4バイト繰り返し。                               |            |
| バイ読み出し                                  | SDO | x xxxx xxxx xx               | x xxxx xxxx xx      | x xxxx xxxx xx  | L LLLL LLLx xx     |                                         |                                         |            |
| ). 2°T/4                                | SDI | 0 0100 0000 00               | 0 7654 3210 00      | 0 0000 0000 00  | 0 0000 0000 00     | 第4バイト後SDO                               | =Highまで待機。                              |            |
| ヒュース・下位                                 | SII | 0 0100 1100 00               | 0 0010 1100 00      | 0 0110 0100 00  | 0 0110 1100 00     | 7~0はビット位置                               | で論理のでプログラ                               | ラム         |
| 書き込み                                    |     |                              |                     |                 | X XXXX XXXX XX     | (69頁の表17-4.                             | 参照)                                     | ,(         |
|                                         |     |                              |                     |                 | 0 0000 0000 00     | 第4バイト後SDO                               |                                         |            |
| ヒュース・上位                                 |     |                              |                     |                 |                    |                                         | =Highよで行機。<br>【で論理 <mark>0</mark> でプログラ | ラム         |
| 書き込み                                    |     |                              |                     |                 |                    | 4~00aにッド位値<br> (69頁の <b>表17-3</b> .     |                                         | 1 H        |
|                                         |     | X XXXX XXXX XX               |                     |                 |                    |                                         |                                         |            |
| 施錠ビット                                   |     |                              |                     |                 | 0 0000 0000 00     |                                         |                                         | =,         |
| 書き込み                                    |     |                              |                     |                 | 0 0110 1100 00     |                                         | で論理 <mark>0</mark> でプログラ                | 1A         |
|                                         |     | X XXXX XXXX XX               |                     |                 |                    | (68頁の <b>表17-1</b> .                    | 少!!!!                                   |            |
| ヒューズ下位                                  |     | 0 0000 0100 00               |                     |                 |                    | 7~0はビット位置                               | で論理0でプログラ                               | ラム         |
| 読み出し                                    |     | 0 0100 1100 00               |                     |                 |                    | (69頁の表17-4.                             |                                         |            |
| ритрио                                  |     | x xxxx xxxx xx               |                     |                 |                    | (00 A V) <b>X</b> 17 4.                 | >> 1/1/                                 |            |
| ヒュース・上位                                 |     | 0 0000 0100 00               |                     |                 |                    | 4~0/けどいん位置                              | で論理 <mark>0</mark> でプログラ                | ラム         |
|                                         | SII | 0 0100 1100 00               | 0 0111 1010 00      | 0 0111 1110 00  |                    |                                         |                                         | 14         |
| 読み出し                                    | SDO | x xxxx xxxx xx               | x xxxx xxxx xx      | x xx43 210x xx  |                    | (69頁の表17−3.                             | <b>少</b> 思/                             |            |
| 4- (y-1) 1                              |     | 0 0000 0100 00               |                     |                 |                    | 1 0) 1) 2 11 11                         |                                         | <u> </u>   |
| 施錠ビット                                   |     | 0 0100 1100 00               |                     |                 |                    | <u> 1∼0はビット位置で論理0</u> て                 |                                         | フム。        |
| 読み出し                                    |     | x xxxx xxxx xx               |                     |                 | <del></del>        |                                         | 参照)                                     |            |
|                                         |     | 0 0000 1000 00               |                     |                 |                    |                                         |                                         |            |
| 識票バイト                                   |     |                              |                     |                 |                    | A=アトレス                                  |                                         |            |
| 読み出し                                    |     | 0 0100 1100 00               |                     |                 |                    | 7~0はビット位置                               | •0                                      |            |
| ,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,, |     | X XXXX XXXX XX               |                     |                 |                    | ,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,, |                                         |            |
| 校正バイト                                   |     | 0 0000 1000 00               |                     |                 |                    | A=アト・レス                                 |                                         |            |
| // II                                   | SII | 0 0100 1100 00               | 0 0000 1100 00      | 10 0111 1000 00 | 10 0111 1100 00    | · ·                                     |                                         |            |
| 読み出し                                    | 511 | 0 0100 1100 00               | 0 0000 1100 00      | 0 0111 1000 00  | 7 6543 210x xx     | 7~0はビット位置                               | <u> </u>                                |            |

#### 表17-13 (続き). 高電圧直列プログラミング命令一式

| 命令  |     | 命令形式           |       |       |       |          |       |    |
|-----|-----|----------------|-------|-------|-------|----------|-------|----|
|     |     | 第1バイト          | 第2バイト | 第3バイト | 第4バイト | 第5バイト    | 第6バイト | 備考 |
|     | SDI | 0 0000 0000 00 |       |       |       |          |       |    |
| 無操作 | SII | 0 0100 1100 00 |       |       |       | アイドル状態に復 | 帰。    |    |
|     | SDO | x xxxx xxxx xx |       |       |       |          |       |    |

注1: 256語(ワート)よりも少ないページ 容量に関する上位余剰ビットはページ アトレス部です。

**注2**: 256バイトよりも少ないページ容量に関する上位余剰ビットはページアドレス部です。

注3: EEPROMはペーン単位で書かれます。しかし、ページ内に設定されたバイだけが実際にEEPROMへ書かれます。複数バイが 同じヘージに書かれるべきなら、ヘージ単位EEPROMアクセスはより効果的です。EEPROMの自動消去はSPI(低電圧)直列プログ ラミングだけで、高電圧直列プログラミングで利用できないことに注意してください。

#### 17.7.2. チップ 消去

チップ消去はフラッシュ メモリ、EEPROM(<mark>注1</mark>)、施錠ビットを消去します。施錠ビットはプログラム メモリが完全に消去されてしまうまでリセット(消去) されません。ヒューズビットは変更されません。チップ消去はフラッシュ メモリやEEPROMが再書き込みされる前に実行されなければなりませ

- 1. チップ消去命令を設定します(表17-13.をご覧ください)。
- 2. チップ消去終了に対してSDOがHighになるまで待ちます。
- 3. 無操作命令を設定します。

注1: EESAVEヒューーズがプログラム(0)されていると、EEPROMはチップ消去中に保護されます。

#### 17.7.3. フラッシュ メモリ書き込み

フラッシュ メモリはヘ゜ーシ゛で構成されます(70頁の**表17-5**.参照)。 フラッシュ メモリへ書く時にプログラム テ゛ータはヘ゜ーシ゛緩衝部にラッチされます。 こ れは同時に書かれることをプログラムデータの1ページに許します。次の手順は完全なフラッシュメモリの書き込み方法を記述します。

- 1. フラッシュ書き込み移行命令を設定します(表17-13.をご覧ください)。
- 2. フラッシュ メモリ ヘーン 緩衝部を設定します。
- 3. フラッシュ メモリ上位アト・レス設定とフラッシュ ヘーン・書き込み命令を設定します。第3命令ハ・イト後、ヘーン・書き込み終了に対してSDOが highになるまで待ちます。
- **4.** フラッシュ メモリ全体または全データが書かれてしまうまで②~③を繰り返します。
- 5. 無操作命令の設定によってフラッシュ ページ 書き込みを終えます。

ATtiny13との直列データ読み書き時、データは直列クロックの上昇端でクロック駆動(取得/出力変更)されます。詳細については図17-4、81 頁の図18-6.と表18-9.をご覧ください。



注: PCPAGEとPCWORDは70頁の表17-5.で一覧されます。

#### 図17-4. 高電圧直列プログラミング バイト通信波形 直列データ入力(SDI/PB0) MSB X XLSB 直列命令入力(SII/PB1) /MSBX X LSB \ MSB X X LSB 直列データ出力(SDO/PB2) 0 1 2 3 4 5 6 7 8 9 10 直列クロック入力(SCI/PB3)



#### 17.7.4. EEPROM書き込み

EEPROMはペーシで構成されます(70頁の表17-6.参照)。EEPROMを書く時にデータはページ緩衝部にラッチされます。これは同時に書かれることをデータの1ページに許します。データ用EEPROMメモリの書き込み方法は次のとおりです。(表17-13.参照)

- 1. EEPROM書き込み移行命令を設定します。
- 2. EEPROMへージ緩衝部を設定します。
- 3. EEPROMへージ書き込み命令を設定します。第2命令ハイト後、ヘージ書き込み終了に対してSDOがhighになるまで待ちます。
- 4. EEPROM全体または全データが書かれてしまうまで②~③を繰り返します。
- 5. 無操作命令の設定によってEEPROMページ書き込みを終えます。

# 17.7.5. フラッシュ メモリ読み出し

フラッシュ メモリの読み出し方法は次のとおりです。(表17-13.参照)

- 1. フラッシュ読み出し移行命令を設定します。
- 2. フラッシュの上下バイトを読み出します。選択したアドレスの内容はSDO直列出力で利用可能です。

#### 17.7.6. EEPROM読み出し

EEPROMの読み出し方法は次のとおりです。(表17-13.参照)

- 1. EEPROM読み出し移行命令を設定します。
- 2. EEPROMのバイを読み出します。選択したアドレスの内容はSDO直列出力で利用可能です。

#### 17.7.7. ヒュース、と施錠ビットの読み出し/書き込み

ヒュース、上位/下位と施錠ビットの読み出し/書き込み方法は表17-13.で示されます。

#### 17.7.8. 識票バイと校正バイの読み出し

識票バイン校正バイの読み出し方法は表17-13で示されます。

#### 17.7.9. 電源OFF手順

SCIをOに設定します。RESETを1に設定します。VCC電源をOFFにします。

### 17.8. 効率的なプログラミングへの考慮

設定した命令とアドレスはプログラミング中、デバイス内で維持されます。効率的なプログラミングを行うために次が考慮されるべきです。

- ・複数のメモリ領域を読み書きする時に命令設定は一度だけ必要です。
- ・ チップ消去後のフラッシュ メモリと(EESAVEヒューズがプログラム(0)されている場合を除き)EEPROM全体の内容は\$FFなので、値が\$FFの データ書き込みを飛ばします。
- ・アトンス上位バイトはフラッシュ メモリで新規256語(ワード)枠、EEPROMで新規256バイト枠の読み書き前に一度だけ必要です。この考慮は識票バイト読み出しにも適用されます。

# 18. 電気的特性

#### 18.1. 絶対最大定格 (警告)

動作温度 --55 °C ~ +125 °C 保存温度 --65 °C ~ +150 °C RESETを除くピン許容電圧 -0.5 V ~ VCC+0.5 V RESET ピン許容電圧 -0.5 V ~ +13.0 V 最大動作電圧 -6.0 V 入出力ピン出力電流 -40.0 mA 消費電流 200.0 mA

#### (警告)

絶対最大定格を超える負担はデバイスに定常的な損傷を与えます。 絶対最大定格は負担の定格を示すためだけのもので、この値また は、この仕様書の動作特性で示された値を超える条件で動作する ことを示すものではありません。長時間の最大定格での使用はデバイスの信頼性を損なう場合があります。

# 18.2. DC特性

表18-1. DC特性 (TA=-40°C~85°C)

|        | DC特性 (TA=-40°C~85°C)                   |                   |                      |         |                      |        |
|--------|----------------------------------------|-------------------|----------------------|---------|----------------------|--------|
| シンホ゛ル  | 項目                                     | 条件                | 最小                   | 代表 (注1) | 最大                   | 単位     |
|        | Lowレベル入力電圧                             | VCC=1.8∼2.4V      | -0.5                 |         | 0.2VCC ( <b>注2</b> ) |        |
| VIL    | (I/Oとしての全ピン)                           | VCC=2.4~5.5V      | -0.5                 |         | 0.3VCC ( <b>注2</b> ) |        |
| VIL    | Lowレベル入力電圧_<br>(リセットとしてのRESET ピン) (注3) | VCC=1.8~5.5V      | -0.5                 |         | 0.2VCC ( <b>注2</b> ) |        |
|        | Highレベル入力電圧                            | VCC=1.8∼2.4V      | 0.7VCC ( <b>注4</b> ) |         | VCC+0.5              |        |
| Vih    | (I/Oとしての全ピン)                           | VCC=2.4~5.5V      | 0.6VCC ( <b>注4</b> ) |         | VCC+0.5              |        |
| V 11 1 | Highレベル入力電圧<br>(リセットとしてのRESETt°ン) (注3) | VCC=1.8~5.5V      | 0.9VCC ( <b>注4</b> ) |         | VCC+0.5              |        |
|        | Lレヘブル出力電圧 ( <b>注5</b> )                | IOL=20mA, VCC=5V  |                      |         | 0.7                  | V      |
| Vol    | (PB1,PB0)                              | IOL=10mA, VCC=3V  |                      |         | 0.5                  |        |
| VOL    | Lレヘブル出力電圧 (注5)                         | IOL=10mA, VCC=5V  |                      |         | 0.7                  |        |
|        | (PB4,PB3,PB2)                          | IOL=5mA, VCC=3V   |                      |         | 0.5                  |        |
|        | Hレベル出力電圧 (注6)                          | IOH=-20mA, VCC=5V | 4.2                  |         |                      |        |
| Vон    | (PB1,PB0)                              | IOH=-10mA, VCC=3V | 2.5                  |         |                      |        |
| VOH    | Hレベル出力電圧 (注6)                          | IOH=-10mA, VCC=5V | 4.2                  |         |                      |        |
|        | (PB4,PB3,PB2) (/±6)                    | IOH=-5mA, VCC=3V  | 2.5                  |         |                      |        |
| IIL    | I/OビンLowレベル入力漏れ電流                      | VCC=5.5V,         | -1                   |         | 1                    | Δ      |
| IIH    | I/OビンHighレベル入力漏れ電流                     | 確実なH/L範囲          | -1                   |         | 1                    | μA     |
| Rpu    | I/Oピン プルアップ抵抗                          | VCC=5.5V,         | 20                   |         | 50                   | kΩ     |
| KPU    | RESETピン プルアップ抵抗                        | Low入力             | 30                   |         | 80                   | K 52   |
|        |                                        | VCC=2V, 1MHz      |                      | 0.3     | 0.35                 |        |
|        | 活動動作消費電流                               | VCC=3V, 4MHz      |                      | 1.6     | 1.8                  |        |
|        |                                        | VCC=5V, 8MHz      |                      | 5       | 6                    | mA     |
| ICC    |                                        | VCC=2V, 1MHz      |                      | 0.08    | 0.2                  | 111/-1 |
| 100    | アイドル動作消費電流                             | VCC=3V, 4MHz      |                      | 0.41    | 1                    |        |
|        |                                        | VCC=5V, 8MHz      |                      | 1.6     | 3                    |        |
|        | パプーダウン動作消費電流                           | VCC=3V, WDT有効     |                      | 5       | 10                   | 11 Λ   |
|        | /・/ / リノ 野川ト付貨 电伽                      | VCC=3V, WDT禁止     |                      | 0.5     | 2                    | μA     |

注1: 25℃での代表値です。

注2: Lowレベルの認識が保証される最高電圧です。

注3: 製造で検査されていません。

注4: Highレベルの認識が保証される最低電圧です。

注5: 各I/Oポートは安定状態(非過渡時)に於いて検査条件よりも多くの吸い込み電流を流すことができますが、(全ポートに対する) 全てのIOLの合計が60mAを超えるべきではありません。IOLが検査条件を超える場合、VOLも仕様書での値を超えます。表の検査条件よりも大きな吸い込み電流を流すことは保証されません。

注6: 各I/Oポートは安定状態(非過渡時)に於いて検査条件よりも多くの吐き出し電流を流すことができますが、(全ポートに対する) 全てのIOHの合計が60mAを超えるべきではありません。IOHが検査条件を超える場合、VOHも仕様書での値を超えます。表の検査条件よりも大きな吐き出し電流を流すことは保証されません。





#### 18.3. 速度勾配

デバイスの最高動作周波数は供給電圧に依存します。**図18-1**.と**図18-2**.で示されるように最高周波数とVCC間の関連は1.8~2.7Vと2.7~4.5V間で直線です。





# 18.4. クロック特性

#### 18.4.1. 校正付き内蔵RC発振器精度

工場既定校正よりも高い精度に内蔵発振器を手動校正することが可能です。この発振器周波数が温度と電圧に依存することに注意してください。電圧と温度の特性は98頁の図19-50.~100頁の図19-55.で得られます。

表18-2. 校正付き内蔵RC発振器の校正精度

| 校正種別  | 周波数                    | Vcc                                                                | 温度                | 校正精度(注1) |
|-------|------------------------|--------------------------------------------------------------------|-------------------|----------|
| 工場校正  | 4.8/9.6MHz             | 3V                                                                 | 25℃               | ±10%     |
| 使用者校正 | 4~5/8~10MHz<br>内の固定周波数 | 1.8~5.5V( <mark>注2</mark> ), 2.7~5.5V( <mark>注3</mark> )<br>内の固定電圧 | -40~85℃<br>内の固定温度 | ±2%      |

注1: 校正点での発振器周波数精度(固定温度と固定電圧)

注2: ATtiny13Vに対する電圧範囲 注3: ATtiny13に対する電圧範囲

#### 18.4.2. 外部クロック特性



#### 表18-3. 外部クロック特性

| シンホ゛ル               | 項目            | VCC=1.8∼5.5V |     | VCC=2.7∼5.5V |     | VCC=4.5∼5.5V |     | 単位  |  |
|---------------------|---------------|--------------|-----|--------------|-----|--------------|-----|-----|--|
| クンホ ル               | <b>坦</b>      | 最小           | 最大  | 最小           | 最大  | 最小           | 最大  | 単位  |  |
| 1/t <sub>CLCL</sub> | クロック周波数       | 0            | 4   | 0            | 10  | 0            | 20  | MHz |  |
| tclcl               | クロック周期        | 250          |     | 100          |     | 50           |     |     |  |
| t <sub>CHCX</sub>   | Highレヘル時間     | 100          |     | 40           |     | 20           |     | ns  |  |
| tclcx               | Lowレヘール時間     | 100          |     | 40           |     | 20           |     |     |  |
| tclch               | 上昇時間          |              | 2.0 |              | 1.6 |              | 0.5 | 110 |  |
| tchcl               | 下降時間          |              | 2.0 |              | 1.6 |              | 0.5 | μs  |  |
| ⊿tclcl              | 隣接クロック周期間の変化率 |              | 2   |              | 2   |              | 2   | %   |  |

注: 詳細については16頁の「外部クロック信号」を参照してください。

# 18.5. システムとリセットの特性

表18-4. リセット、低電圧検出(BOD)、内部基準電圧の特性

| シンホ゛ル             | 項目                  | 条件          | 最小     | 代表  | 最大     | 単位 |
|-------------------|---------------------|-------------|--------|-----|--------|----|
| V <sub>POT</sub>  | 上昇時電源ONリセット閾値電圧     | TA=-40~85°C |        | 1.2 |        |    |
| VPOT              | 下降時電源ONリセット閾値電圧(注1) | 1A40' -00 C |        | 1.1 |        | V  |
| V <sub>RST</sub>  | RESETt°ン閾値電圧        | VCC=1.8∼5V  | 0.2VCC |     | 0.9VCC |    |
| t <sub>RST</sub>  | リセットハペルス幅           | VCC-1.67~5V | 2.5    |     |        | μs |
| V <sub>HYST</sub> | 低電圧検出ヒステリシス電圧       |             |        | 50  |        | mV |
| ${ m t_{BOD}}$    | 最小低電圧検出時間           |             | 2      |     |        | μs |
| $V_{BG}$          | 基準電圧                |             | 1.0    | 1.1 | 1.2    | V  |
| ${ m t_{BG}}$     | 起動時間                |             |        | 40  | 70     | μs |
| $I_{\mathrm{BG}}$ | 消費電流                |             |        | 15  |        | μA |

注1: 供給電圧がこの電圧以下にならないと、上昇時の電源ONJセットは動作しません。

#### 18.5.1. 低電圧検出 (BOD)

# 表18-5. BODLEVELtュース (VBOT) 設定 (注1)

| BODLEVEL1,0 | 最小  | 代表  | 最大 | 単位 |
|-------------|-----|-----|----|----|
| 1 1         | 低電圧 | 卜禁止 |    |    |
| 1 0         |     | 1.8 |    |    |
| 0 1         |     | 2.7 |    | V  |
| 0 0         |     | 4.3 |    |    |

注1: いくつかのデバイスでVBOTが公称最低動作電圧以下の可能性があります。この状態のデバイスについては、製造検査中、VCC=VBOTに落として検査されています。これはマイクロコントローラの正しい動作がもはや保証されない電圧になる前に、低電圧検出(BOD) リセットが起きることを保証します。

# 18.6. アナログ 比較器特性

表18-6. アナログ比較器特性 (TA=-40°C~85°C)

| 2.10 0.7777 20-32 in [1] 1 (1) 10 00 07 |                          |                    |     |     |    |      |
|-----------------------------------------|--------------------------|--------------------|-----|-----|----|------|
| シンホ゛ル                                   | 項目                       | 条件                 | 最小  | 代表  | 最大 | 単位   |
| VAIO                                    | 入力オフセット電圧                | VCC-EV VINI-VCC /9 | <10 |     | 40 | mV   |
| ILAC                                    | 入力漏れ電流                   | VCC=5V,VIN=VCC/2   | -50 |     | 50 | nA   |
|                                         | アナログ伝播遅延<br>(飽和から僅かに過駆動) | VCC=2.7V           |     | 750 |    |      |
| Vol                                     |                          | VCC=4.0V           |     | 500 |    | to a |
| VOL                                     | アナログ伝播遅延<br>(大きな段階変化)    | VCC=2.7V           |     | 100 |    | ns   |
|                                         |                          | VCC=4.0V           |     | 75  |    |      |
| $t_{\mathrm{DPD}}$                      | デジタル伝播遅延                 | VCC=1.8∼5.5V       |     | 1   | 2  | CLK  |

注: 全てのパラメータはシミュレーション結果に基いており、これらは製造で検査されていません。





# 18.7. A/D変換器特性

表18-7. A/D変換特性 (TA=-40°C~85°C)

| シンホ゛ル | 項目            |                        | 条件            | 最小   | 代表   | 最大   | 単位  |
|-------|---------------|------------------------|---------------|------|------|------|-----|
|       | 分解能           |                        |               |      |      | 10   | ピット |
|       | 絶対精度          | VCC=4V                 | 変換クロック=200kHz |      | 2    |      |     |
|       | (積分非直線性、微分非   | VREF=4V                | 変換クロック=1MHz   |      | 3    |      |     |
|       | 直線性、量子化、利得、   | 雑音低                    | 変換クロック=200kHz |      | 1.5  |      |     |
|       | オフセットの各誤差を含む) | 減動作                    | 変換クロック=1MHz   |      | 2.5  |      | LSB |
|       | 積分非直線性誤差      |                        |               |      | 1    |      | LSD |
|       | 微分非直線性誤差      | VCC=4V,V <sub>RE</sub> | F=4V          |      | 0.5  |      |     |
|       | 利得誤差          | 変換クロック=20              | 00kHz         |      | 2.5  |      |     |
|       | オフセット(セ゛ロ)誤差  |                        |               |      | 1.5  |      |     |
|       | 変換時間          | 連続変換動作                 | F             | 13   |      | 260  | μs  |
|       | 変換クロック周波数     |                        |               | 0.05 |      | 1    | MHz |
| VIN   | 入力電圧          |                        |               | GND  |      | VREF | V   |
|       | 入力周波数帯域       |                        |               |      | 38.5 |      | kHz |
| VINT  | 内蔵基準電圧        |                        |               | 1.0  | 1.1  | 1.2  | V   |
| RAIN  | アナログ入力インピーダンス |                        |               |      | 100  |      | ΜΩ  |

# 18.8. 低電圧直列プログラミング特性





表18-8. 低電圧直列プログラミング特性 (特記条件を除いて、TA=-40℃~85℃, VCC=1.8~5.5V)

| シンホ゛ル               | 項目                |      |          | 最小                 | 代表 | 最大  | 単位  |  |
|---------------------|-------------------|------|----------|--------------------|----|-----|-----|--|
|                     |                   | V版のみ | 1.8~2.7V | 0                  |    | 1   |     |  |
| 1/t <sub>CLCL</sub> | 発振器周波数            |      | 2.7~4.5V | 0                  |    | 9.6 | MHz |  |
|                     | 4.5               |      |          | 0                  |    | 20  |     |  |
|                     | V版                |      | 1.8~2.7V | 1000               |    |     |     |  |
| tclcl               | 発振器周期             |      | 2.7~4.5V | 104                |    |     |     |  |
|                     |                   |      | 4.5~5.5V | 62.5               |    |     |     |  |
| tshsl               | SCKパルスHレヘール幅      |      | (注1)     | 2tclcl             |    |     | ns  |  |
| tslsh               | SCKパルスLレヘ・ル幅 (注1) |      |          | 2tclcl             |    |     |     |  |
| tovsh               | SCK↑に対するMOSI準備時間  |      |          | tclcl              |    |     |     |  |
| t <sub>SHOX</sub>   | SCK↑に対するMOSI保持時間  |      |          | 2t <sub>CLCL</sub> |    |     |     |  |

注1: f<sub>CK</sub><12MHz時2t<sub>CLCL</sub>、f<sub>CK</sub>≥12MHz時3t<sub>CLCL</sub>。

# 18.9. 高電圧直列プログラミング特性



| 表18-9. 高電圧直列プログラミング・特性 (特記条件を除いて、TA=25℃, VCC=5.0V±10%) |                     |     |     |    |    |  |  |
|--------------------------------------------------------|---------------------|-----|-----|----|----|--|--|
| シンホ゛ル                                                  | 項目                  | 最小  | 代表  | 最大 | 単位 |  |  |
| tshsl                                                  | SCIパルスHレベル幅         | 110 |     |    |    |  |  |
| tslsh                                                  | SCIパルスLレベル幅         | 110 |     |    |    |  |  |
| t <sub>IVSH</sub>                                      | SCI↑に対するSDI,SII準備時間 | 50  |     |    | ns |  |  |
| t <sub>SHIX</sub>                                      | SCI↑に対するSDI,SII保持時間 | 50  |     |    |    |  |  |
| tshov                                                  | SCI↑に対するSDO出力遅延時間   |     | 16  |    |    |  |  |
| t <sub>WLWH_PFB</sub>                                  | ヒューズ書き込み第3バイト後待機時間  |     | 2.5 |    | ms |  |  |





# 19. 代表特性

本項内に含まれたデータは主に同じ製法と設計法の類似デバイスの特徴付けとシミュレーションに基いています。従って、このデータはデバイスがどう反応するかについての指標として扱われるべきです。

以下の図は代表的な特性を示します。これらの図は製造中に検査されていません。特性付けの間、デバイスは検査限界よりも高い周波数で動作していますが、それらは注文コードが示すよりも高い周波数での正しい機能が保証される訳ではありません。

全ての消費電流測定は全I/Oピンを入力として設定した内部プルアップ許可で行われています。消費電流は動作電圧、動作周波数、I/Oピンの負荷、I/Oピンの切り替え速度、命令実行、周囲温度のような様々な要素の関数です。支配的な要素は動作電圧と動作周波数です。

電源幅振幅の方形波発振器がクロック源として使われていますが、パワーダウン動作での消費電力はクロック選択と無関係です。ウォッチトック タイマ許可のハプローダウン動作での消費電流とウォッチトック タイマ禁止のハプローダウン動作での消費電流間の違いは、ウォッチトック タイマによって引き込んだ(消費した)差電流を表します。

容量性負荷のピンの引き込み電流は(1つのピンに対して) CL(負荷容量)×VCC(動作電圧)×fSW(I/Oピンの平均切り替え周波数) として推測できます。

#### 19.1. 活動動作消費電流

















# 19.2. アイドル動作消費電流

















# 19.3. パワーダウン動作消費電流





# 19.4. ピン プルアップ











# 19.5. ピン駆動能力

















































# 19.6. ピン 閾値とヒステリシス























# 19.7. 低電圧検出器(BOD)閾値とアナログ比較器オフセット













# 19.8. 内部発振器周波数





















# 19.9. 周辺機能部消費電流













# 19.10. リセット消費電流とリセット パルス幅











# 20. レジスタ要約

| アト・レス                      | レジスタ略称         | ヒ゛ット7     | ヒ゛ット6   | ヒ゛ット5   | ヒ゛ット4       | ピット3                 | ピット2                   | ヒ゛ット1    | ピット0      | 頁              |
|----------------------------|----------------|-----------|---------|---------|-------------|----------------------|------------------------|----------|-----------|----------------|
| \$3F (\$5F)                | SREG           | I         | T       | Н       | S           | V                    | N                      | Z        | С         | 6              |
| \$3E (\$5E)<br>\$3D (\$5D) | 予約<br>SPL      | SP7       | SP6     | SP5     | SP4         | SP3                  | SP2                    | SP1      | SP0       | 7              |
| \$3C (\$5C)                | 予約             | SF (      | 310     | 31.0    | SF 4        | SES                  | SF Z                   | SF I     | SFU       | 1              |
| \$3B (\$5B)                | GIMSK          | -         | INT0    | PCIE    | _           | -                    | -                      | -        | -         | 31             |
| \$3A (\$5A)                | GIFR           | -         | INTF0   | PCIF    | -           | -                    | -                      | -        | -         | 31             |
| \$39 (\$59)                | TIMSK0         | -         | _       | -       | -           | OCIE0B               | OCIE0A                 | TOIE0    | -         | 49             |
| \$38 (\$58)                | TIFR0          | -         | -       | -       | -           | OCF0B                | OCF0A                  | TOV0     | -         | 49             |
| \$37 (\$57)                | SPMCSR         | -         | -       | -       | CTPB        | RFLB<br>比較Aレジスタ      | PGWRT                  | PGERS    | SELFPRGEN | 67             |
| \$36 (\$56)<br>\$35 (\$55) | OCR0A<br>MCUCR | _         | PUD     | SE      | SM1         | に単文Aレン Aタ<br>SM0     | _                      | ISC01    | ISC00     | 48<br>37,22,30 |
| \$34 (\$54)                | MCUSR          | _         | _ FOD   | - SE    | - SWII      | WDRF                 | BORF                   | EXTRF    | PORF      | 27             |
| \$33 (\$53)                | TCCR0B         | FOC0A     | FOC0B   | _       | -           | WGM02                | CS02                   | CS01     | CS00      | 47             |
| \$32 (\$52)                | TCNT0          |           |         |         | タイマ/;       | カウンタ0                |                        |          | ,         | 48             |
| \$31 (\$51)                | OSCCAL         | -         |         |         | 内蔵RC発       | 辰器 発振校               | 正値レジスタ                 |          |           | 18             |
| \$30 (\$50)                | 予約             | 00) (0.4) | 0011010 | COLIODA | COLIODO     |                      |                        | 11101101 | IIIO) (0° | 40             |
| \$2F (\$4F)<br>\$2E (\$4E) | TCCR0A<br>DWDR | COM0A1    | COM0A0  | COM0B1  | COMOBO      | ー<br>データ レジスク        | -<br><del>5</del>      | WGM01    | WGM00     | 46<br>63       |
| \$2E (\$4E)<br>\$2D (\$4D) | 予約             |           |         | ,       | / / Y/ WIKE | ,                    | ,                      |          |           | 03             |
| \$2C (\$4C)                | 予約             |           |         |         |             |                      |                        |          |           |                |
| \$2B (\$4B)                | 予約             |           |         |         |             |                      |                        |          |           |                |
| \$2A (\$4A)                | 予約             |           |         |         |             |                      |                        |          |           |                |
| \$29 (\$49)                | OCR0B          | mov (     |         |         | タイマ/カウンタ    | 比較Bレジスタ              |                        |          | DCD10     | 48             |
| \$28 (\$48)<br>\$27 (\$47) | GTCCR          | TSM       | -       | -       | -           | -                    | -                      | _        | PSR10     | 51             |
| \$26 (\$46)                | 予約<br>CLKPR    | CLKPCE    | _       | _       | _           | CLKPS3               | CLKPS2                 | CLKPS1   | CLKPS0    | 18             |
| \$25 (\$45)                | 予約             | OLIGI OL  |         |         |             | CLIVI 00             | OLIVI 02               | CLINIOI  | CLINISO   | 10             |
| \$24 (\$44)                | 予約             |           |         |         |             |                      |                        |          |           |                |
| \$23 (\$43)                | 予約             |           |         |         |             |                      |                        |          |           |                |
| \$22 (\$42)                | 予約             |           |         |         |             |                      |                        |          |           |                |
| \$21 (\$41)                | WDTCR          | WDTIF     | WDTIE   | WDP3    | WDCE        | WDE                  | WDP2                   | WDP1     | WDP0      | 28             |
| \$20 (\$40)<br>\$1F (\$3F) | 予約<br><br>予約   |           |         |         |             |                      |                        |          |           |                |
| \$1E (\$3E)                | EEARL          | -         | -       |         | EEPF        | ROMアドレスレ             | シ <sup>゛</sup> スタ(EEAF | 25~0)    |           | 13             |
| \$1D (\$3D)                | EEDR           |           |         |         |             | ・ータ レシ・スタ            | ,                      |          | 1         | 13             |
| \$1C (\$3C)                | EECR           | -         | -       | EEPM1   | EEPM0       | EERIE                | EEMPE                  | EEPE     | EERE      | 13             |
| \$1B (\$3B)<br>\$1A (\$3A) | 予約<br><br>予約   |           |         |         |             |                      |                        |          |           |                |
| \$1A (\$3A)<br>\$19 (\$39) | 予約             |           |         |         |             |                      |                        |          |           |                |
| \$18 (\$38)                | PORTB          | -         | -       | PORTB5  | PORTB4      | PORTB3               | PORTB2                 | PORTB1   | PORTB0    | 37             |
| \$17 (\$37)                | DDRB           | -         | -       | DDB5    | DDB4        | DDB3                 | DDB2                   | DDB1     | DDB0      | 37             |
| \$16 (\$36)                | PINB           | -         | -       | PINB5   | PINB4       | PINB3                | PINB2                  | PINB1    | PINB0     | 37             |
| \$15 (\$35)                | PCMSK          | -         | -       | PCINT5  | PCINT4      | PCINT3               | PCINT2                 | PCINT1   | PCINT0    | 31             |
| \$14 (\$34)                | DIDR0<br>予約    | =         | =       | ADC0D   | ADC2D       | ADC3D                | ADC1D                  | AIN1D    | AIN0D     | 53,62          |
| \$13 (\$33)<br>\$12 (\$32) | 予約             |           |         |         |             |                      |                        |          |           |                |
| \$11 (\$31)                | 予約             |           |         |         |             |                      |                        |          |           |                |
| \$10 (\$30)                | 予約             |           |         |         |             |                      |                        |          |           |                |
| \$0F (\$2F)                | 予約             |           |         |         |             |                      |                        |          |           |                |
| \$0E (\$2E)                | 予約             |           |         |         |             |                      |                        |          |           |                |
| \$0D (\$2D)<br>\$0C (\$2C) | 予約<br><br>予約   |           |         |         |             |                      |                        |          |           |                |
| \$0C (\$2C)<br>\$0B (\$2B) |                |           |         |         |             |                      |                        |          |           |                |
| \$0A (\$2A)                | 予約             |           |         |         |             |                      |                        |          |           |                |
| \$09 (\$29)                | 予約             |           |         |         |             |                      |                        |          |           |                |
| \$08 (\$28)                | ACSR           | ACD       | ACBG    | ACO     | ACI         | ACIE                 | -                      | ACIS1    | ACIS0     | 53             |
| \$07 (\$27)                | ADGCDA         | ADENI     | REFS0   | ADLAR   | - ADID      | - ADID               | ADDCo                  | MUX1     | MUX0      | 60             |
| \$06 (\$26)<br>\$05 (\$25) | ADCSRA<br>ADCH | ADEN      | ADSC    | ADATE   | ADIF        | ADIE<br>(ADC9~8ま     | ADPS2                  | ADPS1    | ADPS0     | 60             |
| \$05 (\$25)                | ADCH           |           |         |         |             | (ADC9~83<br>(ADC7~03 |                        |          | 1         | 62             |
| \$03 (\$23)                | ADCSRB         | -         | ACME    | _       | -           | -                    | ADTS2                  | ADTS1    | ADTS0     | 52,61          |
| \$02 (\$22)                | 予約             |           |         |         |             |                      |                        |          |           |                |
| \$01 (\$21)                | 予約             |           |         |         |             |                      |                        |          |           |                |
| \$00 (\$20)                | 予約             |           |         |         |             |                      |                        |          |           |                |

注:・将来のデバイスとの共通性のため、予約ビットへ書く場合は0を書くべきです。予約I/Oメモリ アドレスは決して書かれるべきではありません。

<sup>・</sup>アトンス範囲\$00~\$1FのI/Oレシ、スタはCBIとSBI命令の使用で直接アクセス可能です。これらのレシ、スタの単一ビットはCBISとSBIS命令の使用によって検査できます。いくつかの状態ビットはそれらへ論理1を書くことによって解除(0)されます。他の多くのAVRと異なり、CBIとSBI命令は指定ビットだけ操作し、従ってこのような状態フラグを含むレシ、スタで使えることに注意してください。CBIとSBI命令は\$00~\$1Fのレシ、スタだけで動作します。

# 21. 命令要約

| ニーモニック       | オペラント゛         | 意味                                       | 動作                                               | フラク゛                               | クロック              |
|--------------|----------------|------------------------------------------|--------------------------------------------------|------------------------------------|-------------------|
|              |                | 算術、論理                                    | 運演算命令                                            |                                    |                   |
| ADD          | Rd,Rr          | 汎用レジスタ間の加算                               | Rd ← Rd + Rr                                     | I,T,H,S,V,N,Z,C                    | 1                 |
| ADC          | Rd,Rr          | キャリーを含めた汎用レジスタ間の加算                       | $Rd \leftarrow Rd + Rr + C$                      | I,T,H,S,V,N,Z,C                    | 1                 |
| ADIW         | Rd,K6          | 即値の語(ワード)長加算                             | RdH:RdL ← RdH:RdL + K6                           | I,T,H,S,V,N,Z,C                    | 2                 |
| SUB          | Rd,Rr          | 汎用レジスタ間の減算                               | Rd ← Rd − Rr                                     | I,T,H,S,V,N,Z,C                    | 1                 |
| SUBI         | Rd,K           | 汎用レジスタから即値の減算                            | Rd ← Rd − K                                      | I,T,H,S,V,N,Z,C                    | 1                 |
| SBIW<br>SBC  | Rd,K6          | 即値の語(ワード)長減算                             | RdH:RdL ← RdH:RdL - K6                           | I,T,H,S,V,N,Z,C                    | 2                 |
| SBCI         | Rd,Rr<br>Rd,K  | キャリーを含めた汎用レジスタ間の減算<br>汎用レジスタからキャリーと即値の減算 | Rd ← Rd − Rr − C<br>Rd ← Rd − K − C              | I,T,H,S,V,N,Z,C<br>I,T,H,S,V,N,Z,C | 1                 |
| AND          | Ra,K<br>Rd,Rr  | 汎用レジスタがらイヤリーと副値の減算<br>汎用レジスタ間の論理積(AND)   | Rd ← Rd − K − C<br>Rd ← Rd AND Rr                | I,T,H,S,V,N,Z,C                    | 1                 |
| ANDI         | Rd,Ki          | 汎用レジスタと即値の論理積(AND)                       | Rd ← Rd AND K                                    | I,T,H,S,V,N,Z,C                    | 1                 |
| OR           | Rd,Rr          | 汎用レジスタ間の論理和(OR)                          | Rd ← Rd OR Rr                                    | I,T,H,S,V,N,Z,C                    | 1                 |
| ORI          | Rd,K           | 汎用レジスタと即値の論理和(OR)                        | Rd ← Rd OR K                                     | I,T,H,S,0,N,Z,C                    | 1                 |
| EOR          | Rd,Rr          | 汎用レシブスタ間の排他的論理和(Ex-OR)                   | Rd ← Rd EOR Rr                                   | I,T,H,S,0,N,Z,C                    | 1                 |
| COM          | Rd             | 1の補数(論理反転)                               | Rd ← \$FF - Rd                                   | I,T,H,S,0,N,Z,C                    | 1                 |
| NEG          | Rd             | 2の補数                                     | Rd ← \$00 - Rd                                   | I,T,H,S,V,N,Z,C                    | 1                 |
| SBR          | Rd,K           | 汎用レシブスタの(複数)ビット設定(1)                     | Rd ← Rd OR K                                     | I,T,H,S,0,N,Z,C                    | 1                 |
| CBR          | Rd,K           | 汎用レジスタの(複数)ビット解除( <mark>0</mark> )       | $Rd \leftarrow Rd \ AND \ (\$FF - K)$            | I,T,H,S,0,N,Z,C                    | 1                 |
| INC          | Rd             | 汎用レシブスタの増加(+1)                           | Rd ← Rd + 1                                      | I,T,H,S,V,N,Z,C                    | 1                 |
| DEC          | Rd             | 汎用レジスタの減少(-1)                            | Rd ← Rd - 1                                      | I,T,H,S,V,N,Z,C                    | 1                 |
| TST          | Rd             | 汎用レシブスタのセブロとマイナス検査                       | Rd ← Rd AND Rd                                   | I,T,H, <mark>S,0,N,Z,</mark> C     | 1                 |
| CLR          | Rd             | 汎用レジスタの全0設定(=\$00)                       | Rd ← Rd EOR Rd                                   | I,T,H,0,0,0,1,C                    | 1                 |
| SER          | Rd             | 汎用レジスタの全1設定(=\$FF)                       | Rd ← \$FF                                        | I,T,H,S,V,N,Z,C                    | 1                 |
|              | _              |                                          | 命令                                               | ,                                  |                   |
| RJMP         | k              | 相対分岐                                     | $PC \leftarrow PC + k + 1$                       | I,T,H,S,V,N,Z,C                    | 2                 |
| IJMP         |                | Zレジスタ間接分岐                                | PC ← Z                                           | I,T,H,S,V,N,Z,C                    | 2                 |
| RCALL        | k              | 相対サブルーチン呼び出し                             | $STACK \leftarrow PC, PC \leftarrow PC + k + 1$  | I,T,H,S,V,N,Z,C                    | 3                 |
| ICALL        |                | Zレジスタ間接サブルーチン呼び出し                        | $STACK \leftarrow PC, PC \leftarrow Z$           | I,T,H,S,V,N,Z,C                    | 3                 |
| RET          |                | サブルーチンからの復帰                              | PC ← STACK                                       | I,T,H,S,V,N,Z,C                    | 4                 |
| RETI         | D I D          | 割り込みからの復帰                                | PC ← STACK                                       | <b>1</b> ,T,H,S,V,N,Z,C            | 4                 |
| CPSE<br>CP   | Rd,Rr<br>Rd,Rr | 汎用レジ、スタ間比較、一致でスキップ<br>  汎用レジ、スタ間の比較      | Rd=Rr'\$6, PC ← PC + 2or3<br>Rd – Rr             | I,T,H,S,V,N,Z,C<br>I,T,H,S,V,N,Z,C | 1/2,3             |
| CPC          | Rd,Rr          | キャリーを含めた汎用レジスタ間の比較                       | Rd - Rr - C                                      | I,T,H,S,V,N,Z,C                    | 1                 |
| CPI          | Rd,Ki          | 汎用レジスタと即値の比較                             | Rd - K                                           | I,T,H,S,V,N,Z,C                    | 1                 |
| SBRC         | Rr,b           | 汎用レジスタのビットが解除(0)でスキッフ。                   | Rr(b)=0なら、PC ← PC + 2or3                         | I,T,H,S,V,N,Z,C                    | 1/2,3             |
| SBRS         | Rr,b           | 汎用レジスタのビットが設定(1)でスキップ                    | Rr(b)=1なら, PC ← PC + 2or3                        | I,T,H,S,V,N,Z,C                    | 1/2,3             |
| SBIC         | P,b            | I/Oレシブスタのビットが解除(0)でスキップ                  | P(b)=07\$6, PC ← PC + 2or3                       | I,T,H,S,V,N,Z,C                    |                   |
| SBIS         | P,b            | I/Oレジスタのビットが設定(1)でスキップ                   | P(b)=1なら, PC ← PC + 2or3                         | I,T,H,S,V,N,Z,C                    | 1/2,3             |
| BRBS         | s,k            | ステータス フラク が設定(1)で分岐                      | SREG(s)=1なら, PC ← PC + K + 1                     | I,T,H,S,V,N,Z,C                    | 1/2               |
| BRBC         | s,k            | ステータス フラク が解除(0)で分岐                      | SREG(s)=0735, PC ← PC + K + 1                    | I,T,H,S,V,N,Z,C                    | 1/2               |
| BREQ         | k              | 一致で分岐                                    | Z=1なら, PC ← PC + K + 1                           | I,T,H,S,V,N,Z,C                    | 1/2               |
| BRNE         | k              | 不一致で分岐                                   | Z=0なら, PC ← PC + K + 1                           | I,T,H,S,V,N,Z,C                    | 1/2               |
| BRCS         | k              | キャリー フラグが設定(1)で分岐                        | C=1なら, PC ← PC + K + 1                           | I,T,H,S,V,N,Z,C                    | 1/2               |
| BRCC         | k              | キャリー フラク が解除(0)で分岐                       | C=07\$6, PC ← PC + K + 1                         | I,T,H,S,V,N,Z,C                    |                   |
| BRSH         | k              | 符号なしの≧で分岐                                | C=0なら, PC ← PC + K + 1                           | I,T,H,S,V,N,Z,C                    | 1/2               |
| BRLO         | k              | 符号なしの<で分岐                                | C=1なら, PC ← PC + K + 1                           | I,T,H,S,V,N,Z,C                    | 1/2               |
| BRMI         | k              | -(マイナス)で分岐                               | N=1なら, PC ← PC + K + 1                           | I,T,H,S,V,N,Z,C                    | 1/2               |
| BRPL         | k              | +(プラス)で分岐                                | N=0なら, PC ← PC + K + 1                           | I,T,H,S,V,N,Z,C                    | 1/2               |
| BRGE         | k              | 符号付きの≧で分岐                                | (N EOR V)=07\$\$, PC ← PC + K + 1                | I,T,H,S,V,N,Z,C                    | 1/2               |
| BRLT         | k              | 符号付きの<で分岐                                | (N EOR V)=1なら、PC ← PC + K + 1                    | I,T,H,S,V,N,Z,C                    | 1/2               |
| BRHS         | k              | ハーフキャリー フラグが設定(1)で分岐                     | H=1なら, PC ← PC + K + 1                           | I,T,H,S,V,N,Z,C                    | 1/2               |
| BRHC         | k              | ハーフキャリー フラグが解除(0)で分岐                     | H=07\$\$, PC ← PC + K + 1                        | I,T,H,S,V,N,Z,C                    | 1/2               |
| BRTS         | k              | 一時7ラグが設定(1)で分岐                           | T=1/26, PC ← PC + K + 1                          | I,T,H,S,V,N,Z,C                    | 1/2               |
| BRTC         | k              | 一時フラグが解除(0)で分岐                           | T=0'\$\(\delta\), PC ← PC + K + 1                | I,T,H,S,V,N,Z,C                    | 1/2               |
| BRVS         | k<br>le        | 2の補数溢れフラグが設定(1)で分岐<br>2の補数溢れフラグが解除(0)で分岐 | V=1なら, PC ← PC + K + 1                           | I,T,H,S,V,N,Z,C                    | 1/2               |
| BRVC         | k<br>le        | 200 情級値和777 が解除(0)で分岐   割り込み許可で分岐        | $V=0$ 7 $c$ 6, $PC \leftarrow PC + K + 1$        | I,T,H,S,V,N,Z,C<br>I,T,H,S,V,N,Z,C | 1/2               |
| BRIE<br>BRID | k<br>k         | 割り込み禁止で分岐                                | I=1なら, PC ← PC + K + 1<br>I=0なら, PC ← PC + K + 1 |                                    | $\frac{1/2}{1/2}$ |
| סמוט         | K              | 可り心か示単し刀収                                | 11-0/40, FC ← FC + N + I                         | I,T,H,S,V,N,Z,C                    | 1/4               |

K6, K: 6, 8ビット定数 P: I/Oレシブスタ Rd, Rr:汎用レジブスタ(R0~R31) X, Y, Z: X, Y, Zレシブスタ

b: ビット(0~7) k: アドレス定数(7,12,16ビット) q: 符号なし6ビット定数(変位) s: ステータス フラグ(C,Z,N,V,X,H,T,I)





| ニーモニック      | オペラント゛          | 意味                                                                  | 動作                                                                                 | フラク゛                                        | クロック     |
|-------------|-----------------|---------------------------------------------------------------------|------------------------------------------------------------------------------------|---------------------------------------------|----------|
|             | 1 4 1 1 1       | データ科                                                                | 多動命令                                                                               | 7//                                         | 7-77     |
| MOV         | Rd,Rr           | 汎用レジスタ間の複写                                                          | Rd ← Rr                                                                            | I,T,H,S,V,N,Z,C                             | 1        |
| MOVW        | Rd,Rr           | 汎用レジスタ対間の複写                                                         | Rd+1:Rd ← Rr+1:Rr                                                                  | I,T,H,S,V,N,Z,C                             | 1        |
| LDI         | Rd,K            | 即値の取得                                                               | $Rd \leftarrow K$                                                                  | I,T,H,S,V,N,Z,C                             | 1        |
| LD<br>LD    | Rd,X<br>Rd,X+   | Xレシ、スタ間接での取得<br>事後増加付きXレシ、スタ間接での取得                                  | $Rd \leftarrow (X)$ $Rd \leftarrow (X), X \leftarrow X + 1$                        | I,T,H,S,V,N,Z,C<br>I,T,H,S,V,N,Z,C          | 2 2      |
| LD          | Rd,-X           | 事前減少付きXレジスタ間接での取得                                                   | $X \leftarrow (X), X \leftarrow X + 1$<br>$X \leftarrow X - 1, Rd \leftarrow (X)$  | I,T,H,S,V,N,Z,C                             | 2        |
| LD          | Rd, Y           | Yレジスタ間接での取得                                                         | $Rd \leftarrow (Y)$                                                                | I,T,H,S,V,N,Z,C                             | 2        |
| LD          | Rd,Y+           | 事後増加付きYレジスタ間接での取得                                                   | $Rd \leftarrow (Y), Y \leftarrow Y + 1$                                            | I,T,H,S,V,N,Z,C                             | 2        |
| LD          | Rd,-Y           | 事前減少付きYレジスタ間接での取得                                                   | $Y \leftarrow Y - 1$ , $Rd \leftarrow (Y)$                                         | I,T,H,S,V,N,Z,C                             | 2        |
| LDD         | Rd,Y+q          | 変位付きYレシブスタ間接での取得                                                    | $Rd \leftarrow (Y + q)$                                                            | I,T,H,S,V,N,Z,C                             | 2        |
| LD          | Rd,Z            | Zレジスタ間接での取得                                                         | $Rd \leftarrow (Z)$                                                                | I,T,H,S,V,N,Z,C                             | 2        |
| LD<br>LD    | Rd,Z+<br>Rd,-Z  | 事後増加付きZレジスタ間接での取得<br>事前減少付きZレジスタ間接での取得                              | $Rd \leftarrow (Z), Z \leftarrow Z + 1$ $Z \leftarrow Z - 1, Rd \leftarrow (Z)$    | I,T,H,S,V,N,Z,C<br>I,T,H,S,V,N,Z,C          | 2 2      |
| LDD         | Rd,-Z<br>Rd,Z+q | 変位付きZレジスタ間接での取得                                                     | $Z \leftarrow Z - 1$ , $Rd \leftarrow (Z)$<br>$Rd \leftarrow (Z + q)$              | I,T,H,S,V,N,Z,C                             | 2        |
| LDS         | Rd,k            | データ空間(SRAM)から直接取得                                                   | $Rd \leftarrow (k)$                                                                | I,T,H,S,V,N,Z,C                             | 2        |
| ST          | X,Rr            | Xレシ、スタ間接での設定                                                        | $(X) \leftarrow Rr$                                                                | I,T,H,S,V,N,Z,C                             | 2        |
| ST          | X+,Rr           | 事後増加付きXレジスタ間接での設定                                                   | $(X) \leftarrow Rr, X \leftarrow X + 1$                                            | I,T,H,S,V,N,Z,C                             | 2        |
| ST          | -X,Rr           | 事前減少付きXレジスタ間接での設定                                                   | $X \leftarrow X - 1$ , $(X) \leftarrow Rr$                                         | I,T,H,S,V,N,Z,C                             | 2        |
| ST          | Y,Rr            | Yレジスタ間接での設定                                                         | $(Y) \leftarrow Rr$                                                                | I,T,H,S,V,N,Z,C                             | 2        |
| ST<br>ST    | Y+,Rr           | 事後増加付きYレジスタ間接での設定                                                   | $(Y) \leftarrow Rr, Y \leftarrow Y + 1$<br>$Y \leftarrow Y - 1, (Y) \leftarrow Rr$ | I,T,H,S,V,N,Z,C                             | 2        |
| STD         | -Y,Rr<br>Y+q,Rr | 事前減少付きYレジスタ間接での設定<br>変位付きYレジスタ間接での設定                                | $Y \leftarrow Y - 1, (Y) \leftarrow Rr$<br>$(Y + q) \leftarrow Rr$                 | I,T,H,S,V,N,Z,C<br>I,T,H,S,V,N,Z,C          | 2 2      |
| STD         | Z,Rr            | Zレジスタ間接での設定                                                         | $(1+q) \leftarrow Rr$<br>$(Z) \leftarrow Rr$                                       | I.T.H.S.V.N.Z.C                             | 2        |
| ST          | Z+,Rr           | 事後増加付きZレジスタ間接での設定                                                   | $(Z) \leftarrow Rr, Z \leftarrow Z + 1$                                            | I,T,H,S,V,N,Z,C                             | 2        |
| ST          | −Z,Rr           | 事前減少付きZレジスタ間接での設定                                                   | $Z \leftarrow Z - 1$ , $(Z) \leftarrow Rr$                                         | I,T,H,S,V,N,Z,C                             | 2        |
| STD         | Z+q,Rr          | 変位付きZレジスタ間接での設定                                                     | $(Z + q) \leftarrow Rr$                                                            | I,T,H,S,V,N,Z,C                             | 2        |
| STS         | k,Rr            | データ空間(SRAM)へ直接設定                                                    | $(k) \leftarrow Rr$                                                                | I,T,H,S,V,N,Z,C                             | 2        |
| LPM         | D.1.5           | プログラム領域からZレジスタ間接での取得                                                | $R0 \leftarrow (Z)$                                                                | I,T,H,S,V,N,Z,C                             | 3        |
| LPM<br>LPM  | Rd,Z            | 同上 (任意のレジスタへ)<br>同上 (事後増加付き)                                        | $Rd \leftarrow (Z)$ $Rd \leftarrow (Z), Z \leftarrow Z + 1$                        | I,T,H,S,V,N,Z,C                             | 3        |
| SPM         | Rd,Z+           | 円上(争後増加付さ)<br> プログラム領域へZレジスタ間接での設定                                  | $(Z) \leftarrow R1:R0$                                                             | I,T,H,S,V,N,Z,C<br>I,T,H,S,V,N,Z,C          | <u> </u> |
| IN          | Rd,P            | I/Oレジスタからの入力                                                        | $Rd \leftarrow P$                                                                  | I,T,H,S,V,N,Z,C                             | 1        |
| OUT         | P,Rr            | I/Oレジスタへの出力                                                         | P ← Rr                                                                             | I,T,H,S,V,N,Z,C                             | 1        |
| PUSH        | Rr              | 汎用レシブスタをスタックへ保存                                                     | STACK ← Rr                                                                         | I,T,H,S,V,N,Z,C                             | 2        |
| POP         | Rd              | スタックから汎用レジスタへ復帰                                                     | Rd ← STACK                                                                         | I,T,H,S,V,N,Z,C                             | 2        |
| CDI         | D.I             |                                                                     | 保命令<br>1.70(P1)                                                                    | ITHOUNT O                                   | 0        |
| SBI<br>CBI  | P,b<br>P,b      | I/Oレジスタのビット設定(1) I/Oレジスタのビット解除(0)                                   | $I/O(P,b) \leftarrow 1$ $I/O(P,b) \leftarrow 0$                                    | I,T,H,S,V,N,Z,C<br>I,T,H,S,V,N,Z,C          | 2 2      |
| LSL         | Rd              | 計でして 入りのと 外解病(の)   論理的左と、小移動                                        | $Rd(n+1) \leftarrow Rd(n), Rd(0) \leftarrow 0$                                     | I,T,H,S,V,N,Z,C                             | 1        |
| LSR         | Rd              | 論理的右ビット移動                                                           | $Rd(n) \leftarrow Rd(n+1), Rd(7) \leftarrow 0$                                     | I,T,H,S,V,0,Z,C                             | 1        |
| ROL         | Rd              | キャリーを含めた左回転                                                         | $Rd(0) \leftarrow C$ , $Rd(n+1) \leftarrow Rd(n)$ , $C \leftarrow Rd(7)$           | I,T,H,S,V,N,Z,C                             | 1        |
| ROR         | Rd              | キャリーを含めた右回転                                                         | $Rd(7) \leftarrow C, Rd(n) \leftarrow Rd(n+1), C \leftarrow Rd(0)$                 | I,T,H,S,V,N,Z,C                             | 1        |
| ASR         | Rd              | 算術的右ビット移動                                                           | $Rd(n) \leftarrow Rd(n+1), n=0 \sim 6$                                             | I,T,H,S,V,N,Z,C                             | 1        |
| SWAP        | Rd              | ニブル(4ビット)上位/下位交換                                                    | $Rd(7\sim4) \Leftrightarrow Rd(3\sim0)$                                            | I,T,H,S,V,N,Z,C                             | 1        |
| BSET        | S               | ステータス レジスタのビット設定(1)<br>ステータス レジスタのビット解除(0)                          | $SREG(s) \leftarrow 1$                                                             | 1,T,H,\$,V,N,Z,C                            | 1        |
| BCLR<br>BST | s<br>Rr,b       | ハアーダスレン スタのどット解除(0)   汎用レジスタのどットを一時フラグへ移動                           | $SREG(s) \leftarrow 0$ $T \leftarrow Rr(b)$                                        | 0,0,0,0,0,0,0,0<br>I,T,H,S,V,N,Z,C          | 1        |
| BLD         | Rr,b<br>Rd,b    | 一時フラグを汎用レジスタのピットへ移動                                                 | $Rd(b) \leftarrow T$                                                               | I, T, H, S, V, N, Z, C                      | 1        |
| SEC         | 114,0           | キャリー フラグを設定(1)                                                      | $C \leftarrow 1$                                                                   | I,T,H,S,V,N,Z,C                             | 1        |
| CLC         |                 | キャリー フラグを解除( <mark>0</mark> )                                       | C ← 0                                                                              | I,T,H,S,V,N,Z, <b>0</b>                     | 1        |
| SEN         |                 | 負フラグを設定( <u>1</u> )                                                 | N ← 1                                                                              | I,T,H,S,V,N,Z,C                             | 1        |
| CLN         |                 | 負フラグを解除(0)                                                          | $N \leftarrow 0$                                                                   | I,T,H,S,V,0,Z,C                             | 1        |
| SEZ         |                 | ゼロ フラグを設定(1)                                                        | Z ← 1                                                                              | I,T,H,S,V,N,I,C                             | 1        |
| CLZ<br>SEI  |                 | t <sup>*</sup> ip フラク <sup>*</sup> を解除( <mark>0</mark> )<br>全割り込み許可 | Z ← 0<br>I ← 1                                                                     | I,T,H,S,V,N,Ø,C<br>1,T,H,S,V,N,Z,C          | 1        |
| CLI         |                 | 全割り込み禁止                                                             | $I \leftarrow I$                                                                   | 0,T,H,S,V,N,Z,C                             | 1        |
| SES         |                 | 至的りた。ケ宗正   符号フラグを設定(1)                                              | S ← 1                                                                              | I,T,H,\$,V,N,Z,C                            | 1        |
| CLS         |                 | 符号フラグを解除(0)                                                         | S ← 0                                                                              | $I,T,H,\theta,V,N,Z,C$                      | 1        |
| SEV         |                 | 2の補数溢れフラグを設定(1)                                                     | V ← 1                                                                              | I,T,H,S,Y,N,Z,C                             | 1        |
| CLV         |                 | 2の補数溢れフラグを解除(0)                                                     | V ← 0                                                                              | I,T,H,S, <b>0</b> ,N,Z,C                    | 1        |
| SET         |                 | 一時フラグを設定(1)                                                         | $T \leftarrow 1$                                                                   | I,T,H,S,V,N,Z,C                             | 1        |
| CLT<br>SEH  |                 | 一時フラグを解除(0)                                                         | $T \leftarrow 0$ $H \leftarrow 1$                                                  | I, <b>0</b> ,H,S,V,N,Z,C<br>I,T,H,S,V,N,Z,C | 1<br>1   |
| SEH<br>CLH  |                 | ハーフキャリー フラケ を設定(1)<br>  ハーフキャリー フラケ を解除(0)                          | $H \leftarrow 1$ $H \leftarrow 0$                                                  | I,T,H,S,V,N,Z,C<br>I,T, <b>0</b> ,S,V,N,Z,C | 1        |
| CLII        |                 |                                                                     |                                                                                    | 1, 1, M, O, V, IV, L, C                     | 1        |
| NOP         |                 | 無操作                                                                 | The Late 18                                                                        | I,T,H,S,V,N,Z,C                             | 1        |
| SLEEP       |                 | 休止形態開始                                                              | 休止形態参照                                                                             | I,T,H,S,V,N,Z,C                             | 1        |
| WDR         |                 | ウォッチト゛ック゛ タイマ リセット                                                  | ウォッチト・ック・タイマ参照                                                                     | I,T,H,S,V,N,Z,C                             | 1        |
| BREAK       |                 | 一時停止                                                                | 内蔵デバッグWIRE機能専用                                                                     | I,T,H,S,V,N,Z,C                             | N/A      |
|             |                 |                                                                     |                                                                                    |                                             |          |

# 22. 注文情報

| 速度(MHz)          | 電源電圧     | 注文コート (注2,4)    | 外囲器    | 動作範囲         |
|------------------|----------|-----------------|--------|--------------|
|                  |          | ATtiny13V-10PU  | 8P3    |              |
|                  |          | ATtiny13V-10SU  | 8S2    |              |
|                  |          | ATtiny13V-10SU  | 032    |              |
|                  |          | ATtiny13V-10SSU | S8S1   |              |
| 10 ( <b>注3</b> ) | 1.8~5.5V | ATtiny13V-10SSU | 3031   |              |
|                  |          | ATtiny13V-10MMU | 10M1   |              |
|                  |          | ATtiny13V-10MMU | TOWIT  |              |
|                  |          | ATtiny13V-10MU  | 20M1   |              |
|                  |          | ATtiny13V-10MU  | 201011 | 工業用          |
|                  |          | ATtiny13-20PU   | 8P3    | (-40°C∼85°C) |
|                  |          | ATtiny13-20SU   | 8S2    |              |
|                  |          | ATtiny13-20SU   | 052    |              |
|                  |          | ATtiny13-20SSU  | S8S1   |              |
| 20 ( <b>注3</b> ) | 2.7~5.5V | ATtiny13-20SSU  | 3031   |              |
|                  |          | ATtiny13-20MMU  | 10M1   |              |
|                  |          | ATtiny13-20MMU  | TOWIT  |              |
|                  |          | ATtiny13-20MU   | 20M1   |              |
|                  |          | ATtiny13-20MU   | 201/11 |              |

注: このデバイスはウェハー(チップ<sup>°</sup>単体)形状でも供給できます。最低数量と詳細な注文情報については最寄のAtmel営業所へお問い合わせください。

注2: 有害物質使用制限に関する欧州指令(RoHS指令)適合の鉛フリー製品。またハロケン化合物フリーで完全に安全です。

注3: 速度対VCCについては78頁の「速度勾配」をご覧ください。

注4: 符号は以下を示します。

U:半光沢錫R:テープとリール

|      | 外囲器形式                                                 |
|------|-------------------------------------------------------|
| 8P3  | 8ピン 300mil幅 プラスティック2列直線外囲器 (PDIP)                     |
| 8S2  | 8リート、209mil幅 プラスティック小型外形外囲器 (EIAJ SOIC)               |
| S8S1 | 8リート・150mil幅 プラスティック小型外形外囲器 (JEDEC SOIC)              |
| 10M1 | 10パット、3×3×1mm 0.5mmピッチ 4方向平板リードなし/小リート・枠外囲器 (QFN/MLF) |
| 20M1 | 20パッド4×4×0.8mm 0.5mmピッチ 4方向平板リードなし/小リード枠外囲器 (QFN/MLF) |





# 23. 外囲器情報

#### 23.1. 8P3



#### 23.2. S8S1



#### 23.3. 8S2



#### 23.4. 10M1



# 23.5. 20M1







# 24. 障害情報

この章の改訂番号はATtiny13デバイスの改訂版を参照してください。

#### 改訂A.C

改訂版AとCは試供されていません。

・単独消去操作後の不正値読み込み
 ・フラッシュメモリ、EEPROM、ヒューズと施錠じットの高電圧直列プログラミング失敗の可能性
 ・更なるプログラミングに対するデバイス固定化の可能性
 ・施錠じットによるデバッグWIRE通信の防止未了
 ・ウォッチドッグ、タイマ割り込みが禁止
 ・1.9V以下でのEEPROM書き込み不可

#### 1. 単独消去操作後の不正値読み込み (B)

2.7V以下の電圧印加で、消去操作のみで消去されたEEPROM位置はプログラム(\$00)として読むかもしれません。

#### 対策/対処

単独消去後にEEPROM位置を読む必要がある場合、その位置を消去するために値として\$FFの非分離書き込みを使ってください。どんな場合も単独書き込み操作は予定どおりに使えます。従って消去された位置がプログラミング以前に読まれない限り、特別な考慮の必要はありません。

#### 2. フラッシュ メモリ、EEPROM、ヒュース、と施錠ビットの高電圧直列プログラミング失敗の可能性(B)

これらの位置とビットへの書き込みはいくつかの場合で失敗するかもしれません。

#### 対策/対処

書き込み開始後、常にRDY/BSY信号を監視してください。書き込み失敗した場合、RDY/BSYが正しい書き込みを確認するまで再書き込みを行ってください。これは改訂Dで修正されるでしょう。

#### 3. 更なるプログラミングに対するデバイス固定化の可能性(B)

ヒュース、ヒットの特別な組み合わせは更なるプログラミングに対してデバイスを固定化し、実際上OTP(One Time Programmable)デバイス に切り替えます。次のヒュース、ヒットの組み合わせ設定がこの結果を引き起こします。

- ・128kHz内部発振器(CKSEL1,0=11)、最短起動時間(SUT1,0=00)、デブックWIRE許可(DWEN=0)または外部リセット禁止(RSTDIS BL=0)
- ・9.6MHz内蔵RC発振器(CKSEL1,0=10)、最短起動時間(SUT1,0=00)、デバッグWIRE許可(DWEN=0)または外部リセット禁止(RST DISBL=0)
- ・4.8MHz内蔵RC発振器(CKSEL1,0=01)、最短起動時間(SUT1,0=00)、デブックWIRE許可(DWEN=0)または外部リセット禁止(RST DISBL=0)

#### 対策/対処

上のヒューズ設定を避けてください。長い起動時間選択(設定)がこの問題を無くします。

#### 4. 施錠ビットによるデバッグWIRE通信の防止未了(B)

デバック、WIRE内蔵デバックが許可(DWEN=0)されると、例え更なるデバイス読み出しを防止するために施錠ビットが設定されていても、プログラム メモリとEEPROMデータ メモリの内容は読めます。

#### 対策/対処

ATtiny13の内蔵デバッグ許可で製品を出荷しないでください。

### 5. ウォッチト゛ック゛タイマ割り込みが禁止(B)

ウォッチト、ック、タイマ割り込み要求フラグ(WDTIF)が次の計時完了発生に先立って解除(0)されなければ、ウォッチト、ック、は禁止され、割り込み要求フラグは自動的に解除(0)されます。これは割り込みのみの動作種別にだけ当てはまります。ウォッチト、ッグ計時完了に続く割り込みでウォッチト、ッグがデバイスリセットに設定されれば、デバイスは正しく動作します。

#### 対策/対処

次のウォッチドッグ計時完了が起こる前に、先行する計時完了発生での処理が常に充分な時間であることに注意してください。これは充分に長い計時完了周期を選択することによって行われます。

#### 6. 1.9V以下でのEEPROM書き込み不可(B/D)

1.9V以下のVCCでのEEPROM書き込みは失敗するかもしれません。

#### 対策/対処

VCCが1.9V以下の時にEEPROMを書かないでください。

# 25. データシート改訂履歴

本章内の頁番号がこの資料の現状版を参照することに注意してください。

### 25.1. 2535A - 2003年6月

1. 未公開

#### 25.2. 2535B - 2004年1月

- 1. 3頁の図2-1.を更新
- 2. 28頁の表8-2、60頁の表14-3、78頁の表18-3、79頁の表18-4を更新
- 3. 16頁の「校正付き内蔵4.8/9.6MHz発振器」を更新
- 4. 25頁からの「ウォッチト`ック` タイマ」全体を更新
- 5. 71頁の図17-1、73頁の図17-2を更新
- 6. 37頁の「MCU制御レシ、スタ(MCUCR)」、47頁の「タイマ/カウンタ制御レシ、スタB(TCCR0B)」、53頁の「テ゛ジタル入力禁止レシ、スタの(DIDR0)」を 更新
- 7. 77頁の「電気的特性」で「絶対最大特性」と「DC特性」を更新
- 8. 78頁に「速度勾配」を追加
- 9. 80頁の「A/D変換器特性」を更新
- 10. 82頁からの「代表特性」を更新
- 11. 107頁の「注文情報」を更新
- 12. 108頁の「外囲器情報」を更新
- 13. 110頁の「障害情報」を更新
- 14. EEARをEEARLに改名

#### 25.3. 2535C - 2004年2月

- 1. Cコート 例をIAR標準構文規則へ更新
- 2. WDIFをWDTIF、WDIEをWDTIEに改名
- 3. 7頁の「スタック ポインタ(SPL)」を更新
- 4. 16頁の「校正付き内蔵4.8/9.6MHz発振器」を更新
- 5. 18頁の「**発振校正レジスタ(OSCCAL)**」を更新
- **6**. 25頁の「ウォッチト'ック' タイマ」で序文の誤植を更新
- 7. 57頁の表14-1.「A/D変換時間」を更新
- 8. 71頁の「**低電圧直列プログラミング**」を更新
- 9. 77頁の「電気的特性」を更新
- 10. 107頁の「注文情報」を更新
- 11. 110頁の「障害情報」から改訂Cを削除

#### 25.4. 2535D - 2004年4月

- 1. 最大動作速度を変更
  - ・12MHzを10MHzへ
  - ・24MHzを20MHzへ
- 2. 72頁の「低電圧直列プログラミング命令一式」を更新
- 3. 78頁の「速度勾配」を更新
- 4. 107頁の「注文情報」を更新

#### 25.5. 2535E - 2004年10月

- 1. 資料内でEEMWE/EEWEL \*\* y トをEEMPE/EEPEに変更
- 2. 2頁の「ピン配置」を更新
- 3. 74頁の表17-13.での「下位ヒュース」書き込み」、78頁の表18-3.を更新
- **4**. 30頁に「ピン変化割り込みタイミング」を追加
- 5. 31頁の「一般割り込み許可レジスタ(GIMSK)」を更新
- **6**. 31頁の「ピン変化割り込み許可レジスタ(PCMSK)」を更新





- 7. 71頁の「**低電圧直列プログラミング手順**」で項目4.を更新
- 8. 73頁の「**高電圧直列プログラミング動作への移行**」を更新
- 9. 77頁の「DC特性」を更新
- 10. 82頁からの「代表特性」を更新
- 11. 107頁の「注文情報」を更新
- 12. 108頁の「外囲器情報」を更新
- 13. 110頁の「障害情報」を更新

#### 25.6. 2535F - 2006年4月

1. 未公開

#### 25.7. 2535G - 2007年1月

- 1. 暫定を削除
- 2. 28頁の表8-1.、79頁の表18-4.、80頁の表18-8.を更新
- 3. 79頁の表18-4.から注を削除
- 4. 53頁の「tinh6 ACBG: 基準電圧選択」を更新
- 5. 56頁の「**前置分周と変換タイミンク**゙」を更新
- 6.80頁の図18-4.を更新
- 7. 77頁の「電気的特性」を更新
- 8. 107頁の「注文情報」を更新
- 9. 108頁の「外囲器情報」を更新

#### 25.8. 2535H - 2007年10月

- 1. 1頁の「特徴」を更新
- 2. 2頁の「L°ン配置」を更新
- 3. 4頁に「データ保持力」を追加
- 4. 26頁のアセンフリ言語コート・例を更新
- **5**. 31頁の「一般割り込み許可レジスタ (GIMSK)」でビット5記述を更新
- 6. 36頁の「ポートBの交換機能」で表10-3.を更新
- 7. 57頁の「A/D変換基準電圧」を更新
- 8. 70頁の「校正値バイ」を更新
- 9. 72頁で「校正値読み出し」を更新
- **10**. 73頁の「**高電圧直列プログラミンク** 動作への移行」で方法を更新
- 11. 74頁で「校正値読み出し」を更新
- 12. 78頁の外部クロック特性で値(表18-3.)を更新
- 13. 80頁の「低電圧直列プログラミング特性」で表18-8.を更新
- 14. 107頁の「注文情報」を更新
- 15. 108頁の「外囲器情報」を更新

#### **25.9**. 2535I - 2008年5月

- 1. 資料雛形、配置、段落形式を更新
- 2. 1頁の「特徴」を更新
- 3. 項目作成:
  - ・78頁の「校正付き内蔵RC発振器精度」
  - ・79頁の「アナログ比較器特性」

# 4. 項目更新:

- ・15頁の「システム クロックとクロック選択」
- ・16頁の「校正付き内蔵4.8/9.6MHz発振器」
- ・30頁の「外部割り込み」
- ・58頁の「アナログ雑音低減技術」
- ・63頁の「デバッグWIREの制限」
- ・66頁の「ファームウェアからの施錠ビットとヒュース」の読み出し」

- 69頁の「ヒュース゛ビット」
- ・70頁の「校正値バイ」
- ・73頁の「高電圧直列プログラミング特性」
- ・107頁の「注文情報」

#### 5. 図更新:

- ・58頁の「**アナログ入力回路**」
- ・81頁の「高電圧直列プログラミング、タイミング」

#### 6. 図移動:

- ・80頁の「低電圧直列プログラミング、タイミング」
- ・80頁の「低電圧直列プログラミング波形」
- ・81頁の「高電圧直列プログラミング、タイミング」

#### 7. 表更新:

- 77頁の「DC特性」
- ・80頁の「低電圧直列プログラミング特性」

#### 8. 表移動:

- ・72頁の「低電圧直列プログラミング命令一式」
- ・80頁の「低電圧直列プログラミング特性」
- ・81頁の「高電圧直列プログラミング特性」

#### 9. 項に関してレジスタ内容更新:

- 46頁の「タイマ/カウンタ制御レシ、スタA(TCCR0A)」
- 62頁の「デジタル入力禁止レジスタの(DIDRO)」
- 10. 71頁で手順1.の内容を更新
- 11. デバイス状況を「新規設計に推奨されない」に変更

#### 25.10. 2535J - 20010年8月

- 1. 表紙で「新規設計に推奨されない」の文章を削除
- **2**. 107頁の「**注文情報**」にテープとリール品の番号を追加
- 3. 最終頁を更新





|       | 特徴 ・・・・・・・ 1                                             |      |       | 8ビット タイマ/カウンタ0用レジスタ ・・・・・・・・・・・                           |    |
|-------|----------------------------------------------------------|------|-------|-----------------------------------------------------------|----|
| 1.    | <b>ピン配置 ・・・・・・・・</b> 2                                   | 12.  | タイマノ  | /カウンタの前置分周器・・・・・・・・・・・・・・・・                               | 50 |
| •••   | 1.1. L°ン説明 ····································          |      |       | 概要                                                        | 50 |
| 0     | 概要 ••••• 3                                               |      | 12.2. |                                                           | 50 |
| ۷.    |                                                          |      | 12.3. |                                                           | 50 |
|       | 2.1. 構成図                                                 |      |       | タイマ/カウンタ前置分周器制御用レジスタ・・・・・・・                               |    |
| 3.    | 一般情報 •••••• 4                                            | 12   |       | が比較器・・・・・・・・・・・・・・・・・・・・・・・・・・・・・・・・・・・・                  |    |
|       | 3.1. 資料 · · · · · · 4                                    | 13.  |       | 7 比较硫                                                     |    |
|       | <b>3.2</b> . ¬─ド例 ······ 4                               |      | 10.1. | 7747 丘牧奋人力选択 ************************************         | 52 |
|       | 3.3. データ保持力 ・・・・・・・・・・・・・ 4                              |      |       | アナログ比較器用レジスタ・・・・・・・・・・・・・・・・・・・・・・・・・・・・・・・・・・・・          |    |
| 4.    | <b>CPU 37</b> ····· 5                                    | 14.  | A/D   | 変換器 ・・・・・・・・・・・・・・・・・・・・・・・・                              | 54 |
|       | 4.1. 構造概要 ・・・・・・・・・・・ 5                                  |      | 14.1. | 特徴                                                        | 54 |
|       | <b>4.2.</b> ALU (Arithmetic Logic Unit) ••••• 5          |      | 14.2. | 概要 ・・・・・・・・・                                              | 54 |
|       | 4.3. ステータス レジスタ ・・・・・・・・・・・・・・・・・・・・・・・・・・・・・・・・・・・・     |      | 14.3. | 操作 · · · · · · · · · · · · · · · · · · ·                  |    |
|       | 4.4. 汎用レジスタファイル・・・・・・・・・・・・ 7                            |      | 14.4. | 変換の開始・・・・・・・・・・・・・・・・・・・・・・・・・・・・・・・・・・・・                 | 55 |
|       | <b>4.5.</b> スタック ホ°インタ · · · · · · · · · · · · · · · 7   |      | 14.5. |                                                           | 56 |
|       | 4.6. 命令実行タイミング・・・・・・・8                                   |      | 14.6. | チャネル変更と基準電圧選択 ・・・・・・・・・・・・・・                              | 57 |
|       | 4.7. リセットと割り込みの扱い・・・・・・・・・・8                             |      | 14.7. | 雜音低減機能 ••••••                                             | 58 |
| 5     | メモリ ・・・・・・・・・・・・・・・・・10                                  |      | 14.8. | アナログ入力回路・・・・・・・・・・・・・・・・・・・・・・・・・・・・・・・・・・・・              | 58 |
| ٥.    | 5.1. 実装書き換え可能なプログラム用フラッシュメモリ・・・10                        |      | 14.9. | アナログ雑音低減技術・・・・・・・・・・・・・・・・・・・・・・・・・・・・・・・・・・・・            | 58 |
|       | 5.2. データ用SRAMメモリ · · · · · · · · · · · · · · · · · · ·   |      | 14.10 | D. A/D変換の精度定義 · · · · · · · · · · · · · · · · · · ·       | 59 |
|       | 5.3. データ用EEPROMメモリ · · · · · · · · · · · · · · · · · · · |      | 14.11 | I. A/D変換の結果・・・・・・・・・・・・・・・・・・・・・・・・・・・・・・・・・・・・           | 59 |
|       | 5.4. I/Oメモリ (レジスタ) · · · · · · · · · · · · · · · · · · · |      | 14.12 | 2. A/D変換用レジスタ ······                                      | 60 |
|       | 5.5. メモリ関係レジスタ・・・・・・・・13                                 | 15.  | デバッ   | ック、WIRE内蔵デバッグ機能 ・・・・・・・・・                                 | 63 |
| ^     |                                                          |      | 15.1. | 特徴                                                        | 63 |
| 6.    | システム クロックとクロック選択 ・・・・・・・・ 15                             |      | 15.2. | 概要                                                        | 63 |
|       | 6.1. クロック系統とその配給・・・・・・・15                                |      | 15.3. | 物理インターフェース ・・・・・・・・・・・・・・・・・・・・・・・・・・・・・・・・・・・・           | 63 |
|       | 6.2. クロック元 ・・・・・・・・・15                                   |      | 15.4. | ソフトウェア中断点・・・・・・・・・・・・・・・・・・・・・・・・・・・・・・・・・・・・             | 63 |
|       | 6.3. システム クロック前置分周器 ・・・・・・・・ 17                          |      | 15.5. | デバッグWIREの制限・・・・・・・・・・・・・・・・・・・・・・・・・・・・・・・・・・・・           | 63 |
|       | 6.4. クロック関係レジスタ・・・・・・18                                  |      | 15.6. | デバッグWIRE用レジスタ ・・・・・・・・・・・・・・・・・・・・・・・・・・・・・・・・・・・・        | 63 |
| 7.    | 電力管理と休止形態 ・・・・・・・・・ 20                                   | 16   | フラッシ  | /ュの自己プログラミング・・・・・・・・・・・                                   | 64 |
|       | 7.1. 休止形態種別                                              |      | 16 1  | SPM命令によるページ消去の実行・・・・・・・・・・・・・・・・・・・・・・・・・・・・・・・・・・・・      | 64 |
|       | 7.2. 消費電力の最小化 ・・・・・・・・ 21                                |      |       | ページー時緩衝部の設定(ページ設定)・・・・・・・                                 |    |
|       | 7.3. 電力管理用レジスタ ・・・・・・・・・ 22                              |      |       | ページ書き込みの実行・・・・・・・・・・・・・・・・・・・・・・・・・・・・・・・・・・・・            |    |
| 8.    | <b>システム制御とリセット・・・・・・・・・・</b> 23                          |      |       | 自己プログラミングでのフラッシュアドレス指定・・・・・                               |    |
|       | 8.1. AVRのリセット · · · · · · 23                             |      |       | SPM書き込みへのEEPROM書き込み妨害・・・                                  |    |
|       | <b>8.2.</b> リセット元 ・・・・・・・・・・・・・・23                       |      |       | ファームウェアからのヒュース、と施錠の読み出し・・・                                |    |
|       | <b>8.3</b> . 内部基準電圧 · · · · · · · · · · · · · · · · 25   |      |       | フラッシュ メモリ データ化けの防止・・・・・・・・・・・・・・・・・・・・・・・・・・・・・・・・・・・・    |    |
|       | <b>8.4.</b> ウォッチト ック タイマ · · · · · · · · 25              |      |       | SPM時フラッシュ プログラミング 時間 ・・・・・・・・・・・・・・・・・・・・・・・・・・・・・・・・・・・  |    |
|       | 8.5. リセット関係レジスタ・・・・・・・・・・27                              |      |       | 自己プログラミング・用レジスタ・・・・・・・・・・・・・・・・・・・・・・・・・・・・・・・・・・・・       |    |
| 9.    | 割り込み ・・・・・・ 29                                           | 17   |       | プログラミング・・・・・・・・・・・・・・・・・・・・・・・・・・・・・・・・・・・                |    |
|       | 9.1. 割り込みベクタ ・・・・・・・・・・ 29                               | ١,,. | 171   | プログラム メモリとデータ メモリ用施錠ビット・・・・・・・                            | 68 |
|       | 9.2. 外部割り込み・・・・・・・・・・・・・30                               |      |       | ヒュース、ヒット・・・・・・・・・・・・・・・・・・・・・・・・・・・・・・・・・・・・              |    |
|       | 9.3. 割り込み用レジスタ・・・・・・・・・ 30                               |      | 17.2  | 校正バイト ・・・・・・・・・・・・・・・・・・・・・・・・・・・・・・・・・・・・                | 70 |
| 10.   | <b>入出力ポート ・・・・・・・・・・・・・・</b> 32                          |      | 17.4  | 識票/v*/ ······                                             | 70 |
|       | 10.1. 概要 ・・・・・・・・・・・ 32                                  |      |       | へ <sup>0</sup> ージ。容量 ・・・・・・・・・・・・・・・・・・・・・・・・・・・・・・・・・・・・ |    |
|       | 10.2. 標準デジタル入出力としてのポート・・・・・・・32                          |      | 17.6  | 低電圧直列プログラミング・・・・・・・・・・・・・・・・・・・・・・・・・・・・・・・・・・・           | 71 |
|       | 10.3. 交換ポート機能 ・・・・・・・・・・・35                              |      | 17.7  | 高電圧直列プログラミング・・・・・・・・・・・・・・・・・・・・・・・・・・・・・・・・・・・           | 73 |
|       | 10.4. I/Oポート用レジスタ ・・・・・・・・・・・37                          |      | 17.8. |                                                           | 75 |
| 11    | 8ビット タイマ/カウンタ0 (PWM) ・・・・・・・・・ 38                        | 12   |       | 的特性····                                                   |    |
| • • • | 11.1. 特徴 ···································             | 10.  |       | - 約付け、 - ・・・・・・・・・・・・・・・・・・・・・・・・・・・・・・・・・・・              |    |
|       | 11.2. 概要                                                 |      |       | <b>NATION AND ADD ADD ADD ADD ADD ADD ADD ADD AD</b>      |    |
|       | 11.3. タイマ/カウンタのクロック ・・・・・・・・・・・39                        |      |       | 速度勾配 ••••••                                               |    |
|       | 11.4. 計数器部 ······· 39                                    |      | 10.0. |                                                           | 79 |
|       | 11.5. 比較出力部 ・・・・・・・・・・・・・・・・・40                          |      |       | システムとリセットの特性 ・・・・・・・・・・・・・・・・・・・・・・・・・・・・・・・・・・・・         |    |
|       | 11.6. 比較一致出力部 ・・・・・・・・・・・・ 41                            |      |       | アナログ比較器特性・・・・・・・・・・・・・・・・・・・・・・・・・・・・・・・・・・・・             |    |
|       | 11.7. 動作種別 · · · · · · · · · 42                          |      |       | A/D変換器特性······                                            |    |
|       | 11.8. タイマ/カウンタのタイミング・・・・・・・・・・・45                        |      |       | 低電圧直列プログラミング特性・・・・・・・・・・・・・・・・・・・・・・・・・・・・・・・・・・・・        |    |
|       | 10                                                       |      | 10.0. | 120 昭江 巨がい 17 // / 1寸 江                                   | 50 |

# ATtiny13

|     |        | 高電圧直列プログラミング特性 ・・・・・・・・ 81                      |
|-----|--------|-------------------------------------------------|
| 19. | 代表特    | 寺性 ••••• 82                                     |
|     | 19.1.  | 活動動作消費電流 ・・・・・・・・・ 82<br>アイドル動作消費電流 ・・・・・・・・ 84 |
|     | 19.2.  |                                                 |
|     | 19.3.  | <b>パワーダウン動作消費電流 ・・・・・・・・・ 86</b>                |
|     | 19.4.  | ピン プルアップ・・・・・・・ 87                              |
|     | 19.5.  | <b>ピン駆動能力 ・・・・・・・・・ 88</b>                      |
|     | 19.6.  | ピン 閾値とヒステリシス・・・・・・・・ 94                         |
|     | 19.7.  | 低電圧検出器(BOD)閾値と 97 アナログ 比較器オフセット                 |
|     | 19.8.  | 内部発振器周波数 ******* 98                             |
|     | 19.9.  | 周辺機能部消費電流 ********** 101                        |
|     | 19.10. | リセット消費電流とリセット n°ルス幅 ・・・・・・・ 102                 |
| 20. | レジスタ   | <b>要約・・・・・・・・・・・・・・・・</b> 104                   |
| 21. | 命令     | 要約・・・・・・ 105                                    |
| 22. | 注文的    | 青報 ••••• 107                                    |
| 23. | 外囲     | <br>器情報 ・・・・・ 108                               |
| 24. | 障害性    | 青報・・・・・・・・・・・・・・・・・・ 110                        |
| 25. | データシ   | <b>/ト改訂履歴 ・・・・・・・・・・・</b> 111                   |





#### 本社

#### Atmel Corporation

2325 Orchard Parkway San Jose, CA 95131 USA

TEL 1(408) 441-0311 FAX 1(408) 487-2600

#### 国外営業拠点

#### Atmel Asia

Unit 1-5 & 16, 19/F BEA Tower, Millennium City 5 418 Kwun Tong Road Kwun Tong, Kowloon Hong Kong TEL (852) 2245-6100

FAX (852) 2722-1369

#### Atmel Europe

Le Krebs
8, Rue Jean-Pierre Timbaud
BP 309
78054 Saint-Quentin-enYvelines Cedex
France
TEL (33) 1-30-60-70-00
FAX (33) 1-30-60-71-11

#### Atmel Japan

141-0032 東京都品川区 大崎1-6-4 新大崎勧業ピル 16F アトメル ジャハン株式会社 TEL (+81)(3)-6417-0300 FAX (+81)(3)-6417-0370

#### 製品窓口

#### ウェブサイト

www.atmel.com

# 文献請求

www.atmel.com/literature

#### 技術支援

avr@atmel.com

#### 販売窓口

www.atmel.com/contacts

お断り: 本資料内の情報はAtmel製品と関連して提供されています。本資料またはAtmel製品の販売と関連して承諾される何れの知的所有権も禁反言あるいはその逆によって明示的または暗示的に承諾されるものではありません。Atmelのウェブサ小に位置する販売の条件とAtmelの定義での詳しい説明を除いて、商品性、特定目的に関する適合性、または適法性の暗黙保証に制限せず、Atmelはそれらを含むその製品に関連する暗示的、明示的または法令による如何なる保証も否認し、何ら責任がないと認識します。たとえるtmelがそのような損害賠償の可能性を進言されたとしても、本資料を使用できない、または使用以外で発生する(情報の損失、事業中断、または利益の損失に関する制限なしの損害賠償を含み)直接、間接、必然、偶然、特別、または付随して起こる如何なる損害賠償に対しても決してAtmelに責任がないでしょう。Atmelは本資料の内容の正確さまたは完全性に関して断言または保証を行わず、予告なしでいつでも製品内容と仕様の変更を行う権利を保留します。Atmelはここに含まれた情報を更新することに対してどんな公約も行いません。特に別の方法で提供されなければ、Atmel製品は車載応用に対して適当ではなく、使用されるべきではありません。Atmel製品は延命または生命維持を意図した応用での部品としての使用に対して意図、認定、または保証されません。

© Atmel Corporation 2010. 不許複製 Atmel®、ロゴとそれらの組み合わせ、AVR®とその他はAtmel Corporationの登録商標または商標またはその付属物です。他の用語と製品名は一般的に他の商標です。

#### © HERO 2022.

本データシートはAtmelのATtiny13英語版データシート(改訂2535J-08/10)の翻訳日本語版です。日本語では不自然となる重複する形容表現は省略されている場合があります。日本語では難解となる表現は大幅に意訳されている部分もあります。必要に応じて一部加筆されています。 頁割の変更により、原本より頁数が少なくなっています。

汎用入出力ポートの出力データレジスタとピン入力は、対応関係からの理解の容易さから出力レジスタと入力レジスタで統一表現されています。一部の用語がより適切と思われる名称に変更されています。必要と思われる部分には()内に英語表記や略称などを残す形で表記しています。

青字の部分はリンクとなっています。一般的に赤字の0,1は論理0,1を表します。その他の赤字は重要な部分を表します。 8章、17.7.節と17.8.節の構成を部分的に変更しています。