

# ATtiny25/V, ATtiny45/V, ATtiny85/V

# 2/4/8Kバイト実装書き込み可能フラッシュ メモリ付き Atmel 8ビット AVR マイクロ コントローラ

データシート

# 特徴

- 高性能、低消費AVR® 8ビット マイクロ コントローラ
- 進化したRISC構造
  - 強力な123命令(多くは1周期実行)
  - 32個の1バイト長汎用レジスタ
  - 完全なスタティック動作
  - 20MHz時、20MIPSに達する高速動作
- 不揮発性プログラム用メモリとデータ用メモリ
  - 実装自己書き換え可能な2/4/8Kバイト(1/2/4K語)フラッシュメモリ内蔵
    - 10,000回の書き換え耐久性
  - 128/256/512パイトのEEPROM
  - 100,000回の書き換え耐久性
  - 128/256/512バイトの内蔵SRAM
  - リフトウェア保護用の設定可能な施錠機能
- 内蔵周辺機能
  - 前置分周器と2つのPWM出力付き8ビット タイマ/カウンタ
  - 独立した前置分周器付き高速8ビット タイマ/カウンタ
    - 独立した比較レジスタでの2つの高周波数PWM出力
    - 設定可能な沈黙時間生成器
  - 開始条件検出器付き多用途直列インターフェース(USI)
  - 10ビット A/D変換器
    - 4つのシングル エント チャネル
    - ・設定可能な利得(×1,×20)付き2つの差動ADCチャネル
    - 温度測定
  - 設定可能な専用発振器付きウォッチドッグ、タイマ
  - ●アナログ比較器
- 特殊マイクロ コントローラ機能
  - デバッグWIRE内蔵デバッグ機能
  - SPIポート経由の実装書き込み
  - ●外部及び内部の割り込み
  - ●アイドル、A/D変換雑音低減、パワーダウンの3つの低消費動作
  - 強化した電源ONJセット回路
  - 設定可能な低電圧検出器(BOD)回路
  - 校正付き内蔵RC発振器
- I/Oと外囲器
  - 6ビットの設定変更可能なI/O
  - 8ピンPDIP、8リードSOIC、20ハット、QFN/MLF、8リート、TSSOP (ATtiny45/Vのみ)
- 動作速度
  - ATtiny25/45/85V:  $0\sim4$ MHz/1.8 $\sim5.5$ V,  $0\sim10$ MHz/2.7 $\sim5.5$ V
  - ATtiny25/45/85 :  $0\sim10\text{MHz}/2.7\sim5.5\text{V}$ ,  $0\sim20\text{MHz}/4.5\sim5.5\text{V}$
- 工業用温度範囲
- 低消費電力
  - 300µA (1MHz,1.8V,活動動作)
  - 0.1µA (1.8V,パワータ・ウン動作)
- 動作電圧
  - 1.8~5.5V (ATtiny25/45/85V)
  - 2.7~5.5V (ATtiny25/45/85)

本書は一般の方々の便宜のため有志により作成されたもので、Atmel社とは無関係であることを御承知ください。しおりの[はじめに]での内容にご注意ください。

# 1. ピン配置



# 1.1. ピン概要

1.1.1. VCC 電源ピン。 1.1.2. GND 接地ピン。

1.1.3. PB5~PB0 ポートBは(ビット単位で選択される)内蔵プルアップ抵抗付きの6ビット双方向入出力ポートです。ポートB出力緩衝部は共 (ポートB) に高い吐き出し/吸い込み能力の対称駆動特性です。入力のとき、プルアップ抵抗が有効の場合、外部的にLow

に高い吐き出し/吸い込み能力の対称駆動特性です。入力のとき、プルアップ抵抗が有効の場合、外部的にLowへ引き込まれたポートBピンには吐き出し電流が流れます。リセット条件が有効になると、クロックが走行していなくても、

ポートBピンはHi-Zにされます。

ポートBは39頁の「ホートBの交換機能」で示されるATtiny25/45/85の様々な特殊機能も扱います。

ATtiny25デッイスのPB3とPB4入出力ポート(2ピンと3ピン)は、ATtiny15との下位互換性を支援するATtiny15互換動

作で交換されます。

1.1.4. RESET リセット入力。RESETピンが禁止されていなければ、例えクロックが走行していなくても、最小パルス幅より長いこのピンの Lowレヘ・ルはリセットを生成します。最小パルス幅は110頁の表21-4.で与えられます。より短いパルスはリセットの生成が

保証されません。

RESETt°ンは((駆動能力の)弱い)入出力ピンとしても使えます。



# 2. 概要

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

# 2.1. 構成図



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

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

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



# 3. 諸注意

# 3.1. 資料

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

# 3.2. コート 例

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

拡張I/O領域に配置したI/Oレジスタに対し、IN,OUT,SBIS,SBIC,CBI,SBI命令は拡張I/O領域へのアクセスを許す命令に置き換えられなければなりません。これは代表的にSBRS,SBRC,SBR,CBR命令と組み合わせたLDS,STS命令を意味します。全てのAVRデバイスが拡張I/O領域を含むとは限らないことに注意してください。(訳補: 本デバイスに拡張I/O領域はありません。)

# 3.3. 容量性接触感知

Atmel QTouchライブラリはAtmel AVRマイクロコントローラ上の接触感知インターフェースのための使い易い解決策を提供します。QTouchライブラリはQTouch®とQMatrix®採取法用の支援を含みます。

接触感知は接触チャネルと感知器を定義することで応用プログラミング インターフェース(API)を用いてQTouchライブラリをリンクすることによってどの応用にも容易に追加されます。そして応用はチャネル情報を取得して接触感知器の状態を決めるためにAPIを呼び出します。

QTouchライブラリは無料でAtmelのウェブサイトからダウンロードすることができます。より多くの情報と実装の詳細についてはAtmelのウェブサイトからも入手可能なQTouchライブラリ使用者の手引きを参照してください。

# 3.4. データ保持力

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

# 追補. ATtiny15互換動作について(訳注:本項は便宜のため追加)

本デバイスはATtiny15互換で動作できます。この動作への設定は次のとおりです。

CKSELヒュース =0011:18頁の「校正付き内蔵RC発振器」参照

この互換動作では基本的に高速周辺クロックを含むタイマ/カウンタ1関係がATtiny15互換で動作します。本動作ではATtiny15での比較B レジスタ(OCR1B)が本デバイスの比較Cレジスタ(OCR1C)に割り当てられていることに注意してください。但し、ATtiny15のOCR1Bと本デバイスのOCR1CのI/Oアドレスは一致しています。関連記述は以下を参照してください。

- ホート ピン交換:2頁の「ピン概要」の「ホートB」参照
- 高速周辺クロック(PCK): 16頁の「ATtiny15互換動作での内蔵PLL」参照
- タイマ/カウンタ1動作:64頁からの「ATtiny15互換動作でのタイマ/カウンタ1」参照



# 4. AVR CPU コア

# 4.1. 序説

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

# 4.2. 構造概要

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

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

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

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

プログラムの流れは条件/無条件分岐や呼び出し命令によって提供され、全アトンス空間を直接アトンス指定できます。AVR命令の多くは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.3**. **ALU** (Arithmetic Logic Unit)

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



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

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

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

## **4.4.1. SREG - ステータス レシ スタ** (Status Register)

AVRのステータスレジ、スタ(SREG)は次のように定義されます。

| ピット         | 7   | 6   | 5   | 4   | 3   | 2   | 1   | 0   | _    |
|-------------|-----|-----|-----|-----|-----|-----|-----|-----|------|
| \$3F (\$5F) | I   | Т   | Н   | 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)もできます。

#### ● ビット6 - T: ビット変数 (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)を示します。詳細情報については「命令要約」記述をご覧ください。

# ・ ビット1 - Z: ゼロ フラク (Zero Flag)

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

# ● L"ット0 – C: キャリー フラク (Carry Flag)

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



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

このレシブスタファイルは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.5.1. Xレシ、スタ、Yレシ、スタ、Zレシ、スタ

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

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

| 図4-3. X,Y,Z          | レジス     | <b>対構成図</b> |     |            |    |
|----------------------|---------|-------------|-----|------------|----|
|                      | 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  |
|                      | 15<br>7 | ZH (上位)     | 0 7 | ZL (下位)    | 0  |

# **4.6**. スタック ポインタ

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

スタック ポインタはサブルーチンや割り込みのスタックが配置されるデータSRAMのスタック領域を指し示します。データSRAM内のスタック空間はサブルーチン呼び出しの実行や割り込みの許可の何れにも先立って、プログラムによって定義されなければなりません。スタック ポインタは \$0060 以上を指示するように設定されなければなりません(なるべくなら定義名 RAMEND)。スタック ポインタはPUSH命令でデータがスタックに格納されると-1され、サブルーチン呼び出しや割り込みで戻りアトレスがスタックに格納されると-2されます。スタック ポインタはPOP命令でデータがスタックから引き出されると+1され、サブルーチンからの復帰(RET)命令や割り込みからの復帰(RETI)命令でアトレスがスタックから引き出されると+2されます。

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

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



(訳補) 内蔵SRAMはATtiny25が128バイト(\$0060~\$00DF)、ATtiny45が256バイト(\$0060~\$015F)、ATtiny85が512バイト(\$0060~\$025F)です。従って、ATtiny45ではSPHのSP9が、ATtiny25ではSP9,8が利用できません。RAMENDはATtiny25が\$00DF (0000 0000 1101 1111)、ATtiny45が\$015F(0000 0001 0101 1111)、ATtiny45が\$025F(0000 0010 0101 1111)になります。



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

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

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

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





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

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

プログラム メモリ空間の最下位アドレスは既定によってリセットと割り込みベクタとして定義されます。 ベクタの完全な一覧は32頁の「**割り込み**」で示されます。この一覧は各種割り込みの優先順位も決めます。下位側アドレスがより高い優先順位です。 リセットが最高優先順位で、次が外部割り込み要求の(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
                 R16, SREG
                                                   ;EEPROM書き込み手順中割り込み禁止
           CLI
                 EECR, EEMPE
                                                   ;EEPROM主書き込み許可
           SBI
                 EECR, EEPE
                                                   ;EEPROM書き込み開始
           SBI
           OUT
                 SREG, R16
                                                   ;ステータスレジスタを復帰
C言語プログラム例
                                                  /* ステータス レシ スタ保存変数定義 */
           char cSREG;
                                                   /* ステータス レジ スタを保存 */
           cSREG = SREG;
           _CLI() ;
                                                   /* EEPROM書き込み手順中割り込み禁止 */
           EECR = (1 < EEMPE);
                                                  /* EEPROM主書き込み許可*/
                                                  /* EEPROM書き込み開始 */
           EECR = (1 << EEPE);
                                                  /* ステータス レジ スタを復帰 */
           SREG = cSREG:
```

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

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

注: SLEEP命令までは割り込み禁止、保留割り込み実行前に休止形態へ移行します。

# 4.8.1. 割り込み応答時間

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

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



# 5. AVR メモリ

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

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

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

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

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

# 図5-1. プログラム メモリ配置図 プログラム用 フラッシュ メモリ 1/2/4K×16 \$03FF/\$07FF/\$0FFF

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

**図5-2**.はATtiny25/45/85のSRAMメモリ構成方法を示します。

下位224/352/608データメモリ位置はレシ、スタファイル、I/Oメモリ、データ用内蔵SRAMに充てます。先頭の32位置はレシ、スタファイル、次の64位置は標準I/Oメモリ、そして最後の128/256/512位置はデータ用内蔵SRAMに充てます。

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

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

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

図5-2. データ メモリ配置図 アドレス R0 \$0000 レシブスタ ファイル  $(32\times8)$ \$001F R31 \$00 \$0020 I/Oレシ スタ  $(64 \times 8)$ \$3F \$005F \$0060 \$0060 内蔵SRAM  $(128/256/512 \times 8)$ \$00DF/\$015F/\$025F \$0xxF **注**:赤字はI/Oアドレス

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

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

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

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

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



# 5.3. データ用EEPROMメモリ

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

# 5.3.1. EEPROMアクセス

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

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

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

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

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

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

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

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

## 5.3.4. 消去

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

## 5.3.5. 書き込み

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

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



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

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

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

```
アセンブリ言語プログラム例
                                                  ;EEPROMプログラミング完了ならばスキップ
EEPROM RD: SBIC
                 EECR, EEPE
                                                  ;以前のEEPROMプログラミング完了まで待機
           R.JMP
                 EEPROM RD
                                                  ;EEPROMアドレス上位バイト設定
           OUT
                 EEARH, R18
                                                  ;EEPROMアドレス下位バイト設定
           OUT
                 EEARL, R17
                                                  ;EEPROM読み出し開始(読み込み許可ビット設定)
           SBI
                 EECR, EERE
                                                  ;EEPROM読み出し値を取得
                 R16, EEDR
           ΤN
                                                  ;呼び出し元へ復帰
           RET
C言語プログラム例
unsigned char EEPROM read(unsigned int uiAddress)
                                                  /* 以前のEEPROMプログラミング完了まで待機 */
   while (EECR & (1<<EPE));
                                                  /* EEPROMアドレス設定*/
   EEAR = uiAddress;
   EECR = (1 << 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 メモリ (レシ スタ)

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

ATtiny25/45/85の全ての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が加算されなければなりません。

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

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

# **5.4.1. 汎用I/Oレジスタ**(訳注:共通性から本項追加)

ATtiny25/45/85は3つの汎用I/Oレシ、スタを含みます。これらのレシ、スタはどの情報の格納にも使えき、特に全体変数や状態フラケの格納に有用です。(I/O)アトレス範囲\$00~\$1Fの汎用I/Oレシ、スタはSBI,CBI,SBIS,SBIC命令の使用で直接ビットアクセスが可能です。

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

# 5.5.1. EEARH, EEARL (EEAR) - EEPROMアトレス レジスタ (EEPROM Address Register)

| ピット         | 15      | 14    | 13    | 12    | 11    | 10    | 9     | 8       |       |
|-------------|---------|-------|-------|-------|-------|-------|-------|---------|-------|
| \$1F (\$3F) | _       | -     | -     | -     | -     | -     | -     | (EEAR8) | EEARH |
| Read/Write  | R       | R     | R     | R     | R     | R     | R     | R/W     |       |
| 初期値         | 0       | 0     | 0     | 0     | 0     | 0     | 0     | 不定      |       |
| ピット         | 7       | 6     | 5     | 4     | 3     | 2     | 1     | 0       |       |
| \$1E (\$3E) | (EEAR7) | EEAR6 | EEAR5 | EEAR4 | EEAR3 | EEAR2 | EEAR1 | EEAR0   | EEARL |
| Read/Write  | R/W     | R/W   | R/W   | R/W   | R/W   | R/W   | R/W   | R/W     |       |
| 初期値         | 不定      | 不定    | 不定    | 不定    | 不定    | 不定    | 不定    | 不定      |       |

## ヒット15~9 - Res: 予約 (Reserved)

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

## L\*ット8~0 - EEAR8~0: EEPROMアトレス (EEPROM Address)

EEAR8はATtiny85、EEAR7はATtiny45、EEAR6はATtiny25でのEEPROMの各々最上位アドレス ビットです。より小さなEEPROMを持つ デバイスでのこれらのビットは予約され、常に0を読みます。

EEAR5~0はEEPROMアドレス レジスタの下位側ビットです。EEPROMデータ バイトは0~127/255/511の範囲に直線的に配置されます。 EEARの初期値は不定で、従ってEEPROMが入出力される前に正しい値が書かれなければなりません。

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

| ピット         | 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   |      |
| 初期値         | 0     | 0   | 0   | 0   | 0   | 0   | 0   | 0     |      |

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

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

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

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

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

みも無視されます。 リセット中、EEPMnビットは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)

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

EEMPEが設定(1)されると、47ロック周期内のEEPE設定(1)は選択したアドレスのEEPROMをプログラムします。EEMPEが0なら、EEPE設定(1)は無効です。EEMPEがソフトウェアによって設定(1)されてしまうと、47ロック周期後にハードウェアがこのビットを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への読み込みストローブです。EEARに正しいアトレスが設定されると、EEPROM読み出しを起動するためにEEREビットは1を書かれなければなりません。EEPROM読み出しアクセスは(その)1命令で行われ、要求したデータは直ちに利用できます。EEPROMが読まれるとき、次の命令が実行される前にCPUは4周期停止されます。使用者は読み込み操作を始める前にEEPEビットをポーリングすべきです。書き込み(プログラム)操作実行中の場合、EEPROMアトレスレジスタ(EEAR)の変更もEEPROM読み込みもできません。

# 5.5.4. GPIOR2 - 汎用I/Oレジスタ2 (General Purpose I/O Register 2)

| ピット         | 7     | 6   | 5   | 4   | 3   | 2   | 1   | 0     |        |
|-------------|-------|-----|-----|-----|-----|-----|-----|-------|--------|
| \$13 (\$33) | (MSB) |     |     |     |     |     |     | (LSB) | GPIOR2 |
| 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     |        |

# 5.5.5. GPIOR1 - 汎用I/Oレジスタ1 (General Purpose I/O Register 1)

| ピット         | 7     | 6   | 5   | 4   | 3   | 2   | 1   | 0     |        |
|-------------|-------|-----|-----|-----|-----|-----|-----|-------|--------|
| \$12 (\$32) | (MSB) |     |     |     |     |     |     | (LSB) | GPIOR1 |
| 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     |        |

# 5.5.6. GPIORO - 汎用I/OレジスタO (General Purpose I/O Register 0)

| ピット         | 7     | 6   | 5   | 4   | 3   | 2   | 1   | 0     |        |
|-------------|-------|-----|-----|-----|-----|-----|-----|-------|--------|
| \$11 (\$31) | (MSB) |     |     |     |     |     |     | (LSB) | GPIOR0 |
| 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     |        |

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

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

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



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

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

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

**6.1.3**. **7קיילים לחיילי** clk<sub>FLASH</sub>

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

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

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

6.1.5. 高速周辺クロック clk<sub>PCK</sub>

ATtiny25/45/85の内部PLLは供給元入力から8倍したクロック周波数を発生します。既定でのPLLは供給元として8.0Hz内蔵RC発振器の出力を使います。PLL制御/状態レジスタ(PLLCSR)の低速動作(LSM)ビットが設定(1)される場合、PLLは代わりにこのRC発振器の2分周出力を使います。故に(基本の)PLL出力、高速周辺クロックは64MHzです。高速周辺クロックまたはそれから分周したクロックは、タイマ/カウンタ1に対するクロック元またはシステムクロックとして選択できます。図6-2.をご覧ください。高速周辺クロックの周波数はPLLCSRのLSM設定(1)時に2分周され、32MHzのクロック周波数になります。PLLclkがシステムクロックとして使われる場合、LSMが設定(1)できないことに注意してください。



PLLはRC発振器に固定化し、発振校正レジスタ(OSCCAL)経由のRC発振器調整は同時に高速周辺クロックも調整します。けれどもRC発振器が8MHzより高い周波数にされるのが可能でも、高速周辺クロックは(最悪の場合)85MHzで飽和し、最高周波数での発振に留まります。この場合のPLLがRC発振器クロックのどれにも固定化されないことに注意されるべきです。従ってPLLを正しい動作範囲に保持するため、8MHzより高い周波数にOSCCAL補正を行うことは推奨されません。

内部PLLは以下の時に許可されます。

- PLL制御/状態レシ、スタ(PLLCSR)のPLL許可(PLLE)ビットが設定(1)される。
- CKSELヒューズが'0001'に設定される。
- CKSELヒュース'が'0011'に設定される。

PLLCSRのPLL固定化検出(PLOCK)ビットはPLLが固定化されている時に設定(1)されます。 内蔵RC発振器とPLLはパワーダウンの休止形態でOFFへ切り替えられます。

# 6.1.6. ATtiny15互換動作での内蔵PLL

ATtiny25/45/85デ゙バイスはATtiny15使用者用の移植のために、ATtiny15との下位互換用のATtiny15互換動作があります。ATtiny15 互換動作はCKSELヒューズを'0011'に設定することによって選択されます。

ATtiny15互換動作での内蔵RC発振器周波数は6.4MHzに低下校正され、PLLの倍率は4倍に設定されます。図6-3.をご覧ください。 これらの補正でクロック系はATtiny15互換になり、高速周辺クロックの結果は(ATtiny15と同じ)25.6MHzの周波数になります。



ATtiny15互換動作で低速動作が実装されないことに注意してください。

# 6.2. クロック元

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

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

表6-2. WDT発振器の代表計時終了値、周期数

|          | - 11-11-11-11-1 |
|----------|-----------------|
| 代表的計時終了值 | 周期数             |
| 4.0ms    | 512             |
| 64ms     | 8K (8192)       |

| 20 1.7477性加达IX    |                    |
|-------------------|--------------------|
| クロック種別            | CKSEL3~0           |
| 外部クリスタル/セラミック発振子  | 1111~1000          |
| 外部低周波数クリスタル発振子    | 0110               |
| 128kHz内部(WDT)発振器  | 0100               |
| 6.4MHz校正付き内蔵RC発振器 | 0011 ( <b>注2</b> ) |
| 8.0MHz校正付き内蔵RC発振器 | 0010 (注3)          |
| PLLクロック           | 0001               |
| 外部クロック信号          | 0000               |
| (予約)              | 01x1               |

注1: 1=非プログラム、0=プログラム、x=0または1。

注2: 本設定はATtiny15互換動作を選択し、システ ムクロックは4分周され1.6MHzクロック周波数に なります。

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

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

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

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



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

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

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

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

# **6.2.2**. 高周波数PLLクロック - PLL<sub>CLK</sub>

これはタイマ/カウンタ1周辺機能の使用とシステム クロック元用の、RC発振器に固定化した公称64 MHzクロック速度を供給する内部PLLです。CKSELヒューズの'0001'プログラム(設定)によってシステム クロック元として選択されると、これは表6-4.で示されるように4分周されます。

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

| 表6-4. 高周波数PLLクロック動作種別 |       |  |
|-----------------------|-------|--|
| CKSEL3~0              | 公称周波数 |  |
| 0001                  | 16MHz |  |

表6-5. 高周波数PLLクロック用起動遅延時間選択表

| SUT1,0 | パワーダウンからの<br>起動遅延時間 | 電源ONリセットからの付加<br>遅延時間 (VCC=5.0V) |                  |
|--------|---------------------|----------------------------------|------------------|
| 0 0    | (1K+14)×CK+4ms      | 4ms                              | 低電圧検出(BOD)リセット許可 |
| 0 1    | (16K+14)×CK+4ms     | 4ms                              | 高速上昇電源           |
| 1 0    | (1K+14)×CK+64ms     | 4ms                              | 低速上昇電源           |
| 1 1    | (16K+14)×CK+64ms    | 4ms                              | 低速上昇電源           |

## 6.2.3. 校正付き内蔵RC発振器

既定で校正された内蔵RC発振器は概ね8MHzクロックを供給します。電圧と温度に依存しますが、このクロックは使用者によって高精度な校正ができます。より多くの詳細については109頁の表21-2.と127頁の「内部発振器周波数」をご覧ください。本デバイスはCKDIV8ヒュースがプログラム(0)で出荷されます。より多くの詳細については20頁の「システムクロック前置分周器」をご覧ください。

このクロックは表6-6.で示されるようにCKSELヒューズのプログラミングによってシステム クロックとして選択できます。選択したなら、外部部品なしで動作します。リセット中、ハードウェアが発振校正(OSCCAL)レジスタに予めプログラムされた校正値バイトを設定し、これによってRC発振器を自動的に校正します。この校正の精度は表21-2.で工場校正として示されます。

| <b>丰</b> 6-6 | 校正付き内  | おいの様は | <b>堤架制作</b>   |
|--------------|--------|-------|---------------|
| オマローロ.       | かいけいけつ | リルスしき | : 17夜 名字 里儿十月 |

| CKSEL3~0 | 公称周波数(MHz)        |
|----------|-------------------|
| 0 0 1 0  | 8.0 (注1)          |
| 0 0 1 1  | 6.4 ( <b>注2</b> ) |

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

**注2**: 本設定はATtiny15互換動作を選択し、システム クロックは4分周され1.6M Hzクロック周波数になります。

ソフトウェアからOSCCALレシ、スタを変更することによって(発振校正レシ、スタ(OSCCAL)参照)、工場校正を使うよりも高い精度を得ることができます。この校正の精度は表21-2.で使用者校正として示されます。

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

校正付き内蔵RC発振器は表6-6.で示されるようにCKSELtュースに'0011'を書くことによって6.4MHzを供給する設定にもできます。この設定はATtiny15互換動作として参照され、ATtiny15でのように6.4MHzで校正されたクロック元の供給を意図されています。ATtiny15互換動作で、PLLはタイマ/カウンタ1用の25.6MHz周辺クロック信号を生成するのに6.4MHzで走行する内蔵RC発振器を使います(64頁の「ATtiny15互換動作での8ビット タイマ/カウンタ1」をご覧ください)。この動作では常に6.4MHzクロック信号が4分周され、1.6MHzシステムクロックを供給することに注意してください。

クロック元として校正付き内蔵8MHz発振器が選択されると、起動時間は下の表6-7.で示されるようにSUTヒュース、によって決定されます。

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

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

注1: RSTDISBLヒューズがプログラム(0)されると、プログラミング動作への移行可を保証するため、付加遅延時間は14×CK+4.1msに増やされます。

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

ATtiny15互換動作での起動時間は表6-8.で示されるようにSUTヒュース、によって決定されます。

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

| SUT1,0 | パワーダウンからの<br>起動遅延時間 | リセットからの付加遅延<br>時間 (VCC=5.0V) | 推奨使用法 |
|--------|---------------------|------------------------------|-------|
| 0 0    | 6×CK                | 14×CK+64ms                   |       |
| 0 1    | 6×CK                | 14×CK+64ms                   |       |
| 1 0    | 6×CK                | 14×CK+4ms                    |       |
| 1 1    | 1×CK                | 14×CK ( <b>注1</b> )          |       |

注1: RSTDISBLヒューズがプログラム(0)されると、プログラミング動作への移行可を保証するため、付加遅延時間は14×CK+4.1msに増やされます。

概略で、ATtiny15互換動作でのより多くの情報は2頁の「 $\hbar$ °- $\hbar$ B (PB5~0)」、16頁の「ATtiny15互換動作での内蔵PLL」、92頁の「 $\bar{\tau}$ "  $\hbar$ "  $\hbar$ "  $\hbar$ "  $\hbar$ "  $\hbar$ 0 (PB5~0)」、16頁の「ATtiny15互換動作での内蔵PLL」、92頁の「 $\bar{\tau}$ "  $\bar{\tau}$ 0 (PB5~0)」、16頁の「ATtiny15互換動作での内蔵PLL」、92頁の「 $\bar{\tau}$ 0 (PB5~0)」、16頁の「ATtiny15互換動作での内蔵PLL」、16頁の「ATtiny15互換動作での内蔵PLL」、16頁の「ATtiny15互換動作での内蔵PLL」、16頁の「ATtiny15互換動作での内蔵PLL」、16頁の「ATtiny15互換動作での内蔵PLL」、16頁の「ATtiny15互換動作での内蔵PLL」、16頁の「ATtiny15互換動作での内蔵PLL」、16頁の「ATtiny15互換動作での内蔵PLL」、16頁の「ATtiny15互換動作での内蔵PLL」、16頁の「ATtiny15互換動作での内蔵PLL」、16頁の「ATtiny15互換動作での内蔵PLL」、16頁の「ATtiny15互換動作での内蔵PLL」、16頁の「ATtiny15互換動作での内蔵PLL」、16頁の「ATtiny15互換動作での内蔵PLL」、16頁の「ATtiny15互換動作での内蔵PLL」、16頁の「ATtiny15互換動作での内蔵PLL」、16頁の「ATtiny15互換動作での内蔵PLL」、16頁の「ATtiny15互換動作での内蔵PLL」、16頁の「ATtiny15互換動作での内蔵PLL」、16頁の「ATtiny15互換動作での内蔵PLL」、16頁の「ATtiny15互換動作での内蔵PLL」、16頁の「ATtiny15互換動作での内蔵PLL」、16頁の「ATtiny15互換動作での内蔵PLL」、16頁の「ATtiny15互換動作での内域PLL」、16頁の「ATtiny15互換動作での内域PLL」、16頁の「ATtiny15互換動作での内域PLL」、16頁の「ATtiny15互換動作での内域PLL」、16頁の「ATtiny15互



## 6.2.4. 128kHz内部発振器

128kHz内部発振器は128kHzのクロックを供給する低電力発振器です。この周波数は3V,25℃での公称値です。本クロックはCKSELヒューズを'0100'にプログラミング(設定)することによってシステム クロックとして選択できます。

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

表6-9. 128kHz内部発振器用起動遅延時間選択表

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

注1: RSTDISBLヒューズがプログラム(0)されると、プログラミング動作への移行可を保証するため、付加遅延時間は14×CK+4.1msに増 やされます。

# 6.2.5. 低周波数クリスタル用発振器

デバイスに対するクロック元として時計用32.768kHzクリスタルを使うには、CKSEL3~0ヒューズの'0110'設定によって低周波数クリスタル発振器が選択されなければなりません。クリスタルは図6-5.で示されるように接続されるべきです。32.768kHzクリスタル用の適当な負荷容量を探すには製造業者のデータシートを調べてください。

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

表6-10. 低周波数クリスタル用発振器起動遅延時間選択表

| SUT1,0 | パワーダウンからの<br>起動遅延時間 | リセットからの付加遅延<br>時間 (VCC=5.0V) | 推奨使用法                     |
|--------|---------------------|------------------------------|---------------------------|
| 0 0    | 1K×CK ( <b>注1</b> ) | 4ms                          | 高速上昇電源または低電圧検出(BOD)リセット許可 |
| 0 1    | 1K×CK ( <b>注1</b> ) | 64ms                         | 低速上昇電源                    |
| 1 0    | 32K×CK              | 64ms                         | 起動時の周波数安定                 |
| 11     | (予約)                |                              |                           |

注1: これらの選択は起動での周波数安定性が重要でない場合だけ使われるべきです。

低周波数クリスタル用発振器は各XTALピンに於いて表6-11.で見られる内部負荷容量を提供します。

表6-11. 低周波数クリスタル用発振器内部容量

| 32kHz発振器形式      | <b>容量</b> (pF) |       |  |
|-----------------|----------------|-------|--|
| 32KFI2光1KA61/5式 | XTAL1          | XTAL2 |  |
| システム クロック用発振器   | 16             | 6     |  |

# 6.2.6. クリスタル/セラミック用発振器

XTAL1とXTAL2は図6-5.で示されるように、チップ上の発振器としての使用に設定できる反転増幅器の各々、入力と出力です。クリスタル発振子またはセラミック振動子のどちらでも使えます。

C1とC2はクリスタル発振子とセラミック振動子の両方について常に等しくすべきです。このコンデンサの最適値は使うクリスタル発振子やセラミック振動子、浮遊容量の量、その環境の電磁雑音に依存します。クリスタル発振子使用に対するコンデンサ選択について初期の指針のいくつかは表6-12.で与えられます。セラミック振動子については製造業者によって与えられたコンデンサ値が使われるべきです。

図6-5. クリスタル発振子接続図



表6-12. クリスタル発振器動作

| CKSEL3~1 | 周波数範囲      | 推奨C1,2容量 |
|----------|------------|----------|
| 100 (注1) | 0.4~0.9MHz | -        |
| 101      | 0.9∼3.0MHz | 12∼22pF  |
| 110      | 3.0∼8.0MHz | 12∼22pF  |
| 111      | 8.0∼ MHz   | 12∼22pF  |

**注1**: この選択はクリスタル発振子ではなく、セラミック振動子でだけ使われるべきです。

発振器は示された周波数範囲で最適化された4つの異なる動作ができます。この動作は、表6-12.で示されたCKSEL3~1ヒューズによって選択されます。

CKSEL0ヒュースiはSUT1,0ヒュースiと共に、表6-13.で示される起動遅延時間を選択します。



表6-13. クリスタル発振子/セラミック振動子用起動遅延時間選択表

| CKSEL0 | SUT1,0 | パワーダウンからの<br>起動遅延時間  | リセットからの付加遅延<br>時間 (VCC=5.0V) | 推奨使用法                       |
|--------|--------|----------------------|------------------------------|-----------------------------|
|        | 0 0    | 258×CK ( <b>注1</b> ) | 14×CK+4ms                    | 外部セラミック振動子、高速上昇電源           |
| 0      | 0 1    | 258×CK ( <b>注1</b> ) | $14 \times \text{CK+64ms}$   | 外部セラミック振動子、低速上昇電源           |
| U      | 1 0    | 1K×CK ( <b>注2</b> )  | 14×CK                        | 外部セラミック振動子、低電圧検出(BOD)リセット許可 |
|        | 1 1    | 1K×CK ( <b>注2</b> )  | 14×CK+4ms                    | 外部セラミック振動子、高速上昇電源           |
|        | 0 0    | 1K×CK ( <b>注2</b> )  | $14 \times \text{CK+64ms}$   | 外部セラミック振動子、低速上昇電源           |
| 1      | 0 1    | 16K×CK               | 14×CK                        | 外部クリスタル発振子、低電圧検出(BOD)リセット許可 |
| 1      | 1 0    | 16K×CK               | 14×CK+4ms                    | 外部クリスタル発振子、高速上昇電源           |
|        | 1 1    | 16K×CK               | 14×CK+64ms                   | 外部クリスタル発振子、低速上昇電源           |

**注1**: これらの選択はデバイスの最高周波数付近での動作でないとき、応用にとって起動での周波数安定性が重要でない場合だけ使われるべきです。これらの選択はクリスタル発振子用ではありません。

**注2**: これらの選択はセラミック振動子での使用を意図され、起動での周波数安定性を保証します。デバイスの最高周波数付近での動作でないとき、応用にとって起動での周波数安定性が重要でない場合はクリスタル発振子も使えます。

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

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

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

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

# 6.3.1. 切り替え時間

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

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

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

# 6.4. クロック出力緩衝部(外部クロック出力)

本デバイスは(XTAL2ピンとして使わない時に)システム クロックをCLKOピンに出力できます。この出力を許可するにはCKOUTヒューズがプログラム(0)されなければなりません。この動作はチップのクロックがシステム上の他の回路を駆動する時用です。このヒューズがプログラム(0)された時にI/Oピンの標準動作が無視され、このクロックがリセット中に出力されないことに注意してください。内部RC発振器、WDT発振器、PLL、外部クロック(CLKI)はクロックがCLKOに出力される時に選択することができます。クリスタル用発振器(XTAL1,XTAL2)はCLKOでのクロック出力用に使えません。システム クロック前置分周器が使われると、CKOUTヒューズがプログラム(0)された時の出力は分周したシステム クロックです。



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

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

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

## ● ビット7~0 - CAL7~0:発振校正値 (Oscillator Calibration Value)

発振校正レジスタは発振器周波数の偏差処理を省くための内蔵発振器の調整に使われます。チップのリセット中、109頁の表21-2.で指定されるように工場で校正された周波数を与える、予めプログラムされた値が本レジスタへ自動的に書かれます。応用ソフトウェアは発振器周波数を変更するために、このレジスタに書くことができます。この発振器は表21-2.で指定される周波数に校正できます。この範囲外への校正は推奨されません。

この発振器はフラッシュ メモリとEEPROMの書き込みアクセス時間に使われ、これらの書き込み時間はそれに応じて影響されることに注意してください。 フラッシュ メモリまたはEEPROMが書かれる場合、8.8MHzより高く校正してはいけません。 そうでなければ、フラッシュ メモリまたはEEPROM書き込みは失敗するかもしれません。

CAL7t'ットは発振器に関する操作範囲を決めます。このt'ットの(0)設定は低周波数範囲になり、(1)設定は高周波数範囲になります。この2つの周波数範囲は重複し、別の言葉では、OSCCAL=\$7F設定はOSCCAL=\$80設定より高い周波数になります。

CAL6~0ビットは選択した範囲内の周波数調整に使われます。\$00設定はその範囲の最低周波数になり、\$7F設定はその範囲の最高周波数になります。

MCUの安定な動作を保証するために校正値は小さく変更されるべきです。或るクロック周期から次への2%より大きな周波数変化は予測されない事態を引き起こします。OSCCAL変更は各校正に対して\$20を越えるべきではありません。このようなクロック周波数変更の間、MCUはリセットに保たれるのを保証することが必要です。

(訳注)表6-14.は不適切で本来削除されるべき表です。

#### 

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

| ピット         | 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)も行いません。

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

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

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

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

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

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

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

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



| 表6-1 | 5  | クロック前  | 害公 | 国    | 光强护                                                |
|------|----|--------|----|------|----------------------------------------------------|
| 4X U | J. | 7H77H1 |    | 7011 | シャン・シャン・シャン・ファイン・ファイン・ファイン・ファイン・ファイン・ファイン・ファイン・ファイ |

| CLKPS3 |   | 0 |   |   |    |    |    |     |     |   |   |   | 1    |   |   |   |
|--------|---|---|---|---|----|----|----|-----|-----|---|---|---|------|---|---|---|
| CLKPS2 |   |   | 0 |   |    |    | 1  |     |     | ( | ) |   |      | ] | 1 |   |
| CLKPS1 |   | 0 |   | l | (  | )  | -  | 1   | (   | ) |   | 1 | (    | ) |   | 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 |   |   |   | (予約) |   |   |   |

注: 前置分周器はATtiny15互換動作で禁止され、クロック前置分周レジ、スタ(CLKPR)書き込みもCKDIV8ヒュース、のプロケラミンク(結果)の どちらもシステム クロックに何も影響しません(常に1.6MHz)。



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

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

# 7.1. 休止形態種別

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

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

| ſ |           |            | 動作ク          | ロック軍 | 色囲         |            | 発振器                |              | 復帰起動要因 (割り込み)         |             |             |            |           |  |
|---|-----------|------------|--------------|------|------------|------------|--------------------|--------------|-----------------------|-------------|-------------|------------|-----------|--|
|   | 休止種別      | clk<br>CPU | clk<br>FLASH | clk  | clk<br>ADC | clk<br>PCK | 主クロック<br>供給元<br>許可 | INT0<br>ピン変化 | SPM/<br>EEPROM<br>操作可 | USI<br>開始条件 | A/D変換<br>完了 | その他<br>I/O | ウォッチト゛ック゛ |  |
| I | アイドル      |            |              | 0    | 0          | 0          | 0                  | 0            | 0                     | 0           | 0           | 0          | 0         |  |
|   | A/D変換雑音低減 |            |              |      | 0          |            | 0                  | 1            | 0                     | 0           | 0           |            | 0         |  |
|   | パ。ワータ・ウン  |            |              |      |            |            |                    | 1            |                       | 0           |             | ·          | 0         |  |

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

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

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

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

## 7.1.1. アイドル動作

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

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

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

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

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

# 7.1.3. パワーダウン動作

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



# 7.2. ソフトウェア低電圧検出(BOD)禁止

低電圧検出器(BOD)がBODLEVELヒュース (98頁の表20-4.参照)によって許可されていると、BODは休止期間中に電源電圧を活発に 監視します。 いくつかのデバイスはパプローダウン休止動作でソフトウェアでBODを禁止することによる節電が可能です。 この休止形態電力消費はBODがヒュース によって全面的に禁止される時と同じ水準になるでしょう。

BODがソフトウェアで禁止される場合、BOD機能は休止形態移行後、直ちにOFFされます。休止からの起動復帰で、BODは再び自動的に許可されます。これは休止期間中にVCCレベルが落ちた場合の安全な動作を保証します。

BODが禁止されてしまうと、休止形態からの起動時間はリセットからの起動と同じになります。使用者は内部基準(バンドギャップ)電圧が始動のための時間を持ち、MCUがコードの実行を継続する前にBODが正しく動作するような起動時間を手動で設定しなければなりません。98頁の「ヒューズ下位バイト」表でSUT1,0とCKSEL3~0ヒューズをご覧ください。

BOD禁止はMCU制御レジスタ(MCUCR)のBOD休止(BODS)ビットによって制御されます。26頁の「MCUCR - MCU制御レジスタ」をご覧ください。このビットへの1書き込みはパワーダウン動作でのBODをOFFにし、一方このビットの0はBOD活動(有効)を保ちます。既定設定は0、換言するとBOD活動(有効)です。

BODSビットへの書き込みは許可ビットと時間制限手順によって制御されます。26頁の「MCUCR - MCU制御レジスタ」をご覧ください。

## 7.2.1. 制限

BOD禁止機能は以下のデバイスにだけ実装されています。

ATtiny24: 改訂Eとそれ以降ATtiny44: 改訂Dとそれ以降ATtiny84: 改訂Cとそれ以降

改訂はデバイス外囲器上に記され、以下のように配置され得ます。

- 8P3と8S2外囲器の裏側
- 20M1外囲器の表側



# 7.3. 電力削減

電力削減レシ、スタ(26頁の「PRR - 電力削減レシ、スタ」参照)は消費電力削減のために個別周辺機能へのクロックを停止する方法を提供します。周辺機能は現状で固定化され、I/Oレシ、スタは読み込みも書き込みもできません。クロックを停止している時に周辺機能によって使われていた資源は占有されたままなので、その周辺機能は殆どの場合、クロックを停止する前に禁止されるべきです。周辺機能部の起動はPRRのビットを解除(0)することによって行い、その周辺機能部を停止前と同じ状態にします。

周辺機能部の停止は全体に亘る重要な消費電力削減のために活動動作とアイドル動作で使えます。その他の休止形態ではクロックが 予め停止されます。例については117頁の「**周辺機能部供給電流**」をご覧ください。

# 7.4. 消費電力の最小化

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

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

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

## 7.4.2. アナログ比較器

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

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

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

# 7.4.4. 内部基準電圧

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

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

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

# 7.4.6. ホ°ート ヒ°ン

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

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



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

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

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

| ヒット 7           | U     | Э   | 4   | 3   | 2     | 1     | 0     |       |
|-----------------|-------|-----|-----|-----|-------|-------|-------|-------|
| \$35 (\$55) BOD | S PUD | SE  | SM1 | SM0 | BODSE | ISC01 | ISC00 | MCUCR |
| 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 - BODS: BOD休止 (BOD Sleep)

低電圧検出器(BOD)休止機能はいくつかのデバイスでだけ利用可能です。24頁の「制限」をご覧ください。

休止間(23頁の表7-1.参照)にBODを禁止するために、BODSビットは論理1を書かれなければなりません。BODSビットの書き込みは MCUCRのBOD休止許可(BODSE)ビットと時間制限手順によって制御されます。最初にBODSとBODSEの両方が1に設定されなければなりません。次に4クロック周期内にBODSが1に設定され、BODSEが0に設定されなければなりません。BODSビットはそれが設定された後の3クロック周期間活性(有効)です。SLEEP命令は実際の休止形態に対してBODをOFFにするために、BODSが活性(有効)の間に 実行されなければなりません。BODSビットは3クロック周期後、自動的に解除(0)されます。

BOD休止が実装されていないデバイスでは、このビットが使われず、常に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つを選択します。

## ● ビット2 - BODSE: BOD休止許可(BOD Sleep Enable)

BOD休止機能はいくつかのデバイスでだけ利用可能です。24頁の「**制限**」をご覧ください。

BODSEビットはBOD休止(BODS)ビット記述で説明されるように、BODS制御ビットの設定を許可します。このBOD禁止は時間制限手順によって制御されます。

このビットはソフトウェアBOD禁止が実装されていないデバイスで使われず、それらのデバイスで常に0として読めます。

| <b>木止形態</b> | 種別選択        |
|-------------|-------------|
| SM0         | 休止形態種別      |
| 0           | アイドル動作      |
| 1           | A/D変換雑音低減動作 |
| 0           | パプーダウン動作    |
| 1           | (予約)        |
|             |             |

## 7.5.2. PRR - 電力削減レジスタ (Power Reduction Register)

電力削減レジスタは周辺機能のクロック信号の禁止を許すことによって消費電力削減の方法を提供します。

| ピット         | 7 | 6 | 5 | 4 | 3      | 2      | 1     | 0     |     |
|-------------|---|---|---|---|--------|--------|-------|-------|-----|
| \$20 (\$40) | - | - | - | - | PRTIM1 | PRTIM0 | PRUSI | PRADC | PRR |
| Read/Write  | R | R | R | R | R/W    | R/W    | R/W   | R/W   |     |
| 初期値         | 0 | 0 | 0 | 0 | 0      | 0      | 0     | 0     |     |

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

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

# ● ビット3 - PRTIM1: タイマ/カウンタ1電力削減 (Power Reduction Timer/Counter1)

このビットへの1書き込みはタイマ/カウンタ1部を停止します。タイマ/カウンタ1が許可されると、停止前と同様に動作は継続します。

## ビット2 - PRTIM0:タイマ/カウンタ0電力削減 (Power Reduction Timer/Counter0)

このビットへの1書き込みはタイマ/カウンタ0部を停止します。タイマ/カウンタ0が許可されると、停止前と同様に動作は継続します。

## ● ビット1 - PRUSI: 多用途直列インタ-フェース電力削減 (Power Reduction USI)

このビットへの1書き込みはその部分へのクロック停止によって多用途直列インターフェース(USI)を停止します。USIの再起動時、USIは正しい動作を保証するために再初期化されるべきです。

## ● ビット0 - PRADC : A/D変換器電力削減 (Power Reduction ADC)

このビットへの1書き込みはA/D変換器(ADC)を停止します。A/D変換器は停止前に禁止されなければなりません。A/D変換クロックはア ナログ比較器のいくつかの部分でも使われ、本ビット=1時、アナログ比較器が使えないことに注意してください。

注: アナログ 比較器は81頁の「ACSR - アナログ 比較器 制御/状態レジ スタ」のアナログ 比較器禁止(ACD)ビットを使って禁止されます。(訳注: 共通性から本注追加)



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

# 8.1. AVRのリセット

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



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

# 8.2. リセット元

ATtiny25/45/85には次の4つのリセット元があります。

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

## 8.2.1. 電源ONリセット

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

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





## 8.2.2. 外部リセット

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



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

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

BODが許可され、VCCが起動電圧以下に下降すると(**図8-5**.の  $V_{BOT-}$ )、低電圧 $J_{tot}$ やが直ちに有効とされます。VCCが起動電圧以上に上昇すると(**図8-5**.の $V_{BOT+}$ )、(遅延タイマが起動され)遅延タイマは遅延時間( $t_{TOUT}$ )経過後にMCUを始動します。



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

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

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





# 8.3. 内部基準電圧

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

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

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

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

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

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

ウォッチドック タイマは128kHzで動く独立したチップ上の発振器からクロック駆動されます。ウォッチドック タイマ前置分周器の制御により、ウォッチドック リセット間隔は31頁の表8-3.で示されるように調整できます。ウォッチドック リセット(WDR)命令はウォッチドック タイマをリセットします。ウォッチドック タイマはそれが禁止される時とチップ リセットが起こる時もリセットされます。10種の異なるクロック周期がこのリセット周期を決めるために選択できます。別のウォッチドック リセットなしにリセット周期が経過すると、ATtiny25/45/85はリセットしてリセット へ クタから実行します。ウォッチドック リセットの詳細タイミング については31頁の表8-3.を参照してください。

ウォッチドッグ タイマはリセットの代わりに割り込みを生成する設定にもできます。これはパワーダウン動作から起動するのにウォッチドッグを使う時に大変有用となり得ます。

予期せぬウォッチト・ッグ禁止や予期せぬ計時終了周期変更を防ぐため、2つの異なる安全レヘブルが表8-1.で示されるWDTONヒューズによって選択されます。詳細については次の「ウォッチト・ック・タイマ設定変更の時間制限手順」を参照してください。



表8-1. WDTONヒュース、設定によるウォッチト、ック、機能設定

| WDTON t1-2                                          | 安全レベル | WDT初期状態 | WDT禁止方法  | 計時完了時間変更方法 |
|-----------------------------------------------------|-------|---------|----------|------------|
| 非プログラム(1)                                           | 1     | 禁止      | 時間制限     | なし(常時可)    |
| フ <sup>°</sup> ロク <sup>*</sup> ラム( <mark>0</mark> ) | 2     | 許可      | なし(常時許可) | 時間制限       |

# 8.4.1. ウォッチト、ック、タイマ設定変更の時間制限手順

ウォッチドッグ設定変更手順は安全レベル間で僅かに異なります。各レベルに対して独立した手順が記述されます。

#### 8.4.1.1. 安全レベル1

この動作種別ではウォッチト、ック、タイマが初めに禁止されますが、どんな制限もなくウォッチト、ック、許可(WDE)ヒ、ットに1を書くことにより許可できます。許可したウォッチト、ック、タイマを禁止する時に時間制限手順が必要とされます。許可したウォッチト、ック、タイマを禁止するには次の手順に従わなければなりません。

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

## 8.4.1.2. 安全レベル2

この動作種別ではウォッチドッグ タイマが常に許可され、WDEビットは常に1として読めます。時間制限手順はウォッチドッグ計時完了周期を変更する時に必要とされます。ウォッチドッグ計時完了周期を変更するには次の手順に従わなければなりません。

- ① 同じ操作(命令)でWDCEとWDEに論理1を書きます。WDEビットが常に設定(1)されていても、WDEは時間制限手順を開始するために1を書かれなければなりません。
- ② 次からの4クロック周期内に同じ操作(命令)で欲したWDP2~0ビットを書きますが、WDCEビットは解除(0)されてです。WDEビットに書かれた値は無関係です。



## 8.4.2. コート 例

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

```
アセンブリ言語プログラム例
WDT OFF:
           WDR
                                                       ;ウォッチトック タイマ リセット
           LDI
                  R16, (0<<WDRF)
                                                       ;WDRF=0値を取得
                                                       ;MCUSRのWDRFを解除(0)
           OUT
                  MCUSR, R16
           IN
                  R16, WDTCR
                                                       ;現WDTCR値を取得
                  R16, (1<<WDCE) | (1<<WDE)
           ORI
                                                       ;WDCEとWDE論理1値を設定
                                                       ;WDCEとWDEに論理1書き込み
           OUT
                  WDTCR, R16
                  R16, (0<<WDE)
                                                       ;WDE論理0値を取得
           LDI
                  WDTCR, R16
                                                       ;ウォッチドック゛禁止
           OUT
                                                       ;呼び出し元へ復帰
           RET
C言語プログラム例
void WDT_off(void)
                                                      /* ウォッチト・ック・タイマ リセット */
    WDR();
   MCUSR = 0x00;
                                                      /* MCUSRのWDRFを解除(0)*/
    WDTCR = (1 << WDCE) | (1 << WDE);
                                                      /* WDCEとWDEに論理1書き込み */
    WDTCR = 0x00;
                                                      /* ウォッチト・ック 禁止 */
```

# 注: 4頁の「**コード例**」をご覧ください。

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

# 8.5.1. MCUSR - MCU状態レジスタ (MCU Status Register)

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 | 内容参照 | 内容参照 | 内容参照  | 内容参照 |       |

# ビット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. WDTCR - ウォッチトック タイマ制御レシ スタ (Watchdog Timer Control Register)

| ピット         | 7    | 6    | 5    | 4    | 3   | 2    | 1    | 0    |       |
|-------------|------|------|------|------|-----|------|------|------|-------|
| \$21 (\$41) | WDIF | WDIE | 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 - WDIF: ウォッチドッグ割り込み要求フラグ(Watchdog Interrupt Flag)

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

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

このビットが1を書かれ、ステータス レジスタ(SREG)の全割り込み許可(I)ビットが設定(1)されると、ウォッチドッグ割り込みが許可されます。この動作ではウォッチドッグタイマで計時完了が起きる場合、リセットに代わって対応する割り込みが実行されます。

WDEが設定(1)されると、WDIEは計時完了が起きるとき、ハートウェアによって自動的に解除(0)されます。これは割り込みを使う間のウォッチト・ッグ リセット保護を維持するのに有用です。WDIEと、ットが解除(0)された後、次の計時完了はリセットを生成するでしょう。このウォッチト・ッグ・リセットを避けるには、各割り込み後にWDIEが設定(1)されなければなりません。

| 表8-2. | 表8-2. ウォッチドッグ タイマ設定 |      |          |  |  |  |  |  |  |  |
|-------|---------------------|------|----------|--|--|--|--|--|--|--|
| WDE   | WDIE                | 動作状態 | 計時完了での動作 |  |  |  |  |  |  |  |
| 0     | 0                   | 停止   | なし       |  |  |  |  |  |  |  |
| 0     | 1                   | 走行   | 割り込み     |  |  |  |  |  |  |  |
| 1     | 0                   | 走行   | リセット     |  |  |  |  |  |  |  |
| 1     | 1                   | 走行   | 割り込み     |  |  |  |  |  |  |  |

#### ヒット4 - WDCE: ウォッチトック変更許可(Watchdog Change Enable)

ウォッチト、ック・許可(WDE)と、ットが論理0を書かれるとき、このビットは設定(1)されなければなりません。さもなければ、ウォッチト、ック・は禁止されません。一旦1を書かれると、ハート・ウェアが4クロック周期後、このビットを解除(0)します。ウォッチト、ック・禁止手順についてはWDEビットの記述を参照してください。このビットは前置分周ビットを変更する時も設定(1)されなければなりません。29頁の「ウォッチト、ック・タイマ設定変更の時間制限手順」をご覧ください。

# ビット3 - WDE:ウォッチト、ック、許可(Watchdog Enable)

ウォッチト、ック、許可(WDE)が論理1を書かれるとウォッチト、ック、タイマが許可され、WDEが論理0を書かれるとウォッチト、ック、タイマ機能が禁止されます。WDEはウォッチト、ック、変更許可(WDCE)と、ットが論理レヘ、ル1を持つ場合だけ解除(0)できます。許可されているウォッチト、ック、タイマを禁止するには次の手順に従わなければなりません。

- ① 同じ操作(命令)内で、ウォッチドック変更許可(WDCE)ビットとウォッチドック許可(WDE)ビットに論理1を書きます。例え禁止操作を始める前のWDEが1に設定されていても、論理1がWDEに書かれなければなりません。
- ② 次からの4クロック周期内で、論理0をWDEに書きます。これがウォッチドックを禁止します。

安全レヘブル2では上記の手順でもウォッチドック、タイマを禁止することができません。29頁の「ウォッチドック、タイマ設定変更の時間制限手順」をご覧ください。

安全レヘル1ではWDEがMCUSRのウォッチトック・リセット フラク・(WDRF)によって無効にされます。WDRFの説明については30頁の「MCUSR - MCU状態レジスタ」をご覧ください。これはWDRFが設定(1)されていると、WDEが常に設定(1)されることを意味します。WDEを解除(0)するには上記手順でウォッチトック・を禁止する前にWDRFが解除(0)されなければなりません。この特徴は失敗を引き起こす状態中の複数リセットと失敗後の安全な起動を保証します。

注: ウォッチドッグ タイマが応用で使われないなら、デバイス初期化でウォッチドッグ禁止手順を全て行なうことが重要です。 ウォッチドッグが偶然に許可されると(例えばポインタの逸脱や低電圧(ブラウンアウト)状態)、デバイスはリセットし、その転化が次のウォッチドッグ リセットを引き起こすでしょう。この状態を避けるため、応用ソフトウェアは初期化ルーチンでWDRFフラグとWDE制御ビットを常に解除(0)すべきです。

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

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

| 表8-3. ウォッチト゛ック゛前       | 置分周  | <b>周器選</b> | 沢    |        |       |      |      |      |      |       |   |   |     |       |   |   |
|------------------------|------|------------|------|--------|-------|------|------|------|------|-------|---|---|-----|-------|---|---|
| WDP3                   |      | 0          |      |        |       |      |      |      |      |       |   |   | 1   |       |   |   |
| WDP2                   |      | (          | )    |        |       | ]    | L    |      | 0    |       |   |   |     | L     |   |   |
| WDP1                   | (    | )          |      | 1      | (     | )    |      | [    | (    | 0 1   |   | 0 |     | 1     | 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  |   |   | (予約 | ) (注) |   |   |

注: 選択した場合、1010未満の有効な設定の(どれか)1つが使用されます。

# 9. 割り込み

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

# 9.1. ATtiny25/45/85の割り込みべかり

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

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

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

プログラムが決して割り込み元を許可しないなら、割り込みへ、クタは使われず、これらの位置に通常のプログラムコート、が配置できます。 ATtiny25/45/85での代表的で一般的な割り込みへ、クタアトレス構成設定が次のプログラム例で示されます。

| アセンブリ言語プログ |          |                | 00                   |
|------------|----------|----------------|----------------------|
| \$0000     | ORG      | \$0000         | ;プログラム用フラッシュ メモリ先頭位置 |
| \$0000     | RJMP     | RESET          | ;各種リセット              |
| \$0001     | RJMP     | INTO_ISR       | ;外部割り込み要求0           |
| \$0002     | RJMP     | PCINTO_ISR     | ;ピン変化割り込み要求          |
| \$0003     | RJMP     | TIM1_COMPA_ISR | ;タイマ/カウンタ1比較A一致      |
| \$0004     | RJMP     | TIM1_OVF_ISR   | ;タイマ/カウンタ1溢れ         |
| \$0005     | RJMP     | TIMO_OVF_ISR   | ;タイマ/カウンタ0溢れ         |
| \$0006     | RJMP     | EE_RDY_ISR     | ;EEPROM操作可           |
| \$0007     | RJMP     | ANA_COMP_ISR   | ;アナログ・比較器出力遷移        |
| \$0008     | RJMP     | ADC_ISR        | ;A/D変換完了             |
| \$0009     | RJMP     | TIM1_COMPB_ISR | ;タイマ/カウンタ1比較B一致      |
| \$000A     | RJMP     | TIMO_COMPA_ISR | ;タイマ/カウンタ0比較A一致      |
| \$000B     | RJMP     | TIMO_COMPB_ISR | ;タイマ/カウンタ0比較B一致      |
| \$000C     | RJMP     | WDT_OVF_ISR    | ;ウォッチドッグ計時完了         |
| \$000D     | RJMP     | USI_START_ISR  | ;USI 開始条件検出          |
| \$000E     | RJMP     | USI_OVF_ISR    | ;USI 計数器溢れ           |
| ;          |          |                |                      |
| \$000F RES | ET: "命令" |                | ;主プログラム開始            |

注: 4頁の「**コード例**」をご覧ください。



# 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. MCUCR - MCU制御レジスタ (MCU Control Register)

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

| ピット         | 7    | 6   | 5   | 4   | 3   | 2     | 1     | 0     | _     |
|-------------|------|-----|-----|-----|-----|-------|-------|-------|-------|
| \$35 (\$55) | BODS | PUD | SE  | SM1 | SM0 | BODSE | ISC01 | ISC00 | MCUCR |
| 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     |       |

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

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



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

| ピット         | 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. GIFR - 一般割り込み要求フラグレジスタ (General Interrupt Flag Register)

| ピット         | 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)

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

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

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

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

| ピット         | 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の両方に保護ダイオートがあります。各値の完全な一覧については108頁の「電気的特性」を参照してください。



本項内の全てのレジスタとビットの参照は一般形で記されます。小文字の'x'はポート番

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

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

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

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

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

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



# 10.2.1. ピンの設定

各ポート ピンは3つのレジスタ ビット、DDxn、PORTxn、PINxnから成ります。42頁の「I/Oポート用レジスタ」で示されるように、DDxnビットはDDxx 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. | ポート | ピンの | )設定 |
|--------|-----|-----|-----|
|        |     |     |     |

| <u> </u> | 「しつの政ル |             |     |         |                               |
|----------|--------|-------------|-----|---------|-------------------------------|
| 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
                                                                ;プルアップと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は38頁の「**交換ポート機能**」で記載されるように様々な他の交換機能によっても無視されます。

外部割り込みが許可されていない"上昇端、下降端または論理変化(両端)割り込み"として設定された非同期外部割り込みピンに論理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信号で制御されます。出力駆動部がONで0の場合、ポート値は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> ート<br>ピ <sup>°</sup> ン | 交換機能                                                                                                                                                               | ポ <sup>°</sup> ート<br>ピン | 交換機能                                                                                                                        |
|---------------------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------------------------|-----------------------------------------------------------------------------------------------------------------------------|
| PB5                                   | RESET (外部リセット入力) dW (デバッケWIRE入出力) ADC0 (A/D変換チャネル0入力) PCINT5 (ピン変化割り込み5入力)                                                                                         |                         | MISO (SPI直列プログラミング データ入力) DO (3線動作USIデータ出力) OC0B (タイマ/カウンタ0比較B一致/PWM-B出力)                                                   |
| PB4                                   | XTAL2(システム クロック用発振増幅器出力)CLKO(システム クロック出力)OC1B(タイマ/カウンタ1比較B一致/PWM-B非反転出力)ADC2(A/D変換チャネル2入力)PCINT4(ピン変化割り込み4入力)                                                      | PB1                     | OCOB (タイマ/カウンタ1比較A一致/FWM-B田力) OC1A (タイマ/カウンタ1比較A一致/PWM-A非反転出力) AIN1 (アナロケ)比較器反転入力) PCINT1 (ピン変化割り込み1入力)                     |
| PB3                                   | XTAL1 (システム クロック用発振増幅器入力<br>または外部クロック信号入力)<br><u>CLKI</u> (外部システム クロック入力)<br><u>OC1B</u> (タイマ/カウンタ1比較B一致/PWM-B反転出力)<br>ADC3 (A/D変換チャネル3入力)<br>PCINT3 (ピン変化割り込み3入力) |                         | MOSI (SPI直列プログラミング データ出力) DI (3線動作USIデータ入力) SDA (2線動作USI(TWI)データ入出力)                                                        |
| PB2                                   | SCK (SPI直列プログラミング クロック入力) USCK (3線動作USI/ロック入出力) SCL (2線動作USI(TWI)/クロック入出力) T0 (タイマ/カウンタの外部クロック入力) INTO (外部割り込み0入力) ADC1 (A/D変換チャネル1入力) PCINT2 (ピン変化割り込み2入力)        | PB0                     | OC0A (タイマ/カウンタ0比較A一致/PWM-A出力) OC1A (タイマ/カウンタ1比較A一致/PWM-A反転出力) AIN0 (アナログ比較器非反転入力) AREF (A/D変換外部基準電圧入力) PCINT0 (ピン変化割り込み0入力) |

交換ピンの設定は次のとおりです。

• RESET/dW/ADC0/PCINT5 - ホートB ビット5: PB5

RESET:外部リセット入力はLow活性(有効)で、RSTDISBLヒューズの非プログラム(1)により許可されます。このピンがRESETピンとして使われると、プルアップが活性(有効)にされ、出力駆動部とデジタル入力は非活性(無効)にされます。

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

**ADC0**: A/D変換器チャネル0入力。 **PCINT5**: ピン変化割り込み元5入力。

XTAL2/CLKO/OC1B/ADC2/PCINT4 - ホートB ビット4: PB4

XTAL2: システム クロック発振器ピン2。内部RC発振器、外部クロック、PLLクロックを除いて、全てのチップ クロック元用クロック ピンとして使われます。 クロック ピンとして使われると、このピンはI/Oピンとして使えません。 チップ クロック元として内蔵校正可能RC発振器、外部クロック、またはPLLクロックを使うと、PB4は通常のI/Oピンとして取り扱います。

CLKO: システム クロック出力。分周したシステム クロックはPB4ピンに出力できます。分周したシステム クロックはCKOUTヒューズがプログラム(0)されると、PORTB4とDDB4設定に拘らず、出力されます。これはリセット中にも出力されます。

OC1B: タイマ/カウンタ1の比較B一致出力。PB4ピンは出力として設定(DDB4=1)される時にタイマ/カウンタ1の比較B一致用外部出力として扱えます。このOC1BピンはPWM動作用出力ピンでもあります。

**ADC2**: A/D変換器チャネル2入力。 **PCINT4**: ピン変化割り込み元4入力。

XTAL1/CLKI/OC1B/ADC3/PCINT3 - ホートB ビット3: PB3

XTAL1: システムクロック発振器ピン1。内部RC発振器、PLLクロックを除く全てのチップクロック元用クロック ピンとして使われます。クロック ピンとして使われると、このピンはI/Oピンとして使えません。

CLKI:外部クロック元からのクロック入力、17頁の「外部クロック信号」をご覧ください。

OCIB: タイマ/カウンタ1の比較B一致反転出力。PB3ピンは出力として設定(DDB3=1)される時にタイマ/カウンタ1の比較B一致用外部出力として扱えます。このOCIBピンはPWM動作用反転出力ピンでもあります。

**ADC3**: A/D変換器チャネル3入力。 **PCINT3**: ピン変化割り込み元3入力。



• SCK/USCK/SCL/T0/INT0/ADC1/PCINT2 - ホートB ビット2: PB2

SCK: SPI直列プログラミング用クロック入力。ソフトウェアからは利用できません。

USCK: 3線動作USIのクロック入出力。 SCL: 2線動作USI(TWI)のクロック入出力。

T0: タイマ/カウンタ0外部クロック入力はタイマ/カウンタ0制御レジスタB(TCCR0B)のCS02とCS01ビットを設定(1)することによって許可されませ

INTO:外部割り込み0入力。PB2ピンはMCUへの外部割り込み元として扱えます。

**ADC1**: A/D変換器チャネル1入力。 **PCINT2**: ピン変化割り込み元2入力。

MISO/DO/OC0B/OC1A/AIN1/PCINT1 - ホートB ビット1: PB1

MISO: SPI直列プログラミング用データ入力。ソフトウェアからは利用できません。

DO: 3線動作USIのデータ出力。データ出力(DO)はPORTB1値を無効にし、データ方向(DDB1)ビットが設定(1)されると、ポートが駆動されます。けれどもPORTB1ビットは未だプルアップを制御し、方向が入力でPORTB1が設定(1)されるならプルアップを許可します。

OCOB: タイマ/カウンタ0の比較B一致出力。PB1ピンはタイマ/カウンタ0の比較B一致用外部出力として扱えます。この機能を扱うため、このピンは出力として設定(DDB1=1)されなければなりません。このOCOBピンはタイマ機能のPWM動作用出力ピンでもあります。

OC1A: タイマ/カウンタ1の比較A一致出力。PB1ピンは出力として設定(DDB1=1)される時にタイマ/カウンタ1の比較A一致用外部出力として扱えます。このOC1AピンはPWM動作用出力ピンでもあります。

AIN1: アナログ比較器の反転入力。アナログ比較器の機能を妨げるデジタル ポート機能を避けるため、内部プルアップをOFFにした入力としてポート ピンを設定してください。

PCINT1: ピン変化割り込み元1入力。

• MOSI/DI/SDA/OC0A/OC1A/AIN0/AREF/PCINT0 - ホートB ビット0: PB0

MISO: SPI直列プログラミング用データ出力。ソフトウェアからは利用できません。

DI: 3線動作USIのデータ入力。3線動作USIは標準ポート機能を無効にしませんので、ピンはDI機能用入力として設定しなければなりません。

SDA: 2線動作USIのデータ入出力(オープント・レイン出力)。直列データ ピンは双方向でオープント・レイン出力を使います。SDAピンは出力としてこのピンを設定することによって許可されます。このピンはDDB0が設定(1)されるとき、PORTB0またはUSI移動レジスタ(出力)が0の時にLowへ引き込まれます。プルアップは2線動作USIで禁止されます。

OCOA: タイマ/カウンタ0の比較A一致出力。PB0ピンは出力として設定(DDB0=1)される時にタイマ/カウンタ0の比較A一致用外部出力として扱えます。このOC0AピンはPWM動作用出力ピンでもあります。

OC1A: ダイマ/カウンタ1の比較A一致出力。PB0ピンは出力として設定(DDB0=1)される時にタイマ/カウンタ1の比較A一致用外部出力として扱えます。このOC1AピンはPWM動作用反転出力ピンでもあります。

AINO: アナログ比較器の非反転入力。アナログ比較器の機能を妨げるデジタルポート機能を避けるため、内部プルアップをOFFにした入力としてポート ピンを設定してください。

AREF: A/D変換用外部基準電圧。このピンが外部基準電圧またはAREFピンでの外部コンテンサとの内部基準電圧(1.1V)として使われると、プルアップと出力駆動部はPBOで禁止されます。

PCINTO: ピン変化割り込み元0入力。



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

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

| 信号名   | PB5/RESET/ADC0/PCINT5          | PB4/XTAL2/OC1B/ADC2/PCINT4 | PB3/XTAL1/OC1B/ADC3/PCINT3 |
|-------|--------------------------------|----------------------------|----------------------------|
| PUOE  | RSTDISBL • DWEN                | 0                          | 0                          |
| PUOV  | 1                              | 0                          | 0                          |
| DDOE  | RSTDISBL•DWEN                  | 0                          | 0                          |
| DDOV  | デバッグWIRE送信                     | 0                          | 0                          |
| PVOE  | 0                              | OC1B許可                     | OC1B許可                     |
| PVOV  | 0                              | OC1B                       | OC1B                       |
| 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/USCK/SCL/<br>T0/INT0/ADC1/PCINT2 | PB1/MISO/DO/OC0B/<br>OC1A/AIN1/PCINT1 | PB0/MOSI/DI/SDA/OC0A/<br>OC1A/AIN0/AREF/PCINT0 |  |  |
|-------|------------------------------------------|---------------------------------------|------------------------------------------------|--|--|
| PUOE  | 2線USI                                    | 0                                     | 2線USI                                          |  |  |
| PUOV  | 0                                        | 0                                     | 0                                              |  |  |
| DDOE  | 2線USI                                    | 0                                     | 2線USI                                          |  |  |
| DDOV  | (SCL保持+PORTB2)+DDB2                      | 0                                     | (SDA+PORTB0)•DDB0                              |  |  |
| PVOE  | 2線USI•DDB2                               | OC0B許可+3線USI                          | OC0A許可+ <del>OC1A</del> 許可+<br>(2線USI•DDB0)    |  |  |
| PVOV  | 0                                        | OC0B+OC1A+DO                          | OC0A+OC1A                                      |  |  |
| PTOE  | USITC                                    | 0                                     | 0                                              |  |  |
| DIEOE | (PCINT2 • PCIE)+ADC1D+USISIE             | (PCINT1 • PCIE)+ADC1D                 | (PCINTO • PCIE)+ADC0D+USISIE                   |  |  |
| DIEOV | ADC1D                                    | AIN1D                                 | AIN0D                                          |  |  |
| DI    | USCK/SCL/T0/INT0/PCINT2入力                | PCINT1入力                              | DI/SDA/PCINT0入力                                |  |  |
| AIO   | ADC1入力                                   | アナログ比較器反転入力                           | アナログ比較器非反転入力                                   |  |  |



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

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

| ピット         | 7    | 6   | 5   | 4   | 3   | 2     | 1     | 0     | _     |
|-------------|------|-----|-----|-----|-----|-------|-------|-------|-------|
| \$35 (\$55) | BODS | PUD | SE  | SM1 | SM0 | BODSE | ISC01 | ISC00 | MCUCR |
| 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     |       |

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

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

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

| ピット         | 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. DDRB - ホートB方向レシズタ (Port B Data Direction Register)

| ピット         | 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. PINB - ホートB入力レシ、スタ (Port B Input Address)

| ピット         | 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レジスタは赤文字(<mark>訳注</mark>:原文は太字)で示されます。デバイス仕様のI/Oレジスタとビット位置は51頁の「8ビット タイマ/カウンタ0用レジスタ」で一覧されます。



## 11.2.1. 関係レジスタ

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

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

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



#### 11.2.2. 定義

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

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

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

## 11.3. タイマ/カウンタ0の前置分周器とクロック元

このタイマ/カウンタは内部または外部のクロック元によってクロック駆動できます。このクロック元はタイマ/カウンタ0制御レジスタB(TCCR0B)に配置されたクロック選択(CS02~0)ビットによって制御されるクロック選択論理回路によって選択されます。

# 11.3.1. 前置分周器での内部クロック元

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

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

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

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

# 11.3.3. 外部クロック元

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



エッシ<sup>\*</sup>検出器は上昇端(CSn2~0=111)または下降端(CSn2~0=110)の検出毎に1つのclk<sub>T0</sub>ハ<sup>\*</sup>ルスを生成します。

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

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

印加された外部クロックの各半周期は正しい採取を保証するために1システム クロック周期より長くなければなりません。この外部 クロックは50%/50%デューティ比で与えられるものとして、システム ク ロック周波数の半分未満(fexTclk〈fclk\_I/O/2)であることが保証されなければなりません。エッジ検出器が採取を使うために、検



出できる外部クロックの最大周波数は採取周波数の半分です(ナイキストの標本化定理)。然しながら、発振元(クリスタル発振子、セラミック振動子、コンデンサ)公差によって引き起こされたシステム クロック周波数やデューティ比の変動のため、外部クロック元の最大周波数はfclk\_I/O/2.5未満が推奨されます。

外部クロック元は前置分周できません。



# 11.4. 計数器部

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



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

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

タイマ/カウンタ溢れ(TOVO)フラク「は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信号は動作種別(47頁の「動作種別」参照)のいくつかで両端値の特別な場合を扱うため、波形生成器によって使われます。

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

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

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



(<mark>訳注</mark>) ここでは比較nxレジスタ全体をOCR0x、OCR0xを構成する緩衝部分をOCR0x<mark>緩衝部</mark>、実際の比較に使われるレジスタ本体部分を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書き込みでも19イマ/カウンタ クロック周期間、全ての比較一致を妨げるため、タイマ/カウンタが走行中であるかないかに拘らず、比較出力部を使う場合、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-6.は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ビット設定が或る種の動作種別に対して予約されることに注意してください。51頁の「8ビット タイマ/カウンタ0用レジスタ」をご覧ください。

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

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

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



# 11.7. 動作種別

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

タイミング情報の詳細については50頁の「**タイマ/カウンタ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-7.で示されます。カウンタ(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動作

高速 $^\circ$ ルス幅変調(PWM)動作(WGM02 $^\circ$ 0=011または111)は高周波数PWM波形生成選択を提供します。高速PWMはそれが単一傾斜(鋸波)動作であることによって他のPWM動作と異なります。カウンタはBOTTOMからTOPまで計数し、その後BOTTOMから再び始めます。TOPはWGM02 $^\circ$ 0=011時に\$FF、WGM02 $^\circ$ 0=111時にOCR0Aとして定義されます。

非反転比較出力動作(COM0x1,0=10)での比較出力(OC0x)はTCNT0とOCR0x間の比較一致で解除(0)され、BOTTOMで設定(1)されます。反転出力動作(COM0x1,0=11)の出力は比較一致で設定(1)され、BOTTOMで解除(0)されます。

この単一傾斜動作のため、高速PWM動作の動作周波数は、両傾斜(三角波)動作を使う位相基準PWM動作よりも2倍高くできます。 この高い周波数は電力調節、整流、D/A変換に対して高速PWM動作を都合よく適合させます。高い周波数は物理的に小さな外部 部品(コイルやコンデンサ)を許し、従ってシステム総費用を削減します。

高速PWM動作でのタイマ/カウンタはタイマ/カウンタ値がTOP値と一致するまで増加されます。そしてタイマ/カウンタは(一致の)次のタイマ/カウンタクロック周期で解除(\$00)されます。高速PWM動作のタイミング図は図11-8.で示されます。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ピンに対して利用できません(51頁の表11-3.をご覧ください)。実際の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)に設定される時に $f_{OC0x}=f_{clk\_I/O}/2$ の最大周波数でしょう。この特性は高速PWM動作で比較出力部の2重緩衝機能が許可されることを除いて、CTC動作でのOC0A交互出力(COM0A1,0=01)と同じです。



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

位相基準 $^{\circ}$ ル $^{\circ}$ 和 $^$ 

位相基準PWM動作でのカウンタはカウンタ値がTOPと一致するまで増加されます。カウンタはTOPに達すると計数方向を変更します。この TCNT0値は1タイマ/カウンタ クロック周期間TOPと等しくなります。位相基準PWM動作のタイミング図は図11-9.で示されます。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ピンに対して利用できません(51頁の表11-4.をご覧ください)。実際のOC0x値はそのポート ピンに対するデータ方向(DDR\_OC0x)が出力として設定される場合だけ見えるでしょう。PWM波形はカウンタが増加する時のTCNT0とOCR0x間の比較一致でOC0x(内部)レジスタを設定(1)(または解除(0))と、カウンタが減少する時のTCNT0とOCR0x間の比較一致でOC0x(内部)レジスタを設定(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-9.の第2周期のその出発点に於いて、例え比較一致がないとしても、OCnxにはHighからLowへの遷移があります。この遷移点はBOTTOMを挟む対称を保証するためです。比較一致なしに遷移を生ずるのは次のように2つの場合です。

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



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

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



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



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



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



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

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

| ピット         | 7   | 6     | 5      | 4      | 3     | 2     | 1    | 0    | _     |
|-------------|-----|-------|--------|--------|-------|-------|------|------|-------|
| \$2C (\$4C) | TSM | PWM1B | COM1B1 | COM1B0 | FOC1B | FOC1A | PSR1 | PSR0 | GTCCR |
| Read/Write  | R/W | R/W   | R/W    | R/W    | W     | W     | R/W  | R/W  |       |
| 初期値         | 0   | 0     | 0      | 0      | 0     | 0     | 0    | 0    |       |

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

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

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

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

## 11.9.2. TCCROA - タイマ/カウンタO制御レシ スタA (Timer/CounterO Control Register A)

| ピット         | 7      | 6      | 5      | 4      | 3 | 2 | 1     | 0     |        |
|-------------|--------|--------|--------|--------|---|---|-------|-------|--------|
| \$2A (\$4A) | 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)
- ビット5,4 COMOB1,0:比較B出力選択 (Compare Match B Output Mode bit 1 and 0)

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

OC0A/OC0Bがピンに接続されるとき、COM0A1,0/COM0B1,0ピットの機能はWGM02~0ピット設定に依存します。

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

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

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

表11-2. 非PWM動作比較x出力選択 (x=AまたはB)

| COM0x1 | COM0x0 | 意味                     |
|--------|--------|------------------------|
| 0      | 0      | 標準ポート動作 (OC0x切断)       |
| 0      | 1      | 比較一致でOC0xピン トグル(交互)出力  |
| 1      | 0      | 比較一致でOC0xピン Lowレベル出力   |
| 1      | 1      | 比較一致でOC0xピン Highレヘブル出力 |

表11-3. 高速PWM動作比較x出力選択(x=AまたはB)

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

注: COM0x1が設定(1)され、OCR0xがTOPと等しい時に特別な状態が起きます。この状態での比較一致は無視されますが、BOTTOMでの設定(1)や解除(0)は行われます。より多くの詳細については48頁の「高速PWM動作」をご覧ください。

表11-4. 位相基準PWM動作比較x出力選択 (x=AまたはB)

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

注: COM0x1が設定(1)され、OCR0xがTOPと等しい時に特別な状態が起きます。この状態での比較一致は無視されますが、TOPでの設定(1)や解除(0)は行われます。より多くの詳細については49頁の「位相基準PWM動作」をご覧ください。

ヒット3,2 - Res: 予約 (Reserved)

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

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

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

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

| 番号 | 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     | (予約)                  | 1     | -        | _       |
| 5  | 1     | 0     | 1     | 位相基準PWM動作             | OCR0A | TOP      | BOTTOM  |
| 6  | 1     | 1     | 0     | (予約)                  | 1     | _        | _       |
| 7  | 1     | 1     | 1     | 高速PWM動作               | OCR0A | BOTTOM   | TOP     |

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

#### 11.9.3. TCCR0B - タイマ/カウンタ0制御レジスタB (Timer/Counter0 Control Register B)

| ヒ"ット        | 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)も行いません。

FOC0Aビットは常に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)

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

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

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

表11-6. タイマ/カウンタ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.4. TCNT0 - タイマ/カウンタ0 (Timer/Counter0)

| ピット         | 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.5. OCROA - タイマ/カウンタO 比較Aレシ、スタ (Timer/CounterO Output Compare A Register)

| ピット         | 7     | 6   | 5   | 4   | 3   | 2   | 1   | 0     |       |
|-------------|-------|-----|-----|-----|-----|-----|-----|-------|-------|
| \$29 (\$49) | (MSB) |     |     |     |     |     |     | (LSB) | OCR0A |
| 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.6. OCROB - タイマ/カウンタO 比較Bレジスタ (Timer/CounterO Output Compare B Register)

| ヒ゛ット        | 7     | 6   | 5   | 4   | 3   | 2   | 1   | 0     |       |
|-------------|-------|-----|-----|-----|-----|-----|-----|-------|-------|
| \$28 (\$48) | (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.7. TIMSK - タイマ/カウンタ割り込み許可レジスタ (Timer/Counter Interrupt Mask Register)

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

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

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

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

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

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

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

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

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

# 11.9.8. TIFR - タイマ/カウンタ割り込み要求フラク・レシ、スタ (Timer/Counter Interrupt Flag Register)

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

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

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

## ● ビット4 - OCFOA: タイマ/カウンタ0比較A割り込み要求フラグ(Timer/Conter0, Output Compare A Match Flag)

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

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

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

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

TOV0ビットはタイマ/カウンク(TCNT0)溢れが起こる時に設定(1)されます。対応する割り込み処理べクタを実行すると、TOV0はハードウェアによって解除(0)されます。代わりにこのフラグへ論理1を書くことによってもTOV0は解除(0)されます。ステータス レジスタ(SREG)の全割り込み許可(I)ビット、タイマ/カウンク割り込み許可レジスタ(TIMSK)のタイマ/カウンク0溢れ割り込み許可(TOIE0)ビット、TOV0が設定(1)されると、タイマ/カウンク0溢れ割り込みが実行されます。位相基準PWM動作ではタイマ/カウンク0が\$00で計数方向を変える時にこのビットが設定(1)されます。

これらフラケーの設定はWGM02~0ビット設定に依存します。52頁の波形生成種別ビット記述の表11-5.を参照してください。

# **12**. 8ビット タイマ/カウンタ1

タイマ/カウンタ1は独立した前置分周器からの独立した前置分周選択を持つ汎用8ビットタイマ/カウンタ部です。

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

図12-1.は同期クロック動作と非同期クロック動作の2つのクロック動作を支援するタイマ/カウンタ1の前置分周器部を示します。同期クロック動作は基準時間クロックとしてシステム クロック(CK)を使い、非同期クロック動作は基準時間クロックとして高速周辺クロック(PCK)を使います。PLL制御/状態レジスタ(PLLCSR)のPCK許可(PCKE)ビットは設定(1)の時に非同期動作を許可します。

同期クロック動作でのクロック選択はCK~CK/16384と停止、非同期クロック動作でのクロック選択はPCK~PCK/16384と停止です。このクロック任意選択は59頁のタイマ/カウンタ1制御レジスタ(TC CR1)と表12-5.で記述されます。一般タイマ/カウンタ制御レジスタ(GTCCR)のタイマ/カウンタ1前置分周器リセット(PSR1)ビットの設定(1)がこの前置分周器をリセットします。PLLCSRのPCKEビットが非同期動作を許可します。高速周辺クロックの周波数は64MHz(または低速動作で32MHz)です。



#### 12.2. タイマ/カウンタ1

タイマ/カウンタ1の一般的な操作は非同期動作で記述され、同期動作での操作はこれら2つの動作種別間に違いがある時にだけ言及されます。図12-2.はタイマ/カウンタ1同期化レジ、スタ構成図とレジ、スタ間の同期化遅延を示します。全クロック ケート詳細がこの図で示されないことに注意してください。タイマ/カウンタ1のレジ、スタ値は計数動作に影響を及ぼす前に入力同期化遅延を引き起こす内部同期化レジ、スタを通ります。TCCR1、GTCCR、OCR1A、OCR1B、OCR1Cはレジ、スタ書き込み後、正しく読み戻せます。読み戻し値はタイマ/カウンタ1(TCNT1)とOCF1A、OCF1B、TOV1フラグに関して入出力同期化のために遅らされます。

このタイマ/カウンタ1は低前置分周(使用)機会での高分解能及び高精度の使用が特徴です。64MHz(または低速動作で32MHz)までのクロック速度を使う正確で高速な2つの8ビット PWMも支援できます。この動作でタイマ/カウンタ1と比較レジスタは重複しない反転と非反転出力の2つの自立型PWMとして扱います。この機能の詳細記述については57頁の「タイマ/カウンタ1 PWM動作」を参照してください。同様に高前置分周(使用)機会は低速な目的やまれに動く正確なタイシングの目的についてこの部署を有用にします。



タイマ/カウンタ1と前置分周器は前置分周器が非同期動作で高速64MHz(または低速動作で32MHz)のPCKクロック動作をする一方、どのクロック元からもCPUの走行(動作)を許します。

システム クロック周波数がPCK周波数の1/3よりも低くなければならないことに注意してください。非同期タイマ/カウンタ1の同期化機構はシステム クロックがHighの時に最低2つのPCK端を必要とします。システム クロック周波数が高すぎる場合、データまたは制御値を失う危険があります。

次の図12-3.はタイマ/カウンタ1の構成図を示します。



3つの状態フラグ(溢れと比較一致)はタイマ/カウンタ割り込み要求フラグレジ、スタ(TIFR)にあります。制御信号はタイマ/カウンタ1制御レジ、スタ(TCCR1)と一般タイマ/カウンタ制御レジ、スタ(GTCCR)にあります。割り込みの許可/禁止設定はタイマ/カウンタ割り込み許可レジ、スタ(TIMSK)にあります。

タイマ/カウンタ1はタイマ/カウンタ1の内容と比較されるデータ元としてOCR1A、OCR1B、OCR1Cの3つの比較レジ、スタを含みます。標準動作での出力比較機能は3つ全てが出力比較レジ、スタでの動作です。OCR1AはOC1A(PB1)ピンの動作を決め、標準動作とPWM動作で比較A割り込みを生成できます。同様にOCR1BはOC1B(PB4)ピンの動作を決め、標準動作とPWM動作で比較B割り込みを生成できます。OCR1Cはタイマ/カウンタ1の最大値、換言すると比較一致での解除値を保持します。標準動作での溢れ割り込み(TOV1)はタイマ/カウンタ1が\$FFから\$00に計数する時に生成され、一方PWMでの溢れ割り込みはタイマ/カウンタ1が\$FFから\$00に、またはOCR1C(値)から\$00に計数する時のどうちらでも生成されます。反転PWM出力のOCIAとOCIBは標準動作で接続されません。

PWM動作でのOCR1AとOCR1Bはタイマ/カウンタ値が繰り返し比較されるデータ値を供給します。比較一致でPWM出力(OC1A, OC1A, OC1B, OC1B)が生成されます。PWM動作でのタイマ/カウンタは比較Cレジスタ(OCR1C)で指定した値まで上昇計数し、そして再び\$00から始めます。この特性は\$FFよりも小さい指定値へのカウンタ最大値制限を許します。多くの前置分周器任意選択と共に柔軟なPWM周波数選択が提供されます。 $\mathbf{表}12-3$ .は10kHz単位の20kHz $\sim250$ kHzと50kHz世位の250kHzで00kHzのPWM周波数を得るためのOCR1C値とクロック選択の一覧を示します。より高いPWM周波数は分解能を犠牲にすれば得られます。

#### 12.2.1. 非同期動作に対するタイマ/カウンタ1の初期化

タイマ/カウンタ1を非同期動作に設定するには最初にPLLを許可し、そしてPLL安定のために100μs待機し、次にPLOCKビットが設定(1)されるまでポーリングし、そしてその後にPCKEビットを設定(1)してください。



#### 12.2.2. タイマ/カウンタ1 PWM動作

PWM動作が選択されると、 $94\sqrt{/n}$ ン91(TCNT1)と比較Cレジス9(OCR1C)はOC1 A(PB1)とOC1B(PB4)ピン出力とOC1A(PB0)とOC1B(PB3)ピン反転出力での自由 走行で不具合なしの(2出力)1対のPWM発生器を形成します。相互補完出力対 に対する既定非重複時間は0ですが、それらは沈黙時間生成器の使用で挿入できます(70頁の記述をご覧ください)。



カウンタ値が比較Aレシ、スタ(OCR1A)または比較Bレシ、スタ(OCR1B)の内容と一致する

と、**表12-1**.で示されるようにタイマ/カウンタ1制御レシ、スタ(TCCR1)の比較A出力選択(COM1A1,COM1A0)または一般タイマ/カウンタ制御レシ、スタ(GTCCR)の比較B出力選択(COM1B1,COM1B0)と、ットに従ってOC1AとOC1B出力は設定(High)または解除(Low)されます。

タイマ/カウンタ1は\$00から比較Cレシ、スタ(OCR1C)で指定した値まで計数し、再び\$00から始める上昇カウンタとして動きます。OCR1Cとの比較一致は比較事象に続く同期化遅延後に溢れ割り込み要求(TOV1)フラグを設定(1)します。

表12-1. PWM動作での比較出力選択 (x=AまたはB)

| COM1x1 | COM1x0 | 比較出力ピンへの影響                                                                       |             |
|--------|--------|----------------------------------------------------------------------------------|-------------|
| 0      | 0      | OC1x: ピン接続断                                                                      | OC1x: ピン接続断 |
| 0      | 1      | OC1x: 比較一致で解除(Low)、TCNT1=\$00で設定(High)<br>OC1x: 比較一致で設定(High)、TCNT1=\$00で解除(Low) |             |
| 1      | 0      | OC1x: 比較一致で解除(Low)、TCNT1=\$00で設定(High)                                           | OC1x: ピン接続断 |
| 1      | 1      | OC1x: 比較一致で設定(High)、TCNT1=\$00で解除(Low)                                           | OC1x: ピン接続断 |

PWM動作でのOCR1AまたはOCR1B比較レジスタへの書き込みはデータ値が初めに一時領域へ転送されることに注意してください。この値はタイマ/カウンタ1(TCNT1)がOCR1Cに達する時にOCR1AまたはOCR1Bにラッチ(設定)されます。これはOCR1AまたはOCR1Bの非同期の出来事での奇数長PWMパルス(不具合)の発生を防止します。この例については図12-5.をご覧ください。

書き込み(操作)からラッチ動作(実際に設定される)間の期間中、OCR1AまたはOCR1B読み込みは一時領域の内容を読みます。これは最も最近書かれた値が常にOCR1AまたはOCR1Bの読み出しであることを意味します。

OCR1AとOCR1Bは\$00またはOCR1Cで指定した上限値を含むと、OC1A (PB1)またはOC1B(PB4)出力がCOM1A1/COM1A0またはCOM1B1/COM 1B0の設定に従ってHighまたはLowに(更新/)保持されます。これは表12-2.で示されます。

PWM動作での溢れ(TOV1)フラグはタイマ/カウンタ1(TCNT1)がOCR1C値へ計数し、TCNT1が\$00にリセットされる時に設定(1)されます。タイマ/カウンタ1溢れ割り込みはタイマ/カウンタ1溢れ割り込み許可(TOIE1)ビットと全割り込み許可(I)ビットが許可なら、TOV1が設定(1)される時に実行されます。これは比較フラグとその割り込みにも適用されます。

PWM周波数はタイマ/カウンタ1 クロック周波数をOCR1C値+1で割った値です。 次式をご覧ください。

$$f_{\text{PWM}} = \frac{f_{\text{TCK1}}}{\text{OCR1C+1}}$$

分解能はOCR1Cレジスタ内の値を表すのに何ビット必要とされるかを示し、 次式を使って計算できます。

分解能<sub>PWM</sub> = log<sub>2</sub>(OCR1C+1)



表12-2. 上限/下限値でのPWM出力(x=AまたはB)

|   | COM1x1 | COM1x0 | OCR1x | OC1 <mark>x</mark><br>出力 | OC1x<br>出力 |
|---|--------|--------|-------|--------------------------|------------|
|   | 0      | 1      | \$00  | L                        | Н          |
| ı | U      | 1      | OCR1C | Н                        | L          |
|   | 1      | 0      | \$00  | L                        | 接続断        |
| ı | 1      | 0      | OCR1C | Н                        | 接続断        |
| I | 1      | 1      | \$00  | Н                        | 接続断        |
|   | 1      | 1      | OCR1C | L                        | 接続断        |

表12-3 非同期動作での代表的なPWM周波数設定例

| PWM周波数 | PWM周期            | OCR1C値 | 分解能(ビット) | TCNT1クロック | CS13~0  |
|--------|------------------|--------|----------|-----------|---------|
| 20kHz  | 50.00μs          | 199    | 7.6      | PCK/16    | 0 1 0 1 |
| 30kHz  | 33.33µs          | 132    | 7.1      | PCK/16    | 0 1 0 1 |
| 40kHz  | 25 <b>.</b> 00μs | 199    | 7.6      |           |         |
| 50kHz  | 20.00μs          | 159    | 7.3      | PCK/8     | 0 1 0 0 |
| 60kHz  | 16.67µs          | 132    | 7.1      |           |         |
| 70kHz  | 14.29µs          | 228    | 7.8      |           |         |
| 80kHz  | 12.50µs          | 199    | 7.6      |           |         |
| 90kHz  | 11.11µs          | 177    | 7.5      | PCK/4     | 0 0 1 1 |
| 100kHz | 10.00μs          | 159    | 7.3      | PCK/4     | 0 0 1 1 |
| 110kHz | 9.09µs           | 144    | 7.2      |           |         |
| 120kHz | 8.33µs           | 132    | 7.1      |           |         |
| 130kHz | 7.69µs           | 245    | 7.9      |           |         |
| 140kHz | 7.14µs           | 228    | 7.8      |           |         |
| 150kHz | 6.67µs           | 212    | 7.7      |           |         |
| 160kHz | 6.26µs           | 199    | 7.6      | DCV /9    | 0 0 1 0 |
| 170kHz | 5.88µs           | 187    | 7.6      | PCK/2     | 0 0 1 0 |
| 180kHz | 5.56µs           | 177    | 7.5      |           |         |
| 190kHz | 5.26µs           | 167    | 7.4      |           |         |
| 200kHz | 5.00μs           | 159    | 7.3      |           |         |
| 250kHz | 4.00μs           | 255    | 8.0      |           |         |
| 300kHz | 3.34µs           | 212    | 7.7      |           |         |
| 350kHz | 2.86µs           | 182    | 7.5      | DCV       | 0.0.0.1 |
| 400kHz | 2.50µs           | 159    | 7.3      | PCK       | 0 0 0 1 |
| 450kHz | 2.22µs           | 141    | 7.1      |           |         |
| 500kHz | 2.00µs           | 127    | 7.0      |           |         |



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

#### 12.3.1. TCCR1 - タイマ/カウンタ1制御レシ、スタ (Timer/Counter0 Control Register)

| ピット         | 7    | 6     | 5      | 4      | 3    | 2    | 1    | 0    | _     |
|-------------|------|-------|--------|--------|------|------|------|------|-------|
| \$30 (\$50) | CTC1 | PWM1A | COM1A1 | COM1A0 | CS13 | CS12 | CS11 | CS10 | TCCR1 |
| 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 - CTC1: 一致解除許可 (Clear Timer/Counterl on Compare Match)

CTC1制御ビットが設定(1)されると、タイマ/カウンタ1(TCNT1)は比較Cレジスタ(OCR1C)との比較一致後のCPUクロック周期で\$00にリセットされます。この制御ビットが解除(0)されると、タイマ/カウンタ1は計数を継続し、比較一致によって影響を及ぼされません。

#### ● ビット6 - PWM1A: PWM動作A許可 (Pulse Width Modulator A Enable)

このビットを設定(1)すると、タイマ/カウンタ1でOCR1A比較器を基準としたPWM動作を許可し、タイマ/カウンタ値はOCR1C値との比較一致後のCPUクロック周期で\$00にリセットされます。

## ● ビット5,4 - COM1A1,0: 比較A出力選択 (Compare A Output Mode bit 1 and 0)

COM1A1とCOM1A0制御ビットはタイマ/カウンタ1(TCNT1)で比較Aレジスタ(OCR1A)との比較一致に続く何れかの出力ピン動作を決めます。出力ピン動作が入出力ポートの交換機能なので、出力ピンを制御するために、対応する方向制御ビット(DDB1)が設定(1)されなければなりません。

標準動作でのCOM1A1とCOM1A0制御ビットは**表12-4**.で記述されるようにPB1(OC1A)ピンに影響を及ぼす出力ピンの動きを決めます。OC1Aが標準動作で接続されないことに注意してください。

PWM動作でのこれらのビットは異なる機能を持ちます。詳細記述については57頁の表12-1.を参照してください。

ビット3~0 - CS13~0: クロック選択1 (Clock Select1, bit 3,2,1 and 0)
 このクロック選択ビット3,2,1,0はタイマ/カウンタ1の前置分周元を定義します。

| 表12-4. 標 | 準動作での  | )比較A出力選択         |
|----------|--------|------------------|
| COM1A1   | COM1A0 | 意味               |
| 0        | 0      | OC1Aピン未使用(ピン接続断) |
| 0        | 1      | OC1Aピン トグル(交互)出力 |
| 1        | 0      | OC1Aピン Lowレベル出力  |
| 1        | 1      | OC1Aピン Highレベル出力 |

#### 表12-5. タイマ/カウンタ1 前置分周クロック選択

| 0010 | 0010 | 0011 | 0010 | 意           | 味           | 0010 | 0010 | 0011 | 0010 | 意         | 味        |
|------|------|------|------|-------------|-------------|------|------|------|------|-----------|----------|
| CS13 | CS12 | CS11 | CS10 | 非同期動作       | 同期動作        | CS13 | CS12 | CS11 | CS10 | 非同期動作     | 同期動作     |
| 0    | 0    | 0    | 0    | 停止 (タイマ/カウン | 夕1動作停止)     | 1    | 0    | 0    | 0    | PCK/128   | CK/128   |
| 0    | 0    | 0    | 1    | PCK         | CK(CPUクロック) | 1    | 0    | 0    | 1    | PCK/256   | CK/256   |
| 0    | 0    | 1    | 0    | PCK/2       | CK/2        | 1    | 0    | 1    | 0    | PCK/512   | CK/512   |
| 0    | 0    | 1    | 1    | PCK/4       | CK/4        | 1    | 0    | 1    | 1    | PCK/1024  | CK/1024  |
| 0    | 1    | 0    | 0    | PCK/8       | CK/8        | 1    | 1    | 0    | 0    | PCK/2048  | CK/2048  |
| 0    | 1    | 0    | 1    | PCK/16      | CK/16       | 1    | 1    | 0    | 1    | PCK/4096  | CK/4096  |
| 0    | 1    | 1    | 0    | PCK/32      | CK/32       | 1    | 1    | 1    | 0    | PCK/8192  | CK/8192  |
| 0    | 1    | 1    | 1    | PCK/64      | CK/64       | 1    | 1    | 1    | 1    | PCK/16384 | CK/16384 |

停止状態はタイマ/カウンタの許可/禁止機能を提供します。

### 12.3.2. GTCCR - 一般タイマ/カウンタ制御レジスタ (General Timer/Counter Control Register)

| ピット         | 7   | 6     | 5      | 4      | 3     | 2     | 1    | 0    | _     |
|-------------|-----|-------|--------|--------|-------|-------|------|------|-------|
| \$2C (\$4C) | TSM | PWM1B | COM1B1 | COM1B0 | FOC1B | FOC1A | PSR1 | PSR0 | GTCCR |
| Read/Write  | R/W | R/W   | R/W    | R/W    | W     | W     | R/W  | R/W  |       |
| 初期値         | 0   | 0     | 0      | 0      | 0     | 0     | 0    | 0    |       |

#### ● ビット6 - PWM1B: PWM動作B許可 (Pulse Width Modulator B Enable)

このビットを設定(1)すると、タイマ/カウンタ1でOCR1B比較器を基準としたPWM動作を許可し、タイマ/カウンタ値はOCR1C値との比較一致後のCPUクロック周期で\$00にリセットされます。

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

COM1B1とCOM1B0制御ビットはタイマ/カウンタ1(TCNT1)で比較Bレジスタ(OC R1B)での比較一致に続く何れかの出力ピン動作を決めます。出力ピン動作が入出力ポートの交換機能なので、出力ピンを制御するために、対応する方向制御ビット(DDB4)が設定(1)されなければなりません。

標準動作でのCOM1B1とCOM1B0制御ビットは**表12-6**.で記述されるようにPB4(OC1B)ピンに影響を及ぼす出力ピンの動きを決めます。OC1Bが標準動作で接続されないことに注意してください。

PWM動作でのこれらのビットは異なる機能を持ちます。詳細記述については57頁の表12-1.を参照してください。

| 表12-6. 標 | 表12-6. 標準動作での比較B出力選択 |                  |  |  |  |  |  |  |  |  |
|----------|----------------------|------------------|--|--|--|--|--|--|--|--|
| COM1B1   | COM1B0               | 意味               |  |  |  |  |  |  |  |  |
| 0        | 0                    | OC1Bピン未使用(ピン接続断) |  |  |  |  |  |  |  |  |
| 0        | 1                    | OC1Bピン トグル(交互)出力 |  |  |  |  |  |  |  |  |
| 1        | 0                    | OC1Bピン Lowレベル出力  |  |  |  |  |  |  |  |  |
| 1        | 1                    | OC1Bピン Highレベル出力 |  |  |  |  |  |  |  |  |

#### ● ビット3 - FOC1B: OC1B強制変更 (Force Output Compare Match 1B)

このビットへの論理1書き込みは比較B出力制御(COM1B1,COM1B0)ビットで既に設定した値に従って比較一致出力ピンOC1B(PB4)を強制的に変更します。COM1B1とCOM1B0ピットがFOC1Bと同じ周期で書かれる場合、この新しい設定が使われます。この比較出力強制ビットはタイマ/カウンタ値と無関係にこの出力ピンを変更するのに使えます。COM1B1とCOM1B0で設定した自動動作は比較一致が起きてしまったかのようになりますが、割り込みは生成されません。FOC1Bビットは常に0として読めます。PWM1Bビットが設定(1)されると、FOC1Bは行なわれ(実行され)ません。

#### ● ビット2 - FOC1A: OC1A強制変更 (Force Output Compare Match 1A)

このビットへの論理1書き込みは比較A出力制御(COM1A1,COM1A0)ビットで既に設定した値に従って比較一致出力ピンOC1A(PB1)を強制的に変更します。COM1A1とCOM1A0ピットがFOC1Aと同じ周期で書かれる場合、この新しい設定が使われます。この比較出力強制ビットはタイマ/カウンタ値と無関係にこの出力ピンを変更するのに使えます。COM1A1とCOM1A0で設定した自動動作は比較一致が起きてしまったかのようになりますが、割り込みは生成されません。FOC1Aビットは常に0として読めます。PWM1Aビットが設定(1)されると、FOC1Aは行なわれ(実行され)ません。

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

このビットが設定(1)されると、(TCNT1が影響を及ぼされずに)タイマ/カウンタ1の前置分周器がリセットします。このビットは操作が実行された後でハードウェアによって解除(0)されます。このビットへの0書き込みは無効です。このビットは常に0として読めます。

#### 

| ピット         | 7     | 6   | 5   | 4   | 3   | 2   | 1   | 0     | _     |
|-------------|-------|-----|-----|-----|-----|-----|-----|-------|-------|
| \$2F (\$4F) | (MSB) |     |     |     |     |     |     | (LSB) | TCNT1 |
| 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ビットレジスタはタイマ/カウンタ1の値を含みます。

タイマ/カウンタ1は読み書き可能な上昇カウンタとして実現されます。CPUの同期化のため、タイマ/カウンタ1内へのタイマ/カウンタ1データ書き込みは同期動作で1.5CPUクロック周期、非同期動作で最大1CPUクロック周期遅らされます。

#### 12.3.4. OCR1A - タイマ/カウンタ1 比較Aレジスタ (Timer/Counter1 Output Compare Register A)

| ピット         | 7     | 6   | 5   | 4   | 3   | 2   | 1   | 0     |       |
|-------------|-------|-----|-----|-----|-----|-----|-----|-------|-------|
| \$2E (\$4E) | (MSB) |     |     |     |     |     |     | (LSB) | OCR1A |
| 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     |       |

比較Aレシ、スタ(OCR1A)は読み書き可能な8ビットのレシ、スタです。

この比較Aレシ、スタはタイマ/カウンタ1(TCNT1)と継続的に比較されるデータを含みます。比較一致での動作はタイマ/カウンタ1制御レシ、スタ(TC CR1)で指定されます。比較一致はタイマ/カウンタ1がOCR1A値へ計数する場合にだけ起きます。TCNT1とOCR1Aを同一値に設定するソフトウェア書き込みは比較一致を生成しません。

比較一致は比較事象に続く同期化遅延後、比較一致割り込み要求フラグ(OCF1A)を設定(1)します。

#### 12.3.5. OCR1B - タイマ/カウンタ1 比較Bレジスタ (Timer/Counter1 Output Compare Register B)

| ピット         | 7     | 6   | 5   | 4   | 3   | 2   | 1   | 0     |       |
|-------------|-------|-----|-----|-----|-----|-----|-----|-------|-------|
| \$2B (\$4B) | (MSB) |     |     |     |     |     |     | (LSB) | OCR1B |
| 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     |       |

比較Bレジスタ(OCR1B)は読み書き可能な8ビットのレジスタです。

この比較Bレシ、スタはタイマ/カウンタ1(TCNT1)と継続的に比較されるデータを含みます。比較一致での動作はタイマ/カウンタ1制御レシ、スタ(TCC R1)で指定されます。比較一致はタイマ/カウンタ1がOCR1B値へ計数する場合にだけ起きます。TCNT1とOCR1Bを同一値に設定するソフトウェア書き込みは比較一致を生成しません。

比較一致は比較事象に続く同期化遅延後、比較一致割り込み要求フラグ(OCF1B)を設定(1)します。

## 12.3.6. OCR1C - タイマ/カウンタ1 比較Cレジスタ (Timer/Counter1 Output Compare Register C)

| ピット         | 7     | 6   | 5   | 4   | 3   | 2   | 1   | 0     | _     |
|-------------|-------|-----|-----|-----|-----|-----|-----|-------|-------|
| \$2D (\$4D) | (MSB) |     |     |     |     |     |     | (LSB) | OCR1C |
| 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     |       |

比較Cレシブスタ(OCR1C)は読み書き可能な8ビットのレシブスタです。

この比較Bレジスタはタイマ/カウンタ1(TCNT1)と継続的に比較されるデータを含みます。比較一致はタイマ/カウンタ1がOCR1C値へ計数する場合にだけ起きます。TCNT1とOCR1Cを同一値に設定するソフトウェア書き込みは比較一致を生成しません。タイマ/カウンタ1制御レジスタ (TCCR1)でCTC1ビットが設定(1)されると、比較一致はTCNT1を解除(\$00)します。

このレシブスタは標準動作とPWM動作で同じ機能を持ちます。

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

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

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

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

#### • ビット6 - OCIE1A: タイマ/カウンタ1比較A割り込み許可 (Timer/Counter1 Output Compare A Interrupt Enable)

ステータス レシ 、スタ(SREG)の全割り込み許可(I)ビットとOCIE1Aビットが共に設定(1)されると、タイマ/カウンタ1比較A一致割り込みが許可されます。比較A一致が起こると、ヘウタ \$0003 での対応する割り込みが実行されます。このタイマ/カウンタ1の比較フラク (OCF1A)はタイマ/カウンタ割り込み要求フラク 、レシ 、スタ(TIFR)で設定(1)されます。

# ● ビット5 - OCIE1B: タイマ/カウンタ1比較B割り込み許可 (Timer/Counter1 Output Compare B Interrupt Enable)

ステータス レシ スタ(SREG)の全割り込み許可(I) ビットとOCIE1B ビットが共に設定(1)されると、タイマ/カウンタ1比較B一致割り込みが許可されます。比較B一致が起こると、 ベクタ\$0009での対応する割り込みが実行されます。このタイマ/カウンタ1の比較フラグ(OCF1B)はタイマ/カウンタ割り込み要求フラグ レシ スタ(TIFR)で設定(1)されます。

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

ステータス レシ 、スタ(SREG)の全割り込み許可(I) ビットと、TOIE1 ビットが共に設定(1)されると、タイマ/カウンタ1溢れ割り込みが許可されます。タイマ/カウンタ1溢れが起こると、(ヘ、クタ\$004での)対応する割り込みが実行されます。溢れ(TOV1)フラク はタイマ/カウンタ割り込み要求フラク レシ スタ(TIFR)で設定(1)されます。

# 12.3.8. TIFR - タイマ/カウンタ割り込み要求フラク・レシ、スタ (Timer/Counter Interrupt Flag Register)

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

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

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

#### ● ビット6 - OCF1A: 比較A割り込み要求フラグ(Output Compare Interrupt Flag1A)

タイマ/カウンタ1と比較Aレシ、スタ(OCR1A)内のデータ値間で比較一致が起きると、OCF1Aビットが設定(1)されます。OCF1Aは対応する割り込み処理へ、クタを実行するとき、ハート・ウェアによって解除(0)されます。代わりにOCF1Aはこのフラク、への論理1書き込みにより、同期化クロック周期後に解除(0)されます。ステータスレシ、スタ(SREG)の全割り込み許可(I)ビット、タイマ/カウンタ割り込み許可レシ、スタ(TIMSK)の比較A割り込み許可(OCIE1A)ビットとOCF1Aが設定(1)なら、タイマ/カウンタ1比較A一致割り込みが実行されます。

#### ● ビット5 - OCF1B : 比較B割り込み要求フラグ(Output Compare Interrupt Flag1B)

gイマ/カウンタ1と比較Bレシ、スタ(OCR1B)内のデータ値間で比較一致が起きると、OCF1Bビットが設定(1)されます。OCF1Bは対応する割り込み処理へ、クタを実行するとき、ハートウェアによって解除(0)されます。代わりにOCF1Bはこのフラク、への論理1書き込みにより、同期化クロック周期後に解除(0)されます。ステータスレシ、スタ(SREG)の全割り込み許可(I)ビット、TIMSKの比較B割り込み許可(OCIE1B)ビットとOCF1Bが設定(1)なら、タイマ/カウンタ1比較B一致割り込みが実行されます。

# ● ビット2 - TOV1: タイマ/カウンタ1溢れ割り込み要求フラグ(Timer/Counter1 Overflow Interrupt Flag)

標準動作(PWM1A=0且つPWM1B=0)でのTOV1はタイマ/カウンタ1溢れが起きると設定(1)されます。TOV1は対応する割り込み処理へクタを実行するとき、ハートヴェアによって解除(0)されます。代わりにTOV1はこのフラグへの論理1書き込みにより、同期化クロック周期後に解除(0)されます。

PWM動作(PWM1A=1またはPWM1B=1)でのTOV1はタイマ/カウンタ1と比較Cレジスタ(OCR1C)内のデータ値間で比較一致が起こる時に設定(1)されます。

ステータス レジ スタ(SREG)の全割り込み許可(I)ビット、タイマ/カウンタ割り込み許可レシ スタ(TIMSK)のタイマ/カウンタ1溢れ割り込み許可(TOIE1) ビットとTOV1が設定(1)の時にタイマ/カウンタ1溢れ割り込みが実行されます。



## 12.3.9. PLLCSR - PLL制御/状態レジスタ (PLL Control and Status Register)

| ピット         | 7   | 6 | 5 | 4 | 3 | 2    | 1    | 0     |        |
|-------------|-----|---|---|---|---|------|------|-------|--------|
| \$27 (\$47) | LSM | - | - | - | - | PCKE | PLLE | PLOCK | PLLCSR |
| Read/Write  | R/W | R | R | R | R | R/W  | R/W  | R     |        |
| 初期値         | 0   | 0 | 0 | 0 | 0 | 0    | 1/0  | 0     |        |

#### ● ビット7 - LSM: 低速動作(Low Speed Mode)

高速動作が既定として許可され、高速周辺クロックは64MHzですが、LSMビットに1を書くことによって低速動作に設定できます。そして高速周辺クロックは32MHzに下げられます。タイマ/カウンタ1が低電圧状態で充分速く走行できないので、供給電圧が2.7V以下の場合、低速動作が設定されなければなりません。LSMビットが変更される時に必ずタイマ/カウンタ1は停止されていることが強く推奨されます。PLLclkがシステム クロックとして使われる場合、LSMが設定(1)できないことに注意してください。

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

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

#### ● ビット2 - PCKE: PCK許可 (PCK Enable)

PCKEt'ットはタイマ/カウンタ1のクロック元を変更します。設定(1)されると、非同期クロック動作が許可され、タイマ/カウンタ1のクロック元として高速 64MHz(または低速動作で32MHz)のPCKクロックが使われます。このt'ットが解除(0)されると、同期クロック動作が許可され、タイマ/カウンタ1のクロック元としてシステム クロック(CK)が使われます。このt'ットはPLLEt'ットが設定(1)されている場合にだけ設定(1)できます。PLLが固定 化される、換言するとPLOCKt'ットが1の時にだけ、このt'ットを設定(1)するのが無難です。PCKEt'ットは先にPLLが許可されてしまっている場合にだけ設定できます。

#### ● ビット1 - PLLE: PLL許可 (PLL Enable)

PLLEが設定(1)されると、PLLが起動され、必要とされるなら、PLL基準クロックとして内蔵RC発振器が起動されます。システム クロック元としてPLLが選択されると、このビットに対する値は常に1です。

#### ● ビット0 - PLOCK : PLL固定化検出 (PLL Lock Detector)

PLOCKビットが設定(1)されると、PLLが基準クロックに固定化されます。PLL周波数が上下超過する初期PLL固定化の間、PLOCKビットは無視されるべきです。安定状態は100 $\mu$ s以内に得られます。PLL固定化後、タイマ/カウンタ1に対してPCKを許可する前にPLOCKビットの調査が推奨されます。



# 13. ATtiny15互換動作での8ビット タイマ/カウンタ1

ATtiny15互換動作はCKSELヒューズに'0011'を書くことによって選択されます(他の何れかの符号が書かれると、タイマ/カウンタ1は標準動作で動きます)。選択されると、ATtiny15互換動作はATtiny15下位互換の前置分周器とタイマ/カウンタを提供します。更にクロック系はATtiny15と同じクロック周波数を持ちます。

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

図13-1.はATtiny15互換前置分周器を示します。これはシステム クロック(CK)用の10ビット前置分周器と、高速周辺クロック(PCK)用の3ビット前置分周器の、2つの前置分周器部を持ちます。タイマ/カウンタ1のクロック系はATtiny15互換動作で、AVRコアと(前置分周器に対して入力クロックを生成する)PLLクロック元として同じRC発振器が使われるため、常に同期しています。

ATtiny15互換動作で前置分周器が同一、且つ高速周辺クロックの周波数が25.6MHzなので、出力多重器からタイマ/カウンタ1に対してATtiny15と同じクロック選択が選べます。このクロック選択は、PCK, PCK/2, PCK/4, PCK/8. CK(PCK/16), CK/2, CK/4, CK/8, CK/16, CK/32, CK/64, CK/128, CK/256, CK/512, CK/1024と停止です。



#### 13.2. タイマ/カウンタ1

図13-2.はタイマ/カウンタ1同期化レシ、スタ構成図とレシ、スタ間の同期化遅延を示します。全クロック ケート詳細がこの図で示されないことに注意してください。タイマ/カウンタ1のレシ、スタ値はカウンタ動作に影響を及ぼす前に入力同期化遅延を引き起こす内部同期化レシ、スタを通ります。TCCR1,GTCCR,OCR1A,OCR1Cはレシ、スタ書き込み後、正しく読み戻せます。読み戻し値はタイマ/カウンタ1(TCNT1)とOCF1A,TOV 1フラグに関して入出力同期化のために遅らされます。

このタイマ/カウンタ1は低前置分周(使用)機会での高分解能及び高精度の使用が特徴です。25.6MHzまでのクロック速度を使う正確で高速な2つの8ビット PWMも支援できます。この動作でタイマ/カウンタ1と比較レシ、スタは重複しない反転と非反転出力の2つの自立型PWMとして取り扱います。この機能の詳細記述については66頁の「ATtiny15互換動作でのタイマ/カウンタ1 PWM動作」を参照してください。同様に高前置分周(使用)機会は低速な目的やまれに動く正確なタイシングの目的についてこの部署を有用にします。





タイマ/カウンタ1と前置分周器は、前置分周器が非同期動作で高速25.6MHzのPCKクロック動作をする一方、どのクロック元からもCPUの走行(動作)を許します。

次の図13-3.はタイマ/カウンタ1の構成図を示します。



2つの状態フラグ(溢れと比較一致)はタイマ/カウンタ割り込み要求フラグ レシ、スタ(TIFR)にあります。制御信号はタイマ/カウンタ1制御レシ、スタ(TC CR1)と一般タイマ/カウンタ制御レシ、スタ(GTCCR)にあります。割り込みの許可/禁止設定はタイマ/カウンタ割り込み許可レジ、スタ(TIMSK)にあります。

gイマ/カウンg1はgイマ/カウンg1の内容と比較されるデーg元としてg2つの比較レシブスg、OCR1A、OCR1Cを含みます。標準動作での出力比較機能はOCR1Aとだけの動作です。OCR1AはOC1A(PB1)ピンの動作を決め、標準動作とPWM動作で比較A割り込みを生成できます。OCR1Cはg4マ/カウンg1の最大値、換言すると比較一致での解除値を保持します。標準動作での溢れ割り込み(TOV1)はg4マ/カウンg1がg7Fからg800に計数する時に生成され、一方PWM動作での溢れ割り込みはg4マ/カウンg1がg7Fからg800に計数する時のどちらでも生成されます。

PWM動作でのOCR1Aはタイマ/カウンタ値が繰り返し比較されるデータ値を供給します。比較一致でPWM出力(OC1A)が生成されます。PWM動作でのタイマ/カウンタは比較Cレシ、スタ(OCR1C)で指定した値まで上昇計数し、そして再び\$00から始めます。この特性は\$FFよりも小さい指定値へのカウンタ最大値制限を許します。多くの前置分周器任意選択と共に柔軟なPWM周波数選択が提供されます。表13-3.は10kHz単位の10kHz~150kHzのPWM周波数を得るためのOCR1C値とクロック選択の一覧を示します。より高いPWM周波数は分解能を犠牲にすれば得られます。



# 13.2.1. ATtiny15互換動作時 タイマ/カウンタ1 PWM動作

PWM動作が選択されると、タイマ/カウンタ1(TCNT1)と比較Aレジスタ(OCR1A)は自由走行で不具合のない8ビットPWMとOC1A(PB1)ピン出力を形成します。

タイマ/カウンタ1(TCNT1)値が比較Aレシ、スタ(OCR1A)の内容と一致すると、表13-1.で示されるようにタイマ/カウンタ1制御レシ、スタ(TCCR1)の比較出力選択(COM1A1,COM1A0)の指定に従って、OC1A(PB1)ピンが設定(High)または解除(Low)されます。

タイマ/カウンタ1は上昇カウンタとして動作し、\$00から比較Cレシ、スタ(OCR1C)で指定された値まで上昇計数し、そして再び\$00から上昇を始めます。OCR1Cとの比較一致は比較事象に続く同期化遅延後に溢れ割り込み要求(TOV1)フラグを設定(1)します。

表13-1. PWM出力選択 (比較出力選択と兼用)

| COM1A1 | COM1A0 | OC1A(PB1)出力                              |  |  |  |  |  |  |
|--------|--------|------------------------------------------|--|--|--|--|--|--|
| 0      | 0      | OC14出力担係 (DD1)け無準I /Oよ! で動作)             |  |  |  |  |  |  |
| 0      | 1      | DC1A出力切断 (PB1は標準I/Oとして動作)                |  |  |  |  |  |  |
| 1      | 0      | OCR1Aとの比較一致で解除(Low)、TCNT1=\$00時に設定(High) |  |  |  |  |  |  |
| 1      | 1      | OCR1Aとの比較一致で設定(High)、TCNT1=\$00時に解除(Low) |  |  |  |  |  |  |

PWM動作での比較Aレシ、スタ(OCR1A)書き込みはデータ値が最初に一時領域へ転送されることに注意してください。その値はタイマ/カウンタがOCR1Cに到達する時にOCR1Aへラッチ(設定)されます。これはOCR1A非同期書き込みでの奇数長PWMパルス(不具合)の発生を防止します。この例については図13-4.を参照してください。

書き込み(操作)からラッチ動作(実際に設定される)間の期間中、OCR1Aからの読み込みは一時領域の内容が読まれます。これは常に最も最近書かれた値がOCR1Aの読み出しとなることを意味します。

比較Aレジスタ(OCR1A)が\$00またはOCR1Cで指定される上限値のとき、OC1A(PB1)出力はCOM1A1/COM1A0の設定に従ってHighまたはLowに保持されます。これは表13-2.で示されます。

PWM動作での溢れ(TOV1)フラケ はタイマ/カウンタ1(TCNT1)がOCR1C値へ計数し、TC NT1が \$00にリセットされる時に設定(1)されます。タイマ/カウンタ1溢れ割り込み許可(TOIE1)ビットと全割り込み許可(I)ビットが許可なら、TOV1が設定(1)される時に実行されます。これは比較フラケ とその割り込みにも適用されます。

PWM周波数は次式を使ってタイマ/カウンタ1 クロック周波数から得られます。

$$f_{\text{PWM}} = \frac{f_{\text{TCK1}}}{\text{OCR1C+1}}$$

PWM波形のデューティ比は次式を使用して計算できます。

$$\vec{\tau}^* = -\vec{\tau} + \text{th}_{\text{PWM}} = \frac{(\text{OCR1A+1}) \times T_{\text{TCK1}} - T_{\text{PCK}}}{(\text{OCR1C+1}) \times T_{\text{TCK1}}}$$

ここで TPCK は高速周辺クロックの周期(1/25.6MHz=39.1µs)です。

分解能はOCR1C内の値を表すのに何ビット必要とされるかを示します。これは次式を使って計算できます。

# 分解能<sub>PWM</sub> = log<sub>2</sub>(OCR1C+1)

# 

| 表13-2. 上 | 限値、下限  | 値でのPV | WM出力   |  |  |
|----------|--------|-------|--------|--|--|
| COM1A1   | COM1A0 | OCR1A | OC1A出力 |  |  |
| 0        | 1      | \$00  | L      |  |  |
| 0        | 1      | OCR1C | Н      |  |  |
| 1        | 0      | \$00  | L      |  |  |
| 1        | U      | OCR1C | Н      |  |  |
| 1        | 1      | \$00  | Н      |  |  |
| 1        | 1      | OCR1C | L      |  |  |

| 表13-3. 代表的なPWM周波数設定 |
|---------------------|
|---------------------|

| PWM<br>周波数 | PWM<br>周期 | OCR1C<br>値 | 分解能<br>(ビット) | TCNT1<br>クロック | CS13~0  | PWM<br>周波数 | PWM<br>周期 | OCR1C<br>値 | 分解能 (ビット) | TCNT1<br>クロック | CS13~0 |
|------------|-----------|------------|--------------|---------------|---------|------------|-----------|------------|-----------|---------------|--------|
| 10kHz      | 100.00µs  | 159        | 7.3          | CK            | 0 1 0 1 | 90kHz      | 11.11µs   | 141        | 7.1       | PCK/2         | 0010   |
| 20kHz      | 50.00µs   | 159        | 7.3          | PCK/8         | 0 1 0 0 | 100kHz     | 10.00µs   | 255        | 8.0       |               |        |
| 30kHz      | 33.33µs   | 213        | 7.7          | PCK/4         | 0 0 1 1 | 110kHz     | 9.09µs    | 231        | 7.8       |               |        |
| 40kHz      | 25.00µs   | 159        | 7.3          | PCK/4         | 0011    | 120kHz     | 8.33µs    | 213        | 7.7       | PCK           | 0001   |
| 50kHz      | 20.00µs   | 255        | 8.0          |               |         | 130kHz     | 7.69µs    | 195        | 7.6       | PCK           | 0001   |
| 60kHz      | 16.67µs   | 213        | 7.7          | PCK/2         | 0010    | 140kHz     | 7.14µs    | 181        | 7.5       |               |        |
| 70kHz      | 14.29µs   | 199        | 7.6          | FCK/2         | 0010    | 150kHz     | 6.67µs    | 169        | 7.6       |               |        |
| 80kHz      | 12.50µs   | 181        | 7.5          |               |         |            |           |            |           |               |        |

# 13.3. ATtiny15互換動作 8ビット タイマ/カウンタ1 用レジスタ

#### 13.3.1. TCCR1 - タイマ/カウンタ1制御レシ、スタ (Timer/Counter0 Control Register)

| ピット         | 7    | 6     | 5      | 4      | 3    | 2    | 1    | 0    | _     |
|-------------|------|-------|--------|--------|------|------|------|------|-------|
| \$30 (\$50) | CTC1 | PWM1A | COM1A1 | COM1A0 | CS13 | CS12 | CS11 | CS10 | TCCR1 |
| 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    |       |

#### ● ビットフ - CTC1: 一致解除許可 (Clear Timer/Counter1 on Compare Match)

CTC1制御ビットが設定(1)されると、タイマ/カウンタ1(TCNT1)は比較Cレジスタ(OCR1C)との比較一致後のCPUクロック周期で\$00にリセットされます。この制御ビットが解除(0)されると、タイマ/カウンタ1は計数を継続し、比較一致によって影響を及ぼされません。

# ● ビット6 - PWM1A: PWM動作A許可 (Pulse Width Modulator A Enable)

このビットを設定(1)すると、タイマ/カウンタ1でOCR1A比較器を基準としたPWM動作を許可し、タイマ/カウンタ値はOCR1C値との比較一致後のCPUクロック周期で\$00にリセットされます。

## ● ビット5,4 - COM1A1,0:比較A出力選択(Compare A Output Mode bit 1 and 0)

COM1A1とCOM1A0制御ビットはタイマ/カウンタ1(TCNT1)で比較Aレジスタ(OCR1A)との比較一致に続く何れかの出力ピン動作を決めます。出力ピン動作はOC1A(PB1)ピンに影響を及ぼします。これは入出力ポートの交換機能なので、出力ピンを制御するには対応する方向制御ビット(DDB1)が設定(1)されなければなりません。

PWM動作でのこれらのビットは異なる機能を持ちます。詳細記述については66頁の表13-1.を参照してください。

| 表13-4. 比 | 較A出力選  | 択                |
|----------|--------|------------------|
| COM1A1   | COM1A0 | 意味               |
| 0        | 0      | OC1Aピン未使用(ピン接続断) |
| 0        | 1      | OC1Aピン トグル(交互)出力 |
| 1        | 0      | OC1Aピン Lowレベル出力  |
| 1        | 1      | OC1Aピン Highレベル出力 |

# • ビット3~0 - CS13~0: クロック選択1 (Clock Select1, bit 3,2,1 and 0)

このクロック選択ビット3,2,1,0はタイマ/カウンタ1の前置分周元を定義します。

#### 表13-5. タイマ/カウンタ1 前置分周クロック選択

| CS13 | CS12 | CS11 | CS10 | 意味                | CS13 | CS12 | CS11 | CS10 | 意味      |
|------|------|------|------|-------------------|------|------|------|------|---------|
| 0    | 0    | 0    | 0    | 停止(タイマ/カウンタ1動作停止) | 1    | 0    | 0    | 0    | CK/8    |
| 0    | 0    | 0    | 1    | CK×16 (PCK)       | 1    | 0    | 0    | 1    | CK/16   |
| 0    | 0    | 1    | 0    | CK×8 (PCK/2)      | 1    | 0    | 1    | 0    | CK/32   |
| 0    | 0    | 1    | 1    | CK×4 (PCK/4)      | 1    | 0    | 1    | 1    | CK/64   |
| 0    | 1    | 0    | 0    | CK×2 (PCK/8)      | 1    | 1    | 0    | 0    | CK/128  |
| 0    | 1    | 0    | 1    | CK (システム クロック)    | 1    | 1    | 0    | 1    | CK/256  |
| 0    | 1    | 1    | 0    | CK/2              | 1    | 1    | 1    | 0    | CK/512  |
| 0    | 1    | 1    | 1    | CK/4              | 1    | 1    | 1    | 1    | CK/1024 |

停止状態はタイマ/カウンタの許可/禁止機能を提供します。

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

| ピット         | 7   | 6     | 5      | 4      | 3     | 2     | 1    | 0    |       |
|-------------|-----|-------|--------|--------|-------|-------|------|------|-------|
| \$2C (\$4C) | TSM | PWM1B | COM1B1 | COM1B0 | FOC1B | FOC1A | PSR1 | PSR0 | GTCCR |
| Read/Write  | R/W | R/W   | R/W    | R/W    | W     | W     | R/W  | R/W  |       |
| 初期値         | 0   | 0     | 0      | 0      | 0     | 0     | 0    | 0    |       |

#### ● ビット2 - FOC1A: OC1A強制変更 (Force Output Compare Match 1A)

このビットへの論理1書き込みは比較A出力制御(COM1A1,COM1A0)ビットで既に設定した値に従って比較一致出力ピンOC1A(PB1)を強制的に変更します。COM1A1とCOM1A0ピットがFOC1Aと同じ周期で書かれる場合、この新しい設定が使われます。この比較出力強制ビットはタイマ/カウンタ値と無関係にこの出力ピンを変更するのに使えます。COM1A1とCOM1A0で設定した自動動作は比較一致が起きてしまったかのようになりますが、割り込みは生成されません。FOC1Aビットは常に0として読めます。PWM1Aビットが設定(1)されると、FOC1Aは行なわれ(実行され)ません。

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

このビットが設定(1)されると、(TCNT1が影響を及ぼされずに)タイマ/カウンタ1の前置分周器がリセットします。このビットは操作が実行された後、ハードウェアによって解除(0)されます。このビットへの0書き込みは無効です。このビットは常に0として読めます。



#### 13.3.3. TCNT1 - タイマ/カウンタ1 (Timer/Counter1)

| ピット         | 7     | 6   | 5   | 4   | 3   | 2   | 1   | 0     | _     |
|-------------|-------|-----|-----|-----|-----|-----|-----|-------|-------|
| \$2F (\$4F) | (MSB) |     |     |     |     |     |     | (LSB) | TCNT1 |
| 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ビットレジスタはタイマ/カウンタ1の値を含みます。

タイマ/カウンタ1は読み書き可能な上昇カウンタとして実現されます。CPUの同期化のため、タイマ/カウンタ1内へのタイマ/カウンタ1データ書き込みは同期動作で1CPUクロック周期、非同期動作で最大2CPUクロック周期遅らされます。

#### 13.3.4. OCR1A - タイマ/カウンタ1 比較Aレジスタ (Timer/Counter1 Output Compare Register A)

| ピット         | 7     | 6   | 5   | 4   | 3   | 2   | 1   | 0     |       |
|-------------|-------|-----|-----|-----|-----|-----|-----|-------|-------|
| \$2E (\$4E) | (MSB) |     |     |     |     |     |     | (LSB) | OCR1A |
| 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     |       |

比較Aレシ、スタ(OCR1A)は読み書き可能な8ビットのレシ、スタです。

この比較Aレシ、スタはタイマ/カウンタ1(TCNT1)と継続的に比較されるデータを含みます。比較一致での動作はタイマ/カウンタ1制御レシ、スタ(TC CR1)で指定されます。比較一致はタイマ/カウンタ1がOCR1A値へ計数する場合にだけ起きます。TCNT1とOCR1Aを同一値に設定するソフトウェア書き込みは比較一致を生成しません。

比較一致は比較事象に続く同期化遅延後、比較一致割り込み要求フラグ(OCF1A)を設定(1)します。

# 13.3.5. OCR1C - タイマ/カウンタ1 比較Cレジスタ (Timer/Counter1 Output Compare Register C)

| ピット         | 7     | 6   | 5   | 4   | 3   | 2   | 1   | 0     |       |
|-------------|-------|-----|-----|-----|-----|-----|-----|-------|-------|
| \$2D (\$4D) | (MSB) |     |     |     |     |     |     | (LSB) | OCR1C |
| 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     |       |

比較Cレジスタ(OCR1C)は読み書き可能な8ビットのレジスタです。

この比較Bレジスタはタイマ/カウンタ1(TCNT1)と継続的に比較されるデータを含みます。比較一致はタイマ/カウンタ1がOCR1C値へ計数する場合にだけ起きます。TCNT1とOCR1Cを同一値に設定するソフトウェア書き込みは比較一致を生成しません。タイマ/カウンタ1制御レジスタ(TCCR1)でCTC1ビットが設定(1)されると、比較一致はTCNT1を解除(\$00)します。

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

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

ヒット7.0 - Res: 予約 (Reserved)

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

# ● ビット6 - OCIE1A: タイマ/カウンタ1比較A割り込み許可 (Timer/Counter1 Output Compare A Interrupt Enable)

ステータスレシ、スタ(SREG)の全割り込み許可(I)ビットとOCIE1Aビットが共に設定(1)されると、タイマ/カウンタ1比較A一致割り込みが許可されます。比較A一致が起こると、ベクタ\$0003での対応する割り込みが実行されます。このタイマ/カウンタ1の比較フラグ(OCF1A)はタイマ/カウンタ割り込み要求フラグ、レシ、スタ(TIFR)で設定(1)されます。

● ビット2 - TOIE1 : タイマ/カウンタ1溢れ割り込み許可 (Timer/Counterl Overflow Interrupt Enable)

ステータスレジスタ(SREG)の全割り込み許可(I)ビットと、TOIE1ビットが共に設定(1)されると、タイマ/カウンタ1溢れ割り込みが許可されます。タイマ/カウンタ1溢れが起こると、(ベクタ\$004での)対応する割り込みが実行されます。溢れ(TOV1)フラク はタイマ/カウンタ割り込み要求フラク レジスタ(TIFR)で設定(1)されます。

## 13.3.7. TIFR - タイマ/カウンタ割り込み要求フラク・レシ、スタ (Timer/Counter Interrupt Flag Register)

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

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

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

#### ● ビット6 - OCF1A: 比較A割り込み要求フラグ(Output Compare Interrupt Flag1A)

タイマ/カウンタ1と比較Aレシ、スタ(OCR1A)内のデータ値間で比較一致が起きると、OCF1Aビットが設定(1)されます。OCF1Aは対応する割り込み処理へ、クタを実行するとき、ハート・ウェアによって解除(0)されます。代わりにOCF1Aはこのフラケ、への論理1書き込みにより、同期化クロック周期後に解除(0)されます。ステータスレシ、スタ(SREG)の全割り込み許可(I)ビット、タイマ/カウンタ割り込み許可レシ、スタ(TIMSK)の比較A割り込み許可(OCIE1A)ビットとOCF1Aが設定(1)なら、タイマ/カウンタ1比較A一致割り込みが実行されます。

#### ● ビット2 - TOV1 : タイマ/カウンタ1溢れ割り込み要求フラグ(Timer/Counter1 Overflow Interrupt Flag)

TOV1はタイマ/カウンタ1溢れが起きると設定(1)されます。TOV1は対応する割り込み処理へ、クタを実行するとき、ハートウェアによって解除(0)されます。代わりにTOV1はこのフラグへの論理1書き込みにより、同期化クロック周期後に解除(0)されます。ステータスレジ、スタ(SREG)の全割り込み許可(I)ビット、タイマ/カウンタ割り込み許可レジ、スタ(TIMSK)のタイマ/カウンタ1溢れ割り込み許可(TOIE1)ビットとTOV1が設定(1)の時にタイマ/カウンタ1溢れ割り込みが実行されます。

## 13.3.8. PLLCSR - PLL制御/状態レジスタ (PLL Control and Status Register)

| ピット         | 7   | 6 | 5 | 4 | 3 | 2    | 1    | 0     |        |
|-------------|-----|---|---|---|---|------|------|-------|--------|
| \$27 (\$47) | LSM | - | - | - | - | PCKE | PLLE | PLOCK | PLLCSR |
| Read/Write  | R   | R | R | R | R | R/W  | R/W  | R     |        |
| 初期値         | 0   | 0 | 0 | 0 | 0 | 1    | 1    | 0     |        |

● ビット7 - LSM: 低速動作(Low Speed Mode)

LSBビットはATtiny15互換動作で常に解除(0)されます。

ビット6~3 - Res: 予約 (Reserved)

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

● ビット2 - PCKE: PCK許可 (PCK Enable)

PCKEビットはATtiny15互換動作で常に設定(1)されます。

● ビット1 - PLLE: PLL許可 (PLL Enable)

PLLはATtiny15互換動作で常に許可されます。

● ビット0 - PLOCK: PLL固定化検出(PLL Lock Detector)

PLOCKビットが設定(1)されると、PLLが基準クロックに固定化されます。PLL周波数が上下超過する初期PLL固定化の間、PLOCKビットは無視されるべきです。安定状態は100μs以内に得られます。PLL固定化後、タイマ/カウンタ1に対してPCKを許可する前にPLOCKビットの調査が推奨されます。

# 14. 沈黙時間生成器 (Dead Time Generator)

沈黙時間生成器は外部電力制御スィッチの安全な駆動を可能とするためにタイマ/カウンタ1のPWM出力対に対して提供されます。この沈黙時間生成器はタイマ/カウンタ1に接続できる独立部で、タイマ/カウンタ1相互補完出力対(OC1A, OC1A, OC1B, OC1B)に対して沈黙時間(非重複時間)の挿入に使われます。作業の分担は次のとおりです。タイマ/カウンタがPWM出力を生成し、沈黙時間生成器がタイマ/カウンタのPWM信号から非重複PWM出力を生成します。各々のPWM出力に対して1つで、(計)2つの沈黙時間生成器が提供されます。PWM出力の非重複時間は調整可能で、この相互補完出力は独立して調整でき、両PWM出力(A,B間)に対して無関係です。



沈黙時間生成器は図14-2.で示されるように沈黙時間を計数する4ビット下降計数器に基きます。これはタイマ/カウンタ1 クロック(CKまたはPCK)を1,2,4,8分周できる沈黙時間生成器前の専用前置分周器です。これは生成可能な広範囲の沈黙時間を提供します。この前置分周器は沈黙時間前置分周レジスタ(DTPS1)からDTPS11,DTPS10の2つの制御ビットによって制御されます。本部署には沈黙時間計時区間を開始するのに使われる上昇端と下降端の検出器もあります。このエッジに対応してOC1xまたはOC1xの上昇端の遷移はこの(4ピット)計数器が0へ計数されるまで遅らされます。比較器は計数器と0との比較に使われ、0に達した時に沈黙時間挿入を止めます。この計数器は沈黙時間挿入を開始する時にPWM生成器出力のエッジに対応するDT1x I/OレジスタからDT1xHまたはDT1xLの4ビット値が読み込まれます。



この計数時間長は沈黙時間前置分周レジスタ(DTPS1)の沈黙時間前置分周器設定と沈黙時間x(DT1x)レジスタの沈黙時間値選択によって使用者調整が可能です。沈黙時間x(DT1x)レジスタはPWM出力の沈黙時間と相互補完出力を独立して制御するDT1xHとDT1xLの2つの4xEが上がです。従ってOC1xEのC1xEの上昇端は異なる沈黙時間を持ちます。この沈黙時間は前置分周された沈黙時間生成器クロック周期数として調節されます。





# 14.1. タイマ/カウンタ1 沈黙時間用レジスタ

## 14.1.1. DTPS1 - タイマ/カウンタ1 沈黙時間前置分周レジスタ (Timer/Counter 1 Dead Time Prescaler Register)

| ピット         | 7 | 6 | 5 | 4 | 3 | 2 | 1      | 0      |       |
|-------------|---|---|---|---|---|---|--------|--------|-------|
| \$23 (\$43) | - | - | - | - | - | - | DTPS11 | DTPS10 | DTPS1 |
| Read/Write  | R | R | R | R | R | R | R/W    | R/W    |       |
| 初期値         | 0 | 0 | 0 | 0 | 0 | 0 | 0      | 0      |       |

沈黙時間前置分周レシ、スタ(DTPS1)は2ビットの読み書き可能なレシ、スタです。

## ● ビット1,0 - DTPS11,0: 沈黙時間前置分周選択 (Dead Time Prescaler)

沈黙時間生成器前の沈黙時間専用前置分周器はタイマ/カウンタ1クロック(CKまたはPCK)を1,2,4,8分周ができ、広い沈黙時間範囲生成を提供します。この前置分周器は沈黙時間前置分周レジスタ(DTPS1)からDTPS11,DTPS10の2つの制御ビットによって制御されます。これらのビットは沈黙時間前置分周器の分周値を定義します。この分周値は表14-1.で与えられます。

| 表14-1. 沈 | 黙時間前置  | 置分周器の分周値          |
|----------|--------|-------------------|
| DTPS11   | DTPS10 | タイマ/カウンタ1 クロック分周数 |
| 0        | 0      | 1 (分周なし)          |
| 0        | 1      | 2分周               |
| 1        | 0      | 4分周               |
| 1        | 1      | 8分周               |

### 14.1.2. DT1A - タイマ/カウンタ1 沈黙時間A レジスタ (Timer/Counter 1 Dead Time A Register)

| ピット         | 7      | 6      | 5      | 4      | 3      | 2      | 1      | 0      |     |
|-------------|--------|--------|--------|--------|--------|--------|--------|--------|-----|
| \$25 (\$45) | DT1AH3 | DT1AH2 | DT1AH1 | DT1AH0 | DT1AL3 | DT1AL2 | DT1AL1 | DT1AL0 | DT1 |
| Read/Write  | R/W    |     |
| 初期値         | 0      | 0      | 0      | 0      | 0      | 0      | 0      | 0      |     |

沈黙時間Aレシ、スタ(DT1A)は8ビットの読み書き可能なレシ、スタです。

沈黙時間遅延は沈黙時間Aレジスタ(DT1A)によって調節されます。このレジスタは各相互補完出力について1組の、DT1AH3~0とDT1AL3~0の2つの領域から成ります。従ってOC1Aの上昇端とOC1Aの上昇端に対して異なる沈黙時間遅延に調節できます。

#### ● ビット7~4 - DT1AH3~0: OC1A沈黙時間 (Dead Time Value for OC1A Output)

OC1Aに対する沈黙時間値です。沈黙時間遅延は前置分周したタイマ/カウンタ1 クロック数として設定されます。最小沈黙時間は0で、最大沈黙時間は前置分周したタイマ/カウンタ1 クロック周期×15です。

#### ● ビット3~0 - DT1AL3~0: OC1A沈黙時間 (Dead Time Value for OC1A Output)

OC1Aに対する沈黙時間値です。沈黙時間遅延は前置分周したタイマ/カウンタ1 クロック数として設定されます。最小沈黙時間は0で、最大沈黙時間は前置分周したタイマ/カウンタ1 クロック周期×15です。

# 14.1.3. DT1B - タイマ/カウンタ1 沈黙時間B レシ スタ (Timer/Counter 1 Dead Time B Register)

| ピット         | 7      | 6      | 5      | 4      | 3      | 2      | 1      | 0      |
|-------------|--------|--------|--------|--------|--------|--------|--------|--------|
| \$24 (\$44) | DT1BH3 | DT1BH2 | DT1BH1 | DT1BH0 | DT1BL3 | DT1BL2 | DT1BL1 | DT1BL0 |
| Read/Write  | R/W    |
| 初期値         | 0      | 0      | 0      | 0      | 0      | 0      | 0      | 0      |

沈黙時間Bレシ、スタ(DT1A)は8ビットの読み書き可能なレシ、スタです。

沈黙時間遅延は沈黙時間Bレジスタ(DT1B)によって調節されます。このレジスタは各相互補完出力について1組の、DT1BH3~0と DT1BL3~0の2つの領域から成ります。従ってOC1Bの上昇端とOC1Bの上昇端に対して異なる沈黙時間遅延に調節できます。

#### ● ビット7~4 - DT1BH3~0: OC1B沈黙時間 (Dead Time Value for OC1B Output)

OC1Bに対する沈黙時間値です。沈黙時間遅延は前置分周したタイマ/カウンタ1 クロック数として設定されます。最小沈黙時間は0で、最大沈黙時間は前置分周したタイマ/カウンタ1 クロック周期×15です。

#### ● ビット3~0 - DT1BL3~0: OC1B 沈黙時間 (Dead Time Value for OC1B Output)

OC1Bに対する沈黙時間値です。沈黙時間遅延は前置分周したタイマ/カウンタ1 クロック数として設定されます。最小沈黙時間は0で、最大沈黙時間は前置分周したタイマ/カウンタ1 クロック周期×15です。

# 15. 多用途直列インターフェース (USI: Universal Serial Interface)

# 15.1. 特徴

- 2線同期データ転送(主装置または従装置)
- 3線同期データ転送(主装置または従装置)
- データ受信割り込み
- ア仆ル動作からの起動復帰
- 2線動作での全休止形態からの起動復帰
- 割り込み能力を持つ2線動作開始条件検出器

#### 15.2. 概要

多用途直列インターフェース(USI)は直列通信で必要とされる基本的なハードウェア資源(機能)を提供します。最低限の制御ソフトウェアとの組み合わせで、USIはソフトウェアのみを元とした方法よりも少ないコード量と重要な高い転送レートを許します。プロセッサ負荷を最小とするために割り込みが含まれます。

USIの簡単化した構成図は図15-1.で示されます。実際のI/Oピンの配置は2頁の「ピン配置」を参照してください。デバイス仕様のI/Oレジスタとビット位置は77頁の「USI用レジスタ」で一覧されます。



8ビットのUSIデータ レジスタ(USIDR)は入って来るデータと出て行くデータを含みます。これはデータ バス経由で直接的にアクセス可能ですが、その内容の複製を後で回収できるUSI緩衝レジスタ(USIBR)にも配置されます。直接USIデータ レジスタを読む場合、データが失われないことを保証するためにデータは可能な限り早く読まなければなりません。

最上位ビットは(動作種別設定(USI制御レジスタ(USICR)参照)に依存して)2つの出力ピンの1つに接続されます。データ入力採取と逆のク ロック端にデータ出力の変更を遅らせるのが、USIデータ レジスタと出力ピン間のトランスペアレント(透過型)ラッチです。直列入力は(種別)設定に 拘らず、常にデータ入力(DI)ピンから採取されます。

4ビット計数器はデータ バス経由で読み書き両方ができ、溢れ割り込みを生成できます。この計数器とUSIデータ レジスタは同じクロック元によって同時にクロック駆動されます。これは受信または送信したビット数を数え、転送完了時に割り込みの生成を計数器に許します。外部クロック元が選択されると、この計数器が両クロック端で計数することに注意してください。これは計数レジスタがデータ ビット数でなく、クロック端数であることを意味します。クロックは3つの異なるクロック元(USCKピン、タイマ/カウンタ0の比較A一致、ソフトウェア)から選択できます。

2線クロック制御部(回路)は2線バスで開始条件が検出された時に割り込みを生成する設定にできます。開始条件検出後または計数器溢れ後にクロック ピンをLow〜保持することによって待ち状態を生成する設定にもできます。



### 15.3. 機能説明

#### 15.3.1. 3線動作

USIの3線動作は直列周辺インターフェース(SPI)の動作種別0と1に準拠していますが、従装置選択(SS)ピン機能を持ちません。けれども、この特性(機能)は必要ならばソフトウェアで実現できます。この動作で使われるピン名はDI,DO,USCKです。



図15-2.は3線動作での2つのUSI部(一方は主装置、他方は従装置)動作を示します。このような方法で連結された2つの移動レジスタは8USCKクロック後、各々のレジスタのデータが交換されます。この同じクロック(USCK)がUSIの4ビット計数器も増加(+1)します。従って計数器溢れ割り込み要求フラグ(USIOIF)は転送が完了される時を決めるのに使えます。このクロックはPORTレジスタ経由USCKピン1/0交互切り替え、またはUSICRのUSITCビットへの1書き込みによる主装置装置ソフトウェアによって生成されます。



3線動作タイミングは図15-3.で示されます。図の最上部はUSCK周期参照基準です。これらの各周期に対して1ビットがUSI移動レシ、スタ (USIDR)に移動されます。USCKタイミングは両方の外部クロック動作について示されます。外部クロック動作0(USICS0=0)でのDIは上昇端で採取され、DOは下降端で変更(USIDRが1つ移動)されます。外部クロック動作1(USICS0=1)は外部クロック動作0に対して逆端を使用、換言すると下降端でデータを採取、上昇端で出力を変更します。USIクロック動作種別はSPIデータ動作種別0と1に対応します。

このタイミング図(図15-3.)を参照すると、バス転送は次の手順を含みます。

- 1. 主装置と従装置はデータ出力を設定し、使用規約に依存して出力駆動部を許可します(AとB)。この出力は直列データレジスタへの送信されるべきデータ書き込みによって設定します。出力の許可はポート方向レジスタの対応するビット設定によって行います。A点とB点はどんな特別な順番もありませんが、両方共にデータが採取されるC点よりも最低1/2USCK周期前でなければならないことに注意してください。これはデータ設定の必要条件を満足させるのを保証するために行わなければなりません。4ビット計数器は0にリセットします。
- 2. 主装置はUSCK線をソフトウェアで2度切り替えることによってクロック パルスを生成します(CとD)。主装置と従装置のデータ入力(DI)ピンの ビット値は最初のエッジ(C)でUSIによって採取され、データ出力は逆端(D)で変更されます。4ビット計数器は両端で計数します。
- 3. レシブスタ(バイイ)転送完了のために手順2.が8回繰り返されます。
- **4.** 8クロック パルス(換言すると16クロック端)後、計数器が溢れて転送完了を示します。USI緩衝レジスタ(USIBR)が使われない場合、転送したバイト データは新規転送が開始され得るのに先立って直ぐに処置されなければなりません。溢れ割り込みはプロセッサがアイドル動作に設定されているなら、プロセッサを起動復帰します。使用規約によって、従装置は直ぐに出力をHi-Z設定にできます。



### 15.3.2. SPI主装置操作例

次のコードはSPI主装置としてのUSI使用法を実際に示します。

```
アセンブリ言語プログラム例
SPIM:
         OUT
                USIDR, R16
                                                                 ;送信データを設定
         LDI
                R16, (1<<USIOIF)
                                                                 ;USIOIFビットのみ1値を取得
         OUT
                                                                 ;フラグ解除/計数器初期化
                USISR, R16
                R16, (1<<USIWMO) | (1<<USICS1) | (1<<USICLK) | (1<<USITC)
         LDI
                                                                 ;3線動作クロック生成値を取得
         OUT
                                                                 ;SCKクロック端発生
SPIM_LP:
                USICR, R16
                USISR, USIOIF
                                                                 ;計数器溢れでスキップ
         SBIS
         RJMP
                SPIM LP
                                                                 ;計数器溢れまで継続
                                                                 ;受信データを取得
         IN
                R16, USIDR
         RET
                                                                 ;呼び出し元へ復帰
```

このコードは8命令(+RET)のみ使用の容量最適化です。このコード例はDOとUSCKピンがDDRBで出力として許可される仮定です。この 関数が呼び出される前にR16レジスタへ格納した値は従装置に転送され、転送が完了された時に従装置から受信したデータがR16レジスタに格納されて戻ります。

2行目と3行目の命令は計数器溢れ割り込み要求フラケ (USIOIF)を解除(0)し、USI 4ビット計数器値を解除(=0)します。4行目と6行目の命令は3線動作、上昇端クロック、USITCストロープ 計数、SCK出力交互切り替え(PORTB7)を設定します。この繰り返しは16回繰り返されます。

次のコードは最高速( $f_{SCK}=f_{CK}/2$ )でのSPI主装置としてのUSI使用法を実際に示します。

| アセンブリ言語 | <b>雪フ゜ロク・ラム</b> イ | 例                                                                                                            |                 |
|---------|-------------------|--------------------------------------------------------------------------------------------------------------|-----------------|
| SPIM_F: | OUT               | USIDR, R16                                                                                                   | ;送信データを設定       |
|         | LDI               | R16, (1< <usiwmo) (0<<usicso)="" (1<<usitc)<="" td=""  =""><td>;3線動作初期値を取得</td></usiwmo)>                    | ;3線動作初期値を取得     |
|         | LDI               | R17, (1< <usiwmo) (0<<usicso)="" (1<<usiclk)<="" (1<<usitc)="" td=""  =""><td>;3線動作クロック生成値を取得</td></usiwmo)> | ;3線動作クロック生成値を取得 |
| ;       |                   |                                                                                                              |                 |
|         | OUT               | USICR, R16                                                                                                   | ;MSB転送          |
|         | OUT               | USICR, R17                                                                                                   | ;               |
|         | OUT               | USICR, R16                                                                                                   | ;ビット6転送         |
|         | OUT               | USICR, R17                                                                                                   | ;               |
|         | OUT               | USICR, R16                                                                                                   | ;ビット5転送         |
|         | OUT               | USICR, R17                                                                                                   | ;               |
|         | OUT               | USICR, R16                                                                                                   | ;ビット4転送         |
|         | OUT               | USICR, R17                                                                                                   | ;               |
|         | OUT               | USICR, R16                                                                                                   | ;ビット3転送         |
|         | OUT               | USICR, R17                                                                                                   | ,               |
|         | OUT               | USICR, R16                                                                                                   | ;ビット2転送         |
|         | OUT               | USICR, R17                                                                                                   | ;               |
|         | OUT               | USICR, R16                                                                                                   | ;ビット1転送         |
|         | OUT               | USICR, R17                                                                                                   | ;               |
|         | OUT               | USICR, R16                                                                                                   | ;LSB転送          |
|         | OUT               | USICR, R17                                                                                                   | ,               |
| ;       | TNI               | DIC HOLDD                                                                                                    | · 双层二 加土取相      |
|         | IN                | R16, USIDR                                                                                                   | ;受信データを取得       |
|         | RET               |                                                                                                              | ;呼び出し元へ復帰       |



### 15.3.3. SPI従装置操作例

次のコート、はSPI従装置としてのUSI使用法を実際に示します。

```
アセンブリ言語プログラム例
                R16, (1<<USIWMO) | (1<<USICS1)
                                                    ;3線動作,外部クロック値を取得
init:
         LDI
         OUT
                USICR, R16
                                                    ;3線動作,外部クロック設定
SPIS:
         OUT
                USIDR, R16
                                                    ;送信データを設定
                                                    ;USIOIFビットのみ1値を取得
                R16, (1<<USIOIF)
         LDI
         OUT
                                                    ;フラグ解除/計数器初期化
                USISR, R16
SPIS LP:
         SBIS
                USISR, USIOIF
                                                    ;計数器溢れでスキップ
         RJMP
                SPIS_LP
                                                    ;計数器溢れまで継続
                                                    ;受信データを取得
         IN
                R16, USIDR
         RET
                                                    ;呼び出し元へ復帰
```

このコート、は8命令(+RET)のみ使用の容量最適化です。このコート・例はDDRBレシ、スタでDOピンが出力、USCKピンが入力として設定されると仮定します。この関数が呼び出される前にR16レシ、スタへ格納した値は主装置に転送され、転送が完了された時に主装置から受信したデータがR16レシ、スタに格納されて戻ります。

最初の2命令は初期化用だけで、一度だけ実行されるのを必要とすることに注意してください。これらの命令は3線動作と上昇端クロックを設定します。この繰り返しはUSI計数器溢れフラグが設定(1)されるまで繰り返されます。

### 15.3.4. 2線動作

USIの2線動作はI<sup>2</sup>C(TWI)パス規約に準拠していますが、出力のスリューレート制限と入力雑音濾波器がありません。この動作で使われる ピン名はSCLとSDAです。



図15-4.は2線動作での2つのUSI部(一方は主装置、他方は従装置)動作を示します。システム動作が使用通信構造に大きく依存するために示されるのは物理層のみです。この段階での主装置動作と従装置動作間の主な違いは常に主装置によって行われる直列クロック生成と、従装置だけがクロック制御部(回路)を使うことです。クロック生成はソフトウェアで実行されなければなりませんが、移動動作は両装置で自動的に行われます。データの移動に関してこの動作種別で下降端でのクロックだけを実際に使うことに注意してください。従装置はSCLクロックをLowに強制することにより、転送の開始と終了で待ち状態(ウェイトステート)を挿入できます。これは(主装置が)上昇端を生成してしまった後に主装置はSCL線が実際に開放されたかを常に検査しなければならないことを意味します。

このクロックが(4ビット)計数器も増加(+1)するため、計数器溢れ(USIOIF)は転送が完了されたことを示すのに使えます。このクロックは主装置によるPORTBレジスタ経由のSCLピン交互切り替えによって生成されます。

データ方向は物理層によって与えられません。データの流れを制御するためにTWIバスで使ったような或る種の規約が実装されなければなりません。



このタイシング図(図15-5.)を参照すると、バス転送は次の手順を含みます。



- 1. 開始条件は主装置によるSCL線High中のSDA線Low強制によって生成されます(A)。SDAはUSIデータレジスタ(USIDR)のビット7への 0書き込みか、またはPORTレジスタで対応ビットを0に設定のどちらかによって強制実行できます。出力が許可されるにはデータ方向 (DDR)レジスタのビットが1に設定されなければならないことに注意してください。従装置の開始条件検出器論理回路(図15-6.参照) が開始条件を検出してUSISIFフラグを設定(1)します。このフラグは必要ならば割り込みを発生できます。
- 2. 加えて開始条件検出器は主装置がSCL線で上昇端を強制してしまった後にSCL線をLowに保持します(B)。これはアドレスを受信するために移動レジスタを設定する前に休止形態から起動復帰または他の処理を完了することを従装置に許します。これ(保持解除)は(4ビット)計数器をリセット(=0)して開始条件検出フラグ(USISIF)を解除(0)することによって行われます。
- 3. 主装置は転送されるべき最初のビットを設定してSCL線を開放します(C)。従装置はSCLクロックの上昇端でデータを採取して移動レジ スタへ移動します。
- 4. 従装置アドレスとデータ方向(R/W)を含む8ビットが転送された後、従装置の(4ビット)計数器が溢れてSCL線がLowを強制されます(D)。 従装置は主装置の1つがアドレス指定してしまわない場合、SCL線を開放して新規開始条件を待ちます。
- 5. 従装置がアトンス指定されると、再びSCL線をLowに保持する前の応答(ACK)周期の間中、SDA線をLowに保持します(換言すると D点でSCLを開放する前に(4ビット)計数器レシ、スタは14に設定されなければなりません)。R/Wビットに依存して主装置か従装置は出力を許可します。このビットが設定(1)の場合、主装置読み込み動作が進行中です(換言すると従装置がSDA線を駆動します)。従装置は応答後(E)にSCL線をLowに保持することができます。
- 6. 主装置によって停止条件(F)か新規開始条件(再送開始条件)が与えられるまで全て同方向で複数バイが直ぐに転送できます。 従装置はより多くのデータを受信できない場合、最後に受信したバイトデータに応答しません。主装置が読み込み動作を行うとき、最後のバイトが転送された後の応答ビットをLowに強制することよってこの動作を終了しなければなりません。

#### 15.3.5. 開始条件検出器

開始条件検出器は**図15-6**.で示されます。SDA線はSCL線の有効な採取を保証するために(50~300nsの範囲で)遅延されます。開始条件検出器は2線動作でだけ許可されます。

開始条件検出器は非同期に動作し、従ってパワーグウン休止動作からプロセッサを起動できます。けれども使う規約がSCL保持時間で制限を持つかもしれません。従ってこの場合にこの特徴(機能)を使う時にCKSELヒューズで設定する発振器起動時間(15頁の「クロック系統とその配給」参照)も考慮内に取り入れられなければなりません。より多くの詳細については77頁のUSISIFフラグ記述を参照してください。



#### 15.3.6. クロック 速度の 考察

SCLとUSCKに対する最大周波数は $f_{CK}/2$ です。これは2線と3線の両動作での最大データ転送と受信速度でもあります。2線従装置動作では従装置が更にデータを受信する準備ができるまで、2線クロック制御部がSCLを保持します。これは2線動作で実データ速度を減らすかもしれません。

15.4. USIでの代替使用

USI部を直列通信に使わないなら、柔軟な設計のため、代替処理を行うように設定できます。

15.4.1. 半二重非同期データ転送

3線動作で移動レジスタを使うことによってソフトウェアだけよりも簡潔で高性能のUART実装が可能です。

15.4.2. 4ビット計数器

4ビット計数器は溢れ割り込みとの自立型計数器として使えます。この計数器が外部的にクロック 駆動される場合、両クロック端が増加(+1)を発生することに注意してください。

15.4.3. 12ビット計数器

USIの4ビット計数器とタイマ/カウンタ0の組み合わせは12ビット計数器としての使用を許します。

15.4.4. エッジ起動外部割り込み

4ビット計数器を最大値(\$F)に設定することによって追加外部割り込みとして機能できます。溢れフラケと割り込み許可ビットはこの外部割り込みに対して使われます。この特徴(機能)はUSICS1 ビットによって選択(=1)されます。

15.4.5. ソフトウェア割り込み

4ビット計数器の溢れ割り込みはクロック ストローブによって起動するソフトウェア割り込みとして使えます。



### 15.5. USI用 レジスタ

### 15.5.1. USIDR - USI データレジスタ (USI Data Register)

| ピット         | 7     | 6   | 5   | 4   | 3   | 2   | 1   | 0     | _     |
|-------------|-------|-----|-----|-----|-----|-----|-----|-------|-------|
| \$0F (\$2F) | (MSB) |     |     |     |     |     |     | (LSB) | USIDR |
| 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     |       |

データレジスタ(USIDR)は直接アクセスできますが、データの複製がUSI緩衝レジスタ(USIBR)でも得られます。

USI制御レジスタ(USICR)のUSICS1,0ビット設定に応じて(左)移動動作が実行され得ます。この移動動作は外部クロック端、タイマ/カウンタ0比較A一致により、またはUSICLKビット経由のソフトウェア直接で同期化できます。レジスタが書かれるのと同じ周期で直列クロックが起こると、レジスタは書いた値を含み、移動は実行されません。

2または3線動作種別が選択されない(USIWM1,0=00)時でも、外部データ入力(DI/SDA)と外部クロック入力(USCK/SCL)の両方が未だ USIデータ レジスタによって使われ得ることに注意してください。

出力ピン(DOまたはSDA、動作種別依存)は出力ラッチを経由してデータレジスタの最上位ビット(ビット7)に接続されます。このラッチは逆のクロック端でのデータ入力採取とデータ出力変更を保証します。この出力ラッチは外部クロック元が選択される(USICS1=1)時に直列クロック周期の前半中が透過(トランスペプレント)で、内部クロック元が使われる(USICS1=0)時に定常的な透過です。ラッチが透過である限り、新規MSBが書かれると、出力は直ちに変更されます。

USIデータレジスタからの出力データを許可するために、ピンに対応するデータ方向レジスタ(DDxn)が1に設定されなければならないことに注意してください。

### 15.5.2. USIBR - USI緩衝レジスタ (USI Buffer Register)

| ピット         | 7     | 6 | 5 | 4 | 3 | 2 | 1 | 0     | _     |
|-------------|-------|---|---|---|---|---|---|-------|-------|
| \$10 (\$30) | (MSB) |   |   |   |   |   |   | (LSB) | USIBR |
| Read/Write  | R     | R | R | R | R | R | R | R     |       |
| 初期値         | 0     | 0 | 0 | 0 | 0 | 0 | 0 | 0     |       |

USIデータレシ、スタ(USIDR)からデータを読む代わりにUSI緩衝レシ、スタ(USIBR)が使えます。これはUSI制御の微妙なタイミングをなくして他のプログラム処理を扱うより多くの時間をCPUに与えます。USIのフラグはUSIDRを読む時と同様に設定されます。

USIデータレシ、スタ(USIDR)の内容は転送が完了される時にUSI緩衝レシ、スタ(USIBR)へ格納されます。

# 15.5.3. USISR - USI状態レジスタ (USI Status Register)

| ピット         | 7      | 6      | 5     | 4     | 3       | 2       | 1       | 0       |       |
|-------------|--------|--------|-------|-------|---------|---------|---------|---------|-------|
| \$0E (\$2E) | USISIF | USIOIF | USIPF | USIDC | USICNT3 | USICNT2 | USICNT1 | USICNT0 | USISR |
| Read/Write  | R/W    | R/W    | R/W   | R     | R/W     | R/W     | R/W     | R/W     |       |
| 初期値         | 0      | 0      | 0     | 0     | 0       | 0       | 0       | 0       |       |

この状態レジスタは割り込み要求フラグ、状態フラグ、計数器値を含みます。

### ● ビット7 - USISIF: 開始条件検出割り込み要求フラグ(Start Condition Interrupt Flag)

2線動作選択時に開始条件が検出されると、USISIFフラケが設定(1)されます。出力禁止動作または3線動作の選択時、USCKピンのどのエッシもがこのフラケを設定(1)します。

ステータス レシ 、スタ(SREG)の全割り込み許可(I) ビットとUSI制御レシ、スタ(USICR)で開始条件検出許可(USISIE) ビットが設定(1)の場合にこのフラケが設定(1)されると、割り込みが生成されます。このフラケ はUSISIF ビットへの論理1書き込みによってのみ解除(0)されます。この ビットの解除(0)は2線動作でのSCLの開始条件保持を解除(開放)します。

開始条件検出割り込みは全ての休止形態からプロセッサを起動します。

## ● ビット6 - USIOIF: 計数器溢れ割り込み要求フラグ(Counter Overflow Interrupt Flag)

このフラグは4ビット計数器が溢れると(換言すると15から0への遷移で)設定(1)されます。ステータスレジスタ(SREG)の全割り込み許可(I)ビットとUSI制御レジスタ(USICR)で計数器溢れ割り込み許可(USIOIE)ビットが設定(1)の場合にこのフラグが設定(1)されると、割り込みが生成されます。このフラグはUSIOIFビットへの論理1書き込みによってのみ解除(0)されます。このビットの解除(0)は2線動作でのSCLの計数器溢れ保持を解除(開放)します。

計数器溢れ割り込みはアイドル休止動作からプロセッサを起動します。

#### ● ビット5 - USIPF: 停止条件検出フラグ(Stop Condition Flag)

2線動作が選択された時に<mark>停止条件</mark>が検出されると、USIPFフラグが設定(1)されます。このフラグはこのビットへの1書き込みによって解除(0)されます。これが割り込み要求フラグでないことに注意してください。この合図は2線バス主装置調停の実装時に有用です。



#### ● ビット4 - USIDC: 出力データ衝突フラグ(Data Output Collision Flag)

USIデータレジスタ(USIDR)のビット7(MSB)が物理ピン値と異なる時にこのビットは論理1です。このフラグは2線動作が使われる時にだけ有効です。この合図は2線バス主装置調停の実装時に有用です。

#### ● ビット3~0 - USICNT3~0:計数器値(Counter Value)

これらのビットは現在の4ビット計数器値を反映します。この4ビット計数器値はCPUによって直接的に読み書きできます。

この4ビット計数器は外部クロック端検出器、タイマ/カウンタ0比較A一致、USICLKまたはUSITCストローブ・ビットを使うソフトウェアのどれかによって生成した各クロックに対して1つ増加します。このクロック元はUSICS1,0ビット設定に依存します。外部クロック動作に対してUSITCストローブ・ビットへの書き込みによって生成されるのをクロックに許す特別な特徴が付加されます。この特徴は外部クロック元(USICS1=1)設定とUSICLKへの1書き込みによって許可されます。

出力禁止動作(USIWM1,0=00)が選択されている時でも、外部クロック入力(USCK/SCL)が未だ計数器によって使われることに注意してください。

### 15.5.4. USICR - USI制御レジスタ (USI Control Register)

| ピット         | 7      | 6      | 5      | 4      | 3      | 2      | 1      | 0     | _     |
|-------------|--------|--------|--------|--------|--------|--------|--------|-------|-------|
| \$0D (\$2D) | USISIE | USIOIE | USIWM1 | USIWM0 | USICS1 | USICS0 | USICLK | USITC | USICR |
| Read/Write  | R/W    | R/W    | R/W    | R/W    | R/W    | R/W    | W      | W     |       |
| 初期値         | 0      | 0      | 0      | 0      | 0      | 0      | 0      | 0     |       |

この制御レジスタは割り込み許可制御、動作種別設定、クロック選択設定、クロックストローブを含みます。

#### ● ビット7 - USISIE:開始条件検出割り込み許可(Start Condition Interrupt Enable)

このビットを1に設定することが開始条件検出割り込みを許可します。ステータス レジスタ(SREG)の全割り込み許可(I)ビットとUSISIEビットが1に設定され、保留割り込みありなら、割り込みが直ちに実行されます。より多くの詳細については77頁の開始条件検出割り込み要求フラグ(USISIF)記述を参照してください。

#### ● ビット6 - USIOIE: 計数器溢れ割り込み許可 (Counter Overflow Interrupt Enable)

このビットを1に設定することが計数器溢れ割り込みを許可します。ステータスレジスタ(SREG)の全割り込み許可(I)ビットとUSIOIEビットが1に設定され、保留割り込みありなら、割り込みが直ちに実行されます。より多くの詳細については77頁の計数器溢れ割り込み要求フラグ(USIOIF)記述を参照してください。

#### ┗ ビット5,4 - USIWM1,0:動作種別選択 (Wire Mode)

下の表15-1.で示されるようにこれらのビットは使われるべき動作種別(2または3線動作)を設定します。

#### 表15-1. USI操作とUSIWM1.0の関係

| USIWM1 | USIWM0 | 説明                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             |
|--------|--------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 0      | 0      | 出力、クロック保持、開始条件検出器は禁止。ポート ピンは標準として動作。                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           |
| 0      | 1      | 3線動作。DO,DI,USCKピンを使用。<br>データ出力(DO)ピンはこの動作でPORTBレジスタの対応ビットを無視します。けれども対応するDDRBビットは未だデータ方向を制御します。ポート ピンが入力として設定(DDxn=0)されると、そのピンのプルアップはPORTBビットによって制御されます。                                                                                                                                                                                                                                                                                                                                                                        |
|        |        | データ入力(DI)と直列クロック(USCK)ピンは標準ポート操作に影響を及ぼしません。主装置として動作する時の<br>クロック パルスはデータ方向が出力に設定されている(DDxn=1)間のPORTBレジスタの交互切り替えによってソフト<br>ウェアで生成されます。USICRのUSITCビットがこの目的に使えます。                                                                                                                                                                                                                                                                                                                                                                  |
| 1      | 0      | 2線動作。SDA(DI)とSCL(USCK)ピンを使用。(注1)<br>直列データ(SDA)と直列クロック(SCL)ピンは双方向でオープンドレイン出力駆動を使います。この出力駆動部は<br>DDRAレシスタでSDAとSCLに対応するピットの設定(=1)によって許可されます。<br>SDAピンに対して出力駆動部が許可されると、出力駆動部はUSIデータレジスタ(USIDR)の出力またはPORTB<br>レジスタの対応ビットがOならばSDA線をLowに強制します。さもなければ、SDA線は駆動されません(換言する<br>と開放されます)。SCLピン出力駆動部が許可されると、SCL線はPORTBレジスタの対応ビットがOなら、または<br>開始条件検出器によってLowを強制されます。さもなければSCL線は駆動されません。<br>SCL線は出力が許可され、開始条件検出器が開始条件を検出すると、Lowに保持されます。開始条件検<br>出フラケ(USISIF)の解除(0)がその線を開放します。SDAとSCLピン入力はこの動作の許可によって影響を及<br>ぼされません。SDAとSCLピンのプルアップは2線動作で禁止されます。 |
| 1      | 1      | 2線動作。SDAとSCLピンを使用。<br>SCL線は計数器溢れが起こる時にもLow〜保持され、計数器溢れフラグ(USIOIF)が解除(0)されるまでLow<br>に保持されることを除いて、上の2線動作と同じ動作です。                                                                                                                                                                                                                                                                                                                                                                                                                  |

注1: DIとUSCKピンは動作種別間での混乱を避けるため、各々直列データ(SDA)と直列クロック(SCL)に改称されます。



基本的に出力の機能だけがこれらのビットによって影響を及ぼされます。データとクロック入力は選択した動作種別によって影響を及ぼされず、常に同じ機能を持ちます。従って出力が禁止される時でもUSIデータ レジスタ(USIDR)とカウンタは外部的にクロック駆動でき、入力データが採取されます。

#### ● ビット3.2 - USICS1.0: クロック選択 (Clock Source Select)

これらのビットは移動レジスタと計数器に対するクロック元を設定します。外部クロック元(USCK/SCL)を使う時にデータ出力ラッチはデータ入力 (DI/SDA)の採取の逆端で出力が変更されるのを保証します。タイマ/カウンタ0比較A一致またはソフトウェア ストローブが選択されると、出力 ラッチは透過で、従って出力は直ちに変更されます。USICS1,0ビットの解除(=00)がソフトウェア ストローブ選択を許可します。この選択を使う 時のUSICLKビットへの1書き込みはUSIデータ レジスタ(USIDR)と計数器の両方をクロック駆動します。外部クロック元(USICS1=1)に対して USICLKビットはもはやストローブとして使われませんが、外部クロックとUSITCストローブビットによるソフトウェア クロック間を選択します。

表15-2.はUSIデータレシブスタ(USIDR)と4ビット計数器に対して使われるクロック元とUSICS1,0、USICLK設定間の関連を示します。

表15-2. USICS1.0とUSICLK設定との関係

| USICS1 | USICS0 | USICLK | 移動レジスタ クロック元               | 4ビット計数器クロック元                |
|--------|--------|--------|----------------------------|-----------------------------|
|        | 0      | 0      | クロックなし                     | クロックなし                      |
| 0      | 0      | 1      | ソフトウェア クロック ストローフ゛(USICLK) | ソフトウェア クロック ストローフ゛(USICLK)  |
|        | 1      | X      | タイマ/カウンタ0比較A一致             | タイマ/カウンタ0比較A一致              |
|        | 0      | 0      | 外部クロック上昇端                  | 外部クロック両端                    |
| 1      | 1      | 0      | 外部クロック下降端                  | グト音13クロツク 四1 4㎡             |
| 1      | 0      | 1      | 外部クロック上昇端                  | ソフトウェア クロック ストローフ゛(USITC)   |
|        | 1      | 1      | 外部クロック下降端                  | //r//±/ //۳// Aru—/ (USIIC) |

#### ビット1 - USICLK: クロック ストローフ (Clock Strobe)

USICS1,0ビットのゼロ(=00)書き込みによってソフトウェア ストローブ任意選択が選択されたなら、このビット位置への1書き込みはUSIデータ レジスタ(USIDR)を1段移動して計数器を1つ増加します。このクロック ストローブが実行される時、直ちに、換言すると同じ命令周期内で出力が替わります。USIデータ レジスタ(USIDR)内に移動した値は直前の命令周期で採取されます。

外部クロック元が選択される(USICS1=1)と、USICLK機能はクロック ストローブからクロック選択レジスタに変更されます。この場合のUSICLKビットの設定(1)は4ビット計数器に対するクロック元としてのUSITCストローブを選びます(表15-2.参照)。 このビットは0として読まれます。

### ● ビット0 - USITC: クロック値切り替え (Toggle Clock Port Pin)

このビット位置に1を書くことはUSCK/SCL値を0から1、または1から0のどちらかへ切り替えます。この切り替えはデータ方向レジスタでの設定と無関係ですが、PORT値がピンで見られるべきなら、DDRビットが出力として設定(=1)されなければなりません。この特徴は主装置を実現する時の容易なクロック生成を許します。

外部クロック元が選択され(USICS1=1)、USICLKビットが1に設定されると、USITCストローブビットへの書き込みは直接的に4ビット計数器をク ロック駆動します。これは主装置として動作する時に転送が行われる時の早い検出を許します。 このビットは0として読まれます。



## 16. アナログ比較器

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



注: A/D多重器出力については以下の表16-1.をご覧ください。 アナログ比較器ピン配置については、2頁の「ピン配置」と41頁の表 10-5.を参照してください。

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

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

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

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

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

| ピット         | 7   | 6    | 5   | 4 | 3 | 2     | 1     | 0     |        |
|-------------|-----|------|-----|---|---|-------|-------|-------|--------|
| \$03 (\$23) | BIN | ACME | IPR | - | - | ADTS2 | ADTS1 | ADTS0 | ADCSRB |
| Read/Write  | R/W | R/W  | R/W | 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がアナログ比較器の反転入力に印加されます。このビットの詳細な記述については上記の「アナログ比較器入力選択」をご覧ください。

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

| ピット         | 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がアナログ比較器の非反転入力に印加されます。内部基準電圧がアナログ比較器への入力として使われるとき、電圧の安定に一定時間を必要とします。安定(待機を)しない場合、不正な比較になるかもしれません。29頁の「内部基準電圧」をご覧ください。

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

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

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

このビットは比較器出力での出来事がACSRのアナログ比較器割り込み条件(ACIS1,0)ビットによって定義した割り込み方法で起動する時に設定(1)されます。ACSRのアナログ比較器割り込み許可(I)ビットが設定(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)

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

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

| <b>秋10 Z. 7 7 日</b> 7 | / 10年入1日日リンス | 207末斤达1八      |
|-----------------------|--------------|---------------|
| ACIS1                 | ACIS0        | 割り込み発生条件      |
| 0                     | 0            | 比較器出力の変移(トグル) |
| 0                     | 1            | (予約)          |
| 1                     | 0            | 比較器出力の下降端     |
| 1                     | 1            | 比較器出力の上昇端     |

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

| ピット         | 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     |       |

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

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

# 17. A/D変換器

### 17.1. 特徴

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

#### 17.2. 概要

ATtiny25/45/85は10ビット逐次比較A/D変換器(ADC)が特徴です。このA/D変換器はポートBのピンから構成された4つのシング $\nu$  ェンド電圧入力と1つの差動電圧入力を許す4チャネ $\nu$  アナログ多重器に接続されます。差動入力(PB3,PB4またはPB2,PB5)はA/D変換に先立つ差動入力電圧で26dB(×20)の増幅段を提供する設定変更可能な利得段が装備されます。シング $\nu$  ェント、電圧入力は0V(GND)が基準です。

このA/D変換器はA/D変換器への入力電圧が変換中に一定の値で保持されることを保証する採取&保持(S/H)回路を含みます。 A/D変換部の構成図は**図17-1**.で示されます。

公称1.1V/2.56Vの内蔵基準電圧がチップとで提供されます。代わりにVCCがシングルェント、チャネル用の基準電圧として使えます。内部 基準電圧をOFFにして外部基準電圧を使う任意選択もあります。





### 17.3. 操作

A/D変換部は逐次比較を通してアナログ入力電圧を10ビットのデンタル値に変換します。最小値はGNDを表し、最大値はVCC電圧、AREFtプンの電圧、または1.1V/2.56V内部基準電圧を表します。

A/D変換器用の基準電圧はA/D多重器選択Vシ、Zタ(ADMUX)の基準電圧選択( $REFS2\sim0$ )と、Vとの書き込みによって選択できます。 VCC電源、AREFピン、または1.1V/2.56V内部基準電圧がA/D変換器基準電圧として選択できます。任意で2.56V内部基準電圧は雑音耐性を改善するためにAREFピンで外部コンデンサによってデカップ(雑音結合減少)ができます。

アナログ入力チャネルと差動利得はADMUXのチャネル選択(MUX3~0)ビットへの書き込みによって選択されます。4つのADC入力ピン(ADC3~0)のどれもがA/D変換器のシングルエント、入力として選択できます。ADC0とADC2は差動利得増幅器への非反転入力として、ADC0、ADC1、ADC2、ADC3は反転入力として選択できます。

差動チャネルが選択されると、差動利得段は選択した入力チャネル対間の差電圧を、ADMUXのMUX3~0ビット設定に従って、1倍または20倍の選択した増幅率で増幅します。それからこの増幅した値はA/D変換器の入力になります。シングルエンドチャネルが使われると、利得増幅器全体が迂回(無視)されます。

ADC0かADC2が差動利得増幅器への反転と非反転両方の入力として選択(ADC0-ADC0またはADC2-ADC2)されると、利得段と変換回路の残留オフセットが変換結果として直接測定できます。この数値はオフセット誤差を1LSB以下に減らすために、同じ利得設定で後続する変換(結果)から減算できます。

チップ上の温度感知器はADC4チャネルがA/D変換器入力として使われるとき、(即ち)ADMUXのMUX3~0ビットへの'1111'書き込みによって選択されます。

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の読み込み間で禁止されている場合、例えその変換結果が失われても割り込みは起動します。

### 17.4. 変換の開始

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

代わりに、変換は様々な起動元によって自動的に起動できます。自動起動はA/D変換制御/状態レシ、スタA(ADCSR A)のA/D変換自動起動許可(ADATE)と、かの設定(1)によって許可されます。起動元はA/D変換制御/状態レジ、スタB(A DCSRB)のA/D変換起動元選択(ADTS2~0)と、外の設定によって選択されます(起動元の一覧についてはADTSと、外の記述をご覧ください)。選択した起動信号上に上昇端が起きると、A/D変換用前置分周器がリセットし、変換が開始されます。これは一定間隔での変換開始の方法を提供します。変換完了時に起動信号が未だ設定(1)されている場合



は新規の変換が開始されません。変換中にこの起動信号上で別の上昇端が起きると、そのエッジは無視されます。指定した割り込みが禁止またはステータスレジスタ(SREG)の全割り込み許可(I)ビットが解除(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変換雑音低減休止動作中に変換を許可します。詳細については86頁の「**雑音低減機能**」をご覧ください。(<mark>訳注</mark>:共通性から2行追加)



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

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

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

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

通常の変換は13変換クロック周期で行われます。下の図17-4.で示されるように、A/D

変換部がONされる(ADCSRAのADEN=1)後の最初の変換はアナログ回路を初期化するために25変換クロック周期で行われます。





実際の採取&保持(保持開始点)は通常変換の開始後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に留まります。変換時間の要約については表17-1.をご覧ください。



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

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

A/D多重器選択レシ、スタ(ADMUX)のチャネル選択(MUX3~0) ビットと基準電圧選択(REFS2~0) ビットは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変換に影響を及ぼします。

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

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

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

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



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

このA/D変換用の基準電圧( $V_{REF}$ )はA/D変換に対する変換範囲を示します。 $V_{REF}$ を越えるシングル エント、入力チャネルは\$3FFで打ち切るコート、に帰着します。 $V_{REF}$ は $V_{CC}$ 、1.1 $V_{CE}$ 1.56 $V_{CE}$ 内部基準電圧、外部AREFt。 $V_{CE}$ 2.56 $V_{CE}$ 5.6 $V_{CE}$ 7.6 $V_{CE}$ 7.6 $V_{CE}$ 7.6 $V_{CE}$ 7.6 $V_{CE}$ 8.6 $V_{CE}$ 8.6 $V_{CE}$ 9.6 $V_{CE}$ 9.6

### 17.7. 雑音低減機能

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

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

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

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

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

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

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



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

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

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

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



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

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

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

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

#### • 利得誤差 - 図17-10.

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

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

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

#### 差動非直線誤差 (DNL) - 図17-12.

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

#### • 量子化誤差

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

#### 絶対精度

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









# 17.11. A/D変換の結果

変換完了(ADIF=1)後、変換結果はA/Dデータレジ、スタ(ADCH, ADCL)で得られます。変換結果の形式はシングルエント、変換、単極差動 変換、両極差動変換の3つの変換形式に依存します。

### 17.11.1. シングル エント 変換

シングルエンド入力変換での結果は右式で示されます。

極入力動作が使われると、その結果は右式で示されます。

VINは選択した入力ピンの電圧で、VREFは選択した基準電圧です(89頁の表17-3.と表17-4.をご 覧ください)。\$000はアナログGNDを表し、\$3FFは選択した基準電圧-1LSBを表します。結果は0 (\$000)~1023(\$3FF)の符号なし2進数で表されます。

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

### 17.11.2. 単極差動変換

差動チャネルで単極入力動作が使われると、その結果は右式で示されます。

VPOSは非反転入力ピンの電圧、VNEGは反転入力ピンの電圧、GAINは選択した倍率、 VRFFは選択した基準電圧です(89頁の表17-3と表17-4をご覧ください)。非反転ピンの

 $ADC = \frac{(V_{POS} - V_{NEG}) \times GAIN \times 1024}{1000}$ VREF

電圧は常に反転ピンの電圧より高くなければならず、さもなければ差電圧は0に飽和します。結果は0(\$000)~1023(\$3FF)の符号なし 2進数で表されます。GAINは1倍か20倍の何れかです。

### 17.11.3. 両極差動変換

既定としてA/D変換器は単極入力動作で働きますが、A/D変換制御/状態レジスタB(ADCSRB)の両極入力動作(BIN)ビットの1書き込 みにより両極入力動作が選べます。両極入力動作では±両側の差電圧が許され、従っ  $ADC = \frac{(V_{POS} - V_{NEG}) \times GAIN \times 512}{1}$ て反転入力ピンの電圧は非反転入力ピンの電圧よりも高くもできます。差動チャネルで両

VPOSは非反転入力ピンの電圧、VNEGは反転入力ピンの電圧、GAINは選択した倍率、VREFは選択した基準電圧です。結果は-512 (\$200)から0(\$000)を通って+511(\$1FF)までの符号付き2進数で表されます。GAINは1倍か20倍の何れかです。

けれども信号が本質動作(10ビットとして符号+9ビット)で両極でない場合、この仕組みは変換器の機能範囲(ダイナミック レンジ)の1ビットを 失います。そこで使用者が最大機能範囲での変換実行を欲するなら、使用者は(変換)結果を素早く調べ、選択可能な差動入力対 で単極差動変換を使えます(入力極性反転動作、換言すると90頁でADCSRBの入力極性反転(IPR)ビットをご覧ください)。極性検査 実行時、それは結果のMSB読み込み(ADCHのADC9t'ット)で充分です。このt'ットが1ならば結果が負、0ならば正です。

### 17.12. 温度測定

温度測定はシングル エント、ADC4チャネルに連結されるチップ上の温度感知器に基きます。A/D多重器選択(ADMUX)レジスタのチャネル選択 (MUX3~0)ビットへの'1111'書き込みによるADC4チャネル選択がこの温度感知器を許可します。1.1V内部基準電圧も温度感知器測定でA/D変換器基準電圧源に選択されなければなりません。温度感知器が許可されると、A/D変換器は温度感知器上の電圧測定を単独変換動作(ADATE=0)で使うことができます。

測定した電圧は表17-2.で記述されたように温度に対して直線的関係を持ちます。 感度は概ね1LSB/℃で、精度は使用者校正に依存します。代表的には、室温校正 との仮定で、単独温度校正後の測定精度は±10℃です。より良い精度は校正に対 して2つの温度点を使うことで達せられます。

| 表17-2. 温度対感知 | 表17-2. 温度対感知器出力電圧(代表値) |      |      |  |  |  |  |  |  |  |
|--------------|------------------------|------|------|--|--|--|--|--|--|--|
| 温度(℃)        | -40°C                  | +25℃ | +85℃ |  |  |  |  |  |  |  |
| A/D変換値(LSB)  | 230                    | 300  | 370  |  |  |  |  |  |  |  |

表17-2.に記載した値は代表値です。然しながら製法変化のため、温度感知器出力電圧は或るチップと別のチップで変化します。より正確な結果達成を可能とするために温度測定は応用ソフトウェアで校正できます。校正ソフトウェアは次式を使って行なえます。

 $T(温度) = k \times (ADCH < 8 | ADCL) - TOS$ 

ここでADCH:ADCLはA/D変換器データレジスタ、kは固定傾斜係数、TOSは温度感知器オフセット値です。代表的に係数kは1.0に大変近く、単点校正ではこの係数を省略できるかもしれません。高精度が要求される場合、傾斜係数は2つ温度での測定を基に評価されるべきです。



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

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

| ピット         | 7     | 6     | 5     | 4     | 3    | 2    | 1    | 0    | _     |
|-------------|-------|-------|-------|-------|------|------|------|------|-------|
| \$07 (\$27) | REFS1 | REFS0 | ADLAR | REFS2 | MUX3 | MUX2 | MUX1 | MUX0 | ADMUX |
| 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    |       |

#### ● ビット4.7.6 - REFS2~0: 基準電圧選択 (Reference Select Bits)

これらのビットは表17-3.で示されるようにA/D変換器の基準電圧(VREF)を選びます。これらのビットが変換中に変更されると、その変更は変換が完了する(ADCSRAのADIF=1)まで実施しません。これらのビットが変更されると、次の変換は必ず25A/D変換クロック掛かります。活動するチャネルが使われる場合、基準電圧としてVCCまたは(VCC-1V)よりも高い外部AREFの使用は、これがA/D変換精度に影響を及ぼすために推奨されません。

#### 表17-3. A/D変換部の基準電圧選択

| REFS2 | REFS1 | REFS0 | 基準電圧 (V <sub>REF</sub> )                                |
|-------|-------|-------|---------------------------------------------------------|
| X     | 0     | 0     | 基準電圧としてVCC使用 (AREF(PB0)ピン切断)                            |
| X     | 0     | 1     | AREF(PB0)ピンの外部基準電圧 (内部基準電圧はOFF)                         |
| 0     | 1     | 0     | AREF(PB0)外部デカップ用コンデンサなし、1.1V内部基準電圧 (AREF(PB0)ピン切断)      |
| 0     | 1     | 1     | (予約)                                                    |
| 1     | 1     | 0     | AREF(PB0)外部デカップ用コンデンサなし、2.56V内部基準電圧 (注) (AREF(PB0)ピン切断) |
| 1     | 1     | 1     | AREF(PBO)外部デカップ用コンデンサあり、2.56V内部基準電圧(注)                  |

**注**: このデバイスは2.56V基準電圧を生成するために3V以上の供給電圧が必要です。

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

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

### ● ビット3~0 - MUX3~0: A/Dチャネル選択 (Analog Channel Select Bits 3~0)

これらビットの値はA/D変換器にどのアナログ入力の組み合わせが接続されるかを選びます。差動入力(ADC0-ADC1またはADC2-ADC3)の場合、利得選択もこれらのビットで行なわれます。差動利得段への両入力としてのADC0またはADC2選択はオフセット測定を可能にします。シングル エンド チャネルADC4選択は温度感知器を許可します。詳細については表17-4.をご覧ください。これらのビットが変換中に変更される場合、その変更は変換が完了する(ADCSRAのADIF=1)まで実施しません。

表17-4. アナログ入力チャネル選択

| MUX3~0    | シングル エント  | 差動        | 入力 (IPR=0) |            | MUX3~0             | シングル エント   | 差動        | 差動入力 (IPR= <mark>0</mark> ) |            |  |
|-----------|-----------|-----------|------------|------------|--------------------|------------|-----------|-----------------------------|------------|--|
| WIU∧3~U   | 入力        | 非反転入力     | 反転入力       | 利得         | MUX3~0             | 入力         | 非反転入力     | 反転入力                        | 利得         |  |
| 0000      | ADC0(PB5) |           |            |            | 1000 ( <b>注1</b> ) |            | ADC0(PB5) | ADC0(PB5)                   | $\times 1$ |  |
| 0001      | ADC1(PB2) |           |            |            | 1001 ( <b>注1</b> ) |            | ADC0(PB5) | ADC0(PB5)                   | ×20        |  |
| 0010      | ADC2(PB4) |           |            |            | 1010               |            | ADC0(PB5) | ADC1(PB2)                   | $\times 1$ |  |
| 0011      | ADC3(PB3) |           |            |            | 1011               |            | ADC0(PB5) | ADC1(PB2)                   | ×20        |  |
| 0100 (注1) |           | ADC2(PB4) | ADC2(PB4)  | $\times 1$ | 1100 ( <b>注2</b> ) | 1.1V/2.56V |           |                             |            |  |
| 0101 (注1) |           | ADC2(PB4) | ADC2(PB4)  | ×20        | 1101               | 0V(GND)    |           |                             |            |  |
| 0110      |           | ADC2(PB4) | ADC3(PB3)  | $\times 1$ | 1110               |            |           |                             |            |  |
| 0111      |           | ADC2(PB4) | ADC3(PB3)  | ×20        | 1111 ( <b>注3</b> ) | ADC4       |           |                             |            |  |

注1: オフセット校正専用。83頁の「操作」をご覧ください。

**注2**: 内部基準電圧切り替え後、A/D変換器は測定が安定するのに先立って1msの安定時間が必要です。これに先立つ変換開始は信頼できないかもしれません。A/D変換器はこの安定時間中に許可されなければなりません。

注3: 温度感知器用。

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

| ピット         | 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変換完了割り込みが活性に(許可)されます。

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

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

| 表17-5. / | 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 |

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

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

#### ● ビット7 - BIN: 両極入力動作 (Bipolar Input Mode)

利得段は既定として単極動作で動きますが、このBINビット(=1)書き込みによって両極動作が選択できます。単極動作では(±の)片側変換だけが支援され、非反転入力の電圧は反転入力の電圧よりも常に高くなければなりません。さもなければ、その結果は基準電圧に飽和されます。両極動作では(±の)両側変換が支援され、その結果は2の補数形式で表されます。単極動作での分解能は10ビットで、両極動作での分解能は9ビット+1符号ビットです。

### ● ビット5 - IPR:入力極性反転 (Input Polarity Reversal)

入力極性動作は予め決まった入力極性との認識で、ソフトウェアに単極入力動作での全10ビットA/D変換分解能と選択可能な差動入力対を許します。入力極性が判らない場合、先に(1符号ビット+9ビット分解能のA/D変換測定での)両極入力動作を使うことにより、実際に極性を決めることが可能です。そして一旦決まったなら、後続する10ビット単極測定用に必要に応じて極性反転ビットを設定(1)または解除(0)してください。



● ビット4.3 - Res: 予約 (Reserved Bits)

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

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

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

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

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

|             | 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    |      |
|             | ADC1    | ADC0 | -    | -    | -    | -    | -    | _    | ADCL |
|             |         |      |      |      |      |      |      |      |      |

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

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

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

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

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

| \$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     |       |

ビット7,6 - Res: 予約 (Reserved Bits) (訳注:共通性から本項追加)

これらのビットは将来の使用に対して予約されています。将来のデバイスとの共通性のため、DIDR0が書かれるとき、これらのビットは<mark>0</mark>が書かれなければなりません。

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

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

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

### 18.1. 特徴

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

### 18.2. 概要

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

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

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

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

デバッグWIREが使われるシステムの設計時、以下が厳守されなければなりません。

- 図18-1. デバッグWIRE構成図

  1.8~5.5V

  VCC

  dW(RESET)

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

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

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

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

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

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

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

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

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

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

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

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



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



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

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

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

- 手段1 (ページ消去前の一時緩衝部格納)
  - ① ページー 時緩衝部を満たしてください。
  - ② ページ消去を実行してください。
  - ③ ページ書き込みを実行してください。
- 手段2 (ページ消去後の一時緩衝部格納)
  - へーシー消去を実行してください。
  - ② ページー時緩衝部を満たしてください。
  - ③ ページ書き込みを実行してください。

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

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

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

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

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

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

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

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

ページ書き込みを行うにはZポインタにアトレスを設定してSPMCSRに'00000101'を書き、SPMCSR書き込み後4クロック周期内にSPM命令を実行してください。R1とR0のデータは無視されます。ページ、アトレスは(Zポインタの)PCPAGEに書かれなければなりません。この操作の間中、Zポインタの他のビットは0を書かれなければなりません。

注: ページ書き込み中、CPUは停止されます。

### 19.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) | Z7  | Z6  | Z5  | Z4  | Z3  | Z2  | Z1 | Z0 |

フラッシュ メモリがヘージ で構成されるため(99頁の表20-8.参照)、プログラム カウンタ(アドレス ポインタ)は2つの違う領域を持つように取り扱われます。1つの領域は下位側ビットから成り、ヘージ内の語(ワード)をアドレス指定し、一方上位側ビットはそのヘージをアドレス指定します。これは次頁の図19-1.で示されます。ヘージ消去とヘージ書き込み操作が個別にアドレス指定されることに注意してください。従ってソフトウェアはヘージ消去とヘージ書き込み操作の両方で同じヘージをアドレス指定することが最も重要です。

LPM命令はアト・レスを格納するのにZポインタを使います。この命令はフラッシュメモリのバイト単位をアドレス指定するので、Zポインタの最下位ビット(Z0)も使われます。





## 19.5. SPM命令での書き込み時のEEPROM書き込みによる妨害

EEPROM書き込み動作がフラッシュ メモリへの全ソフトウェア プログラミングを妨げることに注意してください。ソフトウェアからのヒューズと施錠ビット読み出しもEEPROM書き込み動作中、妨げられます。使用者はEEPROM制御レジスタ(EECR)のEEPROMプログラム許可(EEPE)ビットを検査し、SPM命令制御/状態レジスタ(SPMCSR)へ書く前に、このビットが解除(0)されているのを確認することが推奨されます。

### 19.6. ソフトウェアからの施錠・ヒュース、と識票データの読み出し

ファームウェアからヒュース、と施錠ビットを読むことが可能です。加えてファームウェアはデバイス識票銘刻部(99頁参照)からデータを読むこともできます。

注: プログラム(0)されたヒューズと施錠ビットは0として読めます。非プログラム(1)にされたヒューズと施錠ビットは1として読めます。

#### 19.6.1. ファームウェアからの施錠ビット読み出し

SPMCSRでフラッシュ/施錠ビット読み込み(RFLB)とSPM操作許可(SPMEN)ビットを設定(1)した後の3CPU周期内のLPM命令実行は転送 先レジスタ内に施錠ビット値を返します。RFLBとSPMENビットは施錠ビット読み出しの完了で、または3CPU周期内にLPM命令が実行されないか、または4CPU周期内にSPM命令が実行されない場合、自動的に解除(0)されます。通常、RFLBとSPMENビットが解除(0)されるのはLPMの作用です。

施錠ビットを読むには以下の手続きに従ってください。

- ① Zポインタに\$0001を格納してください。
- ② SPMCSRでRFLBとSPMENt'ットを設定(1)してください。
- ③ 3クロック周期内にLPM命令を実行してください。
- ④ LPM転送先レシ、スタから施錠ビット値を読んでください。

成功なら、転送先レジスタの内容は次のとおりです。



より多くの情報については97頁の「プログラム メモリとデータ メモリ用施錠ビット」をご覧ください。

## 19.6.2. ファームウェアからのヒュース゛ビット読み出し

ヒューズバイトを読む方法はアドレスが異なるだけで上記の施錠ビット読み出しと同様です。ヒューズ下位バイト(FLB)を読むには以下の手続きに従ってください。

- ① Zポインタに\$0000を格納してください。
- ② SPMCSRでRFLBとSPMENt ットを設定(1)してください。
- ③ 3クロック周期内にLPM命令を実行してください。
- ④ LPM転送先レジスタからFLB値を読んでください。

成功なら、転送先レジスタの内容は次のとおりです。



ヒューズ下位バイの配置と詳細記述については98頁の表20-5.を参照してください。



ヒューズ上位バイト(FHB)を読むには単にZポインタ内のアドレスを<mark>\$0003</mark>に置き換え、前の手続きを繰り返してください。成功なら、転送先レ ジスタの内容は次のとおりです。

| ピット | 7    | 6    | 5    | 4    | 3    | 2    | 1    | 0    |
|-----|------|------|------|------|------|------|------|------|
| Rd  | FLB7 | FLB6 | FLB5 | FLB4 | FLB3 | FLB2 | FLB1 | FLB0 |

ヒュース、上位バイの配置と詳細記述については98頁の表20-4.を参照してください。

ヒューズ拡張バイト(FEB)を読むにはZポインタ内のアドレスを\$0002に置き換え、直前の手続きを繰り返してください。成功なら、転送先レジス タの内容は次のとおりです。

| ピット | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0    |
|-----|---|---|---|---|---|---|---|------|
| Rd  | _ | - | - | _ | - | _ | - | FHB0 |

ヒュース、拡張バイの配置と詳細記述については98頁の表20-3.を参照してください。

#### 19.6.3. ファームウェアからのデバイス識票銘刻読み出し

デバイス識票銘刻部の内容を読むには以下の手続きに従ってください。

- ① Zポインタに銘刻指示子を格納してください。
- ② SPMCSRでデバイス識票銘刻読み込み(RSIG)とSPM操作許可(SPMEN)ビットを設定(1)してください。
- ③ 3クロック周期内にLPM命令を実行してください。
- ④ SPMENt'yトが解除(0)されるために3クロック周期待機してください。
- ⑤ LPM転送先レジスタから表データ値を読んでください。

RSIGとSPMENのビットは3 CPU周期後に自動解除(0)されます。RSIGとSPMENが解除されると、LPM命令は「命令要約」の説明で記述 されるように動きます。

以下のプログラム例をご覧ください。

# アセンブリ言語プログラム例

;表指示子上位バイが値設定 DSIT read: LDI ZH, 0 ;表指示子下位バイト値設定 LDT ZL, 1 R17, (1<<RSIG) | (1<<SPMEN) ;RSIG,SPMEN=1值取得 LDI OUT SPMCSR, R16 ;RSIG,SPMEN=1設定 ;\$0001位置の識票値取得 LPM

R16, Z

RET ;呼び出し元へ復帰

#### 注: 4頁の「コート・例」をご覧ください。

成功なら、転送先レシ、スタの内容は99頁の「デバイス識票銘刻部」項で記述されたとおりです。

## 19.7. フラッシュ メモリ データ化けの防止

低VCCの期間中、CPUとフラッシュメモリの正しい動作に対して供給電圧が低すぎるためにフラッシュメモリのプログラムが不正にされ得ます。 これらの問題はフラッシュ メモリを使う基板段階の装置と同じで、同じ設計上の解決策が適用されるべきです。

フラッシュ メモリのプログラム化けは電圧が低すぎる時の2つの状態によって起こされます。1つ目としてフラッシュ メモリへの通常の書き込み手 順は正しく動作するための最低電圧が必要です。2つ目として供給電圧が低すぎると、CPU自身が命令を間違って実行し得ます。

フラッシュ メモリ化けは次の推奨設計によって容易に避けられます(1つは必須)。

- 不十分な供給電源電圧の期間中、AVR RESETを活性(Low)に保ってください。これは動作電圧が検出電圧と一致するなら、内部 低電圧検出器(BOD)を許可することによって行えます。そうでなければ外部低VCCリセット保護回路が使えます。書き込み操作進行 中にリセットが起こると、その書き込み動作は供給電源電圧が充分であれば完了されます。
- 低VCCの期間中、AVRコアをパワーダウン休止動作に保ってください。これはCPUが命令の復号と実行を試みるのを防ぎ、SPMCSR 従ってフラッシュメモリを予期せぬ書き込みから効果的に保護します。

### 19.8. SPM命令使用時のフラッシュ メモリ用プログラミング(書き込み)時間

校正された内蔵RC発振器がフラッシュ メモリ アクセス時間に使われます。表19-1.はCPUからのフラッシュ メモリ アクセスに対する代表的なプログ ラミング時間を示します。

### 表19-1. SPM命令によるフラッシュ メモリのプログラミング時間

| 項目                                         | Min   | Max   |
|--------------------------------------------|-------|-------|
| SPM命令によるフラッシュ書き込み(ページ消去、ページ書き込み、施錠ビット書き込み) | 3.7ms | 4.5ms |

注: MinとMaxの時間は(項目の)個別操作毎に対してです。



### 19.9. 自己プログラミング用レジスタ

### 19.9.1. SPMCSR - SPM命令制御/状態レジスタ (Store Program Memory Control and Status Register)

このレシ、スタはプログラムメモリ操作を制御するために必要とする制御ビットを含みます。

| ピット         | 7 | 6 | 5    | 4    | 3    | 2     | 1     | 0     | _      |
|-------------|---|---|------|------|------|-------|-------|-------|--------|
| \$37 (\$57) | _ | - | RSIG | СТРВ | RFLB | PGWRT | PGERS | SPMEN | SPMCSR |
| 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 Bits)

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

#### ● ビット5 - RSIG: デバイス識票銘刻読み込み (Read Device Signature Imprint Table)

SPMCSRでRSIGとSPMENが設定(1)された後の3クロック周期内のLPM命令実行はディブイス識票銘刻部から(Zポインタ値に依存する)選択したデータを転送先レジスタ内に返します。詳細については99頁の「デバイス識票銘刻部」をご覧ください。

### ● ビット4 - CTPB : ページ一時緩衝部消去 (Clear Temporary Page Buffer)

ぺーシー・中緩衝部を満たしている間にCTPBビットが1を書かれると、ペーシー・中緩衝部は消去され、データが失われます。

#### ● ビット3 - RFLB: ヒューズ/施錠ビット読み込み (Read Fuse and Lock Bits)

SPMCSRでRFLBとSPMENが設定(1)された後の3クロック周期内のLPM命令は(ZポインタのZ0に依存して)ヒューズビットまたは施錠ビットのどちらかを転送先レジスタに読みます。詳細については94頁の「ソフトウェアからのヒューズビットと施錠ビットの読み出し」をご覧ください。

#### ● ビット2 - PGWRT : ページ書き込み (Page Write)

このビットがSPMENと同時に1を書かれると、次の4クロック周期内のSPM命令は一時緩衝部に格納したデータでページ書き込みを実行します。 ページ アドレスはZポインタの上位部から取得されます。 R1とR0のデータは無視されます。 PGWRTビットはページ書き込みの完了で、または4クロック周期内にSPM命令が実行されない場合、自動的に解除(0)されます。 ページ全体の書き込み動作中に、CPUは停止されます。

### ● ビット1 - PGERS: ページ消去 (Page Erase)

このビットがSPMENと同時に1を書かれると、次の4クロック周期内のSPM命令はページ消去を実行します。 ページアドレスはZポインタの上位部から取得されます。R1とR0のデータは無視されます。PGERSビットはページ消去の完了で、または4クロック周期内にSPM命令が実行されない場合、自動的に解除(0)されます。 ページ全体の消去中、CPUは停止されます。

### ● ビット0 - SPMEN: SPM操作許可 (Store Program Memory Enable)

このビットは次の4クロック周期間、SPM命令を許可します。このビットがRSIG,CTPB,RFLB,PGWRT,PGERSのどれかと共に1に設定されると、別のところで記述されるように続くSPM命令は特別な意味を持ちます。

SPMENだけが書かれると、続くSPM命令はZポインタによってアドレス指定したページ一時緩衝部へR1:R0の値を格納します。Zレジスタの最下位ビットは無視されます。SPMENビットはSPM命令の完了で、または4クロック周期内にSPM命令が実行されない場合、自動的に解除(0)されます。ページ消去とページ書き込み中、SPMENビットはその動作が完了されるまで1に留まります。



# 20. メモリ プログラミング

本項はATtiny25/45/85のメモリ プログラミングに対する各種方法を記述します。

# 20.1. プログラム メモリとデータ メモリ用施錠ビット

ATtiny25/45/85は、非プログラム(1)のままか、表20-2.で一覧される付加機能を得るためにプログラム(0)できる2つの施錠ビットを提供します。この施錠ビットはチップ消去指令でのみ1に消去できます。

プログラム メモリは例え施錠ビットが設定されていても、デバッグWIRE許可(DWEN)ヒュースがプログラム(0)されていると、デバッグWIREインターフェース経由で読み出せます。従って施錠ビット保護が必要とされる場合、(DWENヒュースでの解除(=1))によってデバッグWIREが常に禁止されるべきです。

表20-1. 施錠ビット バイの内容

| 名称  | ピット番号 | 意味                                | 既定値(注)     |
|-----|-------|-----------------------------------|------------|
| _   | 7     |                                   | 1 (非プログラム) |
| _   | 6     |                                   | 1 (非プログラム) |
| _   | 5     |                                   | 1 (非プログラム) |
| _   | 4     |                                   | 1 (非プログラム) |
| _   | 3     |                                   | 1 (非プログラム) |
| _   | 2     |                                   | 1 (非プログラム) |
| LB2 | 1     | フラッシュとEEPROMメモリに対する一般保護用施錠ビット     | 1(非プログラム)  |
| LB1 | 0     | フラッシュCEEFNO!VI/モリ(CX) りる一阪市設用施設しず | 1 (非プログラム) |

注: 0はプログラム、1は非プログラムを意味します。

### 表21-2. 施錠ビットの保護種別

| メモリ施錠ビット |     | •                                        | 保護種別                                                                              |
|----------|-----|------------------------------------------|-----------------------------------------------------------------------------------|
| LB 種別    | LB2 | LB2 LB1 直列、並列、またはデバッグWIRE経由プログラミングに対する保護 |                                                                                   |
| 1        | 1   | 1                                        | メモリ施錠機能は機能しません。                                                                   |
| 2        | 1   | 0                                        | フラッシュ、EEPROMの更なるプログラミング(書き込み)が禁止されます。ヒュース゛ビットが固定されます。 ( <mark>注1</mark> )         |
| 3        | 0   | 0                                        | フラッシュ、EEPROMの更なるプログラミング(書き込み)と照合(読み出し)が禁止されます。ヒュース・ヒットが固定されます。( <mark>注1</mark> ) |

注: 0はプログラム、1は非プログラムを意味します。

注1: 施錠ビットを書く前にヒューズビットを書いてください。デバッグWIREは全面的に禁止されます。

施錠ビットはデバイス ファームウェアによって読むこともできます。94頁の「**ソフトウェアからの施錠,ヒューズと識票のデータ読み出し**」項をご覧ください。



### 20.2. ヒュース゛ヒ゛ット

ATtiny25/45/85には**表20-3**.~5.で記述されるように3つのヒュース、ハイトがあります。ヒュース、はプログラムされると、論理0として読まれることに注意してください。

### 表20-3. 拡張ヒューズバイト一覧

| 名称             | ピット          | 意味             | 既定値                     |
|----------------|--------------|----------------|-------------------------|
| _              | 7 <b>~</b> 1 |                | 1 (非プログラム)              |
| SELFPRGEN (注1) | 0            | 自己プログラミング機能許可。 | 1 (非プログラム) 自己プログラミング不許可 |

注1: SPM命令許可。93頁の「フラッシュ メモリの自己プログラミング」をご覧ください。

#### 表20-4. ヒューズ上位バイト一覧

| 名称                      | ピット | 意味                                           | 既定值                                      |
|-------------------------|-----|----------------------------------------------|------------------------------------------|
| RSTDISBL( <b>注1,2</b> ) | 7   | PB5がI/OピンかまたはRESETピンかを選択します。                 | 1 (非プログラム) PB5/はRESETt°ン                 |
| DWEN ( <b>注1,2,3</b> )  | 6   | デバッグWIRE機能許可。                                | 1 (非プログラム) ディック WIRE不許可                  |
| SPIEN ( <b>注4</b> )     | 5   | 低電圧直列プログラミング許可。                              | <ul><li>(プログラム) 低電圧直列プログラミング許可</li></ul> |
| WDTON ( <b>注5</b> )     | 4   | ウォッチドッグタイマ常時有効。                              | 1 (非プログラム) WDTはWDTCRで許可                  |
| EESAVE                  | 3   | チップ消去からEEPROM内容を保護。                          | 1 (非プログラム) EEPROMは未保護                    |
| BODLEVEL2               | 2   |                                              | 1 (非プログラム)                               |
| BODLEVEL1               | 1   | 低電圧検出(BOD)リセットの制御と検出電圧選択。( <mark>注6</mark> ) | 1 (非プログラム)                               |
| BODLEVEL0               | 0   |                                              | 1 (非プログラム)                               |

注1: RESETピンの使用法を制御します。39頁の「ポートBの交換機能」をご覧ください。

注2: これらのヒュース、がプログラム(0)されてしまった後、デバイスは高電圧直列動作でだけプログラミングできます。

**注3**: 施錠ビット保護が必要とされるとき、非プログラム(1)にされなければなりません。前頁の「**プログラム メモリとデータ メモリ用施錠ビット**」をご覧ください。

注4: このヒュース、は低電圧直列プログラミングでアクセスできません。

注5: 詳細については31頁の「WDTCR - ウォッチドック、タイマ制御レシ、スタ」をご覧ください。

注6: 111頁の「BODLEVELtュース<sup>\*</sup>符号化」表をご覧ください。

### 表20-5. ヒュース 下位 バ 仆一覧

| 名称                   | ピット | 意味               | 既定值                                                |
|----------------------|-----|------------------|----------------------------------------------------|
| CKDIV8 ( <b>注1</b> ) | 7   | システム クロック 8分周選択。 | 0 (プログラム) 8分周                                      |
| CKOUT ( <b>注2</b> )  | 6   | システム クロック出力許可。   | 1 (非プログラム) 不許可                                     |
| SUT1                 | 5   | 起動時間選択。 (注3)     | 1 (非プログラム)                                         |
| SUT0                 | 4   | 性影時間迭代。          | <mark>0</mark> (プ <sup>°</sup> ロク <sup>*</sup> ラム) |
| CKSEL3               | 3   |                  | <mark>0</mark> (プ <sup>°</sup> ロク <sup>*</sup> ラム) |
| CKSEL2               | 2   | <br>  クロック種別選択。  | <mark>0</mark> (プ <sup>°</sup> ロク <sup>*</sup> ラム) |
| CKSEL1               | 1   | クロック性がJ.迭が。      | 1 (非プログラム)                                         |
| CKSEL0               | 0   |                  | <mark>0</mark> (プ <sup>°</sup> ロク <sup>*</sup> ラム) |

注1: 詳細については20頁の「システム クロック前置分周器」をご覧ください。

注2: (PBO)ピンに出力することをシステム クロックに許します。詳細については20頁の「クロック出力緩衝部」をご覧ください。

**注3**: 既定値は既定クロック元に対する最大起動時間を与えます。詳細については18頁の表6-7.をご覧ください。

注4: 既定設定は8MHz校正付き内蔵RC発振器を選択します。詳細については18頁の表6-6.をご覧ください。

施錠ビット1(LB1)がプログラム(0)されると、ヒューズビットが固定されることに注意してください。施錠ビットをプログラム(0)する前にヒューズビットをプログラミング(書き込み)してください。ヒューズビットの状態はチップ消去によって影響されません。

ヒュース、ビットはデバイス ファームウェアによって読むこともできます。94頁の「**ソフトウェアからの施錠,ヒュース、と識票のデータ読み出し**」項をご覧ください。

#### 20.2.1. ヒュース のラッチ

ヒューズ値はデバイスがプログラミング動作へ移行する時にラッチされ、ヒューズ値への変更はデバイスがプログラミング動作を去るまで無効です。これは一旦プログラム(0)されると直ぐに効果があるEESAVEヒューズには適用されません。ヒューズは電源投入でもラッチされます。



### 20.3. デバイス 識票銘刻部

デバイス識票銘刻部はデバイス識票、発振器校正データのような一連の各種デバイス情報に使われる専用のメモリ領域です。表20-6.で略 述されるようにこのメモリ領域の殆どは内部使用に予約されています。

| 表20-6  | -**/7 | ᆎᇠᄼᄼᆉ | والمواطعا |
|--------|-------|-------|-----------|
| オマンリーり | エハ 1人 | 亚美扬列  | ᄞᄭᄶ       |

| アト・レス     | 上位バイト                                        |
|-----------|----------------------------------------------|
| \$00      | 識票バイト0 ( <mark>注</mark> 1)                   |
| \$01      | 8.0MHzでの校正付き内蔵RC発振器用校正データ( <mark>注2</mark> ) |
| \$02      | 識票バイト1 ( <mark>注</mark> 1)                   |
| \$03      | 6.4MHzでの校正付き内蔵RC発振器用校正データ(注2)                |
| \$04      | 識票バイト2 ( <mark>注</mark> 1)                   |
| \$05~\$2A | (内部使用予約)                                     |

注1: より多くの情報については「識票バイト」をご覧ください。 注2: より多くの情報については「校正値バイト」をご覧ください。

#### 20.3.1. 識票が化

全てのAtmelマイクロコントローラはデバイスを識別する3バイの識票符号を持ちます。この符 号は低電圧直列と高電圧直列の両プログラミング動作で、またデバイスが施錠されていて も読めます。

識票バイトはデバイス ファームウェアによって読むこともできます。 94頁の「ソフトウェアからの施 錠、ヒューズと識票のデータ読み出し」項をご覧ください。

この3バイトの識票バイトはデバイス識票銘刻部と呼ばれる分離された空間に存在します。 ATtiny25/45/85用の識票バイトは表20-7.で与えられます。

| 表20-7. デバイスの | の識別番   | 号(ID)   |        |
|--------------|--------|---------|--------|
| 部品番号         | 識男     | 真バイト アロ | ・レス    |
| 叩叩钳方         | \$0000 | \$0001  | \$0002 |
| ATtiny25     | \$1E   | \$91    | \$08   |
| ATtiny45     | \$1E   | \$92    | \$06   |
| ATtinv85     | \$1E   | \$93    | \$0B   |

### 20.3.2. 校正値バイ

表20-6.で示されるようにATtiny25/45/85のデバイス識票銘刻部は内蔵RC発振器用に2バイトの校正値を含みます。標準動作ではリセッ ト中に8.0MHz動作用の校正データが自動的に取得されて発振校正(OSCCAL)レジスタに書かれます。ATtiny15互換動作では6.4MHz 動作用の校正データが代わりに使われます。この手順は内蔵発振器が常に正しい周波数に校正されるのを保証します。

発振校正バイトはデバイス ファームウェアによって読むこともできます。 94頁の「ソフトウェアからの施錠,ヒューズと識票のデータ読み出し」項をご覧 ください。

# 20.4. へージ 容量 表20-8. フラッシュ メモリのヘージ 数とヘージ の語数

| <b>デバイス</b> | 全容量            | ページ容量 | PCWORD | ページ数 | PCPAGE | PCMSB |
|-------------|----------------|-------|--------|------|--------|-------|
| ATtiny25    | 1Kワード(2Kバイト)   | 16ワード | PC3∼0  | 64   | PC9∼4  | 9     |
| ATtiny45    | 2Kワート (4Kハ イト) | 32ワート | PC4∼0  | 64   | PC10∼5 | 10    |
| ATtiny85    | 4Kワート (8Kハ イト) | 32ワート | PC4∼0  | 128  | PC11∼5 | 11    |

### 表20-9. EEPROMメモリのページ数とページの語数

| <b>デバイ</b> ス | 全容量    | ページ容量 | PCWORD | ページ数 | PCPAGE | EEAMSB |
|--------------|--------|-------|--------|------|--------|--------|
| ATtiny25     | 128バイト | 4バイト  | EEA1∼0 | 32   | EEA6∼2 | 6      |
| ATtiny45     | 256バイト | 4バイト  | EEA1∼0 | 64   | EEA7∼2 | 7      |
| ATtiny85     | 512バイト | 4バイト  | EEA1∼0 | 128  | EEA8∼2 | 8      |

### 20.5. 低電圧直列プログラミング

フラッシュとEEPROMの両メモリ配列はRESETがGNDに引かれている間に直列 SPIハ、スを使ってプログラミングできます。この直列インターフェースはSCK入力、 MOSI入力、MISO出力から成ります。右をご覧ください。

RESET がLowに設定された後、書き込み/消去操作が実行され得るのに先 立ってプログラミング許可命令が初めに実行されることを必要とします。

表20-10 低電圧直列プログラミッグ田ピッ配置

| ١. | 表20 10. 民電圧圏バット/ バン/ 川ビン品圏 |     |     |         |  |  |  |  |  |
|----|----------------------------|-----|-----|---------|--|--|--|--|--|
|    | 信号名                        | ピン名 | 入出力 | 機能      |  |  |  |  |  |
|    | MOSI                       | PB0 | 入力  | 直列データ入力 |  |  |  |  |  |
|    | MISO                       | PB1 | 出力  | 直列データ出力 |  |  |  |  |  |
|    | SCK                        | PB2 | 入力  | 直列クロック  |  |  |  |  |  |



ピンにクロック元を接続する必要はありません。

注: 上の表20-10.でSPIプログラミング用のピン配置が一覧されます。全てのデバイスが内部SPIインターフェースに対する専用SPIピンを使うとは 限りません。

EEPROMをプログラミングする時に自動消去周期が自動書き込み動作内に組み入れられ(低電圧直列プログラミングのみ)、チップ消去命令 を先に実行する必要がありません。チップ消去操作はプログラム(フラッシュ メモリ)とEEPROM両方の全メモリ位置の内容を\$FFにします。

CKSELヒュース、に依存して有効なクロックが存在しなければなりません。直列クロック(SCK)入力のLowとHighの区間の最小値は次のように定 義されます。

fcK<12MHz:Low区間>2CPUクロック周期 fCK<12MHz: High区間>2CPUクロック周期 fck≥12MHz:Low区間>3CPUクロック周期 fCK≥12MHz: High区間>3CPUクロック周期

#### 20.5.1. 低電圧直列プログラミング手順

ATtiny25/45/85に直列データを書く時にデータはSCKの上昇端で行われ、ATtiny25/45/85から読む時にデータはSCKの下降端で行わ れます。タイシグの詳細については図21-4と図21-5.をご覧ください。

低電圧直列プログラシング動作でのATtiny25/45/85のプログラシングと照合は次の手順が推奨されます(形式は表20-12.命令一式参照)。

- 1. 電源投入手順: RESETとSCKがLow(0)に設定されている間にVCCとGND間へ電源を印加します。
  - いくつかのシステムで電源投入中、SCKがLowに保持されるのを書き込み器が保証できません。この場合、SCKがLow(0)に設定 されてしまった後、RESETは正パルスを与えられなければなりません。 パルスの幅は最低trst+2CPUクロック周期でなければなりま せん。RESETt゚ンの最小パルス幅(tRST)の定義については110頁の表21-4.をご覧ください。
- 2. 最低20ms待ち、MOSIピンにプログラミング許可命令を送ることによって直列プログラミングを許可してください。
- 3. 通信が同期を外していると、直列プログラミング命令は動作しません。同期していると、プログラミング許可命令の第3バイ・送出時に第2 バイト(\$53)が戻ります。この戻りが正しいかどうかによらず、命令の4バイト全てが送信されなければなりません。\$53が戻らない場 合、RESETに正パルスを与え、新規プログラミング許可命令を行ってください。
- 4. フラッシュ メモリは1ペーシ 単位で書かれます。 ページ 容量は99頁の表20-8.で得られます。 このメモリ ページ はページ 設定命令と共にアド レスの下位4/5/5+1ビットとデータを供給することによって1バイトづつ設定されます。ページが正しく設定されるのを保証するため、与 えられたアトンスにデータ上位バイトが適用される前にデータ下位バイトが設定されなければなりません。プログラムメモリのペーシ、はアトンス の上位6/6/7ビットを含むページ書き込み命令の設定によって(フラッシュ メモリに)格納されます。 ポーリング(BSY/RDY)が使われない場 合、使用者は次のペーシーを行う前に最低twD FLASH(表20-11.参照)待たなければなりません。フラッシュ書き込み操作完了前の (ポーリング以外の)直列プログラミング、インターフェースでのアクセスは不正な書き込み結果になり得ます。
- 5. EEPROMはペーシー単位かハート単位のどちらかでプログラミングできます。

**バイト単位**: EEPROMは適切なEEPROM書き込み命令と共にアトレスとデータを供給することによって1バイト単位で書かれます。EEP ROMのメモリ位置は新規データが書かれるのに先立って始めで自動的に消去されます。ポーリング(BSY/RDY)が使われない場合、 次のバイトを行う前に最低tWD EEPROM(表20-11.参照)待たなければなりません。

ページ単位: EEPROMの1ページはEEPROMページ設定命令と共にアドレスの下位2ピットとデータを供給することによって1パイトづつ設 定されます。EEPROMへージはアドレスの上位5/6/7ビットを含むEEPROMへージ書き込み命令によって(EEPROMに)格納されます。 EEPROMぺージアクセス使用時、EEPROMぺージ設定命令で設定したバイト位置だけが変更されます。残りの位置は無変化で留まり ます。 ポーリング(BSY/RDY)が使われない場合、次のページ(表20-9.参照)を行う前に最低twp EEPROM(表20-11.参照)待たなけれ ばなりません。チップ消去されたデバイスでの\$FFデータは書かれる必要がありません。

- 6. どのメモリ位置も選択したアドレスの内容を直列出力MISOに読み戻す読み出し命令を使うことによって照合できます。
- 7. プログラミング作業終了時、RESETは通常動作を開始するため、High(1)に設定できます。
- 8. 電源OFF手順(必要とされるならば)
  - ① RESETをHigh(1)に設定します。
  - ② VCC電源をOFFにします。



表20-11. ヒューズ.フラッシュ.EEPROM次位置書き込み前の待機時間

| シンホ゛ル      | 最低待機時間 | 備考            |
|------------|--------|---------------|
| two_fuse   | 4.5ms  | ヒュース゛書き込み     |
| two_flash  | 4.5ms  | フラッシュ メモリ書き込み |
| twd_eeprom | 4.0ms  | EEPROM書き込み    |
| twd_erase  | 9.0ms  | チップ。消去        |

### 20.5.2. 低電圧直列プログラミング命令一式

表20-12.と次頁の図20-2.は命令一式を記述します。

表20-12. 低電圧直列プログラミング命令一式

| 命令                 |           | 命令     | 形式     | 備考      |                       |  |  |
|--------------------|-----------|--------|--------|---------|-----------------------|--|--|
| נד קח              | 第1バイト     | 第2バイト  | 第3バイト  | 第4バイト   | 川で                    |  |  |
| プログラミング許可          | \$AC      | \$53   | \$00   | \$00    |                       |  |  |
| チップ消去              | \$AC \$80 |        | \$00   | \$00    |                       |  |  |
| 多忙/準備可検査           | \$F0      | \$00   | \$00   | 状態値     | 最下位ビットが多忙フラグ。         |  |  |
| 設定系命令              |           |        |        |         |                       |  |  |
| 拡張アドレス設定(注1)       | \$4D      | \$00   | 拡張アドレス | \$00    |                       |  |  |
| フラッシュ ページ 内上位バ 仆設定 | \$48      | アドレス上位 | アドレス下位 | 上位バイト   |                       |  |  |
| フラッシュ ページ内下位バ 仆設定  | \$40      | アドレス上位 | アドレス下位 | 下位バイ    |                       |  |  |
| EEPROMページ内バイ設定     | \$C1      | \$00   | ページ内位置 | バイト     | 注:ページ内指示以外のビットは0。     |  |  |
| 読み出し命令             |           |        |        |         |                       |  |  |
| フラッシュメモリ上位バ・仆読み出し  | \$28      | アドレス上位 | アドレス下位 | 上位バイト   |                       |  |  |
| フラッシュメモリ下位バ・仆読み出し  | \$20      | アドレス上位 | アドレス下位 | 下位バイ    |                       |  |  |
| EEPROM読み出し         | \$A0      | アドレス上位 | アドレス下位 | バイト     |                       |  |  |
| 施錠ビット読み出し          | \$58      | \$00   | \$00   | 施錠ビット値  |                       |  |  |
| 識票バイト読み出し          | \$30      | \$00   | アトレス   | 識票バイト   |                       |  |  |
| ヒューズ下位読み出し         | \$50      | \$00   | \$00   | ヒューズ下位  |                       |  |  |
| ヒューズ上位読み出し         | \$58      | \$08   | \$00   | ヒューズ上位  |                       |  |  |
| 拡張ヒューズ読み出し         | \$50      | \$08   | \$00   | 拡張ヒューズ  |                       |  |  |
| 校正値読み出し            | \$38      | \$00   | \$00   | 校正値     |                       |  |  |
| 書き込み命令(注2)         |           |        |        |         |                       |  |  |
| フラッシュ ヘ゜ーシ゛書き込み    | \$4C      | アドレス上位 | アドレス下位 | \$00    |                       |  |  |
| EEPROMバイ書き込み       | \$C0      | アドレス上位 | アトレス下位 | バイト     |                       |  |  |
| EEPROMページ書き込み      | \$C2      | アドレス上位 | アドレス下位 | \$00    | 注:ページ指示以外のアドレス ビットは0。 |  |  |
| 施錠ビット書き込み          | \$AC      | \$E0   | \$00   | 施錠ビット値  |                       |  |  |
| ヒューズ下位書き込み         | \$AC      | \$A0   | \$00   | ヒューズ下位  |                       |  |  |
| ヒューズ上位書き込み         | \$AC      | \$A8   | \$00   | ヒュース・上位 |                       |  |  |
| 拡張ヒューズ書き込み         | \$AC      | \$A4   | \$00   | 拡張ヒューズ  |                       |  |  |

注1:全命令が全デバイスで利用可能な訳ではありません。

注2:プログラム用メモリにアクセスする命令は語(ワート)アトレスを使います。このアトレスはヘーシ、範囲内で乱順にできます。

<mark>注</mark>:・施錠ビットとヒューズ値はプログラムが<mark>0</mark>、非プログラムが<u>1</u>です。将来との互換性のため、未使用のヒューズと施錠ビットは非プログラム(<u>1</u>) にすべきです。

- ・ヒュース、施錠ビット、識票バイト、校正値、ページ容量については対応項を参照してください。
- ・プログラミングと書き込み器に関する応用記述については http://www.atmel.com/avr をご覧ください。
- ・第4バイトの赤背景はホスト読み込み(デバイス出力)を示します。

多忙/準備可検査バイト データ出力のLSBが1なら、プログラミング操作が未だ保留(動作中)です。次の命令が実行される前に本ビットが0 に戻るまで待ってください。

同じへージ内で、下位バイテータは上位バイテータに先行して格納されなければなりません。

データがヘーシ、緩衝部に格納された後にEEPROMヘージをプログラムしてください。次頁の図20-2.をご覧ください。





(<mark>訳補</mark>) フラッシュ メモリ、EEPROM、ページ緩衝部内のアトレス(位置)指定に使われるビットはメモリ容量とページ構成に依存します。ATtiny25/45/85でのこれらの指定方法は次表で要約されます。

### 表20-A. アドレス(第2,3バイト)指定法

| 命令             | 第2バイト                               | 第3バイト                               |                                  | 備考                                                            |
|----------------|-------------------------------------|-------------------------------------|----------------------------------|---------------------------------------------------------------|
| 拡張アドレス設定       |                                     |                                     | 該当命令なし                           |                                                               |
| フラッシュヘ゜ージ内バイ設定 | 0000 0000                           | 0000 LLLL<br>000L LLLL              | ATtiny25<br>ATtiny45/85          | : L=PC3~0<br>: L=PC4~0                                        |
| EEPROMページ内バイ設定 | 0000 0000                           | 0000 00LL                           | ATtiny25/45/85                   | : L=EEA1~0                                                    |
| フラッシュ メモリ読み出し  | 0000 00HH<br>0000 0HHH<br>0000 HHHH | LLLL LLLL                           | ATtiny25<br>ATtiny45<br>ATtiny85 | : H=PC9~8,L=PC7~0<br>: H=PC10~8,L=PC7~0<br>: H=PC11~8,L=PC7~0 |
| EEPROM読み出し     | 0000 0000<br>0000 000H              | OLLL LLLL<br>LLLL LLLL<br>LLLL LLLL | ATtiny25<br>ATtiny45<br>ATtiny85 | : L=EEA6~0<br>: L=EEA7~0<br>: H=EEA8,L=EEA7~0                 |
| フラッシュ ヘージ書き込み  | 0000 00HH<br>0000 0HHH<br>0000 HHHH | LLLL 0000<br>LLL0 0000<br>LLL0 0000 | ATtiny25<br>ATtiny45<br>ATtiny85 | : H=PC9~8,L=PC7~4<br>: H=PC10~8,L=PC7~5<br>: H=PC11~8,L=PC7~5 |
| EEPROMバイ書き込み   | 0000 0000<br>0000 000H              | OLLL LLLL<br>LLLL LLLL<br>LLLL LLLL | ATtiny25<br>ATtiny45<br>ATtiny85 | : L=EEA6~0<br>: L=EEA7~0<br>: H=EEA8,L=EEA7~0                 |
| EEPROMページ書き込み  | 0000 0000<br>0000 0000<br>0000 000H | OLLLLL00LLLLLL00LLLLLL00            | ATtiny25<br>ATtiny45<br>ATtiny85 | : L=EEA6~2<br>: L=EEA7~2<br>: H=EEA8,L=EEA7~2                 |



### **20.6**. 高電圧直列プログラミング

本項はATtiny25/45/85でのプログラム用フラッシュメモリ、データ用EEPROM、施錠ビット、ヒュース・ビットのプログラミングと照合の方法を記述します。

図20-3 高電圧直列プログラミング構成図

表20-13. 高電圧直列プログラミング用ピン配置

| 信号名 | ピン名 | 入出力 | 機能                   |  |  |  |  |  |
|-----|-----|-----|----------------------|--|--|--|--|--|
| SDI | PB0 | 入力  | 直列データ入力              |  |  |  |  |  |
| SII | PB1 | 入力  | 直列命令入力               |  |  |  |  |  |
| SDO | PB2 | 出力  | 直列データ出力              |  |  |  |  |  |
| SCI | PB3 | 入力  | 直列クロック入力(最小周期=220ns) |  |  |  |  |  |



高電圧直列プログラミング間中の直列クロック入力(SCI)に対する最小周期は220nsです。

表20-14. プログラミング動作移行に使用するピン値

| ピン(信号)名 | シンホ゛ル          | 値 |
|---------|----------------|---|
| SDI     | Prog_enable[0] | 0 |
| SII     | Prog_enable[1] | 0 |
| SDO     | Prog_enable[2] | 0 |

### 20.7. 高電圧直列プログラミング手順

高電圧直列プログラミング動作でのATtiny25/45/85のプログラミングと照合は次の手順が推奨されます(命令形式は表20-16.参照)。

### 20.7.1. 高電圧直列プログラミング動作への移行

次に示す方法がデバイスを高電圧直列プログラミング動作にします。

- ① VCCとRESETt°ンを0V、表20-14.で一覧されるProg\_enablet°ンを全てLow(0)に設定します。
- ② VCCとGND間に4.5~5.5Vを印加します。20us以内にVCCが最低1.8Vに達することを保証してください。
- ③ RESETに11.5~12.5Vを印加し、20~60µs待ちます。
- ④ Prog\_enable識別がラッチされてしまうのを確実にするため、高電圧が印加されてしまった後、最低10μs、Prog\_enablet°ンを無変化に保ちます。
- ⑤ Prog\_enable[2]/SDOピンでの駆動衝突を避けるため、Prog\_enable[2]/SDOピンを開放します。
- ⑥ SDI/SIIで如何なる直列命令を与える前に少なくとも300µs間待ちます。
- ⑦ デバイスの電源を落とすか、RESETピンをOVに持ってくることによってプログラミング動作を抜けます。

VCCの上昇時間が上で示した必要条件を完全に満たせない場合、次の代替手順が使えます。

- ① VCCとRESETt ンを0V、表20-14.で一覧されるProg\_enablet ンを全てLow(0)に設定します。
- ② VCCとGND間に4.5~5.5Vを印加します。
- ③ VCCを監視し、0.9~1.1Vに達したら直ぐ、REESTに11.5~12.5Vを印加します。
- ④ Prog\_enable識別がラッチされてしまうのを確実にするため、高電圧が印加されてしまった後、最低10μs、Prog\_enablet°ンを無変化に保ちます。
- (5) Prog enable[2]/SDOピンでの駆動衝突を避けるため、Prog enable[2]/SDOピンを開放します。
- ⑥ SDI/SIIで如何なる直列命令を与える前に、VCCが実際に4.5~5.5Vに達するまで待ちます。
- ⑦ デバイスの電源を落とすか、RESETピンを0Vに持ってくることによってプログラミング動作を抜けます。

# 表20-15. 高電圧リセット特性

| 供給電圧(VCC) | RESETピン高電圧閾値電圧 (V <sub>HVRST</sub> ) | プログラミング許可識別ラッチに対する最小高電圧時間(t <sub>HVRST</sub> ) |
|-----------|--------------------------------------|------------------------------------------------|
| 4.5V      | 11.5V                                | 100ns                                          |
| 5.5V      | 11.5V                                | 100ns                                          |



### 20.7.2. 効率的なプログラミングへの考慮

設定した命令とアドレスはプログラミング中、デバイス内で維持されます。効率的なプログラミングを行うために次が考慮されるべきです。

- 複数のメモリ領域を読み書きする時に命令設定は一度だけ必要です。
- チップ消去後のフラッシュ メモリと(EESAVEヒュース゛がプログラム(O)されている場合を除き)EEPROM全体の内容は\$FFなので、値が\$FFのデータ書き込みを飛ばします。
- アト・レス上位バイトはフラッシュ メモリで新規256語(ワート))枠、EEPROMで新規256バイト枠の読み書き前に一度だけ必要です。この考慮は 識票バイト読み出しにも適用されます。

### 20.7.3. チップ 消去

チップ消去はフラッシュ メモリ、EEPROM(<mark>注1</mark>)、施錠ビットを消去します。施錠ビットはプログラム メモリが完全に消去されてしまうまでリセット(消去) されません。ヒュース、ヒットは変更されません。チップ消去はフラッシュ メモリやEEPROMが再書き込みされる前に実行されなければなりません。

注1: EESAVEヒューズがプログラム(0)されていると、EEPROMはチップ消去中、保護されます。

- (1) チップ消去命令を設定します(表20-16,をご覧ください)。
- ② チップ消去終了に対してSDOがHighになるまで待ちます。
- ③ 無操作命令を設定します。

### 20.7.4. フラッシュ メモリ書き込み

フラッシュ メモリはヘーシ で構成されます(99頁の**表20-8**.参照)。フラッシュ メモリへ書く時にプログラム データはヘージ 緩衝部にラッチされます。これは同時に書かれることをプログラム データの1ヘージ に許します。次の手順は完全なフラッシュ メモリの書き込み方法を記述します。

- ① フラッシュ書き込み移行命令を設定します(表20-16.をご覧ください)。
- ② フラッシュ メモリ ページ 緩衝部を設定します。
- ③ フラッシュ メモリ上位アドレス設定とフラッシュ ヘーシ 書き込み命令を設定します。第3命令バイ後、ヘージ書き込み終了に対してSDOが highになるまで待ちます。
- ④ フラッシュ メモリ全体または全データが書かれてしまうまで②~③を繰り返します。
- (5) 無操作命令の設定によってフラッシュ ページ 書き込みを終えます。

ATtiny25/45/85との直列データ読み書き時、データは直列クロックの上昇端でクロック駆動(取得/出力変更)されます。詳細については**図 20-5.、図21-6.、表21-12**をご覧ください。







#### 20.7.5. EEPROM書き込み

EEPROMはペーシで構成されます(99頁の表20-9.参照)。EEPROMを書く時にデータはページ緩衝部にラッチされます。これは同時に書かれることをデータの1ページに許します。データ用EEPROMメモリの書き込み方法は次のとおりです。(表20-16.参照)

- ① EEPROM書き込み移行命令を設定します。
- ② EEPROMぺージ緩衝部を設定します。
- ③ EEPROMへージ書き込み命令を設定します。第2命令バ仆後、ヘージ書き込み終了に対してSDOがhighになるまで待ちます。
- ④ EEPROM全体または全データが書かれてしまうまで②~③を繰り返します。
- ⑤ 無操作命令の設定によってEEPROMページ書き込みを終えます。

#### 20.7.6. フラッシュ メモリ読み出し

フラッシュ メモリの読み出し方法は次のとおりです。(表20-16.参照)

- ① フラッシュ読み出し移行命令を設定します。
- ② フラッシュの上下バイトを読み出します。 選択したアドレスの内容はSDO直列出力で利用可能です。

#### 20.7.7. EEPROM読み出し

EEPROMの読み出し方法は次のとおりです。(表20-16.参照)

- (1) EEPROM読み出し移行命令を設定します。
- ② EEPROMのバイトを読み出します。選択したアドレスの内容はSDO直列出力で利用可能です。

#### 20.7.8. ヒュース と施錠ビットの読み出し/書き込み

ヒュース、上位/下位と施錠ビットの読み出し/書き込み方法は表20-16.で示されます。

### 20.7.9. 識票バイと校正値バイの読み出し

識票バイと校正値バイの読み出し方法は表20-16.で示されます。

#### 20.7.10. 電源OFF手順

SCIをOに設定します。RESETを1に設定します。VCC電源をOFFにします。



| 表20-16          | 高電圧直列プログラミング命令ー    | -#  |
|-----------------|--------------------|-----|
| <b>ऋ</b> ∠∪−।∪. | 同用川田グリノロン ドノン 叩 コー | IL. |

| 命令                                        |     |                                  |           |                    |      |          |            | 守          | 形式     | *                         |                                    |                                                        | ┤備ネ      |
|-------------------------------------------|-----|----------------------------------|-----------|--------------------|------|----------|------------|------------|--------|---------------------------|------------------------------------|--------------------------------------------------------|----------|
| HI1 II                                    |     | 第1バイト                            |           | <u>バイト</u>         |      |          | <u>バイト</u> |            | 第4     | <u> </u>                  | 第5バイト                              | 第6八个                                                   | I/HI *   |
|                                           | 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バイト後SD                           | O=Highまで待機。                                            |          |
|                                           | SDO | x xxxx xxxx xx                   | x xxxx    | XXXX               | XX : | x xxxx   | XXXX       | XX         |        |                           |                                    |                                                        |          |
| v. )11                                    | SDI | 0 0001 0000 00                   |           |                    |      |          |            |            |        |                           |                                    |                                                        |          |
| フラッシュ メモリ                                 | SII | 0 0100 1100 00                   |           |                    |      |          |            |            |        |                           | フラッシュ メモリ書                         | き込み処理移行。                                               |          |
| 書き込み移行                                    | SDO | x xxxx xxxx xx                   |           |                    |      |          |            |            |        |                           |                                    |                                                        | ,        |
| - 0 s                                     | SDI | O AAAA AAAA OO                   | 0 LLLL    | LLLL               | 00   | О НННН О | НННН       | 00         | 0 0000 | 0000 00                   | 0 0000 0000 0                      | 0 , 75% 1) 654                                         | _ *      |
| フラッシュ ヘ゜ーシ゛                               | SII | 0 0000 1100 00                   |           |                    | _    |          |            |            |        |                           |                                    | 一个一个一个一个一个                                             | ~5/\`    |
| 緩衝部設定                                     |     | x xxxx xxxx xx                   |           |                    | _    |          |            |            |        |                           |                                    | 裸り巡し。                                                  |          |
| コニ ン。 フェリ                                 | SDI |                                  | 0 0000    |                    |      |          |            |            |        |                           |                                    | A = V(Y) V(Y)                                          | 注1)      |
| フラッシュメモリ                                  |     |                                  |           |                    |      |          |            |            | 第3バイ   | <b>冷後SDC</b>              | =Highまで待機                          | 。H=上位データ                                               |          |
| :位アドレス設定<br>゚ージ書き込み                       | SII | 0 0001 1100 00                   |           |                    |      |          |            |            | U=上位   | アトレス                      |                                    | L=下位データ                                                |          |
| ノ盲さどか                                     |     | x xxxx xxxx xx                   | X XXXX    | XXXX               | XX I | X XXXX   | XXXX       | XX         |        |                           |                                    | _ , ,,                                                 |          |
| フラッシュ メモリ                                 |     | 0 0000 0010 00                   |           |                    |      |          |            |            |        | <del> </del>              | + 1113 1 m am 44.1-                |                                                        |          |
| 売み出し移行                                    | SII | 0 0100 1100 00                   |           |                    |      |          |            |            | フラッシュ  | メモリ読み                     | み出し処理移行                            | 0                                                      |          |
| 元 1 日 0 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 | SDO | X XXXX XXXX XX                   |           |                    |      |          |            |            |        |                           |                                    |                                                        |          |
| フラッシュ メモリ                                 | SDI | O AAAA AAAA OO                   | 0 0000    | 000 <mark>U</mark> |      |          |            |            |        |                           |                                    | 0 0 0000 0000 00                                       |          |
| 上下バイト                                     | SII | 0 0000 1100 00                   |           |                    | _    |          |            |            |        |                           |                                    | 0 0 0111 1100 00                                       | _        |
| 読み出し                                      | SDO | x xxxx xxxx xx                   | x xxxx    | XXXX               | XX I | x xxxx   | XXXX       | XX         | L LLLL | LLLx xx                   | x xxxx xxxx x                      | x H HHHH HHHx xx                                       | X        |
| EEDDOM                                    | SDI | 0 0001 0001 00                   |           |                    |      |          |            |            |        |                           |                                    |                                                        | _        |
| EEPROM                                    | SII | 0 0100 1100 00                   |           |                    |      | EEPRC    |            |            |        | トも繰り込                     |                                    | 2007 11 1 2 14                                         | 110      |
| <b>書き込み移行</b>                             | SDO | x xxxx xxxx xx                   |           |                    | _    | 込み処      | 理移行        | 丁          |        |                           |                                    | ·タ, L=下位データ                                            |          |
|                                           |     | 0 00AA AAAA 00                   | O IIIIIII | пппп               | 00   | 0 1111   | IIII       | ΩΩ         |        |                           |                                    | 0                                                      |          |
| EPROMページ゛                                 |     | 0 0000 1100 00                   |           |                    |      |          |            |            |        |                           |                                    |                                                        | ~5ハ゛     |
| 緩衝部設定                                     | SII |                                  |           |                    | _    |          |            |            |        |                           |                                    | → 2型リュクト. (*+)                                         | )        |
| BCIFT HI BCIC                             | SDO | X XXXX XXXX XX                   |           |                    | _    | X XXXX   | XXXX       | XX         | X XXXX | XXXX XX                   |                                    | x U=上位アドレス,                                            |          |
| EEPROM                                    | SDI | 0 0000 0000 00                   |           |                    | _    |          |            |            |        |                           | 第2バイト後                             | A=下位アトレス,                                              |          |
| ージ書き込み                                    | SII | 0 0110 0100 00                   | 0 0110    | 1100               | 00   |          |            |            |        |                           | SDO=High                           |                                                        |          |
| ノ首で込み                                     | SDO | X XXXX XXXX XX                   | X XXXX    | XXXX               | XX   |          |            |            |        |                           | まで待機。                              | L=データ                                                  |          |
| EEDDOM                                    | SDI | 0 00AA AAAA 00                   | 0 UUUU    | UUUU               | 00   | 0 LLLL   | LLLL       | 00         | 0 0000 | 0000 00                   | 0 0000 0000 0                      | 0 0 0000 0000 00                                       | 0        |
| EEPROM                                    | SII | 0 0000 1100 00                   | 0 0001    | 1100               | 00   | 0 0010   | 1100       | 00         | 0 0110 | 1101 00                   | 0 0110 0100 0                      | 0 0 0110 1100 00                                       | )        |
| 、小書き込み                                    | SDO | x xxxx xxxx xx                   | x xxxx    | xxxx               | x x  | x xxxx   | xxxx       | хх         | x xxxx | XXXX XX                   | x xxxx xxxx x                      | x x xxxx xxxx xx                                       | X        |
|                                           |     | 0 0000 0011 00                   | и имии    | 717171             |      |          |            |            |        |                           |                                    |                                                        | <u>-</u> |
| EEPROM                                    | SII | 0 0100 1100 00                   |           |                    |      | EEPRC    |            |            | 力 西粉   | 「仮SDC<br>· <u>八</u> 笠 1 ~ | )=Highまで待機<br>-6バイト繰り返し。           | 。<br>(計2) (計2)                                         |          |
| 売み出し移行                                    |     |                                  |           |                    | -    | 出し処      | 理移行        | <b>丁</b> 。 | △=下位   | アドレス                      | U=上位アドレス, L                        | 。( <b>/エ</b> 2 <i>)</i> ( <i>/</i> エ3 <i>)</i><br>=データ |          |
|                                           |     | x xxxx xxxx xx<br>0 00AA AAAA 00 | 0 0000    | 0000               | 00   | 0 0000   | 0000       | 00         |        |                           |                                    | <del></del>                                            |          |
| EEPROM                                    |     |                                  |           |                    |      |          |            |            |        |                           |                                    | 4* /1 /县/0.1层1                                         |          |
| ・・・・・・・・・・・・・・・・・・・・・・・・・・・・・・・・・・・・・・    | SII | 0 0000 1100 00                   |           |                    | _    |          |            |            |        |                           |                                    | ~4小、小繰り返し。                                             |          |
| 11 Юг у ЩО                                |     | x xxxx xxxx xx                   |           |                    |      |          |            |            |        |                           |                                    |                                                        |          |
| ヒュース・下位                                   | SDI | 0 0100 0000 00                   | 0 7654    | 3210               | 00   | 0 0000   | 0000       | 00         | 0 0000 | 0000 00                   | 第4バイト後SD                           | O=Highまで待機。                                            |          |
|                                           | SII | 0 0100 1100 00                   | 0 0010    | 1100               | 00   | 0 0110   | 0100       | 00         | 0 0110 | 1100 00                   | 7~0はビット位                           | 置で論理0でプロク                                              | ブラム。     |
| 書き込み                                      | SDO | x xxxx xxxx xx                   | x xxxx    | XXXX               | XX I | x xxxx   | XXXX       | XX         | x xxxx | XXXX XX                   | (98頁の <b>表20</b> -                 | 5.参照)                                                  |          |
| )。 ッ* [ <del> 上</del>                     | SDI | 0 0100 0000 00                   | 0 7654    | 3210               | 00   | 0 0000   | 0000       | 00         | 0 0000 | 0000 00                   | 第4バイト後SD                           | O=Highまで待機。                                            |          |
| ヒューズ上位                                    | SII |                                  |           |                    |      |          |            |            |        |                           |                                    | 置で論理のでプログ                                              |          |
| 書き込み                                      | SDO | x xxxx xxxx xx                   |           |                    |      |          |            |            |        |                           |                                    | 4.参照)                                                  | , , , ,  |
| 11.00                                     |     | 0 0100 0000 00                   | 0 0000    | 0000               | 00   | 0 0000   | 0000       | 00         | 0 0000 | 0000 00                   |                                    | O=Highまで待機。                                            |          |
| 拡張ヒューズ                                    | SII | 0.0100.000.00                    | 0 0010    | 1100               | 00   | 0.0110   | 0110       | 00         | 0.0110 | 1110 00                   | 10/けどがはは悪っ                         | J=Highまで付機。<br>ご論理 <mark>0</mark> でプログラム               |          |
| 書き込み                                      |     |                                  |           |                    | _    |          |            |            |        |                           |                                    |                                                        | 10       |
|                                           | SDO | X XXXX XXXX XX                   | X XXXX    | XXXX               | XX . | X XXXX   | XXXX       | XX         | X XXXX | XXXX XX                   |                                    |                                                        |          |
| 施錠ビット                                     |     | 0 0010 0000 00                   | 0 0000    | 0010               | 00   | 0 0000   | 0000       | 00         | 0 0000 | 0000 00                   | 第4八仆後SD                            | O=Highまで待機。                                            |          |
| 書き込み                                      | SII |                                  |           |                    |      |          |            |            |        |                           |                                    | 置で論理0でプログ                                              | ノフム。     |
| a C Z V                                   |     | x xxxx xxxx xx                   |           |                    |      |          |            |            | X XXXX | XXXX XX                   | (97頁の <b>表20</b> -                 | 1.参照)                                                  |          |
| ヒュース・下位                                   | SDI | 0 0000 0100 00                   | 0 0000    | 0000               | 00   | 0 0000   | 0000       | 00         |        |                           | 7~0/ナビットは                          | 置で論理0でプロク                                              | ゲラム      |
|                                           | SII | 0 0100 1100 00                   | 0 0110    | 1000               | 00   | 0 0110   | 1100       | 00         |        |                           |                                    |                                                        | ) A      |
| 読み出し                                      | SDO | x xxxx xxxx xx                   | x xxxx    | XXXX               | XX   | 7 6543   | 210x       | XX         |        |                           | (98頁の表20-                          | 3. 参照)                                                 |          |
| ). w/\ 1 / 1                              |     | 0 0000 0100 00                   |           |                    |      |          |            |            |        |                           | <b>5</b> 6333 377                  | W ~ 3^ ~ 0 .                                           |          |
| ヒュース・上位                                   | SII | 0 0100 1100 00                   |           |                    | _    |          |            |            |        |                           |                                    | 置で論理0でプロク                                              | フノム。     |
| 読み出し                                      |     |                                  |           |                    | _    |          |            |            |        |                           | (98頁の表20-                          | 4.参照)                                                  |          |
|                                           | SDO | X XXXX XXXX XX                   |           |                    |      | 7 6543   |            |            |        |                           |                                    |                                                        |          |
|                                           |     | 0 0000 0100 00                   |           |                    | -    |          |            |            |        |                           | 0はビット位置で                           | で論理 <mark>0でプ</mark> ログラム                              | ١,       |
| 拡張ヒューズ                                    | SII | 0 0100 1100 00                   | 0 0110    | 1010               | 00   | 0 0110   | 1110       | 00         |        |                           | (98頁の表20-                          |                                                        | 0        |
| 拡張ヒューズ 読み出し                               |     |                                  |           |                    |      |          |            |            |        |                           | (JU) (JV) 1X 2U                    | U. 22 US /                                             |          |
| 拡張ヒューズ 読み出し                               | SDO | x xxxx xxxx xx                   |           |                    |      |          |            |            |        |                           |                                    |                                                        |          |
| 読み出し                                      | SDO | x xxxx xxxx xx<br>0 0000 0100 00 |           |                    |      |          |            |            |        |                           | 1~(0)+1,1/+                        |                                                        | ゲラノ      |
|                                           | SDO |                                  | 0 0000    | 0000               | 00   | 0 0000   | 0000       | 00         |        |                           | - 1~0はビット位<br>- (97頁の <b>表20</b> - | 置で論理 <mark>0</mark> でプログ                               | ブラム。     |



表20-16 (続き). 高電圧直列プログラミング命令一式

| 命令            |     | 命令形式           |                |                |                |                      |       |    |
|---------------|-----|----------------|----------------|----------------|----------------|----------------------|-------|----|
|               |     | 第1バイト          | 第2バイト          | 第3バイト          | 第4バイト          | 第5バイト                | 第6バイト | 備考 |
| 識票バイト<br>読み出し | SDI | 0 0000 1000 00 | 0 0000 00AA 00 | 0 0000 0000 00 | 0 0000 0000 00 | A=アト・レス              |       |    |
|               | SII | 0 0100 1100 00 | 0 0000 1100 00 | 0 0110 1000 00 | 0 0110 1100 00 | A=アドレス<br>7~0はビット位置。 |       |    |
|               | SDO | x xxxx xxxx xx | x xxxx xxxx xx | X XXXX XXXX XX | 7 6543 210x xx | 「~0/よしットリエ」直。        | )     |    |
| 校正値<br>読み出し   |     |                |                | 0 0000 0000 00 |                |                      |       |    |
|               | SII | 0 0100 1100 00 | 0 0000 1100 00 | 0 0111 1000 00 | 0 0111 1100 00 | 7~0はビット位置。           | )     |    |
|               | SDO | x xxxx xxxx xx | x xxxx xxxx xx | x xxxx xxxx xx | 7 6543 210x xx |                      |       |    |
|               | 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(低電圧)直列プログ ラジングだけで、高電圧直列プログラジングで利用できないことに注意してください。

**注4**: 上位(ページ)アドレスの有効ビットはATtiny25/45/85で各々異なります(99頁の「**ページ容量**」と102頁の**図20-2.**参照)。



# 21. 電気的特性

# **21.1**. 絶対最大定格 (警告)

| 動作温度 ・・・・・・・・-55℃~+125℃                     |
|---------------------------------------------|
| 保存温度 ・・・・・・・・・・・・・-65℃~+150℃                |
| RESETを除くピン許容電圧・・・・・・・ -0.5V $\sim$ VCC+0.5V |
| RESETt°ン許容電圧 ・・・・・・・・・・・・・・・ -0.5V ~ +13.0V |
| 最大動作電圧 · · · · · · 6.0 V                    |
| 入出力ピン出力電流 ・・・・・・・・・・・・・・・・・ 40.0mA          |
| 消費電流 ······ 200.0 mA                        |

## (警告)

絶対最大定格を超える負担はデバイスに定常的な損傷を与えます。 絶対最大定格は負担の定格を示すためだけのもので、この値また は、この仕様書の動作特性で示された値を超える条件で動作する ことを示すものではありません。長時間の最大定格での使用はデバ イスの信頼性を損なう場合があります。

# 21.2. DC特性

表21-1. DC特性 TA=-40℃~85℃

| シンホ゛ル                         | 項目                                                 | 条件                | Min                  | Typ( <mark>注1</mark> ) | Max                  | 単位 |
|-------------------------------|----------------------------------------------------|-------------------|----------------------|------------------------|----------------------|----|
| VIL                           | Lowレベル入力電圧                                         | VCC=1.8∼2.4V      | -0.5                 |                        | 0.2VCC ( <b>注2</b> ) |    |
| VIL                           | (XTAL1,RESETを除く)                                   | VCC=2.4~5.5V      | -0.5                 |                        | 0.3VCC ( <b>注2</b> ) |    |
| VIL1                          | Lowレヘブル入力電圧 (XTAL1)                                | VCC=1.8∼5.5V      | -0.5                 |                        | 0.1VCC ( <b>注2</b> ) |    |
| VIL2                          | Lowレヘブル入力電圧(RESET)                                 | VCC=1.8∼5.5V      | -0.5                 |                        | 0.2VCC ( <b>注2</b> ) |    |
| V <sub>IL3</sub>              | Lowレベル入力電圧                                         | VCC=1.8∼2.4V      | -0.5                 |                        | 0.2VCC ( <b>注2</b> ) |    |
| VIL3                          | (I/OとしてのRESET)                                     | VCC=2.4~5.5V      | -0.5                 |                        | 0.3VCC ( <b>注2</b> ) |    |
| Vih                           | Highレベル入力電圧                                        | VCC=1.8~2.4V      | 0.7VCC ( <b>注3</b> ) |                        | VCC+0.5              |    |
| VIII                          | (XTAL1,RESETを除く)                                   | VCC=2.4~5.5V      | 0.6VCC ( <b>注3</b> ) |                        | VCC+0.5              |    |
| ViH1                          | Highレベル入力電圧 (XTAL1)                                | VCC=1.8∼2.4V      | 0.8VCC ( <b>注3</b> ) |                        | VCC+0.5              | V  |
| VIHI                          | Tiigiiv 、///// 电/工 (XTALT)                         | VCC=2.4~5.5V      | 0.7VCC ( <b>注3</b> ) |                        | VCC+0.5              |    |
| V <sub>I</sub> H <sub>2</sub> | Highレベル入力電圧 (RESET)                                | VCC=1.8∼5.5V      | 0.9VCC ( <b>注3</b> ) |                        | VCC+0.5              |    |
| V <sub>IH3</sub>              | Highレベル入力電圧                                        | VCC=1.8~2.4V      | 0.7VCC ( <b>注3</b> ) |                        | VCC+0.5              |    |
| V II 13                       | (I/OとしてのRESET)                                     | VCC=2.4~5.5V      | 0.6VCC ( <b>注3</b> ) |                        | VCC+0.5              |    |
| Vol                           | Lレヘ・ル出力電圧<br>(DDSET( <b>注c</b> )な除く) ( <b>注4</b> ) | IOL=10mA, VCC=5V  |                      |                        | 0.6                  |    |
| VOL                           | (KESEI(注0)を除く)                                     | IOL=5mA, VCC=3V   |                      |                        | 0.5                  |    |
| Voh                           | Hレヘブル出力電圧<br>(PRSET( <b>注c</b> )な( <b>注5</b> )     | IOH=-10mA, VCC=5V | 4.3                  |                        |                      |    |
| VOIT                          | (KESEI(注0)を除く)                                     | IOH=-5mA, VCC=3V  | 2.5                  |                        |                      |    |
| IIL                           | I/OビンLowレベル入力漏れ電流                                  | VCC=5.5V          |                      | < 0.05                 | 1                    | μА |
| IIH                           | I/OビンHighレベル入力漏れ電流                                 | 確実なH/L範囲          |                      | < 0.05                 | 1                    |    |
| RRST                          | RESETピン プルアップ抵抗                                    | VCC=5.5V, Low入力   | 30                   |                        | 60                   | kΩ |
| Rpu                           | I/Oピン プルアップ抵抗                                      | VCC=5.5V, Low入力   | 20                   |                        | 50                   |    |
|                               |                                                    | VCC=2V, 1MHz      |                      | 0.3                    | 0.55                 | mA |
|                               | 活動動作消費電流 (注7)                                      | VCC=3V, 4MHz      |                      | 1.5                    | 2.5                  |    |
|                               |                                                    | VCC=5V, 8MHz      |                      | 5                      | 8                    |    |
| ICC                           |                                                    | VCC=2V, 1MHz      |                      | 0.1                    | 0.2                  |    |
|                               | アイドル動作消費電流 (注7)                                    | VCC=3V, 4MHz      |                      | 0.35                   | 0.6                  |    |
|                               |                                                    | VCC=5V, 8MHz      |                      | 1.2                    | 2                    |    |
|                               | パリーダウン動作消費電流 (注8)                                  | VCC=3V, WDT有効     |                      |                        | 10                   | μА |
|                               |                                                    | VCC=3V, WDT禁止     |                      |                        | 2                    |    |

**注1**: 25℃での代表値です。

注2: Lowレベルの認識が保証される最高電圧です。 注3: Highレベルの認識が保証される最低電圧です。

(注4)~(注8)は次頁を参照してください。



- 注4: 各I/Oポートは安定状態(非過渡時)に於いて検査条件(VCC=5Vで10mA、VCC=3Vで5mA)よりも多くの吸い込み電流を流すことができますが、次の条件を厳守してください。
  - ① 全ポートのIOLの合計が60mAを超えるべきではありません。

IOLが検査条件を超える場合、VOLも仕様書での値を超えます。表の検査条件よりも大きな吸い込み電流を流すことは保証されません。

- 注5: 各I/Oポートは安定状態(非過渡時)に於いて検査条件(VCC=5Vで10mA、VCC=3Vで5mA)よりも多くの吐き出し電流を流すことができますが、次の条件を厳守してください。
  - ① 全ポートのIOHの合計が60mAを超えるべきではありません。

IOHが検査条件を超える場合、VOHも仕様書での値を超えます。表の検査条件よりも大きな吐き出し電流を流すことは保証されません。

- 注6: RESETピンはプログラミング動作での操作と移行時に高電圧を許容しなければならず、その結果として標準I/Oピンと比べて弱い 駆動能力を持ちます。(122頁から始まる)図22-23.~26.をご覧ください。
- **注7**: 25頁の「消費電力の最小化」で記述された方法を用いた外部クロックでの値です。電力削減が許可(PRR=\$FF)され、I/Oの駆動はありません。
- 注8: 低電圧検出器(BOD)禁止です。

# 21.3. 速度

最高周波数は動作電圧に依存します。**図21-1**.と**図21-2**.で示されるように最高周波数対動作電圧曲線は1.8~2.7Vと2.7~4.5V間で直線です。(<mark>訳注</mark>: 共通性から2行追加)





#### 21.4. クロック特性

## 21.4.1. 校正付き内蔵RC発振器精度

工場既定校正よりも高い精度に内蔵発振器を手動校正することが可能です。この発振器周波数が温度と電圧に依存することに注意してください。電圧と温度の特性は127頁の図22-40と128頁の図22-41、で得られます。

| 校正種別  | 周波数                  | 周波数 VCC                                                            |                   | 校正精度(注1) |
|-------|----------------------|--------------------------------------------------------------------|-------------------|----------|
| 工場校正  | 8.0MHz ( <b>注2</b> ) | 3V                                                                 | 25℃               | ±10%     |
| 使用者校正 | 6~8MHz<br>内の固定周波数    | 1.8~5.5V( <mark>注3</mark> ), 2.7~5.5V( <mark>注4</mark> )<br>内の固定電圧 | -40~85℃<br>内の固定温度 | ±1%      |

- 注1: 校正点での発振器周波数精度(固定温度と固定電圧)
- 注2: ATtiny25Vのみ: ATtiny15互換動作での6.4MHz
- 注3: ATtiny25V/45V/85Vに対する電圧範囲
- 注4: ATtiny25/45/85に対する電圧範囲

#### 21.4.2. 外部クロック信号駆動



#### 表21-3. 外部クロック特性

| シンホ゛ル               | 項目            | VCC=1. | 8 <b>∼</b> 5.5∨ | VCC=2. | 7 <b>~</b> 5.5∨ | VCC=4. | 5 <b>∼</b> 5.5∨ | 単位  |
|---------------------|---------------|--------|-----------------|--------|-----------------|--------|-----------------|-----|
| シンホ ル               | <b>坦</b>      | Min    | Max             | Min    | Max             | Min    | Max             | 中位  |
| 1/t <sub>CLCL</sub> | クロック周波数       | 0      | 4               | 0      | 10              | 0      | 20              | MHz |
| tclcl               | クロック周期        | 250    |                 | 100    |                 | 50     |                 |     |
| tchcx               | 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               | %   |

注: 詳細については17頁の「外部クロック信号」を参照してください。

# 21.5. システムとリセットの特性

#### 表21-4. システムとリセットの電気的特性

| シンホ゛ル             | 項目            | 条件                | Min    | Тур | Max    | 単位 |
|-------------------|---------------|-------------------|--------|-----|--------|----|
| V <sub>RST</sub>  | RESETt°ン閾値電圧  | VCC=3V            | 0.2VCC |     | 0.9VCC | V  |
| t <sub>RST</sub>  | リセット ハ゜ルス幅    | VCC-3V            |        | 2.5 |        | μs |
| V <sub>HYST</sub> | 低電圧検出ヒステリシス電圧 |                   |        | 50  |        | mV |
| $t_{ m BOD}$      | 最小低電圧検出時間     |                   |        | 2   |        | μs |
| $V_{BG}$          | 基準電圧          | NGC FV            | 1.0    | 1.1 | 1.2    | V  |
| $t_{BG}$          | 起動時間          | VCC=5V<br>TA=25°C |        | 40  | 70     | μs |
| $I_{\mathrm{BG}}$ | 消費電流          | 171 20 0          |        | 15  |        | μA |

注: 値は指針だけです。

以下のように2つの電源ONリセット版が実装されてしまっています。

## 21.5.1. 標準電源ONリセット

この電源ONJセットの実装はATtiny25/45/85の初期版で存在します。下表はこの電源ONJセットの特性を記述し、それは以下のデバイスに対してだけ有効です。

• ATtiny25: 改訂Dとそれ以前

• ATtiny45: 改訂Fとそれ以前

• ATtiny85: 改訂Bとそれ以前

注: 改訂は外囲器上に記されます(8P3と8S2外囲器:裏面、20M1外囲器:表面)。

## 表21-5. 標準電源ONリセット特性 (TA=-40°C~85°C)

| シンホ゛ル            | 項目                                | Min  | Тур | Max | 単位   |
|------------------|-----------------------------------|------|-----|-----|------|
| V <sub>POR</sub> | 電源ONJセット開放閾値電圧( <mark>注1</mark> ) | 0.7  | 1.0 | 1.4 | V    |
| V <sub>POA</sub> | 電源ONJセット活性閾値電圧( <mark>注2</mark> ) | 0.05 | 0.9 | 1.3 | V    |
| SRON             | 電源投入時上昇率                          | 0.01 |     | 4.5 | V/ms |

注: 値は指針だけです。

注1: 電圧上昇時にデバイスがリセットから開放される閾値電圧です。

注2: 供給電圧がVPOA未満でなければ電源ONリセットは動作しません(電圧下降時)。

# 21.5.2. 強化電源ONリセット

この電源ONJセットの実装はATtiny25/45/85の新版で存在します。下表はこの電源ONJセットの特性を記述し、それは以下のデバイスに対してだけ有効です。

• ATtiny25: 改訂Eとそれ以降

● ATtiny45 : 改訂Gとそれ以降

• ATtiny85: 改訂Gとそれ以降

# 表21-6. 強化電源ONリセット特性 (TA=-40°C~85°C)

| シンホ゛ル            | 項目                                | Min | Тур | Max | 単位   |
|------------------|-----------------------------------|-----|-----|-----|------|
| V <sub>POR</sub> | 電源ONリセット開放閾値電圧( <mark>注1</mark> ) | 1.1 | 1.4 | 1.6 | 17   |
| V <sub>POA</sub> | 電源ONリセット活性閾値電圧 (注2)               | 0.6 | 1.3 | 1.6 | V    |
| SR <sub>ON</sub> | ON 電源投入時上昇率                       |     |     |     | V/ms |

注: 値は指針だけです。

注1: 電圧上昇時にデバイスがリセットから開放される閾値電圧です。

注2: 供給電圧がVPOA未満でなければ電源ONリセットは動作しません(電圧下降時)。



# 21.6. 低電圧検出(BOD)

表21-7. BODLEVELヒュース\*符号化 (VBOT、TA=-40~85°C) (注1)

| = 10 10 010 1 2011 |                  |     |     |    |  |  |
|--------------------|------------------|-----|-----|----|--|--|
| BODLEVEL2~0        | Min              | Тур | Max | 単位 |  |  |
| 1 1 1              | 低電圧検出(BOD)リセット禁止 |     |     |    |  |  |
| 1 1 0              | 1.7              | 1.8 | 2.0 |    |  |  |
| 1 0 1              | 2.5              | 2.7 | 2.9 | V  |  |  |
| 1 0 0              | 4.1              | 4.3 | 4.5 |    |  |  |
| $000 \sim 011$     | (予約)             |     |     |    |  |  |

注1: いくつかのテンバイスでVBOTが公称最低動作電圧以下の可能性があります。この状態のテンバイスについては、製造検査中、VCC=VBOTに落として検査されています。これはマイクロコントローラの正しい動作がもはや保証されない電圧になる前に、低電圧検出(BOD) リセットが起きることを保証します。

# 21.7. A/D変換器特性

表21-8. A/D変換特性 (TA=-40°C~85°C)

|          | シンボル  | 項目                               | 条件      |           | Min         | Тур | Max  | 単位      |     |
|----------|-------|----------------------------------|---------|-----------|-------------|-----|------|---------|-----|
|          |       | 分解能                              |         |           |             |     |      | 10      | ピット |
|          |       | Ab I I like the                  | VCC=4V  | 変換クロック=20 | 0kHz        |     | 2    |         |     |
|          |       | 絶対精度<br>(INL,DNL,利得,オフセット,       | VREF=4V | 変換クロック=1M | ИНz         |     | 3    |         |     |
|          |       | はいし、DNL、利持、オブセット、<br>量子化誤差を含む)   | 雑音低     | 変換クロック=20 | 0kHz        |     | 1.5  |         |     |
| ン        |       | 至716次左2月37                       | 減動作     | 変換クロック=1M | ИHz         |     | 2.5  |         | LSB |
| シングルェ    |       | 積分性非直線誤差(INL)<br>(オフセット,利得誤差校正後) | VCC=4V  |           |             |     | 1    |         | LOD |
| ミ        |       | 微分性非直線誤差(DNL)                    | VREF=4V |           |             |     | 0.5  |         |     |
| ᅡ        |       | 利得誤差                             | 変換クロック= | =200kHz   |             |     | 2.5  |         |     |
| Ţ        |       | オフセット(セ゛ロ)誤差                     |         |           |             |     | 1.5  |         |     |
| エンド入力変換  |       | 変換クロック周波数                        |         |           |             | 50  |      | 1000    | kHz |
| 15       |       | 変換時間                             | 連続変換重   | 协作        |             | 14  |      | 280     | μs  |
|          | AREF  | 外部基準電圧                           |         |           |             | 2.0 |      | VCC     | V   |
|          | VIN   | 入力電圧                             |         |           |             | GND |      | Vref    | V   |
|          |       | 入力周波数帯域                          |         |           |             |     | 38.4 |         | kHz |
|          |       | 分解能                              |         |           | $\times 1$  |     |      | 10      | ピット |
|          |       | 刀件化                              |         |           | ×20         |     |      | 10      | Lyr |
|          |       | 絶対精度                             |         |           | $\times 1$  |     | 10.0 |         |     |
|          |       | (INL,DNL,利得,オフセット,<br>量子化誤差を含む)  |         |           | ×20         |     | 20.0 |         |     |
| ,,,      |       | 積分性非直線誤差(INL)                    | VCC=5V  |           | ×1          |     | 4.0  |         |     |
| 単極差動入力変換 |       | (オフセット,利得誤差校正後)                  | VREF=4V |           | ×20         |     | 10.0 |         | LSB |
| 差        |       | 利得誤差                             | 変換クロック= | 50∼200kHz | $\times 1$  |     | 10.0 |         |     |
| 動        |       | 利付缺左                             |         |           | $\times 20$ |     | 15.0 |         |     |
| 分        |       | オフセット(セ゛ロ)誤差                     |         |           | $\times 1$  |     | 3.0  |         |     |
| 変        |       | 14 ノモット(モロ) 映左                   |         |           | ×20         |     | 4.0  |         |     |
| 揆        |       | 変換クロック周波数                        |         |           |             | 50  |      | 200     | kHz |
|          |       | 変換時間                             | 連続変換重   | 协作        |             | 70  |      | 280     | μS  |
|          | AREF  | 外部基準電圧                           |         |           |             | 2.0 |      | VCC-1.0 |     |
|          | Vin   | 入力電圧                             |         |           |             | GND |      | VCC     | V   |
|          | VDIFF | 差動入力電圧差                          |         |           |             |     |      | VREF/利得 |     |
|          |       | 入力周波数带域                          |         |           |             |     | 4    |         | kHz |

[次貝に続く]

(訳注) 原書の表21-8.~10.は表21-8.として統合しました。



表21-8 (続き). A/D変換特性 (TA=-40℃~85℃)

|          | シンボル  | 項目                         | 条件               |            | Min  | Тур  | Max     | 単位  |
|----------|-------|----------------------------|------------------|------------|------|------|---------|-----|
|          |       | 分解能                        |                  | $\times 1$ |      |      | 10      | ピット |
|          |       | 7 件能                       |                  | ×20        |      |      | 10      | しット |
|          |       | 絶対精度<br>(INL,DNL,利得,オフセット, |                  | ×1         |      | 8.0  |         |     |
|          |       | 量子化誤差を含む)                  |                  | ×20        |      | 8.0  |         |     |
| l_       |       | 積分性非直線誤差(INL)              | VCC=5V           | $\times 1$ |      | 4.0  |         |     |
| 両極差動入力変換 |       | (オフセット,利得誤差校正後)            | VREF=4V          | ×20        |      | 5.0  |         | LSB |
| 差        |       | 利得誤差                       | 変換クロック=50~200kHz | $\times 1$ |      | 4.0  |         |     |
| 動        |       | 利付缺左                       |                  | ×20        |      | 5.0  |         |     |
| 分        |       | オフセット(セ゛ロ)誤差               |                  | $\times 1$ |      | 3.0  |         |     |
| 変        |       | A / E y P ( E E ) 映左       |                  | ×20        |      | 4.0  |         |     |
| 揆<br>    |       | 変換クロック周波数                  |                  |            | 50   |      | 200     | kHz |
|          |       | 変換時間                       | 連続変換動作           |            | 70   |      | 280     | μs  |
|          | AREF  | 外部基準電圧                     |                  |            | 2.0  |      | VCC-1.0 |     |
|          | Vin   | 入力電圧                       |                  |            | GND  |      | VCC     | V   |
|          | VDIFF | 差動入力電圧差                    |                  |            |      |      | VREF/利得 |     |
|          |       | 入力周波数帯域                    |                  |            |      | 4    |         | kHz |
|          |       | A/D変換出力                    | 単極動作             |            | 0    |      | 1023    | LSB |
|          |       | M / U 及 1                  | 両極動作             |            | -512 |      | 511     | LOD |
| 共通       | VINT  | 内部基準電圧                     |                  |            | 1.0  | 1.1  | 1.2     | V   |
| 通        | VINI  | 内部2.56V基準電圧( <u>注</u> )    | VCC>3V           |            | 2.3  | 2.56 | 2.8     | V   |
|          | RREF  | 基準電圧入力インピーダンス              |                  |            |      | 32   |         | kΩ  |
|          | Rain  | アナログ入力インピーダンス              |                  |            |      | 100  |         | ΜΩ  |

注: 値は指針の意味だけです。

(訳注) 原書の表21-8.~10.は表21-8.として統合しました。



# 21.8. 低電圧直列プログラミング特性





表21-11. 低電圧直列プログラミング特性 (特記条件を除いて、TA=-40℃~85℃, VCC=1.8~5.5V) シンボル 項目 単位 Min Тур Max 1.8~2.7V 0 4 発振器周波数 1/tclcl  $2.7 \sim 4.5 V$ 10 MHz 4.5~5.5V 0 20 250 1.8~2.7V 発振器周期  $2.7 \sim 4.5 \text{V}$ 100 tclcl 4.5~5.5V 50 SCKパルスHレベル幅 (注1) tshsl 2tclcl ns tslsh SCKパルスLレベル幅 (注1) 2tclcl SCK↑に対するMOSIセットアップ時間 tovsh tclcl SCK↑に対するMOSI保持時間 tsHox 2tclcl SCK↓に対するMISO出力遅延時間 100 tsliv

注1:  $f_{CK} < 12MHz$ 時2tCLCL、 $f_{CK} \ge 12MHz$ 時3tCLCL。

# 21.9. 高電圧直列プログラミング特性



| 表21-12. 高電            | 表21-12. 高電圧直列プログラミング特性(特記条件を除いて、VCC=5.0V±10%) |     |     |     |    |  |  |  |  |  |
|-----------------------|-----------------------------------------------|-----|-----|-----|----|--|--|--|--|--|
| シンホ゛ル                 | 項目                                            | Min | Тур | Max | 単位 |  |  |  |  |  |
| tshsl                 | SCIパルスHレベル幅                                   | 125 |     |     |    |  |  |  |  |  |
| tslsh                 | SCIパルスLレベル幅                                   | 125 |     |     |    |  |  |  |  |  |
| 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 |  |  |  |  |  |



# 22. 代表特性

本項内に含まれたデータは主に同じ製法と設計法の類似デバイスの特徴付けとシミュレーションに基いています。従って、このデータはデバイスがどう反応するかについての指標として扱われるべきです。

以下の図は代表的な特性を示します。これらの図は製造中に検査されていません。全ての消費電流測定は全I/Oピンを入力として設定した内部プルアップ許可で行われています。電源幅振幅の方形波発振器がクロック源として使われています。

パワーダウン動作での消費電力はクロック選択と無関係です。

消費電流は動作電圧、動作周波数、I/Oピンの負荷、I/Oピンの切り替え速度、命令実行、周囲温度のような様々な要素の関数です。 支配的な要素は動作電圧と動作周波数です。

容量性負荷のピンの引き込み電流は(1つのピンに対して)  $C_L$ (負荷容量)×VCC(動作電圧)×f(I/Ot゚ンの平均切り替え周波数) として推測できます。

デバイスは検査範囲よりも高い周波数特性を示します。デバイスは注文番号が示す周波数よりも高い周波数での機能特性を保証されません。

ウォッチト、ック、タイマ許可のパワーダウン動作での消費電流とウォッチト、ック、タイマ禁止のパワーダウン動作での消費電流間の違いは、ウォッチト、ック、タイマによって引き込んだ(消費した)差電流を表します。

# 22.1. 活動動作消費電流















# 22.2. アイドル動作消費電流













# 22.3. 周辺機能部供給電流

以下の表と式は活動動作とアイトル動作で個別周辺機能部対する追加消費電流の計算に使えます。周辺機能部の許可や禁止は電力削減レジスタによって制御されます。詳細については26頁の「PRR - 電力削減レジスタ」をご覧ください。

表22-1. 各部追加消費電流 (絶対値:µA)

| <b>火</b> 二:11 |         |         |         |  |  |  |  |
|---------------|---------|---------|---------|--|--|--|--|
| PRR内ビット       | 1MHz,2V | 4MHz,3V | 8MHz,5V |  |  |  |  |
| PRTIM1        | 45      | 300     | 1100    |  |  |  |  |
| PRTIM0        | 5       | 30      | 110     |  |  |  |  |
| PRUSI         | 5       | 25      | 100     |  |  |  |  |
| PRADC         | 15      | 85      | 340     |  |  |  |  |

表22-2. 各部追加消費電流(相対値:%)

| PRR内ビット | 活動動作(図22-1,図22-2) | アイト・ル動作(図22-6,図22-7) |
|---------|-------------------|----------------------|
| PRTIM1  | 20                | 80                   |
| PRTIM0  | 2                 | 10                   |
| PRUSI   | 2                 | 10                   |
| PRADC   | 5                 | 25                   |

表22-1.で一覧される以外のVCCと周波数設定については表22-2.からの数値を元に代表的な消費電流を計算できます。

**例1**: VCC=2V, *f*=1MHzでUSI, タイマ/カウンタ0, A/D変換器が許可されたアイドル動作での予測される消費電流を計算します。**表22-2**.のアイドル動作列からUSIが10%、タイマ/カウンタ0が10%、A/D変換器が25%追加する必要を知ります。**図22-9**.を読み、VCC=2V, *f*=1MHzでのアイドル動作消費電流が約0.18mAであることを得ます。USI, タイマ/カウンタ0, A/D変換器許可のアイドル動作での総消費電流を得ます。

総消費電流=0.18mA×(1+0.1+0.1+0.25)≒0.261mA



# 22.4. パワーダウン動作消費電流





# **22.5**. ピン プルアップ

















# 22.6. ピン駆動能力























# 22.7. ピン 閾値とヒステリシス

















# 22.8. 低電圧検出器(BOD)閾値















# 22.9. 内部発振器周波数





















# 22.10. 周辺機能部消費電流













# 22.11. リセット消費電流とリセット パルス幅









# 23. レジスタ要約

| アト・レス                      | レジスタ略称         | ヒ゛ット7            | じット6                                  | ピット5             | じット4                              | ピット3                                  | <b>Ľット2</b>          | ピット1             | ピット0                                  | 頁           |
|----------------------------|----------------|------------------|---------------------------------------|------------------|-----------------------------------|---------------------------------------|----------------------|------------------|---------------------------------------|-------------|
| \$3F (\$5F)                | SREG           | I                | Т                                     | Н                | S                                 | V                                     | N                    | Z                | С                                     | 6           |
| \$3E (\$5E)                | SPH            | -                | -                                     | -                | -                                 | -                                     | _                    | (SP9)            | (SP8)                                 | 7           |
| \$3D (\$5D)                | SPL            | SP7              | SP6                                   | SP5              | SP4                               | SP3                                   | SP2                  | SP1              | SP0                                   | · .         |
| \$3C (\$5C)                | 予約             |                  | INITO                                 | DCIE             | _                                 | _                                     | _                    | _                |                                       | 2.4         |
| \$3B (\$5B)<br>\$3A (\$5A) | GIMSK<br>GIFR  |                  | INT0<br>INTF0                         | PCIE<br>PCIF     | _                                 | _                                     | <del></del>          |                  | _                                     | 34<br>34    |
| \$39 (\$59)                | TIMSK          | -                | OCIE1A                                | OCIE1B           | OCIE0A                            | OCIE0B                                | TOIE1                | TOIE0            | _                                     | 68,62,54    |
| \$38 (\$58)                | TIFR           | _                | OCF1A                                 | OCF1B            | OCF0A                             | OCF0B                                 | TOV1                 | TOV0             | _                                     | 68,62,54    |
| \$37 (\$57)                | SPMCSR         | _                | -                                     | RSIG             | CTPB                              | RFLB                                  | PGWRT                | PGERS            | SPMEN                                 | 96          |
| \$36 (\$56)                | 予約             |                  |                                       | 11010            | 0112                              | THE ESS                               | 1 0 11111            | 1 02110          | DI MEN                                | 00          |
| \$35 (\$55)                | MCUCR          | BODS             | PUD                                   | SE               | SM1                               | SM0                                   | BODSE                | ISC01            | ISC00                                 | 42,26,33    |
| \$34 (\$54)                | MCUSR          | _                | -                                     | -                | -                                 | WDRF                                  | BORF                 | EXTRF            | PORF                                  | 30          |
| \$33 (\$53)                | TCCR0B         | FOC0A            | FOC0B                                 | -                | -                                 | WGM02                                 | CS02                 | CS01             | CS00                                  | 52          |
| \$32 (\$52)                | TCNT0          |                  |                                       |                  | 9/7/                              | カウンタ0                                 | ·                    |                  |                                       | 53          |
| \$31 (\$51)                | OSCCAL         | OTTO 1           | DUALLA                                |                  |                                   | を振校正値レ<br>CC10                        |                      | 6611             | 0010                                  | 21          |
| \$30 (\$50)<br>\$2F (\$4F) | TCCR1<br>TCNT1 | CTC1             | PWM1A                                 | COM1A1           | COM1A0                            | CS13<br>カウンタ1                         | CS12                 | CS11             | CS10                                  | 59<br>61,68 |
| \$2F (\$4F)<br>\$2E (\$4E) | OCR1A          |                  | +                                     | · ,              | ・・・・クイマ <i>/ 。</i><br>タイマ / カウンタ1 | ルリンク1<br>比較Aレシブスク                     | 7                    | ·                | <del>-</del>                          | 61,68       |
| \$2D (\$4D)                | OCR1C          |                  | +                                     |                  |                                   | 比較Cレジス                                |                      |                  | ·                                     | 61,68       |
| \$2C (\$4C)                | GTCCR          | TSM              | PWM1B                                 | COM1B1           | COM1B0                            | FOC1B                                 | FOC1A                | PSR1             | PSR0                                  | 60,67,51    |
| \$2B (\$4B)                | OCR1B          |                  |                                       |                  | タイマ/カウンタ1                         | 比較Bレジスタ                               |                      |                  |                                       | 61          |
| \$2A (\$4A)                | TCCR0A         | COM0A1           | COM0A0                                | COM0B1           | COM0B0                            | _                                     | -                    | WGM01            | WGM00                                 | 51          |
| \$29 (\$49)                | OCR0A          |                  |                                       |                  |                                   | 比較Aレジスク                               |                      |                  |                                       | 53          |
| \$28 (\$48)                | OCR0B          |                  |                                       |                  | タイマ/カウンタ0                         | 比較Bレジスタ                               |                      | <del></del>      |                                       | 53          |
| \$27 (\$47)                | PLLCSR         | LSM              | _                                     | _                | -                                 | - CL L/DCo                            | PCKE                 | PLLE             | PLOCK                                 | 63,69       |
| \$26 (\$46)<br>\$25 (\$45) | CLKPR<br>DT1A  | CLKPCE<br>DT1AH3 | DT1AH2                                | DT1AII1          | DT1AH0                            | CLKPS3<br>DT1AL3                      | CLKPS2<br>DT1AL2     | CLKPS1<br>DT1AL1 | CLKPS0<br>DT1AL0                      | 21<br>71    |
| \$24 (\$44)                | DT1A<br>DT1B   | DT1BH3           | DT1BH2                                | DT1AH1<br>DT1BH1 | DT1BH0                            | DT1BL3                                | DT1BL2               | DT1BL1           | DT1BL0                                | 71          |
| \$23 (\$43)                | DTPS1          | - D11B113        | — — — — — — — — — — — — — — — — — — — | -                | - D11B110                         | — — — — — — — — — — — — — — — — — — — | -                    | DTPS11           | DTPS10                                | 71          |
| \$22 (\$42)                | DWDR           |                  | -                                     | ٤                | デハ゛ック゛WIRE                        | データレジスタ                               | Ż                    | 211211           | 211510                                | 92          |
| \$21 (\$41)                | WDTCR          | WDIF             | WDIE                                  | WDP3             | WDCE                              | WDE                                   | WDP2                 | WDP1             | WDP0                                  | 31          |
| \$20 (\$40)                | PRR            | -                | -                                     | -                | -                                 | PRTIM1                                | PRTIM0               | PRUSI            | PRADC                                 | 26          |
| \$1F (\$3F)                | EEARH          | -                | -                                     | -                | _                                 | -                                     | -                    | -                | (EEAR8)                               | 13          |
| \$1E (\$3E)<br>\$1D (\$3D) | EEARL          | (EEAR7)          |                                       |                  |                                   | ドレス レシ スタ<br>ニータ レシ スタ                | $(EEAR6\sim0)$       |                  | ı                                     |             |
| \$1D (\$3D)<br>\$1C (\$3C) | EEDR<br>EECR   | _                |                                       | EEPM1            | EEPM0                             | EERIE                                 | EEMPE                | EEPE             | EERE                                  | 13<br>13    |
| \$1B (\$3B)                | 予約             |                  |                                       | EEI WII          | EEI MO                            | BEKIE                                 | EDIVII E             | EELE             | BEKE                                  | 10          |
| \$1A (\$3A)                | 予約             |                  |                                       |                  |                                   |                                       |                      |                  |                                       |             |
| \$19 (\$39)                | 予約             |                  |                                       |                  |                                   |                                       |                      |                  |                                       |             |
| \$18 (\$38)                | PORTB          | _                | -                                     | PORTB5           | PORTB4                            | PORTB3                                | PORTB2               | PORTB1           | PORTB0                                | 42          |
| \$17 (\$37)                | DDRB           | -                | -                                     | DDB5             | DDB4                              | DDB3                                  | DDB2                 | DDB1             | DDB0                                  | 42          |
| \$16 (\$36)                | PINB           | _                | -                                     | PINB5            | PINB4                             | PINB3                                 | PINB2                | PINB1            | PINB0                                 | 42          |
| \$15 (\$35)<br>\$14 (\$34) | PCMSK<br>DIDR0 | _                | -                                     | PCINT5<br>ADC0D  | PCINT4                            | PCINT3<br>ADC3D                       | PCINT2<br>ADC1D      | PCINT1<br>AIN1D  | PCINT0<br>AIN0D                       | 34<br>91,81 |
| \$14 (\$34)                | GPIOR2         |                  |                                       | ADCOD            |                                   | ADC3D  <br> )レジスタ2                    | ADCID                | AINID            | AINUD                                 | 14          |
| \$12 (\$32)                | GPIOR1         |                  |                                       |                  | 0 -7 14 7                         | シレシブスタ1                               |                      |                  |                                       | 14          |
| \$11 (\$31)                | GPIOR0         |                  |                                       |                  | 汎用I/C                             | )レシ゛スタ0                               |                      |                  |                                       | 14          |
| \$10 (\$30)                | USIBR          |                  |                                       |                  |                                   | 町レシ スタ                                |                      |                  |                                       | 77          |
| \$0F (\$2F)                | USIDR          |                  |                                       | ****             |                                   | タレジスタ                                 | 110101               |                  | * * * * * * * * * * * * * * * * * * * | 77          |
| \$0E (\$2E)                | USISR          | USISIF           | USIOIF                                | USIPF            | USIDC                             | USICNT3                               | USICNT2              | USICNT1          | USICNT0                               | 77          |
| \$0D (\$2D)<br>\$0C (\$2C) | USICR<br>予約    | USISIE           | USIOIE                                | USIWM1           | USIWM0                            | USICS1                                | USICS0               | USICLK           | USITC                                 | 78          |
| \$0B (\$2B)                | 予約             |                  |                                       |                  |                                   |                                       |                      |                  |                                       |             |
| \$0B (\$2B)                | 予約             |                  |                                       |                  |                                   |                                       |                      |                  |                                       |             |
| \$09 (\$29)                | 予約             |                  |                                       |                  |                                   |                                       |                      |                  |                                       |             |
| \$08 (\$28)                | ACSR           | ACD              | ACBG                                  | ACO              | ACI                               | ACIE                                  | -                    | ACIS1            | ACIS0                                 | 81          |
| \$07 (\$27)                | ADMUX          | REFS1            | REFS0                                 | ADLAR            | REFS2                             | MUX3                                  | MUX2                 | MUX1             | MUX0                                  | 89          |
| \$06 (\$26)                | ADCSRA         | ADEN             | ADSC                                  | ADATE            | ADIF                              | ADIE                                  | ADPS2                | ADPS1            | ADPS0                                 | 90          |
| \$05 (\$25)                | ADCI           |                  |                                       |                  |                                   | (ADC9~83                              |                      |                  | -                                     | 91          |
| \$04 (\$24)<br>\$03 (\$23) | ADCL<br>ADCSRB | BIN              | ACME                                  | Dデータレジン<br>IPR   | <u> </u>                          | (ADC7~0±                              | ://2/JADC1^<br>ADTS2 | ADTS1            | ADTS0                                 | 90,80       |
| \$03 (\$23)                | 予約             | DIN              | ACME                                  | 11.17            |                                   |                                       | AD 134               | הואות            | מועה                                  | 30,00       |
| \$01 (\$21)                | 予約             |                  |                                       |                  |                                   |                                       |                      |                  |                                       |             |
| \$00 (\$20)                | 予約             |                  |                                       |                  |                                   |                                       |                      |                  |                                       |             |
|                            | テバイスとの出        | 上番州のため           | ・子ぬど…しゃ                               | 、主ノ担人は           | のな妻ノベキ                            | 万十 圣约I/                               | OJEII マビン            | ルナ沖ルで事           | かわてベキマ                                | いけなりませり     |

注:・将来のデバイスとの共通性のため、予約ビットへ書く場合はOを書くべきです。予約I/Oメモリ アドレスは決して書かれるべきではありません。

- ・アドレス範囲\$00~\$1FのI/OレジスタはCBIとSBI命令の使用で直接アクセス可能です。これらのレジスタの単一ビットはCBISとSBIS命令の使用によって検査できます。
- ・いくつかの状態ビットはそれらへ論理1を書くことによって解除(0)されます。他の多くのAVRと異なり、CBIとSBI命令は指定ビットだけ操作し、従ってこのような状態フラグを含むレジスタで使えることに注意してください。CBIとSBI命令は\$00~\$1Fのレジスタだけで動作します。



# **24**. 命令要約 (1/2)

| ニーモニック | オヘ゜ラント゛ | 意味                                                      | 動作                                                  | フラク゛                    | クロック                  |
|--------|---------|---------------------------------------------------------|-----------------------------------------------------|-------------------------|-----------------------|
|        |         |                                                         | 里演算命令                                               |                         |                       |
| 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   | Rd,K6   | 即値の語(ワード)長減算                                            | RdH:RdL ← RdH:RdL − K6                              | I,T,H,S,V,N,Z,C         | 2                     |
| SBC    | Rd,Rr   | キャリーを含めた汎用レジスタ間の減算                                      | $Rd \leftarrow Rd - Rr - C$                         | I,T,H,S,V,N,Z,C         | 1                     |
| SBCI   | Rd,K    | 汎用レジスタからキャリーと即値の減算                                      | $Rd \leftarrow Rd - K - C$                          | I,T,H,S,V,N,Z,C         | 1                     |
| AND    | Rd,Rr   | 汎用レジスタ間の論理積(AND)                                        | Rd ← Rd AND Rr                                      | I,T,H,S,V,N,Z,C         | 1                     |
| ANDI   | Rd,K    | 汎用レジスタと即値の論理積(AND)                                      | Rd ← Rd AND K                                       | I,T,H,S,0,N,Z,C         | 1                     |
| OR     | Rd,Rr   | 汎用レジスタ間の論理和(OR)                                         | Rd ← Rd OR Rr                                       | I,T,H,S,0,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                                      |                         | 1                     |
|        |         |                                                         |                                                     | 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 \leftarrow Rd \ OR \ K$                         | I,T,H,S,0,N,Z,C         | 1                     |
| CBR    | Rd,K    | 汎用レジスタの(複数)ビット解除(0)                                     | $Rd \leftarrow Rd \text{ AND ($FF - K)}$            | I,T,H,S,0,N,Z,C         | 1                     |
| INC    | Rd      | 汎用レジスタの増加(+1)                                           | $Rd \leftarrow 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,S,0,N,Z,C         | 1                     |
| CLR    | Rd      | 汎用レシブスタの全 <mark>0</mark> 設定(=\$00)                      | Rd ← Rd EOR Rd                                      | $I,T,H,\theta,0,0,1,C$  | 1                     |
| SER    | Rd      | 汎用レシブスタの全1設定(=\$FF)                                     | Rd ← \$FF                                           | I,T,H,S,V,N,Z,C         | 1                     |
|        |         |                                                         | <b>技命令</b>                                          |                         |                       |
| RJMP   | k       | 相対無条件分岐                                                 | $PC \leftarrow PC + k + 1$                          | I,T,H,S,V,N,Z,C         | 2                     |
| IJMP   |         | Zレジブスタ間接無条件分岐                                           | $PC \leftarrow Z$                                   | I,T,H,S,V,N,Z,C         | 2                     |
|        | 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   |         | 割り込みからの復帰                                               | PC ← STACK                                          | <b>1</b> ,T,H,S,V,N,Z,C | 4                     |
| CPSE   | Rd,Rr   | 汎用レジスタ間比較、一致でスキップ                                       | Rd=Rrなら、PC ← PC + 2or3                              | I,T,H,S,V,N,Z,C         | 1/2,3                 |
| CP     | Rd,Rr   | 汎用レジスタ間の比較                                              | Rd - Rr                                             | I,T,H,S,V,N,Z,C         | 1                     |
| CPC    | Rd,Rr   | キャリーを含めた汎用レジスタ間の比較                                      | Rd - Rr - C                                         | I,T,H,S,V,N,Z,C         | 1                     |
| CPI    | Rd,K    | 汎用レジスタと即値の比較                                            | 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)=1756, PC ← PC + 2013                          | I,T,H,S,V,N,Z,C         |                       |
| SBIC   | P,b     | I/Oレシ、スタのアントが解除(0)でスキップ                                 | P(b)=0%b, PC ← PC + 2013                            | I,T,H,S,V,N,Z,C         |                       |
| SBIS   | P,b     | 1/0レジスタのピットが設定(1)でスキップ                                  | P(b)=1なら, PC ← PC + 2or3                            | I.T.H.S.V.N.Z.C         | $\frac{1/2,3}{1/2,3}$ |
|        |         |                                                         |                                                     | I.T.H.S.V.N.Z.C         |                       |
| BRBS   | s,k     | ステータス フラグが設定(1)で分岐                                      | $SREG(s)=1$ \$\forall b, $PC \leftarrow PC + K + 1$ | -, - ,,- , . ,,- , -    | 1/2                   |
| BRBC   | s,k     | ステータス フラグが解除(0)で分岐                                      | SREG(s)= $0\%$ , PC $\leftarrow$ PC + K + 1         | I,T,H,S,V,N,Z,C         | 1/2                   |
| BREQ   | k       | 一致で分岐                                                   | $Z=1$ \$\frac{1}{2}\$, PC \leftarrow PC + K + 1     | I,T,H,S,V,N,Z,C         | 1/2                   |
| BRNE   | k       | 不一致で分岐                                                  | $Z=0$ 7 $c$ 6, $PC \leftarrow 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   |         | キャリー フラグが解除(0)で分岐                                       | C=0なら, PC ← PC + K + 1                              | I,T,H,S,V,N,Z,C         |                       |
| BRSH   | k       | 符号なしの≧で分岐                                               | C=0/\$6, 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)=0なら, 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       | ハーフキャリー フラグが解除( <mark>0</mark> )で分岐                     | H=0なら, PC ← PC + K + 1                              | I,T,H,S,V,N,Z,C         | 1/2                   |
| BRTS   | k       | 一時フラグが設定(1)で分岐                                          | T=1なら, PC ← PC + K + 1                              | I,T,H,S,V,N,Z,C         | 1/2                   |
| BRTC   | k       | 一時フラグが解除( <u>0</u> )で分岐                                 | T=07\$6, PC ← PC + K + 1                            | I,T,H,S,V,N,Z,C         | 1/2                   |
|        |         |                                                         | V=17x6, PC ← PC + K + 1                             | I,T,H,S,V,N,Z,C         | $\frac{1}{2}$         |
| BRVS   | k       | 【 ZVJYH 发X子(m x U / ) / / / / / / / / / / / / / / / / / |                                                     |                         |                       |
|        | k<br>k  | 2の補数溢れフラグが設定(1)で分岐<br>2の補数溢れフラグが解除(0)で分岐                |                                                     |                         | 1/2                   |
| BRVC   | k       | 2の補数溢れフラグが解除(0)で分岐                                      | V=0なら, PC ← PC + K + 1                              | I,T,H,S,V,N,Z,C         | 1/2                   |
|        |         |                                                         |                                                     |                         | 1/2<br>1/2<br>1/2     |

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)



# **命令要約** (2/2)

| ニーモニック | オペラント゛ | 意味                                                                     | 動作                                                                                 | フラク゛                                        | クロ |
|--------|--------|------------------------------------------------------------------------|------------------------------------------------------------------------------------|---------------------------------------------|----|
| MOV    | Rd,Rr  | <u>データ</u> 種<br>【汎用レジスタ間の複 <i>写</i>                                    | 多動命令<br>  Rd ← Rr                                                                  | I,T,H,S,V,N,Z,C                             | 1  |
| MOVW   | Rd,Rr  | 汎用レジスタ対間の複写                                                            | $Rd \leftarrow Rr$<br>$Rd+1:Rd \leftarrow Rr+1:Rr$                                 | I, T, H, S, V, N, Z, C                      | 1  |
| LDI    | Rd,K   | 即値の取得                                                                  | Rd ← K                                                                             | I,T,H,S,V,N,Z,C                             | 1  |
| LDI    | Rd,X   | Xレジスタ間接での取得                                                            | $Rd \leftarrow (X)$                                                                | I,T,H,S,V,N,Z,C                             | 2  |
| LD     | Rd,X+  | 事後増加付きXレジスタ間接での取得                                                      | $Rd \leftarrow (X), X \leftarrow X + 1$                                            | I,T,H,S,V,N,Z,C                             | 6  |
| LD     | Rd,-X  | 事前減少付きXレジスタ間接での取得                                                      | $X \leftarrow X - 1, Rd \leftarrow (X)$                                            | I,T,H,S,V,N,Z,C                             |    |
| LD     | Rd,Y   | Yレジスタ間接での取得                                                            | $Rd \leftarrow (Y)$                                                                | I,T,H,S,V,N,Z,C                             | 6  |
| LD     | Rd,Y+  | 事後増加付きYレジスタ間接での取得                                                      | $Rd \leftarrow (Y), Y \leftarrow Y + 1$                                            | I,T,H,S,V,N,Z,C                             | 6  |
| LD     | Rd,-Y  | 事前減少付きアレジスタ間接での取得                                                      | $Y \leftarrow Y - 1$ , $Rd \leftarrow (Y)$                                         | I,T,H,S,V,N,Z,C                             | 6  |
| LDD    | Rd,Y+q | 変位付きYレジスタ間接での取得                                                        | $Rd \leftarrow (Y + q)$                                                            | I,T,H,S,V,N,Z,C                             | 6  |
| LDD    | Rd,Z   | Zレジスタ間接での取得                                                            | $Rd \leftarrow (Z)$                                                                | I,T,H,S,V,N,Z,C                             | 6  |
| LD     | Rd,Z+  | 事後増加付きZレジスタ間接での取得                                                      | $Rd \leftarrow (Z), Z \leftarrow Z + 1$                                            | I,T,H,S,V,N,Z,C                             | -  |
| LD     | Rd,-Z  | 事前減少付きZレジスタ間接での取得                                                      | $Z \leftarrow Z - 1, Rd \leftarrow (Z)$                                            | I,T,H,S,V,N,Z,C                             | -  |
| LDD    | Rd,Z+q | 変位付きZレジスタ間接での取得                                                        | $Rd \leftarrow (Z + q)$                                                            | I,T,H,S,V,N,Z,C                             | -  |
| LDS    | Rd,k   | データ空間(SRAM)から直接取得                                                      | $Rd \leftarrow (k)$                                                                | I,T,H,S,V,N,Z,C                             | -  |
| ST     | X,Rr   | Xレジスタ間接での設定                                                            | $(X) \leftarrow Rr$                                                                | I,T,H,S,V,N,Z,C                             | 6  |
| ST     | X+,Rr  | 事後増加付きXレジスタ間接での設定                                                      | $(X) \leftarrow Rr$<br>$(X) \leftarrow Rr, X \leftarrow X + 1$                     | I, T, H, S, V, N, Z, C                      | 6  |
|        |        |                                                                        | $(X) \leftarrow Rr, X \leftarrow X + 1$<br>$X \leftarrow X - 1, (X) \leftarrow Rr$ |                                             |    |
| ST     | -X,Rr  | 事前減少付きXレジスタ間接での設定                                                      |                                                                                    | I,T,H,S,V,N,Z,C                             | 4  |
| ST     | Y,Rr   | Yレジスタ間接での設定                                                            | (Y) ← Rr                                                                           | I,T,H,S,V,N,Z,C                             | 4  |
| ST     | Y+,Rr  | 事後増加付きYレジスタ間接での設定                                                      | $(Y) \leftarrow Rr, Y \leftarrow Y + 1$                                            | I,T,H,S,V,N,Z,C                             |    |
| ST     | -Y,Rr  | 事前減少付きソレジスタ間接での設定                                                      | $Y \leftarrow Y - 1, (Y) \leftarrow Rr$                                            | I,T,H,S,V,N,Z,C                             | :  |
| STD    | Y+q,Rr | 変位付きYレジスタ間接での設定                                                        | $(Y + q) \leftarrow Rr$                                                            | I,T,H,S,V,N,Z,C                             | -  |
| ST     | Z,Rr   | Zレジスタ間接での設定                                                            | $(Z) \leftarrow Rr$                                                                | I,T,H,S,V,N,Z,C                             |    |
| ST     | Z+,Rr  | 事後増加付きZレジスタ間接での設定                                                      | $(Z) \leftarrow \operatorname{Rr}, Z \leftarrow Z + 1$                             | I,T,H,S,V,N,Z,C                             | ,  |
| ST     | −Z,Rr  | 事前減少付きZレジスタ間接での設定                                                      | $Z \leftarrow Z - 1, (Z) \leftarrow Rr$                                            | I,T,H,S,V,N,Z,C                             | :  |
| STD    | Z+q,Rr | 変位付きZレジスタ間接での設定                                                        | $(Z+q) \leftarrow Rr$                                                              | I,T,H,S,V,N,Z,C                             |    |
| STS    | k,Rr   | データ空間(SRAM)へ直接設定                                                       | (k) ← Rr                                                                           | I,T,H,S,V,N,Z,C                             | 4  |
| LPM    |        | プログラム領域からZレジスタ間接での取得                                                   | $R0 \leftarrow (Z)$                                                                | I,T,H,S,V,N,Z,C                             |    |
| LPM    | Rd,Z   | 同上(任意のレシブスタへ)                                                          | $Rd \leftarrow (Z)$                                                                | I,T,H,S,V,N,Z,C                             |    |
| LPM    | Rd,Z+  | 同上 (事後増加付き)                                                            | $Rd \leftarrow (Z), Z \leftarrow Z + 1$                                            | I,T,H,S,V,N,Z,C                             | ,  |
| SPM    |        | プログラム領域へZレジスタ間接での設定                                                    | (Z) ← R1:R0                                                                        | I,T,H,S,V,N,Z,C                             | -  |
| IN     | Rd,P   | I/Oレジスタからの入力                                                           | $Rd \leftarrow P$                                                                  | I,T,H,S,V,N,Z,C                             |    |
| OUT    | P,Rr   | I/Oレジスタへの出力                                                            | P ← Rr                                                                             | I,T,H,S,V,N,Z,C                             |    |
| PUSH   | Rr     | 汎用レシブスタをスタックへ保存                                                        | STACK ← Rr                                                                         | I,T,H,S,V,N,Z,C                             | 4  |
| POP    | Rd     | スタックから汎用レシ、スタ〜復帰                                                       | Rd ← STACK                                                                         | I,T,H,S,V,N,Z,C                             | 4  |
|        |        |                                                                        | <b>関係命令</b>                                                                        |                                             |    |
| SBI    | P,b    | I/Oレジスタのビット設定(1)                                                       | $I/O(P,b) \leftarrow 1$                                                            | I,T,H,S,V,N,Z,C                             | 4  |
| CBI    | P,b    | I/Oレジスタのビット解除(0)                                                       | $I/O(P,b) \leftarrow 0$                                                            | I,T,H,S,V,N,Z,C                             | 4  |
| LSL    | Rd     | 論理的左ビット移動                                                              | $Rd(n+1) \leftarrow Rd(n), Rd(0) \leftarrow 0$                                     | I,T,H,S,V,N,Z,C                             |    |
| LSR    | Rd     | 論理的右ビット移動                                                              | $Rd(n) \leftarrow Rd(n+1), Rd(7) \leftarrow 0$                                     | I,T,H,S,V,Ø,Z,C                             |    |
| ROL    | Rd     | キャリーを含めた左回転                                                            | $Rd(0) \leftarrow C, Rd(n+1) \leftarrow Rd(n), C \leftarrow Rd(7)$                 | I,T,H,S,V,N,Z,C                             |    |
| ROR    | Rd     | キャリーを含めた右回転                                                            | $Rd(7) \leftarrow C, Rd(n) \leftarrow Rd(n+1), C \leftarrow Rd(0)$                 | I,T,H,S,V,N,Z,C                             |    |
| ASR    | Rd     | 算術的右ビット移動                                                              | $Rd(n) \leftarrow Rd(n+1), n=0 \sim 6$                                             | I,T,H,S,V,N,Z,C                             |    |
| SWAP   | Rd     | ニブル(4ビット)上位/下位交換                                                       | $Rd(7\sim4) \Leftrightarrow Rd(3\sim0)$                                            | I,T,H,S,V,N,Z,C                             |    |
| BSET   | S      | ステータス レシ スタのビット設定(1)                                                   | $SREG(s) \leftarrow 1$                                                             | 1,T,H,\$,Y,N,Z,C                            |    |
| BCLR   | S      | ステータス レシブスタのビット解除(0)                                                   | $SREG(s) \leftarrow 0$                                                             | $0,0,\Theta,\Theta,0,0,\emptyset,\emptyset$ |    |
| BST    | Rr,b   | 汎用レジブスタのビットを一時フラグへ移動                                                   | $T \leftarrow Rr(b)$                                                               | I,T,H,S,V,N,Z,C                             |    |
| BLD    | Rd,b   | 一時フラグを汎用レジスタのビットへ移動                                                    | $Rd(b) \leftarrow T$                                                               | I,T,H,S,V,N,Z,C                             |    |
| SEC    | ,~     | キャリー フラグを設定(1)                                                         | $C \leftarrow 1$                                                                   | I,T,H,S,V,N,Z,C                             |    |
| CLC    |        | キャリー フラグを解除(0)                                                         | C ← 0                                                                              | I,T,H,S,V,N,Z, <b>0</b>                     |    |
| SEN    |        | (1) と (1) (1) (1) (1) (1) (1) (1) (1) (1) (1)                          | N ← 1                                                                              | I,T,H,S,V,N,Z,C                             |    |
| CLN    |        | <b>負フラグを解除(0)</b>                                                      | $N \leftarrow 0$                                                                   | I,T,H,S,V, <b>0</b> ,Z,C                    |    |
| SEZ    |        | ゼロフラグを設定(1)                                                            | $Z \leftarrow 1$                                                                   | I,T,H,S,V,N, <b>I</b> ,C                    |    |
| CLZ    |        | ゼロフラグを解除(0)                                                            | $Z \leftarrow 0$                                                                   | I,T,H,S,V,N,Ø,C                             |    |
| SEI    |        | 全割り込み許可                                                                | I ← 1                                                                              | 1,T,H,S,V,N,Z,C                             |    |
| CLI    |        | 全割り込み禁止                                                                | I ← 0                                                                              | 0,T,H,S,V,N,Z,C                             |    |
| SES    |        | (1) (1) (1) (1) (2) (1) (2) (1) (2) (2) (2) (2) (2) (2) (2) (2) (2) (2 | S ← 1                                                                              | I,T,H,\$,V,N,Z,C                            |    |
| CLS    |        | 符号フラグを解除(0)                                                            | $S \leftarrow 0$                                                                   | I, T, H, θ, V, N, Z, C                      |    |
| SEV    |        | 2の補数溢れフラグを設定(1)                                                        | V ← 1                                                                              | I,T,H,S,Y,N,Z,C                             |    |
| CLV    |        | 2の補数溢れフラグを解除(0)                                                        | V ← 1<br>V ← 0                                                                     | I, T, H, S, <b>V</b> , N, Z, C              |    |
| SET    |        | - 一時フラグを設定(1)                                                          | V ← 0<br>T ← 1                                                                     | I,T,H,S,V,N,Z,C                             |    |
| CLT    |        | 一時フラグを設定(1)<br>一時フラグを解除(0)                                             | $T \leftarrow 1$ $T \leftarrow 0$                                                  |                                             |    |
|        |        |                                                                        |                                                                                    | I, <b>0</b> ,H,S,V,N,Z,C                    |    |
| SEH    |        | ハーフキャリー フラグを設定(1)                                                      | H ← 1<br>H ← 0                                                                     | I,T,H,S,V,N,Z,C<br>I,T,Ø,S,V,N,Z,C          |    |
| CLH    |        | ハーフキャリー フラケ・を解除(0)                                                     |                                                                                    | 1, 1, M, S, V, N, Z, C                      |    |
| NOP    |        | 無操作                                                                    | רו אייון ניק                                                                       | I,T,H,S,V,N,Z,C                             |    |
| SLEEP  |        | <del>                                    </del>                        | 休止形態参照                                                                             | I,T,H,S,V,N,Z,C                             |    |
| WDR    |        | ウォッチドック・タイマ リセット                                                       | ウォッチトック・タイマ参照                                                                      | I,T,H,S,V,N,Z,C                             |    |
| VVIII  |        | 1/4//1/////////////////////////////////                                | 17477177 7 1 2 2 2 2 2 2 2 2 2 2 2 2 2 2 2                                         | 1, 1, 1, 1, U, V, I V, L, V, U              |    |



# 25. 注文情報

| テ゛ハ゛イス    | 速度(MHz) ( <u>注</u> 1) | 電源電圧       | 動作範囲                                   | 外囲器 (注2)     | 注文コート* (注3)                         |
|-----------|-----------------------|------------|----------------------------------------|--------------|-------------------------------------|
| , ,,,     |                       |            |                                        | 8P3          | ATtiny25V-10PU                      |
|           |                       |            |                                        | 51.5         | ATtiny25V-10SU                      |
|           |                       |            |                                        | 8S2          | ATtiny25V-10SUR                     |
|           |                       |            |                                        | 032          | ATtiny25V-10SH                      |
|           |                       |            | 工業用 (-40℃~85℃)                         |              | ATtiny25V-10SHR                     |
|           |                       |            | (注4)                                   |              | ATtiny25V-10SSU                     |
|           |                       |            | (, <b>_</b> ,/                         | S8S1<br>20M1 | ATtiny25V-10SSUR                    |
|           | 10                    | 1.8~5.5V   |                                        |              | ATtiny25V-10SSH<br>ATtiny25V-10SSHR |
|           | 10                    | 1.8°~5.5V  |                                        |              | ATtiny25V-100011K                   |
|           |                       |            |                                        |              | ATtiny25V-10MUR                     |
|           |                       |            |                                        |              | ATtiny25V-10SN                      |
|           |                       |            | 工業用 (-40℃~105℃)                        | 8S2          | ATtiny25V-10SNR                     |
|           |                       |            | (注5)                                   |              | ATtiny25V-10SSN                     |
|           |                       |            | (,±3)                                  | S8S1         | ATtiny25V-10SSNR                    |
|           |                       |            | 工業用 (-40℃~125℃)                        | 00) (1       | ATtiny25V-10MF                      |
| A.T O.F.  |                       |            | (注6)                                   | 20M1         | ATtiny25V-10MFR                     |
| ATtiny25  |                       |            |                                        | 8P3          | ATtiny25-20PU                       |
|           |                       |            |                                        |              | ATtiny25-20SU                       |
|           |                       |            |                                        | 8S2          | ATtiny25-20SUR                      |
|           |                       |            |                                        | 002          | ATtiny25-20SH                       |
|           |                       |            | 工業用 (-40℃~85℃)                         |              | ATtiny25–20SHR                      |
|           | 20                    |            | (注4)                                   | S8S1         | ATtiny25-20SSU<br>ATtiny25-20SSUR   |
|           |                       |            |                                        |              | ATtiny25–20550K<br>ATtiny25–20SSH   |
|           |                       | 2.7~5.5V   |                                        |              | ATtiny25-20SSHR                     |
|           |                       |            |                                        | 20M1         | ATtiny25-20MU                       |
|           |                       |            |                                        |              | ATtiny25-20MUR                      |
|           |                       |            | 工業用 (-40℃~105℃)<br>( <mark>注5</mark> ) | 8S2          | ATtiny25-20SN                       |
|           |                       |            |                                        |              | ATtiny25–20SNR                      |
|           |                       |            |                                        | S8S1         | ATtiny25-20SSN                      |
|           |                       |            |                                        |              | ATtiny25-20SSNR                     |
|           |                       |            | 工業用 (-40℃~125℃)                        | 20M1         | ATtiny25V-20MF                      |
|           |                       |            | (注6)                                   |              | ATtiny25V-20MFR                     |
|           |                       |            |                                        | 8P3          | ATtiny45V-10PU                      |
|           |                       |            |                                        |              | ATtiny45V-10SU<br>ATtiny45V-10SUR   |
|           |                       |            |                                        | 8S2          | ATtiny45V-1050K<br>ATtiny45V-10SH   |
|           | 10                    | 1.8~5.5V   |                                        |              | ATtiny45V-10SHR                     |
|           |                       | 1.0 0.01   |                                        | 017          | ATtiny45V-10XU                      |
|           |                       |            |                                        | 8X           | ATtiny45V-10XUR                     |
|           |                       |            |                                        | 20M1         | ATtiny45V-10MU                      |
| ATtiny45  |                       |            | 工業用 (-40℃~85℃)                         |              | ATtiny45V-10MUR                     |
| AT thiy40 |                       |            | (注4)                                   | 8P3          | ATtiny45–20PU                       |
|           |                       |            |                                        |              | ATtiny45-20SU                       |
|           |                       |            |                                        | 8S2          | ATtiny45-20SUR                      |
|           | 20                    | 2.7~5.5V   |                                        |              | ATtiny45-20SH<br>ATtiny45-20SHR     |
|           |                       | 2.1 -0.0 V |                                        |              | ATtiny45-20XU                       |
|           |                       |            |                                        | 8X           | ATtiny45-20XU<br>ATtiny45-20XUR     |
|           |                       |            |                                        |              | ATtiny45-20MU                       |
|           |                       |            |                                        | 20M1         | ATtiny45 20MC<br>ATtiny45–20MUR     |
| 次頁へ続く     |                       |            |                                        |              | ,                                   |



| <b>デバイ</b> ス | 速度(MHz) ( <mark>注1</mark> ) | 電源電圧     | 動作範囲           | 外囲器 (注2) | 注文コート (注3)      |
|--------------|-----------------------------|----------|----------------|----------|-----------------|
|              |                             |          |                | 8P3      | ATtiny85V-10PU  |
|              |                             |          |                |          | ATtiny85V-10SU  |
|              |                             |          |                | 8S2      | ATtiny85V-10SUR |
|              | 10                          | 1.8∼5.5V |                | 052      | ATtiny85V-10SH  |
|              |                             |          |                |          | ATtiny85V-10SHR |
|              |                             |          |                | 20M1     | ATtiny85V-10MU  |
| ATtiny85     |                             |          | 工業用 (-40℃~85℃) | 201111   | ATtiny85V-10MUR |
| AT tilly05   |                             |          | (注4)           | 8P3      | ATtiny85–20PU   |
|              |                             |          |                |          | ATtiny85-20SU   |
|              |                             |          |                | 8S2      | ATtiny85-20SUR  |
|              | 20                          | 2.7~5.5V |                | 052      | ATtiny85-20SH   |
|              |                             |          |                |          | ATtiny85-20SHR  |
|              |                             |          |                | 20M1     | ATtiny85–20MU   |
|              |                             |          |                | 201111   | ATtiny85-20MUR  |

注1: 速度対電源電圧については109頁の「速度」をご覧ください。

注2:全ての外囲器は鉛フリー、ハロゲン化合物フリーで完全に安全で、これらは有害物質使用制限に関する欧州指令(RoHS指令)に 適合します。

注3: 符号識別子: H=ニッケル・パラジウム・金(NiPdAu)仕上げ、U,N=半光沢錫、R=テープとリール

注4: このデバイスはウェハー(チップ単体)形状でも供給できます。最低数量と詳細な注文情報については最寄のAtmel営業所へお問 い合わせください。

注5: 特性については対補A,105℃でのATtiny25/V仕様をご覧ください。

注6: 特性については対補B,125℃でのATtiny25/V仕様をご覧ください。

|      | 外囲器形式                                                 |
|------|-------------------------------------------------------|
| 8P3  | 8ピン 300mil幅 プラスティック2列直線外囲器 (PDIP)                     |
| 8S2  | 8リート 208mil幅 プラスティック小型外形外囲器 (EIAJ SOIC)               |
| S8S1 | 8リート 150mil幅 プラスティック小型外形外囲器 (JEDEC SOIC)              |
| 8X   | 8リート、4.4mm幅 プラスティック薄型縮小外形外囲器 (TSSOP)                  |
| 20M1 | 20パッド4×4×0.8mm 0.5mmピッチ 4方向平板リードなし/小リード枠外囲器 (QFN/MLF) |



# 26. 外囲器情報

# 26.1. 8P3



#### **26.2**. 8S2



## 26.3. S8S1



#### 26.4. 8X



# 26.5. 20M1





# 27. 障害情報

この章の改訂番号はATtiny25/45/85(V)デバイスの改訂版を参照してください。

• 高すぎるパワーダウン動作での消費電力

● 1行実行中割り込み時のデバッグWIRE通信切断

• PLL固定化不良

• 応用コート、からのEEPROM読み出しが施錠ビット種別3で働かない

● タイマ/カウンタ1のOC1B PWM出力生成が正しく動作しない

EEPROM読み込みが低供給電圧/低周波数で失敗する可能性

45-A 45-A

45-A∼C

45-A∼C

45-B/C

25-B/C, 45-A~E, 85-A

### 1. 高すぎるパワーダウン動作での消費電力(45-A)

以下の状態は高すぎるパワーダウン動作での電力消費を引き起こします。

- ヒュース、によって外部クロックが選択されているが、そのI/Oポートが未だ出力として許可されている。
- EEPROMがパワーダウン移行前に読まれる。
- VCCが4.5Vまたはそれ以上。

#### 対策/対処

- 外部クロック使用時、出力としてのクロック ピン設定を避けてください。
- パワーダウン動作消費電力が重要なら、EEPROMを読まないでください。
- 4.5V未満のVCCを使ってください。

# 2.1行実行中割り込み時のデバッグWIRE通信切断 (45-A)

1行実行中に割り込みを受けると、デバッグWIREは通信を開放します。

#### 対策/対処

- 1行実行時、割り込みを禁止してください。
- 割り込みのデバッグ時、割り込み処理ルーチン内の中断点を使って割り込み内を走らせてください。

# 3. PLL固定化不良(45-A~C)

6.0MHz以下の周波数での走行時、PLLが固定化しません。

## 対策/対処

● PLL使用時、6.0MHzまたはそれ以上で走らせてください。

## 4. 応用コートからのEEPROM読み出しが施錠ビット種別3で働かない(45-A~C)

メモリ施錠ビットのLB2とLB1が動作種別3にプログラム(設定)されると、EEPROM読み出しが応用コードから動作しません。

# 対策/対処

応用コートがEEPROMからの読み出しを必要とする時は施錠ビット保護動作種別3を設定しないでください。

## 5. タイマ/カウンタ1のOC1B PWM出力生成が正しく動作しない(45-B/C)

タイマ/カウンタ1のOC1B,OC1BのPWM出力が正しく動きません。COM1B1,0制御ビットが各々COM1A1,0と同じ時だけ、OC1B,OC1B 出力は正しく動作します。

#### 対策/対処

対策はCOM1A1,0とCOM1B1,0で同じ制御設定を使うことだけです。データシートの表12-1.をご覧ください。この問題はATtiny45改訂Dで修正されています。

#### 6. EEPROM読み込みが低供給電圧/低周波数で失敗する可能性(25-B/C, 45-A~E, 85-A)

低クロック周波数や低供給電圧でEEPROMを読む試みは不正なデータ読み込みに終わるかもしれません。

#### 対策/対処

クロック周波数が1MHz未満で供給電圧が2V未満の時はEEPROMを使わないでください。動作周波数が1MHz以上に上げられない場合、供給電圧は2Vよりも高くあるべきです。同様に、供給電圧が2V以上に上げられない場合、動作周波数は1MHzよりも高くあるべきです。

この特性は温度依存であることが知られていますが、特性付けされていません。指針は室温に対してだけ与えられます。



# 28. データシート改訂履歴

この章内の参照頁番号はこの資料が参照されていることに注意してください。この章内の改訂番号は資料の改訂番号を参照してください。

#### 28.1. 2586A-02/2005

1. 初版

#### 28.2. 2586B-05/2005

- 1. CLKI追加、例のEEMWE/EEWEをEEMPE/EEPEに改名、いくつかのTBD削除、88頁の「**温度測定**」から"暫定記述"を削除
- 2. 1頁の「特徴」を更新
- 3. 2頁の「ピン配置」と27頁の図8-1.を更新
- 4. 23頁の表7-1、41頁の表10-4.と表10-5.を更新
- 5. 101頁の「低電圧直列プログラミング命令一式」を更新
- **6**. 132頁の「**レジスタ要約」**でSPHレジスタを更新
- 7. 108頁の「DC特性」を更新
- 8. 135頁の「注文情報」を更新
- 9. 139頁の「障害情報」を更新

### 28.3. 2586C-06/2005

- 1. 1頁の「特徴」を更新
- 2. 2頁の「t°ン配置」を更新
- 3. 12頁のコート 例を更新
- 4. 「温度測定」を88頁の17.12.項へ移動
- 5. 132頁の「レシ、スタ要約」を更新
- 6. 135頁の「注文情報」を更新

#### 28.4. 2586D-02/2006

- 1. 17頁の表6-3、19頁の表6-9と表6-10、20頁の表6-13、21頁の表6-14、32頁の表9-1、89頁の表17-4、106頁の表20-16、111頁の表21-8を更新
- 2. 57頁の「タイマ/カウンタ1 PWM動作」を更新
- 3. 62頁の「ビット2 TOV1 : タイマ/カウンタ1溢れ割り込み要求フラグ」の文章を更新
- 4. 108頁の「DC特性」で値を更新
- 5. 132頁の「レジスタ要約」を更新
- 6. 135頁の「注文情報」を更新
- 7. 139頁の「障害情報」を更新
- 8. パワーセーブ動作への全参照を削除
- 9. レジスタ アドレス(表記)を更新

#### 28.5. 2586E-03/2006

- 1. 82頁の「A/D変換器 (ADC)」で「特徴」を更新
- **2**. 82頁の「**A/D変換器** (ADC)」で「操作」を更新
- 3.88頁の表17-2.を更新
- 4.89頁の表17-3.を更新
- 5. 139頁の「障害情報」を更新

## 28.6. 2586F-04/2006

- 1. 37頁の「デジタル入力許可と休止形態」を更新
- 2. 106頁の表20-16.を更新
- 3. 135頁の「注文情報」を更新

#### 28.7. 2586G-05/2006

- 1. 15頁の「**高速周辺クロック clk**pck」を更新
- 2. 18頁の「校正付き内蔵RC発振器」を更新
- 3. 19頁の「低周波数クリスタル用発振器」を更新



- 4. 20頁の「**既定のクロック元**」を更新
- 5. 20頁の「**クロック出力緩衝部**」を更新
- 6. 23頁の「電力管理と休止形態」を更新
- 7. 24頁で「BOD禁止」を追加
- 8.81頁の表16-2.を更新
- 9. 81頁の「ビット6 ACBG: 基準電圧選択」を更新
- 10.89頁の表17-3.に対する注を追加
- 11. 132頁の「レジスタ要約」を更新

### 28.8. 2586H-06/2006

- 1. 18頁の「校正付き内蔵RC発振器」を更新
- **2**. 21頁の「OSCCAL 発振校正レジスタ」を更新
- 3. 109頁に表21-2.を追加

#### 28.9. 2586I-09/2006

- 1. 全ての特性データを108頁の「**電気的特性**」へ移動
- 2. 全てのレジスタ記述は各節の終りで分離項目に纏められました。
- 3. 51頁の表11-3.、52頁の表11-5.、98頁の表20-4.を更新
- 4. 18頁の「校正付き内蔵RC発振器」を更新
- 5. 23頁の表7-1.の注を更新
- 6. 27頁の「システム制御とリセット」を更新
- 7. 35頁からの「入出力ポート」でレジスタ記述を更新
- 8. 72頁の「**多用途直列インターフェー**ス (USI)」内の特徴を更新
- 9. 74頁の「SPI主装置操作例」のコート例を更新
- **10**. 80頁の「**7**ナロケ 比較器入力選択」を更新
- 11. 99頁の「識票バイ」を更新
- 12. 108頁の「電気的特性」を更新

### 28.10. 2586J-12/2006

- 1. 1頁の「低消費電力」を更新
- 2. 5頁の「構造概要」で命令長の記述を更新
- 3. 10頁の「実装書き換え可能なプログラム用フラッシュ メモリ」でフラッシュ容量を更新
- **4**. 11頁の「**非分離バイト プログラミング**」、「消去」、「書き込み」項で参照先を更新
- 5. 11頁の「**非分離バイト プログラミング**」を更新
- **6**. 15頁の「**高速周辺クロック-clk**PCK」を更新
- 7. 15頁の図6-2.と16頁の図6-3.とで1つのクロック系統図を置換
- 8. 16頁の表7-1., 18頁の表6-6., 20頁の表6-13.を更新
- 9. 17頁の表6-5.を更新
- 10. 18頁の「校正付き内蔵RC発振器」を更新
- 11. 21頁の「OSCCAL 発振校正レジスタ」を更新
- 12. 21頁の「CLKPR クロック前置分周器レジスタ」を更新
- 13. 23頁の「パワーダウン動作」を更新
- 14. 26頁の「PRR 電力削減レジスタ」を更新
- 15. 31頁の表8-3.に脚注を追加
- 16. 41頁の表10-5.を更新
- 17. 42頁の「MCUCR MCU制御レジスタ」で「ビット7,2」を削除
- 18. 「タイマ/カウンタ0前置分周器とクロック元」項を44頁へ移動/更新
- 19. 56頁の「非同期動作に対するタイマ/カウンタ1の初期化」を更新
- **20**. 63頁と69頁の「PLLCSR PLL制御/状態レジスタ」内のビット記述を更新
- 21. 4頁の「前置分周と変換タイミンク」」内に推奨最大周波数を追加
- 22.86頁の図17-8.を更新
- 23. 88頁の「温度測定」を更新
- 24. 89頁の表17-3.を更新



#### 28.11. 2586K-01/2008

1. 資料雛形更新

#### 2. 項追加

- ・4頁の「データ保持力」
- ・33頁の「Lowレベル割り込み」
- ・99頁の「デバイス識票銘刻部」

#### 3. 項更新

- ・15頁の「システム クロックとクロック任意選択」と「高速周辺クロック clkpck」、16頁の「ATtiny15互換動作での内蔵PLL」
- ・23頁の「休止形態種別」、24頁の「ソフトウェア低電圧検出(BOD)禁止」
- ・33頁の「外部割り込み」
- ・66頁の「ATtiny15互換動作時 タイマ/カウンタ1 PWM動作」
- ・72頁の「多用途直列インターフェース (USI: Universal Serial Interface)」
- ・88頁の「温度測定」
- ・94頁の「ソフトウェアからの施錠」とユース、と識票データの読み出し」
- ・97頁の「プログラム メモリとデータ メモリ用施錠ビット」、98頁の「ヒューズ ビット」、99頁の「識票バイト」と「校正値バイト」
- ・110頁の「システムとリセットの特性」

#### 4. 図追加

・122頁の**図22-23.,図22-24.,図22-25.**、123頁の**図22-26.** 

#### 5. 図更新

・27頁の**図8-1**.

#### 6. 表更新

- ・18頁の表6-7.,表6-8.、19頁の表6-9.
- ・57頁の表12-1、66頁の表13-1.
- ・91頁の**表17-6**.
- ・108頁の表21-1.、109頁の表21-2.、111頁の表21-8.

#### 7. 項内のコード 例更新

• 12頁のEEPROM\_WR:アセンブリュード例

# 8. I/Oレジスタ内のビット記述更新

- ・42頁の「MCUCR MCU制御レジスタ」
- 51頁の「TCCR0A タイマ/カウンタ0制御レシ、スタA」
- ・96頁の「SPMCSR SPM命令制御/状態レジスタ」
- 9. 135頁の「**注文情報**」でATtiny25を更新
- 10. 136頁の「外囲器形式」を更新
- 11. 137頁の「外囲器情報」にS8S1を追加
- 12. 139頁の「障害情報」を更新

#### 28.12. 2586L-06/2010

#### 1. 項追加

- ・1頁の「特徴」、2頁の「ピン配置」、135頁の「注文情報」、136頁の「26.4. 8X」外囲器情報でATtiny45に対するTSSOP
- ・19頁の「低周波数クリスタル用発振器」の表6-11.
- 126頁の図22-36.と図22-37.、内部バンドギャップ電圧対動作電圧とで動作温度
- ・135頁の「注文情報」でATtiny25の拡張温度版、注文情報
- 135頁の「注文情報」でATtiny25とATtiny45のテープ&リールの部品番号

# 2. 項更新

- ・1頁の「特徴」でATtiny25から暫定を削除
- ・30頁の「8.4.2. コート・例」項
- 34頁の「PCMSK ピン変化割り込み許可レジスタ」, ビット初期値
- 59頁の「TCCR1 タイマ/カウンタ1制御レジスタ」と「GTCCR 一般タイマ/カウンタ制御レジスタ」、COMビット記述を明白化
- ・99頁の「**20.3.2. 校正値バイト**」項、周波数(8MHz,6.4MHz)
- 101頁の「表20-11. ヒュース・,フラッシュ,EEPROM次位置書き込み前の待機時間」、two ERASEの値
- ・106頁の「表20-16. 高電圧直列プログラミング命令一式」
- ・108頁の「表21-1. DC特性」、注を補正
- ・113頁の「表21-11. 低電圧直列プログラミング特性」、tSLIVを追加
- ・データシート全体を通してビット表記法を更新、例えばCS02:0からCS0[2:0]へ(訳注:本書では表記法が異なるため無効)

#### 28.13. 2586M-07/2010

- 1. 20頁の「6.4. クロック出力緩衝部(外部クロック出力)」項を明白化
- 2. ATtiny25の拡張温度版に対して-SNと-SNRの注文コードを追加



# 28.14. 2586N-04/2011

- 1. 項目追加
  - ・4頁の「容量性接触感知」項

#### 2. 項目更新

- 資料雛形
- ・表紙から"暫定"を削除、全デバイスは今や最終で製造中です。
- ・24頁の「制限」項
- ・32頁のプログラム例
- ・82頁の「概要」項
- ・89頁の**表17-4**.
- ・100頁の「低電圧直列プログラミング手順」項
- ・111頁の**表21-7**.
- ・135頁の「注文情報」
- ・139頁のEEPROM障害情報

#### **28.15**. 2586O-02/2013

1. 135頁と136頁で注文符号を更新

#### 28.16. 2586P-06/2013

1. 13頁の「EEARH,EEARL (EEAR) - EEPROMアドレス レジスタ」の説明を更新

#### 28.17. 2586Q-08/2013

1. 60頁の「GTCCR - 一般タイマ/カウンタ制御レジスタ」内の「ビット3 - FOC1B:OC1B強制変更」記述を更新。「比較一致出力ピンOC1B (PB3)」内のPB3をPB4に修正



# 目次

|     | 特徴 ••••• 1                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    |     | 11.5. 比較出力部 … 45                                            |
|-----|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-----|-------------------------------------------------------------|
| 1.  | <b>ピン配置 ・・・・・・・・・</b> 2                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       |     | 11.6. 比較一致出力部 ・・・・・・・・・・ 46                                 |
| ••• | 1.1. ピン説明 ····································                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |     | 11.7. 動作種別 ・・・・・・・・・・・・ 47                                  |
| 2   | 概要 ••••• 3                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    |     | <b>11.8</b> . タイマ/カウンタのタイミング・・・・・・ 50                       |
| ۷.  | <b>2.1.</b> 構成図 ···································                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           |     | 11.9. 8ビットタイマ/カウンタ0用レシ、スタ ・・・・・・・・・ 51                      |
|     |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               | 12. | <b>8ビット タイマ/カウンタ1 ・・・・・・・・</b> 55                           |
| 3.  | <b>諸注意 · · · · · · · · 4</b>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  |     | 12.1. タイマ/カウンタ1の前置分周器 ・・・・・・・・・ 55                          |
|     | 3.1. 資料                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       |     | 12.2. タイマ/カウンタ1 ・・・・・・・・・・・・・・・55                           |
|     | 3.2. ¬-ド例 ・・・・・・・・・・・・・・・・4                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   |     | 12.3. 8ビット タイマ/カウンタ1 用レジスタ ・・・・・・・・ 59                      |
|     | <b>3.3</b> . 容量性接触感知 ······ 4                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 | 10  | ATtiny15互換動作での8ビットタイマ/カウンタ1・64                              |
|     | 3.4. データ保持力 ・・・・・・・・・ 4                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       | 13. | 13.1. タイマ/カウンタ1の前置分周器 ·························64           |
| 4.  | <b>AVR CPU 17 · · · · · · · · </b> 5                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          |     | 13.1. タイマ/カウンタ1 の削値が周縮 111111111111111111111111111111111111 |
|     | 4.1. 序説                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       |     |                                                             |
|     | <b>4.2</b> . 構造概要 ······ 5                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    | 4.4 | 13.3. 互換動作時8ビットタイマ/カウンタ1用レジスタ・・・・・67                        |
|     | <b>4.3. ALU</b> (Arithmetic Logic Unit) • • • • 5                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             | 14. | 沈黙時間生成器 70                                                  |
|     | <b>4.4.</b> ステータス レシ スタ ・・・・・・・・・・・・・・・・・・・・・・・・・・・・・・・・・・・                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   |     | 14.1. タイマ/カウンタ1 沈黙時間用レジスタ・・・・・・・ 71                         |
|     | 4.5. 汎用レジスタ ファイル・・・・・・・・・・ 7                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  | 15. | <b>多用途直列インターフ</b> ェース (USI) ・・・・・・・ 72                      |
|     | <b>4.6.</b> スタック ホ°インタ ・・・・・・・・・・ 7                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           |     | 15.1. 特徴                                                    |
|     | 4.7. 命令実行タイミング・・・・・・・8                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        |     | <b>15.2</b> . 概要 · · · · · · · · · 72                       |
|     | 4.8. リセットと割り込みの扱い ・・・・・・ 8                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    |     | 15.3. 機能説明 ************************************             |
| 5   | AVR メモリ · · · · · · · · · 10                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  |     | <b>15.4.</b> USIでの代替使用 ・・・・・・・・ 76                          |
| Ο.  | 5.1. 実装書き換え可能なプログラム用フラッシュ メモリ ・・・ 10                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          |     | <b>15.5.</b> USI用レジスタ ・・・・・・・・・・ 77                         |
|     | 5.2. データ用SRAMメモリ · · · · · · · · · · · · · · · · · · ·                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        | 16. | アナログ比較器 ・・・・・・・・・・・・ 80                                     |
|     | 5.3. データ用EEPROMメモリ ・・・・・・・・ 11                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |     | 16.1. アナログ比較器入力選択 ・・・・・・80                                  |
|     | 5.4. I/Oメモリ (レジスタ) · · · · · · 13                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             |     | 16.2. アナログ比較器用レジスタ・・・・・・・80                                 |
|     | 5.5. メモリ関係レジスタ・・・・・・・・・・13                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    | 17  | A/D変換器 ······ 82                                            |
| 6   | システム クロックとクロック任意選択 ・・・・・・・・ 15                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                | 17. | 17.1. 特徵 · · · · · · 82                                     |
| υ.  | 6.1. クロック系統とその配給・・・・・・・・・・・15                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 |     | 17.2. 概要 ・・・・・・・・・・・・・・・82                                  |
|     | 6.2. クロック元 ····································                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               |     | 17.3. 操作83                                                  |
|     | 6.3. システム クロック前置分周器 ・・・・・・・20                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 |     | 17.4. 変換の開始 ・・・・・・・・・・・83                                   |
|     | 6.4. システム クロック出力緩衝部・・・・・・・・・・20                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               |     | 17.5. 前置分周と変換タイミング・・・・・・84                                  |
|     | 6.5. クロック関係レジスタ・・・・・・・・・・・・・・・・・・21                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           |     | 17.6. チャネル変更と基準電圧選択 ・・・・・・85                                |
| 7   | 電力管理と休止形態 ・・・・・・・・・・・ 23                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      |     | 17.7. 雑音低減機能                                                |
| 1.  | <b>1.1.</b> 休止形態種別 ····································                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       |     | 17.8. アナログ入力回路・・・・・・・・86                                    |
|     | 7.1. 休止が態性別 · · · · · · · · · · · · · · · · · · ·                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             |     | 17.9. アナログ雑音低減技術・・・・・・・86                                   |
|     | - contract to the contract to |     | 17.10. A/D変換の精度定義・・・・・・・87                                  |
|     | 7.3. 電力削減(電力削減レジスタ) 25<br>7.4. 消費電力の最小化 25                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    |     | 17.11. A/D変換の結果・・・・・・・・87                                   |
|     | 7.4. 消貨電力の最小化 ・・・・・・・・・・・ 25 25 7.5. 電力管理用レジスタ ・・・・・・・ 26                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     |     | 17.12. 温度測定                                                 |
| _   |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               |     | 17.13. A/D変換用レジスタ・・・・・・ 89                                  |
| 8.  | システム制御とリセット・・・・・・・・27                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         | 18  | <b>デバッグWIRE内蔵デバッグ機能 ・・・・・・・・</b> 92                         |
|     | 8.1. AVRのリセット ······· 27<br>8.2. リセット元 ····· 27                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               |     | 18.1. 特徴 92                                                 |
|     | 8.2. りを外元 · · · · · · · · · · · · · · · · · · ·                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               |     | 18.2. 概要92                                                  |
|     | 8.4. ウォッチト・ック・タイマ ······· 29                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  |     | 18.3. 物理インターフェース・・・・・・・・・・・・・・・・・・・・・・・・・92                 |
|     | 8.4. リオッチトック ダイマ・・・・・・・・・・29<br>8.5. リセット関係レジスタ・・・・・・・30                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      |     | 18.4. ソフトウェア中断点・・・・・・・・・・92                                 |
|     |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               |     | <b>18.5</b> . <b>デバッグWIREの制限 ・・・・・・・・・・・</b> 92             |
| 9.  | <b>割り込み ・・・・・・・・</b> 32                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       |     | <b>18.6. デバッグWIRE用レジスタ ・・・・・・・・・・</b> 92                    |
|     | 9.1. ATtiny25/45/85の割り込みベクタ ····· 32                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          | 19  | <b>フラッシュの自己プログラミング・・・・・・・</b> 93                            |
|     | 9.2. 外部割り込み 33                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                | 10. | 19.1. SPM命令によるページ消去の実行 ······ 93                            |
|     | 9.3. 外部割り込み用レジスタ・・・・・・ 33                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     |     | 19.2. ページー 時緩衝部の設定(ページ設定)・・・・・・93                           |
| 10. | 入出力ポート ······ 35                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              |     | 19.3. ページ書き込みの実行 ・・・・・・・・・・93                               |
|     | 10.1. 序説 35                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   |     | 19.4. 自己プログラミングでのフラッシュ アドレス指定 ・・・・・ 93                      |
|     | 10.2. 標準デッタル入出力としてのポート・・・・・・35                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |     | 19.5. SPM書き込み時のEEPROM書き込み妨害 · · 94                          |
|     | 10.3. 交換ポート機能 ・・・・・・・・・・ 38                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   |     | 19.6. ソフトウェアからの施錠,ヒューズと識票読み出し・・・ 94                         |
|     | 10.4. I/Oホート用レジスタ ・・・・・・・・・・・42                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               |     | 19.7. フラッシュ メモリ データ化けの防止・・・・・・・・95                          |
| 11. | 8ビット タイマ/カウンタO (PWM)・・・・・・・・ 43                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               |     | 19.8. SPM使用時のフラッシュ メモリ書き込み時間 ・・・・ 95                        |
|     | 11.1. 特徴 ・・・・・・・・・・・・・・・・・ 43                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 |     | 19.9. 自己プログラミング 用レジスタ ・・・・・・・96                             |
|     | 11.2. 概要 ・・・・・・・・・・・・・・・ 43                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   | 20  | メモリ プ <sup>°</sup> ロケ うこング ・・・・・・・・・・・・・・・・・・・・・・・・ 97      |
|     | 11.3. タイマ/カウンタ0の前置分周器とクロック元・・・・・・ 44                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          | 20. | <b>20.1</b> . プログラム メモリとデータ メモリ用施錠ビット・・・・・・・97              |
|     | 11.4. 計数器部 ・・・・・・・・・・・・・・ 45                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  |     | 20.2. ヒュース・ビット · · · · · · · · · · · · · · · · · · ·        |
|     |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               |     | JO                                                          |



|             | 20.3.  | デバイス識票銘刻部       99         ページ容量       99         低電圧直列プログラミング       100                                                                          |
|-------------|--------|---------------------------------------------------------------------------------------------------------------------------------------------------|
|             | 20.4.  | <b>^°−ジ容量・・・・・・・・・・・・・・・</b> 99                                                                                                                   |
|             | 20.5.  | 低電圧直列プログラミング ・・・・・・・・・ 100                                                                                                                        |
|             | 20.6.  | 高電圧直列プログラミング・・・・・・・103                                                                                                                            |
|             | 20.7.  | - 高雷圧直列プログラミング手順 ・・・・・・・・ 103                                                                                                                     |
| 21.         | 電気的    | 均特性・・・・・・・・・・・・・・・・・・・・・・・・・・・・・・・・・・・・                                                                                                           |
|             | 21.1.  | 絶対最大定格 ********* 108                                                                                                                              |
|             | 21.2.  | DC特性 · · · · · · · · · · · · · · · · · · 108                                                                                                      |
|             | 21.3.  | <b>速度 ······</b> 109                                                                                                                              |
|             | 21.4.  | <u> グロックを1年                                    </u>                                                                                               |
|             | 21.5.  | システムとリセットの特性・・・・・・・110                                                                                                                            |
|             | 21.6.  | 低電圧検出(BOD) · · · · · · 111                                                                                                                        |
|             | 21.7.  | システムとリセットの特性・・・・・・・・・・・・・・・・・・・・・・・・・・・・・・・・・・・・                                                                                                  |
|             | 21.8.  | 低電圧直列プログラミング 特性 ・・・・・・・・ 113                                                                                                                      |
|             | 21.9.  | 高電圧直列プログラミング特性 ・・・・・・・ 113                                                                                                                        |
| 22.         | 代表特    | 高電圧直列プログラミング特性 ・・・・・・・・ 113<br>寺性 ・・・・・・・・・・・・・・・・・・ 114<br>活動動作消費電流 ・・・・・・・・・・・・ 114<br>アイドル動作消費電流 ・・・・・・・・・・・・ 116<br>周辺機能部供給電流 ・・・・・・・・・・・ 117 |
|             | 22.1.  | 活動動作消費電流 ********** 114                                                                                                                           |
|             | 22.2.  | アイドル動作消費電流 ・・・・・・・・ 116                                                                                                                           |
|             | 22.3.  | 周辺機能部供給電流 ・・・・・・・・ 117                                                                                                                            |
|             | 22.4.  | パワーダウン動作消費電流       118         ピンプルアップ       118         ピン駆動能力       120         ピン 閾値とヒステリシス       123                                          |
|             | 22.5.  | <b>ピン プルアップ・・・・・・・・・・・・・・・・</b> 118                                                                                                               |
|             | 22.6.  | <b>ピン駆動能力 ・・・・・・</b> 120                                                                                                                          |
|             | 22.7.  | ピン 閾値とヒステリシス・・・・・・・ 123                                                                                                                           |
|             | 22.8.  | <b>低電圧検出器(BOD)閾値 ・・・・・・・・・</b> 125                                                                                                                |
|             | 22.9.  | 内部発振器周波数127周辺機能部消費電流129                                                                                                                           |
|             | 22.10. | 周辺機能部消費電流                                                                                                                                         |
|             | 22.11. | リセット消費電流とリセット パルス幅 ・・・・・・・ 131                                                                                                                    |
| 23.         | レジスタ   | <b>翠約・・・・・・・・・</b> 132                                                                                                                            |
| 24.         | 命令     | <b>要約 · · · · · · · · · · · · · · · · · · ·</b>                                                                                                   |
| <b>25</b> . | 注文的    | 青報・・・・・・・・・・・・・・・・・・ 135                                                                                                                          |
| 26.         | 外用     | 器情報 ••••• 137                                                                                                                                     |
| 27.         | 陪宝的    | 周辺機能部消貨電流 ・・・・・・・・・・・・・・・・・・・・・・・・・・・・・・・・・・・・                                                                                                    |
|             |        | /─ト改訂履歴 ······ 140                                                                                                                                |
| 28.         | ナ ーダン  | / <b></b> 140                                                                                                                                     |





# Enabling Unlimited Possibilities®

# Atmel Corporation

1600 Technology Drive San Jose, CA 95110 USA

TEL (+1)(408) 441-0311 FAX (+1)(408) 487-2600

www.atmel.com

#### Atmel Asia Limited

Unit 01-5 & 16, 19F BEA Tower, Millennium City 5 418 Kwun Tong Road Kwun Tong, Kowloon HONG KONG

TEL (+852) 2245-6100 FAX (+852) 2722-1369

## Atmel Munich GmbH

Business Campus Parking 4 D-85748 Garching b. Munich GERMANY TEL (+49) 89-31970-0 FAX (+49) 89-3194621

# Atmel Japan G.K.

141-0032 東京都品川区 大崎1-6-4 新大崎勧業ビル 16F アトメル ジャハン合同会社 TEL (+81)(3)-6417-0300 FAX (+81)(3)-6417-0370

#### © 2013 Atmel Corporation. 不許複製 / 改訂:2586Q-AVR-08/2013

Atmel®、Atmelロゴとそれらの組み合わせ、Enabling Unlimited Possibilities®、AVR®、tinyAVR®とその他はAtmel Corporationの登録商標または商標またはその付属物です。他の用語と製品名は一般的に他の商標です。

お断り:本資料内の情報はAtmel製品と関連して提供されています。本資料またはAtmel製品の販売と関連して承諾される何れの知的所有権も禁反言あるいはその逆によって明示的または暗示的に承諾されるものではありません。Atmelのウェブサイに位置する販売の条件とAtmelの定義での詳しい説明を除いて、商品性、特定目的に関する適合性、または適法性の暗黙保証に制限せず、Atmelはそれらを含むその製品に関連する暗示的、明示的または法令による如何なる保証も否認し、何ら責任がないと認識します。たとえるtmelがそのような損害賠償の可能性を進言されたとしても、本資料を使用できない、または使用以外で発生する(情報の損失、事業中断、または利益と損失に関する制限なしの損害賠償を含み)直接、間接、必然、偶然、特別、または付随して起こる如何なる損害賠償に対しても決してAtmelに責任がないでしょう。Atmelは本資料の内容の正確さまたは完全性に関して断言または保証を行わず、予告なしでいつでも製品内容と仕様の変更を行う権利を保留します。Atmelはここに含まれた情報を更新することに対してどんな公約も行いません。特に別の方法で提供されなければ、Atmel製品は車載応用に対して適当ではなく、使用されるべきではありません。Atmel製品は延命または生命維持を意図した応用での部品としての使用に対して意図、認定、または保証されません。

#### © HERO 2019.

本データシートはAtmelのATtiny25/45/85英語版データシート(改訂2586Q-08/2013)の翻訳日本語版です。日本語では不自然となる重複する形容表現は省略されている場合があります。日本語では難解となる表現は大幅に意訳されている部分もあります。必要に応じて一部加筆されています。頁割の変更により、原本より頁数が少なくなっています。

汎用入出力ポートの出力データレジスタとピン入力は、対応関係からの理解の容易さから出力レジスタと入力レジスタで統一表現されています。一部の用語がより適切と思われる名称に変更されています。必要と思われる部分には()内に英語表記や略称などを残す形で表記しています。

青字の部分はリンクとなっています。一般的に<mark>赤字の0,1</mark>は論理0,1を表します。その他の<mark>赤字</mark>は重要な部分を表します。 原書に対して若干構成が異なるため、一部の節/項番号が異なります。